frontport.html 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. {% extends 'generic/object.html' %}
  2. {% load helpers %}
  3. {% load plugins %}
  4. {% block breadcrumbs %}
  5. {{ block.super }}
  6. <li class="breadcrumb-item">
  7. <a href="{% url 'dcim:device_frontports' pk=object.device.pk %}">{{ object.device }}</a>
  8. </li>
  9. {% endblock %}
  10. {% block content %}
  11. <div class="row">
  12. <div class="col col-md-6">
  13. <div class="card">
  14. <h5 class="card-header">
  15. Front Port
  16. </h5>
  17. <div class="card-body">
  18. <table class="table table-hover attr-table">
  19. <tr>
  20. <th scope="row">Device</th>
  21. <td>{{ object.device|linkify }}</td>
  22. </tr>
  23. <tr>
  24. <th scope="row">Module</th>
  25. <td>{{ object.module|linkify|placeholder }}</td>
  26. </tr>
  27. <tr>
  28. <th scope="row">Name</th>
  29. <td>{{ object.name }}</td>
  30. </tr>
  31. <tr>
  32. <th scope="row">Label</th>
  33. <td>{{ object.label|placeholder }}</td>
  34. </tr>
  35. <tr>
  36. <th scope="row">Type</th>
  37. <td>{{ object.get_type_display }}</td>
  38. </tr>
  39. <tr>
  40. <th scope="row">Color</th>
  41. <td>
  42. {% if object.color %}
  43. <span class="badge color-label" style="background-color: #{{ object.color }}">&nbsp;</span>
  44. {% else %}
  45. {{ ''|placeholder }}
  46. {% endif %}
  47. </td>
  48. </tr>
  49. <tr>
  50. <th scope="row">Rear Port</th>
  51. <td>{{ object.rear_port|linkify }}</td>
  52. </tr>
  53. <tr>
  54. <th scope="row">Rear Port Position</th>
  55. <td>{{ object.rear_port_position }}</td>
  56. </tr>
  57. <tr>
  58. <th scope="row">Description</th>
  59. <td>{{ object.description|placeholder }}</td>
  60. </tr>
  61. </table>
  62. </div>
  63. </div>
  64. {% include 'inc/panels/custom_fields.html' %}
  65. {% include 'inc/panels/tags.html' %}
  66. {% plugin_left_page object %}
  67. </div>
  68. <div class="col col-md-6">
  69. <div class="card">
  70. <h5 class="card-header">
  71. Connection
  72. </h5>
  73. <div class="card-body">
  74. {% if object.mark_connected %}
  75. <div class="text-muted">
  76. <span class="text-success"><i class="mdi mdi-check-bold"></i></span> Marked as Connected
  77. </div>
  78. {% elif object.cable %}
  79. <table class="table table-hover attr-table">
  80. <tr>
  81. <th scope="row">Cable</th>
  82. <td>
  83. {{ object.cable|linkify }}
  84. <a href="{% url 'dcim:frontport_trace' pk=object.pk %}" class="btn btn-primary btn-sm lh-1" title="Trace">
  85. <i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i>
  86. </a>
  87. </td>
  88. </tr>
  89. <tr>
  90. <th scope="row">Connection Status</th>
  91. <td>
  92. {% if object.cable.status %}
  93. <span class="badge bg-success">{{ object.cable.get_status_display }}</span>
  94. {% else %}
  95. <span class="badge bg-info">{{ object.cable.get_status_display }}</span>
  96. {% endif %}
  97. </td>
  98. </tr>
  99. </table>
  100. {% else %}
  101. <div class="text-muted">
  102. Not Connected
  103. {% if perms.dcim.add_cable %}
  104. <div class="dropdown float-end">
  105. <button type="button" class="btn btn-primary btn-sm dropdown-toggle" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  106. <span class="mdi mdi-ethernet-cable" aria-hidden="true"></span> Connect
  107. </button>
  108. <ul class="dropdown-menu dropdown-menu-end">
  109. <li>
  110. <a class="dropdown-item" href="{% url 'dcim:cable_add' %}?a_terminations_type=dcim.frontport&a_terminations={{ object.pk }}&b_terminations_type=dcim.interface&termination_b_site={{ object.device.site.pk }}&termination_b_rack={{ object.device.rack.pk }}&return_url={{ object.get_absolute_url }}">Interface</a>
  111. </li>
  112. <li>
  113. <a class="dropdown-item" href="{% url 'dcim:cable_add' %}?a_terminations_type=dcim.frontport&a_terminations={{ object.pk }}&b_terminations_type=dcim.consoleserverport&termination_b_site={{ object.device.site.pk }}&termination_b_rack={{ object.device.rack.pk }}&return_url={{ object.get_absolute_url }}">Console Server Port</a>
  114. </li>
  115. <li>
  116. <a class="dropdown-item" href="{% url 'dcim:cable_add' %}?a_terminations_type=dcim.frontport&a_terminations={{ object.pk }}&b_terminations_type=dcim.consoleport&termination_b_site={{ object.device.site.pk }}&termination_b_rack={{ object.device.rack.pk }}&return_url={{ object.get_absolute_url }}">Console Port</a>
  117. </li>
  118. <li>
  119. <a class="dropdown-item" href="{% url 'dcim:cable_add' %}?a_terminations_type=dcim.frontport&a_terminations={{ object.pk }}&b_terminations_type=dcim.frontport&termination_b_site={{ object.device.site.pk }}&termination_b_rack={{ object.device.rack.pk }}&return_url={{ object.get_absolute_url }}">Front Port</a>
  120. </li>
  121. <li>
  122. <a class="dropdown-item" href="{% url 'dcim:cable_add' %}?a_terminations_type=dcim.frontport&a_terminations={{ object.pk }}&b_terminations_type=dcim.rearport&termination_b_site={{ object.device.site.pk }}&termination_b_rack={{ object.device.rack.pk }}&return_url={{ object.get_absolute_url }}">Rear Port</a>
  123. </li>
  124. <li>
  125. <a class="dropdown-item" href="{% url 'dcim:cable_add' %}?a_terminations_type=dcim.frontport&a_terminations={{ object.pk }}&b_terminations_type=circuits.circuittermination&termination_b_site={{ object.device.site.pk }}&return_url={{ object.get_absolute_url }}">Circuit Termination</a>
  126. </li>
  127. </ul>
  128. </div>
  129. {% endif %}
  130. </div>
  131. {% endif %}
  132. </div>
  133. </div>
  134. {% include 'dcim/inc/panels/inventory_items.html' %}
  135. {% plugin_right_page object %}
  136. </div>
  137. </div>
  138. <div class="row">
  139. <div class="col col-md-12">
  140. {% plugin_full_width_page object %}
  141. </div>
  142. </div>
  143. {% endblock %}