nk20/apps/activity/tables.py

149 lines
5.2 KiB
Python
Raw Permalink Normal View History

Update 131 files - /apps/activity/api/serializers.py - /apps/activity/api/urls.py - /apps/activity/api/views.py - /apps/activity/tests/test_activities.py - /apps/activity/__init__.py - /apps/activity/admin.py - /apps/activity/apps.py - /apps/activity/forms.py - /apps/activity/tables.py - /apps/activity/urls.py - /apps/activity/views.py - /apps/api/__init__.py - /apps/api/apps.py - /apps/api/serializers.py - /apps/api/tests.py - /apps/api/urls.py - /apps/api/views.py - /apps/api/viewsets.py - /apps/logs/signals.py - /apps/logs/apps.py - /apps/logs/__init__.py - /apps/logs/api/serializers.py - /apps/logs/api/urls.py - /apps/logs/api/views.py - /apps/member/api/serializers.py - /apps/member/api/urls.py - /apps/member/api/views.py - /apps/member/templatetags/memberinfo.py - /apps/member/__init__.py - /apps/member/admin.py - /apps/member/apps.py - /apps/member/auth.py - /apps/member/forms.py - /apps/member/hashers.py - /apps/member/signals.py - /apps/member/tables.py - /apps/member/urls.py - /apps/member/views.py - /apps/note/api/serializers.py - /apps/note/api/urls.py - /apps/note/api/views.py - /apps/note/models/__init__.py - /apps/note/static/note/js/consos.js - /apps/note/templates/note/mails/negative_balance.txt - /apps/note/templatetags/getenv.py - /apps/note/templatetags/pretty_money.py - /apps/note/tests/test_transactions.py - /apps/note/__init__.py - /apps/note/admin.py - /apps/note/apps.py - /apps/note/forms.py - /apps/note/signals.py - /apps/note/tables.py - /apps/note/urls.py - /apps/note/views.py - /apps/permission/api/serializers.py - /apps/permission/api/urls.py - /apps/permission/api/views.py - /apps/permission/templatetags/perms.py - /apps/permission/tests/test_oauth2.py - /apps/permission/tests/test_permission_denied.py - /apps/permission/tests/test_permission_queries.py - /apps/permission/tests/test_rights_page.py - /apps/permission/__init__.py - /apps/permission/admin.py - /apps/permission/backends.py - /apps/permission/apps.py - /apps/permission/decorators.py - /apps/permission/permissions.py - /apps/permission/scopes.py - /apps/permission/signals.py - /apps/permission/tables.py - /apps/permission/urls.py - /apps/permission/views.py - /apps/registration/tests/test_registration.py - /apps/registration/__init__.py - /apps/registration/apps.py - /apps/registration/forms.py - /apps/registration/tables.py - /apps/registration/tokens.py - /apps/registration/urls.py - /apps/registration/views.py - /apps/treasury/api/serializers.py - /apps/treasury/api/urls.py - /apps/treasury/api/views.py - /apps/treasury/templatetags/escape_tex.py - /apps/treasury/tests/test_treasury.py - /apps/treasury/__init__.py - /apps/treasury/admin.py - /apps/treasury/apps.py - /apps/treasury/forms.py - /apps/treasury/signals.py - /apps/treasury/tables.py - /apps/treasury/urls.py - /apps/treasury/views.py - /apps/wei/api/serializers.py - /apps/wei/api/urls.py - /apps/wei/api/views.py - /apps/wei/forms/surveys/__init__.py - /apps/wei/forms/surveys/base.py - /apps/wei/forms/surveys/wei2021.py - /apps/wei/forms/surveys/wei2022.py - /apps/wei/forms/surveys/wei2023.py - /apps/wei/forms/__init__.py - /apps/wei/forms/registration.py - /apps/wei/management/commands/export_wei_registrations.py - /apps/wei/management/commands/import_scores.py - /apps/wei/management/commands/wei_algorithm.py - /apps/wei/templates/wei/weilist_sample.tex - /apps/wei/tests/test_wei_algorithm_2021.py - /apps/wei/tests/test_wei_algorithm_2022.py - /apps/wei/tests/test_wei_algorithm_2023.py - /apps/wei/tests/test_wei_registration.py - /apps/wei/__init__.py - /apps/wei/admin.py - /apps/wei/apps.py - /apps/wei/tables.py - /apps/wei/urls.py - /apps/wei/views.py - /note_kfet/settings/__init__.py - /note_kfet/settings/base.py - /note_kfet/settings/development.py - /note_kfet/settings/secrets_example.py - /note_kfet/static/js/base.js - /note_kfet/admin.py - /note_kfet/inputs.py - /note_kfet/middlewares.py - /note_kfet/urls.py - /note_kfet/views.py - /note_kfet/wsgi.py - /entrypoint.sh
2024-02-07 01:26:49 +00:00
# Copyright (C) 2018-2024 by BDE ENS Paris-Saclay
2020-03-27 17:02:22 +00:00
# SPDX-License-Identifier: GPL-3.0-or-later
2020-08-06 15:41:30 +00:00
from django.utils import timezone
from django.utils.html import escape
from django.utils.safestring import mark_safe
2020-03-27 17:02:22 +00:00
from django.utils.translation import gettext_lazy as _
2024-08-01 12:49:52 +00:00
from note_kfet.middlewares import get_current_request
2020-03-27 20:18:27 +00:00
import django_tables2 as tables
from django_tables2 import A
2024-08-01 12:49:52 +00:00
from permission.backends import PermissionBackend
2020-03-28 00:45:13 +00:00
from note.templatetags.pretty_money import pretty_money
2020-03-28 01:09:10 +00:00
2024-08-01 12:49:52 +00:00
from .models import Activity, Entry, Guest, Opener
2020-03-27 17:02:22 +00:00
class ActivityTable(tables.Table):
2020-03-27 20:18:27 +00:00
name = tables.LinkColumn(
'activity:activity_detail',
args=[A('pk'), ],
)
2020-03-27 17:02:22 +00:00
class Meta:
attrs = {
'class': 'table table-condensed table-striped table-hover'
}
2020-08-30 21:54:54 +00:00
row_attrs = {
'class': lambda record: 'bg-success' if record.open else ('' if record.valid else 'bg-warning'),
'title': lambda record: _("The activity is currently open.") if record.open else
('' if record.valid else _("The validation of the activity is pending.")),
}
2020-03-27 17:02:22 +00:00
model = Activity
template_name = 'django_tables2/bootstrap4.html'
2020-03-27 20:18:27 +00:00
fields = ('name', 'activity_type', 'organizer', 'attendees_club', 'date_start', 'date_end', )
2020-03-27 17:02:22 +00:00
class GuestTable(tables.Table):
2020-03-27 20:18:27 +00:00
inviter = tables.LinkColumn(
'member:user_detail',
args=[A('inviter__user__pk'), ],
2020-03-27 20:18:27 +00:00
)
entry = tables.Column(
empty_values=(),
2020-08-30 21:54:54 +00:00
verbose_name=_("Remove"),
2020-03-27 20:18:27 +00:00
)
2020-03-27 17:02:22 +00:00
class Meta:
attrs = {
2020-08-30 21:54:54 +00:00
'class': 'table table-condensed table-striped'
2020-03-27 17:02:22 +00:00
}
model = Guest
template_name = 'django_tables2/bootstrap4.html'
2020-03-27 20:18:27 +00:00
fields = ("last_name", "first_name", "inviter", )
def render_entry(self, record):
2020-03-28 12:38:31 +00:00
if record.has_entry:
return str(_("Entered on ") + str(_("{:%Y-%m-%d %H:%M:%S}").format(record.entry.time, )))
return mark_safe('<button id="{id}" class="btn btn-danger btn-sm" onclick="remove_guest(this.id)"> '
'{delete_trans}</button>'.format(id=record.id, delete_trans=_("remove").capitalize()))
2020-03-28 00:45:13 +00:00
def get_row_class(record):
c = "table-row"
if isinstance(record, Guest):
if record.has_entry:
c += " table-success"
else:
c += " table-warning"
else:
qs = Entry.objects.filter(note=record.note, activity=record.activity, guest=None)
if qs.exists():
c += " table-success"
2020-08-06 15:41:30 +00:00
elif not record.note.user.memberships.filter(club=record.activity.attendees_club,
date_start__lte=timezone.now(),
date_end__gte=timezone.now()).exists():
c += " table-info"
elif record.note.balance < 0:
c += " table-danger"
return c
2020-03-28 00:45:13 +00:00
class EntryTable(tables.Table):
2020-03-28 01:08:29 +00:00
type = tables.Column(verbose_name=_("Type"))
2020-03-28 00:45:13 +00:00
2020-03-28 01:08:29 +00:00
last_name = tables.Column(verbose_name=_("Last name"))
2020-03-28 00:45:13 +00:00
2020-03-28 01:08:29 +00:00
first_name = tables.Column(verbose_name=_("First name"))
2020-03-28 00:45:13 +00:00
2020-03-28 01:08:29 +00:00
note_name = tables.Column(verbose_name=_("Note"))
2020-03-28 00:45:13 +00:00
2020-03-28 01:08:29 +00:00
balance = tables.Column(verbose_name=_("Balance"))
2020-03-28 00:45:13 +00:00
def render_note_name(self, value, record):
if hasattr(record, 'username'):
username = record.username
if username != value:
return mark_safe(escape(value) + " <em>aka.</em> " + escape(username))
2020-03-28 00:45:13 +00:00
return value
def render_balance(self, value):
return pretty_money(value)
class Meta:
attrs = {
'class': 'table table-condensed table-striped table-hover'
}
template_name = 'django_tables2/bootstrap4.html'
row_attrs = {
'class': lambda record: get_row_class(record),
2020-03-28 12:38:31 +00:00
'id': lambda record: "row-" + ("guest-" if isinstance(record, Guest) else "membership-") + str(record.pk),
'data-type': lambda record: "guest" if isinstance(record, Guest) else "membership",
'data-id': lambda record: record.pk if isinstance(record, Guest) else record.note.pk,
2020-03-28 12:38:31 +00:00
'data-inviter': lambda record: record.inviter.pk if isinstance(record, Guest) else "",
'data-last-name': lambda record: record.last_name,
'data-first-name': lambda record: record.first_name,
2020-03-28 00:45:13 +00:00
}
2024-08-01 12:49:52 +00:00
# function delete_button(id) provided in template file
DELETE_TEMPLATE = """
<button id="{{ record.pk }}" class="btn btn-danger btn-sm" onclick="delete_button(this.id)"> {{ delete_trans }}</button>
"""
class OpenerTable(tables.Table):
class Meta:
attrs = {
'class': 'table table condensed table-striped',
'id': "opener_table"
}
model = Opener
fields = ("opener",)
template_name = 'django_tables2/bootstrap4.html'
show_header = False
opener = tables.Column(attrs={'td': {'class': 'text-center'}})
delete_col = tables.TemplateColumn(
template_code=DELETE_TEMPLATE,
extra_context={"delete_trans": _('Delete')},
attrs={
'td': {
'class': lambda record: 'col-sm-1'
+ (' d-none' if not PermissionBackend.check_perm(
get_current_request(), "activity.delete_opener", record)
else '')}},
verbose_name=_("Delete"),)