summaryrefslogtreecommitdiff
path: root/addons/website_livechat/controllers
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/website_livechat/controllers
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/website_livechat/controllers')
-rw-r--r--addons/website_livechat/controllers/__init__.py3
-rw-r--r--addons/website_livechat/controllers/main.py68
-rw-r--r--addons/website_livechat/controllers/test.py19
3 files changed, 90 insertions, 0 deletions
diff --git a/addons/website_livechat/controllers/__init__.py b/addons/website_livechat/controllers/__init__.py
new file mode 100644
index 00000000..29bc11c7
--- /dev/null
+++ b/addons/website_livechat/controllers/__init__.py
@@ -0,0 +1,3 @@
+# -*- coding: utf-8 -*-
+from . import main
+from . import test
diff --git a/addons/website_livechat/controllers/main.py b/addons/website_livechat/controllers/main.py
new file mode 100644
index 00000000..7e0fb0ba
--- /dev/null
+++ b/addons/website_livechat/controllers/main.py
@@ -0,0 +1,68 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo import http, _
+from odoo.http import request
+from odoo.addons.im_livechat.controllers.main import LivechatController
+
+
+class WebsiteLivechat(LivechatController):
+
+ @http.route('/livechat', type='http', auth="public", website=True, sitemap=True)
+ def channel_list(self, **kw):
+ # display the list of the channel
+ channels = request.env['im_livechat.channel'].search([('website_published', '=', True)])
+ values = {
+ 'channels': channels
+ }
+ return request.render('website_livechat.channel_list_page', values)
+
+ @http.route('/livechat/channel/<model("im_livechat.channel"):channel>', type='http', auth='public', website=True, sitemap=True)
+ def channel_rating(self, channel, **kw):
+ # get the last 100 ratings and the repartition per grade
+ domain = [
+ ('res_model', '=', 'mail.channel'), ('res_id', 'in', channel.sudo().channel_ids.ids),
+ ('consumed', '=', True), ('rating', '>=', 1),
+ ]
+ ratings = request.env['rating.rating'].sudo().search(domain, order='create_date desc', limit=100)
+ repartition = channel.sudo().channel_ids.rating_get_grades(domain=domain)
+
+ # compute percentage
+ percentage = dict.fromkeys(['great', 'okay', 'bad'], 0)
+ for grade in repartition:
+ percentage[grade] = round(repartition[grade] * 100.0 / sum(repartition.values()), 1) if sum(repartition.values()) else 0
+
+ # filter only on the team users that worked on the last 100 ratings and get their detailed stat
+ ratings_per_partner = {partner_id: dict(great=0, okay=0, bad=0)
+ for partner_id in ratings.mapped('rated_partner_id.id')}
+ total_ratings_per_partner = dict.fromkeys(ratings.mapped('rated_partner_id.id'), 0)
+ # keep 10 for backward compatibility
+ rating_texts = {10: 'great', 5: 'great', 3: 'okay', 1: 'bad'}
+
+ for rating in ratings:
+ partner_id = rating.rated_partner_id.id
+ ratings_per_partner[partner_id][rating_texts[rating.rating]] += 1
+ total_ratings_per_partner[partner_id] += 1
+
+ for partner_id, rating in ratings_per_partner.items():
+ for k, v in ratings_per_partner[partner_id].items():
+ ratings_per_partner[partner_id][k] = round(100 * v / total_ratings_per_partner[partner_id], 1)
+
+ # the value dict to render the template
+ values = {
+ 'main_object': channel,
+ 'channel': channel,
+ 'ratings': ratings,
+ 'team': channel.sudo().user_ids,
+ 'percentage': percentage,
+ 'ratings_per_user': ratings_per_partner
+ }
+ return request.render("website_livechat.channel_page", values)
+
+ @http.route('/im_livechat/get_session', type="json", auth='public', cors="*")
+ def get_session(self, channel_id, anonymous_name, previous_operator_id=None, **kwargs):
+ """ Override to use visitor name instead of 'Visitor' whenever a visitor start a livechat session. """
+ visitor_sudo = request.env['website.visitor']._get_visitor_from_request()
+ if visitor_sudo:
+ anonymous_name = visitor_sudo.with_context(lang=visitor_sudo.lang_id.code).display_name
+ return super(WebsiteLivechat, self).get_session(channel_id, anonymous_name, previous_operator_id=previous_operator_id, **kwargs)
diff --git a/addons/website_livechat/controllers/test.py b/addons/website_livechat/controllers/test.py
new file mode 100644
index 00000000..0ecabd66
--- /dev/null
+++ b/addons/website_livechat/controllers/test.py
@@ -0,0 +1,19 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo.http import Controller, request, route
+
+
+class TestBusController(Controller):
+ """
+ This controller is only useful for test purpose. Bus is unavailable in test mode, but there is no way to know,
+ at client side, if we are running in test mode or not. This route can be called while running tours to mock
+ some behaviour in function of the test mode status (activated or not).
+
+ E.g. : To test the livechat and to check there is no duplicates in message displayed in the chatter,
+ in test mode, we need to mock a 'message added' notification that is normally triggered by the bus.
+ In Normal mode, the bus triggers itself the notification.
+ """
+ @route('/bus/test_mode_activated', type="json", auth="public")
+ def is_test_mode_activated(self):
+ return request.registry.in_test_mode()