provider.html 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. {% extends '_base.html' %}
  2. {% load static %}
  3. {% load helpers %}
  4. {% block title %}{{ provider }}{% endblock %}
  5. {% block header %}
  6. <div class="row">
  7. <div class="col-sm-8 col-md-9">
  8. <ol class="breadcrumb">
  9. <li><a href="{% url 'circuits:provider_list' %}">Providers</a></li>
  10. <li>{{ provider }}</li>
  11. </ol>
  12. </div>
  13. <div class="col-sm-4 col-md-3">
  14. <form action="{% url 'circuits:provider_list' %}" method="get">
  15. <div class="input-group">
  16. <input type="text" name="q" class="form-control" />
  17. <span class="input-group-btn">
  18. <button type="submit" class="btn btn-primary">
  19. <span class="fa fa-search" aria-hidden="true"></span>
  20. </button>
  21. </span>
  22. </div>
  23. </form>
  24. </div>
  25. </div>
  26. <div class="pull-right">
  27. {% if show_graphs %}
  28. <button type="button" class="btn btn-primary" data-toggle="modal" data-target="#graphs_modal" data-obj="{{ provider.name }}" data-url="{% url 'circuits-api:provider-graphs' pk=provider.pk %}" title="Show graphs">
  29. <i class="fa fa-signal" aria-hidden="true"></i>
  30. Graphs
  31. </button>
  32. {% endif %}
  33. {% if perms.circuits.change_provider %}
  34. <a href="{% url 'circuits:provider_edit' slug=provider.slug %}" class="btn btn-warning">
  35. <span class="fa fa-pencil" aria-hidden="true"></span>
  36. Edit this provider
  37. </a>
  38. {% endif %}
  39. {% if perms.circuits.delete_provider %}
  40. <a href="{% url 'circuits:provider_delete' slug=provider.slug %}" class="btn btn-danger">
  41. <span class="fa fa-trash" aria-hidden="true"></span>
  42. Delete this provider
  43. </a>
  44. {% endif %}
  45. </div>
  46. <h1>{{ provider }}</h1>
  47. {% include 'inc/created_updated.html' with obj=provider %}
  48. <ul class="nav nav-tabs">
  49. <li role="presentation"{% if not active_tab %} class="active"{% endif %}>
  50. <a href="{{ provider.get_absolute_url }}">Provider</a>
  51. </li>
  52. <li role="presentation"{% if active_tab == 'changelog' %} class="active"{% endif %}>
  53. <a href="{% url 'circuits:provider_changelog' slug=provider.slug %}">Changelog</a>
  54. </li>
  55. </ul>
  56. {% endblock %}
  57. {% block content %}
  58. <div class="row">
  59. <div class="col-md-4">
  60. <div class="panel panel-default">
  61. <div class="panel-heading">
  62. <strong>Provider</strong>
  63. </div>
  64. <table class="table table-hover panel-body attr-table">
  65. <tr>
  66. <td>ASN</td>
  67. <td>{{ provider.asn|placeholder }}</td>
  68. </tr>
  69. <tr>
  70. <td>Account</td>
  71. <td>{{ provider.account|placeholder }}</td>
  72. </tr>
  73. <tr>
  74. <td>Customer Portal</td>
  75. <td>
  76. {% if provider.portal_url %}
  77. <a href="{{ provider.portal_url }}">{{ provider.portal_url }}</a>
  78. {% else %}
  79. <span class="text-muted">&mdash;</span>
  80. {% endif %}
  81. </td>
  82. </tr>
  83. <tr>
  84. <td>NOC Contact</td>
  85. <td class="rendered-markdown">{{ provider.noc_contact|gfm|placeholder }}</td>
  86. </tr>
  87. <tr>
  88. <td>Admin Contact</td>
  89. <td class="rendered-markdown">{{ provider.admin_contact|gfm|placeholder }}</td>
  90. </tr>
  91. <tr>
  92. <td>Circuits</td>
  93. <td>
  94. <a href="{% url 'circuits:circuit_list' %}?provider={{ provider.slug }}">{{ provider.circuits.count }}</a>
  95. </td>
  96. </tr>
  97. </table>
  98. </div>
  99. {% include 'inc/custom_fields_panel.html' with obj=provider %}
  100. {% include 'extras/inc/tags_panel.html' with tags=provider.tags.all url='circuits:provider_list' %}
  101. <div class="panel panel-default">
  102. <div class="panel-heading">
  103. <strong>Comments</strong>
  104. </div>
  105. <div class="panel-body rendered-markdown">
  106. {% if provider.comments %}
  107. {{ provider.comments|gfm }}
  108. {% else %}
  109. <span class="text-muted">None</span>
  110. {% endif %}
  111. </div>
  112. </div>
  113. </div>
  114. <div class="col-md-8">
  115. <div class="panel panel-default">
  116. <div class="panel-heading">
  117. <strong>Circuits</strong>
  118. </div>
  119. <table class="table table-hover panel-body">
  120. <tr>
  121. <th>Circuit ID</th>
  122. <th>Type</th>
  123. <th>Tenant</th>
  124. <th>A Side</th>
  125. <th>Z Side</th>
  126. <th>Description</th>
  127. </tr>
  128. {% for c in circuits %}
  129. <tr>
  130. <td>
  131. <a href="{% url 'circuits:circuit' pk=c.pk %}">{{ c.cid }}</a>
  132. </td>
  133. <td>
  134. <a href="{% url 'circuits:circuit_list' %}?type={{ c.type.slug }}">{{ c.type }}</a>
  135. </td>
  136. <td>
  137. {% if c.tenant %}
  138. <a href="{% url 'tenancy:tenant' slug=c.tenant.slug %}">{{ c.tenant }}</a>
  139. {% else %}
  140. <span class="text-muted">&mdash;</span>
  141. {% endif %}
  142. </td>
  143. <td>
  144. {% if c.termination_a %}
  145. <a href="{% url 'dcim:site' slug=c.termination_a.site.slug %}">{{ c.termination_a.site }}</a>
  146. {% else %}
  147. <span class="text-muted">&mdash;</span>
  148. {% endif %}
  149. </td>
  150. <td>
  151. {% if c.termination_z %}
  152. <a href="{% url 'dcim:site' slug=c.termination_z.site.slug %}">{{ c.termination_z.site }}</a>
  153. {% else %}
  154. <span class="text-muted">&mdash;</span>
  155. {% endif %}
  156. </td>
  157. <td>
  158. {% if c.description %}
  159. {{ c.description }}
  160. {% else %}
  161. <span class="text-muted">&mdash;</span>
  162. {% endif %}
  163. </td>
  164. </tr>
  165. {% empty %}
  166. <tr>
  167. <td colspan="6" class="text-muted">None</td>
  168. </tr>
  169. {% endfor %}
  170. </table>
  171. {% if perms.circuits.add_circuit %}
  172. <div class="panel-footer text-right">
  173. <a href="{% url 'circuits:circuit_add' %}?provider={{ provider.pk }}" class="btn btn-xs btn-primary">
  174. <span class="glyphicon glyphicon-plus" aria-hidden="true"></span> Add circuit
  175. </a>
  176. </div>
  177. {% endif %}
  178. </div>
  179. </div>
  180. </div>
  181. {% include 'inc/modal.html' with modal_name='graphs' %}
  182. {% endblock %}
  183. {% block javascript %}
  184. <script src="{% static 'js/graphs.js' %}?v{{ settings.VERSION }}"></script>
  185. {% endblock %}