nk20/apps/member/tables.py

188 lines
6.8 KiB
Python
Raw 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-02-18 20:30:26 +00:00
# SPDX-License-Identifier: GPL-3.0-or-later
2019-08-15 19:52:10 +00:00
from datetime import date
2019-08-15 19:52:10 +00:00
import django_tables2 as tables
2019-09-23 10:50:14 +00:00
from django.contrib.auth.models import User
2020-04-01 16:47:56 +00:00
from django.utils.translation import gettext_lazy as _
2020-04-01 01:42:19 +00:00
from django.urls import reverse_lazy
from django.utils.html import format_html
from note.templatetags.pretty_money import pretty_money
from note_kfet.middlewares import get_current_request
2020-04-01 01:42:19 +00:00
from permission.backends import PermissionBackend
2020-04-01 01:42:19 +00:00
from .models import Club, Membership
2020-02-18 20:14:29 +00:00
2020-02-18 11:31:15 +00:00
2019-08-15 19:52:10 +00:00
class ClubTable(tables.Table):
2020-04-06 06:58:39 +00:00
"""
List all clubs.
"""
2019-08-15 19:52:10 +00:00
class Meta:
2020-02-18 11:31:15 +00:00
attrs = {
'class': 'table table-condensed table-striped table-hover'
2020-02-18 11:31:15 +00:00
}
2020-06-02 07:37:25 +00:00
order_by = ('id',)
2019-08-15 19:52:10 +00:00
model = Club
template_name = 'django_tables2/bootstrap4.html'
2020-06-21 20:27:32 +00:00
fields = ('name', 'email',)
order_by = ('name',)
2020-02-18 11:31:15 +00:00
row_attrs = {
'class': 'table-row',
'id': lambda record: "row-" + str(record.pk),
2021-10-01 12:35:29 +00:00
'data-href': lambda record: record.pk,
'style': 'cursor:pointer',
2020-02-18 11:31:15 +00:00
}
2019-09-23 10:50:14 +00:00
class UserTable(tables.Table):
2020-04-06 06:58:39 +00:00
"""
List all users.
"""
2020-08-06 11:07:22 +00:00
alias = tables.Column()
section = tables.Column(accessor='profile__section', orderable=False)
2020-04-01 18:14:16 +00:00
# Override the column to let replace the URL
email = tables.EmailColumn(linkify=lambda record: "mailto:{}".format(record.email))
balance = tables.Column(accessor='note__balance', verbose_name=_("Balance"), orderable=False)
2020-04-01 18:14:16 +00:00
def render_email(self, record, value):
# Replace the email by a dash if the user can't see the profile detail
# Replace also the URL
if not PermissionBackend.check_perm(get_current_request(), "member.view_profile", record.profile):
value = ""
record.email = value
return value
def render_section(self, record, value):
return value \
if PermissionBackend.check_perm(get_current_request(), "member.view_profile", record.profile) \
else ""
def render_balance(self, record, value):
return pretty_money(value)\
if PermissionBackend.check_perm(get_current_request(), "note.view_note", record.note) else ""
2019-09-23 10:50:14 +00:00
class Meta:
2020-02-18 11:31:15 +00:00
attrs = {
'class': 'table table-condensed table-striped table-hover'
2020-02-18 11:31:15 +00:00
}
template_name = 'django_tables2/bootstrap4.html'
2020-08-06 11:07:22 +00:00
fields = ('last_name', 'first_name', 'username', 'alias', 'email')
2019-09-23 10:50:14 +00:00
model = User
2020-04-01 18:14:16 +00:00
row_attrs = {
'class': 'table-row',
2021-10-01 12:35:29 +00:00
'data-href': lambda record: record.pk,
'style': 'cursor:pointer',
2020-04-01 18:14:16 +00:00
}
2020-04-01 01:42:19 +00:00
class MembershipTable(tables.Table):
2020-04-06 06:58:39 +00:00
"""
List all memberships.
"""
2020-04-01 01:42:19 +00:00
roles = tables.Column(
attrs={
"td": {
"class": "text-truncate",
}
}
)
2020-04-06 06:58:39 +00:00
def render_user(self, value):
# If the user has the right, link the displayed user with the page of its detail.
s = value.username
if PermissionBackend.check_perm(get_current_request(), "auth.view_user", value):
2020-04-06 06:58:39 +00:00
s = format_html("<a href={url}>{name}</a>",
url=reverse_lazy('member:user_detail', kwargs={"pk": value.pk}), name=s)
return s
2020-04-01 16:47:56 +00:00
def render_club(self, value):
2020-04-06 06:58:39 +00:00
# If the user has the right, link the displayed club with the page of its detail.
2020-04-01 16:47:56 +00:00
s = value.name
if PermissionBackend.check_perm(get_current_request(), "member.view_club", value):
2020-04-01 16:47:56 +00:00
s = format_html("<a href={url}>{name}</a>",
url=reverse_lazy('member:club_detail', kwargs={"pk": value.pk}), name=s)
return s
def render_fee(self, value, record):
t = pretty_money(value)
# If it is required and if the user has the right, the renew button is displayed.
2020-08-25 14:44:01 +00:00
if record.club.membership_start is not None \
and record.date_start < record.club.membership_start:
if not Membership.objects.filter(
club=record.club,
user=record.user,
date_start__gte=record.club.membership_start,
date_end__lte=record.club.membership_end or date(9999, 12, 31),
2020-08-25 14:44:01 +00:00
).exists(): # If the renew is not yet performed
empty_membership = Membership(
club=record.club,
user=record.user,
date_start=date.today(),
date_end=date.today(),
fee=0,
)
if PermissionBackend.check_perm(get_current_request(),
"member.add_membership", empty_membership): # If the user has right
2020-08-25 14:44:01 +00:00
renew_url = reverse_lazy('member:club_renew_membership',
kwargs={"pk": record.pk})
t = format_html(
t + ' <a class="btn btn-sm btn-warning" title="{text}"'
' href="{renew_url}"><i class="fa fa-repeat"></i></a>',
renew_url=renew_url, text=_("Renew")
2020-04-01 16:47:56 +00:00
)
return t
2020-04-01 01:42:19 +00:00
def render_roles(self, record):
2020-04-06 06:58:39 +00:00
# If the user has the right to manage the roles, display the link to manage them
2020-04-01 01:42:19 +00:00
roles = record.roles.all()
s = ", ".join(str(role) for role in roles)
if PermissionBackend.check_perm(get_current_request(), "member.change_membership_roles", record):
2020-04-01 01:42:19 +00:00
s = format_html("<a href='" + str(reverse_lazy("member:club_manage_roles", kwargs={"pk": record.pk}))
+ "'>" + s + "</a>")
return s
class Meta:
attrs = {
2020-08-10 16:01:39 +00:00
'class': 'table table-condensed table-striped',
2020-04-01 01:42:19 +00:00
'style': 'table-layout: fixed;'
}
template_name = 'django_tables2/bootstrap4.html'
fields = ('user', 'club', 'date_start', 'date_end', 'roles', 'fee', )
model = Membership
2020-07-31 15:01:52 +00:00
class ClubManagerTable(tables.Table):
"""
List managers of a club.
"""
def render_user(self, value):
# If the user has the right, link the displayed user with the page of its detail.
s = value.username
if PermissionBackend.check_perm(get_current_request(), "auth.view_user", value):
2020-07-31 15:01:52 +00:00
s = format_html("<a href={url}>{name}</a>",
url=reverse_lazy('member:user_detail', kwargs={"pk": value.pk}), name=s)
return s
def render_roles(self, record):
roles = record.roles.all()
return ", ".join(str(role) for role in roles)
class Meta:
attrs = {
'class': 'table table-condensed table-striped table-hover',
'style': 'table-layout: fixed;'
}
template_name = 'django_tables2/bootstrap4.html'
2020-09-01 17:04:35 +00:00
fields = ('user', 'user__first_name', 'user__last_name', 'roles', )
2020-07-31 15:01:52 +00:00
model = Membership