mirror of
https://gitlab.com/flectra-community/partner-contact.git
synced 2024-11-15 02:32:04 +00:00
75 lines
2.6 KiB
Python
75 lines
2.6 KiB
Python
|
# Copyright 2004-2009 Tiny SPRL (<https://tiny.be>).
|
||
|
# Copyright 2013 initOS GmbH & Co. KG (<https://www.initos.com>).
|
||
|
# Copyright 2016 Tecnativa - Vicent Cubells
|
||
|
# Copyright 2016 Camptocamp - Akim Juillerat (<https://www.camptocamp.com>).
|
||
|
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html).
|
||
|
|
||
|
from flectra import _, api, exceptions, models
|
||
|
|
||
|
|
||
|
class ResPartner(models.Model):
|
||
|
"""Assigns 'ref' from a sequence on creation and copying"""
|
||
|
|
||
|
_inherit = "res.partner"
|
||
|
|
||
|
def _get_next_ref(self, vals=None):
|
||
|
return self.env["ir.sequence"].next_by_code("res.partner")
|
||
|
|
||
|
@api.model_create_multi
|
||
|
def create(self, vals_list):
|
||
|
for vals in vals_list:
|
||
|
if not vals.get("ref") and self._needs_ref(vals=vals):
|
||
|
vals["ref"] = self._get_next_ref(vals=vals)
|
||
|
return super().create(vals_list)
|
||
|
|
||
|
def copy(self, default=None):
|
||
|
default = default or {}
|
||
|
if self._needs_ref():
|
||
|
default["ref"] = self._get_next_ref()
|
||
|
return super().copy(default=default)
|
||
|
|
||
|
def write(self, vals):
|
||
|
for partner in self:
|
||
|
partner_vals = vals.copy()
|
||
|
if (
|
||
|
not partner_vals.get("ref")
|
||
|
and partner._needs_ref(vals=partner_vals)
|
||
|
and not partner.ref
|
||
|
):
|
||
|
partner_vals["ref"] = partner._get_next_ref(vals=partner_vals)
|
||
|
super(ResPartner, partner).write(partner_vals)
|
||
|
return True
|
||
|
|
||
|
def _needs_ref(self, vals=None):
|
||
|
"""
|
||
|
Checks whether a sequence value should be assigned to a partner's 'ref'
|
||
|
|
||
|
:param vals: known field values of the partner object
|
||
|
:return: true iff a sequence value should be assigned to the\
|
||
|
partner's 'ref'
|
||
|
"""
|
||
|
if not vals and not self: # pragma: no cover
|
||
|
raise exceptions.UserError(
|
||
|
_("Either field values or an id must be provided.")
|
||
|
)
|
||
|
# only assign a 'ref' to commercial partners
|
||
|
fields_for_check = ["is_company", "parent_id"]
|
||
|
# Copy original vals to prevent modifying them
|
||
|
if vals:
|
||
|
vals_for_check = vals.copy()
|
||
|
else:
|
||
|
vals_for_check = {}
|
||
|
if self:
|
||
|
for field in fields_for_check:
|
||
|
if field not in vals_for_check:
|
||
|
vals_for_check[field] = self[field]
|
||
|
return vals_for_check.get("is_company") or not vals_for_check.get("parent_id")
|
||
|
|
||
|
@api.model
|
||
|
def _commercial_fields(self):
|
||
|
"""
|
||
|
Make the partner reference a field that is propagated
|
||
|
to the partner's contacts
|
||
|
"""
|
||
|
return super()._commercial_fields() + ["ref"]
|