diff --git a/news/forms.py b/news/forms.py
index 6b59f11a..d1aa4609 100644
--- a/news/forms.py
+++ b/news/forms.py
@@ -1,5 +1,6 @@
from django import forms
from django.contrib.auth.models import User
+from django.db.models import Count
from django.db.utils import OperationalError, ProgrammingError
from django.forms import inlineformset_factory
from django.forms.widgets import ClearableFileInput
@@ -111,16 +112,6 @@ def __init__(self, *args, **kwargs):
)
-class UserFullnameChoiceField(forms.ModelMultipleChoiceField):
- """
- Denne klassen overrider ModelChoiceField for å vise vanlige
- fulle navn istedenfor brukernavn
- """
-
- def label_from_instance(self, obj):
- return obj.get_full_name()
-
-
class MaterialFileWidget(ClearableFileInput):
template_name = "files/_file_widget.html"
@@ -175,16 +166,21 @@ class EventForm(UpdatePubDateOnDraftPublishMixin, forms.ModelForm):
registration_end = SplitDateTimeFieldCustom(label="Påmeldingsfrist")
deregistration_end = SplitDateTimeFieldCustom(label="Avmeldingsfrist")
- responsibles = UserFullnameChoiceField(
+ responsibles = forms.Field(
label=_("Arrangementansvarlig"),
- queryset=User.objects.all()
- .filter(groups__name__in=get_committees())
- .order_by("first_name"),
)
def clean_responsibles(self):
- data = self.cleaned_data["responsibles"]
- return User.objects.filter(pk__in=data)
+ """Get users from responsibles data, filter and check if they exist."""
+ data = self.data.getlist("responsibles")
+ users = User.objects.annotate(group_count=Count("groups")).filter(
+ pk__in=data, group_count__gt=0
+ )
+ if type(data) is list and users.count() != len(data):
+ raise forms.ValidationError(
+ _("Bruker er ikke i en registert gruppe."), code="invalid"
+ )
+ return users
class Meta:
model = Event
diff --git a/news/templates/news/edit_event.html b/news/templates/news/edit_event.html
index 2ecdf621..b5904ec4 100644
--- a/news/templates/news/edit_event.html
+++ b/news/templates/news/edit_event.html
@@ -8,7 +8,7 @@