| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  | {% extends 'generic/_base.html' %} | 
					
						
							| 
									
										
										
										
											2019-09-05 17:23:56 -04:00
										 |  |  | {% load helpers %} | 
					
						
							|  |  |  | {% load form_helpers %} | 
					
						
							| 
									
										
										
										
											2023-07-29 03:30:25 +07:00
										 |  |  | {% load i18n %} | 
					
						
							| 
									
										
										
										
											2019-09-05 17:23:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-08 11:23:52 -05:00
										 |  |  | {% comment %} | 
					
						
							|  |  |  | Context: | 
					
						
							|  |  |  |   model: The model class being imported | 
					
						
							|  |  |  |   form: The bulk import form | 
					
						
							|  |  |  |   fields: A dictionary of form fields, to display import options (optional) | 
					
						
							|  |  |  |   return_url: The URL to which the user is redirected after submitting the form | 
					
						
							|  |  |  | {% endcomment %} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-29 03:30:25 +07:00
										 |  |  | {% block title %}{{ model|meta:"verbose_name"|bettertitle }} {% trans "Bulk Import" %}{% endblock %} | 
					
						
							| 
									
										
										
										
											2021-04-18 11:35:42 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-21 09:24:43 -04:00
										 |  |  | {% block tabs %} | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |   <ul class="nav nav-tabs"> | 
					
						
							| 
									
										
										
										
											2021-07-21 09:24:43 -04:00
										 |  |  |     <li class="nav-item" role="presentation"> | 
					
						
							| 
									
										
										
										
											2023-04-12 17:38:16 -04:00
										 |  |  |       <button class="nav-link active" id="import-form-tab" data-bs-toggle="tab" data-bs-target="#import-form" data-href="#tab_import-form" type="button" role="tab" aria-controls="import-form" aria-selected="true"> | 
					
						
							| 
									
										
										
										
											2023-07-29 03:30:25 +07:00
										 |  |  |         {% trans "Direct Import" %} | 
					
						
							| 
									
										
										
										
											2022-11-10 08:01:52 -08:00
										 |  |  |       </button> | 
					
						
							|  |  |  |     </li> | 
					
						
							|  |  |  |     <li class="nav-item" role="presentation"> | 
					
						
							| 
									
										
										
										
											2023-04-12 17:38:16 -04:00
										 |  |  |       <button class="nav-link" id="upload-form-tab" data-bs-toggle="tab" data-bs-target="#upload-form" data-href="#tab_upload-form" type="button" role="tab" aria-controls="upload-form" aria-selected="false"> | 
					
						
							| 
									
										
										
										
											2023-07-29 03:30:25 +07:00
										 |  |  |         {% trans "Upload File" %} | 
					
						
							| 
									
										
										
										
											2022-11-10 08:01:52 -08:00
										 |  |  |       </button> | 
					
						
							| 
									
										
										
										
											2021-07-21 09:24:43 -04:00
										 |  |  |     </li> | 
					
						
							| 
									
										
										
										
											2023-03-14 14:53:26 -04:00
										 |  |  |     <li class="nav-item" role="presentation"> | 
					
						
							| 
									
										
										
										
											2023-04-12 17:38:16 -04:00
										 |  |  |       <button class="nav-link" id="datafile-form-tab" data-bs-toggle="tab" data-bs-target="#datafile-form" data-href="#tab_datafile-form" type="button" role="tab" aria-controls="datafile-form" aria-selected="false"> | 
					
						
							| 
									
										
										
										
											2023-07-29 03:30:25 +07:00
										 |  |  |         {% trans "Data File" %} | 
					
						
							| 
									
										
										
										
											2023-03-14 14:53:26 -04:00
										 |  |  |       </button> | 
					
						
							|  |  |  |     </li> | 
					
						
							| 
									
										
										
										
											2021-07-21 09:24:43 -04:00
										 |  |  |   </ul> | 
					
						
							| 
									
										
										
										
											2022-02-08 11:23:52 -05:00
										 |  |  | {% endblock tabs %} | 
					
						
							| 
									
										
										
										
											2021-07-21 09:24:43 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  | {% block content %} | 
					
						
							| 
									
										
										
										
											2022-11-10 08:01:52 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |   {# Data Import Form #} | 
					
						
							|  |  |  |   <div class="tab-pane show active" id="import-form" role="tabpanel" aria-labelledby="import-form-tab"> | 
					
						
							|  |  |  |     <div class="row"> | 
					
						
							| 
									
										
										
										
											2023-03-14 14:53:26 -04:00
										 |  |  |       <div class="col col-md-12 col-lg-10 offset-lg-1"> | 
					
						
							|  |  |  |         <form action="" method="post" enctype="multipart/form-data" class="form"> | 
					
						
							|  |  |  |           {% csrf_token %} | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |           <input type="hidden" name="import_method" value="direct" /> | 
					
						
							|  |  |  |           {% render_field form.data %} | 
					
						
							| 
									
										
										
										
											2023-03-14 14:53:26 -04:00
										 |  |  |           {% render_field form.format %} | 
					
						
							| 
									
										
										
										
											2023-10-02 12:07:28 -07:00
										 |  |  |           {% render_field form.csv_delimiter %} | 
					
						
							| 
									
										
										
										
											2023-03-14 14:53:26 -04:00
										 |  |  |           <div class="form-group"> | 
					
						
							|  |  |  |             <div class="col col-md-12 text-end"> | 
					
						
							|  |  |  |               {% if return_url %} | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |                 <a href="{{ return_url }}" class="btn btn-outline-secondary">{% trans "Cancel" %}</a> | 
					
						
							| 
									
										
										
										
											2023-03-14 14:53:26 -04:00
										 |  |  |               {% endif %} | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |               <button type="submit" name="data_submit" class="btn btn-primary">{% trans "Submit" %}</button> | 
					
						
							| 
									
										
										
										
											2023-03-14 14:53:26 -04:00
										 |  |  |             </div> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |         </form> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |   </div> | 
					
						
							| 
									
										
										
										
											2023-03-14 14:53:26 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |   {# File Upload Form #} | 
					
						
							|  |  |  |   <div class="tab-pane show" id="upload-form" role="tabpanel" aria-labelledby="upload-form-tab"> | 
					
						
							|  |  |  |     <div class="col col-md-12 col-lg-10 offset-lg-1"> | 
					
						
							|  |  |  |       <form action="" method="post" enctype="multipart/form-data" class="form"> | 
					
						
							|  |  |  |         {% csrf_token %} | 
					
						
							|  |  |  |         <input type="hidden" name="import_method" value="upload" /> | 
					
						
							|  |  |  |         {% render_field form.upload_file %} | 
					
						
							|  |  |  |         {% render_field form.format %} | 
					
						
							|  |  |  |         {% render_field form.csv_delimiter %} | 
					
						
							|  |  |  |         <div class="form-group"> | 
					
						
							|  |  |  |           <div class="col col-md-12 text-end"> | 
					
						
							|  |  |  |             {% if return_url %} | 
					
						
							|  |  |  |               <a href="{{ return_url }}" class="btn btn-outline-secondary">{% trans "Cancel" %}</a> | 
					
						
							|  |  |  |             {% endif %} | 
					
						
							|  |  |  |             <button type="submit" name="file_submit" class="btn btn-primary">{% trans "Submit" %}</button> | 
					
						
							| 
									
										
										
										
											2023-03-14 14:53:26 -04:00
										 |  |  |           </div> | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |         </div> | 
					
						
							|  |  |  |       </form> | 
					
						
							| 
									
										
										
										
											2022-11-10 08:01:52 -08:00
										 |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |   </div> | 
					
						
							| 
									
										
										
										
											2022-11-10 08:01:52 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |   {# DataFile Form #} | 
					
						
							|  |  |  |   <div class="tab-pane show" id="datafile-form" role="tabpanel" aria-labelledby="datafile-form-tab"> | 
					
						
							|  |  |  |     <div class="col col-md-12 col-lg-10 offset-lg-1"> | 
					
						
							|  |  |  |       <form action="" method="post" enctype="multipart/form-data" class="form"> | 
					
						
							|  |  |  |         {% csrf_token %} | 
					
						
							|  |  |  |         <input type="hidden" name="import_method" value="datafile" /> | 
					
						
							|  |  |  |         {% render_field form.data_source %} | 
					
						
							|  |  |  |         {% render_field form.data_file %} | 
					
						
							|  |  |  |         {% render_field form.format %} | 
					
						
							|  |  |  |         {% render_field form.csv_delimiter %} | 
					
						
							|  |  |  |         <div class="form-group"> | 
					
						
							|  |  |  |           <div class="col col-md-12 text-end"> | 
					
						
							|  |  |  |             {% if return_url %} | 
					
						
							|  |  |  |               <a href="{{ return_url }}" class="btn btn-outline-secondary">{% trans "Cancel" %}</a> | 
					
						
							|  |  |  |             {% endif %} | 
					
						
							|  |  |  |             <button type="submit" name="file_submit" class="btn btn-primary">{% trans "Submit" %}</button> | 
					
						
							|  |  |  |           </div> | 
					
						
							| 
									
										
										
										
											2020-05-01 14:26:04 -04:00
										 |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |       </form> | 
					
						
							| 
									
										
										
										
											2022-11-10 08:01:52 -08:00
										 |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |   </div> | 
					
						
							| 
									
										
										
										
											2022-11-10 08:01:52 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |   {% if fields %} | 
					
						
							|  |  |  |   <div class="row my-3"> | 
					
						
							|  |  |  |       <div class="col col-md-12"> | 
					
						
							|  |  |  |           <div class="card"> | 
					
						
							|  |  |  |               <h5 class="card-header">{% trans "Field Options" %}</h5> | 
					
						
							|  |  |  |               <table class="table"> | 
					
						
							|  |  |  |                   <tr> | 
					
						
							|  |  |  |                       <th>{% trans "Field" %}</th> | 
					
						
							|  |  |  |                       <th>{% trans "Required" %}</th> | 
					
						
							|  |  |  |                       <th>{% trans "Accessor" %}</th> | 
					
						
							|  |  |  |                       <th>{% trans "Description" %}</th> | 
					
						
							|  |  |  |                   </tr> | 
					
						
							|  |  |  |                   {% for name, field in fields.items %} | 
					
						
							|  |  |  |                       <tr> | 
					
						
							|  |  |  |                           <td> | 
					
						
							|  |  |  |                               <code>{% if field.required %}<strong>{% endif %}{{ name }}{% if field.required %}</strong>{% endif %}</code> | 
					
						
							|  |  |  |                           </td> | 
					
						
							|  |  |  |                           <td> | 
					
						
							|  |  |  |                               {% if field.required %} | 
					
						
							|  |  |  |                                   {% checkmark True true="Required" %} | 
					
						
							|  |  |  |                               {% else %} | 
					
						
							|  |  |  |                                   {{ ''|placeholder }} | 
					
						
							|  |  |  |                               {% endif %} | 
					
						
							|  |  |  |                           </td> | 
					
						
							|  |  |  |                           <td> | 
					
						
							|  |  |  |                               {% if field.to_field_name %} | 
					
						
							|  |  |  |                                   <code>{{ field.to_field_name }}</code> | 
					
						
							|  |  |  |                               {% else %} | 
					
						
							|  |  |  |                                   {{ ''|placeholder }} | 
					
						
							|  |  |  |                               {% endif %} | 
					
						
							|  |  |  |                           </td> | 
					
						
							|  |  |  |                           <td> | 
					
						
							|  |  |  |                               {% if field.STATIC_CHOICES %} | 
					
						
							|  |  |  |                                   <button type="button" class="btn btn-link float-end" data-bs-toggle="modal" data-bs-target="#{{ name }}_choices"> | 
					
						
							|  |  |  |                                       <i class="mdi mdi-help-circle"></i> | 
					
						
							|  |  |  |                                   </button> | 
					
						
							|  |  |  |                                   <div class="modal fade" id="{{ name }}_choices" tabindex="-1" role="dialog"> | 
					
						
							|  |  |  |                                       <div class="modal-dialog" role="document"> | 
					
						
							|  |  |  |                                           <div class="modal-content"> | 
					
						
							|  |  |  |                                               <div class="modal-header"> | 
					
						
							|  |  |  |                                                   <h5 class="modal-title"><code>{{ name }}</code> {% trans "Choices" %}</h5> | 
					
						
							|  |  |  |                                                   <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button> | 
					
						
							|  |  |  |                                               </div> | 
					
						
							|  |  |  |                                               <div class="modal-body"> | 
					
						
							|  |  |  |                                                   <table class="table table-striped"> | 
					
						
							|  |  |  |                                                       <tr> | 
					
						
							|  |  |  |                                                           <th>{% trans "Import Value" %}</th> | 
					
						
							|  |  |  |                                                           <th>{% trans "Label" %}</th> | 
					
						
							|  |  |  |                                                       </tr> | 
					
						
							|  |  |  |                                                       {% for value, label in field.choices %} | 
					
						
							|  |  |  |                                                       {% if value %} | 
					
						
							|  |  |  |                                                       <tr> | 
					
						
							|  |  |  |                                                           <td> | 
					
						
							|  |  |  |                                                               <samp>{{ value }}</samp> | 
					
						
							|  |  |  |                                                           </td> | 
					
						
							|  |  |  |                                                           <td> | 
					
						
							|  |  |  |                                                               {{ label }} | 
					
						
							|  |  |  |                                                           </td> | 
					
						
							|  |  |  |                                                       </tr> | 
					
						
							|  |  |  |                                                       {% endif %} | 
					
						
							|  |  |  |                                                       {% endfor %} | 
					
						
							|  |  |  |                                                   </table> | 
					
						
							|  |  |  |                                               </div> | 
					
						
							|  |  |  |                                           </div> | 
					
						
							|  |  |  |                                       </div> | 
					
						
							|  |  |  |                                   </div> | 
					
						
							|  |  |  |                               {% endif %} | 
					
						
							|  |  |  |                               {% if field.help_text %} | 
					
						
							|  |  |  |                                   {{ field.help_text }}<br /> | 
					
						
							|  |  |  |                               {% elif field.label %} | 
					
						
							|  |  |  |                                   {{ field.label }}<br /> | 
					
						
							|  |  |  |                               {% endif %} | 
					
						
							|  |  |  |                               {% if field|widget_type == 'dateinput' %} | 
					
						
							|  |  |  |                                   <small class="text-muted">{% trans "Format: YYYY-MM-DD" %}</small> | 
					
						
							|  |  |  |                               {% elif field|widget_type == 'checkboxinput' %} | 
					
						
							|  |  |  |                                   <small class="text-muted">{% trans "Specify true or false" %}</small> | 
					
						
							|  |  |  |                               {% endif %} | 
					
						
							|  |  |  |                           </td> | 
					
						
							|  |  |  |                       </tr> | 
					
						
							|  |  |  |                   {% endfor %} | 
					
						
							|  |  |  |               </table> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2021-07-21 09:24:43 -04:00
										 |  |  |   </div> | 
					
						
							| 
									
										
										
										
											2024-01-17 16:25:42 -05:00
										 |  |  |   <p class="small text-muted"> | 
					
						
							|  |  |  |     <i class="mdi mdi-check-bold text-success"></i> | 
					
						
							|  |  |  |     {% blocktrans trimmed %} | 
					
						
							|  |  |  |       Required fields <strong>must</strong> be specified for all objects. | 
					
						
							|  |  |  |     {% endblocktrans %} | 
					
						
							|  |  |  |   </p> | 
					
						
							|  |  |  |   <p class="small text-muted"> | 
					
						
							|  |  |  |     <i class="mdi mdi-information-outline"></i> | 
					
						
							|  |  |  |     {% blocktrans trimmed with example="vrf.rd" %} | 
					
						
							|  |  |  |       Related objects may be referenced by any unique attribute. For example, <code>{{ example }}</code> would identify a VRF by its route distinguisher. | 
					
						
							|  |  |  |     {% endblocktrans %} | 
					
						
							|  |  |  |   </p> | 
					
						
							|  |  |  |   {% endif %} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | {% endblock content %} |