Локалізація бухгалтерського обліку

Попередження

Цей підручник вимагає знань про те, як створити модуль в Odoo (див. Початок).

Створення модуля локалізації

При установці модуля бухгалтерія автоматично встановлюється модуль локалізації, що відповідає коду країни компанії. Якщо код країни не встановлено або модуль локалізації не знайдено, модуль локалізації l10n_generic_coa (США) встановлюється за замовчуванням.

Наприклад, l10n_be буде встановлено, якщо компанія має Belgium країною.

Така поведінка дозволена наявністю файлу .xml, який містить такий код:

<function model="account.chart.template" name="try_loading_for_current_company">
   <value eval="[ref(module.template_xmlid)]"/>
</function>

Де module.template_xmlid є повним xmlid відповідного шаблону.

Зазвичай він знаходиться в папці data і має бути завантажений останнім у файл __manifest__.py.

Небезпека

Якщо файл .xml відсутній, правильний план рахунків не завантажиться вчасно!

Налаштовую власний план рахунків?

Перш за все, перш ніж я продовжу, нам потрібно поговорити про шаблони. Шаблон - це запис, який допускає свою копію. Цей механізм необхідний при роботі в мультикомпаніях. Наприклад, створення нового облікового запису виконується за допомогою моделі account.account.template. Однак кожна компанія, яка використовує цей план рахунків, буде пов’язана з копією, що має як модель account.account. Таким чином, шаблони ніколи не використовуються безпосередньо компанією.

Потім, коли потрібно встановити план рахунків, усі шаблони, залежні від цього, створять копію та зв’яжуть цей щойно згенерований запис із користувачем компанії. Це означає, що всі такі шаблони мають бути певним чином пов’язані з планом рахунків. Для цього кожен має посилатися на потрібний план рахунків за допомогою поля chart_template_id. З цієї причини нам потрібно визначити екземпляр моделі account.chart.template перед створенням її шаблонів.

<record id="..." model="account.chart.template">
    <!-- [Required] Specify the name to display for this CoA. -->
    <field name="name">...</field>

    <!-- [Required] Specify the currency. E.g. "base.USD". -->
    <field name="currency_id" ref="..."/>

    <!-- [Required] Specify a prefix of the bank accounts. -->
    <field name="bank_account_code_prefix">...</field>

    <!-- [Required] Specify a prefix of the cash accounts. -->
    <field name="cash_account_code_prefix">...</field>

    <!-- [Optional] Define a parent chart of accounts that will be installed just before this one. -->
    <field name="parent_id" ref="..."/>

    <!-- [Optional] Define the number of digits of account codes. By default, the value is 6. -->
    <field name="code_digits">...</field>

    <!-- [Optional] Boolean to show or not this CoA on the list. By default, the CoA is visible.
     This field is mostly used when this CoA has some children (see parent_id field). -->
    <field name="visible" eval="..."/>

    <!-- [Optional] Boolean to enable the Anglo-Saxon accounting. By default, this field is False. -->
    <field name="use_anglo_saxon" eval="..."/>

    <!-- [Optional] Boolean to enable the complete set of taxes. By default, this field is True.
    This boolean helps you to choose if you want to propose to the user to encode the sale and purchase rates or choose from list of taxes.
    This last choice assumes that the set of tax defined on this template is complete. -->
    <field name="complete_tax_set" eval="..."/>

    <!-- [Optional] Specify the spoken languages.
    /!\ This option is only available if your module depends of l10n_multilang.
    You must provide the language codes separated by ';', e.g. eval="'en_US;ar_EG;ar_SY'". -->
    <field name="spoken_languages" eval="..."/>
</record>

Наприклад, давайте поглянемо на план рахунків Бельгії.

<record id="l10nbe_chart_template" model="account.chart.template">
    <field name="name">Belgian PCMN</field>
    <field name="currency_id" ref="base.EUR"/>
    <field name="bank_account_code_prefix">550</field>
    <field name="cash_account_code_prefix">570</field>
    <field name="spoken_languages" eval="'nl_BE'"/>
</record>

Тепер, коли план рахунків створено, ми можемо зосередитися на створенні шаблонів. Як було сказано раніше, кожен запис має посилатися на цей запис через поле chart_template_id. Якщо ні, шаблон буде проігноровано. У наступних розділах детально показано, як створити ці шаблони.

