Consider normal and refund operations separately
Allow to explore all move lines Spanish translation Bugfixes Show negative lines too Show move type in account.move views Tests include new fieldspull/468/head
parent
337fda6119
commit
a223d53e27
|
@ -1,5 +1,6 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
# © 2016 Lorenzo Battistini - Agile Business Group
|
# © 2016 Lorenzo Battistini - Agile Business Group
|
||||||
|
# © 2016 Antonio Espinosa <antonio.espinosa@tecnativa.com>
|
||||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
{
|
{
|
||||||
"name": "Tax Balance",
|
"name": "Tax Balance",
|
||||||
|
@ -7,7 +8,7 @@
|
||||||
"version": "9.0.1.0.0",
|
"version": "9.0.1.0.0",
|
||||||
"category": "Accounting & Finance",
|
"category": "Accounting & Finance",
|
||||||
"website": "https://www.agilebg.com/",
|
"website": "https://www.agilebg.com/",
|
||||||
"author": "Agile Business Group, Therp BV, "
|
"author": "Agile Business Group, Therp BV, Tecnativa, "
|
||||||
"Odoo Community Association (OCA)",
|
"Odoo Community Association (OCA)",
|
||||||
"license": "AGPL-3",
|
"license": "AGPL-3",
|
||||||
"application": False,
|
"application": False,
|
||||||
|
@ -18,6 +19,7 @@
|
||||||
],
|
],
|
||||||
"data": [
|
"data": [
|
||||||
"wizard/open_tax_balances_view.xml",
|
"wizard/open_tax_balances_view.xml",
|
||||||
|
"views/account_move_view.xml",
|
||||||
"views/account_tax_view.xml",
|
"views/account_tax_view.xml",
|
||||||
],
|
],
|
||||||
"images": [
|
"images": [
|
||||||
|
|
|
@ -0,0 +1,261 @@
|
||||||
|
# Translation of Odoo Server.
|
||||||
|
# This file contains the translation of the following modules:
|
||||||
|
# * account_tax_balance
|
||||||
|
#
|
||||||
|
msgid ""
|
||||||
|
msgstr ""
|
||||||
|
"Project-Id-Version: Odoo Server 9.0c\n"
|
||||||
|
"Report-Msgid-Bugs-To: \n"
|
||||||
|
"POT-Creation-Date: 2016-10-21 15:30+0000\n"
|
||||||
|
"PO-Revision-Date: 2016-10-21 15:30+0000\n"
|
||||||
|
"Last-Translator: <>\n"
|
||||||
|
"Language-Team: \n"
|
||||||
|
"MIME-Version: 1.0\n"
|
||||||
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
|
"Content-Transfer-Encoding: \n"
|
||||||
|
"Plural-Forms: \n"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_search_balance
|
||||||
|
msgid "Account"
|
||||||
|
msgstr "Cuenta"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model,name:account_tax_balance.model_account_move
|
||||||
|
msgid "Account Entry"
|
||||||
|
msgstr "Asiento contable"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_search_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_tree_balance
|
||||||
|
msgid "Account Tax"
|
||||||
|
msgstr "Cuenta de impuesto"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: selection:wizard.open.tax.balances,target_move:0
|
||||||
|
msgid "All Entries"
|
||||||
|
msgstr "Todos los asientos"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: selection:wizard.open.tax.balances,target_move:0
|
||||||
|
msgid "All Posted Entries"
|
||||||
|
msgstr "Todos los asientos asentados"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_account_tax_balance_regular
|
||||||
|
msgid "Balance"
|
||||||
|
msgstr "Cuota"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_account_tax_balance_refund
|
||||||
|
msgid "Balance Refund"
|
||||||
|
msgstr "Cuota devoluciones"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_account_tax_base_balance_regular
|
||||||
|
msgid "Base Balance"
|
||||||
|
msgstr "Base imponible"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_account_tax_base_balance_refund
|
||||||
|
msgid "Base Balance Refund"
|
||||||
|
msgstr "Base devoluciones"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_tree_balance
|
||||||
|
msgid "Base Total"
|
||||||
|
msgstr "Base total"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.wizard_open_tax_balances
|
||||||
|
msgid "Cancel"
|
||||||
|
msgstr "Cancelar"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances_company_id
|
||||||
|
msgid "Company"
|
||||||
|
msgstr "Compañía"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances_create_uid
|
||||||
|
msgid "Created by"
|
||||||
|
msgstr "Creado por"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances_create_date
|
||||||
|
msgid "Created on"
|
||||||
|
msgstr "Creado en"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances_date_range_id
|
||||||
|
msgid "Date range"
|
||||||
|
msgstr "Periodo"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances_display_name
|
||||||
|
msgid "Display Name"
|
||||||
|
msgstr "Nombre a mostrar"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances_from_date
|
||||||
|
msgid "From date"
|
||||||
|
msgstr "Desde"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_search_balance
|
||||||
|
msgid "Group By"
|
||||||
|
msgstr "Agrupar por"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances_id
|
||||||
|
msgid "ID"
|
||||||
|
msgstr "ID"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances___last_update
|
||||||
|
msgid "Last Modified on"
|
||||||
|
msgstr "Última modificación en"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances_write_uid
|
||||||
|
msgid "Last Updated by"
|
||||||
|
msgstr "Última modificación por"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances_write_date
|
||||||
|
msgid "Last Updated on"
|
||||||
|
msgstr "Última actualización en"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: selection:account.move,move_type:0
|
||||||
|
msgid "Liquidity"
|
||||||
|
msgstr "Liquidez"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_account_move_move_type
|
||||||
|
msgid "Move type"
|
||||||
|
msgstr "Tipo de operación"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.wizard_open_tax_balances
|
||||||
|
msgid "Open Taxes"
|
||||||
|
msgstr "Ver impuestos"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: selection:account.move,move_type:0
|
||||||
|
msgid "Other"
|
||||||
|
msgstr "Otro"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: selection:account.move,move_type:0
|
||||||
|
msgid "Payable"
|
||||||
|
msgstr "A pagar"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: selection:account.move,move_type:0
|
||||||
|
msgid "Payable refund"
|
||||||
|
msgstr "Devoluciones a cobrar"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: selection:account.move,move_type:0
|
||||||
|
msgid "Receivable"
|
||||||
|
msgstr "A cobrar"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: selection:account.move,move_type:0
|
||||||
|
msgid "Receivable refund"
|
||||||
|
msgstr "Devoluciones a pagar"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_search_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_tree_balance
|
||||||
|
msgid "Short Name"
|
||||||
|
msgstr "Nombre corto"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances_target_move
|
||||||
|
msgid "Target Moves"
|
||||||
|
msgstr "Movimientos destino"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model,name:account_tax_balance.model_account_tax
|
||||||
|
msgid "Tax"
|
||||||
|
msgstr "Impuesto"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_search_balance
|
||||||
|
msgid "Tax Group"
|
||||||
|
msgstr "Grupo del impuesto"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_search_balance
|
||||||
|
msgid "Tax Scope"
|
||||||
|
msgstr "Uso del impuesto"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.actions.act_window,name:account_tax_balance.action_open_tax_balances
|
||||||
|
#: model:ir.actions.act_window,name:account_tax_balance.action_tax_balances_tree
|
||||||
|
#: model:ir.ui.menu,name:account_tax_balance.menu_action_open_tax_balances
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.wizard_open_tax_balances
|
||||||
|
msgid "Taxes Balance"
|
||||||
|
msgstr "Tabla de impuestos"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_wizard_open_tax_balances_to_date
|
||||||
|
msgid "To date"
|
||||||
|
msgstr "Hasta"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_tree_balance
|
||||||
|
msgid "Total"
|
||||||
|
msgstr "Total"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_account_tax_balance
|
||||||
|
msgid "Total Balance"
|
||||||
|
msgstr "Total cuota"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model.fields,field_description:account_tax_balance.field_account_tax_base_balance
|
||||||
|
msgid "Total Base Balance"
|
||||||
|
msgstr "Total base imponible"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_tree_balance
|
||||||
|
msgid "View base lines"
|
||||||
|
msgstr "Ver líneas de base imponible"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_tree_balance
|
||||||
|
msgid "View base refund lines"
|
||||||
|
msgstr "Ver líneas de base imponible de devoluciones"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_tree_balance
|
||||||
|
msgid "View base regular lines"
|
||||||
|
msgstr "Ver líneas de base imponible de operaciones corrientes"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_tree_balance
|
||||||
|
msgid "View tax lines"
|
||||||
|
msgstr "Ver líneas de cuota"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_tree_balance
|
||||||
|
msgid "View tax refund lines"
|
||||||
|
msgstr "Ver líneas de cuota de devoluciones"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.view_tax_tree_balance
|
||||||
|
msgid "View tax regular lines"
|
||||||
|
msgstr "Ver líneas de cuota de operaciones corrientes"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.ui.view,arch_db:account_tax_balance.wizard_open_tax_balances
|
||||||
|
msgid "or"
|
||||||
|
msgstr "o"
|
||||||
|
|
||||||
|
#. module: account_tax_balance
|
||||||
|
#: model:ir.model,name:account_tax_balance.model_wizard_open_tax_balances
|
||||||
|
msgid "wizard.open.tax.balances"
|
||||||
|
msgstr "wizard.open.tax.balances"
|
|
@ -2,4 +2,5 @@
|
||||||
# © 2016 Lorenzo Battistini - Agile Business Group
|
# © 2016 Lorenzo Battistini - Agile Business Group
|
||||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
from . import account_move
|
||||||
from . import account_tax
|
from . import account_tax
|
||||||
|
|
|
@ -0,0 +1,42 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# © 2016 Antonio Espinosa <antonio.espinosa@tecnativa.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
from openerp import models, fields, api
|
||||||
|
|
||||||
|
|
||||||
|
class AccountMove(models.Model):
|
||||||
|
_inherit = 'account.move'
|
||||||
|
|
||||||
|
move_type = fields.Selection(
|
||||||
|
string="Move type", selection=[
|
||||||
|
('other', 'Other'),
|
||||||
|
('liquidity', 'Liquidity'),
|
||||||
|
('receivable', 'Receivable'),
|
||||||
|
('receivable_refund', 'Receivable refund'),
|
||||||
|
('payable', 'Payable'),
|
||||||
|
('payable_refund', 'Payable refund'),
|
||||||
|
], compute='_compute_move_type', store=True, readonly=True)
|
||||||
|
|
||||||
|
@api.multi
|
||||||
|
@api.depends('line_ids.account_id.internal_type', 'line_ids.balance')
|
||||||
|
def _compute_move_type(self):
|
||||||
|
def _balance_get(line_ids, internal_type):
|
||||||
|
return sum(line_ids.filtered(
|
||||||
|
lambda x: x.account_id.internal_type == internal_type).mapped(
|
||||||
|
'balance'))
|
||||||
|
|
||||||
|
for move in self:
|
||||||
|
internal_types = move.line_ids.mapped('account_id.internal_type')
|
||||||
|
if 'liquidity' in internal_types:
|
||||||
|
move.move_type = 'liquidity'
|
||||||
|
elif 'payable' in internal_types:
|
||||||
|
balance = _balance_get(move.line_ids, 'payable')
|
||||||
|
move.move_type = (
|
||||||
|
'payable' if balance < 0 else 'payable_refund')
|
||||||
|
elif 'receivable' in internal_types:
|
||||||
|
balance = _balance_get(move.line_ids, 'receivable')
|
||||||
|
move.move_type = (
|
||||||
|
'receivable' if balance > 0 else 'receivable_refund')
|
||||||
|
else:
|
||||||
|
move.move_type = 'other'
|
|
@ -1,16 +1,68 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
# © 2016 Lorenzo Battistini - Agile Business Group
|
# © 2016 Lorenzo Battistini - Agile Business Group
|
||||||
|
# © 2016 Antonio Espinosa <antonio.espinosa@tecnativa.com>
|
||||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
from openerp import models, fields, api
|
from openerp import models, fields, api
|
||||||
|
from openerp.tools.safe_eval import safe_eval
|
||||||
|
|
||||||
|
|
||||||
class AccountTax(models.Model):
|
class AccountTax(models.Model):
|
||||||
_inherit = 'account.tax'
|
_inherit = 'account.tax'
|
||||||
|
|
||||||
balance = fields.Float(string="Balance", compute="_compute_balance")
|
balance = fields.Float(
|
||||||
|
string="Total Balance", compute="_compute_balance",
|
||||||
|
search='_search_balance')
|
||||||
base_balance = fields.Float(
|
base_balance = fields.Float(
|
||||||
string="Base Balance", compute="_compute_balance")
|
string="Total Base Balance", compute="_compute_balance",
|
||||||
|
search='_search_base_balance')
|
||||||
|
balance_regular = fields.Float(
|
||||||
|
string="Balance", compute="_compute_balance",
|
||||||
|
search='_search_balance_regular')
|
||||||
|
base_balance_regular = fields.Float(
|
||||||
|
string="Base Balance", compute="_compute_balance",
|
||||||
|
search='_search_base_balance_regular')
|
||||||
|
balance_refund = fields.Float(
|
||||||
|
string="Balance Refund", compute="_compute_balance",
|
||||||
|
search='_search_balance_refund')
|
||||||
|
base_balance_refund = fields.Float(
|
||||||
|
string="Base Balance Refund", compute="_compute_balance",
|
||||||
|
search='_search_base_balance_refund')
|
||||||
|
|
||||||
|
def _search_balance_field(self, field, operator, value):
|
||||||
|
operators = {'>', '<', '>=', '<=', '!=', '=', '<>'}
|
||||||
|
fields = {
|
||||||
|
'balance', 'base_balance', 'balance_regular',
|
||||||
|
'base_balance_regular', 'balance_refund', 'base_balance_refund',
|
||||||
|
}
|
||||||
|
domain = []
|
||||||
|
if operator in operators and field in fields:
|
||||||
|
value = float(value) if value else 0
|
||||||
|
taxes = self.search([]).filtered(
|
||||||
|
lambda x: safe_eval(
|
||||||
|
'%.2f %s %.2f' % (x[field], operator, value)))
|
||||||
|
domain.append(('id', 'in', taxes.ids))
|
||||||
|
return domain
|
||||||
|
|
||||||
|
def _search_balance(self, operator, value):
|
||||||
|
return self._search_balance_field('balance', operator, value)
|
||||||
|
|
||||||
|
def _search_base_balance(self, operator, value):
|
||||||
|
return self._search_balance_field('base_balance', operator, value)
|
||||||
|
|
||||||
|
def _search_balance_regular(self, operator, value):
|
||||||
|
return self._search_balance_field('balance_regular', operator, value)
|
||||||
|
|
||||||
|
def _search_base_balance_regular(self, operator, value):
|
||||||
|
return self._search_balance_field(
|
||||||
|
'base_balance_regular', operator, value)
|
||||||
|
|
||||||
|
def _search_balance_refund(self, operator, value):
|
||||||
|
return self._search_balance_field('balance_refund', operator, value)
|
||||||
|
|
||||||
|
def _search_base_balance_refund(self, operator, value):
|
||||||
|
return self._search_balance_field(
|
||||||
|
'base_balance_refund', operator, value)
|
||||||
|
|
||||||
def get_context_values(self):
|
def get_context_values(self):
|
||||||
context = self.env.context
|
context = self.env.context
|
||||||
|
@ -23,8 +75,24 @@ class AccountTax(models.Model):
|
||||||
|
|
||||||
def _compute_balance(self):
|
def _compute_balance(self):
|
||||||
for tax in self:
|
for tax in self:
|
||||||
tax.balance = tax.compute_balance(tax_or_base='tax')
|
tax.balance_regular = tax.compute_balance(
|
||||||
tax.base_balance = tax.compute_balance(tax_or_base='base')
|
tax_or_base='tax', move_type='regular')
|
||||||
|
tax.base_balance_regular = tax.compute_balance(
|
||||||
|
tax_or_base='base', move_type='regular')
|
||||||
|
tax.balance_refund = tax.compute_balance(
|
||||||
|
tax_or_base='tax', move_type='refund')
|
||||||
|
tax.base_balance_refund = tax.compute_balance(
|
||||||
|
tax_or_base='base', move_type='refund')
|
||||||
|
tax.balance = tax.balance_regular + tax.balance_refund
|
||||||
|
tax.base_balance = (
|
||||||
|
tax.base_balance_regular + tax.base_balance_refund)
|
||||||
|
|
||||||
|
def get_target_type_list(self, move_type=None):
|
||||||
|
if move_type == 'refund':
|
||||||
|
return ['receivable_refund', 'payable_refund']
|
||||||
|
elif move_type == 'regular':
|
||||||
|
return ['receivable', 'payable']
|
||||||
|
return []
|
||||||
|
|
||||||
def get_target_state_list(self, target_move="posted"):
|
def get_target_state_list(self, target_move="posted"):
|
||||||
if target_move == 'posted':
|
if target_move == 'posted':
|
||||||
|
@ -42,43 +110,53 @@ class AccountTax(models.Model):
|
||||||
('company_id', '=', company_id),
|
('company_id', '=', company_id),
|
||||||
]
|
]
|
||||||
|
|
||||||
def compute_balance(self, tax_or_base='tax'):
|
def compute_balance(self, tax_or_base='tax', move_type=None):
|
||||||
self.ensure_one()
|
self.ensure_one()
|
||||||
move_lines = self.get_move_lines_domain(tax_or_base=tax_or_base)
|
move_lines = self.get_move_lines_domain(
|
||||||
|
tax_or_base=tax_or_base, move_type=move_type)
|
||||||
# balance is debit - credit whereas on tax return you want to see what
|
# balance is debit - credit whereas on tax return you want to see what
|
||||||
# vat has to be paid so:
|
# vat has to be paid so:
|
||||||
# VAT on sales (credit) - VAT on purchases (debit).
|
# VAT on sales (credit) - VAT on purchases (debit).
|
||||||
total = -sum([l.balance for l in move_lines])
|
total = -sum([l.balance for l in move_lines])
|
||||||
return total
|
return total
|
||||||
|
|
||||||
def get_balance_domain(self, state_list):
|
def get_balance_domain(self, state_list, type_list):
|
||||||
return [
|
domain = [
|
||||||
('move_id.state', 'in', state_list),
|
('move_id.state', 'in', state_list),
|
||||||
('tax_line_id', '=', self.id),
|
('tax_line_id', '=', self.id),
|
||||||
]
|
]
|
||||||
|
if type_list:
|
||||||
|
domain.append(('move_id.move_type', 'in', type_list))
|
||||||
|
return domain
|
||||||
|
|
||||||
def get_base_balance_domain(self, state_list):
|
def get_base_balance_domain(self, state_list, type_list):
|
||||||
return [
|
domain = [
|
||||||
('move_id.state', 'in', state_list),
|
('move_id.state', 'in', state_list),
|
||||||
('tax_ids', 'in', self.id),
|
('tax_ids', 'in', self.id),
|
||||||
]
|
]
|
||||||
|
if type_list:
|
||||||
|
domain.append(('move_id.move_type', 'in', type_list))
|
||||||
|
return domain
|
||||||
|
|
||||||
def get_move_lines_domain(self, tax_or_base='tax'):
|
def get_move_lines_domain(self, tax_or_base='tax', move_type=None):
|
||||||
move_line_model = self.env['account.move.line']
|
move_line_model = self.env['account.move.line']
|
||||||
from_date, to_date, company_id, target_move = self.get_context_values()
|
from_date, to_date, company_id, target_move = self.get_context_values()
|
||||||
state_list = self.get_target_state_list(target_move)
|
state_list = self.get_target_state_list(target_move)
|
||||||
|
type_list = self.get_target_type_list(move_type)
|
||||||
domain = self.get_move_line_partial_domain(
|
domain = self.get_move_line_partial_domain(
|
||||||
from_date, to_date, company_id)
|
from_date, to_date, company_id)
|
||||||
balance_domain = []
|
balance_domain = []
|
||||||
if tax_or_base == 'tax':
|
if tax_or_base == 'tax':
|
||||||
balance_domain = self.get_balance_domain(state_list)
|
balance_domain = self.get_balance_domain(state_list, type_list)
|
||||||
elif tax_or_base == 'base':
|
elif tax_or_base == 'base':
|
||||||
balance_domain = self.get_base_balance_domain(state_list)
|
balance_domain = self.get_base_balance_domain(
|
||||||
|
state_list, type_list)
|
||||||
domain.extend(balance_domain)
|
domain.extend(balance_domain)
|
||||||
return move_line_model.search(domain)
|
return move_line_model.search(domain)
|
||||||
|
|
||||||
def get_lines_action(self, tax_or_base='tax'):
|
def get_lines_action(self, tax_or_base='tax', move_type=None):
|
||||||
move_lines = self.get_move_lines_domain(tax_or_base=tax_or_base)
|
move_lines = self.get_move_lines_domain(
|
||||||
|
tax_or_base=tax_or_base, move_type=move_type)
|
||||||
move_line_ids = [l.id for l in move_lines]
|
move_line_ids = [l.id for l in move_lines]
|
||||||
action = self.env.ref('account.action_account_moves_all_tree')
|
action = self.env.ref('account.action_account_moves_all_tree')
|
||||||
vals = action.read()[0]
|
vals = action.read()[0]
|
||||||
|
@ -95,3 +173,23 @@ class AccountTax(models.Model):
|
||||||
def view_base_lines(self):
|
def view_base_lines(self):
|
||||||
self.ensure_one()
|
self.ensure_one()
|
||||||
return self.get_lines_action(tax_or_base='base')
|
return self.get_lines_action(tax_or_base='base')
|
||||||
|
|
||||||
|
@api.multi
|
||||||
|
def view_tax_regular_lines(self):
|
||||||
|
self.ensure_one()
|
||||||
|
return self.get_lines_action(tax_or_base='tax', move_type='regular')
|
||||||
|
|
||||||
|
@api.multi
|
||||||
|
def view_base_regular_lines(self):
|
||||||
|
self.ensure_one()
|
||||||
|
return self.get_lines_action(tax_or_base='base', move_type='regular')
|
||||||
|
|
||||||
|
@api.multi
|
||||||
|
def view_tax_refund_lines(self):
|
||||||
|
self.ensure_one()
|
||||||
|
return self.get_lines_action(tax_or_base='tax', move_type='refund')
|
||||||
|
|
||||||
|
@api.multi
|
||||||
|
def view_base_refund_lines(self):
|
||||||
|
self.ensure_one()
|
||||||
|
return self.get_lines_action(tax_or_base='base', move_type='refund')
|
||||||
|
|
|
@ -33,9 +33,9 @@ class TestAccountTaxBalance(TransactionCase):
|
||||||
tax_account_id = self.env['account.account'].search(
|
tax_account_id = self.env['account.account'].search(
|
||||||
[('name', '=', 'Tax Paid')], limit=1).id
|
[('name', '=', 'Tax Paid')], limit=1).id
|
||||||
tax = self.env['account.tax'].create({
|
tax = self.env['account.tax'].create({
|
||||||
'name': 'Tax 10.0',
|
'name': 'Tax 10.0%',
|
||||||
'amount': 10.0,
|
'amount': 10.0,
|
||||||
'amount_type': 'fixed',
|
'amount_type': 'percent',
|
||||||
'account_id': tax_account_id,
|
'account_id': tax_account_id,
|
||||||
})
|
})
|
||||||
invoice_account_id = self.env['account.account'].search(
|
invoice_account_id = self.env['account.account'].search(
|
||||||
|
@ -67,8 +67,12 @@ class TestAccountTaxBalance(TransactionCase):
|
||||||
# change the state of invoice to open by clicking Validate button
|
# change the state of invoice to open by clicking Validate button
|
||||||
invoice.signal_workflow('invoice_open')
|
invoice.signal_workflow('invoice_open')
|
||||||
|
|
||||||
self.assertEquals(tax.base_balance, 100)
|
self.assertEquals(tax.base_balance, 100.)
|
||||||
self.assertEquals(tax.balance, 10)
|
self.assertEquals(tax.balance, 10.)
|
||||||
|
self.assertEquals(tax.base_balance_regular, 100.)
|
||||||
|
self.assertEquals(tax.balance_regular, 10.)
|
||||||
|
self.assertEquals(tax.base_balance_refund, 0.)
|
||||||
|
self.assertEquals(tax.balance_refund, 0.)
|
||||||
|
|
||||||
# testing wizard
|
# testing wizard
|
||||||
current_range = self.range.search([
|
current_range = self.range.search([
|
||||||
|
@ -110,3 +114,32 @@ class TestAccountTaxBalance(TransactionCase):
|
||||||
self.assertEqual(state_list, ['posted', 'draft'])
|
self.assertEqual(state_list, ['posted', 'draft'])
|
||||||
state_list = tax.get_target_state_list(target_move='whatever')
|
state_list = tax.get_target_state_list(target_move='whatever')
|
||||||
self.assertEqual(state_list, [])
|
self.assertEqual(state_list, [])
|
||||||
|
|
||||||
|
refund = self.env['account.invoice'].create({
|
||||||
|
'partner_id': self.env.ref('base.res_partner_2').id,
|
||||||
|
'account_id': invoice_account_id,
|
||||||
|
'type': 'out_refund',
|
||||||
|
})
|
||||||
|
|
||||||
|
self.env['account.invoice.line'].create({
|
||||||
|
'product_id': self.env.ref('product.product_product_2').id,
|
||||||
|
'quantity': 1.0,
|
||||||
|
'price_unit': 25.0,
|
||||||
|
'invoice_id': refund.id,
|
||||||
|
'name': 'returned product that cost 25',
|
||||||
|
'account_id': invoice_line_account_id,
|
||||||
|
'invoice_line_tax_ids': [(6, 0, [tax.id])],
|
||||||
|
})
|
||||||
|
refund._onchange_invoice_line_ids()
|
||||||
|
refund._convert_to_write(invoice._cache)
|
||||||
|
self.assertEqual(refund.state, 'draft')
|
||||||
|
|
||||||
|
# change the state of refund to open by clicking Validate button
|
||||||
|
refund.signal_workflow('invoice_open')
|
||||||
|
|
||||||
|
self.assertEquals(tax.base_balance, 75.)
|
||||||
|
self.assertEquals(tax.balance, 7.5)
|
||||||
|
self.assertEquals(tax.base_balance_regular, 100.)
|
||||||
|
self.assertEquals(tax.balance_regular, 10.)
|
||||||
|
self.assertEquals(tax.base_balance_refund, -25.)
|
||||||
|
self.assertEquals(tax.balance_refund, -2.5)
|
||||||
|
|
|
@ -0,0 +1,40 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Copyright 2016 Antonio Espinosa <antonio.espinosa@tecnativa.com>
|
||||||
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). -->
|
||||||
|
<odoo>
|
||||||
|
|
||||||
|
|
||||||
|
<record id="view_move_tree" model="ir.ui.view">
|
||||||
|
<field name="name">Add move type column</field>
|
||||||
|
<field name="model">account.move</field>
|
||||||
|
<field name="inherit_id" ref="account.view_move_tree"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<field name="state" position="after">
|
||||||
|
<field name="move_type"/>
|
||||||
|
</field>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="view_move_form" model="ir.ui.view">
|
||||||
|
<field name="name">Add move type field</field>
|
||||||
|
<field name="model">account.move</field>
|
||||||
|
<field name="inherit_id" ref="account.view_move_form"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<field name="ref" position="after">
|
||||||
|
<field name="move_type"/>
|
||||||
|
</field>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="view_account_move_filter" model="ir.ui.view">
|
||||||
|
<field name="name">Add move type group by</field>
|
||||||
|
<field name="model">account.move</field>
|
||||||
|
<field name="inherit_id" ref="account.view_account_move_filter"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<group expand="0" position="inside">
|
||||||
|
<filter string="Move type" domain="[]" context="{'group_by':'move_type'}"/>
|
||||||
|
</group>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
</odoo>
|
|
@ -1,8 +1,10 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<openerp>
|
<!-- Copyright 2016 Lorenzo Battistini - Agile Business Group
|
||||||
<data>
|
Copyright 2016 Antonio Espinosa <antonio.espinosa@tecnativa.com>
|
||||||
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). -->
|
||||||
|
<odoo>
|
||||||
|
|
||||||
<record id="view_tax_tree_balance" model="ir.ui.view">
|
<record id="view_tax_tree_balance" model="ir.ui.view">
|
||||||
<field name="name">account.tax.tree.balance</field>
|
<field name="name">account.tax.tree.balance</field>
|
||||||
<field name="model">account.tax</field>
|
<field name="model">account.tax</field>
|
||||||
<field eval="100" name="priority"/>
|
<field eval="100" name="priority"/>
|
||||||
|
@ -11,14 +13,29 @@
|
||||||
<field name="name"/>
|
<field name="name"/>
|
||||||
<field name="description" string="Short Name"/>
|
<field name="description" string="Short Name"/>
|
||||||
<field name="account_id"/>
|
<field name="account_id"/>
|
||||||
<field name="balance" sum="Total"></field>
|
<field name="balance_regular" sum="Total"/>
|
||||||
<field name="base_balance" sum="Base Total"></field>
|
<button type="object" name="view_tax_regular_lines"
|
||||||
<button type="object" name="view_tax_lines" string="View tax lines" icon="gtk-find"></button>
|
string="View tax regular lines" icon="fa-search-plus"/>
|
||||||
<button type="object" name="view_base_lines" string="View base lines" icon="gtk-copy"></button>
|
<field name="base_balance_regular" sum="Base Total"/>
|
||||||
|
<button type="object" name="view_base_regular_lines"
|
||||||
|
string="View base regular lines" icon="fa-search-plus"/>
|
||||||
|
<field name="balance_refund" sum="Total"/>
|
||||||
|
<button type="object" name="view_tax_refund_lines"
|
||||||
|
string="View tax refund lines" icon="fa-search-plus"/>
|
||||||
|
<field name="base_balance_refund" sum="Base Total"/>
|
||||||
|
<button type="object" name="view_base_refund_lines"
|
||||||
|
string="View base refund lines" icon="fa-search-plus"/>
|
||||||
|
<field name="balance" sum="Total"/>
|
||||||
|
<button type="object" name="view_tax_lines"
|
||||||
|
string="View tax lines" icon="fa-search-plus"/>
|
||||||
|
<field name="base_balance" sum="Base Total"/>
|
||||||
|
<button type="object" name="view_base_lines"
|
||||||
|
string="View base lines" icon="fa-search-plus"/>
|
||||||
</tree>
|
</tree>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
<record id="view_tax_search_balance" model="ir.ui.view">
|
|
||||||
|
<record id="view_tax_search_balance" model="ir.ui.view">
|
||||||
<field name="name">account.tax.search.balance</field>
|
<field name="name">account.tax.search.balance</field>
|
||||||
<field name="model">account.tax</field>
|
<field name="model">account.tax</field>
|
||||||
<field eval="100" name="priority"/>
|
<field eval="100" name="priority"/>
|
||||||
|
@ -37,13 +54,18 @@
|
||||||
</search>
|
</search>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
<record id="action_tax_balances_tree" model="ir.actions.act_window">
|
|
||||||
|
<record id="action_tax_balances_tree" model="ir.actions.act_window">
|
||||||
<field name="name">Taxes Balance</field>
|
<field name="name">Taxes Balance</field>
|
||||||
<field name="res_model">account.tax</field>
|
<field name="res_model">account.tax</field>
|
||||||
<field name="view_type">form</field>
|
<field name="view_type">form</field>
|
||||||
<field name="view_mode">tree</field>
|
<field name="view_mode">tree</field>
|
||||||
|
<field name="domain">[
|
||||||
|
'|', '|', ('base_balance', '!=', 0), ('base_balance_regular', '!=', 0),
|
||||||
|
'|', '|', ('base_balance_refund', '!=', 0), ('balance', '!=', 0),
|
||||||
|
'|', ('balance_regular', '!=', 0), ('balance_refund', '!=', 0)]</field>
|
||||||
<field name="view_id" ref="view_tax_tree_balance"/>
|
<field name="view_id" ref="view_tax_tree_balance"/>
|
||||||
<field name="search_view_id" ref="view_tax_search_balance"/>
|
<field name="search_view_id" ref="view_tax_search_balance"/>
|
||||||
</record>
|
</record>
|
||||||
</data>
|
|
||||||
</openerp>
|
</odoo>
|
||||||
|
|
|
@ -1,7 +1,9 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<openerp>
|
<!-- Copyright 2016 Lorenzo Battistini - Agile Business Group
|
||||||
<data>
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). -->
|
||||||
<record id="wizard_open_tax_balances" model="ir.ui.view">
|
<odoo>
|
||||||
|
|
||||||
|
<record id="wizard_open_tax_balances" model="ir.ui.view">
|
||||||
<field name="name">wizard_open_tax_balances</field>
|
<field name="name">wizard_open_tax_balances</field>
|
||||||
<field name="model">wizard.open.tax.balances</field>
|
<field name="model">wizard.open.tax.balances</field>
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
|
@ -22,19 +24,19 @@
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<record id="action_open_tax_balances" model="ir.actions.act_window">
|
<record id="action_open_tax_balances" model="ir.actions.act_window">
|
||||||
<field name="name">Taxes Balance</field>
|
<field name="name">Taxes Balance</field>
|
||||||
<field name="res_model">wizard.open.tax.balances</field>
|
<field name="res_model">wizard.open.tax.balances</field>
|
||||||
<field name="view_type">form</field>
|
<field name="view_type">form</field>
|
||||||
<field name="view_mode">form</field>
|
<field name="view_mode">form</field>
|
||||||
<field name="view_id" ref="wizard_open_tax_balances"/>
|
<field name="view_id" ref="wizard_open_tax_balances"/>
|
||||||
<field name="target">new</field>
|
<field name="target">new</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<menuitem
|
<menuitem
|
||||||
action="action_open_tax_balances"
|
action="action_open_tax_balances"
|
||||||
id="menu_action_open_tax_balances"
|
id="menu_action_open_tax_balances"
|
||||||
parent="account.menu_finance_reports"
|
parent="account.menu_finance_reports"
|
||||||
groups="account.group_account_user,account.group_account_manager"></menuitem>
|
groups="account.group_account_user,account.group_account_manager"/>
|
||||||
</data>
|
|
||||||
</openerp>
|
</odoo>
|
||||||
|
|
Loading…
Reference in New Issue