mirror of
https://github.com/netbox-community/netbox.git
synced 2024-05-10 07:54:54 +00:00
* Remove dark mode styling * Condense & rename light mode stylesheet * Upgrade to Bootstrap 5.3.2 * Swap out Bootstrap for Tabler; remove custom styling * Update base page layout for Tabler * Update login page * Bump node to v18 * Update button styles * Update object list view * Tweak navbar size * Clean up dashboard widgets * Ditch separate stylesheet for print media * Remove simplebar * Remove obsolete sidebar styling * Clean up object view template * Clean up object edit template * Standardize primary button sizing * Clean up object list styling * Add buttons for add & import to navigation menu * Fix global search bar * Fix slim-select form widget styling * Fix toast styling * Set base fonts * Clean up paginator styling * Clean up navigation menu group headings * Clean up footer links * Clean up card styles * Move SVG styles to a designated directory * Restructure SCSS files * Remove obsolete/redundant dependencies * Fix icon spacing * Update background color classes * Tweak banner & footer styling and spacing * Fix badge background colors in table content * Bump @types/bootstrap to 5.2.10 * Clean up form layouts * Fix object selector button style * Fix icon padding inside small buttons * Fix icon & badge spacing inside buttons and tabs * Hide paginator for empty pages * Fix hover color for list items (Tabler bug #1694) * Fix width of checkbox column in empty tables * Clean up bulk edit template * Fix border color of reslug button * Package & serve Google fonts locally * Fix tab styling * Reduce vetical space at top of dashboard * Remove obsolete content-wrapper template block * Fix icon spacing in dropdown menu items * Fix color label sizing * Separate bulk delete form & object list into tabs * Fix styling of filter group headings * Fix styling for object changelog & journal views * Standardize ordering & styling of action buttons * Fix designation of active menu item * Automatically expand menu section containing the active link * Clean up nav menu styling * Remove button colors; hide buttons except on hover/active * Highlight menu group containing the active item * Update & standardize alert styling * Refactor base templates to ensure consistent display of header content * Tweak styling for links inside badges * Clean up top menu * Fix JSON/YAML toggles for config context data * Fix object template header * Constrain tabs to container-xl; tweak header margins * Fix object identifier styling * Fix positioning of card header buttons * Remove padding from HTMX tables inside cards * Ensure consistent use of row headings in attribute tables * Remove padding surrounding tables inside cards * Remove obsolete CSS classes * Misc cleanup of old styling * Refactor 'controls' template block; ditch old classes * Fix login button sizing * Limit object edit form width * Append asterisk to required form field labels * Remove obsolete styling * Remove obsolete styling * Fix position of progress bar outside label * Fix alignment of delete button in report/script lists * Fix <pre> styling * Clean up page headers * Replace SVG icons with Material Design icons * Restore dark mode togle functionality * Fix top navbar background color under dark mode * Rebuild static assets
123 lines
5.2 KiB
HTML
123 lines
5.2 KiB
HTML
{% extends 'base/layout.html' %}
|
|
{% load helpers %}
|
|
{% load i18n %}
|
|
|
|
{% block title %}
|
|
{% endblock %}
|
|
|
|
{% block content %}
|
|
<h2>
|
|
{% blocktrans trimmed with object_type=object|meta:"verbose_name"|bettertitle %}
|
|
Cable Trace for {{ object_type }} {{ object }}
|
|
{% endblocktrans %}
|
|
</h2>
|
|
|
|
<div class="row">
|
|
|
|
{# Cable trace SVG & options #}
|
|
<div class="col col-md-5">
|
|
{% if path %}
|
|
<div class="text-center my-3">
|
|
<object data="{{ svg_url }}" class="rack_elevation"></object>
|
|
<div>
|
|
<a class="btn btn-outline-primary my-3" href="{{ svg_url }}">
|
|
<i class="mdi mdi-file-download"></i> {% trans "Download SVG" %}
|
|
</a>
|
|
</div>
|
|
</div>
|
|
<div class="trace-end">
|
|
{% if path.is_split and path.get_asymmetric_nodes %}
|
|
<h3 class="text-danger">{% trans "Asymmetric Path" %}!</h3>
|
|
<p>{% trans "The nodes below have no links and result in an asymmetric path" %}:</p>
|
|
<ul class="text-start">
|
|
{% for next_node in path.get_asymmetric_nodes %}
|
|
<li class="text-muted">{{ next_node|linkify }}</li>
|
|
{% endfor %}
|
|
</ul>
|
|
{% elif path.is_split %}
|
|
<h3 class="text-danger">{% trans "Path split" %}!</h3>
|
|
<p>{% trans "Select a node below to continue" %}:</p>
|
|
<ul class="text-start">
|
|
{% for next_node in path.get_split_nodes %}
|
|
{% if next_node.cable %}
|
|
{% with viewname=next_node|viewname:"trace" %}
|
|
<li>
|
|
<a href="{% url viewname pk=next_node.pk %}">{{ next_node|meta:"verbose_name"|bettertitle }} {{ next_node }}</a>
|
|
({% trans "Cable" %} {{ next_node.cable|linkify }})
|
|
</li>
|
|
{% endwith %}
|
|
{% else %}
|
|
<li class="text-muted">{{ next_node }}</li>
|
|
{% endif %}
|
|
{% endfor %}
|
|
</ul>
|
|
{% else %}
|
|
<h3 class="text-center text-success">{% trans "Trace Completed" %}</h3>
|
|
<table class="table">
|
|
<tr>
|
|
<th scope="row">{% trans "Total segments" %}</th>
|
|
<td>{{ path.segment_count }}</td>
|
|
</tr>
|
|
<tr>
|
|
<th scope="row">{% trans "Total length" %}</th>
|
|
<td>
|
|
{% if total_length %}
|
|
{{ total_length|floatformat:"-2" }}{% if not is_definitive %}+{% endif %} {% trans "Meters" %} /
|
|
{{ total_length|meters_to_feet|floatformat:"-2" }} {% trans "Feet" %}
|
|
{% else %}
|
|
{{ ''|placeholder }}
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
{% endif %}
|
|
</div>
|
|
{% else %}
|
|
<h3 class="text-center text-muted my-3">
|
|
{% trans "No paths found" %}
|
|
</h3>
|
|
{% endif %}
|
|
</div>
|
|
|
|
{# Related paths #}
|
|
<div class="col col-md-7">
|
|
<div class="card">
|
|
<h5 class="card-header">{% trans "Related Paths" %}</h5>
|
|
<table class="table table-hover">
|
|
<thead>
|
|
<tr>
|
|
<th>{% trans "Origin" %}</th>
|
|
<th>{% trans "Destination" %}</th>
|
|
<th>{% trans "Segments" %}</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{% for cablepath in related_paths %}
|
|
<tr{% if cablepath.pk == path.pk %} class="info"{% endif %}>
|
|
<td>
|
|
<a href="?cablepath_id={{ cablepath.pk }}">{{ cablepath.origins|join:", " }}</a>
|
|
</td>
|
|
<td>
|
|
{% if cablepath.destinations %}
|
|
{{ cablepath.destinations|join:", " }}
|
|
{% else %}
|
|
<span class="text-muted">{% trans "Incomplete" %}</span>
|
|
{% endif %}
|
|
</td>
|
|
<td>
|
|
{{ cablepath.segment_count }}
|
|
</td>
|
|
</tr>
|
|
{% empty %}
|
|
<td colspan="3" class="text-muted">
|
|
{% trans "None found" %}
|
|
</td>
|
|
{% endfor %}
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
{% endblock %}
|