summaryrefslogtreecommitdiff
path: root/addons/mass_mailing_crm/models
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/mass_mailing_crm/models
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/mass_mailing_crm/models')
-rw-r--r--addons/mass_mailing_crm/models/__init__.py4
-rw-r--r--addons/mass_mailing_crm/models/mailing_mailing.py46
2 files changed, 50 insertions, 0 deletions
diff --git a/addons/mass_mailing_crm/models/__init__.py b/addons/mass_mailing_crm/models/__init__.py
new file mode 100644
index 00000000..9733ab53
--- /dev/null
+++ b/addons/mass_mailing_crm/models/__init__.py
@@ -0,0 +1,4 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from . import mailing_mailing
diff --git a/addons/mass_mailing_crm/models/mailing_mailing.py b/addons/mass_mailing_crm/models/mailing_mailing.py
new file mode 100644
index 00000000..941b1b7b
--- /dev/null
+++ b/addons/mass_mailing_crm/models/mailing_mailing.py
@@ -0,0 +1,46 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+
+from odoo import api, fields, models, _, tools
+from odoo.osv import expression
+
+
+class MassMailing(models.Model):
+ _name = 'mailing.mailing'
+ _inherit = 'mailing.mailing'
+
+ use_leads = fields.Boolean('Use Leads', compute='_compute_use_leads')
+ crm_lead_count = fields.Integer('Leads/Opportunities Count', groups='sales_team.group_sale_salesman', compute='_compute_crm_lead_count')
+
+ def _compute_use_leads(self):
+ for mass_mailing in self:
+ mass_mailing.use_leads = self.env.user.has_group('crm.group_use_lead')
+
+ def _compute_crm_lead_count(self):
+ lead_data = self.env['crm.lead'].with_context(active_test=False).read_group(
+ [('source_id', 'in', self.source_id.ids)],
+ ['source_id'], ['source_id']
+ )
+ mapped_data = {datum['source_id'][0]: datum['source_id_count'] for datum in lead_data}
+ for mass_mailing in self:
+ mass_mailing.crm_lead_count = mapped_data.get(mass_mailing.source_id.id, 0)
+
+ def action_redirect_to_leads_and_opportunities(self):
+ view = 'crm.crm_lead_all_leads' if self.use_leads else 'crm.crm_lead_opportunities'
+ action = self.env.ref(view).sudo().read()[0]
+ action['view_mode'] = 'tree,kanban,graph,pivot,form,calendar'
+ action['domain'] = [('source_id', 'in', self.source_id.ids)]
+ action['context'] = {'active_test': False, 'create': False}
+ return action
+
+ def _prepare_statistics_email_values(self):
+ self.ensure_one()
+ values = super(MassMailing, self)._prepare_statistics_email_values()
+ if not self.user_id:
+ return values
+ values['kpi_data'][1]['kpi_col1'] = {
+ 'value': tools.format_decimalized_number(self.crm_lead_count, decimal=0),
+ 'col_subtitle': _('LEADS'),
+ }
+ return values