[FIX+IMP] account_chart_update: Create taxes in batch
With this, we gain some performance, but also prevent an error if there are template taxes that have children taxes, as Odoo standard method forces that in the same call all of them are created simultaneously, or it will enter in an infinite loop.
This commit is contained in:
parent
98fd1e8c65
commit
d8644c16a3
@ -868,18 +868,18 @@ class WizardUpdateChartsAccounts(models.TransientModel):
|
|||||||
|
|
||||||
def _update_taxes(self):
|
def _update_taxes(self):
|
||||||
"""Process taxes to create/update/deactivate."""
|
"""Process taxes to create/update/deactivate."""
|
||||||
for wiz_tax in self.tax_ids:
|
# First create taxes in batch
|
||||||
|
taxes_to_create = self.tax_ids.filtered(lambda x: x.type == "new")
|
||||||
|
taxes_to_create.mapped("tax_id")._generate_tax(self.company_id)
|
||||||
|
for wiz_tax in taxes_to_create:
|
||||||
|
_logger.info(_("Created tax %s."), "'%s'" % wiz_tax.tax_id.name)
|
||||||
|
for wiz_tax in self.tax_ids.filtered(lambda x: x.type != "new"):
|
||||||
template, tax = wiz_tax.tax_id, wiz_tax.update_tax_id
|
template, tax = wiz_tax.tax_id, wiz_tax.update_tax_id
|
||||||
# Deactivate tax
|
# Deactivate tax
|
||||||
if wiz_tax.type == "deleted":
|
if wiz_tax.type == "deleted":
|
||||||
tax.active = False
|
tax.active = False
|
||||||
_logger.info(_("Deactivated tax %s."), "'%s'" % tax.name)
|
_logger.info(_("Deactivated tax %s."), "'%s'" % tax.name)
|
||||||
continue
|
continue
|
||||||
# Create tax
|
|
||||||
if wiz_tax.type == "new":
|
|
||||||
template._generate_tax(self.company_id)
|
|
||||||
_logger.info(_("Created tax %s."), "'%s'" % template.name)
|
|
||||||
# Update tax
|
|
||||||
else:
|
else:
|
||||||
for key, value in self.diff_fields(template, tax).items():
|
for key, value in self.diff_fields(template, tax).items():
|
||||||
# We defer update because account might not be created yet
|
# We defer update because account might not be created yet
|
||||||
|
Loading…
Reference in New Issue
Block a user