1
0
mirror of https://github.com/netbox-community/netbox.git synced 2024-05-10 07:54:54 +00:00

144 lines
3.6 KiB
Python
Raw Normal View History

2020-10-16 10:39:13 -04:00
import django_tables2 as tables
from dcim.models import Location, Region, Site, SiteGroup
from tenancy.tables import TenantColumn
2021-04-06 09:42:36 -04:00
from utilities.tables import (
2022-01-06 16:53:24 -05:00
ActionsColumn, BaseTable, ButtonsColumn, ChoiceFieldColumn, LinkedCountColumn, MarkdownColumn, MPTTColumn,
TagColumn, ToggleColumn,
2021-04-06 09:42:36 -04:00
)
from .template_code import LOCATION_ELEVATIONS
2020-10-16 10:39:13 -04:00
__all__ = (
'LocationTable',
2020-10-16 10:39:13 -04:00
'RegionTable',
'SiteTable',
'SiteGroupTable',
2020-10-16 10:39:13 -04:00
)
#
# Regions
#
class RegionTable(BaseTable):
pk = ToggleColumn()
name = MPTTColumn(
linkify=True
)
2021-04-06 09:42:36 -04:00
site_count = LinkedCountColumn(
viewname='dcim:site_list',
url_params={'region_id': 'pk'},
2020-10-16 10:39:13 -04:00
verbose_name='Sites'
)
tags = TagColumn(
url_name='dcim:region_list'
)
2022-01-06 16:53:24 -05:00
actions = ActionsColumn()
2020-10-16 10:39:13 -04:00
class Meta(BaseTable.Meta):
model = Region
2021-11-03 10:29:02 -04:00
fields = ('pk', 'id', 'name', 'slug', 'site_count', 'description', 'tags', 'actions')
2020-10-16 10:39:13 -04:00
default_columns = ('pk', 'name', 'site_count', 'description', 'actions')
#
# Site groups
#
class SiteGroupTable(BaseTable):
pk = ToggleColumn()
name = MPTTColumn(
linkify=True
)
2021-04-06 09:42:36 -04:00
site_count = LinkedCountColumn(
viewname='dcim:site_list',
url_params={'group_id': 'pk'},
verbose_name='Sites'
)
tags = TagColumn(
url_name='dcim:sitegroup_list'
)
2022-01-06 16:53:24 -05:00
actions = ActionsColumn()
class Meta(BaseTable.Meta):
model = SiteGroup
2021-11-03 10:29:02 -04:00
fields = ('pk', 'id', 'name', 'slug', 'site_count', 'description', 'tags', 'actions')
default_columns = ('pk', 'name', 'site_count', 'description', 'actions')
2020-10-16 10:39:13 -04:00
#
# Sites
#
class SiteTable(BaseTable):
pk = ToggleColumn()
name = tables.Column(
linkify=True
2020-10-16 10:39:13 -04:00
)
status = ChoiceFieldColumn()
region = tables.Column(
linkify=True
)
group = tables.Column(
linkify=True
)
2021-10-24 23:42:47 -05:00
asn_count = LinkedCountColumn(
2021-11-04 16:29:43 -04:00
accessor=tables.A('asns.count'),
2021-10-24 23:42:47 -05:00
viewname='ipam:asn_list',
url_params={'site_id': 'pk'},
verbose_name='ASNs'
)
tenant = TenantColumn()
comments = MarkdownColumn()
2020-10-16 10:39:13 -04:00
tags = TagColumn(
url_name='dcim:site_list'
)
class Meta(BaseTable.Meta):
model = Site
fields = (
2021-11-03 12:05:11 -05:00
'pk', 'id', 'name', 'slug', 'status', 'facility', 'region', 'group', 'tenant', 'asn_count', 'time_zone',
'description', 'physical_address', 'shipping_address', 'latitude', 'longitude', 'comments', 'tags',
2020-10-16 10:39:13 -04:00
)
2021-11-04 16:29:43 -04:00
default_columns = ('pk', 'name', 'status', 'facility', 'region', 'group', 'tenant', 'description')
#
# Locations
#
class LocationTable(BaseTable):
pk = ToggleColumn()
name = MPTTColumn(
linkify=True
)
site = tables.Column(
linkify=True
)
tenant = TenantColumn()
rack_count = LinkedCountColumn(
viewname='dcim:rack_list',
url_params={'location_id': 'pk'},
verbose_name='Racks'
)
device_count = LinkedCountColumn(
viewname='dcim:device_list',
url_params={'location_id': 'pk'},
verbose_name='Devices'
)
tags = TagColumn(
url_name='dcim:location_list'
)
actions = ButtonsColumn(
model=Location,
prepend_template=LOCATION_ELEVATIONS
)
class Meta(BaseTable.Meta):
model = Location
fields = (
2021-11-03 10:29:02 -04:00
'pk', 'id', 'name', 'site', 'tenant', 'rack_count', 'device_count', 'description', 'slug', 'tags',
'actions',
)
default_columns = ('pk', 'name', 'site', 'tenant', 'rack_count', 'device_count', 'description', 'actions')