mirror of
				https://gitlab.crans.org/bde/nk20
				synced 2025-10-31 15:50:03 +01:00 
			
		
		
		
	Compare commits
	
		
			39 Commits
		
	
	
		
			non-BDE-me
			...
			944f0468ee
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 944f0468ee | ||
|  | 0a5368d23f | ||
|  | 26b351a51c | ||
|  | 1836677c47 | ||
|  | e7a98c86f0 | ||
|  | eb5044490b | ||
|  | 983d7ec052 | ||
|  | dc56deaf85 | ||
|  | 694f54e1c4 | ||
|  | 0d0fdef363 | ||
|  | 821efbf78b | ||
|  | a209e0d366 | ||
|  | ef485e0628 | ||
|  | 1481aa0635 | ||
|  | 867bf9fd25 | ||
|  | 47fda0ea36 | ||
|  | 623290827a | ||
|  | a87ce625f3 | ||
|  | 3559787fa7 | ||
|  | bd6ed27ae5 | ||
|  | 43dc676747 | ||
|  | caaeab6b0b | ||
|  | 54ba786884 | ||
|  | 80e109114f | ||
|  | 787005e60d | ||
|  | 414e103686 | ||
|  | 942d887c2e | ||
|  | a63c34fe37 | ||
|  | 2be6133458 | ||
|  | 7975fe47a6 | ||
|  | 476fbceeea | ||
|  | 8fbaa0bdc8 | ||
|  | a0de63effd | ||
|  | 09fb1d227e | ||
|  | 2e27d4f05c | ||
|  | 3c34033bf5 | ||
|  | 5a0fe7a6f0 | ||
|  | eda8460014 | ||
|  | 15c71ad31a | 
| @@ -329,7 +329,7 @@ class ActivityEntryView(LoginRequiredMixin, SingleTableMixin, TemplateView): | ||||
|         context["noteuser_ctype"] = ContentType.objects.get_for_model(NoteUser).pk | ||||
|         context["notespecial_ctype"] = ContentType.objects.get_for_model(NoteSpecial).pk | ||||
|  | ||||
|         activities_open = Activity.objects.filter(open=True).filter( | ||||
|         activities_open = Activity.objects.filter(open=True, activity_type__manage_entries=True).filter( | ||||
|             PermissionBackend.filter_queryset(self.request, Activity, "view")).distinct().all() | ||||
|         context["activities_open"] = [a for a in activities_open | ||||
|                                       if PermissionBackend.check_perm(self.request, | ||||
|   | ||||
| @@ -44,6 +44,7 @@ class ProfileForm(forms.ModelForm): | ||||
|     """ | ||||
|     A form for the extras field provided by the :model:`member.Profile` model. | ||||
|     """ | ||||
|     # Remove widget=forms.HiddenInput() if you want to use report frequency. | ||||
|     report_frequency = forms.IntegerField(required=False, initial=0, label=_("Report frequency")) | ||||
|  | ||||
|     last_report = forms.DateTimeField(required=False, disabled=True, label=_("Last report date")) | ||||
| @@ -76,7 +77,8 @@ class ProfileForm(forms.ModelForm): | ||||
|     class Meta: | ||||
|         model = Profile | ||||
|         fields = '__all__' | ||||
|         exclude = ('user', 'email_confirmed', 'registration_valid', ) | ||||
|         # Remove ml_[asso]_registration from exclude if the concerned association uses nk20 to manage its mailing list. | ||||
|         exclude = ('user', 'email_confirmed', 'registration_valid', 'ml_sport_registration', ) | ||||
|  | ||||
|  | ||||
| class ImageForm(forms.Form): | ||||
|   | ||||
							
								
								
									
										18
									
								
								apps/member/migrations/0013_auto_20240807_1409.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								apps/member/migrations/0013_auto_20240807_1409.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| # Generated by Django 2.2.28 on 2024-08-07 12:09 | ||||
|  | ||||
| from django.db import migrations, models | ||||
|  | ||||
|  | ||||
| class Migration(migrations.Migration): | ||||
|  | ||||
|     dependencies = [ | ||||
|         ('member', '0012_club_add_registration_form'), | ||||
|     ] | ||||
|  | ||||
|     operations = [ | ||||
|         migrations.AlterField( | ||||
|             model_name='profile', | ||||
|             name='promotion', | ||||
|             field=models.PositiveSmallIntegerField(default=2024, help_text='Year of entry to the school (None if not ENS student)', null=True, verbose_name='promotion'), | ||||
|         ), | ||||
|     ] | ||||
| @@ -26,6 +26,7 @@ from note_kfet.middlewares import _set_current_request | ||||
| from permission.backends import PermissionBackend | ||||
| from permission.models import Role | ||||
| from permission.views import ProtectQuerysetMixin, ProtectedCreateView | ||||
| from django import forms | ||||
|  | ||||
| from .forms import UserForm, ProfileForm, ImageForm, ClubForm, MembershipForm, \ | ||||
|     CustomAuthenticationForm, MembershipRolesForm | ||||
| @@ -72,11 +73,24 @@ class UserUpdateView(ProtectQuerysetMixin, LoginRequiredMixin, UpdateView): | ||||
|         form.fields['email'].required = True | ||||
|         form.fields['email'].help_text = _("This address must be valid.") | ||||
|  | ||||
|         if PermissionBackend.check_perm(self.request, "member.change_profile", context['user_object'].profile): | ||||
|             context['profile_form'] = self.profile_form(instance=context['user_object'].profile, | ||||
|                                                         data=self.request.POST if self.request.POST else None) | ||||
|             if not self.object.profile.report_frequency: | ||||
|                 del context['profile_form'].fields["last_report"] | ||||
|         profile_form = self.profile_form(instance=context['user_object'].profile, | ||||
|                                          data=self.request.POST if self.request.POST else None) | ||||
|  | ||||
|         if not self.object.profile.report_frequency: | ||||
|             del profile_form.fields["last_report"] | ||||
|  | ||||
|         fields_to_check = list(profile_form.fields.keys()) | ||||
|         fields_modifiable = False | ||||
|  | ||||
|         # Delete the fields for which the user does not have the permission to modify | ||||
|         for field_name in fields_to_check: | ||||
|             if not PermissionBackend.check_perm(self.request, f"member.change_profile_{field_name}", context['user_object'].profile): | ||||
|                 profile_form.fields[field_name].widget = forms.HiddenInput() | ||||
|             else: | ||||
|                 fields_modifiable = True | ||||
|  | ||||
|         if fields_modifiable: | ||||
|             context['profile_form'] = profile_form | ||||
|  | ||||
|         return context | ||||
|  | ||||
|   | ||||
							
								
								
									
										65
									
								
								apps/note/templates/note/mails/summary_notes_report.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								apps/note/templates/note/mails/summary_notes_report.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | ||||
| {% load pretty_money %} | ||||
| {% load i18n %} | ||||
|  | ||||
| <!DOCTYPE html> | ||||
| <html lang="fr"> | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <title>[Note Kfet] Récapitulatif de trésorerie</title> | ||||
| </head> | ||||
| <body> | ||||
| <h1> | ||||
|   Récapitulatif de trésorerie au {{ summary.date|date:"d/m/Y" }} à {{ summary.date|date:"H:i:s" }} : | ||||
| </h1> | ||||
|  | ||||
| <h2> | ||||
|   Tous les utilisateur⋅rices : | ||||
| </h2> | ||||
| <ul> | ||||
|   <li>Positifs : {{ summary.total_positive_user }} soit {{ summary.balance_positive_user / 100 }} €</li> | ||||
|   <li>Neutres : {{ summary.total_zero_user }}</li> | ||||
|   <li>Négatifs : {{ summary.total_negative_user }} soit {{ summary.balance_negative_user / 100 }} €</li> | ||||
| </ul> | ||||
|  | ||||
| <h2> | ||||
|   Les {{ summary.total_positive_user_bde + summary.total_zero_user_bde + summary.total_negative_user_bde }} adhérent⋅es BDE : | ||||
| </h2> | ||||
| <ul> | ||||
|   <li>Positifs : {{ summary.total_positive_user_bde }} soit {{ summary.balance_positive_user_bde / 100 }} €</li> | ||||
|   <li>Neutres : {{ summary.total_zero_user_bde }}</li> | ||||
|   <li>Négatifs : {{ summary.total_negative_user_bde }} soit {{ summary.balance_negative_user_bde / 100 }} €</li> | ||||
| </ul> | ||||
|  | ||||
| <h2> | ||||
|   Clubs : | ||||
| </h2> | ||||
| <ul> | ||||
|   <li>Positifs : {{ summary.total_positive_club }} soit {{ summary.balance_positive_club / 100 }} €</li> | ||||
|   <li>Neutres : {{ summary.total_zero_club }}</li> | ||||
|   <li>Négatifs : {{ summary.total_negative_club }} soit {{ summary.balance_negative_club / 100 }} €</li> | ||||
| </ul> | ||||
|  | ||||
| <h2> | ||||
|   Clubs hors BDE / Kfet et club dont le nom fini par "- BDE" : | ||||
| </h2> | ||||
| <ul> | ||||
|   <li>Positifs : {{ summary.total_positive_club_nbde }} soit {{ summary.balance_positive_club_nbde / 100 }} €</li> | ||||
|   <li>Neutres : {{ summary.total_zero_club_nbde }}</li> | ||||
|   <li>Négatifs : {{ summary.total_negative_club_nbde }} soit {{ summary.balance_negative_club_nbde / 100 }} €</li> | ||||
| </ul> | ||||
|  | ||||
| <h2> | ||||
|   Progression : | ||||
| </h2> | ||||
| <ul> | ||||
|   <li>Ceci correspond à une différence de {{ balance_difference_user / 100 }} € pour les utilisateur⋅rices</li> | ||||
|   <li>Ceci correspond à une différence de {{ balance_difference_club / 100 }} € pour les clubs</li> | ||||
| </ul> | ||||
|  | ||||
| -- | ||||
| <p> | ||||
|     Le BDE<br> | ||||
|     {% trans "Mail generated by the Note Kfet on the" %} {% now "j F Y à H:i:s" %} | ||||
| </p> | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										33
									
								
								apps/note/templates/note/mails/summary_notes_report.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								apps/note/templates/note/mails/summary_notes_report.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| {% load pretty_money %} | ||||
| {% load i18n %} | ||||
|  | ||||
| Récapitulatif de trésorerie au {{ summary.date|date:"d/m/Y" }} à {{ summary.date|date:"H:i:s" }} : | ||||
|  | ||||
| Tous les utilisateur⋅rices : | ||||
|   - Positifs : {{ summary.total_positive_user }} soit {{ summary.balance_positive_user / 100 }} € | ||||
|   - Neutres : {{ summary.total_zero_user }} | ||||
|   - Négatifs : {{ summary.total_negative_user }} soit {{ summary.balance_negative_user / 100 }} € | ||||
|  | ||||
| Les {{ summary.total_positive_user_bde + summary.total_zero_user_bde + summary.total_negative_user_bde }} adhérent⋅es BDE : | ||||
|   - Positifs : {{ summary.total_positive_user_bde }} soit {{ summary.balance_positive_user_bde / 100 }} € | ||||
|   - Neutres : {{ summary.total_zero_user_bde }} | ||||
|   - Négatifs : {{ summary.total_negative_user_bde }} soit {{ summary.balance_negative_user_bde /100 }} € | ||||
|  | ||||
| Clubs : | ||||
|   - Positifs : {{ summary.total_positive_club }} soit {{ summary.balance_positive_club / 100 }} € | ||||
|   - Neutres : {{ summary.total_zero_club }} | ||||
|   - Négatifs : {{ summary.total_negative_club }} soit {{ summary.balance_negative_club / 100 }} € | ||||
|  | ||||
| Clubs hors BDE / Kfet et club dont le nom fini par "- BDE" : | ||||
|   - Positifs : {{ summary.total_positive_club_nbde }} soit {{ summary.balance_positive_club_nbde / 100 }} € | ||||
|   - Neutres : {{ summary.total_zero_club_nbde }} | ||||
|   - Négatifs : {{ summary.total_negative_club_nbde }} soit {{ summary.balance_negative_club_nbde / 100 }} € | ||||
|  | ||||
| Progression : | ||||
|   - Ceci correspond à une différence de {{ balance_difference_user / 100 }} € pour les utilisateur⋅rices | ||||
|   - Ceci correspond à une différence de {{ balance_difference_club / 100 }} € pour les clubs | ||||
|  | ||||
| -- | ||||
| Le BDE | ||||
|  | ||||
| {% trans "Mail generated by the Note Kfet on the" %} {% now "j F Y à H:i:s" %} | ||||
| @@ -31,3 +31,4 @@ class RoleAdmin(admin.ModelAdmin): | ||||
|     Admin customisation for Role | ||||
|     """ | ||||
|     list_display = ('name', ) | ||||
|     filter_horizontal = ('permissions',) | ||||
|   | ||||
| @@ -127,7 +127,7 @@ | ||||
|                 "auth", | ||||
|                 "user" | ||||
|             ], | ||||
|             "query": "{\"pk\": [\"user\", \"pk\"]}", | ||||
|             "query": "[\"AND\", {\"pk\": [\"user\", \"pk\"]}, {\"memberships__club__parent_club__isnull\": true}]", | ||||
|             "type": "change", | ||||
|             "mask": 1, | ||||
|             "field": "last_login", | ||||
| @@ -3800,6 +3800,102 @@ | ||||
|             "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.permission", | ||||
|         "pk": 244, | ||||
|         "fields": { | ||||
|             "model": [ | ||||
|                 "member", | ||||
|                 "profile" | ||||
|             ], | ||||
|             "query": "{}", | ||||
|             "type": "change", | ||||
|             "mask": 3, | ||||
|             "field": "ml_events_registration", | ||||
|             "permanent": false, | ||||
|             "description": "Modifier l'abonnement à la Newsletter BDE pour n'importe quel profil" | ||||
|         } | ||||
|     }, | ||||
|     { | ||||
|         "model": "permission.permission", | ||||
|         "pk": 245, | ||||
|         "fields": { | ||||
|             "model": [ | ||||
|                 "member", | ||||
|                 "profile" | ||||
|             ], | ||||
|             "query": "{}", | ||||
|             "type": "change", | ||||
|             "mask": 3, | ||||
|             "field": "ml_art_registration", | ||||
|             "permanent": false, | ||||
|             "description": "Modifier l'abonnement à la Newsletter Art pour n'importe quel profil" | ||||
|         } | ||||
|     }, | ||||
|     { | ||||
|         "model": "permission.permission", | ||||
|         "pk": 246, | ||||
|         "fields": { | ||||
|             "model": [ | ||||
|                 "member", | ||||
|                 "profile" | ||||
|             ], | ||||
|             "query": "{}", | ||||
|             "type": "change", | ||||
|             "mask": 3, | ||||
|             "field": "ml_sport_registration", | ||||
|             "permanent": false, | ||||
|             "description": "Modifier l'abonnement à la Newsletter Sport pour n'importe quel profil" | ||||
|         } | ||||
|     }, | ||||
|     { | ||||
|         "model": "permission.permission", | ||||
|         "pk": 247, | ||||
|         "fields": { | ||||
|             "model": [ | ||||
|                 "activity", | ||||
|                 "guest" | ||||
|             ], | ||||
|             "query": "{\"activity__organizer\": [\"club\"]}", | ||||
|             "type": "view", | ||||
|             "mask": 2, | ||||
|             "field": "", | ||||
|             "permanent": false, | ||||
|             "description": "Voir les personnes invitées aux événements organisés par son club" | ||||
|         } | ||||
|     }, | ||||
|     { | ||||
|         "model": "permission.role", | ||||
|         "pk": 1, | ||||
| @@ -4377,7 +4473,7 @@ | ||||
|                 238 | ||||
|             ] | ||||
|         } | ||||
|     }, | ||||
|     },   | ||||
|     { | ||||
|         "model": "wei.weirole", | ||||
|         "pk": 12, | ||||
|   | ||||
 Submodule apps/scripts updated: f580f9b9e9...f76acb3248
									
								
							| @@ -5,13 +5,13 @@ from django.contrib import admin | ||||
| from note_kfet.admin import admin_site | ||||
|  | ||||
| from .forms import ProductForm | ||||
| from .models import RemittanceType, Remittance, SogeCredit, Invoice, Product | ||||
| from .models import Invoice, NoteSummary, Product, RemittanceType, Remittance, SogeCredit | ||||
|  | ||||
|  | ||||
| @admin.register(RemittanceType, site=admin_site) | ||||
| class RemittanceTypeAdmin(admin.ModelAdmin): | ||||
|     """ | ||||
|     Admin customisation for RemiitanceType | ||||
|     Admin customisation for RemittanceType | ||||
|     """ | ||||
|     list_display = ('note', ) | ||||
|  | ||||
| @@ -55,3 +55,19 @@ class InvoiceAdmin(admin.ModelAdmin): | ||||
|     """ | ||||
|     list_display = ('object', 'id', 'bde', 'name', 'date', 'acquitted',) | ||||
|     inlines = (ProductInline,) | ||||
|  | ||||
|  | ||||
| @admin.register(NoteSummary, site=admin_site) | ||||
| class NoteSummaryAdmin(admin.ModelAdmin): | ||||
|     """ | ||||
|     Admin customisation for NoteSummary | ||||
|     """ | ||||
|     list_display = ( | ||||
|         'date', 'total_positive_user', 'balance_positive_user', 'total_positive_user_bde', | ||||
|         'balance_positive_user_bde', 'total_zero_user', 'total_zero_user_bde', 'total_negative_user', | ||||
|         'balance_negative_user', 'total_negative_user_bde', 'balance_negative_user_bde', | ||||
|         'total_vnegative_user', 'balance_vnegative_user', 'total_vnegative_user_bde', | ||||
|         'balance_vnegative_user_bde', 'total_positive_club', 'balance_positive_club', | ||||
|         'total_positive_club_nbde', 'balance_positive_club_nbde', 'total_zero_club', 'total_zero_club_nbde', | ||||
|         'total_negative_club', 'balance_negative_club', 'total_negative_club_nbde', 'balance_negative_club_nbde', | ||||
|     ) | ||||
|   | ||||
							
								
								
									
										49
									
								
								apps/treasury/migrations/0009_notesummary.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								apps/treasury/migrations/0009_notesummary.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | ||||
| # Generated by Django 2.2.28 on 2024-08-07 12:09 | ||||
|  | ||||
| import datetime | ||||
| from django.db import migrations, models | ||||
|  | ||||
|  | ||||
| class Migration(migrations.Migration): | ||||
|  | ||||
|     dependencies = [ | ||||
|         ('treasury', '0008_auto_20240322_0045'), | ||||
|     ] | ||||
|  | ||||
|     operations = [ | ||||
|         migrations.CreateModel( | ||||
|             name='NoteSummary', | ||||
|             fields=[ | ||||
|                 ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), | ||||
|                 ('date', models.DateField(default=datetime.date.today, verbose_name='Date')), | ||||
|                 ('total_positive_user', models.PositiveIntegerField(verbose_name='Total positive user')), | ||||
|                 ('balance_positive_user', models.PositiveIntegerField(verbose_name='Balance positive user')), | ||||
|                 ('total_positive_user_bde', models.PositiveIntegerField(verbose_name='Total positive user BDE')), | ||||
|                 ('balance_positive_user_bde', models.PositiveIntegerField(verbose_name='Balance positive user BDE')), | ||||
|                 ('total_zero_user', models.PositiveIntegerField(verbose_name='Total zero user')), | ||||
|                 ('total_zero_user_bde', models.PositiveIntegerField(verbose_name='Total zero user BDE')), | ||||
|                 ('total_negative_user', models.PositiveIntegerField(verbose_name='Total negative user')), | ||||
|                 ('balance_negative_user', models.PositiveIntegerField(verbose_name='Balance negative user')), | ||||
|                 ('total_negative_user_bde', models.PositiveIntegerField(verbose_name='Total negative user BDE')), | ||||
|                 ('balance_negative_user_bde', models.PositiveIntegerField(verbose_name='Balance negative user BDE')), | ||||
|                 ('total_vnegative_user', models.PositiveIntegerField(verbose_name='Total very negative user')), | ||||
|                 ('balance_vnegative_user', models.PositiveIntegerField(verbose_name='Balance very negative user')), | ||||
|                 ('total_vnegative_user_bde', models.PositiveIntegerField(verbose_name='Total very negative user BDE')), | ||||
|                 ('balance_vnegative_user_bde', models.PositiveIntegerField(verbose_name='Balance very negative user BDE')), | ||||
|                 ('total_positive_club', models.PositiveIntegerField(verbose_name='Total positive club')), | ||||
|                 ('balance_positive_club', models.PositiveIntegerField(verbose_name='Balance positive club')), | ||||
|                 ('total_positive_club_nbde', models.PositiveIntegerField(verbose_name='Total positive club nbde')), | ||||
|                 ('balance_positive_club_nbde', models.PositiveIntegerField(verbose_name='Balance positive club nbde')), | ||||
|                 ('total_zero_club', models.PositiveIntegerField(verbose_name='Total zero club')), | ||||
|                 ('total_zero_club_nbde', models.PositiveIntegerField(verbose_name='Total zero club nbde')), | ||||
|                 ('total_negative_club', models.PositiveIntegerField(verbose_name='Total negative club')), | ||||
|                 ('balance_negative_club', models.PositiveIntegerField(verbose_name='Balance negative club')), | ||||
|                 ('total_negative_club_nbde', models.PositiveIntegerField(verbose_name='Total negative club nbde')), | ||||
|                 ('balance_negative_club_nbde', models.PositiveIntegerField(verbose_name='Balance negative club nbde')), | ||||
|             ], | ||||
|             options={ | ||||
|                 'verbose_name': 'Summary', | ||||
|                 'verbose_name_plural': 'Summaries', | ||||
|             }, | ||||
|         ), | ||||
|     ] | ||||
| @@ -460,3 +460,117 @@ class SogeCredit(models.Model): | ||||
|             self.credit_transaction._force_save = True | ||||
|             self.credit_transaction.save() | ||||
|         super().delete(**kwargs) | ||||
|  | ||||
|  | ||||
| class NoteSummary(models.Model): | ||||
|     """ | ||||
|     Summary of every notes | ||||
|     """ | ||||
|  | ||||
|     date = models.DateField( | ||||
|         default=date.today, | ||||
|         verbose_name=_("Date"), | ||||
|     ) | ||||
|  | ||||
|     total_positive_user = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total positive user"), | ||||
|     ) | ||||
|  | ||||
|     balance_positive_user = models.PositiveIntegerField( | ||||
|         verbose_name=_("Balance positive user"), | ||||
|     ) | ||||
|  | ||||
|     total_positive_user_bde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total positive user BDE"), | ||||
|     ) | ||||
|  | ||||
|     balance_positive_user_bde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Balance positive user BDE"), | ||||
|     ) | ||||
|  | ||||
|     total_zero_user = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total zero user"), | ||||
|     ) | ||||
|  | ||||
|     total_zero_user_bde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total zero user BDE"), | ||||
|     ) | ||||
|  | ||||
|     total_negative_user = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total negative user"), | ||||
|     ) | ||||
|  | ||||
|     balance_negative_user = models.PositiveIntegerField( | ||||
|         verbose_name=_("Balance negative user"), | ||||
|     ) | ||||
|  | ||||
|     total_negative_user_bde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total negative user BDE"), | ||||
|     ) | ||||
|  | ||||
|     balance_negative_user_bde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Balance negative user BDE"), | ||||
|     ) | ||||
|  | ||||
|     total_vnegative_user = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total very negative user"), | ||||
|     ) | ||||
|  | ||||
|     balance_vnegative_user = models.PositiveIntegerField( | ||||
|         verbose_name=_("Balance very negative user"), | ||||
|     ) | ||||
|  | ||||
|     total_vnegative_user_bde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total very negative user BDE"), | ||||
|     ) | ||||
|  | ||||
|     balance_vnegative_user_bde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Balance very negative user BDE"), | ||||
|     ) | ||||
|  | ||||
|     total_positive_club = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total positive club"), | ||||
|     ) | ||||
|  | ||||
|     balance_positive_club = models.PositiveIntegerField( | ||||
|         verbose_name=_("Balance positive club"), | ||||
|     ) | ||||
|  | ||||
|     total_positive_club_nbde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total positive club nbde"), | ||||
|     ) | ||||
|  | ||||
|     balance_positive_club_nbde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Balance positive club nbde"), | ||||
|     ) | ||||
|  | ||||
|     total_zero_club = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total zero club"), | ||||
|     ) | ||||
|  | ||||
|     total_zero_club_nbde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total zero club nbde"), | ||||
|     ) | ||||
|  | ||||
|     total_negative_club = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total negative club"), | ||||
|     ) | ||||
|  | ||||
|     balance_negative_club = models.PositiveIntegerField( | ||||
|         verbose_name=_("Balance negative club"), | ||||
|     ) | ||||
|  | ||||
|     total_negative_club_nbde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Total negative club nbde"), | ||||
|     ) | ||||
|  | ||||
|     balance_negative_club_nbde = models.PositiveIntegerField( | ||||
|         verbose_name=_("Balance negative club nbde"), | ||||
|     ) | ||||
|  | ||||
|     class Meta: | ||||
|         verbose_name = _("Summary") | ||||
|         verbose_name_plural = _("Summaries") | ||||
|  | ||||
|     def __str__(self): | ||||
|         return "Note summary of {date}".format(date=self.date) | ||||
|   | ||||
| @@ -279,7 +279,6 @@ class WEISurveyAlgorithm2024(WEISurveyAlgorithm): | ||||
|         # 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) | ||||
| @@ -288,15 +287,13 @@ class WEISurveyAlgorithm2024(WEISurveyAlgorithm): | ||||
|         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 | ||||
|         for survey in surveys: | ||||
|             survey.free() | ||||
|             if survey.registration.user_id in hardcoded_first_year.keys(): | ||||
|                 survey.select_bus(hardcoded_first_year[s.registration.user_id]) | ||||
|                 survey.select_bus(hardcoded_first_year[survey.registration.user_id]) | ||||
|             survey.save() | ||||
|  | ||||
|  | ||||
|         non_men = [s for s in surveys if s.registration.gender != 'male'] | ||||
|         men = [s for s in surveys if s.registration.gender == 'male'] | ||||
|  | ||||
|   | ||||
| @@ -795,11 +795,11 @@ msgstr "Masque de permissions" | ||||
|  | ||||
| #: apps/member/forms.py:46 | ||||
| msgid "Report frequency" | ||||
| msgstr "Fréquence des rapports (en jours)" | ||||
| msgstr "Fréquence des relevés (en jours)" | ||||
|  | ||||
| #: apps/member/forms.py:48 | ||||
| msgid "Last report date" | ||||
| msgstr "Date de dernier rapport" | ||||
| msgstr "Date de dernier relevé" | ||||
|  | ||||
| #: apps/member/forms.py:52 | ||||
| msgid "" | ||||
| @@ -1032,6 +1032,7 @@ msgid "" | ||||
| "Register on the mailing list to stay informed of the sport events of the " | ||||
| "campus (1 mail/week)" | ||||
| msgstr "" | ||||
| "S'inscrire sur la liste de diffusion pour rester informé·e des actualités " | ||||
| "sportives sur le campus (1 mail par semaine)" | ||||
|  | ||||
| #: apps/member/models.py:113 | ||||
| @@ -1044,11 +1045,11 @@ msgstr "" | ||||
|  | ||||
| #: apps/member/models.py:117 | ||||
| msgid "report frequency (in days)" | ||||
| msgstr "fréquence des rapports (en jours)" | ||||
| msgstr "fréquence des relevés (en jours)" | ||||
|  | ||||
| #: apps/member/models.py:122 | ||||
| msgid "last report date" | ||||
| msgstr "date de dernier rapport" | ||||
| msgstr "date de dernier relevé" | ||||
|  | ||||
| #: apps/member/models.py:127 | ||||
| msgid "email confirmed" | ||||
| @@ -1970,6 +1971,8 @@ msgstr "Historique des transactions récentes" | ||||
| #: apps/note/templates/note/mails/negative_balance.txt:25 | ||||
| #: apps/note/templates/note/mails/negative_notes_report.html:46 | ||||
| #: apps/note/templates/note/mails/negative_notes_report.txt:13 | ||||
| #: apps/note/templates/note/mails/summary_notes_report.html:62 | ||||
| #: apps/note/templates/note/mails/summary_ntoes_report.txt:33 | ||||
| #: apps/note/templates/note/mails/weekly_report.html:51 | ||||
| #: apps/note/templates/note/mails/weekly_report.txt:32 | ||||
| #: apps/registration/templates/registration/mails/email_validation_email.html:40 | ||||
| @@ -2526,6 +2529,7 @@ msgid "Address" | ||||
| msgstr "Adresse" | ||||
|  | ||||
| #: apps/treasury/models.py:69 apps/treasury/models.py:202 | ||||
| #: apps/treasury/models.py:472 | ||||
| msgid "Date" | ||||
| msgstr "Date" | ||||
|  | ||||
| @@ -2644,6 +2648,102 @@ msgstr "" | ||||
| "Cet·te utilisateur·rice n'a pas assez d'argent pour payer les adhésions avec sa " | ||||
| "note. Merci de lui demander de recharger sa note avant d'invalider ce crédit." | ||||
|  | ||||
| #: apps/treasury/models.py:476 | ||||
| msgid "Total positive user" | ||||
| msgstr "Nombre d'utilisateur⋅rices en positif" | ||||
|  | ||||
| #: apps/treasury/models.py:480 | ||||
| msgid "Balance positive user" | ||||
| msgstr "Solde des utilisateur⋅rices en positif" | ||||
|  | ||||
| #: apps/treasury/models.py:484 | ||||
| msgid "Total positive user BDE" | ||||
| msgstr "Nombre d'adhérent⋅es au BDE en positif" | ||||
|  | ||||
| #: apps/treasury/models.py:488 | ||||
| msgid "Balance positive user BDE" | ||||
| msgstr "Solde des adhérent⋅es au BDE en positif" | ||||
|  | ||||
| #: apps/treasury/models.py:492 | ||||
| msgid "Total zero user" | ||||
| msgstr "Nombre d'utilisateur⋅rices à zéro" | ||||
|  | ||||
| #: apps/treasury/models.py:496 | ||||
| msgid "Total zero user BDE" | ||||
| msgstr "Nombre d'adhérent⋅es au BDE à zéro" | ||||
|  | ||||
| #: apps/treasury/models.py:500 | ||||
| msgid "Total negative user" | ||||
| msgstr "Nombre d'utilisateur⋅rices en négatif" | ||||
|  | ||||
| #: apps/treasury/models.py:504 | ||||
| msgid "Balance negative user" | ||||
| msgstr "Solde des utilisateur⋅rices en négatif" | ||||
|  | ||||
| #: apps/treasury/models.py:508 | ||||
| msgid "Total negative user BDE" | ||||
| msgstr "Nombre d'adhérent⋅es au BDE en négatif" | ||||
|  | ||||
| #: apps/treasury/models.py:512 | ||||
| msgid "Balance negative user BDE" | ||||
| msgstr "Solde des adhérent⋅es au BDE en négatif" | ||||
|  | ||||
| #: apps/treasury/models.py:516 | ||||
| msgid "Total very negative user" | ||||
| msgstr "Nombre d'utilisateur⋅rices en négatif sévère" | ||||
|  | ||||
| #: apps/treasury/models.py:520 | ||||
| msgid "Balance very negative user" | ||||
| msgstr "Solde des utilisateur⋅rices en négatif sévère" | ||||
|  | ||||
| #: apps/treasury/models.py:524 | ||||
| msgid "Total very negative user BDE" | ||||
| msgstr "Nombre d'adhérent⋅es au BDE en négatif sévère" | ||||
|  | ||||
| #: apps/treasury/models.py:528 | ||||
| msgid "Balance very negative user BDE" | ||||
| msgstr "Solde des adhérent⋅es au BDE en négatif sévère" | ||||
|  | ||||
| #: apps/treasury/models.py:532 | ||||
| msgid "Total positive club" | ||||
| msgstr "Nombre de clubs en positif" | ||||
|  | ||||
| #: apps/treasury/models.py:536 | ||||
| msgid "Balance positive club" | ||||
| msgstr "Solde des clubs en positif" | ||||
|  | ||||
| #: apps/treasury/models.py:540 | ||||
| msgid "Total positive club nbde" | ||||
| msgstr "Nombre de clubs non-BDE en positif" | ||||
|  | ||||
| #: apps/treasury/models.py:544 | ||||
| msgid "Balance positive club nbde" | ||||
| msgstr "Solde des clubs non-BDE en positif" | ||||
|  | ||||
| #: apps/treasury/models.py:548 | ||||
| msgid "Total zero club" | ||||
| msgstr "Nombre de clubs à zéro" | ||||
|  | ||||
| #: apps/treasury/models.py:552 | ||||
| msgid "Total zero club nbde" | ||||
| msgstr "Nombre de clubs non-BDE à zéro" | ||||
|  | ||||
| #: apps/treasury/models.py:556 | ||||
| msgid "Total negative club" | ||||
| msgstr "Nombre de clubs en négatif" | ||||
|  | ||||
| #: apps/treasury/models.py:560 | ||||
| msgid "Balance negative club" | ||||
| msgstr "Solde des clubs en négatif" | ||||
|  | ||||
| #: apps/treasury/models.py:564 | ||||
| msgid "Total negative club nbde" | ||||
| msgstr "Nombre de clubs non-BDE en négatif" | ||||
|  | ||||
| #: apps/treasury/models.py:568 | ||||
| msgid "Balance negative club nbde" | ||||
| msgstr "Solde des clubs non-BDE en négatif" | ||||
|  | ||||
| #: apps/treasury/tables.py:20 | ||||
| msgid "Invoice #{:d}" | ||||
| msgstr "Facture n°{:d}" | ||||
|   | ||||
| @@ -20,9 +20,13 @@ MAILTO=notekfet2020@lists.crans.org | ||||
|  00  5     *   *   2     root   cd /var/www/note_kfet && env/bin/python manage.py send_mail_to_negative_balances --spam --negative-amount 1 -v 0 | ||||
| # Envoyer le rapport mensuel aux trésoriers et respos info | ||||
|  00  8     *   *   5     root   cd /var/www/note_kfet && env/bin/python manage.py send_mail_to_negative_balances --report --add-years 1 -v 0 | ||||
| # Envoyer le recap de tresorerie | ||||
|  00  8     *   *   5     root   cd /var/www/note_kfet && env/bin/python manage.py send_summary_notes_report --negative-amount 2000 | ||||
| # Envoyer les rapports aux gens | ||||
|  55  6     *   *   *     root   cd /var/www/note_kfet && env/bin/python manage.py send_reports -v 0 | ||||
| # Mettre à jour les boutons mis en avant | ||||
|  00  9     *   *   *     root   cd /var/www/note_kfet && env/bin/python manage.py refresh_highlighted_buttons -v 0 | ||||
| # Vider les tokens Oauth2 | ||||
|  00  6     *   *   *     root   cd /var/www/note_kfet && env/bin/python manage.py cleartokens -v 0 | ||||
| # Envoyer la liste des abonnés à la NL BDA | ||||
|  00  8     *   *   0     root   cd /var/www/note_kfet && env/bin/python manage.py extract_ml_registrations -t art -v 0 | ||||
| @@ -158,7 +158,7 @@ SPDX-License-Identifier: GPL-3.0-or-later | ||||
|         </div> | ||||
|     </nav> | ||||
|     <div class="{% block containertype %}container{% endblock %} my-3"> | ||||
|         <div id="messages"> | ||||
| 	<div id="messages"> | ||||
|             {% if user.is_authenticated %} | ||||
|                 {% if not user|is_member:"BDE" %} | ||||
|                     <div class="alert alert-danger"> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user