暫無描述
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.

fields.py 4.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. #-*- coding: utf-8 -*-
  2. import importlib
  3. from EditorialModel.components import EmComponent
  4. from EditorialModel.exceptions import EmComponentCheckError
  5. import EditorialModel
  6. from django.db import models
  7. ## EmField (Class)
  8. #
  9. # Represents one data for a lodel2 document
  10. class EmField(EmComponent):
  11. ranked_in = 'fieldgroup_id'
  12. ftype = None
  13. fieldtypes = {
  14. 'int': models.IntegerField,
  15. 'integer': models.IntegerField,
  16. 'bigint': models.BigIntegerField,
  17. 'smallint': models.SmallIntegerField,
  18. 'boolean': models.BooleanField,
  19. 'bool': models.BooleanField,
  20. 'float': models.FloatField,
  21. 'char': models.CharField,
  22. 'varchar': models.CharField,
  23. 'text': models.TextField,
  24. 'time': models.TimeField,
  25. 'date': models.DateField,
  26. 'datetime': models.DateTimeField,
  27. }
  28. ## Instanciate a new EmField
  29. # @todo define and test type for icon and fieldtype
  30. # @warning nullable == True by default
  31. def __init__(self, model, uid, name, fieldgroup_id, optional=False, internal=False, rel_field_id=None, icon='0', string=None, help_text=None, date_update=None, date_create=None, rank=None, nullable = True, default = None, **kwargs):
  32. self.fieldgroup_id = fieldgroup_id
  33. self.check_type('fieldgroup_id', int)
  34. self.optional = optional
  35. self.check_type('optional', bool)
  36. self.internal = internal
  37. self.check_type('internal', bool)
  38. self.rel_field_id = rel_field_id
  39. self.check_type('rel_field_id', (int, type(None)))
  40. self.icon = icon
  41. self.nullable = nullable
  42. self.default = default
  43. self.options = kwargs
  44. super(EmField, self).__init__(model=model, uid=uid, name=name, string=string, help_text=help_text, date_update=date_update, date_create=date_create, rank=rank)
  45. @staticmethod
  46. def get_field_class(ftype, **kwargs):
  47. ftype_module = importlib.import_module('EditorialModel.fieldtypes.%s'%ftype)
  48. return ftype_module.fclass
  49. ## @brief Abstract method that should return a validation function
  50. # @param raise_e Exception : if not valid raise this exception
  51. # @param ret_valid : if valid return this value
  52. # @param ret_invalid : if not valid return this value
  53. def validation_function(self, raise_e = None, ret_valid = None, ret_invalid = None):
  54. if self.__class__ == EmField:
  55. raise NotImplementedError("Abstract method")
  56. if raise_e is None and ret_valid is None:
  57. raise AttributeError("Behavior doesn't allows to return a valid validation function")
  58. return False
  59. ## @brief Return the list of relation fields for a rel_to_type
  60. # @return None if the field is not a rel_to_type else return a list of EmField
  61. def rel_to_type_fields(self):
  62. if not self.rel_to_type_id:
  63. return None
  64. return [ f for f in self.model.components(EmField) if f.rel_field_id == self.uid ]
  65. ## Check if the EmField is valid
  66. # @return True if valid False if not
  67. def check(self):
  68. super(EmField, self).check()
  69. em_fieldgroup = self.model.component(self.fieldgroup_id)
  70. if not em_fieldgroup:
  71. raise EmComponentCheckError("fieldgroup_id contains a non existing uid : '%d'" % self.fieldgroup_id)
  72. if not isinstance(em_fieldgroup, EditorialModel.fieldgroups.EmFieldGroup):
  73. raise EmComponentCheckError("fieldgroup_id contains an uid from a component that is not an EmFieldGroup but a %s" % str(type(em_fieldgroup)))
  74. ## @brief Delete a field if it's not linked
  75. # @return bool : True if deleted False if deletion aborded
  76. # @todo Check if unconditionnal deletion is correct
  77. def delete_check(self):
  78. return True
  79. """
  80. def to_django(self):
  81. if self.fieldtype in ('varchar', 'char'):
  82. max_length = None if 'max_length' not in self.options else self.options['max_length']
  83. return self.fieldtypes[self.fieldtype](max_length=max_length, **self.options)
  84. if self.fieldtype in ('time', 'datetime', 'date'):
  85. auto_now = False if 'auto_now' not in self.options else self.options['auto_now']
  86. auto_now_add = False if 'auto_now_add' not in self.options else self.options['auto_now_add']
  87. return self.fieldtypes[self.fieldtype](auto_now=auto_now, auto_now_add=auto_now_add, **self.options)
  88. if self.fieldtype == 'boolean' and ('nullable' in self.options and self.options['nullable'] == 1):
  89. return models.NullBooleanField(**self.options)
  90. return self.fieldtypes[self.fieldtype](**self.options)
  91. """