| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- {% extends 'generic/object.html' %}
- {% load helpers %}
- {% load plugins %}
- {% load tz %}
- {% load i18n %}
- {% block breadcrumbs %}
- {{ block.super }}
- {% if object.region %}
- {% for region in object.region.get_ancestors %}
- <li class="breadcrumb-item"><a href="{% url 'dcim:site_list' %}?region_id={{ region.pk }}">{{ region }}</a></li>
- {% endfor %}
- <li class="breadcrumb-item"><a href="{% url 'dcim:site_list' %}?region_id={{ object.region.pk }}">{{ object.region }}</a></li>
- {% elif object.group %}
- {% for group in object.group.get_ancestors %}
- <li class="breadcrumb-item"><a href="{% url 'dcim:site_list' %}?group_id={{ group.pk }}">{{ group }}</a></li>
- {% endfor %}
- <li class="breadcrumb-item"><a href="{% url 'dcim:site_list' %}?group_id={{ object.group.pk }}">{{ object.group }}</a></li>
- {% endif %}
- {% endblock %}
- {% block content %}
- <div class="row">
- <div class="col col-md-6">
- <div class="card">
- <h5 class="card-header">{% trans "Site" %}</h5>
- <div class="card-body">
- <table class="table table-hover attr-table">
- <tr>
- <th scope="row">{% trans "Region" %}</th>
- <td>
- {% if object.region %}
- {% for region in object.region.get_ancestors %}
- {{ region|linkify }} /
- {% endfor %}
- {{ object.region|linkify }}
- {% else %}
- {{ ''|placeholder }}
- {% endif %}
- </td>
- </tr>
- <tr>
- <th scope="row">{% trans "Group" %}</th>
- <td>
- {% if object.group %}
- {% for group in object.group.get_ancestors %}
- {{ group|linkify }} /
- {% endfor %}
- {{ object.group|linkify }}
- {% else %}
- {{ ''|placeholder }}
- {% endif %}
- </td>
- </tr>
- <tr>
- <th scope="row">{% trans "Status" %}</th>
- <td>{% badge object.get_status_display bg_color=object.get_status_color %}</td>
- </tr>
- <tr>
- <th scope="row">{% trans "Tenant" %}</th>
- <td>
- {% if object.tenant.group %}
- {{ object.tenant.group|linkify }} /
- {% endif %}
- {{ object.tenant|linkify|placeholder }}
- </td>
- </tr>
- <tr>
- <th scope="row">{% trans "Facility" %}</th>
- <td>{{ object.facility|placeholder }}</td>
- </tr>
- <tr>
- <th scope="row">{% trans "Description" %}</th>
- <td>{{ object.description|placeholder }}</td>
- </tr>
- <tr>
- <th scope="row">{% trans "Time Zone" %}</th>
- <td>
- {% if object.time_zone %}
- {{ object.time_zone }} ({% trans "UTC" %} {{ object.time_zone|tzoffset }})<br />
- <small class="text-muted">{% trans "Site time" %}: {% timezone object.time_zone %}{% annotated_now %}{% endtimezone %}</small>
- {% else %}
- {{ ''|placeholder }}
- {% endif %}
- </td>
- </tr>
- <tr>
- <th scope="row">{% trans "Physical Address" %}</th>
- <td class="position-relative">
- {% if object.physical_address %}
- {% if config.MAPS_URL %}
- <div class="position-absolute top-50 end-0 translate-middle-y noprint">
- <a href="{{ config.MAPS_URL }}{{ object.physical_address|urlencode }}" target="_blank" class="btn btn-primary btn-sm">
- <i class="mdi mdi-map-marker"></i> {% trans "Map" %}
- </a>
- </div>
- {% endif %}
- <span>{{ object.physical_address|linebreaksbr }}</span>
- {% else %}
- {{ ''|placeholder }}
- {% endif %}
- </td>
- </tr>
- <tr>
- <th scope="row">{% trans "Shipping Address" %}</th>
- <td>{{ object.shipping_address|linebreaksbr|placeholder }}</td>
- </tr>
- <tr>
- <th scope="row">{% trans "GPS Coordinates" %}</th>
- <td class="position-relative">
- {% if object.latitude and object.longitude %}
- {% if config.MAPS_URL %}
- <div class="position-absolute top-50 end-0 translate-middle-y noprint">
- <a href="{{ config.MAPS_URL }}{{ object.latitude }},{{ object.longitude }}" target="_blank" class="btn btn-primary btn-sm">
- <i class="mdi mdi-map-marker"></i> {% trans "Map It" %}
- </a>
- </div>
- {% endif %}
- <span>{{ object.latitude }}, {{ object.longitude }}</span>
- {% else %}
- {{ ''|placeholder }}
- {% endif %}
- </td>
- </tr>
- </table>
- </div>
- </div>
- {% include 'inc/panels/custom_fields.html' %}
- {% include 'inc/panels/tags.html' %}
- {% include 'inc/panels/comments.html' %}
- {% plugin_left_page object %}
- </div>
- <div class="col col-md-6">
- {% include 'inc/panels/related_objects.html' with filter_name='site_id' %}
- {% include 'inc/panels/image_attachments.html' %}
- {% plugin_right_page object %}
- </div>
- </div>
- <div class="row">
- <div class="col col-md-12">
- <div class="card">
- <h5 class="card-header">Locations</h5>
- <div class="card-body htmx-container table-responsive"
- hx-get="{% url 'dcim:location_list' %}?site_id={{ object.pk }}"
- hx-trigger="load"
- ></div>
- {% if perms.dcim.add_location %}
- <div class="card-footer text-end noprint">
- <a href="{% url 'dcim:location_add' %}?site={{ object.pk }}&return_url={{ object.get_absolute_url }}" class="btn btn-primary btn-sm">
- <i class="mdi mdi-plus-thick" aria-hidden="true"></i> {% trans "Add a Location" %}
- </a>
- </div>
- {% endif %}
- </div>
- <div class="card">
- <h5 class="card-header">Non-Racked Devices</h5>
- <div class="card-body htmx-container table-responsive"
- hx-get="{% url 'dcim:device_list' %}?site_id={{ object.pk }}&rack_id=null&parent_bay_id=null"
- hx-trigger="load"
- ></div>
- {% if perms.dcim.add_device %}
- <div class="card-footer text-end noprint">
- <a href="{% url 'dcim:device_add' %}?site={{ object.pk }}&return_url={{ object.get_absolute_url }}" class="btn btn-primary btn-sm">
- <i class="mdi mdi-plus-thick" aria-hidden="true"></i> {% trans "Add a Device" %}
- </a>
- </div>
- {% endif %}
- </div>
- {% plugin_full_width_page object %}
- </div>
- </div>
- {% endblock %}
|