Initial commit: L10N_Asia Pacific packages

This commit is contained in:
Ernad Husremovic 2025-08-29 15:20:52 +02:00
commit 54c86b612c
828 changed files with 58224 additions and 0 deletions

View file

@ -0,0 +1,9 @@
# -*- coding: utf-8 -*-
# Part of Odoo. See LICENSE file for full copyright and licensing details.
# Copyright (C) 2014 Tech Receptives (<http://techreceptives.com>).
from . import models
def _preserve_tag_on_taxes(cr, registry):
from odoo.addons.account.models.chart_template import preserve_existing_tags_on_taxes
preserve_existing_tags_on_taxes(cr, registry, 'l10n_sg')

View file

@ -0,0 +1,38 @@
# -*- coding: utf-8 -*-
# Part of Odoo. See LICENSE file for full copyright and licensing details.
# Copyright (C) 2014 Tech Receptives (<http://techreceptives.com>)
{
'name': 'Singapore - Accounting',
'author': 'Tech Receptives',
'version': '2.2',
'category': 'Accounting/Localizations/Account Charts',
'description': """
Singapore accounting chart and localization.
=======================================================
This module add, for accounting:
- The Chart of Accounts of Singapore
- Field UEN (Unique Entity Number) on company and partner
- Field PermitNo and PermitNoDate on invoice
""",
'depends': ['base', 'account'],
'data': [
'data/l10n_sg_chart_data.xml',
'data/account_tax_group_data.xml',
'data/account_tax_report_data.xml',
'data/account_tax_data.xml',
'data/account_tax_template_data_2024.xml',
'data/account_chart_template_data.xml',
'views/account_invoice_view.xml',
'views/res_company_view.xml',
'views/res_partner_view.xml',
],
'demo': [
'demo/demo_company.xml',
],
'post_init_hook': '_preserve_tag_on_taxes',
'license': 'LGPL-3',
}

View file

@ -0,0 +1,8 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<data noupdate="1">
<function model="account.chart.template" name="try_loading">
<value eval="[ref('l10n_sg.sg_chart_template')]"/>
</function>
</data>
</odoo>

File diff suppressed because it is too large Load diff

View file

@ -0,0 +1,18 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<data noupdate="1">
<record id="tax_group_0" model="account.tax.group">
<field name="name">TAX 0%</field>
<field name="country_id" ref="base.sg"/>
</record>
<record id="tax_group_8" model="account.tax.group">
<field name="name">TAX 8%</field>
<field name="country_id" ref="base.sg"/>
</record>
<record id="tax_group_7" model="account.tax.group">
<field name="name">TAX 7%</field>
<field name="country_id" ref="base.sg"/>
</record>
</data>
</odoo>

View file

@ -0,0 +1,145 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<record id="tax_report" model="account.report">
<field name="name">Singapore Tax Report</field>
<field name="root_report_id" ref="account.generic_tax_report"/>
<field name="country_id" ref="base.sg"/>
<field name="filter_fiscal_position" eval="True"/>
<field name="availability_condition">country</field>
<field name="column_ids">
<record id="tax_report_balance" model="account.report.column">
<field name="name">Balance</field>
<field name="expression_label">balance</field>
</record>
</field>
<field name="line_ids">
<record id="account_tax_report_line_supplies" model="account.report.line">
<field name="name">Supplies</field>
<field name="aggregation_formula">BOX1.balance + BOX2.balance + BOX3.balance</field>
<field name="children_ids">
<record id="account_tax_report_line_std_rated_supplies" model="account.report.line">
<field name="name">Box 1 - Total value of standard-rated supplies</field>
<field name="code">BOX1</field>
<field name="expression_ids">
<record id="account_tax_report_line_std_rated_supplies_tag" model="account.report.expression">
<field name="label">balance</field>
<field name="engine">tax_tags</field>
<field name="formula">Box 1</field>
</record>
</field>
</record>
<record id="account_tax_report_line_zero_rated_supplies" model="account.report.line">
<field name="name">Box 2 - Total value of zero-rated supplies</field>
<field name="code">BOX2</field>
<field name="expression_ids">
<record id="account_tax_report_line_zero_rated_supplies_tag" model="account.report.expression">
<field name="label">balance</field>
<field name="engine">tax_tags</field>
<field name="formula">Box 2</field>
</record>
</field>
</record>
<record id="account_tax_report_line_exempt_supplies" model="account.report.line">
<field name="name">Box 3 - Total value of exempt supplies</field>
<field name="code">BOX3</field>
<field name="expression_ids">
<record id="account_tax_report_line_exempt_supplies_tag" model="account.report.expression">
<field name="label">balance</field>
<field name="engine">tax_tags</field>
<field name="formula">Box 3</field>
</record>
</field>
</record>
<record id="account_tax_report_line_total_supplies" model="account.report.line">
<field name="name">Box 4 - Total value of (1) + (2) + (3)</field>
<field name="aggregation_formula">BOX1.balance + BOX2.balance + BOX3.balance</field>
</record>
</field>
</record>
<record id="account_tax_report_line_purchases" model="account.report.line">
<field name="name">Purchases</field>
<field name="aggregation_formula">BOX_5.balance</field>
<field name="children_ids">
<record id="account_tax_report_line_total_taxable_purchases" model="account.report.line">
<field name="name">Box 5 - Total value of taxable purchases</field>
<field name="code">BOX_5</field>
<field name="expression_ids">
<record id="account_tax_report_line_total_taxable_purchases_tag" model="account.report.expression">
<field name="label">balance</field>
<field name="engine">tax_tags</field>
<field name="formula">Box 5</field>
</record>
</field>
</record>
</field>
</record>
<record id="account_tax_report_line_taxes" model="account.report.line">
<field name="name">Taxes</field>
<field name="aggregation_formula">BOX6.balance + BOX7.balance</field>
<field name="children_ids">
<record id="account_tax_report_line_output_tax_due" model="account.report.line">
<field name="name">Box 6 - Output tax due</field>
<field name="code">BOX6</field>
<field name="expression_ids">
<record id="account_tax_report_line_output_tax_due_tag" model="account.report.expression">
<field name="label">balance</field>
<field name="engine">tax_tags</field>
<field name="formula">Box 6</field>
</record>
</field>
</record>
<record id="account_tax_report_line_inp_tax_refund_claim" model="account.report.line">
<field name="name">Box 7 - Less : Input tax and refunds claimed</field>
<field name="code">BOX7</field>
<field name="expression_ids">
<record id="account_tax_report_line_inp_tax_refund_claim_tag" model="account.report.expression">
<field name="label">balance</field>
<field name="engine">tax_tags</field>
<field name="formula">Box 7</field>
</record>
</field>
</record>
<record id="account_tax_report_line_total_gst_paid_iras" model="account.report.line">
<field name="name">Box 8 - Equals : Net GST to be paid to IRAS</field>
<field name="aggregation_formula">BOX6.balance - BOX7.balance</field>
</record>
</field>
</record>
<record id="account_tax_report_line_applicable" model="account.report.line">
<field name="name">Applicable to Taxable Persons under Major Exported Scheme / Approved 3rd Party Logistics Company / Other Approved Schemes Only</field>
<field name="aggregation_formula">BOX_9.balance</field>
<field name="children_ids">
<record id="account_tax_report_line_applicable_goods_imported_value" model="account.report.line">
<field name="name">Box 9 - Total value of goods imported under this scheme</field>
<field name="code">BOX_9</field>
<field name="expression_ids">
<record id="account_tax_report_line_applicable_goods_imported_value_tag" model="account.report.expression">
<field name="label">balance</field>
<field name="engine">tax_tags</field>
<field name="formula">Box 9</field>
</record>
</field>
</record>
</field>
</record>
<record id="account_tax_report_line_revenues" model="account.report.line">
<field name="name">Revenue</field>
<field name="aggregation_formula">BOX_13.balance</field>
<field name="children_ids">
<record id="account_tax_report_line_revenues_accounting_period" model="account.report.line">
<field name="name">Box 13 - Revenue for the accounting period</field>
<field name="code">BOX_13</field>
<field name="expression_ids">
<record id="account_tax_report_line_revenues_accounting_period_formula" model="account.report.expression">
<field name="label">balance</field>
<field name="engine">aggregation</field>
<field name="formula">OPINC.balance</field>
<field name="subformula">cross_report</field>
</record>
</field>
</record>
</field>
</record>
</field>
</record>
</odoo>

View file

