mirror of
				https://gitlab.crans.org/bde/nk20
				synced 2025-11-03 17:08:47 +01:00 
			
		
		
		
	Compare commits
	
		
			11 Commits
		
	
	
		
			Automation
			...
			c7a92fa4b2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					c7a92fa4b2 | ||
| 
						 | 
					0a5368d23f | ||
| 
						 | 
					26b351a51c | ||
| 
						 | 
					1836677c47 | ||
| 
						 | 
					e7a98c86f0 | ||
| 
						 | 
					eb5044490b | ||
| 
						 | 
					983d7ec052 | ||
| 
						 | 
					dc56deaf85 | ||
| 
						 | 
					694f54e1c4 | ||
| 
						 | 
					0d0fdef363 | ||
| 
						 | 
					821efbf78b | 
@@ -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,
 | 
			
		||||
 
 | 
			
		||||
@@ -45,7 +45,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"), widget=forms.HiddenInput())
 | 
			
		||||
    report_frequency = forms.IntegerField(required=False, initial=0, label=_("Report frequency"))
 | 
			
		||||
 | 
			
		||||
    last_report = forms.DateTimeField(required=False, disabled=True, label=_("Last report date"))
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -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,
 | 
			
		||||
        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"]
 | 
			
		||||
            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
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -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",
 | 
			
		||||
@@ -3832,6 +3832,86 @@
 | 
			
		||||
            "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.permission",
 | 
			
		||||
        "pk": 248,
 | 
			
		||||
        "fields": {
 | 
			
		||||
            "model": [
 | 
			
		||||
                "member",
 | 
			
		||||
                "profile"
 | 
			
		||||
            ],
 | 
			
		||||
            "query": "[\"NOT\", {\"pk__isnull\": [\"user\", \"note\", \"activity_responsible\", [\"filter\", {\"activity__open\": true, \"activity__activity_type__manage_entries\":true}], [\"exists\"]]}]",
 | 
			
		||||
            "type": "view",
 | 
			
		||||
            "mask": 3,
 | 
			
		||||
            "field": "",
 | 
			
		||||
            "permanent": false,
 | 
			
		||||
            "description": "Voir n'importe quel profil"
 | 
			
		||||
        }
 | 
			
		||||
    },
 | 
			
		||||
    {
 | 
			
		||||
        "model": "permission.role",
 | 
			
		||||
        "pk": 1,
 | 
			
		||||
 
 | 
			
		||||
@@ -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 ""
 | 
			
		||||
@@ -1045,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"
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user