Browse Source

[ADD][partner_do_merge]Added wizard for merge partner by partner

pull/2/head
Luis Tores 12 years ago
parent
commit
8845e671c2
  1. 1
      partner_do_merge/__openerp__.py
  2. 1
      partner_do_merge/wizard/__init__.py
  3. 27
      partner_do_merge/wizard/base_partner_merge.py
  4. 67
      partner_do_merge/wizard/merge_by_partner.py
  5. 36
      partner_do_merge/wizard/merge_by_partner.xml

1
partner_do_merge/__openerp__.py

@ -50,6 +50,7 @@ created an action menu in the partner view
], ],
'data': [ 'data': [
'wizard/base_partner_merge_view.xml', 'wizard/base_partner_merge_view.xml',
'wizard/merge_by_partner.xml',
], ],
'js': [ 'js': [
], ],

1
partner_do_merge/wizard/__init__.py

@ -1 +1,2 @@
import base_partner_merge import base_partner_merge
import merge_by_partner

27
partner_do_merge/wizard/base_partner_merge.py

@ -312,7 +312,7 @@ class MergePartnerAutomatic(osv.TransientModel):
dst_partner.id) dst_partner.id)
@mute_logger('openerp.osv.expression', 'openerp.osv.orm') @mute_logger('openerp.osv.expression', 'openerp.osv.orm')
def _merge(self, cr, uid, partner_ids, dst_partner=None, context=None):
def _merge(self, cr, uid, partner_ids, dst_partner=None, remove=None,context=None):
proxy = self.pool.get('res.partner') proxy = self.pool.get('res.partner')
partner_ids = proxy.exists(cr, uid, list(partner_ids), context=context) partner_ids = proxy.exists(cr, uid, list(partner_ids), context=context)
@ -375,9 +375,13 @@ class MergePartnerAutomatic(osv.TransientModel):
", ".join('%s<%s>(ID %s)' % ", ".join('%s<%s>(ID %s)' %
(p.name, p.email or 'n/a', p.id) for p in (p.name, p.email or 'n/a', p.id) for p in
src_partners))) src_partners)))
for partner in src_partners:
partner.unlink()
if remove == False:
for partner in src_partners:
partner.write({'active' : False})
else:
for partner in src_partners:
partner.unlink()
def clean_emails(self, cr, uid, context=None): def clean_emails(self, cr, uid, context=None):
""" """
@ -478,13 +482,13 @@ class MergePartnerAutomatic(osv.TransientModel):
for key in self._columns.keys() for key in self._columns.keys()
if key.startswith(group_by_str) if key.startswith(group_by_str)
] ]
groups = [ groups = [
field field
for field in fields for field in fields
if getattr(this, '%s%s' % (group_by_str, field), False) if getattr(this, '%s%s' % (group_by_str, field), False)
] ]
if not groups: if not groups:
raise osv.except_osv(_('Error'), raise osv.except_osv(_('Error'),
_("""You have to specify a filter for your _("""You have to specify a filter for your
@ -536,7 +540,7 @@ class MergePartnerAutomatic(osv.TransientModel):
}) })
this.write(values) this.write(values)
return { return {
'type': 'ir.actions.act_window', 'type': 'ir.actions.act_window',
'res_model': this._name, 'res_model': this._name,
@ -628,7 +632,7 @@ class MergePartnerAutomatic(osv.TransientModel):
groups = self._compute_selected_groupby(this) groups = self._compute_selected_groupby(this)
query = self._generate_query(groups, this.maximum_group) query = self._generate_query(groups, this.maximum_group)
self._process_query(cr, uid, ids, query, context=context) self._process_query(cr, uid, ids, query, context=context)
return self._next_screen(cr, uid, this, context) return self._next_screen(cr, uid, this, context)
def automatic_process_cb(self, cr, uid, ids, context=None): def automatic_process_cb(self, cr, uid, ids, context=None):
@ -773,12 +777,17 @@ class MergePartnerAutomatic(osv.TransientModel):
return self._next_screen(cr, uid, this, context) 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, False,\
context=context)
return True
def merge_cb(self, cr, uid, ids, context=None): def merge_cb(self, cr, uid, ids, context=None):
assert is_integer_list(ids) assert is_integer_list(ids)
context = dict(context or {}, active_test=False) context = dict(context or {}, active_test=False)
this = self.browse(cr, uid, ids[0], context=context) this = self.browse(cr, uid, ids[0], context=context)
partner_ids = set(map(int, this.partner_ids)) partner_ids = set(map(int, this.partner_ids))
if not partner_ids: if not partner_ids:
this.write({'state': 'finished'}) this.write({'state': 'finished'})

67
partner_do_merge/wizard/merge_by_partner.py

@ -0,0 +1,67 @@
# -*- 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]})
return True

36
partner_do_merge/wizard/merge_by_partner.xml

@ -0,0 +1,36 @@
<openerp>
<data>
<record model="ir.ui.view" id="view_merge_parter_by_partner_wizard">
<field name="name">view.merge.partner.by.partner.wizard</field>
<field name="model">wizard.merge.partner.by.partner</field>
<field name="arch" type="xml">
<form string="Merge Parners" version="7.0">
<group>
<field name='partner_id'/>
<field name='partner_ids'>
<tree string="Partners to Merge">
<field name="name"/>
</tree>
</field>
</group>
<footer>
<button name="merge_cb" type="object" string="Merge" class="oe_highlight"/>
or
<button name="action_skip" type="object" special="cancel" string="Cancel" class="oe_link"/>
</footer>
</form>
</field>
</record>
<act_window id="merge_parter_by_partner_wizard"
name="Merge Partners"
src_model="res.partner"
res_model="wizard.merge.partner.by.partner"
view_mode="form"
target="new"
key2="client_action_multi"
/>
</data>
</openerp>
Loading…
Cancel
Save