100 lines
4.5 KiB
Python
100 lines
4.5 KiB
Python
##############################################################################
|
|
#
|
|
# OpenERP, Open Source Management Solution
|
|
# Copyright (C) 2004-2010 Tiny SPRL (<http://tiny.be>).
|
|
#
|
|
# 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.osv import fields, osv
|
|
from openerp.tools.translate import _
|
|
|
|
class crm_merge_opportunity(osv.osv_memory):
|
|
"""
|
|
Merge opportunities together.
|
|
If we're talking about opportunities, it's just because it makes more sense
|
|
to merge opps than leads, because the leads are more ephemeral objects.
|
|
But since opportunities are leads, it's also possible to merge leads
|
|
together (resulting in a new lead), or leads and opps together (resulting
|
|
in a new opp).
|
|
"""
|
|
|
|
_name = 'crm.merge.opportunity'
|
|
_description = 'Merge opportunities'
|
|
_columns = {
|
|
'opportunity_ids': fields.many2many('crm.lead', rel='merge_opportunity_rel', id1='merge_id', id2='opportunity_id', string='Leads/Opportunities'),
|
|
'user_id': fields.many2one('res.users', 'Salesperson', select=True),
|
|
'section_id': fields.many2one('crm.case.section', 'Sales Team', select=True),
|
|
}
|
|
|
|
def action_merge(self, cr, uid, ids, context=None):
|
|
if context is None:
|
|
context = {}
|
|
|
|
lead_obj = self.pool.get('crm.lead')
|
|
wizard = self.browse(cr, uid, ids[0], context=context)
|
|
opportunity2merge_ids = wizard.opportunity_ids
|
|
|
|
#TODO: why is this passed through the context ?
|
|
context['lead_ids'] = [opportunity2merge_ids[0].id]
|
|
|
|
merge_id = lead_obj.merge_opportunity(cr, uid, [x.id for x in opportunity2merge_ids], wizard.user_id.id, wizard.section_id.id, context=context)
|
|
|
|
# The newly created lead might be a lead or an opp: redirect toward the right view
|
|
merge_result = lead_obj.browse(cr, uid, merge_id, context=context)
|
|
|
|
if merge_result.type == 'opportunity':
|
|
return lead_obj.redirect_opportunity_view(cr, uid, merge_id, context=context)
|
|
else:
|
|
return lead_obj.redirect_lead_view(cr, uid, merge_id, context=context)
|
|
|
|
def default_get(self, cr, uid, fields, context=None):
|
|
"""
|
|
Use active_ids from the context to fetch the leads/opps to merge.
|
|
In order to get merged, these leads/opps can't be in 'Done' or
|
|
'Cancel' state.
|
|
"""
|
|
if context is None:
|
|
context = {}
|
|
record_ids = context.get('active_ids', False)
|
|
res = super(crm_merge_opportunity, self).default_get(cr, uid, fields, context=context)
|
|
|
|
if record_ids:
|
|
opp_ids = []
|
|
opps = self.pool.get('crm.lead').browse(cr, uid, record_ids, context=context)
|
|
for opp in opps:
|
|
if opp.state not in ('done', 'cancel'):
|
|
opp_ids.append(opp.id)
|
|
if 'opportunity_ids' in fields:
|
|
res.update({'opportunity_ids': opp_ids})
|
|
|
|
return res
|
|
|
|
def on_change_user(self, cr, uid, ids, user_id, section_id, context=None):
|
|
""" When changing the user, also set a section_id or restrict section id
|
|
to the ones user_id is member of. """
|
|
if user_id:
|
|
if section_id:
|
|
user_in_section = self.pool.get('crm.case.section').search(cr, uid, [('id', '=', section_id), '|', ('user_id', '=', user_id), ('member_ids', '=', user_id)], context=context, count=True)
|
|
else:
|
|
user_in_section = False
|
|
if not user_in_section:
|
|
section_id = False
|
|
section_ids = self.pool.get('crm.case.section').search(cr, uid, ['|', ('user_id', '=', user_id), ('member_ids', '=', user_id)], context=context)
|
|
if section_ids:
|
|
section_id = section_ids[0]
|
|
return {'value': {'section_id': section_id}}
|
|
|
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|