circuit_termination.html 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. {% load helpers %}
  2. <div class="card">
  3. <div class="card-header">
  4. <div class="float-md-end">
  5. {% if not termination and perms.circuits.add_circuittermination %}
  6. <a href="{% url 'circuits:circuittermination_add' %}?circuit={{ object.pk }}&term_side={{ side }}&return_url={{ object.get_absolute_url }}" class="btn btn-sm btn-success lh-1">
  7. <span class="mdi mdi-plus-thick" aria-hidden="true"></span> Add
  8. </a>
  9. {% endif %}
  10. {% if termination and perms.circuits.change_circuittermination %}
  11. <a href="{% url 'circuits:circuittermination_edit' pk=termination.pk %}?return_url={{ object.get_absolute_url }}" class="btn btn-sm btn-warning lh-1">
  12. <span class="mdi mdi-pencil" aria-hidden="true"></span> Edit
  13. </a>
  14. <a href="{% url 'circuits:circuit_terminations_swap' pk=object.pk %}?return_url={{ object.get_absolute_url }}" class="btn btn-sm btn-primary lh-1">
  15. <span class="mdi mdi-swap-vertical" aria-hidden="true"></span> Swap
  16. </a>
  17. {% endif %}
  18. {% if termination and perms.circuits.delete_circuittermination %}
  19. <a href="{% url 'circuits:circuittermination_delete' pk=termination.pk %}?return_url={{ object.get_absolute_url }}" class="btn btn-sm btn-danger lh-1">
  20. <span class="mdi mdi-trash-can-outline" aria-hidden="true"></span> Delete
  21. </a>
  22. {% endif %}
  23. </div>
  24. <h5>Termination {{ side }}</h5>
  25. </div>
  26. <div class="card-body">
  27. {% if termination %}
  28. <table class="table table-hover attr-table">
  29. {% if termination.site %}
  30. <tr>
  31. <td>Site</td>
  32. <td>
  33. {% if termination.site.region %}
  34. {{ termination.site.region|linkify }} /
  35. {% endif %}
  36. {{ termination.site|linkify }}
  37. </td>
  38. </tr>
  39. <tr>
  40. <td>Termination</td>
  41. <td>
  42. {% if termination.mark_connected %}
  43. <span class="text-success"><i class="mdi mdi-check-bold"></i></span>
  44. <span class="text-muted">Marked as connected</span>
  45. {% elif termination.cable %}
  46. <a class="d-block d-md-inline" href="{{ termination.cable.get_absolute_url }}">{{ termination.cable }}</a> to
  47. {% for peer in termination.link_peers %}
  48. {% if peer.device %}
  49. {{ peer.device|linkify }}<br/>
  50. {% elif peer.circuit %}
  51. {{ peer.circuit|linkify }}<br/>
  52. {% endif %}
  53. {{ peer|linkify }}{% if not forloop.last %},{% endif %}
  54. {% endfor %}
  55. <div class="mt-1">
  56. <a href="{% url 'circuits:circuittermination_trace' pk=termination.pk %}" class="btn btn-primary btn-sm lh-1" title="Trace">
  57. <i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i> Trace
  58. </a>
  59. {% if perms.dcim.delete_cable %}
  60. <a href="{% url 'dcim:cable_delete' pk=termination.cable.pk %}?return_url={{ termination.circuit.get_absolute_url }}" title="Remove cable" class="btn btn-danger btn-sm lh-1">
  61. <i class="mdi mdi-ethernet-cable-off" aria-hidden="true"></i> Disconnect
  62. </a>
  63. {% endif %}
  64. </div>
  65. {% elif perms.dcim.add_cable %}
  66. <div class="dropdown">
  67. <button type="button" class="btn btn-success btn-sm dropdown-toggle" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  68. <span class="mdi mdi-ethernet-cable" aria-hidden="true"></span> Connect
  69. </button>
  70. <ul class="dropdown-menu">
  71. <li><a class="dropdown-item" href="{% url 'dcim:cable_add' %}?a_terminations_type=circuits.circuittermination&a_terminations={{ termination.pk }}&b_terminations_type=dcim.interface&termination_b_site={{ termination.site.pk }}&return_url={{ object.get_absolute_url }}">Interface</a></li>
  72. <li><a class="dropdown-item" href="{% url 'dcim:cable_add' %}?a_terminations_type=circuits.circuittermination&a_terminations={{ termination.pk }}&b_terminations_type=dcim.frontport&termination_b_site={{ termination.site.pk }}&return_url={{ object.get_absolute_url }}">Front Port</a></li>
  73. <li><a class="dropdown-item" href="{% url 'dcim:cable_add' %}?a_terminations_type=circuits.circuittermination&a_terminations={{ termination.pk }}&b_terminations_type=dcim.rearport&termination_b_site={{ termination.site.pk }}&return_url={{ object.get_absolute_url }}">Rear Port</a></li>
  74. <li><a class="dropdown-item" href="{% url 'dcim:cable_add' %}?a_terminations_type=circuits.circuittermination&a_terminations={{ termination.pk }}&b_terminations_type=circuits.circuittermination&termination_b_site={{ termination.site.pk }}&return_url={{ object.get_absolute_url }}">Circuit Termination</a></li>
  75. </ul>
  76. </div>
  77. {% endif %}
  78. </td>
  79. </tr>
  80. {% else %}
  81. <tr>
  82. <td>Provider Network</td>
  83. <td>{{ termination.provider_network|linkify }}</td>
  84. </tr>
  85. {% endif %}
  86. <tr>
  87. <td>Speed</td>
  88. <td>
  89. {% if termination.port_speed and termination.upstream_speed %}
  90. <i class="mdi mdi-arrow-down-bold" title="Downstream"></i> {{ termination.port_speed|humanize_speed }} &nbsp;
  91. <i class="mdi mdi-arrow-up-bold" title="Upstream"></i> {{ termination.upstream_speed|humanize_speed }}
  92. {% elif termination.port_speed %}
  93. {{ termination.port_speed|humanize_speed }}
  94. {% else %}
  95. {{ ''|placeholder }}
  96. {% endif %}
  97. </td>
  98. </tr>
  99. <tr>
  100. <td>Cross-Connect</td>
  101. <td>{{ termination.xconnect_id|placeholder }}</td>
  102. </tr>
  103. <tr>
  104. <td>Patch Panel/Port</td>
  105. <td>{{ termination.pp_info|placeholder }}</td>
  106. </tr>
  107. <tr>
  108. <td>Description</td>
  109. <td>{{ termination.description|placeholder }}</td>
  110. </tr>
  111. <tr>
  112. <td>Tags</td>
  113. <td>
  114. {% for tag in termination.tags.all %}
  115. {% tag tag %}
  116. {% empty %}
  117. {{ ''|placeholder }}
  118. {% endfor %}
  119. </td>
  120. </tr>
  121. {% for group_name, fields in termination.get_custom_fields_by_group.items %}
  122. <tr>
  123. <td colspan="2">
  124. <strong>{{ group_name|default:"Custom Fields" }}</strong>
  125. </td>
  126. </tr>
  127. {% for field, value in fields.items %}
  128. <tr>
  129. <td>
  130. <span title="{{ field.description|escape }}">{{ field }}</span>
  131. </td>
  132. <td>
  133. {% customfield_value field value %}
  134. </td>
  135. </tr>
  136. {% endfor %}
  137. {% endfor %}
  138. </table>
  139. {% else %}
  140. <span class="text-muted">None</span>
  141. {% endif %}
  142. </div>
  143. </div>