circuit_termination.html 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. {% load helpers %}
  2. <div class="card">
  3. <div class="card-header">
  4. <strong class="d-block d-md-inline mb-3 mb-md-0">Termination - {{ side }} Side</strong>
  5. <div class="float-md-end">
  6. {% if not termination and perms.circuits.add_circuittermination %}
  7. <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">
  8. <span class="mdi mdi-plus-thick" aria-hidden="true"></span> Add
  9. </a>
  10. {% endif %}
  11. {% if termination and perms.circuits.change_circuittermination %}
  12. <a href="{% url 'circuits:circuittermination_edit' pk=termination.pk %}" class="btn btn-sm btn-warning lh-1">
  13. <span class="mdi mdi-pencil" aria-hidden="true"></span> Edit
  14. </a>
  15. <a href="{% url 'circuits:circuit_terminations_swap' pk=object.pk %}" class="btn btn-sm btn-primary lh-1">
  16. <span class="mdi mdi-swap-vertical" aria-hidden="true"></span> Swap
  17. </a>
  18. {% endif %}
  19. {% if termination and perms.circuits.delete_circuittermination %}
  20. <a href="{% url 'circuits:circuittermination_delete' pk=termination.pk %}?return_url={{ object.get_absolute_url }}" class="btn btn-sm btn-danger lh-1">
  21. <span class="mdi mdi-trash-can-outline" aria-hidden="true"></span> Delete
  22. </a>
  23. {% endif %}
  24. </div>
  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>
  47. {% with peer=termination.get_link_peer %}
  48. to
  49. {% if peer.device %}
  50. {{ peer.device|linkify }}<br/>
  51. {% elif peer.circuit %}
  52. {{ peer.circuit|linkify }}<br/>
  53. {% endif %}
  54. {{ peer|linkify }}
  55. {% endwith %}
  56. <div class="mt-1">
  57. <a href="{% url 'circuits:circuittermination_trace' pk=termination.pk %}" class="btn btn-primary btn-sm lh-1" title="Trace">
  58. <i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i> Trace
  59. </a>
  60. {% if perms.dcim.delete_cable %}
  61. <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">
  62. <i class="mdi mdi-ethernet-cable-off" aria-hidden="true"></i> Disconnect
  63. </a>
  64. {% endif %}
  65. </div>
  66. {% elif perms.dcim.add_cable %}
  67. <div class="dropdown">
  68. <button type="button" class="btn btn-success btn-sm dropdown-toggle" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  69. <span class="mdi mdi-ethernet-cable" aria-hidden="true"></span> Connect
  70. </button>
  71. <ul class="dropdown-menu">
  72. <li><a class="dropdown-item" href="{% url 'circuits:circuittermination_connect' %}?termination_a_id={{ termination.pk }}&termination_b_type=dcim.interface&termination_b_site={{ termination.site.pk }}&return_url={{ object.get_absolute_url }}">Interface</a></li>
  73. <li><a class="dropdown-item" href="{% url 'circuits:circuittermination_connect' %}?termination_a_id={{ termination.pk }}&termination_b_type=dcim.frontport&termination_b_site={{ termination.site.pk }}&return_url={{ object.get_absolute_url }}">Front Port</a></li>
  74. <li><a class="dropdown-item" href="{% url 'circuits:circuittermination_connect' %}?termination_a_id={{ termination.pk }}&termination_b_type=dcim.rearport&termination_b_site={{ termination.site.pk }}&return_url={{ object.get_absolute_url }}">Rear Port</a></li>
  75. <li><a class="dropdown-item" href="{% url 'circuits:circuittermination_connect' %}?termination_a_id={{ termination.pk }}&termination_b_type=circuits.circuittermination&termination_b_site={{ termination.site.pk }}&return_url={{ object.get_absolute_url }}">Circuit Termination</a></li>
  76. </ul>
  77. </div>
  78. {% endif %}
  79. </td>
  80. </tr>
  81. {% else %}
  82. <tr>
  83. <td>Provider Network</td>
  84. <td>{{ termination.provider_network|linkify }}</td>
  85. </tr>
  86. {% endif %}
  87. <tr>
  88. <td>Speed</td>
  89. <td>
  90. {% if termination.port_speed and termination.upstream_speed %}
  91. <i class="mdi mdi-arrow-down-bold" title="Downstream"></i> {{ termination.port_speed|humanize_speed }} &nbsp;
  92. <i class="mdi mdi-arrow-up-bold" title="Upstream"></i> {{ termination.upstream_speed|humanize_speed }}
  93. {% elif termination.port_speed %}
  94. {{ termination.port_speed|humanize_speed }}
  95. {% else %}
  96. <span class="text-muted">&mdash;</span>
  97. {% endif %}
  98. </td>
  99. </tr>
  100. <tr>
  101. <td>Cross-Connect</td>
  102. <td>{{ termination.xconnect_id|placeholder }}</td>
  103. </tr>
  104. <tr>
  105. <td>Patch Panel/Port</td>
  106. <td>{{ termination.pp_info|placeholder }}</td>
  107. </tr>
  108. <tr>
  109. <td>Description</td>
  110. <td>{{ termination.description|placeholder }}</td>
  111. </tr>
  112. </table>
  113. {% else %}
  114. <span class="text-muted">None</span>
  115. {% endif %}
  116. </div>
  117. </div>