|
@ -1,6 +1,6 @@ |
|
|
# -*- coding: utf-8 -*- |
|
|
# -*- coding: utf-8 -*- |
|
|
############################################################################## |
|
|
############################################################################## |
|
|
# |
|
|
|
|
|
|
|
|
# |
|
|
# Copyright (C) 2012 Agile Business Group sagl (<http://www.agilebg.com>) |
|
|
# Copyright (C) 2012 Agile Business Group sagl (<http://www.agilebg.com>) |
|
|
# Copyright (C) 2012 Domsense srl (<http://www.domsense.com>) |
|
|
# Copyright (C) 2012 Domsense srl (<http://www.domsense.com>) |
|
|
# |
|
|
# |
|
@ -27,106 +27,151 @@ from datetime import datetime |
|
|
from openerp import tools |
|
|
from openerp import tools |
|
|
from openerp.tools import safe_eval as eval |
|
|
from openerp.tools import safe_eval as eval |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def _models_get(self, cr, uid, context=None): |
|
|
def _models_get(self, cr, uid, context=None): |
|
|
obj = self.pool.get('ir.model') |
|
|
obj = self.pool.get('ir.model') |
|
|
ids = obj.search(cr, uid, []) |
|
|
ids = obj.search(cr, uid, []) |
|
|
res = obj.read(cr, uid, ids, ['model', 'name'], context) |
|
|
res = obj.read(cr, uid, ids, ['model', 'name'], context) |
|
|
return [(r['model'], r['name']) for r in res] |
|
|
return [(r['model'], r['name']) for r in res] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class super_calendar_configurator(orm.Model): |
|
|
class super_calendar_configurator(orm.Model): |
|
|
_logger = logging.getLogger('super.calendar') |
|
|
_logger = logging.getLogger('super.calendar') |
|
|
_name = 'super.calendar.configurator' |
|
|
_name = 'super.calendar.configurator' |
|
|
_columns = { |
|
|
|
|
|
|
|
|
_columns = { |
|
|
'name': fields.char('Name', size=64, required=True), |
|
|
'name': fields.char('Name', size=64, required=True), |
|
|
'line_ids': fields.one2many('super.calendar.configurator.line', 'configurator_id', 'Lines'), |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
'line_ids': fields.one2many( |
|
|
|
|
|
'super.calendar.configurator.line', 'configurator_id', 'Lines'), |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
def generate_calendar_records(self, cr, uid, ids, context=None): |
|
|
def generate_calendar_records(self, cr, uid, ids, context=None): |
|
|
configurator_ids = self.search(cr, uid, []) |
|
|
configurator_ids = self.search(cr, uid, []) |
|
|
super_calendar_pool = self.pool.get('super.calendar') |
|
|
super_calendar_pool = self.pool.get('super.calendar') |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# removing old records |
|
|
# removing old records |
|
|
super_calendar_ids = super_calendar_pool.search(cr, uid, [], context=context) |
|
|
|
|
|
super_calendar_pool.unlink(cr, uid, super_calendar_ids, context=context) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
super_calendar_ids = super_calendar_pool.search( |
|
|
|
|
|
cr, uid, [], context=context) |
|
|
|
|
|
super_calendar_pool.unlink( |
|
|
|
|
|
cr, uid, super_calendar_ids, context=context) |
|
|
|
|
|
|
|
|
for configurator in self.browse(cr, uid, configurator_ids, context): |
|
|
for configurator in self.browse(cr, uid, configurator_ids, context): |
|
|
for line in configurator.line_ids: |
|
|
for line in configurator.line_ids: |
|
|
current_pool = self.pool.get(line.name.model) |
|
|
current_pool = self.pool.get(line.name.model) |
|
|
current_record_ids = current_pool.search(cr, uid, line.domain and eval(line.domain) or [], context=context) |
|
|
|
|
|
|
|
|
current_record_ids = current_pool.search( |
|
|
|
|
|
cr, uid, line.domain and eval(line.domain) or [], |
|
|
|
|
|
context=context) |
|
|
for current_record_id in current_record_ids: |
|
|
for current_record_id in current_record_ids: |
|
|
current_record = current_pool.browse(cr, uid, current_record_id, context=context) |
|
|
|
|
|
|
|
|
current_record = current_pool.browse( |
|
|
|
|
|
cr, uid, current_record_id, context=context) |
|
|
if line.user_field_id and \ |
|
|
if line.user_field_id and \ |
|
|
current_record[line.user_field_id.name] and current_record[line.user_field_id.name]._table_name != 'res.users': |
|
|
|
|
|
raise osv.except_osv(_('Error'), |
|
|
|
|
|
_("The 'User' field of record %s (%s) does not refer to res.users") |
|
|
|
|
|
% (current_record[line.description_field_id.name], line.name.model)) |
|
|
|
|
|
|
|
|
current_record[line.user_field_id.name] and\ |
|
|
|
|
|
current_record[line.user_field_id.name]._table_name \ |
|
|
|
|
|
!= 'res.users': |
|
|
|
|
|
raise osv.except_osv( |
|
|
|
|
|
_('Error'), |
|
|
|
|
|
_("The 'User' field of record %s (%s) does not " |
|
|
|
|
|
"refer to res.users") |
|
|
|
|
|
% ( |
|
|
|
|
|
current_record[line.description_field_id.name], |
|
|
|
|
|
line.name.model) |
|
|
|
|
|
) |
|
|
if (((line.description_field_id |
|
|
if (((line.description_field_id |
|
|
and current_record[line.description_field_id.name]) |
|
|
|
|
|
or line.description_code) |
|
|
|
|
|
and current_record[line.date_start_field_id.name]): |
|
|
|
|
|
|
|
|
and current_record[line.description_field_id.name]) |
|
|
|
|
|
or line.description_code) |
|
|
|
|
|
and current_record[line.date_start_field_id.name]): |
|
|
duration = False |
|
|
duration = False |
|
|
if not line.duration_field_id and line.date_stop_field_id and current_record[line.date_start_field_id.name] and current_record[line.date_stop_field_id.name]: |
|
|
|
|
|
date_start= datetime.strptime(current_record[line.date_start_field_id.name], tools.DEFAULT_SERVER_DATETIME_FORMAT) |
|
|
|
|
|
date_stop= datetime.strptime(current_record[line.date_stop_field_id.name], tools.DEFAULT_SERVER_DATETIME_FORMAT) |
|
|
|
|
|
duration = (date_stop - date_start).total_seconds() / 3600 |
|
|
|
|
|
|
|
|
if not line.duration_field_id and\ |
|
|
|
|
|
line.date_stop_field_id and\ |
|
|
|
|
|
current_record[line.date_start_field_id.name] and\ |
|
|
|
|
|
current_record[line.date_stop_field_id.name]: |
|
|
|
|
|
date_start = datetime.strptime( |
|
|
|
|
|
current_record[line.date_start_field_id.name], |
|
|
|
|
|
tools.DEFAULT_SERVER_DATETIME_FORMAT) |
|
|
|
|
|
date_stop = datetime.strptime( |
|
|
|
|
|
current_record[line.date_stop_field_id.name], |
|
|
|
|
|
tools.DEFAULT_SERVER_DATETIME_FORMAT) |
|
|
|
|
|
duration = (date_stop - date_start).total_seconds() |
|
|
|
|
|
duration /= 3600 |
|
|
elif line.duration_field_id: |
|
|
elif line.duration_field_id: |
|
|
duration = current_record[line.duration_field_id.name] |
|
|
|
|
|
|
|
|
duration = current_record[ |
|
|
|
|
|
line.duration_field_id.name] |
|
|
if line.description_type != 'code': |
|
|
if line.description_type != 'code': |
|
|
name = current_record[line.description_field_id.name] |
|
|
|
|
|
|
|
|
name = current_record[ |
|
|
|
|
|
line.description_field_id.name] |
|
|
else: |
|
|
else: |
|
|
parse_dict = {'o': current_record} |
|
|
parse_dict = {'o': current_record} |
|
|
mytemplate = Template(line.description_code) |
|
|
mytemplate = Template(line.description_code) |
|
|
name= mytemplate.render(**parse_dict) |
|
|
|
|
|
|
|
|
name = mytemplate.render(**parse_dict) |
|
|
super_calendar_values = { |
|
|
super_calendar_values = { |
|
|
'name': name, |
|
|
'name': name, |
|
|
'model_description': line.description, |
|
|
'model_description': line.description, |
|
|
'date_start': current_record[line.date_start_field_id.name], |
|
|
|
|
|
|
|
|
'date_start': current_record[ |
|
|
|
|
|
line.date_start_field_id.name], |
|
|
'duration': duration, |
|
|
'duration': duration, |
|
|
'user_id': line.user_field_id and current_record[line.user_field_id.name] and current_record[line.user_field_id.name].id or False, |
|
|
|
|
|
|
|
|
'user_id': line.user_field_id and |
|
|
|
|
|
current_record[line.user_field_id.name] and |
|
|
|
|
|
current_record[line.user_field_id.name].id or |
|
|
|
|
|
False, |
|
|
'configurator_id': configurator.id, |
|
|
'configurator_id': configurator.id, |
|
|
'res_id': line.name.model+','+str(current_record['id']), |
|
|
|
|
|
|
|
|
'res_id': line.name.model + ',' + |
|
|
|
|
|
str(current_record['id']), |
|
|
'model_id': line.name.id, |
|
|
'model_id': line.name.id, |
|
|
} |
|
|
|
|
|
super_calendar_pool.create(cr, uid, super_calendar_values, context=context) |
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
super_calendar_pool.create( |
|
|
|
|
|
cr, uid, super_calendar_values, context=context) |
|
|
self._logger.info('Calendar generated') |
|
|
self._logger.info('Calendar generated') |
|
|
return True |
|
|
return True |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class super_calendar_configurator_line(orm.Model): |
|
|
class super_calendar_configurator_line(orm.Model): |
|
|
_name = 'super.calendar.configurator.line' |
|
|
_name = 'super.calendar.configurator.line' |
|
|
_columns = { |
|
|
|
|
|
|
|
|
_columns = { |
|
|
'name': fields.many2one('ir.model', 'Model', required=True), |
|
|
'name': fields.many2one('ir.model', 'Model', required=True), |
|
|
'description': fields.char('Description', size=128, required=True), |
|
|
'description': fields.char('Description', size=128, required=True), |
|
|
'domain': fields.char('Domain', size=512), |
|
|
'domain': fields.char('Domain', size=512), |
|
|
'configurator_id': fields.many2one('super.calendar.configurator', 'Configurator'), |
|
|
|
|
|
'description_type': fields.selection([ |
|
|
|
|
|
('field', 'Field'), |
|
|
|
|
|
('code', 'Code'), |
|
|
|
|
|
|
|
|
'configurator_id': fields.many2one( |
|
|
|
|
|
'super.calendar.configurator', 'Configurator'), |
|
|
|
|
|
'description_type': fields.selection( |
|
|
|
|
|
[ |
|
|
|
|
|
('field', 'Field'), |
|
|
|
|
|
('code', 'Code'), |
|
|
], string="Description Type"), |
|
|
], string="Description Type"), |
|
|
'description_field_id': fields.many2one('ir.model.fields', 'Description field', |
|
|
|
|
|
|
|
|
'description_field_id': fields.many2one( |
|
|
|
|
|
'ir.model.fields', 'Description field', |
|
|
domain="[('model_id', '=', name),('ttype', '=', 'char')]"), |
|
|
domain="[('model_id', '=', name),('ttype', '=', 'char')]"), |
|
|
'description_code': fields.text('Description field', help="Use '${o}' to refer to the involved object. E.g.: '${o.project_id.name}'"), |
|
|
|
|
|
'date_start_field_id': fields.many2one('ir.model.fields', 'Start date field', |
|
|
|
|
|
domain="['&','|',('ttype', '=', 'datetime'),('ttype', '=', 'date'),('model_id', '=', name)]", |
|
|
|
|
|
|
|
|
'description_code': fields.text( |
|
|
|
|
|
'Description field', |
|
|
|
|
|
help="Use '${o}' to refer to the involved object. " |
|
|
|
|
|
"E.g.: '${o.project_id.name}'"), |
|
|
|
|
|
'date_start_field_id': fields.many2one( |
|
|
|
|
|
'ir.model.fields', 'Start date field', |
|
|
|
|
|
domain="['&','|',('ttype', '=', 'datetime')," |
|
|
|
|
|
"('ttype', '=', 'date'),('model_id', '=', name)]", |
|
|
required=True), |
|
|
required=True), |
|
|
'date_stop_field_id': fields.many2one('ir.model.fields', 'End date field', |
|
|
|
|
|
|
|
|
'date_stop_field_id': fields.many2one( |
|
|
|
|
|
'ir.model.fields', 'End date field', |
|
|
domain="['&',('ttype', '=', 'datetime'),('model_id', '=', name)]"), |
|
|
domain="['&',('ttype', '=', 'datetime'),('model_id', '=', name)]"), |
|
|
'duration_field_id': fields.many2one('ir.model.fields', 'Duration field', |
|
|
|
|
|
|
|
|
'duration_field_id': fields.many2one( |
|
|
|
|
|
'ir.model.fields', 'Duration field', |
|
|
domain="['&',('ttype', '=', 'float'),('model_id', '=', name)]"), |
|
|
domain="['&',('ttype', '=', 'float'),('model_id', '=', name)]"), |
|
|
'user_field_id': fields.many2one('ir.model.fields', 'User field', |
|
|
|
|
|
|
|
|
'user_field_id': fields.many2one( |
|
|
|
|
|
'ir.model.fields', 'User field', |
|
|
domain="['&',('ttype', '=', 'many2one'),('model_id', '=', name)]"), |
|
|
domain="['&',('ttype', '=', 'many2one'),('model_id', '=', name)]"), |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class super_calendar(orm.Model): |
|
|
class super_calendar(orm.Model): |
|
|
_name = 'super.calendar' |
|
|
_name = 'super.calendar' |
|
|
_columns = { |
|
|
|
|
|
|
|
|
_columns = { |
|
|
'name': fields.char('Description', size=512, required=True), |
|
|
'name': fields.char('Description', size=512, required=True), |
|
|
'model_description': fields.char('Model Description', size=128, required=True), |
|
|
|
|
|
'date_start':fields.datetime('Start date', required=True), |
|
|
|
|
|
'duration':fields.float('Duration'), |
|
|
|
|
|
|
|
|
'model_description': fields.char( |
|
|
|
|
|
'Model Description', size=128, required=True), |
|
|
|
|
|
'date_start': fields.datetime('Start date', required=True), |
|
|
|
|
|
'duration': fields.float('Duration'), |
|
|
'user_id': fields.many2one('res.users', 'User'), |
|
|
'user_id': fields.many2one('res.users', 'User'), |
|
|
'configurator_id': fields.many2one('super.calendar.configurator', 'Configurator'), |
|
|
|
|
|
'res_id': fields.reference('Resource', selection=_models_get, size=128), |
|
|
|
|
|
|
|
|
'configurator_id': fields.many2one( |
|
|
|
|
|
'super.calendar.configurator', 'Configurator'), |
|
|
|
|
|
'res_id': fields.reference( |
|
|
|
|
|
'Resource', selection=_models_get, size=128), |
|
|
'model_id': fields.many2one('ir.model', 'Model'), |
|
|
'model_id': fields.many2one('ir.model', 'Model'), |
|
|
} |
|
|
|
|
|
|
|
|
} |