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.

69 lines
2.3 KiB

9 years ago
9 years ago
9 years ago
9 years ago
9 years ago
9 years ago
9 years ago
9 years ago
9 years ago
9 years ago
9 years ago
  1. # -*- coding: utf-8 -*-
  2. # © 2004-2009 Tiny SPRL (<http://tiny.be>).
  3. # © 2013 initOS GmbH & Co. KG (<http://www.initos.com>).
  4. # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
  5. from openerp import models, api
  6. class ResPartner(models.Model):
  7. """Assigns 'ref' from a sequence on creation and copying"""
  8. _inherit = 'res.partner'
  9. @api.model
  10. def _needsRef(self, partner_id=None, vals=None):
  11. """
  12. Checks whether a sequence value should be assigned to a partner's 'ref'
  13. :param parnter_id: id of the partner object
  14. :param vals: known field values of the partner object
  15. :return: true iff a sequence value should be assigned to the\
  16. partner's 'ref'
  17. """
  18. if not vals and not partner_id:
  19. raise Exception('Either field values or an id must be provided.')
  20. vals = vals or {}
  21. # only assign a 'ref' to commercial partners
  22. if partner_id:
  23. partner = self.browse(partner_id)
  24. vals.setdefault('is_company', partner.is_company)
  25. vals.setdefault('parent_id', partner.parent_id.id)
  26. return vals.get('is_company') or not vals.get('parent_id')
  27. @api.model
  28. def _commercial_fields(self):
  29. """
  30. Make the partner reference a field that is propagated
  31. to the partner's contacts
  32. """
  33. return super(ResPartner, self)._commercial_fields() + ['ref']
  34. @api.model
  35. def _get_next_ref(self, partner=None, vals=None):
  36. return self.env['ir.sequence'].get('res.partner')
  37. @api.model
  38. def create(self, vals):
  39. if not vals.get('ref') and self._needsRef(vals=vals):
  40. vals['ref'] = self._get_next_ref(vals=vals)
  41. return super(ResPartner, self).create(vals)
  42. @api.multi
  43. def write(self, vals):
  44. for partner in self:
  45. ref = vals.get('ref') if 'ref' in vals else partner.ref
  46. if not ref and self._needsRef(partner.id, vals):
  47. vals['ref'] = self._get_next_ref(partner, vals)
  48. super(ResPartner, partner).write(vals)
  49. return True
  50. @api.one
  51. def copy(self, default=None):
  52. default = default or {}
  53. if self._needsRef(self.id):
  54. default.update({
  55. 'ref': self._get_next_ref(),
  56. })
  57. return super(ResPartner, self).copy(default)