diff --git a/addons/snailmail/models/snailmail_letter.py b/addons/snailmail/models/snailmail_letter.py index bb05177535de9e145302e49e2612c3a095a2c3e5..d594d380d50ff69098dcf36ef53b9ed4d1de84d1 100644 --- a/addons/snailmail/models/snailmail_letter.py +++ b/addons/snailmail/models/snailmail_letter.py @@ -199,6 +199,14 @@ class SnailmailLetter(models.Model): documents = [] for letter in self: + recipient_name = letter.partner_id.name or letter.partner_id.parent_id and letter.partner_id.parent_id.name + if not recipient_name: + letter.write({ + 'info_msg': _('Invalid recipient name.'), + 'state': 'error', + 'error_code': 'MISSING_REQUIRED_FIELDS' + }) + continue document = { # generic informations to send 'letter_id': letter.id, @@ -206,7 +214,7 @@ class SnailmailLetter(models.Model): 'res_id': letter.res_id, 'contact_address': letter.partner_id.with_context(snailmail_layout=True, show_address=True).name_get()[0][1], 'address': { - 'name': letter.partner_id.name, + 'name': recipient_name, 'street': letter.partner_id.street, 'street2': letter.partner_id.street2, 'zip': letter.partner_id.zip, @@ -414,7 +422,9 @@ class SnailmailLetter(models.Model): return failures_infos def _append_cover_page(self, invoice_bin: bytes): - address = self.partner_id.with_context(show_address=True, lang='en_US')._get_name().replace('\n', '<br/>') + address_split = self.partner_id.with_context(show_address=True, lang='en_US')._get_name().split('\n') + address_split[0] = self.partner_id.name or self.partner_id.parent_id and self.partner_id.parent_id.name or address_split[0] + address = '<br/>'.join(address_split) address_x = 118 * mm address_y = 60 * mm frame_width = 85.5 * mm