~tempo-openerp/+junk/loewert-prod

« back to all changes in this revision

Viewing changes to addons/account/project/wizard/account_analytic_journal_report.py

  • Committer: jbe at tempo-consulting
  • Date: 2013-08-21 08:48:11 UTC
  • Revision ID: jbe@tempo-consulting.fr-20130821084811-913uo4l7b5ayxq8m
[NEW] Création de la branche trunk Loewert

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# -*- coding: utf-8 -*-
 
2
##############################################################################
 
3
#
 
4
#    OpenERP, Open Source Management Solution
 
5
#    Copyright (C) 2004-2010 Tiny SPRL (<http://tiny.be>).
 
6
#
 
7
#    This program is free software: you can redistribute it and/or modify
 
8
#    it under the terms of the GNU Affero General Public License as
 
9
#    published by the Free Software Foundation, either version 3 of the
 
10
#    License, or (at your option) any later version.
 
11
#
 
12
#    This program is distributed in the hope that it will be useful,
 
13
#    but WITHOUT ANY WARRANTY; without even the implied warranty of
 
14
#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
15
#    GNU Affero General Public License for more details.
 
16
#
 
17
#    You should have received a copy of the GNU Affero General Public License
 
18
#    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
19
#
 
20
##############################################################################
 
21
import time
 
22
 
 
23
from openerp.osv import fields, osv
 
24
 
 
25
class account_analytic_journal_report(osv.osv_memory):
 
26
    _name = 'account.analytic.journal.report'
 
27
    _description = 'Account Analytic Journal'
 
28
 
 
29
    _columns = {
 
30
        'date1': fields.date('Start of period', required=True),
 
31
        'date2': fields.date('End of period', required=True),
 
32
        'analytic_account_journal_id': fields.many2many('account.analytic.journal', 'account_analytic_journal_name', 'journal_line_id', 'journal_print_id', 'Analytic Journals', required=True),
 
33
    }
 
34
 
 
35
    _defaults = {
 
36
        'date1': lambda *a: time.strftime('%Y-01-01'),
 
37
        'date2': lambda *a: time.strftime('%Y-%m-%d')
 
38
    }
 
39
 
 
40
    def check_report(self, cr, uid, ids, context=None):
 
41
        if context is None:
 
42
            context = {}
 
43
        data = self.read(cr, uid, ids)[0]
 
44
        ids_list = []
 
45
        if context.get('active_id',False):
 
46
            ids_list.append(context.get('active_id',False))
 
47
        else:
 
48
            record = self.browse(cr,uid,ids[0],context=context)
 
49
            for analytic_record in record.analytic_account_journal_id:
 
50
                ids_list.append(analytic_record.id)
 
51
        datas = {
 
52
             'ids': ids_list,
 
53
             'model': 'account.analytic.journal',
 
54
             'form': data
 
55
                 }
 
56
        return {
 
57
            'type': 'ir.actions.report.xml',
 
58
            'report_name': 'account.analytic.journal',
 
59
            'datas': datas,
 
60
            }
 
61
        
 
62
    def default_get(self, cr, uid, fields, context=None):
 
63
        if context is None:
 
64
            context = {}
 
65
        res = super(account_analytic_journal_report, self).default_get(cr, uid, fields, context=context)
 
66
        if not context.has_key('active_ids'):
 
67
            journal_ids = self.pool.get('account.analytic.journal').search(cr, uid, [], context=context)
 
68
        else:
 
69
            journal_ids = context.get('active_ids')
 
70
        if 'analytic_account_journal_id' in fields:
 
71
            res.update({'analytic_account_journal_id': journal_ids})
 
72
        return res
 
73
 
 
74
account_analytic_journal_report()
 
75
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: