consoleport.html 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  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_consoleports' 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. Console 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>
  22. <a href="{{ object.device.get_absolute_url }}">{{ object.device }}</a>
  23. </td>
  24. </tr>
  25. <tr>
  26. <th scope="row">Name</th>
  27. <td>{{ object.name }}</td>
  28. </tr>
  29. <tr>
  30. <th scope="row">Label</th>
  31. <td>{{ object.label|placeholder }}</td>
  32. </tr>
  33. <tr>
  34. <th scope="row">Type</th>
  35. <td>{{ object.get_type_display }}</td>
  36. </tr>
  37. <tr>
  38. <th scope="row">Speed</th>
  39. <td>{{ object.get_speed_display }}</td>
  40. </tr>
  41. <tr>
  42. <th scope="row">Description</th>
  43. <td>{{ object.description|placeholder }}</td>
  44. </tr>
  45. </table>
  46. </div>
  47. </div>
  48. {% include 'inc/panels/custom_fields.html' %}
  49. {% include 'inc/panels/tags.html' %}
  50. {% plugin_left_page object %}
  51. </div>
  52. <div class="col col-md-6">
  53. <div class="card">
  54. <h5 class="card-header">
  55. Connection
  56. </h5>
  57. <div class="card-body">
  58. {% if object.mark_connected %}
  59. <span class="text-success"><i class="mdi mdi-check-bold"></i></span> Marked as connected
  60. {% elif object.cable %}
  61. <table class="table table-hover attr-table">
  62. <tr>
  63. <th scope="row">Cable</th>
  64. <td>
  65. <a href="{{ object.cable.get_absolute_url }}">{{ object.cable }}</a>
  66. <a href="{% url 'dcim:consoleport_trace' pk=object.pk %}" class="btn btn-primary btn-sm lh-1" title="Trace">
  67. <i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i>
  68. </a>
  69. </td>
  70. </tr>
  71. {% if object.connected_endpoint %}
  72. <tr>
  73. <th scope="row">Device</th>
  74. <td>
  75. <a href="{{ object.connected_endpoint.device.get_absolute_url }}">{{ object.connected_endpoint.device }}</a>
  76. </td>
  77. </tr>
  78. <tr>
  79. <th scope="row">Name</th>
  80. <td>
  81. <a href="{{ object.connected_endpoint.get_absolute_url }}">{{ object.connected_endpoint.name }}</a>
  82. </td>
  83. </tr>
  84. <tr>
  85. <th scope="row">Type</th>
  86. <td>{{ object.connected_endpoint.get_type_display|placeholder }}</td>
  87. </tr>
  88. <tr>
  89. <th scope="row">Description</th>
  90. <td>{{ object.connected_endpoint.description|placeholder }}</td>
  91. </tr>
  92. <tr>
  93. <th scope="row">Path Status</th>
  94. <td>
  95. {% if object.path.is_active %}
  96. <span class="badge bg-success">Reachable</span>
  97. {% else %}
  98. <span class="badge bg-danger">Not Reachable</span>
  99. {% endif %}
  100. </td>
  101. </tr>
  102. {% endif %}
  103. </table>
  104. {% else %}
  105. <div class="text-muted">
  106. Not Connected
  107. {% if perms.dcim.add_cable %}
  108. <div class="dropdown float-end">
  109. <button type="button" class="btn btn-primary btn-sm dropdown-toggle" data-bs-toggle="dropdown" aria-expanded="false">
  110. <span class="mdi mdi-ethernet-cable" aria-hidden="true"></span> Connect
  111. </button>
  112. <ul class="dropdown-menu dropdown-menu-end">
  113. <li>
  114. <a
  115. class="dropdown-item"
  116. href="{% url 'dcim:consoleport_connect' termination_a_id=object.pk termination_b_type='console-server-port' %}?return_url={{ object.get_absolute_url }}"
  117. >
  118. Console Server Port
  119. </a>
  120. </li>
  121. <li>
  122. <a
  123. class="dropdown-item"
  124. href="{% url 'dcim:consoleport_connect' termination_a_id=object.pk termination_b_type='front-port' %}?return_url={{ object.get_absolute_url }}"
  125. >
  126. Front Port
  127. </a>
  128. </li>
  129. <li>
  130. <a
  131. class="dropdown-item"
  132. href="{% url 'dcim:consoleport_connect' termination_a_id=object.pk termination_b_type='rear-port' %}?return_url={{ object.get_absolute_url }}"
  133. >
  134. Rear Port
  135. </a>
  136. </li>
  137. </ul>
  138. </div>
  139. {% endif %}
  140. </div>
  141. {% endif %}
  142. </div>
  143. </div>
  144. {% plugin_right_page object %}
  145. </div>
  146. </div>
  147. <div class="row">
  148. <div class="col col-md-12">
  149. {% plugin_full_width_page object %}
  150. </div>
  151. </div>
  152. {% endblock %}