rack.html 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. {% extends '_base.html' %}
  2. {% load helpers %}
  3. {% load render_table from django_tables2 %}
  4. {% block title %}{{ rack.site }} - Rack {{ rack.name }}{% endblock %}
  5. {% block content %}
  6. <div class="row">
  7. <div class="col-sm-8 col-md-9">
  8. <ol class="breadcrumb">
  9. <li><a href="{% url 'dcim:rack_list' %}">Racks</a></li>
  10. <li><a href="{% url 'dcim:rack_list' %}?site={{ rack.site.slug }}">{{ rack.site }}</a></li>
  11. <li>{{ rack }}</li>
  12. </ol>
  13. </div>
  14. <div class="col-sm-4 col-md-3">
  15. <form action="{% url 'dcim:rack_list' %}" method="get">
  16. <div class="input-group">
  17. <input type="text" name="q" class="form-control" placeholder="Search racks" />
  18. <span class="input-group-btn">
  19. <button type="submit" class="btn btn-primary">
  20. <span class="fa fa-search" aria-hidden="true"></span>
  21. </button>
  22. </span>
  23. </div>
  24. </form>
  25. </div>
  26. </div>
  27. <div class="pull-right">
  28. {% if prev_rack %}
  29. <a href="{% url 'dcim:rack' pk=prev_rack.pk %}" class="btn btn-primary">
  30. <span class="fa fa-chevron-left" aria-hidden="true"></span>
  31. Previous Rack
  32. </a>
  33. {% endif %}
  34. {% if next_rack %}
  35. <a href="{% url 'dcim:rack' pk=next_rack.pk %}" class="btn btn-primary">
  36. <span class="fa fa-chevron-right" aria-hidden="true"></span>
  37. Next Rack
  38. </a>
  39. {% endif %}
  40. {% if perms.dcim.change_rack %}
  41. <a href="{% url 'dcim:rack_edit' pk=rack.pk %}" class="btn btn-warning">
  42. <span class="fa fa-pencil" aria-hidden="true"></span>
  43. Edit this rack
  44. </a>
  45. {% endif %}
  46. {% if perms.dcim.delete_rack %}
  47. <a href="{% url 'dcim:rack_delete' pk=rack.pk %}" class="btn btn-danger">
  48. <span class="fa fa-trash" aria-hidden="true"></span>
  49. Delete this rack
  50. </a>
  51. {% endif %}
  52. </div>
  53. <h1>Rack {{ rack.name }}</h1>
  54. {% include 'inc/created_updated.html' with obj=rack %}
  55. <div class="row">
  56. <div class="col-md-6">
  57. <div class="panel panel-default">
  58. <div class="panel-heading">
  59. <strong>Rack</strong>
  60. </div>
  61. <table class="table table-hover panel-body attr-table">
  62. <tr>
  63. <td>Site</td>
  64. <td>
  65. {% if rack.site.region %}
  66. <a href="{{ rack.site.region.get_absolute_url }}">{{ rack.site.region }}</a>
  67. <i class="fa fa-angle-right"></i>
  68. {% endif %}
  69. <a href="{% url 'dcim:site' slug=rack.site.slug %}">{{ rack.site }}</a>
  70. </td>
  71. </tr>
  72. <tr>
  73. <td>Group</td>
  74. <td>
  75. {% if rack.group %}
  76. <a href="{% url 'dcim:rack_list' %}?site={{ rack.site.slug }}&group={{ rack.group.slug }}">{{ rack.group.name }}</a>
  77. {% else %}
  78. <span class="text-muted">None</span>
  79. {% endif %}
  80. </td>
  81. </tr>
  82. <tr>
  83. <td>Facility ID</td>
  84. <td>
  85. {% if rack.facility_id %}
  86. <span>{{ rack.facility_id }}</span>
  87. {% else %}
  88. <span class="text-muted">N/A</span>
  89. {% endif %}
  90. </td>
  91. </tr>
  92. <tr>
  93. <td>Tenant</td>
  94. <td>
  95. {% if rack.tenant %}
  96. {% if rack.tenant.group %}
  97. <a href="{{ rack.tenant.group.get_absolute_url }}">{{ rack.tenant.group.name }}</a>
  98. <i class="fa fa-angle-right"></i>
  99. {% endif %}
  100. <a href="{{ rack.tenant.get_absolute_url }}">{{ rack.tenant }}</a>
  101. {% else %}
  102. <span class="text-muted">None</span>
  103. {% endif %}
  104. </td>
  105. </tr>
  106. <tr>
  107. <td>Role</td>
  108. <td>
  109. {% if rack.role %}
  110. <a href="{{ rack.role.get_absolute_url }}">{{ rack.role }}</a>
  111. {% else %}
  112. <span class="text-muted">None</span>
  113. {% endif %}
  114. </td>
  115. </tr>
  116. <tr>
  117. <td>Type</td>
  118. <td>
  119. {% if rack.type %}
  120. {{ rack.get_type_display }}
  121. {% else %}
  122. <span class="text-muted">None</span>
  123. {% endif %}
  124. </td>
  125. </tr>
  126. <tr>
  127. <td>Width</td>
  128. <td>{{ rack.get_width_display }}</td>
  129. </tr>
  130. <tr>
  131. <td>Height</td>
  132. <td>{{ rack.u_height }}U ({% if rack.desc_units %}descending{% else %}ascending{% endif %})</td>
  133. </tr>
  134. <tr>
  135. <td>Devices</td>
  136. <td>
  137. <a href="{% url 'dcim:device_list' %}?rack_id={{ rack.id }}">{{ rack.devices.count }}</a>
  138. </td>
  139. </tr>
  140. </table>
  141. </div>
  142. {% with rack.get_custom_fields as custom_fields %}
  143. {% include 'inc/custom_fields_panel.html' %}
  144. {% endwith %}
  145. <div class="panel panel-default">
  146. <div class="panel-heading">
  147. <strong>Non-Racked Devices</strong>
  148. </div>
  149. {% if nonracked_devices %}
  150. <table class="table table-hover panel-body">
  151. <tr>
  152. <th>Name</th>
  153. <th>Role</th>
  154. <th>Type</th>
  155. <th>Parent</th>
  156. </tr>
  157. {% for device in nonracked_devices %}
  158. <tr{% if device.device_type.u_height %} class="warning"{% endif %}>
  159. <td>
  160. <a href="{% url 'dcim:device' pk=device.pk %}">{{ device.name }}</a>
  161. </td>
  162. <td>{{ device.device_role }}</td>
  163. <td>{{ device.device_type.full_name }}</td>
  164. <td>
  165. {% if device.parent_bay %}
  166. <a href="{{ device.parent_bay.device.get_absolute_url }}">{{ device.parent_bay }}</a>
  167. {% else %}
  168. <span class="text-muted">N/A</span>
  169. {% endif %}
  170. </td>
  171. </tr>
  172. {% endfor %}
  173. </table>
  174. {% else %}
  175. <div class="panel-body text-muted">None</div>
  176. {% endif %}
  177. {% if perms.dcim.add_device %}
  178. <div class="panel-footer text-right">
  179. <a href="{% url 'dcim:device_add' %}?site={{ rack.site.pk }}&rack={{ rack.pk }}" class="btn btn-primary btn-xs">
  180. <span class="glyphicon glyphicon-plus" aria-hidden="true"></span>
  181. Add a non-racked device
  182. </a>
  183. </div>
  184. {% endif %}
  185. </div>
  186. <div class="panel panel-default">
  187. <div class="panel-heading">
  188. <strong>Comments</strong>
  189. </div>
  190. <div class="panel-body">
  191. {% if rack.comments %}
  192. {{ rack.comments|gfm }}
  193. {% else %}
  194. <span class="text-muted">None</span>
  195. {% endif %}
  196. </div>
  197. </div>
  198. <div class="panel panel-default">
  199. <div class="panel-heading">
  200. <strong>Reservations</strong>
  201. </div>
  202. {% if reservations %}
  203. <table class="table table-hover panel-body">
  204. <tr>
  205. <th>Units</th>
  206. <th>Description</th>
  207. <th></th>
  208. </tr>
  209. {% for resv in reservations %}
  210. <tr>
  211. <td>{{ resv.units|join:', ' }}</td>
  212. <td>
  213. {{ resv.description }}<br />
  214. <small>{{ resv.user }} &middot; {{ resv.created }}</small>
  215. </td>
  216. <td class="text-right">
  217. {% if perms.dcim.change_rackreservation %}
  218. <a href="{% url 'dcim:rackreservation_edit' pk=resv.pk %}" class="btn btn-warning btn-xs" title="Edit reservation">
  219. <i class="glyphicon glyphicon-pencil" aria-hidden="true"></i>
  220. </a>
  221. {% endif %}
  222. {% if perms.dcim.delete_rackreservation %}
  223. <a href="{% url 'dcim:rackreservation_delete' pk=resv.pk %}" class="btn btn-danger btn-xs" title="Delete reservation">
  224. <i class="glyphicon glyphicon-trash" aria-hidden="true"></i>
  225. </a>
  226. {% endif %}
  227. </td>
  228. </tr>
  229. {% endfor %}
  230. </table>
  231. {% else %}
  232. <div class="panel-body text-muted">None</div>
  233. {% endif %}
  234. {% if perms.dcim.add_rackreservation %}
  235. <div class="panel-footer text-right">
  236. <a href="{% url 'dcim:rack_add_reservation' rack=rack.pk %}" class="btn btn-primary btn-xs">
  237. <span class="glyphicon glyphicon-plus" aria-hidden="true"></span>
  238. Add a reservation
  239. </a>
  240. </div>
  241. {% endif %}
  242. </div>
  243. </div>
  244. <div class="row col-md-6">
  245. <div class="col-md-6 col-sm-6 col-xs-12">
  246. <div class="rack_header">
  247. <h4>Front</h4>
  248. </div>
  249. {% include 'dcim/inc/rack_elevation.html' with primary_face=front_elevation secondary_face=rear_elevation face_id=0 %}
  250. </div>
  251. <div class="col-md-6 col-sm-6 col-xs-12">
  252. <div class="rack_header">
  253. <h4>Rear</h4>
  254. </div>
  255. {% include 'dcim/inc/rack_elevation.html' with primary_face=rear_elevation secondary_face=front_elevation face_id=1 %}
  256. </div>
  257. </div>
  258. </div>
  259. {% endblock %}
  260. {% block javascript %}
  261. <script type="text/javascript">
  262. $(function() {
  263. $('[data-toggle="popover"]').popover()
  264. })
  265. </script>
  266. {% endblock %}