fix access restriction group editing
This commit is contained in:
parent
067eadecb8
commit
a23be40cac
1 changed files with 13 additions and 11 deletions
|
@ -166,6 +166,7 @@ class EditorFormBase(I18nModelFormMixin, ModelForm):
|
||||||
|
|
||||||
def _save_m2m(self):
|
def _save_m2m(self):
|
||||||
super()._save_m2m()
|
super()._save_m2m()
|
||||||
|
if self._meta.model.__name__ != 'AccessRestriction':
|
||||||
try:
|
try:
|
||||||
field = self._meta.model._meta.get_field('groups')
|
field = self._meta.model._meta.get_field('groups')
|
||||||
except FieldDoesNotExist:
|
except FieldDoesNotExist:
|
||||||
|
@ -174,7 +175,8 @@ class EditorFormBase(I18nModelFormMixin, ModelForm):
|
||||||
if field.many_to_many:
|
if field.many_to_many:
|
||||||
groups = reduce(operator.or_, (set(value) for name, value in self.cleaned_data.items()
|
groups = reduce(operator.or_, (set(value) for name, value in self.cleaned_data.items()
|
||||||
if name.startswith('groups_')), set())
|
if name.startswith('groups_')), set())
|
||||||
groups |= set(value for name, value in self.cleaned_data.items() if name.startswith('group_') and value)
|
groups |= set(value for name, value in self.cleaned_data.items()
|
||||||
|
if name.startswith('group_') and value)
|
||||||
groups = tuple((int(val) if val.isdigit() else val) for val in groups)
|
groups = tuple((int(val) if val.isdigit() else val) for val in groups)
|
||||||
self.instance.groups.set(groups)
|
self.instance.groups.set(groups)
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue