Browse Source

[FIX] partner_second_lastname: False value should be set on lastname2

not firstname

before this commit the following error happen:
name = 'Van-Eyck Jan'

this was converted to

firstname = False
lastname= 'Van-Eyck'
lastname2 = 'Jan'

and it should be like

firstname = 'Jan'
lastname= 'Van-Eyck'
lastname2 = False
14.0
Hugo Adan 4 years ago
committed by Luis Torres
parent
commit
5b6013018b
  1. 2
      partner_second_lastname/__manifest__.py
  2. 48
      partner_second_lastname/models/res_partner.py
  3. 20
      partner_second_lastname/tests/test_name.py

2
partner_second_lastname/__manifest__.py

@ -6,7 +6,7 @@
{ {
"name": "Partner second last name", "name": "Partner second last name",
"summary": "Have split first and second lastnames", "summary": "Have split first and second lastnames",
"version": "13.0.1.0.0",
"version": "13.0.2.0.0",
"license": "AGPL-3", "license": "AGPL-3",
"website": "https://github.com/OCA/partner-contact", "website": "https://github.com/OCA/partner-contact",
"author": "Tecnativa, " "Odoo Community Association (OCA)", "author": "Tecnativa, " "Odoo Community Association (OCA)",

48
partner_second_lastname/models/res_partner.py

@ -70,32 +70,46 @@ class ResPartner(models.Model):
- If the partner is a company, save it in the lastname. - If the partner is a company, save it in the lastname.
- Otherwise, make a guess. - Otherwise, make a guess.
""" """
# Company name goes to the lastname
result = { result = {
"firstname": False, "firstname": False,
"lastname": name or False, "lastname": name or False,
"lastname2": False, "lastname2": False,
} }
if not is_company and name:
# Company name goes to the lastname
if not name or is_company:
return result
order = self._get_names_order() order = self._get_names_order()
result = super(ResPartner, self)._get_inverse_name(name, is_company)
parts = []
if order == "last_first":
if result["firstname"]:
parts = result["firstname"].split(" ", 1)
while len(parts) < 2:
parts.append(False)
result["lastname2"] = parts[0]
result["firstname"] = parts[1]
result.update(super(ResPartner, self)._get_inverse_name(name, is_company))
if order in ("first_last", "last_first_comma"):
parts = self._split_part("lastname", result)
if parts:
result.update({"lastname": parts[0], "lastname2": u" ".join(parts[1:])})
else: else:
if result["lastname"]:
parts = result["lastname"].split(" ", 1)
while len(parts) < 2:
parts.append(False)
result["lastname"] = parts[0]
result["lastname2"] = parts[1]
parts = self._split_part("firstname", result)
if parts:
result.update(
{"firstname": parts[-1], "lastname2": u" ".join(parts[:-1])}
)
return result return result
def _split_part(self, name_part, name_split):
"""Split a given part of a name.
:param name_split: The parts of the name
:type dict
:param name_part: The part to split
:type str
"""
name = name_split.get(name_part, False)
parts = name.split(" ", 1) if name else []
if not name or len(parts) < 2:
return False
return parts
@api.constrains("firstname", "lastname", "lastname2") @api.constrains("firstname", "lastname", "lastname2")
def _check_name(self): def _check_name(self):
"""Ensure at least one name is set.""" """Ensure at least one name is set."""

20
partner_second_lastname/tests/test_name.py

@ -128,6 +128,15 @@ class PersonCase(TransactionCase):
"name": "{} {}, {}".format(self.lastname, self.lastname2, self.firstname), "name": "{} {}, {}".format(self.lastname, self.lastname2, self.firstname),
} }
def test_firstname_last_wo_comma(self):
"""Create a person setting his first name last and the order as 'last_first'"""
self.env["ir.config_parameter"].set_param("partner_names_order", "last_first")
self.template = "%(last1)s %(last2)s %(first)s"
self.params = {
"is_company": False,
"name": "{} {} {}".format(self.lastname, self.lastname2, self.firstname),
}
def test_firstname_only(self): def test_firstname_only(self):
"""Create a person setting his first name only.""" """Create a person setting his first name only."""
self.env["ir.config_parameter"].set_param("partner_names_order", "first_last") self.env["ir.config_parameter"].set_param("partner_names_order", "first_last")
@ -157,6 +166,17 @@ class PersonCase(TransactionCase):
"name": "{}, {}".format(self.lastname, self.firstname), "name": "{}, {}".format(self.lastname, self.firstname),
} }
def test_lastname_firstname_only_wo_comma(self):
"""Create a person setting his last name 1 and first name only.
Set order to 'last_first' to test name split without comma"""
self.env["ir.config_parameter"].set_param("partner_names_order", "last_first")
self.lastname2 = False
self.template = "%(last1)s %(first)s"
self.params = {
"is_company": False,
"name": "{} {}".format(self.lastname, self.firstname),
}
def test_separately(self): def test_separately(self):
"""Create a person setting separately all fields.""" """Create a person setting separately all fields."""
self.params = { self.params = {

Loading…
Cancel
Save