@ -0,0 +1,412 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<data noupdate="1">
<record id="tax_group_9" model="account.tax.group">
<field name="name">TAX 9%</field>
</record>
</data>
<record id="sg_sale_tax_ds_9" model="account.tax.template">
<field name="name">Sales Tax 9% DS</field>
<field name="description">9% DS</field>
<field name="price_include" eval="0"/>
<field name="amount">9</field>
<field name="amount_type">percent</field>
<field name="type_tax_use">sale</field>
<field name="chart_template_id" ref="sg_chart_template"/>
<field name="tax_group_id" ref="tax_group_9"/>
<field name="invoice_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'plus_report_expression_ids': [ref('account_tax_report_line_std_rated_supplies_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_792'),
'plus_report_expression_ids': [ref('account_tax_report_line_output_tax_due_tag')],
}),
]"/>
<field name="refund_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'minus_report_expression_ids': [ref('account_tax_report_line_std_rated_supplies_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_792'),
'minus_report_expression_ids': [ref('account_tax_report_line_output_tax_due_tag')],
}),
]"/>
</record>
<record id="sg_sale_tax_sr_9" model="account.tax.template">
<field name="name">Sales Tax 9% SR</field>
<field name="description">9% SR</field>
<field name="price_include" eval="0"/>
<field name="amount">9</field>
<field name="amount_type">percent</field>
<field name="type_tax_use">sale</field>
<field name="chart_template_id" ref="sg_chart_template"/>
<field name="tax_group_id" ref="tax_group_9"/>
<field name="invoice_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'plus_report_expression_ids': [ref('account_tax_report_line_std_rated_supplies_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_796'),
'plus_report_expression_ids': [ref('account_tax_report_line_output_tax_due_tag')],
}),
]"/>
<field name="refund_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'minus_report_expression_ids': [ref('account_tax_report_line_std_rated_supplies_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_796'),
'minus_report_expression_ids': [ref('account_tax_report_line_output_tax_due_tag')],
}),
]"/>
</record>
<record id="sg_sale_tax_srca_c_9" model="account.tax.template">
<field name="name">Sales Tax 9% SRCA-C</field>
<field name="description">9% SRCA-C</field>
<field name="price_include" eval="0"/>
<field name="amount">9</field>
<field name="amount_type">percent</field>
<field name="type_tax_use">sale</field>
<field name="chart_template_id" ref="sg_chart_template"/>
<field name="tax_group_id" ref="tax_group_9"/>
<field name="invoice_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'plus_report_expression_ids': [ref('account_tax_report_line_std_rated_supplies_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_798'),
'plus_report_expression_ids': [ref('account_tax_report_line_output_tax_due_tag')],
}),
]"/>
<field name="refund_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'minus_report_expression_ids': [ref('account_tax_report_line_std_rated_supplies_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_798'),
'minus_report_expression_ids': [ref('account_tax_report_line_output_tax_due_tag')],
}),
]"/>
</record>
<record id="sg_purchase_tax_txn33_9" model="account.tax.template">
<field name="name">Purchase Tax 9% TX-N33</field>
<field name="description">9% TX-N33</field>
<field name="price_include" eval="0"/>
<field name="amount">9</field>
<field name="amount_type">percent</field>
<field name="type_tax_use">purchase</field>
<field name="chart_template_id" ref="sg_chart_template"/>
<field name="tax_group_id" ref="tax_group_9"/>
<field name="invoice_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'plus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_738'),
'plus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
<field name="refund_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'minus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_738'),
'minus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
</record>
<record id="sg_purchase_tax_txe33_9" model="account.tax.template">
<field name="name">Purchase Tax 9% TX-E33</field>
<field name="description">9% TX-E33</field>
<field name="price_include" eval="0"/>
<field name="amount">9</field>
<field name="amount_type">percent</field>
<field name="type_tax_use">purchase</field>
<field name="chart_template_id" ref="sg_chart_template"/>
<field name="tax_group_id" ref="tax_group_9"/>
<field name="invoice_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'plus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_739'),
'plus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
<field name="refund_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'minus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_739'),
'minus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
</record>
<record id="sg_purchase_tax_bl_9" model="account.tax.template">
<field name="name">Purchase Tax 9% BL</field>
<field name="description">9% BL</field>
<field name="price_include" eval="0"/>
<field name="amount">9</field>
<field name="amount_type">percent</field>
<field name="type_tax_use">purchase</field>
<field name="chart_template_id" ref="sg_chart_template"/>
<field name="tax_group_id" ref="tax_group_9"/>
<field name="invoice_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_740'),
}),
]"/>
<field name="refund_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_740'),
}),
]"/>
</record>
<record id="sg_purchase_tax_im_9" model="account.tax.template">
<field name="name">Purchase Tax 9% IM</field>
<field name="description">9% IM</field>
<field name="price_include" eval="0"/>
<field name="amount">9</field>
<field name="amount_type">percent</field>
<field name="type_tax_use">purchase</field>
<field name="chart_template_id" ref="sg_chart_template"/>
<field name="tax_group_id" ref="tax_group_9"/>
<field name="invoice_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'plus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_741'),
'plus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
<field name="refund_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'minus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_741'),
'minus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
</record>
<record id="sg_purchase_tax_txre_9" model="account.tax.template">
<field name="name">Purchase Tax 9% TX-RE</field>
<field name="description">9% TX-RE</field>
<field name="price_include" eval="0"/>
<field name="amount">9</field>
<field name="amount_type">percent</field>
<field name="type_tax_use">purchase</field>
<field name="chart_template_id" ref="sg_chart_template"/>
<field name="tax_group_id" ref="tax_group_9"/>
<field name="invoice_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'plus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_742'),
'plus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
<field name="refund_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'minus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_742'),
'minus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
</record>
<record id="sg_purchase_tax_igds_9" model="account.tax.template">
<field name="name">Purchase Tax 9% IGDS</field>
<field name="description">9% IGDS</field>
<field name="price_include" eval="0"/>
<field name="amount">9</field>
<field name="amount_type">percent</field>
<field name="type_tax_use">purchase</field>
<field name="chart_template_id" ref="sg_chart_template"/>
<field name="tax_group_id" ref="tax_group_9"/>
<field name="invoice_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'plus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_743'),
'plus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
<field name="refund_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'minus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_743'),
'minus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
</record>
<record id="sg_purchase_tax_tx8_9" model="account.tax.template">
<field name="name">Purchase Tax 9% TX9</field>
<field name="description">9% TX9</field>
<field name="price_include" eval="0"/>
<field name="amount">9</field>
<field name="amount_type">percent</field>
<field name="type_tax_use">purchase</field>
<field name="chart_template_id" ref="sg_chart_template"/>
<field name="tax_group_id" ref="tax_group_9"/>
<field name="invoice_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'plus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_749'),
'plus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
<field name="refund_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'minus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_749'),
'minus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
</record>
<record id="sg_purchase_tax_txca_9" model="account.tax.template">
<field name="name">Purchase Tax 9% TXCA</field>
<field name="description">9% TXCA</field>
<field name="price_include" eval="0"/>
<field name="amount">9</field>
<field name="amount_type">percent</field>
<field name="type_tax_use">purchase</field>
<field name="chart_template_id" ref="sg_chart_template"/>
<field name="tax_group_id" ref="tax_group_9"/>
<field name="invoice_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'plus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_750'),
'plus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
<field name="refund_repartition_line_ids" eval="[(5, 0, 0),
(0,0, {
'factor_percent': 100,
'repartition_type': 'base',
'minus_report_expression_ids': [ref('account_tax_report_line_total_taxable_purchases_tag')],
}),
(0,0, {
'factor_percent': 100,
'repartition_type': 'tax',
'account_id': ref('account_account_750'),
'minus_report_expression_ids': [ref('account_tax_report_line_inp_tax_refund_claim_tag')],
}),
]"/>
</record>
</odoo>

File diff suppressed because it is too large Load diff

View file

@ -0,0 +1,34 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<record id="partner_demo_company_sg" model="res.partner">
<field name="name">SG Company</field>
<field name="vat">197401143C</field>
<field name="l10n_sg_unique_entity_number">201131415A</field>
<field name="street">Tyersall Avenue</field>
<field name="city">Central Singapore</field>
<field name="country_id" ref="base.sg"/>
<field name="zip">248048</field>
<field name="phone">+65 9123 4567</field>
<field name="email">info@company.sg.example.com</field>
<field name="website">www.sg.example.com</field>
</record>
<record id="demo_company_sg" model="res.company">
<field name="name">SG Company</field>
<field name="partner_id" ref="partner_demo_company_sg"/>
</record>
<function model="res.company" name="_onchange_country_id">
<value eval="[ref('demo_company_sg')]"/>
</function>
<function model="res.users" name="write">
<value eval="[ref('base.user_root'), ref('base.user_admin'), ref('base.user_demo')]"/>
<value eval="{'company_ids': [(4, ref('l10n_sg.demo_company_sg'))]}"/>
</function>
<function model="account.chart.template" name="try_loading">
<value eval="[ref('l10n_sg.sg_chart_template')]"/>
<value model="res.company" eval="obj().env.ref('l10n_sg.demo_company_sg')"/>
</function>
</odoo>

View file

@ -0,0 +1,6 @@
# Part of Odoo. See LICENSE file for full copyright and licensing details.
from odoo.addons.account.models.chart_template import update_taxes_from_templates
def migrate(cr, version):
update_taxes_from_templates(cr, 'l10n_sg.sg_chart_template')

