From 3751379f1e9a4c215fb6eb898b4ccc67659b9ace Mon Sep 17 00:00:00 2001 From: stephanchrst Date: Tue, 10 May 2022 21:51:50 +0700 Subject: initial commit 2 --- addons/l10n_nl/models/__init__.py | 5 ++++ addons/l10n_nl/models/account_chart_template.py | 25 +++++++++++++++++++ addons/l10n_nl/models/account_journal.py | 33 +++++++++++++++++++++++++ 3 files changed, 63 insertions(+) create mode 100644 addons/l10n_nl/models/__init__.py create mode 100644 addons/l10n_nl/models/account_chart_template.py create mode 100644 addons/l10n_nl/models/account_journal.py (limited to 'addons/l10n_nl/models') 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 -- cgit v1.2.3