Fix average attendance annotation returning None for users that doesn't have any RaidResponses for past raids yet.
This occurs because we don't filter users on weather or not they even have RaidResponses for past raids, but only do the filtering on the Avg function. This is correct behaviour, as we want to show *all* users in the attendance matrix. We therefore introduce the 'Coalesce' function to default to an average attendance of 0.
This commit is contained in:
parent
3d1faa49c3
commit
57d5b3f131
1 changed files with 11 additions and 7 deletions
|
@ -1,6 +1,7 @@
|
||||||
from contextlib import suppress
|
from contextlib import suppress
|
||||||
|
|
||||||
from django.db.models import Avg, Q
|
from django.db.models import Avg, Q, Value
|
||||||
|
from django.db.models.functions import Coalesce
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
from django.views.generic import TemplateView
|
from django.views.generic import TemplateView
|
||||||
|
|
||||||
|
@ -17,12 +18,15 @@ class AttendanceView(TemplateView):
|
||||||
.filter(is_active=True) \
|
.filter(is_active=True) \
|
||||||
.select_related("main") \
|
.select_related("main") \
|
||||||
.annotate(
|
.annotate(
|
||||||
avg_attendance=Avg(
|
avg_attendance=Coalesce(
|
||||||
"characters__raid_responses__attendance",
|
Avg(
|
||||||
filter=Q(
|
"characters__raid_responses__attendance",
|
||||||
characters__raid_responses__raid__date__lte=timezone.now(), # only count past raids
|
filter=Q(
|
||||||
characters__raid_responses__raid__is_optional=False
|
characters__raid_responses__raid__date__lte=timezone.now(), # only count past raids
|
||||||
)
|
characters__raid_responses__raid__is_optional=False
|
||||||
|
)
|
||||||
|
),
|
||||||
|
Value(0) # default to 0 if user doesn't have any responses for past raids yet
|
||||||
)
|
)
|
||||||
).order_by("main__klass", "-avg_attendance", "main__name")
|
).order_by("main__klass", "-avg_attendance", "main__name")
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue