forked from Techsystech/web
[IMP] web_switch_context_warning: black, isort
parent
bb9b0f9118
commit
0c6150bedd
|
@ -8,17 +8,10 @@
|
|||
"category": "web",
|
||||
"website": "https://github.com/OCA/web",
|
||||
"license": "AGPL-3",
|
||||
"author": "Akretion, "
|
||||
"Odoo Community Association (OCA)",
|
||||
"depends": [
|
||||
'web',
|
||||
],
|
||||
"data": [
|
||||
"view/view.xml",
|
||||
],
|
||||
"qweb": [
|
||||
"static/src/xml/switch_context_warning.xml",
|
||||
],
|
||||
'installable': True,
|
||||
"author": "Akretion, " "Odoo Community Association (OCA)",
|
||||
"depends": ["web"],
|
||||
"data": ["view/view.xml"],
|
||||
"qweb": ["static/src/xml/switch_context_warning.xml"],
|
||||
"installable": True,
|
||||
"application": False,
|
||||
}
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
odoo.define('web_switch_context_warning.widget', function (require) {
|
||||
'use strict';
|
||||
odoo.define("web_switch_context_warning.widget", function(require) {
|
||||
"use strict";
|
||||
|
||||
var Widget = require('web.Widget');
|
||||
var UserMenu = require('web.UserMenu');
|
||||
var session = require('web.session');
|
||||
var Widget = require("web.Widget");
|
||||
var UserMenu = require("web.UserMenu");
|
||||
var session = require("web.session");
|
||||
// Show a big banner in the top of the page if the context has been
|
||||
// changed in another tab or window (in the same browser)
|
||||
|
||||
|
@ -12,13 +12,15 @@ odoo.define('web_switch_context_warning.widget', function (require) {
|
|||
return;
|
||||
}
|
||||
var SwitchCompanyWarningWidget = Widget.extend({
|
||||
template:'web_switch_context_warning.warningWidget',
|
||||
init: function () {
|
||||
template: "web_switch_context_warning.warningWidget",
|
||||
init: function() {
|
||||
this._super();
|
||||
var self = this;
|
||||
var w = new SharedWorker('/web_switch_context_warning/static/src/js/switch_context_warning_worker.js');
|
||||
w.port.addEventListener('message', function (msg) {
|
||||
if (msg.data.type !== 'newCtx') {
|
||||
var w = new SharedWorker(
|
||||
"/web_switch_context_warning/static/src/js/switch_context_warning_worker.js"
|
||||
);
|
||||
w.port.addEventListener("message", function(msg) {
|
||||
if (msg.data.type !== "newCtx") {
|
||||
return;
|
||||
}
|
||||
if (msg.data.newCtx === self.generateSignature()) {
|
||||
|
@ -30,20 +32,18 @@ odoo.define('web_switch_context_warning.widget', function (require) {
|
|||
w.port.start();
|
||||
w.port.postMessage(this.generateSignature());
|
||||
},
|
||||
generateSignature: function () {
|
||||
generateSignature: function() {
|
||||
return [session.uid, session.company_id, session.db].join();
|
||||
},
|
||||
});
|
||||
|
||||
UserMenu.include({
|
||||
init: function (parent) {
|
||||
init: function(parent) {
|
||||
this._super(parent);
|
||||
var switchCompanyWarning = new SwitchCompanyWarningWidget();
|
||||
switchCompanyWarning.insertAfter('.o_main_navbar');
|
||||
switchCompanyWarning.insertAfter(".o_main_navbar");
|
||||
},
|
||||
|
||||
});
|
||||
|
||||
return SwitchCompanyWarningWidget;
|
||||
});
|
||||
|
||||
|
|
|
@ -4,20 +4,28 @@
|
|||
var con = [];
|
||||
var lastCtx = null;
|
||||
|
||||
addEventListener("connect", function (ee) {
|
||||
addEventListener(
|
||||
"connect",
|
||||
function(ee) {
|
||||
"use strict";
|
||||
|
||||
var port = ee.ports[0];
|
||||
con.push(port);
|
||||
|
||||
port.onmessage = function (e) {
|
||||
port.onmessage = function(e) {
|
||||
var newCtx = e.data;
|
||||
|
||||
if (lastCtx && newCtx !== lastCtx) {
|
||||
con.forEach(function (eport) {
|
||||
eport.postMessage({type: "newCtx", "newCtx": newCtx, "lastCtx": lastCtx});
|
||||
con.forEach(function(eport) {
|
||||
eport.postMessage({
|
||||
type: "newCtx",
|
||||
newCtx: newCtx,
|
||||
lastCtx: lastCtx,
|
||||
});
|
||||
});
|
||||
}
|
||||
lastCtx = newCtx;
|
||||
};
|
||||
}, false);
|
||||
},
|
||||
false
|
||||
);
|
||||
|
|
|
@ -1,9 +1,16 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<?xml version="1.0" encoding="UTF-8" ?>
|
||||
<template>
|
||||
<t t-name="web_switch_context_warning.warningWidget">
|
||||
<div class="container-fluid bg-warning" style="text-align: center; display:none;padding-top:20px;padding-bottom:5px">
|
||||
<h3>You switched to a different user, company or database with another tab or window</h3>
|
||||
<p><button onclick="location.reload(true);" class="btn">Reload</button> to refresh your session</p>
|
||||
<div
|
||||
class="container-fluid bg-warning"
|
||||
style="text-align: center; display:none;padding-top:20px;padding-bottom:5px"
|
||||
>
|
||||
<h3
|
||||
>You switched to a different user, company or database with another tab or window</h3>
|
||||
<p><button
|
||||
onclick="location.reload(true);"
|
||||
class="btn"
|
||||
>Reload</button> to refresh your session</p>
|
||||
</div>
|
||||
</t>
|
||||
</template>
|
||||
|
|
|
@ -1,9 +1,16 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<?xml version="1.0" encoding="UTF-8" ?>
|
||||
<openerp>
|
||||
<data>
|
||||
<template id="assets_backend" name="web_switch_context_warning assets" inherit_id="web.assets_backend">
|
||||
<template
|
||||
id="assets_backend"
|
||||
name="web_switch_context_warning assets"
|
||||
inherit_id="web.assets_backend"
|
||||
>
|
||||
<xpath expr="." position="inside">
|
||||
<script type="text/javascript" src="/web_switch_context_warning/static/src/js/switch_context_warning.js"></script>
|
||||
<script
|
||||
type="text/javascript"
|
||||
src="/web_switch_context_warning/static/src/js/switch_context_warning.js"
|
||||
/>
|
||||
</xpath>
|
||||
</template>
|
||||
</data>
|
||||
|
|
Loading…
Reference in New Issue