[MERGE] forward port of branch 7.0 up to de07c64
[odoo/odoo.git] / addons / account / wizard / account_move_bank_reconcile.py
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
22 from openerp.osv import fields, osv
23 from openerp.tools.translate import _
24
25 class account_move_bank_reconcile(osv.osv_memory):
26     """
27         Bank Reconciliation
28     """
29     _name = "account.move.bank.reconcile"
30     _description = "Move bank reconcile"
31     _columns = {
32        'journal_id': fields.many2one('account.journal', 'Journal', required=True),
33     }
34
35     def action_open_window(self, cr, uid, ids, context=None):
36         """
37        @param cr: the current row, from the database cursor,
38        @param uid: the current user’s ID for security checks,
39        @param ids: account move bank reconcile’s ID or list of IDs
40        @return: dictionary of  Open  account move line   on given journal_id.
41         """
42         if context is None:
43             context = {}
44         data = self.read(cr, uid, ids, context=context)[0]
45         cr.execute('select default_credit_account_id \
46                         from account_journal where id=%s', (data['journal_id'],))
47         account_id = cr.fetchone()[0]
48         if not account_id:
49              raise osv.except_osv(_('Error!'), _('You have to define \
50 the bank account\nin the journal definition for reconciliation.'))
51         return {
52             'domain': "[('journal_id','=',%d), ('account_id','=',%d), ('state','<>','draft')]" % (data['journal_id'], account_id),
53             'name': _('Standard Encoding'),
54             'view_type': 'form',
55             'view_mode': 'tree,form',
56             'res_model': 'account.move.line',
57             'view_id': False,
58             'context': "{'journal_id': %d}" % (data['journal_id'],),
59             'type': 'ir.actions.act_window'
60              }
61
62
63 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: