Moved SMS function out of admin.py

This commit is contained in:
John Mullins
2023-12-07 10:36:32 +11:00
parent 93410d5c9e
commit 1cec36d593
3 changed files with 44 additions and 33 deletions
+5 -24
View File
@@ -13,12 +13,14 @@ from django.utils.translation import gettext_lazy
from import_export.admin import ImportExportModelAdmin
from rangefilter.filters import DateRangeFilterBuilder
from mail_templates.admin import TemplateMixin
from .adminClone import CloneModelAdmin
from .context_helpers import bus_roll_context, emergency_contacts_context, traveller_roll_context, \
traveller_route_context, school_roll_context, confirmation_letter_context
from .email_helpers import email_companies_bus_roll, render_to_pdf, email_school_roll
from .form import SMSForm
from .models import *
from .utils.send_sms import send_sms
class BusRollMixin:
@@ -80,28 +82,7 @@ class TravellerRollMixin:
return render_to_pdf('mail/confirmation_letter.html', confirmation_letter_context(queryset))
def send_sms(self, request, queryset):
if 'send' in request.POST:
message = request.POST["message"]
send_to_parents = False
if request.POST.get("send_to_parents"):
send_to_parents = True
send_to_emergency_contacts = False
if request.POST.get("send_to_emergency_contacts"):
send_to_emergency_contacts = True
only_include_active_travellers = False
if request.POST.get("only_include_active_travellers"):
only_include_active_travellers = True
total = 0
for traveller in queryset:
if only_include_active_travellers and not traveller.is_active():
continue
total += traveller.send_sms(message, parents=send_to_parents, emergency=send_to_emergency_contacts)
self.message_user(request, f"SMS has been sent to {total} recipients")
return HttpResponseRedirect(request.get_full_path())
form = SMSForm(initial={'_selected_action': queryset.values_list('id', flat=True)})
return render(request, 'admin/sms_form.html', context={'form': form, 'items': queryset})
return send_sms(self, request, queryset)
def export_to_csv(self, request, queryset):
traveller_list = traveller_roll_context(queryset)
@@ -212,7 +193,7 @@ class TravellerRouteInline(admin.TabularInline):
@admin.register(Traveller)
class TravellerAdmin(MyImportExportModelAdmin, CloneModelAdmin, admin.ModelAdmin, TravellerRollMixin):
class TravellerAdmin(MyImportExportModelAdmin, CloneModelAdmin, admin.ModelAdmin, TravellerRollMixin, TemplateMixin):
list_display = ["first_name", "last_name", "school", "year_level", "residential_address", "residential_suburb", "stop_route", "shuttle", "travel_start_date", "travel_end_date"]
list_filter = [
"school", "year_level", "eligibility_status", "bus_stops__bus", "shuttle", "residential_suburb",
@@ -234,7 +215,7 @@ class TravellerAdmin(MyImportExportModelAdmin, CloneModelAdmin, admin.ModelAdmin
"emergency_contact_B_phone", "emergency_contact_B_relation"]
inlines = [TravellerRouteInline]
readonly_fields = ["fare_paying", "created_on", "last_edit", "is_archived"]
actions = ["export_to_csv", "send_sms", "confirmation_letter", "yearly_rollover"]
actions = ["export_to_csv", "send_sms", "confirmation_letter", "letter_creator", "yearly_rollover"]
fieldsets = [
(None, {
'fields': [
-9
View File
@@ -1,9 +0,0 @@
from django import forms
class SMSForm(forms.Form):
_selected_action = forms.CharField(widget=forms.MultipleHiddenInput)
send_to_parents = forms.BooleanField(required=False)
send_to_emergency_contacts = forms.BooleanField(required=False)
only_include_active_travellers = forms.BooleanField(initial=True, required=False)
message = forms.CharField(label="Message", max_length=320, widget=forms.Textarea)
+39
View File
@@ -0,0 +1,39 @@
from django.http import HttpResponseRedirect
from django import forms
from django.shortcuts import render
class SMSForm(forms.Form):
_selected_action = forms.CharField(widget=forms.MultipleHiddenInput)
send_to_parents = forms.BooleanField(required=False)
send_to_emergency_contacts = forms.BooleanField(required=False)
only_include_active_travellers = forms.BooleanField(initial=True, required=False)
message = forms.CharField(label="Message", max_length=320, widget=forms.Textarea)
def send_sms(send_sms_mixin, request, queryset):
if 'send' in request.POST:
message = request.POST["message"]
send_to_parents = False
if request.POST.get("send_to_parents"):
send_to_parents = True
send_to_emergency_contacts = False
if request.POST.get("send_to_emergency_contacts"):
send_to_emergency_contacts = True
only_include_active_travellers = False
if request.POST.get("only_include_active_travellers"):
only_include_active_travellers = True
total = 0
numbers = []
for traveller in queryset:
if only_include_active_travellers and not traveller.is_active():
continue
numbers.append(traveller.get_parsed_numbers(parents=send_to_parents, emergency=send_to_emergency_contacts))
len(numbers)
send_sms_mixin.message_user(request, f"SMS has been sent to {total} recipients")
return HttpResponseRedirect(request.get_full_path())
form = SMSForm(initial={'_selected_action': queryset.values_list('id', flat=True)})
return render(request, 'admin/sms_form.html', context={'form': form, 'items': queryset})