mirror of
https://github.com/ae-utbm/sith.git
synced 2024-11-25 18:44:23 +00:00
Improve Club views
This commit is contained in:
parent
a14d940db2
commit
e2b0668ee8
@ -11,21 +11,24 @@ from club.models import Club, Membership
|
|||||||
from subscription.views import SubscriberMixin
|
from subscription.views import SubscriberMixin
|
||||||
|
|
||||||
class ClubListView(CanViewMixin, ListView):
|
class ClubListView(CanViewMixin, ListView):
|
||||||
|
"""
|
||||||
|
List the Clubs
|
||||||
|
"""
|
||||||
model = Club
|
model = Club
|
||||||
template_name = 'club/club_list.jinja'
|
template_name = 'club/club_list.jinja'
|
||||||
|
|
||||||
class ClubView(CanViewMixin, DetailView):
|
class ClubView(CanViewMixin, DetailView):
|
||||||
|
"""
|
||||||
|
Front page of a Club
|
||||||
|
"""
|
||||||
model = Club
|
model = Club
|
||||||
pk_url_kwarg = "club_id"
|
pk_url_kwarg = "club_id"
|
||||||
template_name = 'club/club_detail.jinja'
|
template_name = 'club/club_detail.jinja'
|
||||||
|
|
||||||
class ClubEditView(CanEditMixin, UpdateView):
|
|
||||||
model = Club
|
|
||||||
pk_url_kwarg = "club_id"
|
|
||||||
fields = ['address']
|
|
||||||
template_name = 'club/club_edit.jinja'
|
|
||||||
|
|
||||||
class ClubMemberForm(forms.ModelForm):
|
class ClubMemberForm(forms.ModelForm):
|
||||||
|
"""
|
||||||
|
Form handling the members of a club
|
||||||
|
"""
|
||||||
error_css_class = 'error'
|
error_css_class = 'error'
|
||||||
required_css_class = 'required'
|
required_css_class = 'required'
|
||||||
class Meta:
|
class Meta:
|
||||||
@ -33,24 +36,37 @@ class ClubMemberForm(forms.ModelForm):
|
|||||||
fields = ['user', 'role']
|
fields = ['user', 'role']
|
||||||
|
|
||||||
def clean(self):
|
def clean(self):
|
||||||
|
"""
|
||||||
|
Validates the permissions
|
||||||
|
e.g.: the president can add anyone anywhere, but a member can not make someone become president
|
||||||
|
"""
|
||||||
ret = super(ClubMemberForm, self).clean()
|
ret = super(ClubMemberForm, self).clean()
|
||||||
ms = self.instance.club.get_membership_for(self._user)
|
ms = self.instance.club.get_membership_for(self._user)
|
||||||
if ms is not None and ms.role >= self.cleaned_data['role']:
|
if ms is not None and ms.role >= self.cleaned_data['role']:
|
||||||
return ret
|
return ret
|
||||||
raise ValidationError("You do not have the permission to do that")
|
raise ValidationError("You do not have the permission to do that")
|
||||||
|
|
||||||
|
def save(self, *args, **kwargs):
|
||||||
|
"""
|
||||||
|
Overloaded to return the club, and not to a Membership object that has no view
|
||||||
|
"""
|
||||||
|
ret = super(ClubMemberForm, self).save(*args, **kwargs)
|
||||||
|
return self.instance.club
|
||||||
|
|
||||||
class ClubMembersView(CanViewMixin, UpdateView):
|
class ClubMembersView(CanViewMixin, UpdateView):
|
||||||
|
"""
|
||||||
|
View of a club's members
|
||||||
|
"""
|
||||||
model = Club
|
model = Club
|
||||||
pk_url_kwarg = "club_id"
|
pk_url_kwarg = "club_id"
|
||||||
form_class = ClubMemberForm
|
form_class = ClubMemberForm
|
||||||
template_name = 'club/club_members.jinja'
|
template_name = 'club/club_members.jinja'
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
|
||||||
super(ClubMembersView, self).__init__(*args, **kwargs)
|
|
||||||
# TODO FIXME: error forbidden when adding new member to club, because self.object changes to the Membership object
|
|
||||||
# somewhere!!!
|
|
||||||
|
|
||||||
def get_form(self):
|
def get_form(self):
|
||||||
|
"""
|
||||||
|
Here we get a Membership object, but the view handles Club object.
|
||||||
|
That's why the save method of ClubMemberForm is overridden.
|
||||||
|
"""
|
||||||
form = super(ClubMembersView, self).get_form()
|
form = super(ClubMembersView, self).get_form()
|
||||||
if 'user' in form.data and form.data.get('user') != '': # Load an existing membership if possible
|
if 'user' in form.data and form.data.get('user') != '': # Load an existing membership if possible
|
||||||
form.instance = Membership.objects.filter(club=self.object).filter(user=form.data.get('user')).filter(end_date=None).first()
|
form.instance = Membership.objects.filter(club=self.object).filter(user=form.data.get('user')).filter(end_date=None).first()
|
||||||
@ -60,9 +76,21 @@ class ClubMembersView(CanViewMixin, UpdateView):
|
|||||||
form._user = self.request.user
|
form._user = self.request.user
|
||||||
return form
|
return form
|
||||||
|
|
||||||
class ClubEditPropView(CanEditPropMixin, UpdateView):
|
class ClubEditView(CanEditMixin, UpdateView):
|
||||||
|
"""
|
||||||
|
Edit a Club's main informations (for the club's members)
|
||||||
|
"""
|
||||||
model = Club
|
model = Club
|
||||||
pk_url_kwarg = "club_id"
|
pk_url_kwarg = "club_id"
|
||||||
fields = ['name', 'address', 'parent']
|
fields = ['address']
|
||||||
|
template_name = 'club/club_edit.jinja'
|
||||||
|
|
||||||
|
class ClubEditPropView(CanEditPropMixin, UpdateView):
|
||||||
|
"""
|
||||||
|
Edit the properties of a Club object (for the Sith admins)
|
||||||
|
"""
|
||||||
|
model = Club
|
||||||
|
pk_url_kwarg = "club_id"
|
||||||
|
fields = ['name', 'parent']
|
||||||
template_name = 'club/club_edit_prop.jinja'
|
template_name = 'club/club_edit_prop.jinja'
|
||||||
|
|
||||||
|
@ -72,6 +72,9 @@ class CanViewMixin(View):
|
|||||||
"""
|
"""
|
||||||
def dispatch(self, request, *arg, **kwargs):
|
def dispatch(self, request, *arg, **kwargs):
|
||||||
res = super(CanViewMixin, self).dispatch(request, *arg, **kwargs)
|
res = super(CanViewMixin, self).dispatch(request, *arg, **kwargs)
|
||||||
|
import traceback
|
||||||
|
traceback.print_stack(limit=10)
|
||||||
|
print(self.__dict__)
|
||||||
if hasattr(self, 'object'):
|
if hasattr(self, 'object'):
|
||||||
obj = self.object
|
obj = self.object
|
||||||
elif hasattr(self, 'object_list'):
|
elif hasattr(self, 'object_list'):
|
||||||
|
Loading…
Reference in New Issue
Block a user