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.

177 lines
8.3 KiB

12 years ago
12 years ago
12 years ago
12 years ago
12 years ago
12 years ago
12 years ago
12 years ago
  1. # -*- coding: utf-8 -*-
  2. ##############################################################################
  3. #
  4. # Copyright (C) 2012 Agile Business Group sagl (<http://www.agilebg.com>)
  5. # Copyright (C) 2012 Domsense srl (<http://www.domsense.com>)
  6. #
  7. # This program is free software: you can redistribute it and/or modify
  8. # it under the terms of the GNU Affero General Public License as published
  9. # by the Free Software Foundation, either version 3 of the License, or
  10. # (at your option) any later version.
  11. #
  12. # This program is distributed in the hope that it will be useful,
  13. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. # GNU General Public License for more details.
  16. #
  17. # You should have received a copy of the GNU Affero General Public License
  18. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  19. #
  20. ##############################################################################
  21. from openerp.osv import fields, osv, orm
  22. from openerp.tools.translate import _
  23. import logging
  24. from mako.template import Template
  25. from datetime import datetime
  26. from openerp import tools
  27. from openerp.tools import safe_eval as eval
  28. def _models_get(self, cr, uid, context=None):
  29. obj = self.pool.get('ir.model')
  30. ids = obj.search(cr, uid, [])
  31. res = obj.read(cr, uid, ids, ['model', 'name'], context)
  32. return [(r['model'], r['name']) for r in res]
  33. class super_calendar_configurator(orm.Model):
  34. _logger = logging.getLogger('super.calendar')
  35. _name = 'super.calendar.configurator'
  36. _columns = {
  37. 'name': fields.char('Name', size=64, required=True),
  38. 'line_ids': fields.one2many(
  39. 'super.calendar.configurator.line', 'configurator_id', 'Lines'),
  40. }
  41. def generate_calendar_records(self, cr, uid, ids, context=None):
  42. configurator_ids = self.search(cr, uid, [])
  43. super_calendar_pool = self.pool.get('super.calendar')
  44. # removing old records
  45. super_calendar_ids = super_calendar_pool.search(
  46. cr, uid, [], context=context)
  47. super_calendar_pool.unlink(
  48. cr, uid, super_calendar_ids, context=context)
  49. for configurator in self.browse(cr, uid, configurator_ids, context):
  50. for line in configurator.line_ids:
  51. current_pool = self.pool.get(line.name.model)
  52. current_record_ids = current_pool.search(
  53. cr, uid, line.domain and eval(line.domain) or [],
  54. context=context)
  55. for current_record_id in current_record_ids:
  56. current_record = current_pool.browse(
  57. cr, uid, current_record_id, context=context)
  58. if line.user_field_id and \
  59. current_record[line.user_field_id.name] and\
  60. current_record[line.user_field_id.name]._table_name \
  61. != 'res.users':
  62. raise osv.except_osv(
  63. _('Error'),
  64. _("The 'User' field of record %s (%s) does not "
  65. "refer to res.users")
  66. % (
  67. current_record[line.description_field_id.name],
  68. line.name.model)
  69. )
  70. if (((line.description_field_id
  71. and current_record[line.description_field_id.name])
  72. or line.description_code)
  73. and current_record[line.date_start_field_id.name]):
  74. duration = False
  75. if not line.duration_field_id and\
  76. line.date_stop_field_id and\
  77. current_record[line.date_start_field_id.name] and\
  78. current_record[line.date_stop_field_id.name]:
  79. date_start = datetime.strptime(
  80. current_record[line.date_start_field_id.name],
  81. tools.DEFAULT_SERVER_DATETIME_FORMAT)
  82. date_stop = datetime.strptime(
  83. current_record[line.date_stop_field_id.name],
  84. tools.DEFAULT_SERVER_DATETIME_FORMAT)
  85. duration = (date_stop - date_start).total_seconds()
  86. duration /= 3600
  87. elif line.duration_field_id:
  88. duration = current_record[
  89. line.duration_field_id.name]
  90. if line.description_type != 'code':
  91. name = current_record[
  92. line.description_field_id.name]
  93. else:
  94. parse_dict = {'o': current_record}
  95. mytemplate = Template(line.description_code)
  96. name = mytemplate.render(**parse_dict)
  97. super_calendar_values = {
  98. 'name': name,
  99. 'model_description': line.description,
  100. 'date_start': current_record[
  101. line.date_start_field_id.name],
  102. 'duration': duration,
  103. 'user_id': line.user_field_id and
  104. current_record[line.user_field_id.name] and
  105. current_record[line.user_field_id.name].id or
  106. False,
  107. 'configurator_id': configurator.id,
  108. 'res_id': line.name.model + ',' +
  109. str(current_record['id']),
  110. 'model_id': line.name.id,
  111. }
  112. super_calendar_pool.create(
  113. cr, uid, super_calendar_values, context=context)
  114. self._logger.info('Calendar generated')
  115. return True
  116. class super_calendar_configurator_line(orm.Model):
  117. _name = 'super.calendar.configurator.line'
  118. _columns = {
  119. 'name': fields.many2one('ir.model', 'Model', required=True),
  120. 'description': fields.char('Description', size=128, required=True),
  121. 'domain': fields.char('Domain', size=512),
  122. 'configurator_id': fields.many2one(
  123. 'super.calendar.configurator', 'Configurator'),
  124. 'description_type': fields.selection(
  125. [
  126. ('field', 'Field'),
  127. ('code', 'Code'),
  128. ], string="Description Type"),
  129. 'description_field_id': fields.many2one(
  130. 'ir.model.fields', 'Description field',
  131. domain="[('model_id', '=', name),('ttype', '=', 'char')]"),
  132. 'description_code': fields.text(
  133. 'Description field',
  134. help="Use '${o}' to refer to the involved object. "
  135. "E.g.: '${o.project_id.name}'"),
  136. 'date_start_field_id': fields.many2one(
  137. 'ir.model.fields', 'Start date field',
  138. domain="['&','|',('ttype', '=', 'datetime'),"
  139. "('ttype', '=', 'date'),('model_id', '=', name)]",
  140. required=True),
  141. 'date_stop_field_id': fields.many2one(
  142. 'ir.model.fields', 'End date field',
  143. domain="['&',('ttype', '=', 'datetime'),('model_id', '=', name)]"),
  144. 'duration_field_id': fields.many2one(
  145. 'ir.model.fields', 'Duration field',
  146. domain="['&',('ttype', '=', 'float'),('model_id', '=', name)]"),
  147. 'user_field_id': fields.many2one(
  148. 'ir.model.fields', 'User field',
  149. domain="['&',('ttype', '=', 'many2one'),('model_id', '=', name)]"),
  150. }
  151. class super_calendar(orm.Model):
  152. _name = 'super.calendar'
  153. _columns = {
  154. 'name': fields.char('Description', size=512, required=True),
  155. 'model_description': fields.char(
  156. 'Model Description', size=128, required=True),
  157. 'date_start': fields.datetime('Start date', required=True),
  158. 'duration': fields.float('Duration'),
  159. 'user_id': fields.many2one('res.users', 'User'),
  160. 'configurator_id': fields.many2one(
  161. 'super.calendar.configurator', 'Configurator'),
  162. 'res_id': fields.reference(
  163. 'Resource', selection=_models_get, size=128),
  164. 'model_id': fields.many2one('ir.model', 'Model'),
  165. }