summaryrefslogtreecommitdiff
path: root/ishtar_common/views.py
diff options
context:
space:
mode:
Diffstat (limited to 'ishtar_common/views.py')
-rw-r--r--ishtar_common/views.py22
1 files changed, 21 insertions, 1 deletions
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