rack.html 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  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-md-9">
  8. <ol class="breadcrumb">
  9. <li><a href="{% url 'dcim:site' slug=rack.site.slug %}">{{ rack.site }}</a></li>
  10. <li><a href="{% url 'dcim:rack_list' %}?site={{ rack.site.slug }}">Racks</a></li>
  11. <li>{{ rack }}</li>
  12. </ol>
  13. </div>
  14. <div class="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="Rack name or ID" />
  18. <span class="input-group-btn">
  19. <button type="submit" class="btn btn-primary">
  20. <span class="glyphicon glyphicon-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="glyphicon glyphicon-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="glyphicon glyphicon-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="glyphicon glyphicon-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="glyphicon glyphicon-trash" aria-hidden="true"></span>
  49. Delete this rack
  50. </a>
  51. {% endif %}
  52. </div>
  53. <h1>Rack {{ rack.name }}</h1>
  54. <div class="row">
  55. <div class="col-md-6">
  56. <div class="panel panel-default">
  57. <div class="panel-heading">
  58. <strong>Rack</strong>
  59. </div>
  60. <table class="table table-hover panel-body">
  61. <tr>
  62. <td>Site</td>
  63. <td>
  64. <a href="{% url 'dcim:site' slug=rack.site.slug %}">{{ rack.site }}</a>
  65. </td>
  66. </tr>
  67. <tr>
  68. <td>Group</td>
  69. <td>
  70. {% if rack.group %}
  71. <a href="{% url 'dcim:rack_list' %}?site={{ rack.site.slug }}&group={{ rack.group.slug }}">{{ rack.group.name }}</a>
  72. {% else %}
  73. <span class="text-muted">None</span>
  74. {% endif %}
  75. </td>
  76. </tr>
  77. <tr>
  78. <td>Facility ID</td>
  79. <td>
  80. {% if rack.facility_id %}
  81. <span>{{ rack.facility_id }}</span>
  82. {% else %}
  83. <span class="text-muted">None</span>
  84. {% endif %}
  85. </td>
  86. </tr>
  87. <tr>
  88. <td>Height</td>
  89. <td>{{ rack.u_height }}U</td>
  90. </tr>
  91. <tr>
  92. <td>Devices</td>
  93. <td>
  94. <a href="{% url 'dcim:device_list' %}?rack_id={{ rack.id }}">{{ rack.devices.count }}</a>
  95. </td>
  96. </tr>
  97. <tr>
  98. <td>Created</td>
  99. <td>{{ rack.created }}</td>
  100. </tr>
  101. <tr>
  102. <td>Last Updated</td>
  103. <td>{{ rack.last_updated }}</td>
  104. </tr>
  105. </table>
  106. </div>
  107. <div class="panel panel-default">
  108. <div class="panel-heading">
  109. <strong>Non-Racked Devices</strong>
  110. </div>
  111. {% if nonracked_devices %}
  112. <table class="table table-hover panel-body">
  113. <tr>
  114. <th>Name</th>
  115. <th>Role</th>
  116. <th>Type</th>
  117. <th>Parent</th>
  118. </tr>
  119. {% for device in nonracked_devices %}
  120. <tr{% if device.device_type.u_height %} class="warning"{% endif %}>
  121. <td>
  122. <a href="{% url 'dcim:device' pk=device.pk %}">{{ device.name }}</a>
  123. </td>
  124. <td>{{ device.device_role }}</td>
  125. <td>{{ device.device_type }}</td>
  126. <td>{% if device.parent_bay %}<a href="{{ device.parent_bay.device.get_absolute_url }}">{{ device.parent_bay }}</a>{% endif %}</td>
  127. </tr>
  128. {% endfor %}
  129. </table>
  130. {% else %}
  131. <div class="panel-body text-muted">None</div>
  132. {% endif %}
  133. {% if perms.dcim.add_device %}
  134. <div class="panel-footer text-right">
  135. <a href="{% url 'dcim:device_add' %}?site={{ rack.site.pk }}&rack={{ rack.pk }}" class="btn btn-primary btn-xs">
  136. <span class="glyphicon glyphicon-plus" aria-hidden="true"></span>
  137. Add a non-racked device
  138. </a>
  139. </div>
  140. {% endif %}
  141. </div>
  142. <div class="panel panel-default">
  143. <div class="panel-heading">
  144. <strong>Comments</strong>
  145. </div>
  146. <div class="panel-body">
  147. {% if rack.comments %}
  148. {{ rack.comments|gfm }}
  149. {% else %}
  150. <span class="text-muted">None</span>
  151. {% endif %}
  152. </div>
  153. </div>
  154. </div>
  155. <div class="row col-md-6">
  156. <div class="col-md-6 col-sm-6 col-xs-12">
  157. <div class="rack_header">
  158. <h4>Front</h4>
  159. </div>
  160. {% include 'dcim/_rack_elevation.html' with primary_face=front_elevation secondary_face=rear_elevation face_id=0 %}
  161. </div>
  162. <div class="col-md-6 col-sm-6 col-xs-12">
  163. <div class="rack_header">
  164. <h4>Rear</h4>
  165. </div>
  166. {% include 'dcim/_rack_elevation.html' with primary_face=rear_elevation secondary_face=front_elevation face_id=1 %}
  167. </div>
  168. </div>
  169. </div>
  170. {% endblock %}
  171. {% block javascript %}
  172. <script type="text/javascript">
  173. $(function() {
  174. $('[data-toggle="popover"]').popover()
  175. })
  176. </script>
  177. {% endblock %}