|
@ -37,9 +37,7 @@ class ir_model(orm.Model): |
|
|
_("Can't create quickly. Opening create form")) |
|
|
_("Can't create quickly. Opening create form")) |
|
|
return wrapper |
|
|
return wrapper |
|
|
|
|
|
|
|
|
def _register_hook(self, cr, ids=None): |
|
|
|
|
|
if ids is None: |
|
|
|
|
|
ids = self.search(cr, SUPERUSER_ID, []) |
|
|
|
|
|
|
|
|
def _patch_quick_create(self, cr, ids): |
|
|
for model in self.browse(cr, SUPERUSER_ID, ids): |
|
|
for model in self.browse(cr, SUPERUSER_ID, ids): |
|
|
if model.avoid_quick_create: |
|
|
if model.avoid_quick_create: |
|
|
model_name = model.model |
|
|
model_name = model.model |
|
@ -50,14 +48,18 @@ class ir_model(orm.Model): |
|
|
model_obj.check_quick_create = True |
|
|
model_obj.check_quick_create = True |
|
|
return True |
|
|
return True |
|
|
|
|
|
|
|
|
|
|
|
def _register_hook(self, cr): |
|
|
|
|
|
self._patch_quick_create(cr, self.search(cr, SUPERUSER_ID, [])) |
|
|
|
|
|
return super(ir_model, self)._register_hook(cr) |
|
|
|
|
|
|
|
|
def create(self, cr, uid, vals, context=None): |
|
|
def create(self, cr, uid, vals, context=None): |
|
|
res_id = super(ir_model, self).create(cr, uid, vals, context=context) |
|
|
res_id = super(ir_model, self).create(cr, uid, vals, context=context) |
|
|
self._register_hook(cr, [res_id]) |
|
|
|
|
|
|
|
|
self._patch_quick_create(cr, [res_id]) |
|
|
return res_id |
|
|
return res_id |
|
|
|
|
|
|
|
|
def write(self, cr, uid, ids, vals, context=None): |
|
|
def write(self, cr, uid, ids, vals, context=None): |
|
|
if isinstance(ids, (int, long)): |
|
|
if isinstance(ids, (int, long)): |
|
|
ids = [ids] |
|
|
ids = [ids] |
|
|
res = super(ir_model, self).write(cr, uid, ids, vals, context=context) |
|
|
res = super(ir_model, self).write(cr, uid, ids, vals, context=context) |
|
|
self._register_hook(cr, ids) |
|
|
|
|
|
|
|
|
self._patch_quick_create(cr, ids) |
|
|
return res |
|
|
return res |