|
|
# -*- coding: utf-8 -*- ############################################################################## # # OpenERP, Open Source Management Solution # Copyright (C) 2004-2010 Tiny SPRL (<http://tiny.be>). # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as # published by the Free Software Foundation, either version 3 of the # License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see <http://www.gnu.org/licenses/>. # ##############################################################################
from osv import osv, fields from tools.translate import _
class account_bs_report(osv.osv_memory): """
This wizard will provide the account balance sheet report by periods, between any two dates. """
_name = 'account.bs.report' _inherit = "account_report_alt.common.account.report" _description = 'Account Balance Sheet Report'
def _get_def_reserve_account(self, cr, uid, context=None): chart_id = self._get_account(cr, uid, context=context) res = self.onchange_chart_id(cr, uid, [], chart_id, context=context) if not res: return False return res['value']['reserve_account_id']
_columns = { 'display_type': fields.boolean("Landscape Mode"), 'reserve_account_id': fields.many2one('account.account', 'Reserve & Profit/Loss Account', required=True, help='This Account is used for transfering Profit/Loss ' \ '(Profit: Amount will be added, Loss: Amount will be duducted), ' \ 'which is calculated from Profilt & Loss Report', domain = [('type','=','other')]), }
_defaults={ 'display_type': True, 'journal_ids': [], 'reserve_account_id': _get_def_reserve_account, }
def onchange_chart_id(self, cr, uid, ids, chart_id, context=None): if not chart_id: return {} account = self.pool.get('account.account').browse(cr, uid, chart_id , context=context) if not account.company_id.property_reserve_and_surplus_account: return {'value': {'reserve_account_id': False}} return {'value': {'reserve_account_id': account.company_id.property_reserve_and_surplus_account.id}}
def _print_report(self, cr, uid, ids, data, context=None): if context is None: context = {} data['form'].update(self.read(cr, uid, ids, ['display_type','reserve_account_id'])[0]) if not data['form']['reserve_account_id']: raise osv.except_osv(_('Warning'),_('Please define the Reserve and Profit/Loss account for current user company !')) data = self.pre_print_report(cr, uid, ids, data, context=context) if data['form']['display_type']: return { 'type': 'ir.actions.report.xml', 'report_name': 'account.balancesheet.horizontal', 'datas': data, } else: return { 'type': 'ir.actions.report.xml', 'report_name': 'account.balancesheet', 'datas': data, }
account_bs_report()
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|