mirror of
https://github.com/OCA/web.git
synced 2025-02-22 13:21:25 +02:00
Merge pull request #722 from akretion/10.0-mig-web_switch_company_warning
[MIG] web_switch_company_warning to 10.0 Migration
This commit is contained in:
@@ -1,15 +1,16 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
# © <2015> <Akretion, OCA>
|
||||
# Copyright 2017 Akretion <raphael.reverdy@akretion.com>
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
|
||||
{
|
||||
"name": "Multicompany - Switch Company Warning",
|
||||
"summary": "Show a warning if current company has been switched"
|
||||
" in another tab or window.",
|
||||
"version": "8.0.0.1.0",
|
||||
" in another tab or window.",
|
||||
"version": "10.0.0.1.0",
|
||||
"category": "web",
|
||||
"website": "http://akretion.com",
|
||||
"license": "AGPL-3",
|
||||
"author": "Akretion / Odoo Community Association (OCA)",
|
||||
"author": "Akretion, "
|
||||
"Odoo Community Association (OCA)",
|
||||
"depends": [
|
||||
'web',
|
||||
],
|
||||
@@ -19,6 +20,6 @@
|
||||
"qweb": [
|
||||
"static/src/xml/switch_company_warning.xml",
|
||||
],
|
||||
'installable': False,
|
||||
'installable': True,
|
||||
"application": False,
|
||||
}
|
||||
|
||||
@@ -1,52 +1,46 @@
|
||||
'use strict';
|
||||
|
||||
openerp.web_switch_company_warning = function (instance) {
|
||||
|
||||
odoo.define('web_switch_company_warning.widget', function (require) {
|
||||
var Widget = require('web.Widget');
|
||||
var UserMenu = require('web.UserMenu');
|
||||
//Show a big banner in the top of the page if the company has been
|
||||
//changed in another tab or window (in the same browser)
|
||||
|
||||
if (!window.SharedWorker)
|
||||
return; //not supported
|
||||
|
||||
instance.web.SwitchCompanyWorker = null; //keep a global reference
|
||||
|
||||
instance.web.SwitchCompanyWarningWidget = instance.web.Widget.extend({
|
||||
|
||||
if (!window.SharedWorker) {
|
||||
//not supported
|
||||
return;
|
||||
}
|
||||
var SwitchCompanyWarningWidget = Widget.extend({
|
||||
template:'web_switch_company_warning.warningWidget',
|
||||
init: function() {
|
||||
this._super();
|
||||
|
||||
var self = this;
|
||||
|
||||
var w = new SharedWorker('/web_switch_company_warning/static/src/js/switch_company_warning_worker.js');
|
||||
instance.web.SwitchCompanyWorker = w;
|
||||
var w = new SharedWorker('/web_switch_company_warning/static/src/js/switch_company_warning_worker.js');
|
||||
|
||||
w.port.addEventListener('message', function (msg) {
|
||||
if (msg.data.type !== 'newCtx')
|
||||
return;
|
||||
|
||||
if(msg.data.newCtx != self.session.company_id) {
|
||||
self.$el.show();
|
||||
} else {
|
||||
if (msg.data.type !== 'newCtx') {
|
||||
return;
|
||||
}
|
||||
if(msg.data.newCtx === self.session.company_id) {
|
||||
self.$el.hide();
|
||||
} else {
|
||||
self.$el.show();
|
||||
}
|
||||
});
|
||||
|
||||
w.port.start();
|
||||
w.port.postMessage(this.session.company_id);
|
||||
}
|
||||
});
|
||||
|
||||
instance.web.UserMenu = instance.web.UserMenu.extend({
|
||||
|
||||
UserMenu.include({
|
||||
init: function(parent) {
|
||||
this._super(parent);
|
||||
|
||||
var switchCompanyWarning = new instance.web.SwitchCompanyWarningWidget();
|
||||
switchCompanyWarning.insertAfter(instance.webclient.$el.find('#oe_main_menu_navbar'));
|
||||
var switchCompanyWarning = new SwitchCompanyWarningWidget();
|
||||
switchCompanyWarning.appendTo('#oe_main_menu_navbar');
|
||||
}
|
||||
|
||||
});
|
||||
|
||||
};
|
||||
return SwitchCompanyWarningWidget;
|
||||
});
|
||||
|
||||
|
||||
@@ -3,22 +3,20 @@
|
||||
//changed in another tab or window (in the same browser)
|
||||
|
||||
var con = [];
|
||||
|
||||
var lastCtx = null;
|
||||
var lastCtx = null;
|
||||
|
||||
addEventListener("connect", function(ee) {
|
||||
var port = ee.ports[0];
|
||||
con.push(port);
|
||||
|
||||
port.onmessage = function (e) { //addEventListener doesnt seams to work well
|
||||
port.onmessage = function (e) {
|
||||
var newCtx = e.data;
|
||||
|
||||
if (lastCtx && newCtx != lastCtx) {
|
||||
con.map(function (eport) {
|
||||
eport.postMessage({ type: "newCtx", "newCtx": newCtx, "lastCtx": lastCtx});
|
||||
if (lastCtx && newCtx !== lastCtx) {
|
||||
con.forEach(function (eport) {
|
||||
eport.postMessage({type: "newCtx", "newCtx": newCtx, "lastCtx": lastCtx});
|
||||
});
|
||||
}
|
||||
lastCtx = newCtx;
|
||||
};
|
||||
|
||||
}, false);
|
||||
|
||||
@@ -6,4 +6,4 @@
|
||||
<p><button onclick="location.reload(true);" class="btn">Reload</button> to refresh your session</p>
|
||||
</div>
|
||||
</t>
|
||||
</template>
|
||||
</template>
|
||||
|
||||
Reference in New Issue
Block a user