fix prefix layout

This commit is contained in:
checktheroads 2021-03-13 14:26:12 -07:00
parent f65f924011
commit 9e51ddd8d8

View File

@ -31,161 +31,159 @@
{% endblock %} {% endblock %}
{% block tab_items %}
<li role="presentation" class="nav-item">
<a class="nav-link{% if not active_tab %} active{% endif %}" href="{% url 'ipam:prefix' pk=object.pk %}">
Prefix
</a>
</li>
<li role="presentation" class="nav-item">
<a class="nav-link{% if active_tab %} active{% endif %}" href="{% url 'ipam:prefix_prefixes' pk=object.pk %}">
Child Prefixes <span class="badge bg-primary">{{ object.get_child_prefixes.count }}</span>
</a>
</li>
{% if perms.ipam.view_ipaddress and object.status != 'container' %}
<li role="presentation" class="nav-item">
<a class="nav-link{% if active_tab %} active{% endif %}" href="{% url 'ipam:prefix_ipaddresses' pk=object.pk %}">
IP Addresses <span class="badge bg-primary">{{ object.get_child_ips.count }}</span>
</a>
</li>
{% endif %}
{% if perms.extras.view_objectchange %}
<li role="presentation" class="nav-item">
<a
class="nav-link{% if active_tab == 'changelog' %} active{% endif %}"
href="{% url 'ipam:prefix_changelog' pk=object.pk %}"
>
Change Log
</a>
</li>
{% endif %}
{% endblock %}
{% block content %} {% block content %}
{% block tabs %} <div class="row">
<ul class="nav nav-tabs mb-3" role="tablist"> <div class="col-md-5">
<li role="presentation" class="nav-item"> <div class="card">
<a class="nav-link{% if not active_tab %} active{% endif %}" href="{% url 'ipam:prefix' pk=object.pk %}"> <h5 class="card-header">
Prefix Prefix
</a> </h5>
</li> <div class="card-body">
<li role="presentation" class="nav-item"> <table class="table table-hover attr-table">
<a class="nav-link{% if active_tab %} active{% endif %}" href="{% url 'ipam:prefix_prefixes' pk=object.pk %}"> <tr>
Child Prefixes <span class="badge bg-primary">{{ object.get_child_prefixes.count }}</span> <td colspan="2">
</a> <span class="badge bg-{{ object.get_status_class }}">{{ object.get_status_display }}</span>
</li> {% if object.is_pool %}
{% if perms.ipam.view_ipaddress and object.status != 'container' %} <span class="badge bg-success">Is a Pool</span>
<li role="presentation" class="nav-item"> {% else %}
<a class="nav-link{% if active_tab %} active{% endif %}" href="{% url 'ipam:prefix_ipaddresses' pk=object.pk %}"> <span class="badge bg-info">Not a Pool</span>
IP Addresses <span class="badge bg-primary">{{ object.get_child_ips.count }}</span> {% endif %}
</a> </td>
</li>
{% endif %}
{% if perms.extras.view_objectchange %}
<li role="presentation" class="nav-item">
<a
class="nav-link{% if active_tab == 'changelog' %} active{% endif %}"
href="{% url 'ipam:prefix_changelog' pk=object.pk %}"
>
Change Log
</a>
</li>
{% endif %}
</ul>
{% endblock %}
<div class="row">
<div class="col-md-5">
<div class="card">
<h5 class="card-header">
Prefix
</h5>
<div class="card-body">
<table class="table table-hover attr-table">
<tr>
<td colspan="2">
<span class="badge bg-{{ object.get_status_class }}">{{ object.get_status_display }}</span>
{% if object.is_pool %}
<span class="badge bg-success">Is a Pool</span>
{% else %}
<span class="badge bg-info">Not a Pool</span>
{% endif %}
</td>
</tr> </tr>
<tr> <tr>
<th scope="row">Family</th> <th scope="row">Family</th>
<td>IPv{{ object.family }}</td> <td>IPv{{ object.family }}</td>
</tr> </tr>
<tr> <tr>
<th scope="row">VRF</th> <th scope="row">VRF</th>
<td> <td>
{% if object.vrf %} {% if object.vrf %}
<a href="{% url 'ipam:vrf' pk=object.vrf.pk %}">{{ object.vrf }}</a> ({{ object.vrf.rd }}) <a href="{% url 'ipam:vrf' pk=object.vrf.pk %}">{{ object.vrf }}</a> ({{ object.vrf.rd }})
{% else %} {% else %}
<span>Global</span> <span>Global</span>
{% endif %}
</td>
</tr>
<tr>
<th scope="row">Tenant</th>
<td>
{% if object.tenant %}
{% if object.tenant.group %}
<a href="{{ object.tenant.group.get_absolute_url }}">{{ object.tenant.group }}</a> /
{% endif %} {% endif %}
</td> <a href="{{ object.tenant.get_absolute_url }}">{{ object.tenant }}</a>
</tr> {% else %}
<tr> <span class="text-muted">None</span>
<th scope="row">Tenant</th> {% endif %}
<td> </td>
{% if object.tenant %} </tr>
{% if object.tenant.group %} <tr>
<a href="{{ object.tenant.group.get_absolute_url }}">{{ object.tenant.group }}</a> / <th scope="row">Aggregate</th>
{% endif %} <td>
<a href="{{ object.tenant.get_absolute_url }}">{{ object.tenant }}</a> {% if aggregate %}
{% else %} <a href="{% url 'ipam:aggregate' pk=aggregate.pk %}">{{ aggregate.prefix }}</a> ({{ aggregate.rir }})
<span class="text-muted">None</span> {% else %}
<span class="text-warning">None</span>
{% endif %}
</td>
</tr>
<tr>
<th scope="row">Site</th>
<td>
{% if object.site %}
{% if object.site.region %}
<a href="{{ object.site.region.get_absolute_url }}">{{ object.site.region }}</a> /
{% endif %} {% endif %}
</td> <a href="{{ object.site.get_absolute_url }}">{{ object.site }}</a>
</tr> {% else %}
<tr> <span class="text-muted">None</span>
<th scope="row">Aggregate</th> {% endif %}
<td> </td>
{% if aggregate %} </tr>
<a href="{% url 'ipam:aggregate' pk=aggregate.pk %}">{{ aggregate.prefix }}</a> ({{ aggregate.rir }}) <tr>
{% else %} <th scope="row">VLAN</th>
<span class="text-warning">None</span> <td>
{% if object.vlan %}
{% if object.vlan.group %}
<a href="{{ object.vlan.group.get_absolute_url }}">{{ object.vlan.group }}</a> /
{% endif %} {% endif %}
</td> <a href="{% url 'ipam:vlan' pk=object.vlan.pk %}">{{ object.vlan.display_name }}</a>
</tr> {% else %}
<tr> <span class="text-muted">None</span>
<th scope="row">Site</th> {% endif %}
<td> </td>
{% if object.site %} </tr>
{% if object.site.region %} <tr>
<a href="{{ object.site.region.get_absolute_url }}">{{ object.site.region }}</a> / <th scope="row">Role</th>
{% endif %} <td>
<a href="{{ object.site.get_absolute_url }}">{{ object.site }}</a> {% if object.role %}
{% else %} <a href="{% url 'ipam:prefix_list' %}?role={{ object.role.slug }}">{{ object.role }}</a>
<span class="text-muted">None</span> {% else %}
{% endif %} <span class="text-muted">None</span>
</td> {% endif %}
</tr> </td>
<tr> </tr>
<th scope="row">VLAN</th> <tr>
<td> <th scope="row">Description</th>
{% if object.vlan %} <td>{{ object.description|placeholder }}</td>
{% if object.vlan.group %} </tr>
<a href="{{ object.vlan.group.get_absolute_url }}">{{ object.vlan.group }}</a> / <tr>
{% endif %} <th scope="row">Utilization</th>
<a href="{% url 'ipam:vlan' pk=object.vlan.pk %}">{{ object.vlan.display_name }}</a> <td>{% utilization_graph object.get_utilization %}</td>
{% else %} </tr>
<span class="text-muted">None</span> </table>
{% endif %}
</td>
</tr>
<tr>
<th scope="row">Role</th>
<td>
{% if object.role %}
<a href="{% url 'ipam:prefix_list' %}?role={{ object.role.slug }}">{{ object.role }}</a>
{% else %}
<span class="text-muted">None</span>
{% endif %}
</td>
</tr>
<tr>
<th scope="row">Description</th>
<td>{{ object.description|placeholder }}</td>
</tr>
<tr>
<th scope="row">Utilization</th>
<td>{% utilization_graph object.get_utilization %}</td>
</tr>
</table>
</div>
</div> </div>
{% include 'inc/custom_fields_panel.html' %}
{% plugin_left_page object %}
</div>
<div class="col-md-7">
{% if duplicate_prefix_table.rows %}
{% include 'panel_table.html' with table=duplicate_prefix_table heading='Duplicate Prefixes' %}
{% endif %}
{% include 'panel_table.html' with table=parent_prefix_table heading='Parent Prefixes' %}
{% plugin_right_page object %}
</div> </div>
{% include 'inc/custom_fields_panel.html' %}
{% plugin_left_page object %}
</div> </div>
<div class="row my-3"> <div class="col-md-7">
<div class="col-md-5"> {% if duplicate_prefix_table.rows %}
{% include 'extras/inc/tags_panel.html' with tags=object.tags.all url='ipam:prefix_list' %} {% include 'panel_table.html' with table=duplicate_prefix_table heading='Duplicate Prefixes' %}
</div> {% endif %}
{% include 'panel_table.html' with table=parent_prefix_table heading='Parent Prefixes' %}
{% plugin_right_page object %}
</div> </div>
<div class="row"> </div>
<div class="col-md-12"> <div class="row my-3">
{% plugin_full_width_page object %} <div class="col-md-5">
</div> {% include 'extras/inc/tags_panel.html' with tags=object.tags.all url='ipam:prefix_list' %}
</div> </div>
</div>
<div class="row">
<div class="col-md-12">
{% plugin_full_width_page object %}
</div>
</div>
{% endblock %} {% endblock %}