diff --git a/gulliver/system/class.headPublisher.php b/gulliver/system/class.headPublisher.php
index 156fa6aab..49f8909a0 100644
--- a/gulliver/system/class.headPublisher.php
+++ b/gulliver/system/class.headPublisher.php
@@ -330,6 +330,8 @@ class headPublisher
$head = "";
$head = $head . " \n";
$head = $head . " \n";
+ $head = $head . " \n";
+ $head = $head . " \n";
if (SYS_LANG != 'en') {
$tempLang = str_replace('-', '_', SYS_LANG);
diff --git a/workflow/engine/js/src/PM.js b/workflow/engine/js/src/PM.js
new file mode 100644
index 000000000..ce6fd0e51
--- /dev/null
+++ b/workflow/engine/js/src/PM.js
@@ -0,0 +1,5 @@
+var PM = PM || {};
+(function() {
+ PM.version = '3.0.1.8';
+}());
+
diff --git a/workflow/engine/js/src/Register.js b/workflow/engine/js/src/Register.js
new file mode 100644
index 000000000..15336890f
--- /dev/null
+++ b/workflow/engine/js/src/Register.js
@@ -0,0 +1,3 @@
+PM.Sessions.register();
+
+localStorage.setItem('ID_BLOCKER_MSG', PM.Sessions.getCookie('PM-Warning'));
\ No newline at end of file
diff --git a/workflow/engine/js/src/Sessions.js b/workflow/engine/js/src/Sessions.js
new file mode 100644
index 000000000..c0599e4a2
--- /dev/null
+++ b/workflow/engine/js/src/Sessions.js
@@ -0,0 +1,118 @@
+PM.Sessions = (function () {
+ var Sessions = function () {
+ if (window.location.pathname.indexOf("login") === -1 &&
+ window.location.pathname.indexOf("sysLogin") === -1 &&
+ this.getCookie('PM-TabPrimary') != 101010010) {
+ this.checkTab();
+ }
+ };
+
+ Sessions.prototype.register = function () {
+ window.name = this.getCookie('PM-TabPrimary');
+ };
+
+ Sessions.prototype.checkTab = function () {
+ var ieVersion,
+ msg;
+ if (parent.parent.parent.window.name !== this.getCookie('PM-TabPrimary') && parent.parent.parent.window.name.indexOf(this.getCookie('PM-TabPrimary')) === -1 ) {
+ ieVersion = this.detectBrowser();
+ msg = this.getLabel('ID_BLOCKER_MSG');
+
+ if (ieVersion && ieVersion <= 11) {
+ window.open('', '_self', '');
+ window.document.execCommand('Stop');
+ if (confirm(msg)) {
+ window.close();
+ }
+ } else if (ieVersion && ieVersion <= 12) {
+ window.open('', '_self', '');
+ window.document.execCommand('Stop');
+ if (confirm(msg)) {
+ window.close();
+ }
+ } else {
+ window.open('', '_self', '');
+ window.stop();
+ if (confirm(msg)) {
+ window.close();
+ }
+ }
+ }
+ };
+
+ Sessions.prototype.detectBrowser = function() {
+ var ua = window.navigator.userAgent,
+ msie = ua.indexOf('MSIE '),
+ trident = ua.indexOf('Trident/'),
+ edge = ua.indexOf('Edge/');
+
+ // Test values; Uncomment to check result …
+
+ // IE 10
+ // ua = 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0)';
+
+ // IE 11
+ // ua = 'Mozilla/5.0 (Windows NT 6.3; Trident/7.0; rv:11.0) like Gecko';
+
+ // IE 12 / Spartan
+ // ua = 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.71 Safari/537.36 Edge/12.0';
+
+ // Edge (IE 12+)
+ // ua = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2486.0 Safari/537.36 Edge/13.10586';
+ if (msie > 0) {
+ // IE 10 or older => return version number
+ return parseInt(ua.substring(msie + 5, ua.indexOf('.', msie)), 10);
+ }
+ if (trident > 0) {
+ // IE 11 => return version number
+ var rv = ua.indexOf('rv:');
+ return parseInt(ua.substring(rv + 3, ua.indexOf('.', rv)), 10);
+ }
+ if (edge > 0) {
+ // Edge (IE 12+) => return version number
+ return parseInt(ua.substring(edge + 5, ua.indexOf('.', edge)), 10);
+ }
+ // other browser
+ return false;
+ };
+
+ Sessions.prototype.getCookie = function (cname) {
+ var name = cname + "=",
+ c,
+ ca = document.cookie.split(';');
+ for (var i = 0; i < ca.length; i++) {
+ c = ca[i];
+ while (c.charAt(0) == ' ') c = c.substring(1);
+ if (c.indexOf(name) == 0) return c.substring(name.length, c.length);
+ }
+ return "";
+ };
+
+ Sessions.prototype.createCookie = function(name, value, days) {
+ var date,
+ expires;
+ if (days) {
+ date = new Date();
+ date.setTime(date.getTime()+(days*24*60*60*1000));
+ expires = "; expires="+date.toGMTString();
+ } else {
+ expires = "";
+ }
+ document.cookie = name+"="+value+expires+"; path=/";
+ };
+
+ Sessions.prototype.eraseCookie = function(name) {
+ this.createCookie(name,"",-1);
+ };
+
+ Sessions.prototype.setLabel = function(nameLabel) {
+ localStorage.setItem(nameLabel, _(nameLabel));
+ };
+
+ Sessions.prototype.getLabel = function(nameLabel) {
+ return localStorage.getItem(nameLabel);
+ };
+
+ return new Sessions();
+})();
+
diff --git a/workflow/engine/methods/cases/main.php b/workflow/engine/methods/cases/main.php
index b6c8fcb58..6ba9c640f 100755
--- a/workflow/engine/methods/cases/main.php
+++ b/workflow/engine/methods/cases/main.php
@@ -31,5 +31,8 @@ $_POST['qs'] = isset( $_SERVER['QUERY_STRING'] ) && $_SERVER['QUERY_STRING'] !=
$G_PUBLISH = new Publisher();
$G_PUBLISH->AddContent( 'view', 'cases/cases_Load' );
+$oHeadPublisher = & headPublisher::getSingleton();
+$oHeadPublisher->addScriptFile('/jscore/src/PM.js');
+$oHeadPublisher->addScriptFile('/jscore/src/Sessions.js');
G::RenderPage( 'publish' );
diff --git a/workflow/engine/methods/login/authentication.php b/workflow/engine/methods/login/authentication.php
index 70e099ea9..2fee26017 100755
--- a/workflow/engine/methods/login/authentication.php
+++ b/workflow/engine/methods/login/authentication.php
@@ -412,6 +412,12 @@ try {
die;
}
+ $configS = System::getSystemConfiguration('', '', SYS_SYS);
+ $activeSession = array_key_exists('session_block', $configS) ? !(int)$configS['session_block']:true;
+ if ($activeSession){
+ setcookie("PM-TabPrimary", 101010010, time() + (24 * 60 * 60), '/');
+ }
+
$oHeadPublisher = &headPublisher::getSingleton();
$oHeadPublisher->extJsInit = true;
diff --git a/workflow/engine/methods/login/login.php b/workflow/engine/methods/login/login.php
index 00e86e5b7..b9edcfc8a 100755
--- a/workflow/engine/methods/login/login.php
+++ b/workflow/engine/methods/login/login.php
@@ -338,7 +338,13 @@ $flagForgotPassword = isset($oConf->aConfig['login_enableForgotPassword'])
? $oConf->aConfig['login_enableForgotPassword']
: 'off';
+setcookie('PM-Warning', trim(G::LoadTranslation('ID_BLOCKER_MSG'),'*'), time() + (24 * 60 * 60), SYS_CURRENT_URI);
+setcookie("PM-TabPrimary", uniqid(), time() + (24 * 60 * 60), '/');
+
$oHeadPublisher->addScriptCode("var flagForgotPassword = '$flagForgotPassword';");
+$oHeadPublisher->addScriptFile('/jscore/src/PM.js');
+$oHeadPublisher->addScriptFile('/jscore/src/Sessions.js');
+$oHeadPublisher->addScriptFile('/jscore/src/Register.js');
G::RenderPage('publish');
diff --git a/workflow/engine/methods/login/sysLogin.php b/workflow/engine/methods/login/sysLogin.php
index 116d3c465..61c6772f8 100755
--- a/workflow/engine/methods/login/sysLogin.php
+++ b/workflow/engine/methods/login/sysLogin.php
@@ -177,6 +177,12 @@ switch (WS_IN_LOGIN) {
$fileLogin = 'login/sysLogin';
break;
}
+setcookie("PM-Warning", trim(G::LoadTranslation('ID_BLOCKER_MSG'),'*'), time() + (24 * 60 * 60), SYS_CURRENT_URI);
+setcookie("PM-TabPrimary", uniqid(), time() + (24 * 60 * 60), '/');
+$oHeadPublisher = & headPublisher::getSingleton();
+$oHeadPublisher->addScriptFile('/jscore/src/PM.js');
+$oHeadPublisher->addScriptFile('/jscore/src/Sessions.js');
+$oHeadPublisher->addScriptFile('/jscore/src/Register.js');
$G_PUBLISH->AddContent ('xmlform', 'xmlform', $fileLogin, '', $aField, 'sysLogin');
G::RenderPage ("publish");
diff --git a/workflow/engine/methods/processes/main.php b/workflow/engine/methods/processes/main.php
index b2fc2a860..f460062b7 100755
--- a/workflow/engine/methods/processes/main.php
+++ b/workflow/engine/methods/processes/main.php
@@ -48,8 +48,9 @@ $G_ID_MENU_SELECTED = 'PROCESSES';
$G_ID_SUB_MENU_SELECTED = '-';
$G_PUBLISH = new Publisher();
-// $oHeadPublisher = & headPublisher::getSingleton();
-//$oHeadPublisher->addScriptFile('/jscore/processes/main.js');
+$oHeadPublisher = & headPublisher::getSingleton();
+$oHeadPublisher->addScriptFile('/jscore/src/PM.js');
+$oHeadPublisher->addScriptFile('/jscore/src/Sessions.js');
$G_PUBLISH->AddContent( 'view', 'processes/mainLoad' );
if (isset( $_GET['type'] ))
diff --git a/workflow/engine/templates/cases/casesList.js b/workflow/engine/templates/cases/casesList.js
index 7f17209a4..c3faa001c 100755
--- a/workflow/engine/templates/cases/casesList.js
+++ b/workflow/engine/templates/cases/casesList.js
@@ -80,7 +80,8 @@ function caseNotes(){
}
function openCase(){
- var rowModel = grid.getSelectionModel().getSelected();
+ var rowModel = grid.getSelectionModel().getSelected(),
+ nameTab;
if(rowModel){
var appUid = rowModel.data.APP_UID;
var delIndex = rowModel.data.DEL_INDEX;
@@ -134,7 +135,8 @@ function openCase(){
if(casesNewTab) {
casesNewTab.close();
}
- casesNewTab = window.open(requestFile + '?' + params);
+ nameTab = PM.Sessions.getCookie('PM-TabPrimary') + '_openCase';
+ casesNewTab = window.open(requestFile + '?' + params, nameTab);
} else {
redirect(requestFile + '?' + params);
}
diff --git a/workflow/engine/templates/cases/casesListConsolidated.js b/workflow/engine/templates/cases/casesListConsolidated.js
index fec3f8a53..f01dd85b6 100644
--- a/workflow/engine/templates/cases/casesListConsolidated.js
+++ b/workflow/engine/templates/cases/casesListConsolidated.js
@@ -262,7 +262,9 @@ function openCase(){
if(newCaseNewTab) {
newCaseNewTab.close();
}
- newCaseNewTab = window.open(requestFile + '?' + params);
+
+ newCaseNewTab = window.open(requestFile + '?' + params);
+ newCaseNewTab.name = PM.Sessions.getCookie('PM-TabPrimary');
} else {
redirect(requestFile + '?' + params);
}
@@ -278,7 +280,8 @@ function jumpToCase(appNumber){
Ext.Ajax.request({
url: 'cases_Ajax',
success: function(response) {
- var res = Ext.decode(response.responseText);
+ var res = Ext.decode(response.responseText),
+ nameTab;
if (res.exists === true) {
params = 'APP_NUMBER=' + appNumber;
params += '&action=jump';
@@ -287,7 +290,8 @@ function jumpToCase(appNumber){
if(newCaseNewTab) {
newCaseNewTab.close();
}
- newCaseNewTab = window.open(requestFile + '?' + params);
+ nameTab = PM.Sessions.getCookie('PM-TabPrimary') + '_openCase';
+ newCaseNewTab = window.open(requestFile + '?' + params, nameTab);
} else {
redirect(requestFile + '?' + params);
}
diff --git a/workflow/engine/templates/cases/casesStartCase.js b/workflow/engine/templates/cases/casesStartCase.js
index cd25db210..776a4eedd 100755
--- a/workflow/engine/templates/cases/casesStartCase.js
+++ b/workflow/engine/templates/cases/casesStartCase.js
@@ -461,7 +461,7 @@ function openCaseA(n){
taskId : n.attributes.tas_uid
},
success : function(response) {
-
+ var nameTab;
try {
var res = Ext.util.JSON.decode(response.responseText);
if (res.openCase) {
@@ -469,7 +469,8 @@ function openCaseA(n){
if(newCaseNewTab) {
newCaseNewTab.close();
}
- newCaseNewTab = window.open(res.openCase.PAGE);
+ nameTab = PM.Sessions.getCookie('PM-TabPrimary') + '_openCase';
+ newCaseNewTab = window.open(res.openCase.PAGE, nameTab);
} else {
window.location = res.openCase.PAGE;
}
diff --git a/workflow/engine/templates/cases/cases_Load.php b/workflow/engine/templates/cases/cases_Load.php
index 64324745b..29daf4d79 100755
--- a/workflow/engine/templates/cases/cases_Load.php
+++ b/workflow/engine/templates/cases/cases_Load.php
@@ -56,4 +56,6 @@ $_POST['qs'] = $filter->xssFilterHard($_POST['qs']);
}
}
+
+