1
0
mirror of https://gitlab.crans.org/bde/nk20 synced 2025-01-19 06:31:20 +00:00
nk20/apps/member/forms.py

162 lines
4.9 KiB
Python
Raw Normal View History

2020-02-18 21:30:26 +01:00
# Copyright (C) 2018-2020 by BDE ENS Paris-Saclay
2019-07-08 13:59:31 +02:00
# SPDX-License-Identifier: GPL-3.0-or-later
2020-02-18 21:30:26 +01:00
2020-03-07 22:28:59 +01:00
from django import forms
2020-04-05 05:17:28 +02:00
from django.contrib.auth.forms import AuthenticationForm
2019-08-11 16:22:52 +02:00
from django.contrib.auth.models import User
2020-08-03 13:33:25 +02:00
from django.forms import CheckboxSelectMultiple
2020-04-05 18:37:04 +02:00
from django.utils.translation import gettext_lazy as _
from note.models import NoteSpecial, Alias
2020-03-31 23:54:14 +02:00
from note_kfet.inputs import Autocomplete, AmountInput, DatePickerInput
2020-07-25 19:40:30 +02:00
from permission.models import PermissionMask, Role
2020-03-20 02:14:43 +01:00
2020-07-25 19:40:30 +02:00
from .models import Profile, Club, Membership
2019-07-08 13:59:31 +02:00
2020-03-19 16:12:52 +01:00
class CustomAuthenticationForm(AuthenticationForm):
permission_mask = forms.ModelChoiceField(
label="Masque de permissions",
queryset=PermissionMask.objects.order_by("rank"),
empty_label=None,
)
class UserForm(forms.ModelForm):
def _get_validation_exclusions(self):
# Django usernames can only contain letters, numbers, @, ., +, - and _.
# We want to allow users to have uncommon and unpractical usernames:
# That is their problem, and we have normalized aliases for us.
return super()._get_validation_exclusions() + ["username"]
class Meta:
model = User
fields = ('first_name', 'last_name', 'username', 'email',)
2019-08-11 16:22:52 +02:00
class ProfileForm(forms.ModelForm):
2019-08-11 17:52:41 +02:00
"""
A form for the extras field provided by the :model:`member.Profile` model.
2019-08-11 17:52:41 +02:00
"""
2020-08-05 23:19:17 +02:00
last_report = forms.DateField(required=False, disabled=True, label=_("Last report date"))
2020-03-07 22:28:59 +01:00
def save(self, commit=True):
if not self.instance.section or (("department" in self.changed_data
or "promotion" in self.changed_data) and "section" not in self.changed_data):
self.instance.section = self.instance.section_generated
return super().save(commit)
2019-08-11 16:22:52 +02:00
class Meta:
model = Profile
fields = '__all__'
exclude = ('user', 'email_confirmed', 'registration_valid', )
2019-08-11 23:25:27 +02:00
2020-02-18 12:31:15 +01:00
2019-08-11 23:25:27 +02:00
class ClubForm(forms.ModelForm):
def clean(self):
cleaned_data = super().clean()
if not self.instance.pk: # Creating a club
if Alias.objects.filter(normalized_name=Alias.normalize(self.cleaned_data["name"])).exists():
self.add_error('name', _("An alias with a similar name already exists."))
return cleaned_data
2019-08-11 23:25:27 +02:00
class Meta:
model = Club
2020-02-18 12:31:15 +01:00
fields = '__all__'
2020-03-31 01:03:30 +02:00
widgets = {
"membership_fee_paid": AmountInput(),
"membership_fee_unpaid": AmountInput(),
"parent_club": Autocomplete(
Club,
attrs={
'api_url': '/api/members/club/',
}
),
2020-03-31 23:54:14 +02:00
"membership_start": DatePickerInput(),
"membership_end": DatePickerInput(),
2020-03-31 01:03:30 +02:00
}
class MembershipForm(forms.ModelForm):
soge = forms.BooleanField(
label=_("Inscription paid by Société Générale"),
required=False,
help_text=_("Check this case is the Société Générale paid the inscription."),
)
2020-04-05 18:37:04 +02:00
credit_type = forms.ModelChoiceField(
queryset=NoteSpecial.objects,
label=_("Credit type"),
empty_label=_("No credit"),
required=False,
help_text=_("You can credit the note of the user."),
)
credit_amount = forms.IntegerField(
label=_("Credit amount"),
required=False,
initial=0,
widget=AmountInput(),
)
last_name = forms.CharField(
label=_("Last name"),
required=False,
)
first_name = forms.CharField(
label=_("First name"),
required=False,
)
bank = forms.CharField(
label=_("Bank"),
required=False,
)
class Meta:
model = Membership
fields = ('user', 'date_start')
2020-02-08 21:40:32 +01:00
# Le champ d'utilisateur est remplacé par un champ d'auto-complétion.
# Quand des lettres sont tapées, une requête est envoyée sur l'API d'auto-complétion
# et récupère les noms d'utilisateur valides
2020-02-08 20:39:37 +01:00
widgets = {
2020-02-18 12:31:15 +01:00
'user':
Autocomplete(
User,
2020-03-07 22:28:59 +01:00
attrs={
'api_url': '/api/user/',
'name_field': 'username',
'placeholder': 'Nom ...',
2020-03-07 22:28:59 +01:00
},
),
2020-03-31 23:54:14 +02:00
'date_start': DatePickerInput(),
2020-02-08 20:39:37 +01:00
}
2020-08-01 16:07:47 +02:00
class MembershipRolesForm(forms.ModelForm):
user = forms.ModelChoiceField(
queryset=User.objects,
label=_("User"),
disabled=True,
widget=Autocomplete(
2020-08-01 16:07:47 +02:00
User,
attrs={
'api_url': '/api/user/',
'name_field': 'username',
'placeholder': 'Nom ...',
},
),
)
roles = forms.ModelMultipleChoiceField(
queryset=Role.objects.filter(weirole=None).all(),
label=_("Roles"),
2020-08-03 13:33:25 +02:00
widget=CheckboxSelectMultiple(),
)
class Meta:
model = Membership
2020-08-01 16:07:47 +02:00
fields = ('user', 'roles')