Alejandro Santana
10 years ago
18 changed files with 385 additions and 279 deletions
-
1__unported__/super_calendar/AUTHORS.txt
-
88__unported__/super_calendar/__openerp__.py
-
163__unported__/super_calendar/super_calendar.py
-
53super_calendar/README.rst
-
3super_calendar/__init__.py
-
49super_calendar/__openerp__.py
-
0super_calendar/data/cron_data.xml
-
0super_calendar/i18n/it.po
-
0super_calendar/i18n/ru.po
-
0super_calendar/i18n/super_calendar.pot
-
7super_calendar/models/__init__.py
-
235super_calendar/models/super_calendar.py
-
0super_calendar/security/ir.model.access.csv
-
BINsuper_calendar/static/description/meetings.png
-
BINsuper_calendar/static/description/month_calendar.png
-
BINsuper_calendar/static/description/phone_calls.png
-
BINsuper_calendar/static/description/week_calendar.png
-
23super_calendar/views/super_calendar_view.xml
@ -1 +0,0 @@ |
|||||
Lorenzo Battistini <lorenzo.battistini@agilebg.com> |
|
@ -1,88 +0,0 @@ |
|||||
# -*- coding: utf-8 -*- |
|
||||
############################################################################## |
|
||||
# |
|
||||
# Copyright (C) 2012 Agile Business Group sagl (<http://www.agilebg.com>) |
|
||||
# Copyright (C) 2012 Domsense srl (<http://www.domsense.com>) |
|
||||
# |
|
||||
# This program is free software: you can redistribute it and/or modify |
|
||||
# it under the terms of the GNU Affero General Public License as published |
|
||||
# by the Free Software Foundation, either version 3 of the License, or |
|
||||
# (at your option) any later version. |
|
||||
# |
|
||||
# This program is distributed in the hope that it will be useful, |
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
||||
# GNU General Public License for more details. |
|
||||
# |
|
||||
# You should have received a copy of the GNU Affero General Public License |
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|
||||
# |
|
||||
############################################################################## |
|
||||
{ |
|
||||
'name': "Super Calendar", |
|
||||
'version': '0.1', |
|
||||
'category': 'Generic Modules/Others', |
|
||||
'summary': 'This module allows to create configurable calendars.', |
|
||||
'description': """ |
|
||||
This module allows to create configurable calendars. |
|
||||
|
|
||||
Through the 'calendar configurator' object, you can specify which models have |
|
||||
to be merged in the super calendar. For each model, you have to define the |
|
||||
'description' and 'date_start' fields at least. Then you can define 'duration' |
|
||||
and the 'user_id' fields. |
|
||||
|
|
||||
The 'super.calendar' object contains the the merged calendars. The |
|
||||
'super.calendar' can be updated by 'ir.cron' or manually. |
|
||||
|
|
||||
Configuration |
|
||||
============= |
|
||||
|
|
||||
After installing the module you can go to |
|
||||
|
|
||||
Super calendar → Configuration → Configurators |
|
||||
|
|
||||
and create a new configurator. For instance, if you want to see meetings and |
|
||||
phone calls, you can create the following lines |
|
||||
|
|
||||
.. image:: http://planet.domsense.com/wp-content/uploads/2012/04/meetings.png |
|
||||
:width: 400 px |
|
||||
|
|
||||
.. image:: http://planet.domsense.com/wp-content/uploads/2012/04/phone_calls.png |
|
||||
:width: 400 px |
|
||||
|
|
||||
Then, you can use the ‘Generate Calendar’ button or wait for the scheduled |
|
||||
action (‘Generate Calendar Records’) to be run. |
|
||||
|
|
||||
When the calendar is generated, you can visualize it by the ‘super calendar’ main menu. |
|
||||
|
|
||||
Here is a sample monthly calendar: |
|
||||
|
|
||||
.. image:: http://planet.domsense.com/wp-content/uploads/2012/04/month_calendar.png |
|
||||
:width: 400 px |
|
||||
|
|
||||
And here is the weekly one: |
|
||||
|
|
||||
.. image:: http://planet.domsense.com/wp-content/uploads/2012/04/week_calendar.png |
|
||||
:width: 400 px |
|
||||
|
|
||||
As you can see, several filters are available. A typical usage consists in |
|
||||
filtering by ‘Configurator’ (if you have several configurators, |
|
||||
‘Scheduled calls and meetings’ can be one of them) and by your user. |
|
||||
Once you filtered, you can save the filter as ‘Advanced filter’ or even |
|
||||
add it to a dashboard. |
|
||||
""", |
|
||||
'author': "Agile Business Group,Odoo Community Association (OCA)", |
|
||||
'website': 'http://www.agilebg.com', |
|
||||
'license': 'AGPL-3', |
|
||||
'depends': ['base'], |
|
||||
"data": [ |
|
||||
'super_calendar_view.xml', |
|
||||
'cron_data.xml', |
|
||||
'security/ir.model.access.csv', |
|
||||
], |
|
||||
'demo': [], |
|
||||
'test': [], |
|
||||
'installable': False, |
|
||||
'application': True, |
|
||||
'auto_install': False, |
|
||||
} |
|
@ -1,163 +0,0 @@ |
|||||
# -*- coding: utf-8 -*- |
|
||||
############################################################################## |
|
||||
# |
|
||||
# Copyright (C) 2012 Agile Business Group sagl (<http://www.agilebg.com>) |
|
||||
# Copyright (C) 2012 Domsense srl (<http://www.domsense.com>) |
|
||||
# |
|
||||
# This program is free software: you can redistribute it and/or modify |
|
||||
# it under the terms of the GNU Affero General Public License as published |
|
||||
# by the Free Software Foundation, either version 3 of the License, or |
|
||||
# (at your option) any later version. |
|
||||
# |
|
||||
# This program is distributed in the hope that it will be useful, |
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
||||
# GNU General Public License for more details. |
|
||||
# |
|
||||
# You should have received a copy of the GNU Affero General Public License |
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|
||||
# |
|
||||
############################################################################## |
|
||||
|
|
||||
from openerp.osv import fields, orm |
|
||||
from openerp.tools.translate import _ |
|
||||
import logging |
|
||||
from mako.template import Template |
|
||||
from datetime import datetime |
|
||||
from openerp import tools |
|
||||
from openerp.tools.safe_eval import safe_eval |
|
||||
|
|
||||
|
|
||||
def _models_get(self, cr, uid, context=None): |
|
||||
obj = self.pool.get('ir.model') |
|
||||
ids = obj.search(cr, uid, []) |
|
||||
res = obj.read(cr, uid, ids, ['model', 'name'], context) |
|
||||
return [(r['model'], r['name']) for r in res] |
|
||||
|
|
||||
|
|
||||
class super_calendar_configurator(orm.Model): |
|
||||
_logger = logging.getLogger('super.calendar') |
|
||||
_name = 'super.calendar.configurator' |
|
||||
_columns = { |
|
||||
'name': fields.char('Name', size=64, required=True), |
|
||||
'line_ids': fields.one2many('super.calendar.configurator.line', 'configurator_id', 'Lines'), |
|
||||
} |
|
||||
|
|
||||
def generate_calendar_records(self, cr, uid, ids, context=None): |
|
||||
configurator_ids = self.search(cr, uid, []) |
|
||||
super_calendar_pool = self.pool.get('super.calendar') |
|
||||
|
|
||||
# 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) |
|
||||
|
|
||||
for configurator in self.browse(cr, uid, configurator_ids, context): |
|
||||
for line in configurator.line_ids: |
|
||||
current_pool = self.pool.get(line.name.model) |
|
||||
current_record_ids = current_pool.search( |
|
||||
cr, |
|
||||
uid, |
|
||||
line.domain and safe_eval(line.domain) or [], |
|
||||
context=context) |
|
||||
|
|
||||
for current_record_id in current_record_ids: |
|
||||
current_record = current_pool.browse(cr, uid, current_record_id, context=context) |
|
||||
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 orm.except_orm( |
|
||||
_('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 and current_record[line.description_field_id.name]) or |
|
||||
line.description_code) and |
|
||||
current_record[line.date_start_field_id.name]): |
|
||||
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 |
|
||||
elif line.duration_field_id: |
|
||||
duration = current_record[line.duration_field_id.name] |
|
||||
if line.description_type != 'code': |
|
||||
name = current_record[line.description_field_id.name] |
|
||||
else: |
|
||||
parse_dict = {'o': current_record} |
|
||||
mytemplate = Template(line.description_code) |
|
||||
name = mytemplate.render(**parse_dict) |
|
||||
super_calendar_values = { |
|
||||
'name': name, |
|
||||
'model_description': line.description, |
|
||||
'date_start': current_record[line.date_start_field_id.name], |
|
||||
'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 |
|
||||
), |
|
||||
'configurator_id': configurator.id, |
|
||||
'res_id': line.name.model+','+str(current_record['id']), |
|
||||
'model_id': line.name.id, |
|
||||
} |
|
||||
super_calendar_pool.create(cr, uid, super_calendar_values, context=context) |
|
||||
self._logger.info('Calendar generated') |
|
||||
return True |
|
||||
|
|
||||
|
|
||||
class super_calendar_configurator_line(orm.Model): |
|
||||
_name = 'super.calendar.configurator.line' |
|
||||
_columns = { |
|
||||
'name': fields.many2one('ir.model', 'Model', required=True), |
|
||||
'description': fields.char('Description', size=128, required=True), |
|
||||
'domain': fields.char('Domain', size=512), |
|
||||
'configurator_id': fields.many2one('super.calendar.configurator', 'Configurator'), |
|
||||
'description_type': fields.selection([ |
|
||||
('field', 'Field'), |
|
||||
('code', 'Code'), |
|
||||
], string="Description Type"), |
|
||||
'description_field_id': fields.many2one( |
|
||||
'ir.model.fields', 'Description field', |
|
||||
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)]", |
|
||||
required=True), |
|
||||
'date_stop_field_id': fields.many2one( |
|
||||
'ir.model.fields', 'End date field', |
|
||||
domain="['&',('ttype', '=', 'datetime'),('model_id', '=', name)]" |
|
||||
), |
|
||||
'duration_field_id': fields.many2one( |
|
||||
'ir.model.fields', 'Duration field', |
|
||||
domain="['&',('ttype', '=', 'float'),('model_id', '=', name)]"), |
|
||||
'user_field_id': fields.many2one( |
|
||||
'ir.model.fields', 'User field', |
|
||||
domain="['&',('ttype', '=', 'many2one'),('model_id', '=', name)]"), |
|
||||
} |
|
||||
|
|
||||
|
|
||||
class super_calendar(orm.Model): |
|
||||
_name = 'super.calendar' |
|
||||
_columns = { |
|
||||
'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'), |
|
||||
'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), |
|
||||
'model_id': fields.many2one('ir.model', 'Model'), |
|
||||
} |
|
@ -0,0 +1,53 @@ |
|||||
|
SUPER CALENDAR |
||||
|
============== |
||||
|
|
||||
|
This module allows to create configurable calendars. |
||||
|
|
||||
|
Through the 'calendar configurator' object, you can specify which models have |
||||
|
to be merged in the super calendar. For each model, you have to define the |
||||
|
'description' and 'date_start' fields at least. Then you can define 'duration' |
||||
|
and the 'user_id' fields. |
||||
|
|
||||
|
The 'super.calendar' object contains the the merged calendars. The |
||||
|
'super.calendar' can be updated by 'ir.cron' or manually. |
||||
|
|
||||
|
Configuration |
||||
|
============= |
||||
|
|
||||
|
After installing the module you can go to |
||||
|
|
||||
|
*Super calendar > Configuration > Configurators* |
||||
|
|
||||
|
and create a new configurator. For instance, if you want to see meetings and |
||||
|
phone calls, you can create the following lines |
||||
|
|
||||
|
Meetings: |
||||
|
|
||||
|
.. image:: super_calendar/static/description/meetings.png |
||||
|
:width: 400 px |
||||
|
|
||||
|
Phonecalls: |
||||
|
|
||||
|
.. image:: super_calendar/static/description/phone_calls.png |
||||
|
:width: 400 px |
||||
|
|
||||
|
Then, you can use the 'Generate Calendar' button or wait for the scheduled |
||||
|
action (‘Generate Calendar Records’) to be run. |
||||
|
|
||||
|
When the calendar is generated, you can visualize it by the 'super calendar' main menu. |
||||
|
|
||||
|
Here is a sample monthly calendar: |
||||
|
|
||||
|
.. image:: super_calendar/static/description/month_calendar.png |
||||
|
:width: 400 px |
||||
|
|
||||
|
And here is the weekly one: |
||||
|
|
||||
|
.. image:: super_calendar/static/description/week_calendar.png |
||||
|
:width: 400 px |
||||
|
|
||||
|
As you can see, several filters are available. A typical usage consists in |
||||
|
filtering by 'Configurator' (if you have several configurators, |
||||
|
'Scheduled calls and meetings' can be one of them) and by your user. |
||||
|
Once you filtered, you can save the filter as 'Advanced filter' or even |
||||
|
add it to a dashboard. |
@ -0,0 +1,49 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
############################################################################## |
||||
|
# |
||||
|
# Copyright (c) All rights reserved: |
||||
|
# (c) 2012 Agile Business Group sagl (<http://www.agilebg.com>) |
||||
|
# Lorenzo Battistini <lorenzo.battistini@agilebg.com> |
||||
|
# (c) 2012 Domsense srl (<http://www.domsense.com>) |
||||
|
# (c) 2015 Anubía, soluciones en la nube,SL (http://www.anubia.es) |
||||
|
# Alejandro Santana <alejandrosantana@anubia.es> |
||||
|
# |
||||
|
# This program is free software: you can redistribute it and/or modify |
||||
|
# it under the terms of the GNU Affero General Public License as |
||||
|
# published by the Free Software Foundation, either version 3 of the |
||||
|
# License, or (at your option) any later version. |
||||
|
# |
||||
|
# This program is distributed in the hope that it will be useful, |
||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
|
# GNU Affero General Public License for more details. |
||||
|
# |
||||
|
# You should have received a copy of the GNU Affero General Public License |
||||
|
# along with this program. If not, see http://www.gnu.org/licenses |
||||
|
# |
||||
|
############################################################################## |
||||
|
{ |
||||
|
'name': 'Super Calendar', |
||||
|
'version': '0.2', |
||||
|
'category': 'Generic Modules/Others', |
||||
|
'summary': 'This module allows to create configurable calendars.', |
||||
|
'author': ('Agile Business Group, ' |
||||
|
'Alejandro Santana <alejandrosantana@anubia.es>, ' |
||||
|
'Odoo Community Association (OCA)'), |
||||
|
'website': 'http://www.agilebg.com', |
||||
|
'license': 'AGPL-3', |
||||
|
'depends': [ |
||||
|
'base', |
||||
|
'web_calendar', |
||||
|
], |
||||
|
'data': [ |
||||
|
'views/super_calendar_view.xml', |
||||
|
'data/cron_data.xml', |
||||
|
'security/ir.model.access.csv', |
||||
|
], |
||||
|
'demo': [], |
||||
|
'test': [], |
||||
|
'installable': True, |
||||
|
'application': True, |
||||
|
'auto_install': False, |
||||
|
} |
@ -0,0 +1,7 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
################################################################ |
||||
|
# License, author and contributors information in: # |
||||
|
# __openerp__.py file at the root folder of this module. # |
||||
|
################################################################ |
||||
|
|
||||
|
from . import super_calendar |
@ -0,0 +1,235 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
############################################################################## |
||||
|
# |
||||
|
# Odoo, Open Source Management Solution |
||||
|
# |
||||
|
# Copyright (c) All rights reserved: |
||||
|
# (c) 2012 Agile Business Group sagl (<http://www.agilebg.com>) |
||||
|
# (c) 2012 Domsense srl (<http://www.domsense.com>) |
||||
|
# (c) 2015 Anubía, soluciones en la nube,SL (http://www.anubia.es) |
||||
|
# Alejandro Santana <alejandrosantana@anubia.es> |
||||
|
# |
||||
|
# This program is free software: you can redistribute it and/or modify |
||||
|
# it under the terms of the GNU Affero General Public License as |
||||
|
# published by the Free Software Foundation, either version 3 of the |
||||
|
# License, or (at your option) any later version. |
||||
|
# |
||||
|
# This program is distributed in the hope that it will be useful, |
||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
|
# GNU Affero General Public License for more details. |
||||
|
# |
||||
|
# You should have received a copy of the GNU Affero General Public License |
||||
|
# along with this program. If not, see http://www.gnu.org/licenses |
||||
|
# |
||||
|
############################################################################## |
||||
|
|
||||
|
from openerp import models, fields, api |
||||
|
from openerp.tools.translate import _ |
||||
|
from mako.template import Template |
||||
|
from datetime import datetime |
||||
|
from openerp import tools |
||||
|
from openerp.tools.safe_eval import safe_eval |
||||
|
import logging |
||||
|
|
||||
|
|
||||
|
def _models_get(self): |
||||
|
model_obj = self.env['ir.model'] |
||||
|
model_ids = model_obj.search([]) |
||||
|
return [(model.model, model.name) for model in model_ids] |
||||
|
|
||||
|
|
||||
|
class super_calendar_configurator(models.Model): |
||||
|
_logger = logging.getLogger(__name__) |
||||
|
_name = 'super.calendar.configurator' |
||||
|
|
||||
|
name = fields.Char( |
||||
|
string='Name', |
||||
|
size=64, |
||||
|
required=True, |
||||
|
) |
||||
|
line_ids = fields.One2many( |
||||
|
comodel_name='super.calendar.configurator.line', |
||||
|
inverse_name='configurator_id', |
||||
|
string='Lines', |
||||
|
) |
||||
|
|
||||
|
@api.multi |
||||
|
def generate_calendar_records(self): |
||||
|
configurator_ids = self.search([]) |
||||
|
super_calendar_pool = self.env['super.calendar'] |
||||
|
|
||||
|
# Remove old records |
||||
|
super_calendar_ids = super_calendar_pool.search([]) |
||||
|
super_calendar_ids.unlink() |
||||
|
|
||||
|
# Rebuild all calendar records |
||||
|
for configurator in configurator_ids: |
||||
|
for line in configurator.line_ids: |
||||
|
current_pool = self.env[line.name.model] |
||||
|
domain = line.domain and safe_eval(line.domain) or [] |
||||
|
current_record_ids = current_pool.search(domain) |
||||
|
|
||||
|
for cur_rec in current_record_ids: |
||||
|
f_user = line.user_field_id and line.user_field_id.name |
||||
|
f_descr = (line.description_field_id and |
||||
|
line.description_field_id.name) |
||||
|
f_date_start = (line.date_start_field_id and |
||||
|
line.date_start_field_id.name) |
||||
|
f_date_stop = (line.date_stop_field_id and |
||||
|
line.date_stop_field_id.name) |
||||
|
f_duration = (line.duration_field_id and |
||||
|
line.duration_field_id.name) |
||||
|
if (f_user and |
||||
|
cur_rec[f_user] and |
||||
|
cur_rec[f_user]._model._name != 'res.users'): |
||||
|
raise orm.except_orm( |
||||
|
_('Error'), |
||||
|
_("The 'User' field of record %s (%s) " |
||||
|
"does not refer to res.users") |
||||
|
% (cur_rec[f_descr], line.name.model)) |
||||
|
|
||||
|
if (((f_descr and cur_rec[f_descr]) or |
||||
|
line.description_code) and |
||||
|
cur_rec[f_date_start]): |
||||
|
duration = False |
||||
|
if (not line.duration_field_id and |
||||
|
line.date_stop_field_id and |
||||
|
cur_rec[f_date_start] and |
||||
|
cur_rec[f_date_stop]): |
||||
|
date_start = datetime.strptime( |
||||
|
cur_rec[f_date_start], |
||||
|
tools.DEFAULT_SERVER_DATETIME_FORMAT |
||||
|
) |
||||
|
date_stop = datetime.strptime( |
||||
|
cur_rec[f_date_stop], |
||||
|
tools.DEFAULT_SERVER_DATETIME_FORMAT |
||||
|
) |
||||
|
date_diff = (date_stop - date_start) |
||||
|
duration = date_diff.total_seconds() / 3600 |
||||
|
elif line.duration_field_id: |
||||
|
duration = cur_rec[f_duration] |
||||
|
if line.description_type != 'code': |
||||
|
name = cur_rec[f_descr] |
||||
|
else: |
||||
|
parse_dict = {'o': cur_rec} |
||||
|
mytemplate = Template(line.description_code) |
||||
|
name = mytemplate.render(**parse_dict) |
||||
|
|
||||
|
super_calendar_values = { |
||||
|
'name': name, |
||||
|
'model_description': line.description, |
||||
|
'date_start': cur_rec[f_date_start], |
||||
|
'duration': duration, |
||||
|
'user_id': ( |
||||
|
f_user and |
||||
|
cur_rec[f_user] and |
||||
|
cur_rec[f_user].id or |
||||
|
False |
||||
|
), |
||||
|
'configurator_id': configurator.id, |
||||
|
'res_id': line.name.model+','+str(cur_rec['id']), |
||||
|
'model_id': line.name.id, |
||||
|
} |
||||
|
super_calendar_pool.create(super_calendar_values) |
||||
|
self._logger.info('Calendar generated') |
||||
|
return True |
||||
|
|
||||
|
|
||||
|
class super_calendar_configurator_line(models.Model): |
||||
|
_name = 'super.calendar.configurator.line' |
||||
|
|
||||
|
name = fields.Many2one( |
||||
|
comodel_name='ir.model', |
||||
|
string='Model', |
||||
|
required=True, |
||||
|
) |
||||
|
description = fields.Char( |
||||
|
string='Description', |
||||
|
size=128, |
||||
|
required=True, |
||||
|
) |
||||
|
domain = fields.Char( |
||||
|
string='Domain', |
||||
|
size=512, |
||||
|
) |
||||
|
configurator_id = fields.Many2one( |
||||
|
comodel_name='super.calendar.configurator', |
||||
|
string='Configurator', |
||||
|
) |
||||
|
description_type = fields.Selection( |
||||
|
[('field', 'Field'), |
||||
|
('code', 'Code')], |
||||
|
string="Description Type", |
||||
|
) |
||||
|
description_field_id = fields.Many2one( |
||||
|
comodel_name='ir.model.fields', |
||||
|
string='Description field', |
||||
|
domain="[('model_id', '=', name), ('ttype', '=', 'char')]", |
||||
|
) |
||||
|
description_code = fields.Text( |
||||
|
string='Description field', |
||||
|
help=("Use '${o}' to refer to the involved object. " |
||||
|
"E.g.: '${o.project_id.name}'"), |
||||
|
) |
||||
|
date_start_field_id = fields.Many2one( |
||||
|
comodel_name='ir.model.fields', |
||||
|
string='Start date field', |
||||
|
domain=("['&','|',('ttype', '=', 'datetime'),('ttype', '=', 'date')," |
||||
|
"('model_id', '=', name)]"), |
||||
|
required=True, |
||||
|
) |
||||
|
date_stop_field_id = fields.Many2one( |
||||
|
comodel_name='ir.model.fields', |
||||
|
string='End date field', |
||||
|
domain="['&',('ttype', '=', 'datetime'),('model_id', '=', name)]" |
||||
|
) |
||||
|
duration_field_id = fields.Many2one( |
||||
|
comodel_name='ir.model.fields', |
||||
|
string='Duration field', |
||||
|
domain="['&',('ttype', '=', 'float'), ('model_id', '=', name)]", |
||||
|
) |
||||
|
user_field_id = fields.Many2one( |
||||
|
comodel_name='ir.model.fields', |
||||
|
string='User field', |
||||
|
domain="['&', ('ttype', '=', 'many2one'), ('model_id', '=', name)]", |
||||
|
) |
||||
|
|
||||
|
|
||||
|
class super_calendar(models.Model): |
||||
|
_name = 'super.calendar' |
||||
|
|
||||
|
name = fields.Char( |
||||
|
string='Description', |
||||
|
size=512, |
||||
|
required=True, |
||||
|
) |
||||
|
model_description = fields.Char( |
||||
|
string='Model Description', |
||||
|
size=128, |
||||
|
required=True, |
||||
|
) |
||||
|
date_start = fields.Datetime( |
||||
|
string='Start date', |
||||
|
required=True, |
||||
|
) |
||||
|
duration = fields.Float( |
||||
|
string='Duration' |
||||
|
) |
||||
|
user_id = fields.Many2one( |
||||
|
comodel_name='res.users', |
||||
|
string='User', |
||||
|
) |
||||
|
configurator_id = fields.Many2one( |
||||
|
comodel_name='super.calendar.configurator', |
||||
|
string='Configurator', |
||||
|
) |
||||
|
res_id = fields.Reference( |
||||
|
selection=_models_get, |
||||
|
string='Resource', |
||||
|
size=128, |
||||
|
) |
||||
|
model_id = fields.Many2one( |
||||
|
comodel_name='ir.model', |
||||
|
string='Model', |
||||
|
) |
After Width: 962 | Height: 374 | Size: 25 KiB |
After Width: 1064 | Height: 536 | Size: 70 KiB |
After Width: 960 | Height: 322 | Size: 26 KiB |
After Width: 1062 | Height: 566 | Size: 78 KiB |
Write
Preview
Loading…
Cancel
Save
Reference in new issue