Initial import from Docker volume
This commit is contained in:
147
modules/account_be/account.py
Executable file
147
modules/account_be/account.py
Executable file
@@ -0,0 +1,147 @@
|
||||
# This file is part of Tryton. The COPYRIGHT file at the top level of
|
||||
# this repository contains the full copyright notices and license terms.
|
||||
from sql import Literal
|
||||
from sql.aggregate import Max, Min, Sum
|
||||
|
||||
from trytond.model import ModelSQL, ModelView, fields
|
||||
from trytond.modules.account.exceptions import FiscalYearNotFoundError
|
||||
from trytond.modules.currency.fields import Monetary
|
||||
from trytond.pool import Pool, PoolMeta
|
||||
from trytond.pyson import Eval
|
||||
from trytond.transaction import Transaction
|
||||
|
||||
|
||||
class CreateChart(metaclass=PoolMeta):
|
||||
__name__ = 'account.create_chart'
|
||||
|
||||
def default_properties(self, fields):
|
||||
pool = Pool()
|
||||
ModelData = pool.get('ir.model.data')
|
||||
defaults = super().default_properties(fields)
|
||||
for lang in ['fr', 'nl']:
|
||||
try:
|
||||
template_id = ModelData.get_id('account_be.root_' + lang)
|
||||
except KeyError:
|
||||
continue
|
||||
if self.account.account_template.id == template_id:
|
||||
defaults['account_receivable'] = self.get_account(
|
||||
'account_be.400_' + lang)
|
||||
defaults['account_payable'] = self.get_account(
|
||||
'account_be.440_' + lang)
|
||||
break
|
||||
return defaults
|
||||
|
||||
|
||||
class BEVATCustomer(ModelSQL, ModelView):
|
||||
"Belgium VAT Customer"
|
||||
__name__ = 'account.be.vat_customer'
|
||||
|
||||
company_tax_identifier = fields.Many2One(
|
||||
'party.identifier', "Company Tax Identifier")
|
||||
party_tax_identifier = fields.Many2One(
|
||||
'party.identifier', "Party Tax Identifier")
|
||||
turnover = Monetary("Turnover", currency='currency', digits='currency')
|
||||
vat = Monetary("VAT", currency='currency', digits='currency')
|
||||
currency = fields.Many2One('currency.currency', "Currency")
|
||||
|
||||
@classmethod
|
||||
def tax_groups(cls):
|
||||
for group in ['group_tva_vente_biens', 'group_tva_vente_services',
|
||||
'tva_vente_biens_coco', 'tva_vente_services_coco']:
|
||||
for lang in ['fr', 'nl']:
|
||||
yield 'account_be', '%s_%s' % (group, lang)
|
||||
|
||||
@classmethod
|
||||
def table_query(cls):
|
||||
pool = Pool()
|
||||
Identifier = pool.get('party.identifier')
|
||||
Invoice = pool.get('account.invoice')
|
||||
InvoiceTax = pool.get('account.invoice.tax')
|
||||
ModelData = pool.get('ir.model.data')
|
||||
Move = pool.get('account.move')
|
||||
Period = pool.get('account.period')
|
||||
Tax = pool.get('account.tax')
|
||||
context = Transaction().context
|
||||
company_identifier = Identifier.__table__()
|
||||
party_identifier = Identifier.__table__()
|
||||
invoice = Invoice.__table__()
|
||||
invoice_tax = InvoiceTax.__table__()
|
||||
move = Move.__table__()
|
||||
period = Period.__table__()
|
||||
tax = Tax.__table__()
|
||||
|
||||
groups = []
|
||||
for module, fs_id in cls.tax_groups():
|
||||
try:
|
||||
groups.append(ModelData.get_id(module, fs_id))
|
||||
except KeyError:
|
||||
# table_query can be called before the XML is loaded
|
||||
continue
|
||||
|
||||
where = ((invoice.company == context.get('company'))
|
||||
& (period.fiscalyear == context.get('fiscalyear')))
|
||||
where &= invoice.type == 'out'
|
||||
where &= ((company_identifier.code.ilike('BE%')
|
||||
& (company_identifier.type == 'eu_vat'))
|
||||
| (company_identifier.type == 'be_vat'))
|
||||
where &= ((party_identifier.code.ilike('BE%')
|
||||
& (party_identifier.type == 'eu_vat'))
|
||||
| (party_identifier.type == 'be_vat'))
|
||||
where &= tax.group.in_(groups)
|
||||
return (invoice_tax
|
||||
.join(invoice,
|
||||
condition=invoice_tax.invoice == invoice.id)
|
||||
.join(tax, condition=invoice_tax.tax == tax.id)
|
||||
.join(move, condition=invoice.move == move.id)
|
||||
.join(period, condition=move.period == period.id)
|
||||
.join(company_identifier,
|
||||
condition=invoice.tax_identifier == company_identifier.id)
|
||||
.join(party_identifier,
|
||||
condition=invoice.party_tax_identifier == party_identifier.id)
|
||||
.select(
|
||||
Max(invoice_tax.id).as_('id'),
|
||||
Literal(0).as_('create_uid'),
|
||||
Min(invoice_tax.create_date).as_('create_date'),
|
||||
Literal(0).as_('write_uid'),
|
||||
Max(invoice_tax.write_date).as_('write_date'),
|
||||
invoice.tax_identifier.as_('company_tax_identifier'),
|
||||
invoice.party_tax_identifier.as_('party_tax_identifier'),
|
||||
Sum(invoice_tax.base).as_('turnover'),
|
||||
Sum(invoice_tax.amount).as_('vat'),
|
||||
invoice.currency.as_('currency'),
|
||||
where=where,
|
||||
group_by=[
|
||||
invoice.tax_identifier,
|
||||
invoice.party_tax_identifier,
|
||||
invoice.currency,
|
||||
]))
|
||||
|
||||
|
||||
class BEVATCustomerContext(ModelView):
|
||||
"Belgium VAT Customer Context"
|
||||
__name__ = 'account.be.vat_customer.context'
|
||||
|
||||
company = fields.Many2One('company.company', "Company", required=True)
|
||||
fiscalyear = fields.Many2One(
|
||||
'account.fiscalyear', "Fiscal Year", required=True,
|
||||
domain=[
|
||||
('company', '=', Eval('company')),
|
||||
])
|
||||
|
||||
@classmethod
|
||||
def default_company(cls):
|
||||
return Transaction().context.get('company')
|
||||
|
||||
@classmethod
|
||||
def default_fiscalyear(cls):
|
||||
pool = Pool()
|
||||
FiscalYear = pool.get('account.fiscalyear')
|
||||
context = Transaction().context
|
||||
if 'fiscalyear' not in context:
|
||||
try:
|
||||
fiscalyear = FiscalYear.find(
|
||||
cls.default_company(), test_state=False)
|
||||
except FiscalYearNotFoundError:
|
||||
return None
|
||||
return fiscalyear.id
|
||||
return context['fiscalyear']
|
||||
Reference in New Issue
Block a user