# -*- coding: utf-8 -*- ############################################################################## # # OpenERP, Open Source Management Solution # Copyright (C) 2004-2010 Tiny SPRL (). # # 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 . # ############################################################################## from osv import fields, osv class report_menu_create(osv.osv_memory): """ Create Menu """ _name = "report.menu.create" _description = "Menu Create" _columns = { 'menu_name':fields.char('Menu Name', size=64, required=True), 'menu_parent_id':fields.many2one('ir.ui.menu', 'Parent Menu', required=True), } def report_menu_create(self, cr, uid, ids, context=None): """ Create Menu. @param cr: the current row, from the database cursor, @param uid: the current user’s ID for security checks, @param ids: List of Report Menu Create's IDs @return: Dictionary {}. """ if context is None: context = {} context_id = context and context.get('active_id', False) or False obj_menu = self.pool.get('ir.ui.menu') data_obj = self.pool.get('ir.model.data') obj_board = self.pool.get('base_report_creator.report') if context_id: data = self.browse(cr, uid, ids, context=context) if not data: return {} data = data[0] board = obj_board.browse(cr, uid, context_id, context=context) view = board.view_type1 if board.view_type2: view += ',' + board.view_type2 if board.view_type3: view += ',' + board.view_type3 result = data_obj._get_id(cr, uid, 'base_report_creator', 'view_report_filter') res = data_obj.read(cr, uid, result, ['res_id']) action_id = self.pool.get('ir.actions.act_window').create(cr, uid, { 'name': board.name, 'view_type':'form', 'view_mode':view, 'context': "{'report_id':%d}" % (board.id,), 'res_model': 'base_report_creator.report', 'search_view_id': res['res_id'] }) menu_id = obj_menu.create(cr, uid, { 'name': data.menu_name, 'parent_id': data.menu_parent_id.id, 'icon': 'STOCK_SELECT_COLOR', 'action': 'ir.actions.act_window, ' + str(action_id) }, context=context) obj_board.write(cr, uid, context_id, {'menu_id': menu_id}) return {} report_menu_create() # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: