Files
bus-manager/busManager/coord/views.py
T
John Mullins f9981aadf0 New reports
Added per term fare paid to traveller model
Fixed parent in emergency contacts report
2023-08-28 11:41:31 +10:00

158 lines
5.6 KiB
Python

from django.contrib.admin.views.decorators import staff_member_required
from django.http import HttpResponse
from django.shortcuts import render
from django.views.generic import ListView
from .models import Company, Bus, Traveller, BusStop, TravellerRoute, Shuttle, Driver
# def index(request):
# return HttpResponse("Hello, world. You're at the coord index.")
@staff_member_required
def bus_numbers(request):
buses = []
for bus in Bus.objects.all():
drivers = ""
for driver in Driver.objects.filter(bus=bus):
driver_name = f"{driver.first_name} {driver.last_name}"
if drivers == "":
drivers = driver_name
else:
drivers += f", {driver_name}"
route_travellers = Traveller.objects.filter(bus_stops__bus=bus).count()
over_capacity = route_travellers > bus.seating_capacity
shuttle = Shuttle.objects.filter(bus=bus).first()
if shuttle:
shuttle = shuttle.school.shortName
shuttle_travellers = Traveller.objects.filter(shuttle__bus=bus).count()
over_capacity = over_capacity or int(shuttle_travellers) > bus.seating_capacity
else:
shuttle = ""
shuttle_travellers = ""
buses.append({
'route_name': bus.route_name,
'drivers': drivers,
'route_travellers': route_travellers,
'shuttle': shuttle,
'shuttle_travellers': shuttle_travellers,
'seating_capacity': bus.seating_capacity,
'over_capacity': over_capacity,
})
return render(request, 'reports/bus_numbers.html', {'buses': buses})
@staff_member_required
def bus_roll(request, queryset=None):
bus_routes = []
if queryset is None:
buses = Bus.objects.all()
else:
buses = queryset
for bus in buses:
bus_route = []
for bus_stop in BusStop.objects.filter(bus=bus):
traveller_list = []
for trav_route in TravellerRoute.objects.filter(busStop=bus_stop):
traveller = trav_route.traveller
if not traveller.is_active():
continue
is_fared = "---"
if traveller.eligibility_status == "2":
is_fared = "Y"
traveller_list.append({
'display': f"{traveller} ({traveller.get_year_level_display()}, {traveller.school.shortName})",
'isFared': is_fared
})
stop_result = {
'stop_num': bus_stop.get_stop_number(),
'name': bus_stop.address,
'am': bus_stop.am_time,
'pm': bus_stop.pm_time,
'travellers': traveller_list
}
# print(traveller_list)
bus_route.append(stop_result)
# Todo Add shuttles
bus_routes.append({'route_name': bus.route_name, 'stops': bus_route})
return render(request, 'reports/bus_roll.html', {'routes': bus_routes})
@staff_member_required
def bus_summary(request, queryset=None):
bus_routes = []
if queryset is None:
buses = Bus.objects.all()
else:
buses = queryset
for bus in buses:
drivers = ""
for driver in Driver.objects.filter(bus=bus):
driver_name = f"{driver.first_name} {driver.last_name}"
if drivers == "":
drivers = driver_name
else:
drivers += f", {driver_name}"
stops = []
for bus_stop in BusStop.objects.filter(bus=bus):
stops.append(bus_stop)
bus_routes.append({
'bus': bus,
'drivers': drivers,
'stops': stops
})
return render(request, 'reports/bus_summary.html', {'routes': bus_routes})
@staff_member_required
def emergency_contacts(request, queryset=None):
if queryset is None:
buses = Bus.objects.all()
else:
buses = queryset
bus_routes = []
for bus in buses:
traveller_list = []
for travellerRoute in TravellerRoute.objects.filter(busStop__bus=bus):
traveller = travellerRoute.traveller
parent_a = ""
if travellerRoute.traveller.parent_A_firstname:
parent_a = f"{traveller.parent_A_firstname} {traveller.parent_A_lastname} ({traveller.parent_A_phone})"
parent_b = ""
if travellerRoute.traveller.parent_B_firstname:
parent_b = f"{traveller.parent_B_firstname} {traveller.parent_B_lastname} ({traveller.parent_B_phone})"
contact_a = ""
if travellerRoute.traveller.emergency_contact_A_firstname:
contact_a = f"{traveller.emergency_contact_A_firstname} {traveller.emergency_contact_A_lastname} ({traveller.emergency_contact_A_phone})"
contact_b = ""
if travellerRoute.traveller.emergency_contact_B_firstname:
contact_b = f"{traveller.emergency_contact_B_firstname} {traveller.emergency_contact_B_lastname} ({traveller.emergency_contact_B_phone})"
traveller_list.append({
'traveller': traveller,
'parent_a': parent_a,
'parent_b': parent_b,
'contact_a': contact_a,
'contact_b': contact_b,
'note': travellerRoute.notes
})
bus_routes.append({'bus': bus, 'travellers': traveller_list})
return render(request, 'reports/emergency_contacts.html', {'routes': bus_routes})
@staff_member_required
class CompanyList(ListView):
model = Company
template_name = "companies.html"