Nessuna descrizione
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

fieldgroups.py 2.3KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. #-*- coding: utf-8 -*-
  2. from EditorialModel.components import EmComponent
  3. from EditorialModel.classes import EmClass
  4. import EditorialModel.fieldtypes as ftypes
  5. # from Database import sqlutils
  6. # import sqlalchemy as sql
  7. # import EditorialModel
  8. ## Represents groups of EmField associated with an EmClass
  9. #
  10. # EmClass fields representation is organised with EmFieldGroup
  11. # @see EditorialModel::fields::EmField EditorialModel::classes::EmClass
  12. class EmFieldGroup(EmComponent):
  13. ## The database table name
  14. table = 'em_fieldgroup'
  15. ranked_in = 'class_id'
  16. ## List of fields
  17. _fields = [('class_id', ftypes.EmField_integer)]
  18. def __init__(self, data, components):
  19. super(EmFieldGroup, self).__init__(data, components)
  20. @classmethod
  21. ## Create a new EmFieldGroup
  22. #
  23. # Save it in database and return an instance*
  24. # @param **em_component_args : @ref EditorialModel::components::create(), must contain fields "name" (str) and "class" (EmClass)
  25. # @throw EmComponentExistError If an EmFieldGroup with this name allready exists
  26. # @throw TypeError If an argument is of an unexepted type
  27. def create(cls, **em_component_args):
  28. fieldgroup_name = em_component_args['name']
  29. fieldgroup_class = em_component_args['class']
  30. if not isinstance(name, str):
  31. raise TypeError("Excepting <class str> as name. But got %s" % str(type(fielgroup_name)))
  32. if not isinstance(em_class, EmClass):
  33. raise TypeError("Excepting <class EmClass> as em_class. But got %s" % str(type(fieldgroup_class)))
  34. return super(EmFieldGroup, cls).create(**em_component_args)
  35. ## Get the list of associated fields
  36. # @return A list of EmField instance
  37. def fields(self):
  38. result = []
  39. for _,field in self.components['field']:
  40. if field.fieldgroup_id==self.uid:
  41. result.append(field)
  42. return result
  43. # meta = sqlutils.meta(self.db_engine)
  44. # field_table = sql.Table(EditorialModel.fields.EmField.table, meta)
  45. # req = field_table.select(field_table.c.uid).where(field_table.c.fieldgroup_id == self.uid)
  46. # conn = self.db_engine.connect()
  47. # res = conn.execute(req)
  48. # rows = res.fetchall()
  49. # conn.close()
  50. # return [EditorialModel.fields.EmField(row['uid']) for row in rows]