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 @@
-
-
-
-
-
-
-
-