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.

67 lines
2.6 KiB

  1. # -*- coding: utf-8 -*-
  2. #
  3. #
  4. # Authors: Guewen Baconnier
  5. # Copyright 2015 Camptocamp SA
  6. #
  7. # This program is free software: you can redistribute it and/or modify
  8. # it under the terms of the GNU Affero General Public License as
  9. # published by the Free Software Foundation, either version 3 of the
  10. # License, or (at your option) any later version.
  11. #
  12. # This program is distributed in the hope that it will be useful,
  13. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. # GNU Affero General Public License for more details.
  16. #
  17. # You should have received a copy of the GNU Affero General Public License
  18. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  19. #
  20. #
  21. from openerp import models, fields, api
  22. class ResPartner(models.Model):
  23. _inherit = 'res.partner'
  24. changeset_ids = fields.One2many(comodel_name='res.partner.changeset',
  25. inverse_name='partner_id',
  26. string='Changesets',
  27. readonly=True)
  28. count_pending_changesets = fields.Integer(
  29. string='Pending Changesets',
  30. compute='_count_pending_changesets',
  31. search='_search_count_pending_changesets')
  32. @api.one
  33. @api.depends('changeset_ids', 'changeset_ids.state')
  34. def _count_pending_changesets(self):
  35. changesets = self.changeset_ids.filtered(
  36. lambda rev: rev.state == 'draft' and rev.partner_id == self
  37. )
  38. self.count_pending_changesets = len(changesets)
  39. @api.multi
  40. def write(self, values):
  41. if self.env.context.get('__no_changeset'):
  42. return super(ResPartner, self).write(values)
  43. else:
  44. changeset_model = self.env['res.partner.changeset']
  45. for record in self:
  46. local_values = changeset_model.add_changeset(record, values)
  47. super(ResPartner, record).write(local_values)
  48. return True
  49. def _search_count_pending_changesets(self, operator, value):
  50. if operator not in ('=', '!=', '<', '<=', '>', '>=', 'in', 'not in'):
  51. return []
  52. query = ("SELECT p.id "
  53. "FROM res_partner p "
  54. "INNER JOIN res_partner_changeset r ON r.partner_id = p.id "
  55. "WHERE r.state = 'draft' "
  56. "GROUP BY p.id "
  57. "HAVING COUNT(r.id) %s %%s ") % operator
  58. self.env.cr.execute(query, (value,))
  59. ids = [row[0] for row in self.env.cr.fetchall()]
  60. return [('id', 'in', ids)]