rearport.html 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  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. Rear 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">Color</th>
  33. <td>
  34. <span class="badge color-label" style="background-color: #{{ object.color }}">&nbsp;</span>
  35. </td>
  36. </tr>
  37. <tr>
  38. <th scope="row">Positions</th>
  39. <td>{{ object.positions }}</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. <div class="text-muted">
  60. <span class="text-success"><i class="mdi mdi-check-bold"></i></span> Marked as Connected
  61. </div>
  62. {% elif object.cable %}
  63. <table class="table table-hover attr-table">
  64. <tr>
  65. <th scope="row">Cable</th>
  66. <td>
  67. <a href="{{ object.cable.get_absolute_url }}">{{ object.cable }}</a>
  68. <a href="{% url 'dcim:rearport_trace' pk=object.pk %}" class="btn btn-primary btn-sm lh-1" title="Trace">
  69. <i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i>
  70. </a>
  71. </td>
  72. </tr>
  73. <tr>
  74. <th scope="row">Connection Status</th>
  75. <td>
  76. {% if object.cable.status %}
  77. <span class="badge bg-success">{{ object.cable.get_status_display }}</span>
  78. {% else %}
  79. <span class="badge bg-info">{{ object.cable.get_status_display }}</span>
  80. {% endif %}
  81. </td>
  82. </tr>
  83. </table>
  84. {% else %}
  85. <div class="text-muted">
  86. Not connected
  87. {% if perms.dcim.add_cable %}
  88. <span class="dropdown float-end">
  89. <button type="button" class="btn btn-primary btn-sm dropdown-toggle" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  90. <span class="mdi mdi-ethernet-cable" aria-hidden="true"></span> Connect
  91. </button>
  92. <ul class="dropdown-menu dropdown-menu-end">
  93. <li>
  94. <a class="dropdown-link" href="{% url 'dcim:rearport_connect' termination_a_id=object.pk termination_b_type='interface' %}?return_url={{ object.get_absolute_url }}">Interface</a>
  95. </li>
  96. <li>
  97. <a class="dropdown-link" href="{% url 'dcim:rearport_connect' termination_a_id=object.pk termination_b_type='front-port' %}?return_url={{ object.get_absolute_url }}">Front Port</a>
  98. </li>
  99. <li>
  100. <a class="dropdown-link" href="{% url 'dcim:rearport_connect' termination_a_id=object.pk termination_b_type='rear-port' %}?return_url={{ object.get_absolute_url }}">Rear Port</a>
  101. </li>
  102. <li>
  103. <a class="dropdown-link" href="{% url 'dcim:rearport_connect' termination_a_id=object.pk termination_b_type='circuit-termination' %}?return_url={{ object.get_absolute_url }}">Circuit Termination</a>
  104. </li>
  105. </ul>
  106. </span>
  107. {% endif %}
  108. </div>
  109. {% endif %}
  110. </div>
  111. </div>
  112. {% plugin_right_page object %}
  113. </div>
  114. </div>
  115. <div class="row">
  116. <div class="col col-md-12">
  117. {% plugin_full_width_page object %}
  118. </div>
  119. </div>
  120. {% endblock %}