From 6773a6d61074961f2d7a95e03a6cdef433797e91 Mon Sep 17 00:00:00 2001
From: Leonardo Pistone
Date: Wed, 8 Jan 2014 12:55:30 +0100
Subject: [PATCH] [imp] add mail thread with report attached to hours block
---
analytic_hours_block/__openerp__.py | 1 +
analytic_hours_block/hours_block.py | 42 ++++++++++++
analytic_hours_block/hours_block_data.xml | 24 +++++++
analytic_hours_block/hours_block_view.xml | 83 ++++++++++++-----------
4 files changed, 112 insertions(+), 38 deletions(-)
create mode 100644 analytic_hours_block/hours_block_data.xml
diff --git a/analytic_hours_block/__openerp__.py b/analytic_hours_block/__openerp__.py
index 09c78ad7..d6ae9142 100644
--- a/analytic_hours_block/__openerp__.py
+++ b/analytic_hours_block/__openerp__.py
@@ -44,6 +44,7 @@ you can track and follow how much has been used.
],
"data": [
"hours_block_view.xml",
+ "hours_block_data.xml",
"hours_block_menu.xml",
"report.xml",
"security/hours_block_security.xml",
diff --git a/analytic_hours_block/hours_block.py b/analytic_hours_block/hours_block.py
index b341702a..064edca5 100644
--- a/analytic_hours_block/hours_block.py
+++ b/analytic_hours_block/hours_block.py
@@ -24,6 +24,7 @@ from openerp.osv import orm, fields
class AccountHoursBlock(orm.Model):
_name = "account.hours.block"
+ _inherit = ['mail.thread']
def _get_last_action(self, cr, uid, ids, name, arg, context=None):
""" Return the last analytic line date for an invoice"""
@@ -163,6 +164,47 @@ class AccountHoursBlock(orm.Model):
block_ids.update([inv.id for inv in invoice.account_hours_block_ids])
return list(block_ids)
+ def action_send_block(self, cr, uid, ids, context=None):
+ """Open a form to send by email. Return an action dict."""
+
+ assert len(ids) == 1, '''\
+ This option should only be used for a single ID at a time.'''
+
+ ir_model_data = self.pool.get('ir.model.data')
+
+ try:
+ template_id = ir_model_data.get_object_reference(
+ cr, uid, 'analytic_hours_block', 'email_template_hours_block'
+ )[1]
+ except ValueError:
+ template_id = False
+
+ try:
+ compose_form_id = ir_model_data.get_object_reference(
+ cr, uid, 'mail', 'email_compose_message_wizard_form'
+ )[1]
+ except ValueError:
+ compose_form_id = False
+
+ ctx = context.copy()
+ ctx.update({
+ 'default_model': self._name,
+ 'default_res_id': ids[0],
+ 'default_use_template': bool(template_id),
+ 'default_template_id': template_id,
+ 'default_composition_mode': 'comment',
+ })
+ return {
+ 'type': 'ir.actions.act_window',
+ 'view_type': 'form',
+ 'view_mode': 'form',
+ 'res_model': 'mail.compose.message',
+ 'views': [(compose_form_id, 'form')],
+ 'view_id': compose_form_id,
+ 'target': 'new',
+ 'context': ctx,
+ }
+
_recompute_triggers = {
'account.hours.block': (lambda self, cr, uid, ids, c=None:
ids, ['invoice_id', 'type'], 10),
diff --git a/analytic_hours_block/hours_block_data.xml b/analytic_hours_block/hours_block_data.xml
new file mode 100644
index 00000000..dc5f9eaa
--- /dev/null
+++ b/analytic_hours_block/hours_block_data.xml
@@ -0,0 +1,24 @@
+
+
+
+
+
+ Hours Block - Send by Email
+ ${(object.user_id.email or object.company_id.email or 'noreply@localhost')|safe}
+ ${object.company_id.name} Hours Block (Ref ${object.number or 'n/a'})
+ ${object.partner_id.id}
+
+
+
+ Hours_Block_${(object.number or '').replace('/','_')}_${object.state == 'draft' and 'draft' or ''}
+ ${object.partner_id.lang}
+ Hello ${object.partner_id.name},
+
+ Please find attached your Hours Block Report.
+ Best regards.
+ ]]>
+
+
+
diff --git a/analytic_hours_block/hours_block_view.xml b/analytic_hours_block/hours_block_view.xml
index a81bc136..3c6da3a5 100644
--- a/analytic_hours_block/hours_block_view.xml
+++ b/analytic_hours_block/hours_block_view.xml
@@ -41,44 +41,51 @@
account.hours.block