Sith/club/views.py

787 lines
24 KiB
Python
Raw Normal View History

2023-04-06 11:08:42 +00:00
# -*- coding:utf-8 -*-
#
2023-04-06 11:08:42 +00:00
# Copyright 2023 © AE UTBM
# ae@utbm.fr / ae.info@utbm.fr
# All contributors are listed in the CONTRIBUTORS file.
#
2023-04-06 11:08:42 +00:00
# This file is part of the website of the UTBM Student Association (AE UTBM),
# https://ae.utbm.fr.
#
2023-04-06 11:08:42 +00:00
# You can find the whole source code at https://github.com/ae-utbm/sith3
#
2023-04-06 11:08:42 +00:00
# LICENSED UNDER THE GNU GENERAL PUBLIC LICENSE VERSION 3 (GPLv3)
# SEE : https://raw.githubusercontent.com/ae-utbm/sith3/master/LICENSE
# OR WITHIN THE LOCAL FILE "LICENSE"
#
2023-04-06 11:08:42 +00:00
# PREVIOUSLY LICENSED UNDER THE MIT LICENSE,
# SEE : https://raw.githubusercontent.com/ae-utbm/sith3/master/LICENSE.old
# OR WITHIN THE LOCAL FILE "LICENSE.old"
#
import csv
from django.conf import settings
2024-06-24 11:07:36 +00:00
from django.core.exceptions import NON_FIELD_ERRORS, PermissionDenied, ValidationError
from django.core.paginator import InvalidPage, Paginator
from django.db.models import Sum
from django.http import (
Http404,
2024-06-24 11:07:36 +00:00
HttpResponseRedirect,
StreamingHttpResponse,
)
2024-06-24 11:07:36 +00:00
from django.shortcuts import get_object_or_404, redirect
from django.urls import reverse, reverse_lazy
2016-09-02 19:21:57 +00:00
from django.utils import timezone
from django.utils.translation import gettext as _t
2024-06-24 11:07:36 +00:00
from django.utils.translation import gettext_lazy as _
from django.views.generic import DetailView, ListView, TemplateView, View
from django.views.generic.edit import CreateView, DeleteView, UpdateView
2016-09-08 01:29:49 +00:00
2024-06-24 11:07:36 +00:00
from club.forms import ClubEditForm, ClubMemberForm, MailingForm, SellingsForm
from club.models import Club, Mailing, MailingSubscription, Membership
from com.views import (
PosterCreateBaseView,
PosterDeleteBaseView,
PosterEditBaseView,
PosterListBaseView,
)
from core.models import PageRev
2018-10-05 19:51:54 +00:00
from core.views import (
CanCreateMixin,
CanEditMixin,
CanEditPropMixin,
2024-06-24 11:07:36 +00:00
CanViewMixin,
DetailFormView,
2024-06-24 11:07:36 +00:00
PageEditViewBase,
TabedViewMixin,
UserIsRootMixin,
2018-10-05 19:51:54 +00:00
)
from counter.models import Selling
class ClubTabsMixin(TabedViewMixin):
def get_tabs_title(self):
obj = self.get_object()
if isinstance(obj, PageRev):
self.object = obj.page.club
return self.object.get_display_name()
def get_list_of_tabs(self):
tab_list = []
2018-10-05 19:51:54 +00:00
tab_list.append(
{
"url": reverse("club:club_view", kwargs={"club_id": self.object.id}),
"slug": "infos",
"name": _("Infos"),
}
)
if self.request.user.can_view(self.object):
2018-10-05 19:51:54 +00:00
tab_list.append(
{
"url": reverse(
"club:club_members", kwargs={"club_id": self.object.id}
),
"slug": "members",
"name": _("Members"),
}
)
tab_list.append(
{
"url": reverse(
"club:club_old_members", kwargs={"club_id": self.object.id}
),
"slug": "elderlies",
"name": _("Old members"),
}
)
if self.object.page:
2018-10-05 19:51:54 +00:00
tab_list.append(
{
"url": reverse(
"club:club_hist", kwargs={"club_id": self.object.id}
),
"slug": "history",
"name": _("History"),
}
)
if self.request.user.can_edit(self.object):
2018-10-05 19:51:54 +00:00
tab_list.append(
{
"url": reverse("club:tools", kwargs={"club_id": self.object.id}),
"slug": "tools",
"name": _("Tools"),
}
)
tab_list.append(
{
"url": reverse(
"club:club_edit", kwargs={"club_id": self.object.id}
),
"slug": "edit",
"name": _("Edit"),
}
)
if self.object.page and self.request.user.can_edit(self.object.page):
2018-10-05 19:51:54 +00:00
tab_list.append(
{
"url": reverse(
"core:page_edit",
kwargs={"page_name": self.object.page.get_full_name()},
),
"slug": "page_edit",
"name": _("Edit club page"),
}
)
tab_list.append(
{
"url": reverse(
"club:club_sellings", kwargs={"club_id": self.object.id}
),
"slug": "sellings",
"name": _("Sellings"),
}
)
tab_list.append(
{
"url": reverse("club:mailing", kwargs={"club_id": self.object.id}),
"slug": "mailing",
"name": _("Mailing list"),
}
)
tab_list.append(
{
"url": reverse(
"club:poster_list", kwargs={"club_id": self.object.id}
),
"slug": "posters",
"name": _("Posters list"),
}
)
if self.request.user.is_owner(self.object):
2018-10-05 19:51:54 +00:00
tab_list.append(
{
"url": reverse(
"club:club_prop", kwargs={"club_id": self.object.id}
),
"slug": "props",
"name": _("Props"),
}
)
return tab_list
2017-06-12 06:54:48 +00:00
2016-07-27 15:23:02 +00:00
class ClubListView(ListView):
2016-02-08 16:09:52 +00:00
"""
List the Clubs
"""
2018-10-05 19:51:54 +00:00
model = Club
2018-10-05 19:51:54 +00:00
template_name = "club/club_list.jinja"
2017-06-12 06:54:48 +00:00
class ClubView(ClubTabsMixin, DetailView):
2016-02-08 16:09:52 +00:00
"""
Front page of a Club
"""
2018-10-05 19:51:54 +00:00
model = Club
pk_url_kwarg = "club_id"
2018-10-05 19:51:54 +00:00
template_name = "club/club_detail.jinja"
current_tab = "infos"
def get_context_data(self, **kwargs):
kwargs = super(ClubView, self).get_context_data(**kwargs)
if self.object.page and self.object.page.revisions.exists():
2018-10-05 19:51:54 +00:00
kwargs["page_revision"] = self.object.page.revisions.last().content
return kwargs
class ClubRevView(ClubView):
"""
Display a specific page revision
"""
2018-10-05 19:51:54 +00:00
def dispatch(self, request, *args, **kwargs):
obj = self.get_object()
2018-10-05 19:51:54 +00:00
self.revision = get_object_or_404(PageRev, pk=kwargs["rev_id"], page__club=obj)
return super(ClubRevView, self).dispatch(request, *args, **kwargs)
def get_context_data(self, **kwargs):
kwargs = super(ClubRevView, self).get_context_data(**kwargs)
2018-10-05 19:51:54 +00:00
kwargs["page_revision"] = self.revision.content
return kwargs
class ClubPageEditView(ClubTabsMixin, PageEditViewBase):
2018-10-05 19:51:54 +00:00
template_name = "club/pagerev_edit.jinja"
current_tab = "page_edit"
def dispatch(self, request, *args, **kwargs):
2018-10-05 19:51:54 +00:00
self.club = get_object_or_404(Club, pk=kwargs["club_id"])
if not self.club.page:
raise Http404
return super(ClubPageEditView, self).dispatch(request, *args, **kwargs)
def get_object(self):
self.page = self.club.page
return self._get_revision()
def get_success_url(self, **kwargs):
2018-10-05 19:51:54 +00:00
return reverse_lazy("club:club_view", kwargs={"club_id": self.club.id})
class ClubPageHistView(ClubTabsMixin, CanViewMixin, DetailView):
"""
Modification hostory of the page
"""
2018-10-05 19:51:54 +00:00
model = Club
pk_url_kwarg = "club_id"
2018-10-05 19:51:54 +00:00
template_name = "club/page_history.jinja"
current_tab = "history"
2017-06-12 06:54:48 +00:00
class ClubToolsView(ClubTabsMixin, CanEditMixin, DetailView):
2016-05-09 09:49:01 +00:00
"""
Tools page of a Club
"""
2018-10-05 19:51:54 +00:00
2016-05-09 09:49:01 +00:00
model = Club
pk_url_kwarg = "club_id"
2018-10-05 19:51:54 +00:00
template_name = "club/club_tools.jinja"
current_tab = "tools"
2016-09-02 07:23:21 +00:00
2017-06-12 06:54:48 +00:00
class ClubMembersView(ClubTabsMixin, CanViewMixin, DetailFormView):
2016-02-08 16:09:52 +00:00
"""
View of a club's members
"""
2018-10-05 19:51:54 +00:00
model = Club
pk_url_kwarg = "club_id"
2016-02-04 07:59:03 +00:00
form_class = ClubMemberForm
2018-10-05 19:51:54 +00:00
template_name = "club/club_members.jinja"
current_tab = "members"
def get_form_kwargs(self):
kwargs = super(ClubMembersView, self).get_form_kwargs()
kwargs["request_user"] = self.request.user
kwargs["club"] = self.get_object()
2019-04-24 16:17:03 +00:00
kwargs["club_members"] = self.members
return kwargs
def get_context_data(self, *args, **kwargs):
kwargs = super(ClubMembersView, self).get_context_data(*args, **kwargs)
2019-04-24 16:17:03 +00:00
kwargs["members"] = self.members
return kwargs
2016-02-04 07:59:03 +00:00
def form_valid(self, form):
2016-09-27 19:05:57 +00:00
"""
2020-08-27 13:59:42 +00:00
Check user rights
2016-09-27 19:05:57 +00:00
"""
resp = super(ClubMembersView, self).form_valid(form)
data = form.clean()
users = data.pop("users", [])
2019-04-24 16:17:03 +00:00
users_old = data.pop("users_old", [])
for user in users:
Membership(club=self.get_object(), user=user, **data).save()
2019-04-24 16:17:03 +00:00
for user in users_old:
membership = self.get_object().get_membership_for(user)
membership.end_date = timezone.now()
membership.save()
return resp
2016-09-27 19:05:57 +00:00
def dispatch(self, request, *args, **kwargs):
self.members = self.get_object().members.ongoing().order_by("-role")
return super(ClubMembersView, self).dispatch(request, *args, **kwargs)
def get_success_url(self, **kwargs):
return reverse_lazy(
"club:club_members", kwargs={"club_id": self.get_object().id}
)
2017-06-12 06:54:48 +00:00
class ClubOldMembersView(ClubTabsMixin, CanViewMixin, DetailView):
2016-09-02 19:21:57 +00:00
"""
Old members of a club
"""
2018-10-05 19:51:54 +00:00
2016-09-02 19:21:57 +00:00
model = Club
pk_url_kwarg = "club_id"
2018-10-05 19:51:54 +00:00
template_name = "club/club_old_members.jinja"
current_tab = "elderlies"
2016-09-02 19:21:57 +00:00
2017-06-12 06:54:48 +00:00
class ClubSellingView(ClubTabsMixin, CanEditMixin, DetailFormView):
2016-09-08 01:29:49 +00:00
"""
Sellings of a club
"""
2018-10-05 19:51:54 +00:00
2016-09-08 01:29:49 +00:00
model = Club
pk_url_kwarg = "club_id"
2018-10-05 19:51:54 +00:00
template_name = "club/club_sellings.jinja"
2016-09-08 01:29:49 +00:00
current_tab = "sellings"
form_class = SellingsForm
paginate_by = 70
def dispatch(self, request, *args, **kwargs):
try:
self.asked_page = int(request.GET.get("page", 1))
except ValueError:
raise Http404
return super(ClubSellingView, self).dispatch(request, *args, **kwargs)
2016-09-08 01:29:49 +00:00
def get_form_kwargs(self):
kwargs = super(ClubSellingView, self).get_form_kwargs()
kwargs["club"] = self.object
return kwargs
def post(self, request, *args, **kwargs):
return self.get(request, *args, **kwargs)
2016-09-08 01:29:49 +00:00
def get_context_data(self, **kwargs):
kwargs = super(ClubSellingView, self).get_context_data(**kwargs)
qs = Selling.objects.filter(club=self.object)
kwargs["result"] = qs[:0]
kwargs["paginated_result"] = kwargs["result"]
kwargs["total"] = 0
kwargs["total_quantity"] = 0
kwargs["benefit"] = 0
form = self.get_form()
2016-09-08 01:29:49 +00:00
if form.is_valid():
2016-09-12 15:34:17 +00:00
if not len([v for v in form.cleaned_data.values() if v is not None]):
qs = Selling.objects.filter(id=-1)
2018-10-05 19:51:54 +00:00
if form.cleaned_data["begin_date"]:
qs = qs.filter(date__gte=form.cleaned_data["begin_date"])
if form.cleaned_data["end_date"]:
qs = qs.filter(date__lte=form.cleaned_data["end_date"])
if form.cleaned_data["counters"]:
qs = qs.filter(counter__in=form.cleaned_data["counters"])
selected_products = []
if form.cleaned_data["products"]:
selected_products.extend(form.cleaned_data["products"])
if form.cleaned_data["archived_products"]:
2019-11-28 14:14:51 +00:00
selected_products.extend(form.cleaned_data["archived_products"])
if len(selected_products) > 0:
qs = qs.filter(product__in=selected_products)
2018-10-05 19:51:54 +00:00
kwargs["result"] = qs.all().order_by("-id")
kwargs["total"] = sum([s.quantity * s.unit_price for s in kwargs["result"]])
total_quantity = qs.all().aggregate(Sum("quantity"))
if total_quantity["quantity__sum"]:
kwargs["total_quantity"] = total_quantity["quantity__sum"]
benefit = (
qs.exclude(product=None).all().aggregate(Sum("product__purchase_price"))
)
if benefit["product__purchase_price__sum"]:
kwargs["benefit"] = benefit["product__purchase_price__sum"]
kwargs["paginator"] = Paginator(kwargs["result"], self.paginate_by)
try:
kwargs["paginated_result"] = kwargs["paginator"].page(self.asked_page)
except InvalidPage:
raise Http404
2016-09-08 01:29:49 +00:00
return kwargs
2017-06-12 06:54:48 +00:00
2016-11-07 21:05:09 +00:00
class ClubSellingCSVView(ClubSellingView):
"""
Generate sellings in csv for a given period
"""
class StreamWriter:
"""Implements a file-like interface for streaming the CSV"""
def write(self, value):
"""Write the value by returning it, instead of storing in a buffer."""
return value
def write_selling(self, selling):
row = [selling.date, selling.counter]
if selling.seller:
row.append(selling.seller.get_display_name())
else:
row.append("")
if selling.customer:
row.append(selling.customer.user.get_display_name())
else:
row.append("")
row = row + [
selling.label,
selling.quantity,
selling.quantity * selling.unit_price,
selling.get_payment_method_display(),
]
if selling.product:
row.append(selling.product.selling_price)
row.append(selling.product.purchase_price)
row.append(selling.product.selling_price - selling.product.purchase_price)
else:
row = row + ["", "", ""]
return row
2016-11-07 21:05:09 +00:00
def get(self, request, *args, **kwargs):
self.object = self.get_object()
kwargs = self.get_context_data(**kwargs)
# Use the StreamWriter class instead of request for streaming
pseudo_buffer = self.StreamWriter()
2018-10-05 19:51:54 +00:00
writer = csv.writer(
pseudo_buffer, delimiter=";", lineterminator="\n", quoting=csv.QUOTE_ALL
2018-10-05 19:51:54 +00:00
)
writer.writerow([_t("Quantity"), kwargs["total_quantity"]])
writer.writerow([_t("Total"), kwargs["total"]])
writer.writerow([_t("Benefit"), kwargs["benefit"]])
writer.writerow(
[
_t("Date"),
_t("Counter"),
_t("Barman"),
_t("Customer"),
_t("Label"),
_t("Quantity"),
_t("Total"),
_t("Payment method"),
_t("Selling price"),
_t("Purchase price"),
_t("Benefit"),
]
)
# Stream response
response = StreamingHttpResponse(
(
writer.writerow(self.write_selling(selling))
for selling in kwargs["result"]
),
content_type="text/csv",
)
name = _("Sellings") + "_" + self.object.name + ".csv"
response["Content-Disposition"] = "filename=" + name
2016-11-07 21:05:09 +00:00
return response
2017-06-12 06:54:48 +00:00
class ClubEditView(ClubTabsMixin, CanEditMixin, UpdateView):
2016-02-08 16:09:52 +00:00
"""
Edit a Club's main informations (for the club's members)
"""
2018-10-05 19:51:54 +00:00
2016-02-08 16:09:52 +00:00
model = Club
pk_url_kwarg = "club_id"
form_class = ClubEditForm
2018-10-05 19:51:54 +00:00
template_name = "core/edit.jinja"
current_tab = "edit"
2016-09-02 07:23:21 +00:00
2017-06-12 06:54:48 +00:00
class ClubEditPropView(ClubTabsMixin, CanEditPropMixin, UpdateView):
2016-02-08 16:09:52 +00:00
"""
Edit the properties of a Club object (for the Sith admins)
"""
2018-10-05 19:51:54 +00:00
model = Club
pk_url_kwarg = "club_id"
2018-10-05 19:51:54 +00:00
fields = ["name", "unix_name", "parent", "is_active"]
template_name = "core/edit.jinja"
current_tab = "props"
2016-05-03 10:06:03 +00:00
2017-06-12 06:54:48 +00:00
2019-10-21 20:56:24 +00:00
class ClubCreateView(CanCreateMixin, CreateView):
2016-05-03 10:06:03 +00:00
"""
Create a club (for the Sith admin)
"""
2018-10-05 19:51:54 +00:00
2016-05-03 10:06:03 +00:00
model = Club
pk_url_kwarg = "club_id"
2018-10-05 19:51:54 +00:00
fields = ["name", "unix_name", "parent"]
template_name = "core/edit.jinja"
2016-05-03 10:06:03 +00:00
2017-06-12 06:54:48 +00:00
2016-09-02 19:21:57 +00:00
class MembershipSetOldView(CanEditMixin, DetailView):
"""
Set a membership as beeing old
"""
2018-10-05 19:51:54 +00:00
2016-09-02 19:21:57 +00:00
model = Membership
pk_url_kwarg = "membership_id"
def get(self, request, *args, **kwargs):
self.object = self.get_object()
self.object.end_date = timezone.now()
self.object.save()
2018-10-05 19:51:54 +00:00
return HttpResponseRedirect(
reverse(
"club:club_members",
args=self.args,
kwargs={"club_id": self.object.club.id},
)
)
2016-09-02 19:21:57 +00:00
def post(self, request, *args, **kwargs):
self.object = self.get_object()
2018-10-05 19:51:54 +00:00
return HttpResponseRedirect(
reverse(
"club:club_members",
args=self.args,
kwargs={"club_id": self.object.club.id},
)
)
2016-09-02 19:21:57 +00:00
2017-06-12 06:54:48 +00:00
class MembershipDeleteView(UserIsRootMixin, DeleteView):
"""
Delete a membership (for admins only)
"""
model = Membership
pk_url_kwarg = "membership_id"
template_name = "core/delete_confirm.jinja"
def get_success_url(self):
return reverse_lazy("core:user_clubs", kwargs={"user_id": self.object.user.id})
2016-11-25 14:26:45 +00:00
class ClubStatView(TemplateView):
2017-06-12 06:54:48 +00:00
template_name = "club/stats.jinja"
2016-11-25 14:26:45 +00:00
def get_context_data(self, **kwargs):
kwargs = super(ClubStatView, self).get_context_data(**kwargs)
2018-10-05 19:51:54 +00:00
kwargs["club_list"] = Club.objects.all()
2016-11-25 14:26:45 +00:00
return kwargs
2017-08-16 22:07:19 +00:00
class ClubMailingView(ClubTabsMixin, CanEditMixin, DetailFormView):
2017-08-16 22:07:19 +00:00
"""
A list of mailing for a given club
"""
2018-10-05 19:51:54 +00:00
model = Club
form_class = MailingForm
pk_url_kwarg = "club_id"
2017-08-16 22:07:19 +00:00
template_name = "club/mailing.jinja"
2018-10-05 19:51:54 +00:00
current_tab = "mailing"
2017-08-17 18:55:20 +00:00
def get_form_kwargs(self):
kwargs = super(ClubMailingView, self).get_form_kwargs()
kwargs["club_id"] = self.get_object().id
kwargs["user_id"] = self.request.user.id
kwargs["mailings"] = self.mailings
return kwargs
def dispatch(self, request, *args, **kwargs):
self.mailings = Mailing.objects.filter(club_id=self.get_object().id).all()
return super(ClubMailingView, self).dispatch(request, *args, **kwargs)
2017-08-16 22:07:19 +00:00
def get_context_data(self, **kwargs):
kwargs = super(ClubMailingView, self).get_context_data(**kwargs)
kwargs["club"] = self.get_object()
kwargs["user"] = self.request.user
kwargs["mailings"] = self.mailings
kwargs["mailings_moderated"] = (
kwargs["mailings"].exclude(is_moderated=False).all()
)
kwargs["mailings_not_moderated"] = (
kwargs["mailings"].exclude(is_moderated=True).all()
)
kwargs["form_actions"] = {
"NEW_MALING": self.form_class.ACTION_NEW_MAILING,
"NEW_SUBSCRIPTION": self.form_class.ACTION_NEW_SUBSCRIPTION,
"REMOVE_SUBSCRIPTION": self.form_class.ACTION_REMOVE_SUBSCRIPTION,
}
2017-08-16 22:07:19 +00:00
return kwargs
def add_new_mailing(self, cleaned_data) -> ValidationError | None:
"""
Create a new mailing list from the form
"""
mailing = Mailing(
club=self.get_object(),
email=cleaned_data["mailing_email"],
moderator=self.request.user,
is_moderated=False,
)
try:
mailing.clean()
except ValidationError as validation_error:
return validation_error
mailing.save()
return None
2017-12-22 11:06:23 +00:00
def add_new_subscription(self, cleaned_data) -> ValidationError | None:
"""
Add mailing subscriptions for each user given and/or for the specified email in form
"""
2019-05-09 16:06:11 +00:00
users_to_save = []
for user in cleaned_data["subscription_users"]:
sub = MailingSubscription(
mailing=cleaned_data["subscription_mailing"], user=user
)
2019-05-09 16:06:11 +00:00
try:
sub.clean()
except ValidationError as validation_error:
return validation_error
sub.save()
users_to_save.append(sub)
2017-08-16 22:07:19 +00:00
if cleaned_data["subscription_email"]:
sub = MailingSubscription(
mailing=cleaned_data["subscription_mailing"],
email=cleaned_data["subscription_email"],
)
try:
sub.clean()
except ValidationError as validation_error:
return validation_error
sub.save()
2019-05-09 16:06:11 +00:00
# Save users after we are sure there is no error
for user in users_to_save:
user.save()
return None
2018-10-05 19:51:54 +00:00
def remove_subscription(self, cleaned_data):
"""
Remove specified users from a mailing list
"""
fields = [
cleaned_data[key]
for key in cleaned_data.keys()
if key.startswith("removal_")
]
for field in fields:
for sub in field:
sub.delete()
def form_valid(self, form):
resp = super(ClubMailingView, self).form_valid(form)
2017-08-16 22:07:19 +00:00
cleaned_data = form.clean()
error = None
2017-08-16 22:07:19 +00:00
if cleaned_data["action"] == self.form_class.ACTION_NEW_MAILING:
error = self.add_new_mailing(cleaned_data)
2017-08-16 22:07:19 +00:00
if cleaned_data["action"] == self.form_class.ACTION_NEW_SUBSCRIPTION:
error = self.add_new_subscription(cleaned_data)
if cleaned_data["action"] == self.form_class.ACTION_REMOVE_SUBSCRIPTION:
self.remove_subscription(cleaned_data)
if error:
form.add_error(NON_FIELD_ERRORS, error)
return self.form_invalid(form)
return resp
2017-08-16 22:07:19 +00:00
def get_success_url(self, **kwargs):
return reverse_lazy("club:mailing", kwargs={"club_id": self.get_object().id})
2017-08-17 18:55:20 +00:00
class MailingDeleteView(CanEditMixin, DeleteView):
model = Mailing
2018-10-05 19:51:54 +00:00
template_name = "core/delete_confirm.jinja"
2017-08-17 18:55:20 +00:00
pk_url_kwarg = "mailing_id"
2017-08-21 17:53:17 +00:00
redirect_page = None
2017-08-17 18:55:20 +00:00
def dispatch(self, request, *args, **kwargs):
self.club_id = self.get_object().club.id
return super(MailingDeleteView, self).dispatch(request, *args, **kwargs)
def get_success_url(self, **kwargs):
2017-08-21 17:53:17 +00:00
if self.redirect_page:
return reverse_lazy(self.redirect_page)
else:
2018-10-05 19:51:54 +00:00
return reverse_lazy("club:mailing", kwargs={"club_id": self.club_id})
2017-08-17 18:55:20 +00:00
class MailingSubscriptionDeleteView(CanEditMixin, DeleteView):
model = MailingSubscription
2018-10-05 19:51:54 +00:00
template_name = "core/delete_confirm.jinja"
2017-08-17 18:55:20 +00:00
pk_url_kwarg = "mailing_subscription_id"
def dispatch(self, request, *args, **kwargs):
self.club_id = self.get_object().mailing.club.id
2018-10-05 19:51:54 +00:00
return super(MailingSubscriptionDeleteView, self).dispatch(
request, *args, **kwargs
)
2017-08-17 18:55:20 +00:00
def get_success_url(self, **kwargs):
2018-10-05 19:51:54 +00:00
return reverse_lazy("club:mailing", kwargs={"club_id": self.club_id})
2017-10-01 22:10:52 +00:00
2017-10-01 22:10:52 +00:00
class MailingAutoGenerationView(View):
def dispatch(self, request, *args, **kwargs):
2018-10-05 19:51:54 +00:00
self.mailing = get_object_or_404(Mailing, pk=kwargs["mailing_id"])
2017-10-01 22:10:52 +00:00
if not request.user.can_edit(self.mailing):
raise PermissionDenied
return super(MailingAutoGenerationView, self).dispatch(request, *args, **kwargs)
def get(self, request, *args, **kwargs):
club = self.mailing.club
self.mailing.subscriptions.all().delete()
2018-10-05 19:51:54 +00:00
members = club.members.filter(
role__gte=settings.SITH_CLUB_ROLES_ID["Board member"]
).exclude(end_date__lte=timezone.now())
2017-10-01 22:10:52 +00:00
for member in members.all():
MailingSubscription(user=member.user, mailing=self.mailing).save()
2018-10-05 19:51:54 +00:00
return redirect("club:mailing", club_id=club.id)
2017-10-01 22:10:52 +00:00
class PosterListView(ClubTabsMixin, PosterListBaseView, CanViewMixin):
2017-11-01 17:12:33 +00:00
"""List communication posters"""
2017-12-05 14:53:36 +00:00
def get_object(self):
return self.club
2017-12-05 14:24:46 +00:00
2017-11-01 17:12:33 +00:00
def get_context_data(self, **kwargs):
kwargs = super(PosterListView, self).get_context_data(**kwargs)
2018-10-05 19:51:54 +00:00
kwargs["app"] = "club"
kwargs["club"] = self.club
2017-11-01 17:12:33 +00:00
return kwargs
2017-12-05 14:24:46 +00:00
class PosterCreateView(PosterCreateBaseView, CanCreateMixin):
2017-11-01 17:12:33 +00:00
"""Create communication poster"""
pk_url_kwarg = "club_id"
2017-11-01 17:12:33 +00:00
def get_object(self):
obj = super(PosterCreateView, self).get_object()
if not obj:
return self.club
return obj
def get_success_url(self, **kwargs):
2018-10-05 19:51:54 +00:00
return reverse_lazy("club:poster_list", kwargs={"club_id": self.club.id})
2017-11-01 17:12:33 +00:00
2017-12-05 14:24:46 +00:00
class PosterEditView(ClubTabsMixin, PosterEditBaseView, CanEditMixin):
2017-11-01 17:12:33 +00:00
"""Edit communication poster"""
2017-11-28 13:43:05 +00:00
def get_success_url(self):
2018-10-05 19:51:54 +00:00
return reverse_lazy("club:poster_list", kwargs={"club_id": self.club.id})
2017-11-01 17:12:33 +00:00
def get_context_data(self, **kwargs):
kwargs = super(PosterEditView, self).get_context_data(**kwargs)
2018-10-05 19:51:54 +00:00
kwargs["app"] = "club"
2017-11-01 17:12:33 +00:00
return kwargs
2017-12-05 14:24:46 +00:00
class PosterDeleteView(PosterDeleteBaseView, ClubTabsMixin, CanEditMixin):
"""Delete communication poster"""
def get_success_url(self):
2018-10-05 19:51:54 +00:00
return reverse_lazy("club:poster_list", kwargs={"club_id": self.club.id})