Skip to content

Commit

Permalink
[FIX] account_invoice_ubl: Fix CreditNote
Browse files Browse the repository at this point in the history
A credit note must follow a dedicated schema
  • Loading branch information
jbaudoux committed Dec 20, 2023
1 parent 1c5b2a8 commit 93fa0e2
Showing 1 changed file with 28 additions and 9 deletions.
37 changes: 28 additions & 9 deletions account_invoice_ubl/models/account_move.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,10 @@ def _ubl_add_header(self, parent_node, ns, version="2.1"):
if self.invoice_date_due and version >= "2.1":
due_date = etree.SubElement(parent_node, ns["cbc"] + "DueDate")
due_date.text = fields.Date.to_string(self.invoice_date_due)
type_code = etree.SubElement(parent_node, ns["cbc"] + "InvoiceTypeCode")
if self.move_type == "out_invoice":
type_code = etree.SubElement(parent_node, ns["cbc"] + "InvoiceTypeCode")
elif self.move_type == "out_refund":
type_code = etree.SubElement(parent_node, ns["cbc"] + "CreditNoteTypeCode")
type_code.text = self._ubl_get_invoice_type_code()
if self.narration:
note = etree.SubElement(parent_node, ns["cbc"] + "Note")
Expand Down Expand Up @@ -247,21 +250,28 @@ def _ubl_add_invoice_line_discount(
def _ubl_add_invoice_line(self, parent_node, iline, line_number, ns, version="2.1"):
self.ensure_one()
cur_name = self.currency_id.name
line_root = etree.SubElement(parent_node, ns["cac"] + "InvoiceLine")
if self.move_type == "out_invoice":
line_root = etree.SubElement(parent_node, ns["cac"] + "InvoiceLine")
elif self.move_type == "out_refund":
line_root = etree.SubElement(parent_node, ns["cac"] + "CreditNoteLine")
dpo = self.env["decimal.precision"]
qty_precision = dpo.precision_get("Product Unit of Measure")
account_precision = self.currency_id.decimal_places
line_id = etree.SubElement(line_root, ns["cbc"] + "ID")
line_id.text = str(line_number)
uom_unece_code = False
# product_uom_id is not a required field on account.move.line
if self.move_type == "out_invoice":
qty_element_name = "InvoicedQuantity"
elif self.move_type == "out_refund":
qty_element_name = "CreditedQuantity"
if iline.product_uom_id.unece_code:
uom_unece_code = iline.product_uom_id.unece_code
quantity = etree.SubElement(
line_root, ns["cbc"] + "InvoicedQuantity", unitCode=uom_unece_code
line_root, ns["cbc"] + qty_element_name, unitCode=uom_unece_code
)
else:
quantity = etree.SubElement(line_root, ns["cbc"] + "InvoicedQuantity")
quantity = etree.SubElement(line_root, ns["cbc"] + qty_element_name)
qty = iline.quantity
quantity.text = "%0.*f" % (qty_precision, qty)
base_price, price_precision, base_qty = self._ubl_get_invoice_line_price_unit(
Expand All @@ -274,7 +284,6 @@ def _ubl_add_invoice_line(self, parent_node, iline, line_number, ns, version="2.
self._ubl_add_invoice_line_discount(
line_root, iline, base_price, base_qty, ns, version=version
)
self._ubl_add_invoice_line_tax_total(iline, line_root, ns, version=version)
self._ubl_add_item(
iline.name,
iline.product_id,
Expand Down Expand Up @@ -418,8 +427,12 @@ def _ubl_add_tax_total(self, xml_root, ns, version="2.1"):

def generate_invoice_ubl_xml_etree(self, version="2.1"):
self.ensure_one()
nsmap, ns = self._ubl_get_nsmap_namespace("Invoice-2", version=version)
xml_root = etree.Element("Invoice", nsmap=nsmap)
if self.move_type == "out_invoice":
nsmap, ns = self._ubl_get_nsmap_namespace("Invoice-2", version=version)
xml_root = etree.Element("Invoice", nsmap=nsmap)
elif self.move_type == "out_refund":
nsmap, ns = self._ubl_get_nsmap_namespace("CreditNote-2", version=version)
xml_root = etree.Element("CreditNote", nsmap=nsmap)
self._ubl_add_header(xml_root, ns, version=version)
if version == "2.1":
self._ubl_add_buyer_reference(xml_root, ns, version=version)
Expand Down Expand Up @@ -489,7 +502,10 @@ def generate_ubl_xml_string(self, version="2.1"):
xml_string = etree.tostring(
xml_root, pretty_print=True, encoding="UTF-8", xml_declaration=True
)
self._ubl_check_xml_schema(xml_string, "Invoice", version=version)
if self.move_type == "out_invoice":
self._ubl_check_xml_schema(xml_string, "Invoice", version=version)
elif self.move_type == "out_refund":
self._ubl_check_xml_schema(xml_string, "CreditNote", version=version)
logger.debug(
"Invoice UBL XML file generated for account invoice ID %d " "(state %s)",
self.id,
Expand All @@ -500,7 +516,10 @@ def generate_ubl_xml_string(self, version="2.1"):

def get_ubl_filename(self, version="2.1"):
"""This method is designed to be inherited"""
return "UBL-Invoice-%s.xml" % version
if self.move_type == "out_invoice":
return "UBL-Invoice-%s.xml" % version
elif self.move_type == "out_refund":
return "UBL-CreditNote-%s.xml" % version

def get_ubl_version(self):
return self.env.context.get("ubl_version") or "2.1"
Expand Down

0 comments on commit 93fa0e2

Please sign in to comment.