From 1ba6f50db25321f2a89d35620200b498f96c0dbd Mon Sep 17 00:00:00 2001 From: Abhimanyu Saharan Date: Wed, 18 Jan 2023 17:04:10 +0530 Subject: [PATCH] updated templates --- netbox/dcim/views.py | 19 +++++++++++++++++- netbox/templates/dcim/devicerole.html | 7 ------- netbox/templates/dcim/devicerole/devices.html | 20 +++++++++++++++++++ .../dcim/devicerole/virtual_machines.html | 20 +++++++++++++++++++ 4 files changed, 58 insertions(+), 8 deletions(-) create mode 100644 netbox/templates/dcim/devicerole/devices.html create mode 100644 netbox/templates/dcim/devicerole/virtual_machines.html diff --git a/netbox/dcim/views.py b/netbox/dcim/views.py index 3ba24b351..585237be0 100644 --- a/netbox/dcim/views.py +++ b/netbox/dcim/views.py @@ -1738,13 +1738,30 @@ class DeviceRoleView(generic.ObjectView): } +@register_model_view(DeviceRole, 'devices', path='devices') +class DeviceRoleDevicesView(generic.ObjectChildrenView): + queryset = DeviceRole.objects.all() + child_model = Device + table = tables.DeviceTable + filterset = filtersets.DeviceFilterSet + template_name = 'dcim/devicerole/devices.html' + tab = ViewTab( + label=_('Devices'), + badge=lambda obj: obj.devices.count(), + permission='dcim.view_device', + weight=400 + ) + + def get_children(self, request, parent): + return Device.objects.restrict(request.user, 'view').filter(device_role=parent) + @register_model_view(DeviceRole, 'virtual_machines', path='virtual-machines') class DeviceRoleVirtualMachinesView(generic.ObjectChildrenView): queryset = DeviceRole.objects.all() child_model = VirtualMachine table = VirtualMachineTable filterset = VirtualMachineFilterSet - template_name = 'virtualization/cluster/virtual_machines.html' + template_name = 'dcim/devicerole/virtual_machines.html' tab = ViewTab( label=_('Virtual machines'), badge=lambda obj: obj.virtual_machines.count(), diff --git a/netbox/templates/dcim/devicerole.html b/netbox/templates/dcim/devicerole.html index 610c53071..6724333d9 100644 --- a/netbox/templates/dcim/devicerole.html +++ b/netbox/templates/dcim/devicerole.html @@ -71,13 +71,6 @@
-
-
Devices
-
- {% render_table devices_table 'inc/table.html' %} - {% include 'inc/paginator.html' with paginator=devices_table.paginator page=devices_table.page %} -
-
{% plugin_full_width_page object %}
diff --git a/netbox/templates/dcim/devicerole/devices.html b/netbox/templates/dcim/devicerole/devices.html new file mode 100644 index 000000000..d7a69f013 --- /dev/null +++ b/netbox/templates/dcim/devicerole/devices.html @@ -0,0 +1,20 @@ +{% extends 'dcim/devicerole.html' %} +{% load helpers %} +{% load render_table from django_tables2 %} + +{% block content %} + {% include 'inc/table_controls_htmx.html' with table_modal='DeviceTable_config' %} +
+ {% csrf_token %} +
+
+ {% include 'htmx/table.html' %} +
+
+
+{% endblock content %} + +{% block modals %} + {{ block.super }} + {% table_config_form table %} +{% endblock modals %} \ No newline at end of file diff --git a/netbox/templates/dcim/devicerole/virtual_machines.html b/netbox/templates/dcim/devicerole/virtual_machines.html new file mode 100644 index 000000000..d94e86839 --- /dev/null +++ b/netbox/templates/dcim/devicerole/virtual_machines.html @@ -0,0 +1,20 @@ +{% extends 'dcim/devicerole.html' %} +{% load helpers %} +{% load render_table from django_tables2 %} + +{% block content %} + {% include 'inc/table_controls_htmx.html' with table_modal='VirtualMachineTable_config' %} +
+ {% csrf_token %} +
+
+ {% include 'htmx/table.html' %} +
+
+
+{% endblock content %} + +{% block modals %} + {{ block.super }} + {% table_config_form table %} +{% endblock modals %} \ No newline at end of file