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.

52 lines
2.1 KiB

  1. # -*- coding: utf-8 -*-
  2. # Copyright 2015-2017 Camptocamp SA
  3. # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
  4. from odoo import api, fields, models
  5. class ResPartner(models.Model):
  6. _inherit = 'res.partner'
  7. changeset_ids = fields.One2many(comodel_name='res.partner.changeset',
  8. inverse_name='partner_id',
  9. string='Changesets',
  10. readonly=True)
  11. count_pending_changesets = fields.Integer(
  12. string='Changes',
  13. compute='_count_pending_changesets',
  14. search='_search_count_pending_changesets')
  15. @api.depends('changeset_ids', 'changeset_ids.state')
  16. def _count_pending_changesets(self):
  17. for rec in self:
  18. changesets = rec.changeset_ids.filtered(
  19. lambda rev: rev.state == 'draft' and rev.partner_id == rec
  20. )
  21. rec.count_pending_changesets = len(changesets)
  22. @api.multi
  23. def write(self, values):
  24. if (self.env.context.get('__no_changeset') or
  25. self.env.context.get('test_enable') and
  26. not self.env.context.get('test_partner_changeset')):
  27. return super(ResPartner, self).write(values)
  28. else:
  29. changeset_model = self.env['res.partner.changeset']
  30. for record in self:
  31. local_values = changeset_model.add_changeset(record, values)
  32. super(ResPartner, record).write(local_values)
  33. return True
  34. def _search_count_pending_changesets(self, operator, value):
  35. if operator not in ('=', '!=', '<', '<=', '>', '>=', 'in', 'not in'):
  36. return []
  37. query = ("SELECT p.id "
  38. "FROM res_partner p "
  39. "INNER JOIN res_partner_changeset r ON r.partner_id = p.id "
  40. "WHERE r.state = 'draft' "
  41. "GROUP BY p.id "
  42. "HAVING COUNT(r.id) %s %%s ") % operator
  43. self.env.cr.execute(query, (value,))
  44. ids = [row[0] for row in self.env.cr.fetchall()]
  45. return [('id', 'in', ids)]