frontport.html 7.4 KB

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