rack.html 12 KB

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