mirror of
https://gitlab.crans.org/bde/nk20
synced 2025-06-22 10:28:21 +02:00
Compare commits
4 Commits
361de9f8b4
...
survey_wei
Author | SHA1 | Date | |
---|---|---|---|
c1a353963a | |||
178ce2b579 | |||
185a2cabf2 | |||
7552e55c8d |
@ -55,7 +55,7 @@ buses_descr = [
|
|||||||
pour les plus calmes, vous trouverez au bus Aspique-Kyottes les 2A+ qui vous feront kiffer votre WEI.""",
|
pour les plus calmes, vous trouverez au bus Aspique-Kyottes les 2A+ qui vous feront kiffer votre WEI.""",
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
"Zanzo[Bus] 🤩👽🐔", "#FFFF", 3,
|
"Zanzo[Bus] 🤯🚸🐒", "#FFFF", 3,
|
||||||
"""Dans un entre-trois bien senti entre zinzinerie, enfance et vieillerie, le Zanzo[BUS] est un concentré de fun mêlé à
|
"""Dans un entre-trois bien senti entre zinzinerie, enfance et vieillerie, le Zanzo[BUS] est un concentré de fun mêlé à
|
||||||
de la dinguerie à gogo. N'hésitez plus et rejoignez-nous pour un WEI toujours plus déjanté !""",
|
de la dinguerie à gogo. N'hésitez plus et rejoignez-nous pour un WEI toujours plus déjanté !""",
|
||||||
],
|
],
|
||||||
@ -276,13 +276,27 @@ class WEISurveyAlgorithm2024(WEISurveyAlgorithm):
|
|||||||
surveys = list(self.get_survey_class()(r) for r in self.get_registrations()) # All surveys
|
surveys = list(self.get_survey_class()(r) for r in self.get_registrations()) # All surveys
|
||||||
surveys = [s for s in surveys if s.is_complete()] # Don't consider invalid surveys
|
surveys = [s for s in surveys if s.is_complete()] # Don't consider invalid surveys
|
||||||
# Don't manage hardcoded people
|
# Don't manage hardcoded people
|
||||||
surveys = [s for s in surveys if not hasattr(s.information, 'hardcoded') or not s.information.hardcoded]
|
# surveys = [s for s in surveys if s.bus_id != None]
|
||||||
|
# surveys = [s for s in surveys if not hasattr(s.information, 'hardcoded') or not s.information.hardcoded]
|
||||||
|
|
||||||
|
|
||||||
|
# surveys = [s for s in surveys if s.registration.user_id in free_users]
|
||||||
|
|
||||||
|
# hardcoded_first_year_mb = WEIMembership.objects.filter(bus != None,registration__first_year=True)
|
||||||
|
# hardcoded_first_year = hardcoded_first_year_mb.values_list('user__id', 'bus__id')
|
||||||
|
|
||||||
|
hardcoded_first_year_mb = WEIMembership.objects.filter(registration__first_year=True)
|
||||||
|
hardcoded_first_year = {mb.user.id if mb.bus else None: mb.bus.id if mb.bus else None for mb in hardcoded_first_year_mb}
|
||||||
|
|
||||||
|
|
||||||
# Reset previous algorithm run
|
# Reset previous algorithm run
|
||||||
for survey in surveys:
|
for survey in surveys:
|
||||||
survey.free()
|
survey.free()
|
||||||
|
if survey.registration.user_id in hardcoded_first_year.keys():
|
||||||
|
survey.select_bus(hardcoded_first_year[s.registration.user_id])
|
||||||
survey.save()
|
survey.save()
|
||||||
|
|
||||||
|
|
||||||
non_men = [s for s in surveys if s.registration.gender != 'male']
|
non_men = [s for s in surveys if s.registration.gender != 'male']
|
||||||
men = [s for s in surveys if s.registration.gender == 'male']
|
men = [s for s in surveys if s.registration.gender == 'male']
|
||||||
|
|
||||||
@ -291,9 +305,7 @@ class WEISurveyAlgorithm2024(WEISurveyAlgorithm):
|
|||||||
non_men_total = registrations.filter(~Q(gender='male')).count()
|
non_men_total = registrations.filter(~Q(gender='male')).count()
|
||||||
for bus in self.get_buses():
|
for bus in self.get_buses():
|
||||||
free_seats = bus.size - WEIMembership.objects.filter(bus=bus, registration__first_year=False).count()
|
free_seats = bus.size - WEIMembership.objects.filter(bus=bus, registration__first_year=False).count()
|
||||||
# Remove hardcoded people
|
free_seats -= sum(1 for s in non_men if s.information.selected_bus_pk == bus.pk)
|
||||||
free_seats -= WEIMembership.objects.filter(bus=bus, registration__first_year=True,
|
|
||||||
registration__information_json__icontains="hardcoded").count()
|
|
||||||
quotas[bus] = 4 + int(non_men_total / registrations.count() * free_seats)
|
quotas[bus] = 4 + int(non_men_total / registrations.count() * free_seats)
|
||||||
|
|
||||||
tqdm_obj = None
|
tqdm_obj = None
|
||||||
@ -308,9 +320,6 @@ class WEISurveyAlgorithm2024(WEISurveyAlgorithm):
|
|||||||
for bus in self.get_buses():
|
for bus in self.get_buses():
|
||||||
free_seats = bus.size - WEIMembership.objects.filter(bus=bus, registration__first_year=False).count()
|
free_seats = bus.size - WEIMembership.objects.filter(bus=bus, registration__first_year=False).count()
|
||||||
free_seats -= sum(1 for s in non_men if s.information.selected_bus_pk == bus.pk)
|
free_seats -= sum(1 for s in non_men if s.information.selected_bus_pk == bus.pk)
|
||||||
# Remove hardcoded people
|
|
||||||
free_seats -= WEIMembership.objects.filter(bus=bus, registration__first_year=True,
|
|
||||||
registration__information_json__icontains="hardcoded").count()
|
|
||||||
quotas[bus] = free_seats
|
quotas[bus] = free_seats
|
||||||
|
|
||||||
if display_tqdm:
|
if display_tqdm:
|
||||||
|
@ -0,0 +1,17 @@
|
|||||||
|
# Generated by Django 4.2.15 on 2024-08-29 20:15
|
||||||
|
|
||||||
|
from django.db import migrations
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('wei', '0009_weiregistration_specific_diet'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='weiregistration',
|
||||||
|
name='specific_diet',
|
||||||
|
),
|
||||||
|
]
|
@ -232,12 +232,6 @@ class WEIRegistration(models.Model):
|
|||||||
verbose_name=_("health issues"),
|
verbose_name=_("health issues"),
|
||||||
)
|
)
|
||||||
|
|
||||||
specific_diet = models.TextField(
|
|
||||||
blank=True,
|
|
||||||
default="",
|
|
||||||
verbose_name=_("specific diet"),
|
|
||||||
)
|
|
||||||
|
|
||||||
emergency_contact_name = models.CharField(
|
emergency_contact_name = models.CharField(
|
||||||
max_length=255,
|
max_length=255,
|
||||||
verbose_name=_("emergency contact name"),
|
verbose_name=_("emergency contact name"),
|
||||||
|
@ -25,12 +25,9 @@
|
|||||||
<dt class="col-xl-6">{% trans 'department'|capfirst %}</dt>
|
<dt class="col-xl-6">{% trans 'department'|capfirst %}</dt>
|
||||||
<dd class="col-xl-6">{{ object.user.profile.get_department_display }}</dd>
|
<dd class="col-xl-6">{{ object.user.profile.get_department_display }}</dd>
|
||||||
|
|
||||||
<dt class="col-xl-6">{% trans 'health issues'|capfirst %}</dt>
|
<dt class="col-xl-6">{% trans 'health issues or specific diet'|capfirst %}</dt>
|
||||||
<dd class="col-xl-6">{{ object.health_issues|default:"—" }}</dd>
|
<dd class="col-xl-6">{{ object.health_issues|default:"—" }}</dd>
|
||||||
|
|
||||||
<dt class="col-xl-6">{% trans 'specific diet'|capfirst %}</dt>
|
|
||||||
<dd class="col-xl-6">{{ object.specific_diet|default:"—" }}</dd>
|
|
||||||
|
|
||||||
<dt class="col-xl-6">{% trans 'suggested bus'|capfirst %}</dt>
|
<dt class="col-xl-6">{% trans 'suggested bus'|capfirst %}</dt>
|
||||||
<dd class="col-xl-6">{{ survey.information.selected_bus_name }}</dd>
|
<dd class="col-xl-6">{{ survey.information.selected_bus_name }}</dd>
|
||||||
</dl>
|
</dl>
|
||||||
|
@ -64,12 +64,9 @@ SPDX-License-Identifier: GPL-3.0-or-later
|
|||||||
<dt class="col-xl-6">{% trans 'birth date'|capfirst %}</dt>
|
<dt class="col-xl-6">{% trans 'birth date'|capfirst %}</dt>
|
||||||
<dd class="col-xl-6">{{ registration.birth_date }}</dd>
|
<dd class="col-xl-6">{{ registration.birth_date }}</dd>
|
||||||
|
|
||||||
<dt class="col-xl-6">{% trans 'health issues'|capfirst %}</dt>
|
<dt class="col-xl-6">{% trans 'health issues or specific diet'|capfirst %}</dt>
|
||||||
<dd class="col-xl-6">{{ registration.health_issues }}</dd>
|
<dd class="col-xl-6">{{ registration.health_issues }}</dd>
|
||||||
|
|
||||||
<dt class="col-xl-6">{% trans 'specific diet'|capfirst %}</dt>
|
|
||||||
<dd class="col-xl-6">{{ registration.specific_diet }}</dd>
|
|
||||||
|
|
||||||
<dt class="col-xl-6">{% trans 'emergency contact name'|capfirst %}</dt>
|
<dt class="col-xl-6">{% trans 'emergency contact name'|capfirst %}</dt>
|
||||||
<dd class="col-xl-6">{{ registration.emergency_contact_name }}</dd>
|
<dd class="col-xl-6">{{ registration.emergency_contact_name }}</dd>
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user