From 7fb3c1ba7e3d07709ef20d3c7cc82278b6729583 Mon Sep 17 00:00:00 2001 From: "Harry (OpenERP)" Date: Fri, 25 Nov 2011 14:23:25 +0530 Subject: [PATCH] [IMP] project: attachments also copy when delegate task bzr revid: hmo@tinyerp.com-20111125085325-lmf9qttl9jwqe2be --- addons/project/project.py | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/addons/project/project.py b/addons/project/project.py index abebd2d..e13b920 100644 --- a/addons/project/project.py +++ b/addons/project/project.py @@ -879,14 +879,24 @@ class task(osv.osv): self.write(cr, uid, ids, {'state': 'draft'}, context=context) return True + + def _delegate_task_attachments(self, cr, uid, task_id, delegated_task_id, context=None): + attachment = self.pool.get('ir.attachment') + attachment_ids = attachment.search(cr, uid, [('res_model', '=', self._name), ('res_id', '=', task_id)], context=context) + new_attachment_ids = [] + for attachment_id in attachment_ids: + new_attachment_ids.append(attachment.copy(cr, uid, attachment_id, default={'res_id': delegated_task_id}, context=context)) + return new_attachment_ids + + def do_delegate(self, cr, uid, ids, delegate_data={}, context=None): """ Delegate Task to another users. """ assert delegate_data['user_id'], _("Delegated User should be specified") - delegrated_tasks = {} + delegated_tasks = {} for task in self.browse(cr, uid, ids, context=context): - delegrated_task_id = self.copy(cr, uid, task.id, { + delegated_task_id = self.copy(cr, uid, task.id, { 'name': delegate_data['name'], 'project_id': delegate_data['project_id'] and delegate_data['project_id'][0] or False, 'user_id': delegate_data['user_id'] and delegate_data['user_id'][0] or False, @@ -897,6 +907,7 @@ class task(osv.osv): 'child_ids': [], 'work_ids': [] }, context=context) + self._delegate_task_attachments(cr, uid, task.id, delegated_task_id, context=context) newname = delegate_data['prefix'] or '' task.write({ 'remaining_hours': delegate_data['planned_hours_me'], @@ -910,8 +921,8 @@ class task(osv.osv): message = _("The task '%s' has been delegated to %s.") % (delegate_data['name'], delegate_data['user_id'][1]) self.log(cr, uid, task.id, message) - delegrated_tasks[task.id] = delegrated_task_id - return delegrated_tasks + delegated_tasks[task.id] = delegated_task_id + return delegated_tasks def do_pending(self, cr, uid, ids, context={}): self.write(cr, uid, ids, {'state': 'pending'}, context=context) -- 1.7.10.4