You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
150 lines
6.0 KiB
150 lines
6.0 KiB
# -*- coding: utf-8 -*-
|
|
##############################################################################
|
|
#
|
|
# This module uses OpenERP, Open Source Management Solution Framework.
|
|
# Copyright (C):
|
|
# 2012-Today Serpent Consulting Services (<http://www.serpentcs.com>)
|
|
#
|
|
# 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 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 General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>
|
|
#
|
|
##############################################################################
|
|
|
|
from openerp.osv import orm, fields, osv
|
|
from openerp.tools.translate import _
|
|
|
|
|
|
class ir_model_fields(orm.Model):
|
|
_inherit = 'ir.model.fields'
|
|
|
|
def search(
|
|
self, cr, uid, args, offset=0, limit=0, order=None, context=None,
|
|
count=False):
|
|
model_domain = []
|
|
for domain in args:
|
|
if (len(domain) > 2 and domain[0] == 'model_id'
|
|
and isinstance(domain[2], basestring)):
|
|
model_domain += [
|
|
('model_id', 'in', map(int, domain[2][1:-1].split(',')))
|
|
]
|
|
else:
|
|
model_domain.append(domain)
|
|
return super(ir_model_fields, self).search(
|
|
cr, uid, model_domain, offset=offset, limit=limit, order=order,
|
|
context=context, count=count)
|
|
|
|
ir_model_fields()
|
|
|
|
|
|
class mass_object(orm.Model):
|
|
_name = "mass.object"
|
|
|
|
_columns = {
|
|
'name': fields.char("Name", size=64, required=True, select=1),
|
|
'model_id': fields.many2one(
|
|
'ir.model', 'Model', required=True, select=1),
|
|
'field_ids': fields.many2many(
|
|
'ir.model.fields', 'mass_field_rel', 'mass_id', 'field_id',
|
|
'Fields'),
|
|
'ref_ir_act_window': fields.many2one(
|
|
'ir.actions.act_window', 'Sidebar Action', readonly=True,
|
|
help="Sidebar action to make this template available on records \
|
|
of the related document model"),
|
|
'ref_ir_value': fields.many2one(
|
|
'ir.values', 'Sidebar Button', readonly=True,
|
|
help="Sidebar button to open the sidebar action"),
|
|
'model_ids': fields.many2many('ir.model', string='Model List')
|
|
}
|
|
|
|
_sql_constraints = [
|
|
('name_uniq', 'unique (name)', _('Name must be unique!')),
|
|
]
|
|
|
|
def onchange_model(self, cr, uid, ids, model_id, context=None):
|
|
if context is None:
|
|
context = {}
|
|
if not model_id:
|
|
return {'value': {'model_ids': [(6, 0, [])]}}
|
|
model_ids = [model_id]
|
|
model_obj = self.pool.get('ir.model')
|
|
active_model_obj = self.pool.get(model_obj.browse(
|
|
cr, uid, model_id).model)
|
|
if active_model_obj._inherits:
|
|
for key, val in active_model_obj._inherits.items():
|
|
found_model_ids = model_obj.search(
|
|
cr, uid, [('model', '=', key)], context=context)
|
|
model_ids += found_model_ids
|
|
return {'value': {'model_ids': [(6, 0, model_ids)]}}
|
|
|
|
def create_action(self, cr, uid, ids, context=None):
|
|
vals = {}
|
|
action_obj = self.pool.get('ir.actions.act_window')
|
|
ir_values_obj = self.pool.get('ir.values')
|
|
for data in self.browse(cr, uid, ids, context=context):
|
|
src_obj = data.model_id.model
|
|
button_name = _('Mass Editing (%s)') % data.name
|
|
vals['ref_ir_act_window'] = action_obj.create(cr, uid, {
|
|
'name': button_name,
|
|
'type': 'ir.actions.act_window',
|
|
'res_model': 'mass.editing.wizard',
|
|
'src_model': src_obj,
|
|
'view_type': 'form',
|
|
'context': "{'mass_editing_object' : %d}" % (data.id),
|
|
'view_mode': 'form,tree',
|
|
'target': 'new',
|
|
'auto_refresh': 1,
|
|
}, context)
|
|
vals['ref_ir_value'] = ir_values_obj.create(cr, uid, {
|
|
'name': button_name,
|
|
'model': src_obj,
|
|
'key2': 'client_action_multi',
|
|
'value': (
|
|
"ir.actions.act_window,"
|
|
+ str(vals['ref_ir_act_window'])),
|
|
'object': True,
|
|
}, context)
|
|
self.write(cr, uid, ids, {
|
|
'ref_ir_act_window': vals.get('ref_ir_act_window', False),
|
|
'ref_ir_value': vals.get('ref_ir_value', False),
|
|
}, context)
|
|
return True
|
|
|
|
def unlink_action(self, cr, uid, ids, context=None):
|
|
for template in self.browse(cr, uid, ids, context=context):
|
|
try:
|
|
if template.ref_ir_act_window:
|
|
self.pool.get('ir.actions.act_window').unlink(
|
|
cr, uid, template.ref_ir_act_window.id, context)
|
|
if template.ref_ir_value:
|
|
ir_values_obj = self.pool.get('ir.values')
|
|
ir_values_obj.unlink(
|
|
cr, uid, template.ref_ir_value.id, context)
|
|
except:
|
|
raise osv.except_osv(
|
|
_("Warning"),
|
|
_("Deletion of the action record failed."))
|
|
return True
|
|
|
|
def unlink(self, cr, uid, ids, context=None):
|
|
self.unlink_action(cr, uid, ids, context)
|
|
return super(mass_object, self).unlink(cr, uid, ids, context)
|
|
|
|
def copy(self, cr, uid, record_id, default=None, context=None):
|
|
if default is None:
|
|
default = {}
|
|
default.update({'name': '', 'field_ids': []})
|
|
return super(mass_object, self).copy(
|
|
cr, uid, record_id, default, context)
|
|
|
|
mass_object()
|
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|