diff options
| author | Étienne Loks <etienne.loks@iggdrasil.net> | 2016-10-22 13:41:02 +0200 | 
|---|---|---|
| committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2016-10-22 13:41:02 +0200 | 
| commit | dafc5d16f3095bad00356b6198afcd5bbeab61d6 (patch) | |
| tree | 7040d1fd325ba67b890122059a8f50a3857e332a /archaeological_operations/models.py | |
| parent | 64bb69c03ce1688c72b3f7ebd0e1550cd941aa69 (diff) | |
| parent | 0ecd905165193897129a71a1e8203232f0b2b68c (diff) | |
| download | Ishtar-dafc5d16f3095bad00356b6198afcd5bbeab61d6.tar.bz2 Ishtar-dafc5d16f3095bad00356b6198afcd5bbeab61d6.zip | |
Merge branch 'master' into v0.9
Diffstat (limited to 'archaeological_operations/models.py')
| -rw-r--r-- | archaeological_operations/models.py | 140 | 
1 files changed, 128 insertions, 12 deletions
| diff --git a/archaeological_operations/models.py b/archaeological_operations/models.py index d64936c90..14e5e1f7e 100644 --- a/archaeological_operations/models.py +++ b/archaeological_operations/models.py @@ -177,10 +177,56 @@ class Operation(ClosedItem, BaseHistorizedItem, ImageModel, OwnPerms,      QUALITY_DICT = dict(QUALITY)      SHOW_URL = 'show-operation'      TABLE_COLS = ['year_index', 'operation_type', 'remains', 'towns', -                  'start_date', 'excavation_end_date'] -    TABLE_COLS.insert(4, 'associated_file_short_label') +                  'associated_file_short_label', 'start_date', +                  'excavation_end_date']      IMAGE_PREFIX = 'operations/'      SLUG = 'operation' + +    # search parameters +    BOOL_FIELDS = ['end_date__isnull', 'virtual_operation', +                   'documentation_received', 'finds_received'] +    DATED_FIELDS = [ +        'start_date__lte', 'start_date__gte', 'excavation_end_date__lte', +        'excavation_end_date__gte', 'documentation_deadline__lte', +        'documentation_deadline__gte', 'finds_deadline__lte', +        'finds_deadline__gte'] +    RELATIVE_SESSION_NAMES = [('file', 'associated_file__pk')] +    EXTRA_REQUEST_KEYS = { +        'common_name': 'common_name__icontains', +        'cached_label': 'cached_label__icontains', +        'comment': 'comment__icontains', +        'scientific_documentation_comment': +        'scientific_documentation_comment__icontains', +        'abstract': 'abstract__icontains', +        'end_date': 'end_date__isnull', +        'year_index': ('year', 'operation_code'), +        'start_before': 'start_date__lte', +        'start_after': 'start_date__gte', +        'end_before': 'excavation_end_date__lte', +        'end_after': 'excavation_end_date__gte', +        'towns__numero_insee__startswith': +        'towns__numero_insee__startswith', +        'parcel_0': ('parcels__section', +                     'associated_file__parcels__section'), +        'parcel_1': ( +            'parcels__parcel_number', +            'associated_file__parcels__parcel_number'), +        'parcel_2': ( +            'parcels__public_domain', +            'associated_file__parcels__public_domain'), +        'history_creator': +        'history_creator__ishtaruser__person__pk', +        'history_modifier': +        'history_modifier__ishtaruser__person__pk', +        'archaeological_sites': +        'archaeological_sites__pk', +        'documentation_deadline_before': 'documentation_deadline__lte', +        'documentation_deadline_after': 'documentation_deadline__gte', +        'finds_deadline_before': 'finds_deadline__lte', +        'finds_deadline_after': 'finds_deadline__gte', +    } + +    # fields definition      creation_date = models.DateField(_(u"Creation date"),                                       default=datetime.date.today)      end_date = models.DateField(_(u"Closing date"), null=True, blank=True) @@ -387,6 +433,9 @@ class Operation(ClosedItem, BaseHistorizedItem, ImageModel, OwnPerms,          cached_label = settings.JOINT.join(items)          return cached_label +    def _get_associated_cached_labels(self): +        return list(self.context_record.all()) +      def get_town_label(self):          lbl = unicode(_('Intercommunal'))          if self.towns.count() == 1: @@ -701,6 +750,7 @@ def operation_post_save(sender, **kwargs):      if not kwargs['instance']:          return      operation = kwargs['instance'] +    operation.skip_history_when_saving = True      if operation.fnap_financing and operation.cost:          fnap_cost = int(float(operation.cost) / 100 * operation.fnap_financing)          if not operation.fnap_cost or operation.fnap_cost != fnap_cost: @@ -708,8 +758,9 @@ def operation_post_save(sender, **kwargs):              operation.save()      elif operation.fnap_cost and operation.cost:          fnap_percent = float(operation.fnap_cost) * 100 / operation.cost -        operation.fnap_financing = fnap_percent -        operation.save() +        if operation.fnap_financing != fnap_percent: +            operation.fnap_financing = fnap_percent +            operation.save()      cached_label_changed(sender, **kwargs)      if operation.associated_file:          operation.associated_file.update_short_menu_class() @@ -760,6 +811,31 @@ class OperationByDepartment(models.Model):  class OperationSource(Source): +    SHOW_URL = 'show-operationsource' +    MODIFY_URL = 'operation_source_modify' +    TABLE_COLS = ['operation.year', 'operation.operation_code', 'index'] + \ +        Source.TABLE_COLS + +    # search parameters +    BOOL_FIELDS = ['duplicate'] +    EXTRA_REQUEST_KEYS = { +        'title': 'title__icontains', +        'description': 'description__icontains', +        'comment': 'comment__icontains', +        'additional_information': 'additional_information__icontains', +        'person': 'authors__person__pk', +        'operation__towns': 'operation__towns__pk', +        'operation__operation_code': 'operation__operation_code', +        'operation__code_patriarche': 'operation__code_patriarche', +        'operation__operation_type': 'operation__operation_type__pk', +        'operation__year': 'operation__year'} + +    # fields +    operation = models.ForeignKey(Operation, verbose_name=_(u"Operation"), +                                  related_name="source") +    index = models.IntegerField(verbose_name=_(u"Index"), blank=True, +                                null=True) +      class Meta:          verbose_name = _(u"Operation documentation")          verbose_name_plural = _(u"Operation documentations") @@ -775,14 +851,6 @@ class OperationSource(Source):              ("delete_own_operationsource",               ugettext(u"Can delete own Operation source")),          ) -    operation = models.ForeignKey(Operation, verbose_name=_(u"Operation"), -                                  related_name="source") -    index = models.IntegerField(verbose_name=_(u"Index"), blank=True, -                                null=True) -    TABLE_COLS = ['operation.year', 'operation.operation_code', 'index'] + \ -        Source.TABLE_COLS -    SHOW_URL = 'show-operationsource' -    MODIFY_URL = 'operation_source_modify'      @property      def owner(self): @@ -823,6 +891,54 @@ class AdministrativeAct(BaseHistorizedItem, OwnPerms, ValueGetter):          TABLE_COLS.append('departments_label')          TABLE_COLS_FILE.append('departments_label')          TABLE_COLS_OPE.append('departments_label') + +    # search parameters +    DATED_FIELDS = ['signature_date__lte', 'signature_date__gte'] +    ASSOCIATED_MODELS = [ +        ('File', 'associated_file'), +        (Person, 'associated_file__general_contractor')] +    EXTRA_REQUEST_KEYS = { +        'act_object': 'act_object__icontains', +        'act_type__intented_to': 'act_type__intented_to', +        'associated_file__general_contractor__attached_to': +            'associated_file__general_contractor__attached_to__pk', +        'associated_file__name': 'associated_file__name__icontains', +        'associated_file__operations__code_patriarche': +        'associated_file__operations__code_patriarche', +        'associated_file__permit_reference': +            'associated_file__permit_reference__icontains', +        'associated_file__towns': 'associated_file__towns__pk', +        'associated_file__towns__numero_insee__startswith': +        'associated_file__towns__numero_insee__startswith', +        'indexed': 'index__isnull', +        'history_creator': +        'history_creator__ishtaruser__person__pk', +        'history_modifier': +        'history_modifier__ishtaruser__person__pk', +        'operation__code_patriarche': 'operation__code_patriarche', +        'operation__towns': 'operation__towns__pk', +        'operation__towns__numero_insee__startswith': +        'operation__towns__numero_insee__startswith', +        'parcel_0': ('associated_file__parcels__section', +                     'operation__parcels__section', +                     'operation__associated_file__parcels__section'), +        'parcel_1': ( +            'associated_file__parcels__parcel_number' +            'operation__parcels__parcel_number', +            'operation__associated_file__parcels__parcel_number'), +        'parcel_2': ( +            'associated_file__parcels__public_domain', +            'operation__parcels__public_domain', +            'operation__associated_file__parcels__public_domain'), +        'signature_date_before': 'signature_date__lte', +        'signature_date_after': 'signature_date__gte', +        'year': 'signature_date__year', +    } +    REVERSED_BOOL_FIELDS = ['index__isnull'] +    RELATIVE_SESSION_NAMES = [('operation', 'operation__pk'), +                              ('file', 'associated_file__pk')] + +    # fields      act_type = models.ForeignKey(ActType, verbose_name=_(u"Act type"))      in_charge = models.ForeignKey(          Person, blank=True, null=True, | 
