summaryrefslogtreecommitdiff
path: root/addons/im_livechat/static/src/models/messaging_initializer
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/im_livechat/static/src/models/messaging_initializer
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/im_livechat/static/src/models/messaging_initializer')
-rw-r--r--addons/im_livechat/static/src/models/messaging_initializer/messaging_initializer.js33
1 files changed, 33 insertions, 0 deletions
diff --git a/addons/im_livechat/static/src/models/messaging_initializer/messaging_initializer.js b/addons/im_livechat/static/src/models/messaging_initializer/messaging_initializer.js
new file mode 100644
index 00000000..56e02d9b
--- /dev/null
+++ b/addons/im_livechat/static/src/models/messaging_initializer/messaging_initializer.js
@@ -0,0 +1,33 @@
+odoo.define('im_livechat/static/src/models/messaging_initializer/messaging_initializer.js', function (require) {
+'use strict';
+
+const { registerInstancePatchModel } = require('mail/static/src/model/model_core.js');
+const { executeGracefully } = require('mail/static/src/utils/utils.js');
+
+registerInstancePatchModel('mail.messaging_initializer', 'im_livechat/static/src/models/messaging_initializer/messaging_initializer.js', {
+
+ //----------------------------------------------------------------------
+ // Private
+ //----------------------------------------------------------------------
+
+ /**
+ * @override
+ * @param {Object[]} [param0.channel_livechat=[]]
+ */
+ async _initChannels(initMessagingData) {
+ await this.async(() => this._super(initMessagingData));
+ const { channel_livechat = [] } = initMessagingData;
+ return executeGracefully(channel_livechat.map(data => () => {
+ const channel = this.env.models['mail.thread'].insert(
+ this.env.models['mail.thread'].convertData(data),
+ );
+ // flux specific: channels received at init have to be
+ // considered pinned. task-2284357
+ if (!channel.isPinned) {
+ channel.pin();
+ }
+ }));
+ },
+});
+
+});