diff --git a/partner_do_merge/__openerp__.py b/partner_do_merge/__openerp__.py index 29a246270..7461e5585 100644 --- a/partner_do_merge/__openerp__.py +++ b/partner_do_merge/__openerp__.py @@ -50,6 +50,8 @@ created an action menu in the partner view ], 'data': [ 'wizard/base_partner_merge_view.xml', + 'wizard/merge_by_partner.xml', + 'view/res_partner_view.xml', ], 'js': [ ], diff --git a/partner_do_merge/model/partner.py b/partner_do_merge/model/partner.py index c9a1bd8c1..36b9cf6f5 100644 --- a/partner_do_merge/model/partner.py +++ b/partner_do_merge/model/partner.py @@ -66,6 +66,10 @@ class res_partner(osv.Model): store=_display_name_store_triggers), 'id': fields.integer('Id', readonly=True), 'create_date': fields.datetime('Create Date', readonly=True), + 'partner_merged_ids' : fields.many2many('res.partner',\ + 'partners_mergeds', 'partner_active', 'partner_id', 'Relation '\ + 'with partner merged', domain=['|', ('active','=',True), (\ + 'active','=',False)], readonly=True) } diff --git a/partner_do_merge/view/res_partner_view.xml b/partner_do_merge/view/res_partner_view.xml new file mode 100644 index 000000000..615860a99 --- /dev/null +++ b/partner_do_merge/view/res_partner_view.xml @@ -0,0 +1,21 @@ + + + + + + view.partner.form.inh.partner.merge.form + form + res.partner + + + + + + + + + + + + + diff --git a/partner_do_merge/wizard/__init__.py b/partner_do_merge/wizard/__init__.py index 65c9179ec..30b45aaab 100644 --- a/partner_do_merge/wizard/__init__.py +++ b/partner_do_merge/wizard/__init__.py @@ -1 +1,2 @@ import base_partner_merge +import merge_by_partner diff --git a/partner_do_merge/wizard/base_partner_merge.py b/partner_do_merge/wizard/base_partner_merge.py index 412b1f5ce..27928dd30 100644 --- a/partner_do_merge/wizard/base_partner_merge.py +++ b/partner_do_merge/wizard/base_partner_merge.py @@ -375,9 +375,9 @@ class MergePartnerAutomatic(osv.TransientModel): ", ".join('%s<%s>(ID %s)' % (p.name, p.email or 'n/a', p.id) for p in src_partners))) - + for partner in src_partners: - partner.unlink() + partner.write({'active' : False}) def clean_emails(self, cr, uid, context=None): """ @@ -478,13 +478,13 @@ class MergePartnerAutomatic(osv.TransientModel): for key in self._columns.keys() if key.startswith(group_by_str) ] - + groups = [ field for field in fields if getattr(this, '%s%s' % (group_by_str, field), False) ] - + if not groups: raise osv.except_osv(_('Error'), _("""You have to specify a filter for your @@ -536,7 +536,7 @@ class MergePartnerAutomatic(osv.TransientModel): }) this.write(values) - + return { 'type': 'ir.actions.act_window', 'res_model': this._name, @@ -628,7 +628,7 @@ class MergePartnerAutomatic(osv.TransientModel): groups = self._compute_selected_groupby(this) query = self._generate_query(groups, this.maximum_group) self._process_query(cr, uid, ids, query, context=context) - + return self._next_screen(cr, uid, this, context) def automatic_process_cb(self, cr, uid, ids, context=None): @@ -773,12 +773,16 @@ class MergePartnerAutomatic(osv.TransientModel): return self._next_screen(cr, uid, this, context) + def merge_pbp(self, cr, uid, partner_ids, dst_partner_id, context=None): + self._merge(cr, uid, partner_ids, dst_partner_id, context=context) + return True + def merge_cb(self, cr, uid, ids, context=None): assert is_integer_list(ids) context = dict(context or {}, active_test=False) this = self.browse(cr, uid, ids[0], context=context) - + partner_ids = set(map(int, this.partner_ids)) if not partner_ids: this.write({'state': 'finished'}) diff --git a/partner_do_merge/wizard/merge_by_partner.py b/partner_do_merge/wizard/merge_by_partner.py new file mode 100644 index 000000000..77dd4894c --- /dev/null +++ b/partner_do_merge/wizard/merge_by_partner.py @@ -0,0 +1,65 @@ +# -*- 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 . +# +############################################################################## +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) + 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 + + diff --git a/partner_do_merge/wizard/merge_by_partner.xml b/partner_do_merge/wizard/merge_by_partner.xml new file mode 100644 index 000000000..efbad65de --- /dev/null +++ b/partner_do_merge/wizard/merge_by_partner.xml @@ -0,0 +1,36 @@ + + + + + view.merge.partner.by.partner.wizard + wizard.merge.partner.by.partner + +
+ + + + + + + + +
+
+
+
+
+ + + +
+