diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2016-09-06 16:10:46 +0200 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2016-09-06 16:10:46 +0200 |
commit | c18dba0656a194f966b95674e31993e88b650f78 (patch) | |
tree | 656e7f51f769a313c16f32a0a62dd684c0d1639e /archaeological_context_records/forms.py | |
parent | 6a569a6ea6eb91791d0a6530d7604d2be2267af9 (diff) | |
parent | 36d03c08136e6ff63812cbbc431d06304e7ba156 (diff) | |
download | Ishtar-c18dba0656a194f966b95674e31993e88b650f78.tar.bz2 Ishtar-c18dba0656a194f966b95674e31993e88b650f78.zip |
Merge branch 'v0.9' into wheezy
Diffstat (limited to 'archaeological_context_records/forms.py')
-rw-r--r-- | archaeological_context_records/forms.py | 31 |
1 files changed, 30 insertions, 1 deletions
diff --git a/archaeological_context_records/forms.py b/archaeological_context_records/forms.py index 462300317..daaf5f5ed 100644 --- a/archaeological_context_records/forms.py +++ b/archaeological_context_records/forms.py @@ -43,6 +43,18 @@ from archaeological_operations.forms import OperationSelect, ParcelField,\ RecordRelationsForm as OpeRecordRelationsForm +class OperationFormSelection(forms.Form): + form_label = _("Operation") + associated_models = {'operation': Operation} + currents = {'operation': Operation} + operation = forms.IntegerField( + label=_(u"Operation"), required=False, + widget=widgets.JQueryAutoComplete( + reverse_lazy('autocomplete-operation'), + associated_model=Operation), + validators=[valid_id(Operation)]) + + class RecordSelect(TableSelect): label = forms.CharField(label=_(u"ID"), max_length=100) parcel__town = get_town_field() @@ -148,7 +160,24 @@ class RecordFormGeneral(ManageOldType, forms.Form): ('operation' in kwargs['data'] or 'context_record' in kwargs['data']): if 'operation' in kwargs['data']: - operation = kwargs['data']['operation'] + operation = kwargs['data'].pop('operation') + if type(operation) in (list, tuple): + operation = operation[0] + if not hasattr(operation, 'id'): + operation_id = operation + try: + operation = Operation.objects.get(pk=operation_id) + except Operation.DoesNotExist: + operation = None + # force operation modification + # if posted + if operation and kwargs['data']: + if hasattr(operation, 'id'): + kwargs['data'][kwargs['prefix'] + '-operation_id'] = \ + operation.id + else: + kwargs['data'][kwargs['prefix'] + '-operation_id'] = \ + operation if 'context_record' in kwargs['data'] and \ kwargs['data']['context_record']: operation = kwargs['data']['context_record'].operation |