Додавання нового облікового запису до мого плану рахунків

Настав час створити облікові записи. Він полягає у створенні записів типу account.account.template. Кожен account.account.template може створити account.account для кожної компанії.

<record id="..." model="account.account.template">
    <!-- [Required] Specify the name to display for this account. -->
    <field name="name">...</field>

    <!-- [Required] Specify a code. -->
    <field name="code">...</field>

    <!-- [Required] Specify a type. -->
    <field name="user_type_id">...</field>

    <!-- [Required] Set the CoA owning this account. -->
    <field name="chart_template_id" ref="..."/>

    <!-- [Optional] Specify a secondary currency for each account.move.line linked to this account. -->
    <field name="currency_id" ref="..."/>

    <!-- [Optional] Boolean to allow the user to reconcile entries in this account. True by default. -->
    <field name="reconcile" eval="..."/>

    <!-- [Optional] Specify a group for this account. -->
    <field name="group_id" ref="...">

    <!-- [Optional] Specify some tags. -->
    <field name="tag_ids" eval="...">
</record>

Деякі з описаних вище полів заслуговують на детальніше пояснення.

Поле user_type_id вимагає значення типу account.account.type. Хоча деякі додаткові типи можуть бути створені в модулі локалізації, ми заохочуємо до використання існуючих типів у account/data/data_account_type.xml файл. Використання цих загальних типів забезпечує правильну роботу загальних звітів на додаток до тих, які ви можете створити у своєму модулі локалізації.

Попередження

Уникайте використання ліквідності account.account.type! Дійсно, банківські та касові рахунки створюються безпосередньо під час встановлення модуля локалізації, а потім пов’язуються з account.journal.

Попередження

Досить лише одного рахунку типу заборгованість/дебіторка.

Хоча поле tag_ids необов’язкове, воно залишається дуже потужною функцією. Дійсно, це дозволяє вам визначити деякі теги для своїх облікових записів, щоб правильно розподілити їх у своїх звітах. Наприклад, припустімо, що ви хочете створити фінансовий звіт із кількома рядками, але у вас немає способу знайти правило для розподілу облікових записів відповідно до їх коду або назви. Рішення полягає у використанні тегів, по одному для кожного рядка звіту, для розподілу та агрегування ваших облікових записів, як вам потрібно.

Як і будь-який інший запис, тег можна створити з такою структурою xml:

<record id="..." model="account.account.tag">
    <!-- [Required] Specify the name to display for this tag. -->
    <field name="name">...</field>

    <!-- [Optional] Define a scope for this applicability.
    The available keys are 'accounts' and 'taxes' but 'accounts' is the default value. -->
    <field name="applicability">...</field>
</record>

Як ви можете собі уявити з використанням тегів, цю функцію також можна використовувати з податками.

Приклади з модуля l10n_be:

<record id="a4000" model="account.account.template">
    <field name="name">Clients</field>
    <field name="code">4000</field>
    <field name="user_type_id" ref="account.data_account_type_receivable"/>
    <field name="chart_template_id" ref="l10nbe_chart_template"/>
</record>

Попередження

Не створюйте занадто багато облікових записів: достатньо 200-300.

Додавання нового податку до мого плану рахунків

Щоб створити новий податковий запис, вам просто потрібно виконати той самий процес, що й для створення облікових записів. Єдина відмінність полягає в тому, що ви повинні використовувати модель account.tax.template.

<record id="..." model="account.tax.template">
    <!-- [Required] Specify the name to display for this tax. -->
    <field name="name">...</field>

    <!-- [Required] Specify the amount.
    E.g. 7 with fixed amount_type means v + 7 if v is the amount on which the tax is applied.
     If amount_type is 'percent', the tax amount is v * 0.07. -->
    <field name="amount" eval="..."/>

    <!-- [Required] Set the CoA owning this tax. -->
    <field name="chart_template_id" ref="..."/>

    <!-- [Required/Optional] Define an account if the tax is not a group of taxes. -->
    <field name="account_id" ref="..."/>

    <!-- [Required/Optional] Define an refund account if the tax is not a group of taxes. -->
    <field name="refund_account_id" ref="..."/>

    <!-- [Optional] Define the tax's type.
    'sale', 'purchase' or 'none' are the allowed values. 'sale' is the default value.
    Note: 'none' means a tax can't be used by itself, however it can still be used in a group. -->
    <field name="type_tax_use">...</field>

    <!-- [Optional] Define the type of amount:
    'group' for a group of taxes, 'fixed' for a tax with a fixed amount or 'percent' for a classic percentage of price.
    By default, the type of amount is percentage. -->
    <field name="amount_type" eval="..."/>

    <!-- [Optional] Define some children taxes.
    /!\ Should be used only with an amount_type with 'group' set. -->
    <field name="children_tax_ids" eval="..."/>

    <!-- [Optional] The sequence field is used to define order in which the tax lines are applied.
    By default, sequence = 1. -->
    <field name="sequence" eval="..."/>

    <!-- [Optional] Specify a short text to be displayed on invoices.
    For example, a tax named "15% on Services" can have the following label on invoice "15%". -->
    <field name="description">...</field>

    <!-- [Optional] Boolean that indicates if the amount should be considered as included in price. False by default.
    E.g. Suppose v = 132 and a tax amount of 20.
    If price_include = False, the computed amount will be 132 * 0.2 = 26.4.
    If price_include = True, the computed amount will be 132 - (132 / 1.2) = 132 - 110 = 22. -->
    <field name="price_include" eval="..."/>

    <!-- [Optional] Boolean to set to include the amount to the base. False by default.
     If True, the subsequent taxes will be computed based on the base tax amount plus the amount of this tax.
     E.g. suppose v = 100, t1, a tax of 10% and another tax t2 with 20%.
     If t1 doesn't affects the base,
     t1 amount = 100 * 0.1 = 10 and t2 amount = 100 * 0.2 = 20.
     If t1 affects the base,
     t1 amount = 100 * 0.1 = 10 and t2 amount = 110 * 0.2 = 22.  -->
    <field name="include_base_amount" eval="..."/>

    <!-- [Optional] Boolean false by default.
     If set, the amount computed by this tax will be assigned to the same analytic account as the invoice line (if any). -->
    <field name="analytic" eval="..."/>

    <!-- [Optional] Specify some tags.
    These tags must have 'taxes' as applicability.
    See the previous section for more details. -->
    <field name="tag_ids" eval="...">

    <!-- [Optional] Define a tax group used to display the sums of taxes in the invoices. -->
    <field name="tax_group_id" ref="..."/>

    <!-- [Optional] Define the tax exigibility either based on invoice ('on_invoice' value) or
    either based on payment using the 'on_payment' key.
    The default value is 'on_invoice'. -->
    <field name="tax_exigibility">...</field>

    <!-- [Optional] Define a cash basis account in case of tax exigibility 'on_payment'. -->
    <field name="cash_basis_account" red="..."/>
</record>

Приклад знайдено в модулі l10n_pl:

<record id="vp_leas_sale" model="account.tax.template">
    <field name="chart_template_id" ref="pl_chart_template"/>
    <field name="name">VAT - leasing pojazdu(sale)</field>
    <field name="description">VLP</field>
    <field name="amount">1.00</field>
    <field name="sequence" eval="1"/>
    <field name="amount_type">group</field>
    <field name="type_tax_use">sale</field>
    <field name="children_tax_ids" eval="[(6, 0, [ref('vp_leas_sale_1'), ref('vp_leas_sale_2')])]"/>
    <field name="tag_ids" eval="[(6,0,[ref('l10n_pl.tag_pl_21')])]"/>
    <field name="tax_group_id" ref="tax_group_vat_23"/>
</record>

Додавання нової фінансової позиції до мого плану рахунків

Примітка

Якщо вам потрібна додаткова інформація про те, що таке фіскальна позиція та як вона працює в Odoo, зверніться до Фіскальні позиції (відображення податків і рахунків).

Щоб створити нову фінансову позицію, просто скористайтеся моделлю account.fiscal.position.template:

<record id="..." model="account.fiscal.position.template">
    <!-- [Required] Specify the name to display for this fiscal position. -->
    <field name="name">...</field>

    <!-- [Required] Set the CoA owning this fiscal position. -->
    <field name="chart_template_id" ref="..."/>

    <!-- [Optional] Add some additional notes. -->
    <field name="note">...</field>
</record>

Додавання властивостей до мого плану рахунків

Коли цілі облікові записи створено, ви маєте можливість замінити щойно створений план рахунків, додавши деякі властивості, які відповідають обліковим записам за замовчуванням, які використовуються в певних ситуаціях. Це необхідно зробити після створення рахунків, перш ніж кожен з них повинен бути пов’язаний з планом рахунків.

<?xml version="1.0" encoding="utf-8"?>
<odoo>
    <record id="l10n_xx_chart_template" model="account.chart.template">

        <!-- Define receivable/payable accounts. -->
        <field name="property_account_receivable_id" ref="..."/>
        <field name="property_account_payable_id" ref="..."/>

        <!-- Define categories of expense/income account. -->
        <field name="property_account_expense_categ_id" ref="..."/>
        <field name="property_account_income_categ_id" ref="..."/>

        <!-- Define input/output accounts for stock valuation. -->
        <field name="property_stock_account_input_categ_id" ref="..."/>
        <field name="property_stock_account_output_categ_id" ref="..."/>

        <!-- Define an account template for stock valuation. -->
        <field name="property_stock_valuation_account_id" ref="..."/>

        <!-- Define loss/gain exchange rate accounts. -->
        <field name="expense_currency_exchange_account_id" ref="..."/>
        <field name="income_currency_exchange_account_id" ref="..."/>

        <!-- Define a transfer account. -->
        <field name="transfer_account_id" ref="..."/>
    </record>
</odoo>

Наприклад, повернімося до PCMN Бельгії. Цей план рахунків замінюється таким чином, щоб додати деякі властивості.

<record id="l10nbe_chart_template" model="account.chart.template">
    <field name="property_account_receivable_id" ref="a4000"/>
    <field name="property_account_payable_id" ref="a440"/>
    <field name="property_account_expense_categ_id" ref="a600"/>
    <field name="property_account_income_categ_id" ref="a7010"/>
    <field name="expense_currency_exchange_account_id" ref="a654"/>
    <field name="income_currency_exchange_account_id" ref="a754"/>
    <field name="transfer_account_id" ref="trans"/>
</record>

Як створити нову модель роботи банку?

Примітка

Як саме модель банківської роботи працює в Odoo? Перегляньте Моделі звірки.

Починаючи з V10, у віджеті звірки банківської виписки доступна нова функція: модель банківської операції. Це дозволяє користувачеві заповнювати деякі бухгалтерські записи одним клацанням миші. Створити запис account.reconcile.model.template досить просто:

 <record id="..." model="account.reconcile.model.template">
     <!-- [Required] Specify the name to display. -->
     <field name="name">...</field>

     <!-- [Required] Set the CoA owning this. -->
     <field name="chart_template_id" ref="..."/>

     <!-- [Optional] Set a sequence number defining the order in which it will be displayed.
     By default, the sequence is 10. -->
     <field name="sequence" eval="..."/>

     <!-- [Optional] Define an account. -->
     <field name="account_id" ref="..."/>

     <!-- [Optional] Define a label to be added to the journal item. -->
     <field name="label">...</field>

     <!-- [Optional] Define the type of amount_type, either 'fixed' or 'percentage'.
     The last one is the default value. -->
     <field name="amount_type">...</field>

     <!-- [Optional] Define the balance amount on which this model will be applied to (100 by default).
     Fixed amount will count as a debit if it is negative, as a credit if it is positive. -->
     <field name="amount">...</field>

     <!-- [Optional] Define eventually a tax. -->
     <field name="tax_id" ref="..."/>

     <!-- [Optional] The sames fields are available twice.
     To enable a second journal line, you can set this field to true and
     fill the fields accordingly. -->
     <field name="has_second_line" eval="..."/>
     <field name="second_account_id" ref="..."/>
     <field name="second_label">...</field>
     <field name="second_amount_type">...</field>
     <field name="second_amount">...</field>
     <field name="second_tax_id" ref="..."/>
</record>

Як створити новий динамічний звіт?

Якщо вам потрібно додати кілька звітів про вашу локалізацію, вам потрібно створити новий модуль під назвою l10n_xx_reports. Крім того, цей додатковий модуль має бути присутнім у репозиторії enterprise і має мати принаймні дві залежності: одну для передачі всього матеріалу для вашого модуля локалізації та ще одну, account_reports, для розробки динамічних звітів.

'depends': ['l10n_xx', 'account_reports'],

Після того, як це буде зроблено, ви можете розпочати створення звітів. Документація доступна в наступних слайдах.