24 lines
1.3 KiB
Python
24 lines
1.3 KiB
Python
|
# -*- coding: utf-8 -*-
|
||
|
|
||
|
from odoo import fields, models, _
|
||
|
from odoo.exceptions import UserError
|
||
|
|
||
|
|
||
|
class AccountReportGeneralLedger(models.TransientModel):
|
||
|
_inherit = "account.common.account.report"
|
||
|
_name = "account.report.general.ledger"
|
||
|
_description = "General Ledger Report"
|
||
|
|
||
|
initial_balance = fields.Boolean(string='Include Initial Balances',
|
||
|
help='If you selected date, this field allow you to add a row to display the amount of debit/credit/balance that precedes the filter you\'ve set.')
|
||
|
sortby = fields.Selection([('sort_date', 'Date'), ('sort_journal_partner', 'Journal & Partner')], string='Sort by', required=True, default='sort_date')
|
||
|
journal_ids = fields.Many2many('account.journal', 'account_report_general_ledger_journal_rel', 'account_id', 'journal_id', string='Journals', required=True)
|
||
|
|
||
|
def _print_report(self, data):
|
||
|
data = self.pre_print_report(data)
|
||
|
data['form'].update(self.read(['initial_balance', 'sortby'])[0])
|
||
|
if data['form'].get('initial_balance') and not data['form'].get('date_from'):
|
||
|
raise UserError(_("You must define a Start Date"))
|
||
|
records = self.env[data['model']].browse(data.get('ids', []))
|
||
|
return self.env['report'].with_context(landscape=True).get_action(records, 'account.report_generalledger', data=data)
|