View file

@ -0,0 +1,6 @@
# Part of Odoo. See LICENSE file for full copyright and licensing details.
from odoo.addons.account.models.chart_template import update_taxes_from_templates
def migrate(cr, version):
update_taxes_from_templates(cr, 'l10n_sg.sg_chart_template')

View file

@ -0,0 +1,6 @@
from openerp.modules.registry import RegistryManager
def migrate(cr, version):
registry = RegistryManager.get(cr.dbname)
from openerp.addons.account.models.chart_template import migrate_set_tags_and_taxes_updatable
migrate_set_tags_and_taxes_updatable(cr, registry, 'l10n_sg')

View file

@ -0,0 +1,9 @@
# -*- coding: utf-8 -*-
# Part of Odoo. See LICENSE file for full copyright and licensing details.
# Copyright (C) 2014 Tech Receptives (<http://techreceptives.com>).
from . import account_move
from . import chart_template
from . import res_company
from . import res_partner

View file

@ -0,0 +1,11 @@
# -*- coding: utf-8 -*-
from odoo import fields, models
class AccountMove(models.Model):
_inherit = 'account.move'
l10n_sg_permit_number = fields.Char(string="Permit No.")
l10n_sg_permit_number_date = fields.Date(string="Date of permit number")

View file

@ -0,0 +1,15 @@
# Part of Odoo. See LICENSE file for full copyright and licensing details.
from odoo import models
class AccountChartTemplate(models.Model):
_inherit = 'account.chart.template'
def _load(self, company):
res = super()._load(company)
if company.chart_template_id == self.env.ref('l10n_sg.sg_chart_template'):
company.write({
'account_sale_tax_id': self.env.ref(f'l10n_sg.{company.id}_sg_sale_tax_sr_9').id,
'account_purchase_tax_id': self.env.ref(f'l10n_sg.{company.id}_sg_purchase_tax_tx8_9').id,
})
return res

View file

@ -0,0 +1,18 @@
# -*- coding: utf-8 -*-
from odoo import fields, models
class ResCompany(models.Model):
_name = 'res.company'
_description = 'Companies'
_inherit = 'res.company'
l10n_sg_unique_entity_number = fields.Char(string='UEN', related="partner_id.l10n_sg_unique_entity_number", readonly=False)
def _get_view(self, view_id=None, view_type='form', **options):
arch, view = super()._get_view(view_id, view_type, **options)
company_vat_label = self.env.company.country_id.vat_label
if company_vat_label:
for node in arch.iterfind(".//field[@name='vat']"):
node.set("string", company_vat_label)
return arch, view

View file

@ -0,0 +1,9 @@
# -*- coding: utf-8 -*-
from odoo import fields, models
class ResPartner(models.Model):
_name = 'res.partner'
_inherit = 'res.partner'
l10n_sg_unique_entity_number = fields.Char(string='UEN')

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 90 KiB

View file

@ -0,0 +1,16 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<data>
<record id="view_invoice_form_l10n_sg" model="ir.ui.view">
<field name="name">l10n_sg.invoice.form</field>
<field name="model">account.move</field>
<field name="inherit_id" ref="account.view_move_form"/>
<field name="arch" type="xml">
<xpath expr="//field[@name='fiscal_position_id']" position="after">
<field name="l10n_sg_permit_number"/>
<field name="l10n_sg_permit_number_date"/>
</xpath>
</field>
</record>
</data>
</odoo>

View file

@ -0,0 +1,15 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<data>
<record id="view_company_form_l10n_sg" model="ir.ui.view">
<field name="name">l10n_sg.company.form</field>
<field name="model">res.company</field>
<field name="inherit_id" ref="base.view_company_form"/>
<field name="arch" type="xml">
<xpath expr="//field[@name='email']" position="after">
<field name="l10n_sg_unique_entity_number" attrs="{'invisible': [('country_code', '!=', 'SG')]}"/>
</xpath>
</field>
</record>
</data>
</odoo>

View file

@ -0,0 +1,15 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<data>
<record id="view_partner_form_l10n_sg" model="ir.ui.view">
<field name="name">l10n_sg.partner.form</field>
<field name="model">res.partner</field>
<field name="inherit_id" ref="base.view_partner_form"/>
<field name="arch" type="xml">
<xpath expr="//field[@name='vat']" position="before">
<field name="l10n_sg_unique_entity_number"/>
</xpath>
</field>
</record>
</data>
</odoo>