consoleport.html 7.1 KB

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