site.html 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. {% extends 'generic/object.html' %}
  2. {% load helpers %}
  3. {% load plugins %}
  4. {% load tz %}
  5. {% load i18n %}
  6. {% block breadcrumbs %}
  7. {{ block.super }}
  8. {% if object.region %}
  9. {% for region in object.region.get_ancestors %}
  10. <li class="breadcrumb-item"><a href="{% url 'dcim:site_list' %}?region_id={{ region.pk }}">{{ region }}</a></li>
  11. {% endfor %}
  12. <li class="breadcrumb-item"><a href="{% url 'dcim:site_list' %}?region_id={{ object.region.pk }}">{{ object.region }}</a></li>
  13. {% elif object.group %}
  14. {% for group in object.group.get_ancestors %}
  15. <li class="breadcrumb-item"><a href="{% url 'dcim:site_list' %}?group_id={{ group.pk }}">{{ group }}</a></li>
  16. {% endfor %}
  17. <li class="breadcrumb-item"><a href="{% url 'dcim:site_list' %}?group_id={{ object.group.pk }}">{{ object.group }}</a></li>
  18. {% endif %}
  19. {% endblock %}
  20. {% block content %}
  21. <div class="row">
  22. <div class="col col-md-6">
  23. <div class="card">
  24. <h5 class="card-header">{% trans "Site" %}</h5>
  25. <div class="card-body">
  26. <table class="table table-hover attr-table">
  27. <tr>
  28. <th scope="row">{% trans "Region" %}</th>
  29. <td>
  30. {% if object.region %}
  31. {% for region in object.region.get_ancestors %}
  32. {{ region|linkify }} /
  33. {% endfor %}
  34. {{ object.region|linkify }}
  35. {% else %}
  36. {{ ''|placeholder }}
  37. {% endif %}
  38. </td>
  39. </tr>
  40. <tr>
  41. <th scope="row">{% trans "Group" %}</th>
  42. <td>
  43. {% if object.group %}
  44. {% for group in object.group.get_ancestors %}
  45. {{ group|linkify }} /
  46. {% endfor %}
  47. {{ object.group|linkify }}
  48. {% else %}
  49. {{ ''|placeholder }}
  50. {% endif %}
  51. </td>
  52. </tr>
  53. <tr>
  54. <th scope="row">{% trans "Status" %}</th>
  55. <td>{% badge object.get_status_display bg_color=object.get_status_color %}</td>
  56. </tr>
  57. <tr>
  58. <th scope="row">{% trans "Tenant" %}</th>
  59. <td>
  60. {% if object.tenant.group %}
  61. {{ object.tenant.group|linkify }} /
  62. {% endif %}
  63. {{ object.tenant|linkify|placeholder }}
  64. </td>
  65. </tr>
  66. <tr>
  67. <th scope="row">{% trans "Facility" %}</th>
  68. <td>{{ object.facility|placeholder }}</td>
  69. </tr>
  70. <tr>
  71. <th scope="row">{% trans "Description" %}</th>
  72. <td>{{ object.description|placeholder }}</td>
  73. </tr>
  74. <tr>
  75. <th scope="row">{% trans "Time Zone" %}</th>
  76. <td>
  77. {% if object.time_zone %}
  78. {{ object.time_zone }} ({% trans "UTC" %} {{ object.time_zone|tzoffset }})<br />
  79. <small class="text-muted">{% trans "Site time" %}: {% timezone object.time_zone %}{% annotated_now %}{% endtimezone %}</small>
  80. {% else %}
  81. {{ ''|placeholder }}
  82. {% endif %}
  83. </td>
  84. </tr>
  85. <tr>
  86. <th scope="row">{% trans "Physical Address" %}</th>
  87. <td class="position-relative">
  88. {% if object.physical_address %}
  89. {% if config.MAPS_URL %}
  90. <div class="position-absolute top-50 end-0 translate-middle-y noprint">
  91. <a href="{{ config.MAPS_URL }}{{ object.physical_address|urlencode }}" target="_blank" class="btn btn-primary btn-sm">
  92. <i class="mdi mdi-map-marker"></i> {% trans "Map" %}
  93. </a>
  94. </div>
  95. {% endif %}
  96. <span>{{ object.physical_address|linebreaksbr }}</span>
  97. {% else %}
  98. {{ ''|placeholder }}
  99. {% endif %}
  100. </td>
  101. </tr>
  102. <tr>
  103. <th scope="row">{% trans "Shipping Address" %}</th>
  104. <td>{{ object.shipping_address|linebreaksbr|placeholder }}</td>
  105. </tr>
  106. <tr>
  107. <th scope="row">{% trans "GPS Coordinates" %}</th>
  108. <td class="position-relative">
  109. {% if object.latitude and object.longitude %}
  110. {% if config.MAPS_URL %}
  111. <div class="position-absolute top-50 end-0 translate-middle-y noprint">
  112. <a href="{{ config.MAPS_URL }}{{ object.latitude }},{{ object.longitude }}" target="_blank" class="btn btn-primary btn-sm">
  113. <i class="mdi mdi-map-marker"></i> {% trans "Map It" %}
  114. </a>
  115. </div>
  116. {% endif %}
  117. <span>{{ object.latitude }}, {{ object.longitude }}</span>
  118. {% else %}
  119. {{ ''|placeholder }}
  120. {% endif %}
  121. </td>
  122. </tr>
  123. </table>
  124. </div>
  125. </div>
  126. {% include 'inc/panels/custom_fields.html' %}
  127. {% include 'inc/panels/tags.html' %}
  128. {% include 'inc/panels/comments.html' %}
  129. {% plugin_left_page object %}
  130. </div>
  131. <div class="col col-md-6">
  132. {% include 'inc/panels/related_objects.html' with filter_name='site_id' %}
  133. {% include 'inc/panels/image_attachments.html' %}
  134. {% plugin_right_page object %}
  135. </div>
  136. </div>
  137. <div class="row">
  138. <div class="col col-md-12">
  139. <div class="card">
  140. <h5 class="card-header">Locations</h5>
  141. <div class="card-body htmx-container table-responsive"
  142. hx-get="{% url 'dcim:location_list' %}?site_id={{ object.pk }}"
  143. hx-trigger="load"
  144. ></div>
  145. {% if perms.dcim.add_location %}
  146. <div class="card-footer text-end noprint">
  147. <a href="{% url 'dcim:location_add' %}?site={{ object.pk }}&return_url={{ object.get_absolute_url }}" class="btn btn-primary btn-sm">
  148. <i class="mdi mdi-plus-thick" aria-hidden="true"></i> {% trans "Add a Location" %}
  149. </a>
  150. </div>
  151. {% endif %}
  152. </div>
  153. <div class="card">
  154. <h5 class="card-header">Non-Racked Devices</h5>
  155. <div class="card-body htmx-container table-responsive"
  156. hx-get="{% url 'dcim:device_list' %}?site_id={{ object.pk }}&rack_id=null&parent_bay_id=null"
  157. hx-trigger="load"
  158. ></div>
  159. {% if perms.dcim.add_device %}
  160. <div class="card-footer text-end noprint">
  161. <a href="{% url 'dcim:device_add' %}?site={{ object.pk }}&return_url={{ object.get_absolute_url }}" class="btn btn-primary btn-sm">
  162. <i class="mdi mdi-plus-thick" aria-hidden="true"></i> {% trans "Add a Device" %}
  163. </a>
  164. </div>
  165. {% endif %}
  166. </div>
  167. {% plugin_full_width_page object %}
  168. </div>
  169. </div>
  170. {% endblock %}