summaryrefslogtreecommitdiff
path: root/addons/l10n_nl/models
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/l10n_nl/models
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/l10n_nl/models')
-rw-r--r--addons/l10n_nl/models/__init__.py5
-rw-r--r--addons/l10n_nl/models/account_chart_template.py25
-rw-r--r--addons/l10n_nl/models/account_journal.py33
3 files changed, 63 insertions, 0 deletions
diff --git a/addons/l10n_nl/models/__init__.py b/addons/l10n_nl/models/__init__.py
new file mode 100644
index 00000000..a3c0ab06
--- /dev/null
+++ b/addons/l10n_nl/models/__init__.py
@@ -0,0 +1,5 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from . import account_journal
+from . import account_chart_template
diff --git a/addons/l10n_nl/models/account_chart_template.py b/addons/l10n_nl/models/account_chart_template.py
new file mode 100644
index 00000000..bd196fdb
--- /dev/null
+++ b/addons/l10n_nl/models/account_chart_template.py
@@ -0,0 +1,25 @@
+# -*- coding: utf-8 -*-
+
+from odoo import api, fields, models, _
+
+
+class AccountChartTemplate(models.Model):
+ _inherit = 'account.chart.template'
+
+ def _load(self, sale_tax_rate, purchase_tax_rate, company):
+ # Add tag to 999999 account
+ res = super(AccountChartTemplate, self)._load(sale_tax_rate, purchase_tax_rate, company)
+ if company.country_id.code == 'NL':
+ account = self.env['account.account'].search([('code', '=', '999999'), ('company_id', '=', self.env.company.id)])
+ if account:
+ account.tag_ids = [(4, self.env.ref('l10n_nl.account_tag_12').id)]
+ return res
+
+ @api.model
+ def _prepare_transfer_account_for_direct_creation(self, name, company):
+ res = super(AccountChartTemplate, self)._prepare_transfer_account_for_direct_creation(name, company)
+ if company.country_id.code == 'NL':
+ xml_id = self.env.ref('l10n_nl.account_tag_25').id
+ res.setdefault('tag_ids', [])
+ res['tag_ids'].append((4, xml_id))
+ return res
diff --git a/addons/l10n_nl/models/account_journal.py b/addons/l10n_nl/models/account_journal.py
new file mode 100644
index 00000000..5fc726b0
--- /dev/null
+++ b/addons/l10n_nl/models/account_journal.py
@@ -0,0 +1,33 @@
+# -*- coding: utf-8 -*-
+
+from odoo import api, fields, models, _
+
+
+class AccountJournal(models.Model):
+ _inherit = 'account.journal'
+
+ @api.model
+ def _fill_missing_values(self, vals):
+ super()._fill_missing_values(vals)
+
+ if vals.get('type') != 'purchase':
+ return
+
+ company = self.env['res.company'].browse(vals['company_id']) if vals.get('company_id') else self.env.company
+ if company.country_id.code == "NL":
+ type_control_ids = vals.get('type_control_ids', [])
+ type_control_ids.append(self.env.ref('account.data_account_type_direct_costs').id)
+ vals['type_control_ids'] = [(6, 0, type_control_ids)]
+
+ @api.model
+ def _prepare_liquidity_account_vals(self, company, code, vals):
+ # OVERRIDE
+ account_vals = super()._prepare_liquidity_account_vals(company, code, vals)
+
+ if company.country_id.code == 'NL':
+ # Ensure the newly liquidity accounts have the right account tag in order to be part
+ # of the Dutch financial reports.
+ account_vals.setdefault('tag_ids', [])
+ account_vals['tag_ids'].append((4, self.env.ref('l10n_nl.account_tag_25').id))
+
+ return account_vals