42 lines
1.9 KiB
Python
42 lines
1.9 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
from openerp.osv import fields, osv
|
|
|
|
|
|
class sales_team_configuration(osv.TransientModel):
|
|
_name = 'sale.config.settings'
|
|
_inherit = ['sale.config.settings']
|
|
|
|
def set_group_multi_salesteams(self, cr, uid, ids, context=None):
|
|
""" This method is automatically called by res_config as it begins
|
|
with set. It is used to implement the 'one group or another'
|
|
behavior. We have to perform some group manipulation by hand
|
|
because in res_config.execute(), set_* methods are called
|
|
after group_*; therefore writing on an hidden res_config file
|
|
could not work.
|
|
If group_multi_salesteams is checked: remove group_mono_salesteams
|
|
from group_user, remove the users. Otherwise, just add
|
|
group_mono_salesteams in group_user.
|
|
The inverse logic about group_multi_salesteams is managed by the
|
|
normal behavior of 'group_multi_salesteams' field.
|
|
"""
|
|
def ref(xml_id):
|
|
mod, xml = xml_id.split('.', 1)
|
|
return self.pool['ir.model.data'].get_object(cr, uid, mod, xml, context)
|
|
|
|
for obj in self.browse(cr, uid, ids, context=context):
|
|
config_group = ref('base.group_mono_salesteams')
|
|
base_group = ref('base.group_user')
|
|
if obj.group_multi_salesteams:
|
|
base_group.write({'implied_ids': [(3, config_group.id)]})
|
|
config_group.write({'users': [(3, u.id) for u in base_group.users]})
|
|
else:
|
|
base_group.write({'implied_ids': [(4, config_group.id)]})
|
|
return True
|
|
|
|
_columns = {
|
|
'group_multi_salesteams': fields.boolean("Organize Sales activities into multiple Sales Teams",
|
|
implied_group='base.group_multi_salesteams',
|
|
help="""Allows you to use Sales Teams to manage your leads and opportunities."""),
|
|
}
|