powerfeed.html 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. {% extends 'generic/object.html' %}
  2. {% load buttons %}
  3. {% load static %}
  4. {% load helpers %}
  5. {% load plugins %}
  6. {% block breadcrumbs %}
  7. {{ block.super }}
  8. <li class="breadcrumb-item"><a href="{% url 'dcim:powerfeed_list' %}?site_id={{ object.power_panel.site.pk }}">{{ object.power_panel.site }}</a></li>
  9. <li class="breadcrumb-item"><a href="{% url 'dcim:powerfeed_list' %}?power_panel_id={{ object.power_panel.pk }}">{{ object.power_panel }}</a></li>
  10. {% if object.rack %}
  11. <li class="breadcrumb-item"><a href="{% url 'dcim:powerfeed_list' %}?rack_id={{ object.rack.pk }}">{{ object.rack }}</a></li>
  12. {% endif %}
  13. {% endblock %}
  14. {% block content %}
  15. <div class="row">
  16. <div class="col col-md-6">
  17. <div class="card">
  18. <h5 class="card-header">
  19. Power Feed
  20. </h5>
  21. <div class="card-body">
  22. <table class="table table-hover attr-table">
  23. <tr>
  24. <th scope="row">Power Panel</th>
  25. <td>{{ object.power_panel|linkify }}</td>
  26. </tr>
  27. <tr>
  28. <th scope="row">Rack</th>
  29. <td>{{ object.rack|linkify|placeholder }}</td>
  30. </tr>
  31. <tr>
  32. <th scope="row">Type</th>
  33. <td>{% badge object.get_type_display bg_color=object.get_type_color %}</td>
  34. </tr>
  35. <tr>
  36. <th scope="row">Status</th>
  37. <td>{% badge object.get_status_display bg_color=object.get_status_color %}</td>
  38. </tr>
  39. <tr>
  40. <th scope="row">Connected Device</th>
  41. <td>
  42. {% if object.connected_endpoint %}
  43. {{ object.connected_endpoint.device|linkify }} ({{ object.connected_endpoint }})
  44. {% else %}
  45. {{ ''|placeholder }}
  46. {% endif %}
  47. </td>
  48. </tr>
  49. <tr>
  50. <th scope="row">Utilization (Allocated)</th>
  51. {% with utilization=object.connected_endpoint.get_power_draw %}
  52. {% if utilization %}
  53. <td>
  54. {{ utilization.allocated }}VA / {{ object.available_power }}VA
  55. {% if object.available_power > 0 %}
  56. {% utilization_graph utilization.allocated|percentage:object.available_power %}
  57. {% endif %}
  58. </td>
  59. {% else %}
  60. <td class="text-muted">N/A</td>
  61. {% endif %}
  62. {% endwith %}
  63. </tr>
  64. </table>
  65. </div>
  66. </div>
  67. <div class="card">
  68. <h5 class="card-header">
  69. Electrical Characteristics
  70. </h5>
  71. <div class="card-body">
  72. <table class="table table-hover attr-table">
  73. <tr>
  74. <th scope="row">Supply</th>
  75. <td>{{ object.get_supply_display }}</td>
  76. </tr>
  77. <tr>
  78. <th scope="row">Voltage</th>
  79. <td>{{ object.voltage }}V</td>
  80. </tr>
  81. <tr>
  82. <th scope="row">Amperage</th>
  83. <td>{{ object.amperage }}A</td>
  84. </tr>
  85. <tr>
  86. <th scope="row">Phase</th>
  87. <td>{{ object.get_phase_display }}</td>
  88. </tr>
  89. <tr>
  90. <th scope="row">Max Utilization</th>
  91. <td>{{ object.max_utilization }}%</td>
  92. </tr>
  93. </table>
  94. </div>
  95. </div>
  96. {% include 'inc/panels/custom_fields.html' %}
  97. {% include 'inc/panels/tags.html' %}
  98. {% plugin_left_page object %}
  99. </div>
  100. <div class="col col-md-6">
  101. <div class="card">
  102. <h5 class="card-header">
  103. Connection
  104. </h5>
  105. <div class="card-body">
  106. {% if object.mark_connected %}
  107. <div class="text-muted">
  108. <span class="text-success"><i class="mdi mdi-check-bold"></i></span> Marked as connected
  109. </div>
  110. {% elif object.cable %}
  111. <table class="table table-hover attr-table">
  112. <tr>
  113. <th scope="row">Cable</th>
  114. <td>
  115. {{ object.cable|linkify }}
  116. <a href="{% url 'dcim:powerfeed_trace' pk=object.pk %}" class="btn btn-primary btn-sm lh-1" title="Trace">
  117. <i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i>
  118. </a>
  119. </td>
  120. </tr>
  121. {% if object.connected_endpoint %}
  122. <tr>
  123. <th scope="row">Device</th>
  124. <td>{{ object.connected_endpoint.device|linkify }}</td>
  125. </tr>
  126. <tr>
  127. <th scope="row">Name</th>
  128. <td>{{ object.connected_endpoint|linkify:"name" }}</td>
  129. </tr>
  130. <tr>
  131. <th scope="row">Type</th>
  132. <td>{{ object.connected_endpoint.get_type_display|placeholder }}</td>
  133. </tr>
  134. <tr>
  135. <th scope="row">Description</th>
  136. <td>{{ object.connected_endpoint.description|placeholder }}</td>
  137. </tr>
  138. <tr>
  139. <th scope="row">Path Status</th>
  140. <td>
  141. {% if object.path.is_active %}
  142. <span class="badge bg-success">Reachable</span>
  143. {% else %}
  144. <span class="badge bg-danger">Not Reachable</span>
  145. {% endif %}
  146. </td>
  147. </tr>
  148. {% endif %}
  149. </table>
  150. {% else %}
  151. <div class="text-muted">
  152. Not connected
  153. </div>
  154. {% endif %}
  155. </div>
  156. {% if not object.mark_connected and not object.cable %}
  157. <div class="card-footer">
  158. {% if perms.dcim.add_cable %}
  159. <a href="{% url 'dcim:powerfeed_connect' termination_a_id=object.pk termination_b_type='power-port' %}?return_url={{ object.get_absolute_url }}"
  160. class="btn btn-primary btn-sm float-end">
  161. <i class="mdi mdi-ethernet-cable" aria-hidden="true"></i> Connect
  162. </a>
  163. {% endif %}
  164. </div>
  165. {% endif %}
  166. </div>
  167. {% include 'inc/panels/comments.html' %}
  168. {% plugin_right_page object %}
  169. </div>
  170. </div>
  171. <div class="row">
  172. <div class="col col-md-12">
  173. {% plugin_full_width_page object %}
  174. </div>
  175. </div>
  176. {% endblock %}