From 5ede092b865ee42f63f934f1b5f7144b96a3ed76 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fernanda=20Hern=C3=A1ndez?= Date: Wed, 4 Aug 2021 23:18:54 +0000 Subject: [PATCH] [REF] partner_firstname: Support duplicate multiple names Considering following name: firstname = Francisco Javier lastname = Garcia second_lastname = Cabeza de Vaca When duplicate: firstname = de Vaca Francisco Javier (copy) lastname = Garcia second_lastname = Cabeza It is inverted based on the 'name' and changed the order of the fields But when we are duplicating a contact we don't need to recompute the names since that it should be duplicated as it Video: https://youtu.be/CEFik5COK18 --- partner_firstname/models/res_partner.py | 12 +++++++++++- partner_firstname/tests/base.py | 7 +++++-- 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/partner_firstname/models/res_partner.py b/partner_firstname/models/res_partner.py index 0a62e0b61..83c541d9b 100644 --- a/partner_firstname/models/res_partner.py +++ b/partner_firstname/models/res_partner.py @@ -4,7 +4,7 @@ # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). import logging -from odoo import api, fields, models +from odoo import _, api, fields, models from .. import exceptions @@ -30,6 +30,12 @@ class ResPartner(models.Model): def create(self, vals): """Add inverted names at creation if unavailable.""" context = dict(self.env.context) + is_contact_copied = ( + context.get("copy") and vals.get("firstname") and not vals.get("is_company") + ) + if is_contact_copied and "name" in vals: + vals.pop("name", None) + context.pop("default_name", None) name = vals.get("name", context.get("default_name")) if name is not None: @@ -57,6 +63,10 @@ class ResPartner(models.Model): ignored in :meth:`~.create` because it also copies explicitly firstname and lastname fields. """ + if default is None: + default = {} + if self.firstname and not self.is_company: + default["firstname"] = _("%s (copy)", self.firstname) return super(ResPartner, self.with_context(copy=True)).copy(default) @api.model diff --git a/partner_firstname/tests/base.py b/partner_firstname/tests/base.py index 29dc7e205..de15e4bae 100644 --- a/partner_firstname/tests/base.py +++ b/partner_firstname/tests/base.py @@ -49,8 +49,11 @@ class BaseCase(TransactionCase, MailInstalled): def test_copy(self): """Copy the partner and compare the result.""" - self.expect("%s (copy)" % self.lastname, self.firstname) - self.changed = self.original.with_context(copy=True, lang="en_US").copy() + self.changed = self.original.with_context(lang="en_US").copy() + if self.changed.is_company: + self.expect("%s (copy)" % self.lastname, self.firstname) + else: + self.expect(self.lastname, "%s (copy)" % self.firstname) def test_one_name(self): """Test what happens when only one name is given."""