You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
64 lines
2.2 KiB
64 lines
2.2 KiB
# Copyright 2018 Forest and Biomass Romania
|
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
|
|
|
|
from odoo import _, models
|
|
|
|
|
|
class VATReportXslx(models.AbstractModel):
|
|
_name = 'report.a_f_r.report_vat_report_xlsx'
|
|
_inherit = 'report.account_financial_report.abstract_report_xlsx'
|
|
|
|
def _get_report_name(self, report, data):
|
|
company_id = data.get('company_id', False)
|
|
report_name = _('Vat Report')
|
|
if company_id:
|
|
company = self.env['res.company'].browse(company_id)
|
|
suffix = ' - %s - %s' % (
|
|
company.name, company.currency_id.name)
|
|
report_name = report_name + suffix
|
|
return report_name
|
|
|
|
def _get_report_columns(self, report):
|
|
return {
|
|
0: {'header': _('Code'), 'field': 'code', 'width': 5},
|
|
1: {'header': _('Name'), 'field': 'name', 'width': 100},
|
|
2: {'header': _('Net'),
|
|
'field': 'net',
|
|
'type': 'amount',
|
|
'width': 14},
|
|
3: {'header': _('Tax'),
|
|
'field': 'tax',
|
|
'type': 'amount',
|
|
'width': 14},
|
|
}
|
|
|
|
def _get_report_filters(self, report):
|
|
return [
|
|
[_('Date from'), report.date_from.strftime("%d/%m/%Y")],
|
|
[_('Date to'), report.date_to.strftime("%d/%m/%Y")],
|
|
[_('Based on'), _('Tax Tags') if report.based_on == 'taxtags'else
|
|
_('Tax Groups')]
|
|
]
|
|
|
|
def _get_col_count_filter_name(self):
|
|
return 0
|
|
|
|
def _get_col_count_filter_value(self):
|
|
return 2
|
|
|
|
def _generate_report_content(self, workbook, report, data):
|
|
res_data = self.env[
|
|
'report.account_financial_report.vat_report'
|
|
]._get_report_values(report, data)
|
|
vat_report = res_data['vat_report']
|
|
tax_detail = res_data['tax_detail']
|
|
# For each tax_tag tax_group
|
|
self.write_array_header()
|
|
for tag_or_group in vat_report:
|
|
# Write taxtag line
|
|
self.write_line_from_dict(tag_or_group)
|
|
|
|
# For each tax if detail taxes
|
|
if tax_detail:
|
|
for tax in tag_or_group['taxes']:
|
|
self.write_line_from_dict(tax)
|