diff options
| author | Étienne Loks <etienne.loks@iggdrasil.net> | 2017-01-12 22:43:58 +0100 | 
|---|---|---|
| committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2017-01-12 22:43:58 +0100 | 
| commit | 0b90b1681ca2d14f90bfdd50f86ee2965d7294bf (patch) | |
| tree | 569f270ed0a08c03c3d4ed45042784241ee1f979 /archaeological_finds/forms.py | |
| parent | 07c83a42b720e057f7e28add67a0e1e834745ba3 (diff) | |
| parent | 1d7b5ef3055236b56ec1e104ab66a6ccc8e3da14 (diff) | |
| download | Ishtar-0b90b1681ca2d14f90bfdd50f86ee2965d7294bf.tar.bz2 Ishtar-0b90b1681ca2d14f90bfdd50f86ee2965d7294bf.zip | |
Merge branch 'v0.9' into wheezy
Diffstat (limited to 'archaeological_finds/forms.py')
| -rw-r--r-- | archaeological_finds/forms.py | 66 | 
1 files changed, 62 insertions, 4 deletions
| diff --git a/archaeological_finds/forms.py b/archaeological_finds/forms.py index 9441e6899..11ecf8152 100644 --- a/archaeological_finds/forms.py +++ b/archaeological_finds/forms.py @@ -31,7 +31,8 @@ from django.forms.formsets import formset_factory  from django.utils.safestring import mark_safe  from django.utils.translation import ugettext_lazy as _ -from ishtar_common.models import valid_id, valid_ids, get_current_profile +from ishtar_common.models import valid_id, valid_ids, get_current_profile, \ +    SpatialReferenceSystem  from archaeological_operations.models import Period, ArchaeologicalSite, \      RelationType as OpeRelationType  from archaeological_context_records.models import DatingType, DatingQuality, \ @@ -43,6 +44,7 @@ from ishtar_common.forms import FormSet, FloatField, \      ManageOldType  from ishtar_common.forms_common import get_town_field, SourceSelect +from ishtar_common.utils import convert_coordinates_to_point  from ishtar_common import widgets  from archaeological_operations.widgets import OAWidget @@ -127,7 +129,9 @@ class FindForm(ManageOldType, forms.Form):                           'object_type': models.ObjectType,                           'preservation_to_consider': models.PreservationType,                           'integritie': models.IntegrityType, -                         'remarkabilitie': models.RemarkabilityType} +                         'remarkabilitie': models.RemarkabilityType, +                         'get_first_base_find__spatial_reference_system': +                         SpatialReferenceSystem}      label = forms.CharField(          label=_(u"Free ID"),          validators=[validators.MaxLengthValidator(60)]) @@ -157,10 +161,22 @@ class FindForm(ManageOldType, forms.Form):      remarkabilitie = forms.MultipleChoiceField(          label=_(u"Remarkability"), choices=[],          widget=widgets.CheckboxSelectMultiple, required=False) -    topographic_reference_point = forms.CharField( +    get_first_base_find__topographic_localisation = forms.CharField(          label=_(u"Point of topographic reference"), -        required=False, max_length=20 +        required=False, max_length=120      ) +    get_first_base_find__x = forms.FloatField(label=_(u"X"), required=False) +    get_first_base_find__estimated_error_x = \ +        forms.FloatField(label=_(u"Estimated error for X"), required=False) +    get_first_base_find__y = forms.FloatField(label=_(u"Y"), required=False) +    get_first_base_find__estimated_error_y = \ +        forms.FloatField(label=_(u"Estimated error for Y"), required=False) +    get_first_base_find__z = forms.FloatField(label=_(u"Z"), required=False) +    get_first_base_find__estimated_error_z = \ +        forms.FloatField(label=_(u"Estimated error for Z"), required=False) +    get_first_base_find__spatial_reference_system = \ +        forms.ChoiceField(label=_(u"Spatial Reference System"), required=False, +                          choices=[])      length = FloatField(label=_(u"Length (cm)"), required=False)      width = FloatField(label=_(u"Width (cm)"), required=False)      height = FloatField(label=_(u"Height (cm)"), required=False) @@ -192,6 +208,21 @@ class FindForm(ManageOldType, forms.Form):      def __init__(self, *args, **kwargs):          super(FindForm, self).__init__(*args, **kwargs) +        if not get_current_profile().mapping: +            for k in ['get_first_base_find__x', 'get_first_base_find__y', +                      'get_first_base_find__z', +                      'get_first_base_find__estimated_error_x', +                      'get_first_base_find__estimated_error_y', +                      'get_first_base_find__estimated_error_z', +                      'get_first_base_find__spatial_reference_system',]: +                self.fields.pop(k) +        else: +            srs = 'get_first_base_find__spatial_reference_system' +            self.fields[srs].choices = \ +                SpatialReferenceSystem.get_types( +                    initial=self.init_data.get(srs)) +            self.fields[srs].help_text = \ +                SpatialReferenceSystem.get_help()          self.fields['checked'].choices = models.CHECK_CHOICES          self.fields['material_type'].help_text = models.MaterialType.get_help()          self.fields['conservatory_state'].choices = \ @@ -221,6 +252,33 @@ class FindForm(ManageOldType, forms.Form):              unicode(self.fields['estimated_value'].label),              get_current_profile().currency) +    def clean(self): +        if not get_current_profile().mapping: +            return self.cleaned_data +        x = self.cleaned_data.get('get_first_base_find__x', None) +        y = self.cleaned_data.get('get_first_base_find__y', None) +        s = 'get_first_base_find__spatial_reference_system' +        srs = self.cleaned_data.get(s, None) +        if srs: +            try: +                srs = SpatialReferenceSystem.objects.get(pk=srs) +            except SpatialReferenceSystem.DoesNotExist: +                srs = None +        if x and y and not srs: +            raise forms.ValidationError( +                _(u"You should at least provide X, Y and the spatial " +                  u"reference system used.")) +        if x and y and srs: +            try: +                convert_coordinates_to_point( +                    x, y, self.cleaned_data.get('get_first_base_find__z', None), +                    srs.srid) +            except forms.ValidationError as e: +                raise forms.ValidationError( +                    unicode(_(u"Coordinates are not relevant for the spatial " +                              u"reference system used: {}.")).format(e)) +        return self.cleaned_data +  class DateForm(ManageOldType, forms.Form):      form_label = _("Dating") | 
