From b93d45c2aedb5bc02785c161cd421adcee7e28da Mon Sep 17 00:00:00 2001 From: Maximiliano Mezzavilla Date: Wed, 4 Oct 2023 10:12:29 -0300 Subject: [PATCH] [ADD] l10n_uy_edi: Descuentos globales Tarea: 33936 --- l10n_uy_edi/__manifest__.py | 2 +- l10n_uy_edi/data/cfe_template.xml | 11 +++++++++++ l10n_uy_edi/models/l10n_uy_cfe.py | 32 +++++++++++++++++++++++++++++++ 3 files changed, 44 insertions(+), 1 deletion(-) diff --git a/l10n_uy_edi/__manifest__.py b/l10n_uy_edi/__manifest__.py index 61f7d57d..577353b7 100644 --- a/l10n_uy_edi/__manifest__.py +++ b/l10n_uy_edi/__manifest__.py @@ -7,7 +7,7 @@ 'author': 'ADHOC SA', 'category': 'Localization', 'license': 'LGPL-3', - 'version': "16.0.1.6.0", + 'version': "16.0.1.7.0", 'depends': [ 'l10n_uy_account', 'account_debit_note', diff --git a/l10n_uy_edi/data/cfe_template.xml b/l10n_uy_edi/data/cfe_template.xml index da433bba..0821d588 100644 --- a/l10n_uy_edi/data/cfe_template.xml +++ b/l10n_uy_edi/data/cfe_template.xml @@ -77,6 +77,17 @@ + + + + + + + + + + + diff --git a/l10n_uy_edi/models/l10n_uy_cfe.py b/l10n_uy_edi/models/l10n_uy_cfe.py index b5d0efd5..fb7d596a 100644 --- a/l10n_uy_edi/models/l10n_uy_cfe.py +++ b/l10n_uy_edi/models/l10n_uy_cfe.py @@ -923,6 +923,38 @@ def _l10n_uy_create_cfe(self): return {'cfe_str': cfe} + def _get_discount_of_lines(self): + #retorna el descuento total de las lineas de descuento globales + descuento = 0.0 + descGloblal = self.line_ids.filtered(lambda x: x.price_unit < 0) + for desc in descGloblal: + descuento = descuento + desc.price_unit + return descuento + + def _l10n_uy_get_cfe_discount(self): + values = [] + for line in self.line_ids.filtered(lambda x: x.price_unit < 0): + item = {} + item.update ({ + 'NroLinDR': line.discount, + 'TpoMovDR': 'D', #TODO por ahora solo implementemamos descuentos + 'TpoDR': 2, #Nosotros tenemos descuentos (en la linea) solo por porcentaje + 'CodDR': False, #preguntar si implementar o no + 'GlosaDR': line.name, #descripcion del descuento, usamos directamente la descripcion + 'ValorDR': line.sequence, + 'IndFactDR': False, #este campo es obligatorio y tengo dudas + }) + values.append(item) + return values + + def uy_cfe_D6_ValorDR(self): + ValorDR = self.discount or 0 #revisar bien el valor ya que es en porcentaje + return ValorDR + + def uy_cfe_D1_NroLinDR(self): + NroLinDR = self.sequence or 1 #nosotros no tenemos una linea de descuento en si + return NroLinDR + def _uy_get_cfe_lines(self): self.ensure_one() if self._is_uy_inv_type_cfe():