mirror of
				https://gitlab.crans.org/bde/nk20
				synced 2025-10-30 23:39:54 +01:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			update_inv
			...
			23c8d3fdbd
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 23c8d3fdbd | ||
|  | 93aed87265 | 
| @@ -35,7 +35,7 @@ class GuestAdmin(admin.ModelAdmin): | |||||||
|     """ |     """ | ||||||
|     Admin customisation for Guest |     Admin customisation for Guest | ||||||
|     """ |     """ | ||||||
|     list_display = ('last_name', 'first_name', 'school', 'activity', 'inviter') |     list_display = ('last_name', 'first_name', 'activity', 'inviter') | ||||||
|     form = GuestForm |     form = GuestForm | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -51,9 +51,9 @@ class GuestViewSet(ReadProtectedModelViewSet): | |||||||
|     queryset = Guest.objects.order_by('id') |     queryset = Guest.objects.order_by('id') | ||||||
|     serializer_class = GuestSerializer |     serializer_class = GuestSerializer | ||||||
|     filter_backends = [DjangoFilterBackend, RegexSafeSearchFilter] |     filter_backends = [DjangoFilterBackend, RegexSafeSearchFilter] | ||||||
|     filterset_fields = ['activity', 'activity__name', 'last_name', 'first_name', 'school', 'inviter', 'inviter__alias__name', |     filterset_fields = ['activity', 'activity__name', 'last_name', 'first_name', 'inviter', 'inviter__alias__name', | ||||||
|                         'inviter__alias__normalized_name', ] |                         'inviter__alias__normalized_name', ] | ||||||
|     search_fields = ['$activity__name', '$last_name', '$first_name', '$school', '$inviter__user__email', '$inviter__alias__name', |     search_fields = ['$activity__name', '$last_name', '$first_name', '$inviter__user__email', '$inviter__alias__name', | ||||||
|                      '$inviter__alias__normalized_name', ] |                      '$inviter__alias__normalized_name', ] | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -107,7 +107,7 @@ class GuestForm(forms.ModelForm): | |||||||
|  |  | ||||||
|     class Meta: |     class Meta: | ||||||
|         model = Guest |         model = Guest | ||||||
|         fields = ('last_name', 'first_name', 'school', 'inviter', ) |         fields = ('last_name', 'first_name', 'inviter', ) | ||||||
|         widgets = { |         widgets = { | ||||||
|             "inviter": Autocomplete( |             "inviter": Autocomplete( | ||||||
|                 NoteUser, |                 NoteUser, | ||||||
|   | |||||||
| @@ -1,18 +0,0 @@ | |||||||
| # Generated by Django 4.2.20 on 2025-03-25 09:58 |  | ||||||
|  |  | ||||||
| from django.db import migrations, models |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class Migration(migrations.Migration): |  | ||||||
|     dependencies = [ |  | ||||||
|         ("activity", "0005_alter_opener_options_alter_opener_opener"), |  | ||||||
|     ] |  | ||||||
|  |  | ||||||
|     operations = [ |  | ||||||
|         migrations.AddField( |  | ||||||
|             model_name="guest", |  | ||||||
|             name="school", |  | ||||||
|             field=models.CharField(default="", max_length=255, verbose_name="school"), |  | ||||||
|             preserve_default=False, |  | ||||||
|         ), |  | ||||||
|     ] |  | ||||||
| @@ -247,11 +247,6 @@ class Guest(models.Model): | |||||||
|         verbose_name=_("first name"), |         verbose_name=_("first name"), | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|     school = models.CharField( |  | ||||||
|         max_length=255, |  | ||||||
|         verbose_name=_("school"), |  | ||||||
|     ) |  | ||||||
|  |  | ||||||
|     inviter = models.ForeignKey( |     inviter = models.ForeignKey( | ||||||
|         NoteUser, |         NoteUser, | ||||||
|         on_delete=models.PROTECT, |         on_delete=models.PROTECT, | ||||||
|   | |||||||
| @@ -51,7 +51,7 @@ class GuestTable(tables.Table): | |||||||
|         } |         } | ||||||
|         model = Guest |         model = Guest | ||||||
|         template_name = 'django_tables2/bootstrap4.html' |         template_name = 'django_tables2/bootstrap4.html' | ||||||
|         fields = ("last_name", "first_name", "inviter", "school") |         fields = ("last_name", "first_name", "inviter", ) | ||||||
|  |  | ||||||
|     def render_entry(self, record): |     def render_entry(self, record): | ||||||
|         if record.has_entry: |         if record.has_entry: | ||||||
|   | |||||||
| @@ -50,7 +50,6 @@ class TestActivities(TestCase): | |||||||
|             inviter=self.user.note, |             inviter=self.user.note, | ||||||
|             last_name="GUEST", |             last_name="GUEST", | ||||||
|             first_name="Guest", |             first_name="Guest", | ||||||
|             school="School", |  | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|     def test_activity_list(self): |     def test_activity_list(self): | ||||||
| @@ -157,7 +156,6 @@ class TestActivities(TestCase): | |||||||
|             inviter=self.user.note.id, |             inviter=self.user.note.id, | ||||||
|             last_name="GUEST2", |             last_name="GUEST2", | ||||||
|             first_name="Guest", |             first_name="Guest", | ||||||
|             school="School", |  | ||||||
|         )) |         )) | ||||||
|         self.assertEqual(response.status_code, 200) |         self.assertEqual(response.status_code, 200) | ||||||
|  |  | ||||||
| @@ -169,7 +167,6 @@ class TestActivities(TestCase): | |||||||
|             inviter=self.user.note.id, |             inviter=self.user.note.id, | ||||||
|             last_name="GUEST2", |             last_name="GUEST2", | ||||||
|             first_name="Guest", |             first_name="Guest", | ||||||
|             school="School", |  | ||||||
|         )) |         )) | ||||||
|         self.assertRedirects(response, reverse("activity:activity_detail", args=(self.activity.pk,)), 302, 200) |         self.assertRedirects(response, reverse("activity:activity_detail", args=(self.activity.pk,)), 302, 200) | ||||||
|  |  | ||||||
| @@ -203,7 +200,6 @@ class TestActivityAPI(TestAPI): | |||||||
|             inviter=self.user.note, |             inviter=self.user.note, | ||||||
|             last_name="GUEST", |             last_name="GUEST", | ||||||
|             first_name="Guest", |             first_name="Guest", | ||||||
|             school="School", |  | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|         self.entry = Entry.objects.create( |         self.entry = Entry.objects.create( | ||||||
|   | |||||||
| @@ -168,7 +168,6 @@ class ActivityInviteView(ProtectQuerysetMixin, ProtectedCreateView): | |||||||
|             activity=activity, |             activity=activity, | ||||||
|             first_name="", |             first_name="", | ||||||
|             last_name="", |             last_name="", | ||||||
|             school="", |  | ||||||
|             inviter=self.request.user.note, |             inviter=self.request.user.note, | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -20,12 +20,14 @@ SPDX-License-Identifier: GPL-3.0-or-later | |||||||
|       </form> |       </form> | ||||||
|     </div> |     </div> | ||||||
|     <!-- MODAL TO CROP THE IMAGE --> |     <!-- MODAL TO CROP THE IMAGE --> | ||||||
|     <div class="modal fade" id="modalCrop"> |     <div class="modal fade" id="modalCrop" data-backdrop="static"> | ||||||
|       <div class="modal-dialog"> |       <div class="modal-dialog"> | ||||||
|         <div class="modal-content"> |         <div class="modal-content"> | ||||||
|           <div class="modal-body"> |             <div class="modal-body-wrapper" style="width: 500px; height: 500px; padding: 16px;"> | ||||||
|             <img src="" id="modal-image" style="max-width: 100%;"> |               <div class="modal-body" style="width: 100%; height: 100%; padding: 0"> | ||||||
|           </div> |                 <img src="" id="modal-image" style="display: block; max-width: 100%;"> | ||||||
|  |               </div> | ||||||
|  |             </div> | ||||||
|           <div class="modal-footer"> |           <div class="modal-footer"> | ||||||
|             <div class="btn-group pull-left" role="group"> |             <div class="btn-group pull-left" role="group"> | ||||||
|               <button type="button" class="btn btn-default" id="js-zoom-in"> |               <button type="button" class="btn btn-default" id="js-zoom-in"> | ||||||
|   | |||||||
| @@ -1,18 +0,0 @@ | |||||||
| # Generated by Django 4.2.20 on 2025-04-14 20:21 |  | ||||||
|  |  | ||||||
| from django.db import migrations, models |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class Migration(migrations.Migration): |  | ||||||
|  |  | ||||||
|     dependencies = [ |  | ||||||
|         ('treasury', '0009_alter_sogecredit_transactions'), |  | ||||||
|     ] |  | ||||||
|  |  | ||||||
|     operations = [ |  | ||||||
|         migrations.AlterField( |  | ||||||
|             model_name='invoice', |  | ||||||
|             name='bde', |  | ||||||
|             field=models.CharField(choices=[('Diolistos', 'Diol[list]os'), ('RavePartlist', 'RavePart[list]'), ('SecretStorlist', 'SecretStor[list]'), ('TotalistSpies', 'Tota[list]Spies'), ('Saperlistpopette', 'Saper[list]popette'), ('Finalist', 'Fina[list]'), ('Listorique', '[List]orique'), ('Satellist', 'Satel[list]'), ('Monopolist', 'Monopo[list]'), ('Kataclist', 'Katac[list]')], default='Diolistos', max_length=32, verbose_name='BDE'), |  | ||||||
|         ), |  | ||||||
|     ] |  | ||||||
| @@ -27,9 +27,8 @@ class Invoice(models.Model): | |||||||
|  |  | ||||||
|     bde = models.CharField( |     bde = models.CharField( | ||||||
|         max_length=32, |         max_length=32, | ||||||
|         default='Diolistos', |         default='RavePartlist', | ||||||
|         choices=( |         choices=( | ||||||
|             ('Diolistos', 'Diol[list]os'), |  | ||||||
|             ('RavePartlist', 'RavePart[list]'), |             ('RavePartlist', 'RavePart[list]'), | ||||||
|             ('SecretStorlist', 'SecretStor[list]'), |             ('SecretStorlist', 'SecretStor[list]'), | ||||||
|             ('TotalistSpies', 'Tota[list]Spies'), |             ('TotalistSpies', 'Tota[list]Spies'), | ||||||
|   | |||||||
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 2.8 MiB | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 104 KiB | 
| @@ -55,7 +55,6 @@ Les adhérent⋅es ont la possibilité d'inviter des ami⋅es. Pour cela, les di | |||||||
| * Activité concernée (clé étrangère) | * Activité concernée (clé étrangère) | ||||||
| * Nom de famille | * Nom de famille | ||||||
| * Prénom | * Prénom | ||||||
| * École |  | ||||||
| * Note de la personne ayant invité | * Note de la personne ayant invité | ||||||
|  |  | ||||||
| Certaines contraintes s'appliquent : | Certaines contraintes s'appliquent : | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ msgid "" | |||||||
| msgstr "" | msgstr "" | ||||||
| "Project-Id-Version: \n" | "Project-Id-Version: \n" | ||||||
| "Report-Msgid-Bugs-To: \n" | "Report-Msgid-Bugs-To: \n" | ||||||
| "POT-Creation-Date: 2025-03-25 11:16+0100\n" | "POT-Creation-Date: 2025-03-13 21:08+0100\n" | ||||||
| "PO-Revision-Date: 2022-04-11 22:05+0200\n" | "PO-Revision-Date: 2022-04-11 22:05+0200\n" | ||||||
| "Last-Translator: bleizi <bleizi@crans.org>\n" | "Last-Translator: bleizi <bleizi@crans.org>\n" | ||||||
| "Language-Team: French <http://translate.ynerant.fr/projects/nk20/nk20/fr/>\n" | "Language-Team: French <http://translate.ynerant.fr/projects/nk20/nk20/fr/>\n" | ||||||
| @@ -25,7 +25,7 @@ msgid "This opener already exists" | |||||||
| msgstr "Cette amitié existe déjà" | msgstr "Cette amitié existe déjà" | ||||||
|  |  | ||||||
| #: apps/activity/apps.py:10 apps/activity/models.py:129 | #: apps/activity/apps.py:10 apps/activity/models.py:129 | ||||||
| #: apps/activity/models.py:169 apps/activity/models.py:328 | #: apps/activity/models.py:169 apps/activity/models.py:323 | ||||||
| msgid "activity" | msgid "activity" | ||||||
| msgstr "activité" | msgstr "activité" | ||||||
|  |  | ||||||
| @@ -37,24 +37,24 @@ msgstr "La note du club est inactive." | |||||||
| msgid "The end date must be after the start date." | msgid "The end date must be after the start date." | ||||||
| msgstr "La date de fin doit être après celle de début." | msgstr "La date de fin doit être après celle de début." | ||||||
|  |  | ||||||
| #: apps/activity/forms.py:83 apps/activity/models.py:276 | #: apps/activity/forms.py:83 apps/activity/models.py:271 | ||||||
| msgid "You can't invite someone once the activity is started." | msgid "You can't invite someone once the activity is started." | ||||||
| msgstr "" | msgstr "" | ||||||
| "Vous ne pouvez pas inviter quelqu'un une fois que l'activité a démarré." | "Vous ne pouvez pas inviter quelqu'un une fois que l'activité a démarré." | ||||||
|  |  | ||||||
| #: apps/activity/forms.py:86 apps/activity/models.py:279 | #: apps/activity/forms.py:86 apps/activity/models.py:274 | ||||||
| msgid "This activity is not validated yet." | msgid "This activity is not validated yet." | ||||||
| msgstr "Cette activité n'est pas encore validée." | msgstr "Cette activité n'est pas encore validée." | ||||||
|  |  | ||||||
| #: apps/activity/forms.py:96 apps/activity/models.py:287 | #: apps/activity/forms.py:96 apps/activity/models.py:282 | ||||||
| msgid "This person has been already invited 5 times this year." | msgid "This person has been already invited 5 times this year." | ||||||
| msgstr "Cette personne a déjà été invitée 5 fois cette année." | msgstr "Cette personne a déjà été invitée 5 fois cette année." | ||||||
|  |  | ||||||
| #: apps/activity/forms.py:100 apps/activity/models.py:291 | #: apps/activity/forms.py:100 apps/activity/models.py:286 | ||||||
| msgid "This person is already invited." | msgid "This person is already invited." | ||||||
| msgstr "Cette personne est déjà invitée." | msgstr "Cette personne est déjà invitée." | ||||||
|  |  | ||||||
| #: apps/activity/forms.py:104 apps/activity/models.py:295 | #: apps/activity/forms.py:104 apps/activity/models.py:290 | ||||||
| msgid "You can't invite more than 3 people to this activity." | msgid "You can't invite more than 3 people to this activity." | ||||||
| msgstr "Vous ne pouvez pas inviter plus de 3 personnes à cette activité." | msgstr "Vous ne pouvez pas inviter plus de 3 personnes à cette activité." | ||||||
|  |  | ||||||
| @@ -228,36 +228,32 @@ msgstr "nom de famille" | |||||||
| msgid "first name" | msgid "first name" | ||||||
| msgstr "prénom" | msgstr "prénom" | ||||||
|  |  | ||||||
| #: apps/activity/models.py:252 | #: apps/activity/models.py:254 | ||||||
| msgid "school" |  | ||||||
| msgstr "école" |  | ||||||
|  |  | ||||||
| #: apps/activity/models.py:259 |  | ||||||
| msgid "inviter" | msgid "inviter" | ||||||
| msgstr "hôte" | msgstr "hôte" | ||||||
|  |  | ||||||
| #: apps/activity/models.py:263 | #: apps/activity/models.py:258 | ||||||
| msgid "guest" | msgid "guest" | ||||||
| msgstr "invité·e" | msgstr "invité·e" | ||||||
|  |  | ||||||
| #: apps/activity/models.py:264 | #: apps/activity/models.py:259 | ||||||
| msgid "guests" | msgid "guests" | ||||||
| msgstr "invité·e·s" | msgstr "invité·e·s" | ||||||
|  |  | ||||||
| #: apps/activity/models.py:317 | #: apps/activity/models.py:312 | ||||||
| msgid "Invitation" | msgid "Invitation" | ||||||
| msgstr "Invitation" | msgstr "Invitation" | ||||||
|  |  | ||||||
| #: apps/activity/models.py:335 apps/activity/models.py:339 | #: apps/activity/models.py:330 apps/activity/models.py:334 | ||||||
| msgid "Opener" | msgid "Opener" | ||||||
| msgstr "Ouvreur⋅se" | msgstr "Ouvreur⋅se" | ||||||
|  |  | ||||||
| #: apps/activity/models.py:340 | #: apps/activity/models.py:335 | ||||||
| #: apps/activity/templates/activity/activity_detail.html:16 | #: apps/activity/templates/activity/activity_detail.html:16 | ||||||
| msgid "Openers" | msgid "Openers" | ||||||
| msgstr "Ouvreur⋅ses" | msgstr "Ouvreur⋅ses" | ||||||
|  |  | ||||||
| #: apps/activity/models.py:344 | #: apps/activity/models.py:339 | ||||||
| #, fuzzy, python-brace-format | #, fuzzy, python-brace-format | ||||||
| #| msgid "Entry for {note} to the activity {activity}" | #| msgid "Entry for {note} to the activity {activity}" | ||||||
| msgid "{opener} is opener of activity {acivity}" | msgid "{opener} is opener of activity {acivity}" | ||||||
| @@ -467,25 +463,25 @@ msgstr "Détails de l'activité" | |||||||
| msgid "Update activity" | msgid "Update activity" | ||||||
| msgstr "Modifier l'activité" | msgstr "Modifier l'activité" | ||||||
|  |  | ||||||
| #: apps/activity/views.py:178 | #: apps/activity/views.py:177 | ||||||
| msgid "Invite guest to the activity \"{}\"" | msgid "Invite guest to the activity \"{}\"" | ||||||
| msgstr "Invitation pour l'activité « {} »" | msgstr "Invitation pour l'activité « {} »" | ||||||
|  |  | ||||||
| #: apps/activity/views.py:218 | #: apps/activity/views.py:217 | ||||||
| msgid "You are not allowed to display the entry interface for this activity." | msgid "You are not allowed to display the entry interface for this activity." | ||||||
| msgstr "" | msgstr "" | ||||||
| "Vous n'êtes pas autorisé·e à afficher l'interface des entrées pour cette " | "Vous n'êtes pas autorisé·e à afficher l'interface des entrées pour cette " | ||||||
| "activité." | "activité." | ||||||
|  |  | ||||||
| #: apps/activity/views.py:221 | #: apps/activity/views.py:220 | ||||||
| msgid "This activity does not support activity entries." | msgid "This activity does not support activity entries." | ||||||
| msgstr "Cette activité ne requiert pas d'entrées." | msgstr "Cette activité ne requiert pas d'entrées." | ||||||
|  |  | ||||||
| #: apps/activity/views.py:224 | #: apps/activity/views.py:223 | ||||||
| msgid "This activity is closed." | msgid "This activity is closed." | ||||||
| msgstr "Cette activité est fermée." | msgstr "Cette activité est fermée." | ||||||
|  |  | ||||||
| #: apps/activity/views.py:329 | #: apps/activity/views.py:328 | ||||||
| msgid "Entry for activity \"{}\"" | msgid "Entry for activity \"{}\"" | ||||||
| msgstr "Entrées pour l'activité « {} »" | msgstr "Entrées pour l'activité « {} »" | ||||||
|  |  | ||||||
| @@ -1993,6 +1989,10 @@ msgstr "Historique des transactions récentes" | |||||||
| #: apps/note/templates/note/mails/weekly_report.txt:32 | #: apps/note/templates/note/mails/weekly_report.txt:32 | ||||||
| #: apps/registration/templates/registration/mails/email_validation_email.html:40 | #: apps/registration/templates/registration/mails/email_validation_email.html:40 | ||||||
| #: apps/registration/templates/registration/mails/email_validation_email.txt:16 | #: apps/registration/templates/registration/mails/email_validation_email.txt:16 | ||||||
|  | #: apps/scripts/templates/scripts/horaires.html:35 | ||||||
|  | #: apps/scripts/templates/scripts/horaires.txt:17 | ||||||
|  | #: apps/scripts/templates/scripts/intro_mail.html:49 | ||||||
|  | #: apps/scripts/templates/scripts/intro_mail.txt:25 | ||||||
| msgid "Mail generated by the Note Kfet on the" | msgid "Mail generated by the Note Kfet on the" | ||||||
| msgstr "Mail généré par la Note Kfet le" | msgstr "Mail généré par la Note Kfet le" | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user