summaryrefslogtreecommitdiff
path: root/archaeological_operations
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2017-04-01 19:06:35 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2017-04-01 19:06:35 +0200
commit25bfdf136bd2bd7658878d25e337b02b8150915d (patch)
tree9c277f0f6fdd5ae6a42b0f7201c96c75ca0f7bdf /archaeological_operations
parent59847d040c37d77ebd9c731f9a4587665e906feb (diff)
downloadIshtar-25bfdf136bd2bd7658878d25e337b02b8150915d.tar.bz2
Ishtar-25bfdf136bd2bd7658878d25e337b02b8150915d.zip
Operation wizard: an operation cannot be related to herself (refs #3578)
Diffstat (limited to 'archaeological_operations')
-rw-r--r--archaeological_operations/forms.py28
-rw-r--r--archaeological_operations/wizards.py11
2 files changed, 37 insertions, 2 deletions
diff --git a/archaeological_operations/forms.py b/archaeological_operations/forms.py
index 6423962d8..4796ef68c 100644
--- a/archaeological_operations/forms.py
+++ b/archaeological_operations/forms.py
@@ -387,6 +387,9 @@ class RecordRelationsForm(ManageOldType, forms.Form):
validators=[valid_id(models.Operation)], required=False)
def __init__(self, *args, **kwargs):
+ self.left_record = None
+ if 'left_record' in kwargs:
+ self.left_record = kwargs.pop('left_record')
super(RecordRelationsForm, self).__init__(*args, **kwargs)
self.fields['relation_type'].choices = \
models.RelationType.get_types(
@@ -413,6 +416,9 @@ class RecordRelationsForm(ManageOldType, forms.Form):
cleaned_data.get('right_record', None)):
raise forms.ValidationError(
_(u"You should select a relation type."))
+ if str(cleaned_data.get('right_record')) == str(self.left_record.pk):
+ raise forms.ValidationError(
+ _(u"An operation cannot be related to herself."))
return cleaned_data
@classmethod
@@ -447,7 +453,27 @@ class RecordRelationsForm(ManageOldType, forms.Form):
result.append((_("Deleted relations"), u" ; ".join(deleted)))
return result
-RecordRelationsFormSet = formset_factory(RecordRelationsForm, can_delete=True)
+
+class RecordRelationsFormSetBase(FormSet):
+ # passing left_record should be nicely done with form_kwargs with Django 1.9
+ # with no need of all these complications
+
+ def __init__(self, *args, **kwargs):
+ self.left_record = None
+ if 'left_record' in kwargs:
+ self.left_record = kwargs.pop('left_record')
+ super(RecordRelationsFormSetBase, self).__init__(*args, **kwargs)
+
+ def _construct_forms(self):
+ # instantiate all the forms and put them in self.forms
+ self.forms = []
+ for i in xrange(self.total_form_count()):
+ self.forms.append(self._construct_form(
+ i, left_record=self.left_record))
+
+
+RecordRelationsFormSet = formset_factory(
+ RecordRelationsForm, can_delete=True, formset=RecordRelationsFormSetBase)
RecordRelationsFormSet.form_label = _(u"Relations")
diff --git a/archaeological_operations/wizards.py b/archaeological_operations/wizards.py
index 5410b37f8..c132c24be 100644
--- a/archaeological_operations/wizards.py
+++ b/archaeological_operations/wizards.py
@@ -1,6 +1,6 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
-# Copyright (C) 2012-2016 Étienne Loks <etienne.loks_AT_peacefrogsDOTnet>
+# Copyright (C) 2012-2017 Étienne Loks <etienne.loks_AT_peacefrogsDOTnet>
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as
@@ -275,6 +275,15 @@ class OperationModificationWizard(OperationWizard):
modification = True
filter_owns = {'selec-operation_modification': ['pk']}
+ def get_form_kwargs(self, step, **kwargs):
+ kwargs = super(OperationModificationWizard, self).get_form_kwargs(
+ step, **kwargs)
+ print(step)
+ if step != "relations-operation_modification":
+ return kwargs
+ kwargs["left_record"] = self.get_current_object()
+ return kwargs
+
class OperationClosingWizard(ClosingWizard):
model = models.Operation