diff --git a/l10n_br_fiscal/__manifest__.py b/l10n_br_fiscal/__manifest__.py index 186e88e2d719..42ac3d0e6460 100644 --- a/l10n_br_fiscal/__manifest__.py +++ b/l10n_br_fiscal/__manifest__.py @@ -10,7 +10,7 @@ "maintainers": ["renatonlima"], "website": "https://github.com/OCA/l10n-brazil", "development_status": "Production/Stable", - "version": "14.0.23.11.0", + "version": "14.0.24.0.0", "depends": [ "product", "l10n_br_base", diff --git a/l10n_br_fiscal/data/ibpt_data.xml b/l10n_br_fiscal/data/ibpt_data.xml new file mode 100644 index 000000000000..59eef07022e0 --- /dev/null +++ b/l10n_br_fiscal/data/ibpt_data.xml @@ -0,0 +1,7 @@ + + + + ibpt_request_timeout + 299 + + diff --git a/l10n_br_fiscal/migrations/14.0.24.0.0/post-migration.py b/l10n_br_fiscal/migrations/14.0.24.0.0/post-migration.py new file mode 100644 index 000000000000..2a38fa417f44 --- /dev/null +++ b/l10n_br_fiscal/migrations/14.0.24.0.0/post-migration.py @@ -0,0 +1,8 @@ +from openupgradelib import openupgrade + + +@openupgrade.migrate() +def migrate(env, version): + openupgrade.delete_records_safely_by_xml_id( + env, ["l10n_br_fiscal.l10n_br_fiscal_tax_estimate_rule"] + ) diff --git a/l10n_br_fiscal/models/data_ncm_nbs_abstract.py b/l10n_br_fiscal/models/data_ncm_nbs_abstract.py index 94c558403648..28f3f4e88592 100644 --- a/l10n_br_fiscal/models/data_ncm_nbs_abstract.py +++ b/l10n_br_fiscal/models/data_ncm_nbs_abstract.py @@ -31,47 +31,32 @@ class DataNcmNbsAbstract(models.AbstractModel): readonly=True, ) - estimate_tax_national = fields.Float( - string="Estimate Tax Nacional Percent", - store=True, - readonly=True, - digits="Fiscal Tax Percent", - compute="_compute_amount", - ) - - estimate_tax_imported = fields.Float( - string="Estimate Tax Imported Percent", - store=True, - readonly=True, - digits="Fiscal Tax Percent", - compute="_compute_amount", - ) + def get_estimated_taxes(self): + self.ensure_one() + object_field = OBJECT_FIELDS.get(self._name) + last_estimated = self.env["l10n_br_fiscal.tax.estimate"].search( + [ + (object_field, "=", self.id), + ("state_id", "=", self.env.company.state_id.id), + ], + order="create_date DESC", + limit=1, + ) - @api.depends("tax_estimate_ids") - def _compute_amount(self): - for record in self: - object_field = OBJECT_FIELDS.get(record._name) - last_estimated = record.env["l10n_br_fiscal.tax.estimate"].search( - [ - (object_field, "=", record.id), - ("company_id", "=", record.env.company.id), - ], - order="create_date DESC", - limit=1, + if last_estimated: + estimate_tax_imported = ( + last_estimated.federal_taxes_import + + last_estimated.state_taxes + + last_estimated.municipal_taxes ) - - if last_estimated: - record.estimate_tax_imported = ( - last_estimated.federal_taxes_import - + last_estimated.state_taxes - + last_estimated.municipal_taxes - ) - - record.estimate_tax_national = ( - last_estimated.federal_taxes_national - + last_estimated.state_taxes - + last_estimated.municipal_taxes - ) + estimate_tax_national = ( + last_estimated.federal_taxes_national + + last_estimated.state_taxes + + last_estimated.municipal_taxes + ) + return estimate_tax_national, estimate_tax_imported + else: + return 0, 0 def _get_ibpt(self, config, code_unmasked): return False diff --git a/l10n_br_fiscal/models/tax.py b/l10n_br_fiscal/models/tax.py index 1a583402aa80..60bf34506292 100644 --- a/l10n_br_fiscal/models/tax.py +++ b/l10n_br_fiscal/models/tax.py @@ -320,17 +320,19 @@ def _compute_estimate_taxes(self, **kwargs): and op_line.fiscal_operation_id.fiscal_type == "sale" ): if nbs: + estimate_tax_national, estimate_tax_imported = nbs.get_estimated_taxes() amount_estimate_tax = currency.round( - amount_total * (nbs.estimate_tax_national / 100) + amount_total * (estimate_tax_national / 100) ) elif ncm: + estimate_tax_national, estimate_tax_imported = ncm.get_estimated_taxes() if icms_origin in ICMS_ORIGIN_TAX_IMPORTED: amount_estimate_tax = currency.round( - amount_total * (ncm.estimate_tax_imported / 100) + amount_total * (estimate_tax_imported / 100) ) else: amount_estimate_tax = currency.round( - amount_total * (ncm.estimate_tax_national / 100) + amount_total * (estimate_tax_national / 100) ) return amount_estimate_tax diff --git a/l10n_br_fiscal/models/tax_estimate.py b/l10n_br_fiscal/models/tax_estimate.py index 5e7844183017..059272cf018e 100644 --- a/l10n_br_fiscal/models/tax_estimate.py +++ b/l10n_br_fiscal/models/tax_estimate.py @@ -1,7 +1,7 @@ # Copyright (C) 2012 Renato Lima - Akretion # License AGPL-3 - See http://www.gnu.org/licenses/agpl-3.0.html -from odoo import fields, models +from odoo import api, fields, models class TaxEstimate(models.Model): @@ -43,8 +43,22 @@ class TaxEstimate(models.Model): origin = fields.Char(string="Source", size=32) - company_id = fields.Many2one( - comodel_name="res.company", - string="Company", - default=lambda self: self.env.company, - ) + active = fields.Boolean(string="Ativo", default=True) + + def _deactivate_old_estimates(self): + for estimate in self: + domain = [ + ("id", "!=", estimate.id), + ("state_id", "=", estimate.state_id.id), + "|", + ("ncm_id", "=", estimate.ncm_id.id), + ("nbs_id", "=", estimate.nbs_id.id), + ] + old_estimates = self.search(domain) + old_estimates.write({"active": False}) + + @api.model_create_multi + def create(self, vals_list): + estimates = super().create(vals_list) + estimates._deactivate_old_estimates() + return estimates diff --git a/l10n_br_fiscal/security/fiscal_security.xml b/l10n_br_fiscal/security/fiscal_security.xml index c5a50459655e..f457135a5857 100644 --- a/l10n_br_fiscal/security/fiscal_security.xml +++ b/l10n_br_fiscal/security/fiscal_security.xml @@ -36,9 +36,7 @@ Fiscal Tax Estimate multi-company - ['|',('company_id','=',False),('company_id','in',company_ids)] + [] diff --git a/l10n_br_fiscal/views/nbs_view.xml b/l10n_br_fiscal/views/nbs_view.xml index 7836e105d19b..bc5777da17ea 100644 --- a/l10n_br_fiscal/views/nbs_view.xml +++ b/l10n_br_fiscal/views/nbs_view.xml @@ -98,14 +98,6 @@ - - - - - - - - diff --git a/l10n_br_fiscal/views/ncm_view.xml b/l10n_br_fiscal/views/ncm_view.xml index d124c31121d5..32da2a09fdd2 100644 --- a/l10n_br_fiscal/views/ncm_view.xml +++ b/l10n_br_fiscal/views/ncm_view.xml @@ -150,14 +150,6 @@ - - - - - - - -