88 lines
2.4 KiB
Python
88 lines
2.4 KiB
Python
import calendar
|
|
|
|
import django_tables2 as tables
|
|
|
|
from .models import HIDEvent
|
|
|
|
|
|
class UnitTimeTable(tables.Table):
|
|
members = tables.columns.Column()
|
|
members_delta = tables.columns.TemplateColumn(
|
|
"{{ value|floatformat:2}}%", verbose_name="Δ Members"
|
|
)
|
|
access_count = tables.columns.Column()
|
|
access_count_delta = tables.columns.TemplateColumn(
|
|
"{{ value|floatformat:2}}%", verbose_name="Δ Access Count"
|
|
)
|
|
|
|
class Meta:
|
|
fields = ("members", "members_delta", "access_count", "access_count_delta")
|
|
|
|
|
|
class DeniedAccessTable(tables.Table):
|
|
decoded_card_number = tables.Column(orderable=False)
|
|
name = tables.TemplateColumn(
|
|
"{{ record.forename|default:'' }} {{ record.surname|default:'' }}"
|
|
)
|
|
|
|
class Meta:
|
|
model = HIDEvent
|
|
|
|
fields = (
|
|
"timestamp",
|
|
"door",
|
|
"event_type",
|
|
"name",
|
|
"raw_card_number",
|
|
"decoded_card_number",
|
|
)
|
|
|
|
|
|
class MostActiveMembersTable(tables.Table):
|
|
name = tables.Column()
|
|
access_count = tables.Column()
|
|
|
|
|
|
class DetailByDayTable(tables.Table):
|
|
timestamp__date = tables.DateColumn(verbose_name="Date")
|
|
name = tables.Column()
|
|
access_count = tables.Column()
|
|
granted_access_count = tables.Column()
|
|
|
|
|
|
class BusiestDayOfWeekTable(tables.Table):
|
|
timestamp__week_day = tables.Column("Week Day")
|
|
events = tables.Column()
|
|
members = tables.Column()
|
|
|
|
def render_timestamp__week_day(self, value):
|
|
return calendar.day_name[(value - 2) % 7]
|
|
|
|
|
|
class BusiestTimeOfDayTable(tables.Table):
|
|
timestamp__hour = tables.TemplateColumn("{{ value }}:00", verbose_name="Hour")
|
|
events = tables.Column()
|
|
members = tables.Column()
|
|
|
|
|
|
class AssignedNfcCardsTable(tables.Table):
|
|
member__account_name = tables.Column("Name")
|
|
member__nfc_card_number = tables.Column("MW NFC Card")
|
|
access_user__nfc_cards = tables.TemplateColumn(
|
|
"""
|
|
{% if value %}
|
|
<ul>
|
|
{% for card in value %}
|
|
<li>{{ card.type }}: {{ card.id }}</li>
|
|
{% endfor %}
|
|
</ul>
|
|
{% else %}
|
|
???
|
|
{% endif %}
|
|
""",
|
|
empty_values=[[]],
|
|
verbose_name="UniFi Access Cards",
|
|
)
|
|
member__access_wood_shop = tables.BooleanColumn(verbose_name="Access Wood Shop")
|
|
member__access_metal_shop = tables.BooleanColumn(verbose_name="Access Metal Shop")
|