############################################################################## # # Copyright (c) 2004-2008 TINY SPRL. (http://tiny.be) All Rights Reserved. # # $Id$ # # WARNING: This program as such is intended to be used by professional # programmers who take the whole responsability of assessing all potential # consequences resulting from its eventual inadequacies and bugs # End users who are looking for a ready-to-use solution with commercial # garantees and support are strongly adviced to contract a Free Software # Service Company # # This program is Free Software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # 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 General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. # ############################################################################## import time from osv import fields,osv class board_board(osv.osv): _name = 'board.board' def create(self, cr, user, vals, context=None): if not 'name' in vals: return False return super(board_board, self).create(cr, user, vals, context) def fields_view_get(self, cr, user, view_id=None, view_type='form', context=None, toolbar=False): if context and ('view' in context): board = self.pool.get('board.board').browse(cr, user, int(context['view']), context) left = [] right = [] for line in board.line_ids: linestr = ' %s %s """ % ('\n'.join(left), '\n'.join(right)) result = { 'toolbar': {'print':[],'action':[],'relate':[]}, 'fields': {}, 'arch': arch } return result res = super(board_board, self).fields_view_get(cr, user, view_id, view_type, context, toolbar) res['toolbar'] = {'print':[],'action':[],'relate':[]} return res _columns = { 'name': fields.char('Dashboard', size=64, required=True), 'line_ids': fields.one2many('board.board.line', 'board_id', 'Action Views') } board_board() class board_line(osv.osv): _name = 'board.board.line' _order = 'position,sequence' _columns = { 'name': fields.char('Board', size=64, required=True), 'sequence': fields.integer('Sequence'), 'height': fields.integer('Height'), 'width': fields.integer('Width'), 'board_id': fields.many2one('board.board', 'Dashboard', required=True, ondelete='cascade'), 'action_id': fields.many2one('ir.actions.act_window', 'Action', required=True), 'position': fields.selection([('left','Left'),('right','Right')], 'Position', required=True) } _defaults = { 'position': lambda *args: 'left' } board_line() class board_note_type(osv.osv): _name = 'board.note.type' _columns = { 'name': fields.char('Note Type', size=64, required=True), } board_note_type() def _type_get(self, cr, uid, context={}): obj = self.pool.get('board.note.type') ids = obj.search(cr, uid, []) res = obj.read(cr, uid, ids, ['name'], context) res = [(r['name'], r['name']) for r in res] return res class board_note(osv.osv): _name = 'board.note' _columns = { 'name': fields.char('Subject', size=128, required=True), 'note': fields.text('Note'), 'user_id': fields.many2one('res.users', 'Author', size=64), 'date': fields.date('Date', size=64, required=True), 'type': fields.selection(_type_get, 'Note type', size=64), } _defaults = { 'user_id': lambda object,cr,uid,context: uid, 'date': lambda object,cr,uid,context: time.strftime('%Y-%m-%d'), } board_note()