Browse Source

[IMP] Ease extension if multicompany fiscal unit

pull/736/head
Andrea 5 years ago
committed by Francisco Ivan Anton Prieto
parent
commit
6a86916765
  1. 2
      account_tax_balance/__manifest__.py
  2. 20
      account_tax_balance/models/account_tax.py

2
account_tax_balance/__manifest__.py

@ -6,7 +6,7 @@
{ {
"name": "Tax Balance", "name": "Tax Balance",
"summary": "Compute tax balances based on date range", "summary": "Compute tax balances based on date range",
"version": "12.0.1.1.0",
"version": "12.0.2.0.0",
"category": "Invoices & Payments", "category": "Invoices & Payments",
"website": "https://github.com/OCA/account-financial-reporting", "website": "https://github.com/OCA/account-financial-reporting",
"author": "Agile Business Group, Therp BV, Tecnativa, ACSONE SA/NV, " "author": "Agile Business Group, Therp BV, Tecnativa, ACSONE SA/NV, "

20
account_tax_balance/models/account_tax.py

@ -37,7 +37,7 @@ class AccountTax(models.Model):
return ( return (
context.get('from_date', fields.Date.context_today(self)), context.get('from_date', fields.Date.context_today(self)),
context.get('to_date', fields.Date.context_today(self)), context.get('to_date', fields.Date.context_today(self)),
context.get('company_id', self.env.user.company_id.id),
context.get('company_ids', [self.env.user.company_id.id]),
context.get('target_move', 'posted'), context.get('target_move', 'posted'),
) )
@ -49,17 +49,19 @@ class AccountTax(models.Model):
Caveat: this ignores record rules and ACL but it is good Caveat: this ignores record rules and ACL but it is good
enough for filtering taxes with activity during the period. enough for filtering taxes with activity during the period.
""" """
from_date, to_date, company_ids, _ = self.get_context_values()
company_ids = tuple(company_ids)
req = """ req = """
SELECT id SELECT id
FROM account_tax at FROM account_tax at
WHERE WHERE
company_id = %s AND
company_id in %s AND
EXISTS ( EXISTS (
SELECT 1 FROM account_move_Line aml SELECT 1 FROM account_move_Line aml
WHERE WHERE
date >= %s AND date >= %s AND
date <= %s AND date <= %s AND
company_id = %s AND (
company_id in %s AND (
tax_line_id = at.id OR tax_line_id = at.id OR
EXISTS ( EXISTS (
SELECT 1 FROM account_move_line_account_tax_rel SELECT 1 FROM account_move_line_account_tax_rel
@ -69,9 +71,8 @@ class AccountTax(models.Model):
) )
) )
""" """
from_date, to_date, company_id, target_move = self.get_context_values()
self.env.cr.execute( self.env.cr.execute(
req, (company_id, from_date, to_date, company_id))
req, (company_ids, from_date, to_date, company_ids))
return [r[0] for r in self.env.cr.fetchall()] return [r[0] for r in self.env.cr.fetchall()]
@api.multi @api.multi
@ -121,11 +122,11 @@ class AccountTax(models.Model):
state = [] state = []
return state return state
def get_move_line_partial_domain(self, from_date, to_date, company_id):
def get_move_line_partial_domain(self, from_date, to_date, company_ids):
return [ return [
('date', '<=', to_date), ('date', '<=', to_date),
('date', '>=', from_date), ('date', '>=', from_date),
('company_id', '=', company_id),
('company_id', 'in', company_ids),
] ]
def compute_balance(self, tax_or_base='tax', move_type=None): def compute_balance(self, tax_or_base='tax', move_type=None):
@ -161,11 +162,12 @@ class AccountTax(models.Model):
return domain return domain
def get_move_lines_domain(self, tax_or_base='tax', move_type=None): def get_move_lines_domain(self, tax_or_base='tax', move_type=None):
from_date, to_date, company_id, target_move = self.get_context_values()
from_date, to_date, company_ids, 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) 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_ids)
balance_domain = [] balance_domain = []
if tax_or_base == 'tax': if tax_or_base == 'tax':
balance_domain = self.get_balance_domain(state_list, type_list) balance_domain = self.get_balance_domain(state_list, type_list)

Loading…
Cancel
Save