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.
34 lines
1.4 KiB
34 lines
1.4 KiB
# Copyright 2016 Pedro M. Baeza <pedro.baeza@tecnativa.com>
|
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
|
|
|
|
from odoo import api, fields, models
|
|
|
|
|
|
class BasePartnerMergeAutomaticWizard(models.TransientModel):
|
|
_inherit = "base.partner.merge.automatic.wizard"
|
|
|
|
exclude_is_company = fields.Boolean("'Is a company?' field selected")
|
|
exclude_not_parent = fields.Boolean("Parent company not set")
|
|
exclude_parent = fields.Boolean("Parent company set (Contacts)")
|
|
|
|
@api.multi
|
|
def _process_query(self, query):
|
|
if any([self.exclude_is_company, self.exclude_not_parent,
|
|
self.exclude_parent]):
|
|
filters = []
|
|
if self.exclude_is_company:
|
|
filters.append("is_company = False")
|
|
if self.exclude_not_parent:
|
|
filters.append("parent_id IS NOT NULL")
|
|
if self.exclude_parent:
|
|
filters.append("parent_id IS NULL")
|
|
index_where = query.find('WHERE')
|
|
index_group_by = query.find('GROUP BY')
|
|
subquery = "%s" % ' AND '.join(filters)
|
|
if index_where > 0:
|
|
subquery = "AND (%s) " % subquery
|
|
else: # pragma: no cover
|
|
subquery = "WHERE %s " % subquery
|
|
query = query[:index_group_by] + subquery + query[index_group_by:]
|
|
return super(BasePartnerMergeAutomaticWizard, self)._process_query(
|
|
query)
|