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.

31 lines
1.3 KiB

  1. # Copyright 2016 Tecnativa - Pedro M. Baeza
  2. # License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html).
  3. from odoo import fields, models
  4. class BasePartnerMergeAutomaticWizard(models.TransientModel):
  5. _inherit = "base.partner.merge.automatic.wizard"
  6. exclude_is_company = fields.Boolean("'Is a company?' field selected")
  7. exclude_not_parent = fields.Boolean("Parent company not set")
  8. exclude_parent = fields.Boolean("Parent company set (Contacts)")
  9. def _process_query(self, query):
  10. if any([self.exclude_is_company, self.exclude_not_parent, self.exclude_parent]):
  11. filters = []
  12. if self.exclude_is_company:
  13. filters.append("is_company = False")
  14. if self.exclude_not_parent:
  15. filters.append("parent_id IS NOT NULL")
  16. if self.exclude_parent:
  17. filters.append("parent_id IS NULL")
  18. index_where = query.find("WHERE")
  19. index_group_by = query.find("GROUP BY")
  20. subquery = "%s" % " AND ".join(filters)
  21. if index_where > 0:
  22. subquery = "AND (%s) " % subquery
  23. else: # pragma: no cover
  24. subquery = "WHERE %s " % subquery
  25. query = query[:index_group_by] + subquery + query[index_group_by:]
  26. return super()._process_query(query)