mirror of
				https://gitlab.crans.org/bde/nk20
				synced 2025-11-04 01:12:08 +01:00 
			
		
		
		
	Compare commits
	
		
			19 Commits
		
	
	
		
			9162319734
			...
			New_permis
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					bd6ed27ae5 | ||
| 
						 | 
					43dc676747 | ||
| 
						 | 
					caaeab6b0b | ||
| 
						 | 
					54ba786884 | ||
| 
						 | 
					80e109114f | ||
| 
						 | 
					942d887c2e | ||
| 
						 | 
					a63c34fe37 | ||
| 
						 | 
					2be6133458 | ||
| 
						 | 
					7975fe47a6 | ||
| 
						 | 
					476fbceeea | ||
| 
						 | 
					8fbaa0bdc8 | ||
| 
						 | 
					a0de63effd | ||
| 
						 | 
					09fb1d227e | ||
| 
						 | 
					2e27d4f05c | ||
| 
						 | 
					5d16dc4e7d | ||
| 
						 | 
					3c34033bf5 | ||
| 
						 | 
					131f508433 | ||
| 
						 | 
					c1a353963a | ||
| 
						 | 
					178ce2b579 | 
@@ -31,3 +31,4 @@ class RoleAdmin(admin.ModelAdmin):
 | 
				
			|||||||
    Admin customisation for Role
 | 
					    Admin customisation for Role
 | 
				
			||||||
    """
 | 
					    """
 | 
				
			||||||
    list_display = ('name', )
 | 
					    list_display = ('name', )
 | 
				
			||||||
 | 
					    filter_horizontal = ('permissions',)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3800,6 +3800,38 @@
 | 
				
			|||||||
            "description": "Voir les utilisateurs adhérents au club parent"
 | 
					            "description": "Voir les utilisateurs adhérents au club parent"
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "model": "permission.permission",
 | 
				
			||||||
 | 
					        "pk": 242,
 | 
				
			||||||
 | 
					        "fields": {
 | 
				
			||||||
 | 
					            "model": [
 | 
				
			||||||
 | 
					                "note",
 | 
				
			||||||
 | 
					                "transaction"
 | 
				
			||||||
 | 
					            ],
 | 
				
			||||||
 | 
					            "query": "[\"AND\", {\"destination\": [\"club\", \"note\"]}, [\"OR\", {\"source__balance__gte\": {\"F\": [\"SUB\", [\"MUL\", [\"F\", \"amount\"], [\"F\", \"quantity\"]], 2000]}}, {\"valid\": false}]]",
 | 
				
			||||||
 | 
					            "type": "add",
 | 
				
			||||||
 | 
					            "mask": 2,
 | 
				
			||||||
 | 
					            "field": "",
 | 
				
			||||||
 | 
					            "permanent": false,
 | 
				
			||||||
 | 
					            "description": "Créer une transaction vers la note d'un club"
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "model": "permission.permission",
 | 
				
			||||||
 | 
					        "pk": 243,
 | 
				
			||||||
 | 
					        "fields": {
 | 
				
			||||||
 | 
					            "model": [
 | 
				
			||||||
 | 
					                "member",
 | 
				
			||||||
 | 
					                "profile"
 | 
				
			||||||
 | 
					            ],
 | 
				
			||||||
 | 
					            "query": "{\"user__memberships__club\": [\"club\"], \"user__memberships__date_start__lte\": [\"today\"],\"user__memberships__date_end__gte\": [\"today\"]}",
 | 
				
			||||||
 | 
					            "type": "view",
 | 
				
			||||||
 | 
					            "mask": 3,
 | 
				
			||||||
 | 
					            "field": "",
 | 
				
			||||||
 | 
					            "permanent": false,
 | 
				
			||||||
 | 
					            "description": "Voir les profils des membres du club"
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        "model": "permission.role",
 | 
					        "model": "permission.role",
 | 
				
			||||||
        "pk": 1,
 | 
					        "pk": 1,
 | 
				
			||||||
@@ -3912,7 +3944,8 @@
 | 
				
			|||||||
                12,
 | 
					                12,
 | 
				
			||||||
                13,
 | 
					                13,
 | 
				
			||||||
                14,
 | 
					                14,
 | 
				
			||||||
                22
 | 
					                22,
 | 
				
			||||||
 | 
					                48
 | 
				
			||||||
            ]
 | 
					            ]
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -3961,6 +3994,7 @@
 | 
				
			|||||||
            "for_club": null,
 | 
					            "for_club": null,
 | 
				
			||||||
            "name": "Tr\u00e9sorièr\u22c5e de club",
 | 
					            "name": "Tr\u00e9sorièr\u22c5e de club",
 | 
				
			||||||
            "permissions": [
 | 
					            "permissions": [
 | 
				
			||||||
 | 
					                6,
 | 
				
			||||||
                19,
 | 
					                19,
 | 
				
			||||||
                20,
 | 
					                20,
 | 
				
			||||||
                21,
 | 
					                21,
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -276,11 +276,22 @@ 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[survey.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']
 | 
				
			||||||
@@ -291,9 +302,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 +317,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:
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1032,6 +1032,7 @@ msgid ""
 | 
				
			|||||||
"Register on the mailing list to stay informed of the sport events of the "
 | 
					"Register on the mailing list to stay informed of the sport events of the "
 | 
				
			||||||
"campus (1 mail/week)"
 | 
					"campus (1 mail/week)"
 | 
				
			||||||
msgstr ""
 | 
					msgstr ""
 | 
				
			||||||
 | 
					"S'inscrire sur la liste de diffusion pour rester informé·e des actualités "
 | 
				
			||||||
"sportives sur le campus (1 mail par semaine)"
 | 
					"sportives sur le campus (1 mail par semaine)"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#: apps/member/models.py:113
 | 
					#: apps/member/models.py:113
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -159,6 +159,11 @@ SPDX-License-Identifier: GPL-3.0-or-later
 | 
				
			|||||||
    </nav>
 | 
					    </nav>
 | 
				
			||||||
    <div class="{% block containertype %}container{% endblock %} my-3">
 | 
					    <div class="{% block containertype %}container{% endblock %} my-3">
 | 
				
			||||||
	<div id="messages">
 | 
						<div id="messages">
 | 
				
			||||||
 | 
						    {% if user.is_authenticated %}
 | 
				
			||||||
 | 
							<div class="alert alert-info">
 | 
				
			||||||
 | 
							    Venez au festival des Sens de l'Art du 2 au 7 décembre 🐘 !
 | 
				
			||||||
 | 
							</div>
 | 
				
			||||||
 | 
						    {% endif %}
 | 
				
			||||||
            {% if user.is_authenticated %}
 | 
					            {% if user.is_authenticated %}
 | 
				
			||||||
                {% if not user|is_member:"BDE" %}
 | 
					                {% if not user|is_member:"BDE" %}
 | 
				
			||||||
                    <div class="alert alert-danger">
 | 
					                    <div class="alert alert-danger">
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user