Launchpad automatic translations update.
[odoo/odoo.git] / addons / account / wizard / account_fiscalyear_close_state.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_fiscalyear_close_state(osv.osv_memory):
26     """
27     Closes  Account Fiscalyear
28     """
29     _name = "account.fiscalyear.close.state"
30     _description = "Fiscalyear Close state"
31     _columns = {
32        'fy_id': fields.many2one('account.fiscalyear', \
33                                  'Fiscal Year to Close', required=True, help="Select a fiscal year to close"),
34     }
35
36     def data_save(self, cr, uid, ids, context=None):
37         """
38         This function close account fiscalyear
39         @param cr: the current row, from the database cursor,
40         @param uid: the current user’s ID for security checks,
41         @param ids: List of Account fiscalyear close state’s IDs
42
43         """
44         for data in  self.read(cr, uid, ids, context=context):
45             fy_id = data['fy_id'][0]
46
47             cr.execute('UPDATE account_journal_period ' \
48                         'SET state = %s ' \
49                         'WHERE period_id IN (SELECT id FROM account_period \
50                         WHERE fiscalyear_id = %s)',
51                     ('done', fy_id))
52             cr.execute('UPDATE account_period SET state = %s ' \
53                     'WHERE fiscalyear_id = %s', ('done', fy_id))
54             cr.execute('UPDATE account_fiscalyear ' \
55                     'SET state = %s WHERE id = %s', ('done', fy_id))
56
57             return {'type': 'ir.actions.act_window_close'}
58
59 account_fiscalyear_close_state()
60
61 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: