Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Turn switches in user host table into links
Browse files Browse the repository at this point in the history
Refs #335
lukasjuhrich committed Jan 28, 2024
1 parent daf08ee commit a39324c
Showing 4 changed files with 32 additions and 8 deletions.
17 changes: 11 additions & 6 deletions web/blueprints/host/__init__.py
Original file line number Diff line number Diff line change
@@ -20,7 +20,7 @@
from web.blueprints.helpers.user import get_user_or_404
from web.blueprints.host.forms import InterfaceForm, HostForm
from web.blueprints.host.tables import InterfaceTable, HostTable, HostRow, InterfaceRow
from web.table.table import TableResponse, BtnColResponse
from web.table.table import TableResponse, BtnColResponse, LinkColResponse

bp = Blueprint('host', __name__)
access = BlueprintAccess(bp, required_properties=['user_show'])
@@ -330,17 +330,22 @@ def default_response() -> ResponseReturnValue:
def _host_row(host: Host, user_id: int) -> HostRow:
if host.room:
patch_ports = host.room.connected_patch_ports
switches = ", ".join(
p.switch_port.switch.host.name or "<unnamed switch>" for p in patch_ports
)
switches = [p.switch_port.switch.host for p in patch_ports]
switch_links = [
LinkColResponse(
href=url_for("infrastructure.switch_show", switch_id=s.id),
title=s.name or f"<unnamed switch #{s.id}>",
)
for s in switches
]
ports = ", ".join(p.switch_port.name for p in patch_ports)
else:
switches = None
switch_links = []
ports = None
return HostRow(
id=host.id,
name=host.name,
switch=switches,
switch=switch_links,
port=ports,
actions=[
BtnColResponse(
6 changes: 4 additions & 2 deletions web/blueprints/host/tables.py
Original file line number Diff line number Diff line change
@@ -11,14 +11,16 @@
button_toolbar,
MultiBtnColumn,
BtnColResponse,
MultiLinkColumn,
LinkColResponse,
)


class HostTable(BootstrapTable):
"""A table for displaying hosts
"""
name = Column("Name")
switch = Column("Switch")
switch = MultiLinkColumn("Switch")
port = Column("SwitchPort")
actions = MultiBtnColumn("Aktionen", hide_if=no_hosts_change, width=3)
interfaces_table_link = Column("", hide_if=lambda: True)
@@ -49,7 +51,7 @@ def toolbar(self) -> HasDunderStr | None:

class HostRow(BaseModel):
name: str | None = None
switch: str | None = None
switch: list[LinkColResponse] | None = None
port: str | None = None
actions: list[BtnColResponse]
interfaces_table_link: str
10 changes: 10 additions & 0 deletions web/resources/js/table.js
Original file line number Diff line number Diff line change
@@ -174,6 +174,16 @@ export function multiBtnFormatter(value, row, index) {
return btnFormatter(value, row, index);
}

export function multiLinkFormatter(value, row, index) {
if (!value) {
return;
}
if (Array.isArray(value)) {
return value.map(v => linkFormatter(v, row, index)).join('&nbsp;');
}
return linkFormatter(value, row, index);
}

export function listFormatter(value, row, index) {
if (!value) {
return;
7 changes: 7 additions & 0 deletions web/table/table.py
Original file line number Diff line number Diff line change
@@ -191,6 +191,13 @@ def value(
...


@custom_formatter_column("table.multiLinkFormatter")
class MultiLinkColumn(Column):
def __init__(self, *a: t.Any, **kw: t.Any) -> None:
kw.setdefault("sortable", False)
super().__init__(*a, **kw)



@custom_formatter_column('table.dateFormatter')
class DateColumn(Column):

0 comments on commit a39324c

Please sign in to comment.