123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- #-*- coding: utf-8 -*-
-
- from EditorialModel.components import EmComponent
- from EditorialModel.fields import EmField
- from EditorialModel.classes import EmClass
- from EditorialModel.exceptions import EmComponentCheckError
-
-
- ## Represents groups of EmField associated with an EmClass
- #
- # EmClass fields representation is organised with EmFieldGroup
- # @see EditorialModel::fields::EmField EditorialModel::classes::EmClass
- class EmFieldGroup(EmComponent):
-
- ranked_in = 'class_id'
-
- ## EmFieldGroup instanciation
- def __init__(self, model, uid, name, class_id, string=None, help_text=None, date_update=None, date_create=None, rank=None):
- self.class_id = class_id
- self.check_type('class_id', int)
- super(EmFieldGroup, self).__init__(model=model, uid=uid, name=name, string=string, help_text=help_text, date_update=date_update, date_create=date_create, rank=rank)
-
- @property
- def em_class(self):
- return self.model.component(self.class_id)
-
- ## Check if the EmFieldGroup is valid
- # @throw EmComponentCheckError if fails
- def check(self):
- super(EmFieldGroup, self).check()
- em_class = self.model.component(self.class_id)
- if not em_class:
- raise EmComponentCheckError("class_id contains a non existing uid '%s'" % str(self.class_id))
- if not isinstance(em_class, EmClass):
- raise EmComponentCheckError("class_id cointains an uid from a component that is not an EmClass but an %s" % type(em_class))
-
- ## Deletes a fieldgroup
- # @return True if the deletion is possible, False if not
- def delete_check(self):
- # all the EmField objects contained in this fieldgroup should be deleted first
- fieldgroup_fields = self.fields()
- if len(fieldgroup_fields) > 0:
- raise NotEmptyError("This Fieldgroup still contains fields. It can't be deleted then")
- return True
-
- ## Get the list of associated fields
- # if type_id, the fields will be filtered to represent selected fields of this EmType
- # @param type_id int|None : if not None the fields will be filtered to represent selected fields of the EmType identified by this uid
- # @param relational bool : If False don't returns the relational fields
- # @return A list of EmField instance
- def fields(self, type_id=None, relational=True):
- if type_id is None:
- fields = [field for field in self.model.components(EmField) if field.fieldgroup_id == self.uid]
- else:
- # for an EmType, fields have to be filtered
- em_type = self.model.component(type_id)
- fields = []
- for field in self.model.components(EmField):
- if field.fieldgroup_id != self.uid or (field.optional and field.uid not in em_type.fields_list):
- continue
- # don't include relational field if parent should not be included
- if field.rel_field_id:
- parent = self.model.component(field.rel_field_id)
- if parent.optional and parent.uid not in em_type.fields_list:
- continue
- fields.append(field)
-
- if not relational:
- fields = [ f for f in fields if f.rel_field_id is None and f.fieldtype != 'rel2type' ]
-
- return fields
-
-
- class NotEmptyError(Exception):
- pass
|