From 547a20789faf6bbc9979357c7f65cbe61e56ed07 Mon Sep 17 00:00:00 2001 From: Étienne Loks Date: Tue, 29 Oct 2024 17:50:49 +0100 Subject: ✨ permissions refactoring: link items to user QA forms MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ishtar_common/views.py | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) (limited to 'ishtar_common/views.py') diff --git a/ishtar_common/views.py b/ishtar_common/views.py index f01e848a0..03b029fe2 100644 --- a/ishtar_common/views.py +++ b/ishtar_common/views.py @@ -3121,7 +3121,10 @@ class QAItemForm(IshtarMixin, LoginRequiredMixin, FormView): def pre_dispatch(self, request, *args, **kwargs): if not self.model: - raise NotImplementedError("No attribute model defined.") + if "model" in kwargs: + self.model = kwargs["model"] + else: + raise NotImplementedError("No attribute model defined.") pks = [int(pk) for pk in kwargs.get("pks").split("-")] self.items = list(self.model.objects.filter(pk__in=pks)) if not self.items: @@ -3252,6 +3255,23 @@ class QABaseLockView(QAItemForm): return HttpResponseRedirect(reverse("success")) +class QALinkView(QAItemForm): + form_class = forms.QALinkForm + page_name = _("Link items") + icon = "fa fa-link" + + def pre_dispatch(self, request, *args, **kwargs): + self.base_url = kwargs["url"] + super().pre_dispatch(request, *args, **kwargs) + if not request.user.ishtaruser.is_ishtaradmin: + url = reverse("qa-not-available") + return HttpResponseRedirect(url) + + def form_valid(self, form): + form.save(self.items, self.request.user) + return HttpResponseRedirect(reverse("success")) + + class QAOrganizationForm(QAItemEditForm): model = models.Organization form_class = forms.QAOrganizationFormMulti -- cgit v1.2.3