diff --git a/addons/mass_mailing/models/__init__.py b/addons/mass_mailing/models/__init__.py index 9797d43aeff26ce7d1e6076ed12c1e00b9cea30b..64b451ac37b1cad5049995b31083b1b0b3c445f5 100644 --- a/addons/mass_mailing/models/__init__.py +++ b/addons/mass_mailing/models/__init__.py @@ -10,4 +10,5 @@ from . import mail_mail from . import mail_template from . import mail_thread from . import res_config_settings +from . import res_users from . import utm diff --git a/addons/mass_mailing/models/res_users.py b/addons/mass_mailing/models/res_users.py new file mode 100644 index 0000000000000000000000000000000000000000..04b1cb749104b367a66c972fc924749aae8093dd --- /dev/null +++ b/addons/mass_mailing/models/res_users.py @@ -0,0 +1,21 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo import api, models, _ + + +class Users(models.Model): + _name = 'res.users' + _inherit = ['res.users'] + + @api.model + def systray_get_activities(self): + """ Update systray name of mailing.mailing from "Mass Mailing" + to "Email Marketing". + """ + activities = super(Users, self).systray_get_activities() + for activity in activities: + if activity.get('model') == 'mailing.mailing': + activity['name'] = _('Email Marketing') + break + return activities diff --git a/addons/mass_mailing_sms/models/__init__.py b/addons/mass_mailing_sms/models/__init__.py index 76457e3bdf4c48835bd3d91ede223a3605e68060..1f0a7eb2c869af74501dd59b30b911c1179d6ae5 100644 --- a/addons/mass_mailing_sms/models/__init__.py +++ b/addons/mass_mailing_sms/models/__init__.py @@ -5,5 +5,6 @@ from . import mailing_contact from . import mailing_list from . import mailing_mailing from . import mailing_trace +from . import res_users from . import sms_sms from . import utm diff --git a/addons/mass_mailing_sms/models/res_users.py b/addons/mass_mailing_sms/models/res_users.py new file mode 100644 index 0000000000000000000000000000000000000000..cc095e7e39700c41de0adc9a16f579034e17f068 --- /dev/null +++ b/addons/mass_mailing_sms/models/res_users.py @@ -0,0 +1,67 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo import api, fields, models, modules, _ + + +class Users(models.Model): + _name = 'res.users' + _inherit = ['res.users'] + + @api.model + def systray_get_activities(self): + """ Split mass_mailing and mass_mailing_sms activities in systray by + removing the single mailing.mailing activity represented and + doing a new query to split them by mailing_type. + """ + activities = super(Users, self).systray_get_activities() + for activity in activities: + if activity.get('model') == 'mailing.mailing': + activities.remove(activity) + query = """SELECT m.mailing_type, count(*), act.res_model as model, + CASE + WHEN %(today)s::date - act.date_deadline::date = 0 Then 'today' + WHEN %(today)s::date - act.date_deadline::date > 0 Then 'overdue' + WHEN %(today)s::date - act.date_deadline::date < 0 Then 'planned' + END AS states + FROM mail_activity AS act + JOIN mailing_mailing AS m ON act.res_id = m.id + WHERE act.res_model = 'mailing.mailing' AND act.user_id = %(user_id)s + GROUP BY m.mailing_type, states, act.res_model; + """ + self.env.cr.execute(query, { + 'today': fields.Date.context_today(self), + 'user_id': self.env.uid, + }) + activity_data = self.env.cr.dictfetchall() + + user_activities = {} + for act in activity_data: + if not user_activities.get(act['mailing_type']): + if act['mailing_type'] == 'sms': + module = 'mass_mailing_sms' + name = _('SMS Marketing') + else: + module = 'mass_mailing' + name = _('Email Marketing') + icon = module and modules.module.get_module_icon(module) + user_activities[act['mailing_type']] = { + 'name': name, + 'model': 'mailing.mailing', + 'type': 'activity', + 'icon': icon, + 'total_count': 0, 'today_count': 0, 'overdue_count': 0, 'planned_count': 0, + } + user_activities[act['mailing_type']]['%s_count' % act['states']] += act['count'] + if act['states'] in ('today', 'overdue'): + user_activities[act['mailing_type']]['total_count'] += act['count'] + + for mailing_type in user_activities.keys(): + user_activities[mailing_type].update({ + 'actions': [{'icon': 'fa-clock-o', 'name': 'Summary',}], + }) + + activities.extend(list(user_activities.values())) + break + + return activities