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.
74 lines
3.4 KiB
74 lines
3.4 KiB
# -*- encoding: utf-8 -*-
|
|
###########################################################################
|
|
# Module Writen to OpenERP, Open Source Management Solution
|
|
#
|
|
# Copyright (c) 2010 Vauxoo - http://www.vauxoo.com/
|
|
# All Rights Reserved.
|
|
# info Vauxoo (info@vauxoo.com)
|
|
############################################################################
|
|
# Coded by: Luis Torres (luis_t@vauxoo.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 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 osv, fields
|
|
from openerp import SUPERUSER_ID
|
|
|
|
class wizard_merge_partner_by_partner(osv.osv_memory):
|
|
_name = 'wizard.merge.partner.by.partner'
|
|
|
|
def default_get(self, cr, uid, fields, context=None):
|
|
partner_obj = self.pool.get('res.partner')
|
|
partner = partner_obj.browse(cr, uid, context.get('active_id'),\
|
|
context=context)
|
|
res = {'partner_id' : partner.id , 'partner_ids' : [partner.id]}
|
|
return res
|
|
|
|
_columns = {
|
|
'partner_id' : fields.many2one('res.partner', 'Partner', readonly=True,
|
|
required=True, help='Correct partner to complete data'),
|
|
'partner_ids': fields.many2many('res.partner', 'partners_to_merge',
|
|
'partner_id', 'wizard_id', 'Partner to merge', help='Partners to '\
|
|
'merge'),
|
|
}
|
|
|
|
def merge_cb(self, cr, uid, ids, context=None):
|
|
base_partner_obj = self.pool.get('base.partner.merge.automatic.wizard')
|
|
partner_obj = self.pool.get('res.partner')
|
|
for data in self.browse(cr, uid, ids, context=context):
|
|
dst_partner = data.partner_id
|
|
partner_ids = set(map(int, data.partner_ids))
|
|
if len(partner_ids) >= 2:
|
|
base_partner_obj.merge_pbp(cr, SUPERUSER_ID, partner_ids,\
|
|
dst_partner, context=context)
|
|
adminpac_ids = {}
|
|
for partner in data.partner_ids:
|
|
if partner.adminpaq_id:
|
|
adminpac_ids.update({partner.id : partner.adminpaq_id})
|
|
if len(adminpac_ids) == 1:
|
|
partner_obj.write(cr, uid, adminpac_ids.keys()[0], {
|
|
'adminpaq_id' : 0})
|
|
partner_obj.write(cr, uid, data.partner_id.id, {
|
|
'adminpaq_id' : adminpac_ids.values()[0]})
|
|
list_partners = data.partner_ids
|
|
if dst_partner in data.partner_ids:
|
|
list_partners.remove(dst_partner)
|
|
partner_mergeds = []
|
|
for x in list_partners:
|
|
partner_mergeds.append(x.id)
|
|
partner_obj.write(cr, uid, dst_partner.id, {'partner_merged_ids' : [(6, 0, partner_mergeds)]}, context=context)
|
|
return True
|
|
|
|
|