From d06c20db2531cec31cc856bb534e81363b38f1bf Mon Sep 17 00:00:00 2001 From: tbrehm <t.brehm@ispconfig.org> Date: Wed, 23 Nov 2011 04:43:08 -0500 Subject: [PATCH] Fixed: FS#1877 - Redirect Bug --- interface/web/js/scrigo.js.php | 495 ++++++++++++++++++++++++++++++------------------------ 1 files changed, 273 insertions(+), 222 deletions(-) diff --git a/interface/web/js/scrigo.js.php b/interface/web/js/scrigo.js.php index 8831141..94b7075 100644 --- a/interface/web/js/scrigo.js.php +++ b/interface/web/js/scrigo.js.php @@ -1,70 +1,61 @@ <?php session_start(); include('../../lib/config.inc.php'); - include_once(ISPC_ROOT_PATH.'/web/js/lib/lang/'.$_SESSION['s']['language'].'_javascript.lng'); + $lang = (isset($_SESSION['s']['language']) && $_SESSION['s']['language'] != '')?$_SESSION['s']['language']:'en'; + include_once(ISPC_ROOT_PATH.'/web/strengthmeter/lib/lang/'.$lang.'_strengthmeter.lng'); ?> redirect = ''; +function reportError(request) { + /* Error reporting is disabled by default as some browsers like safari + sometimes throw errors when a ajax request is delayed even if the + ajax request worked. */ + + /*alert(request);*/ +} + function loadContentRefresh(pagename) { - var pageContentCallbackRefresh = { - success: function(o) { - document.getElementById('pageContent').innerHTML = o.responseText; - }, - failure: function(o) { - alert('Ajax Request was not successful.'+pagename); - } - } if(document.getElementById('refreshinterval').value > 0) { - var pageContentObject2 = YAHOO.util.Connect.asyncRequest('GET', pagename+"&refresh="+document.getElementById('refreshinterval').value, pageContentCallbackRefresh); + var pageContentObject2 = jQuery.ajax({ type: "GET", + url: pagename, + data: "refresh="+document.getElementById('refreshinterval').value, + dataType: "html", + success: function(data, textStatus, jqXHR) { + jQuery('#pageContent').html(jqXHR.responseText); + }, + error: function() { + reportError('Ajax Request was not successful.'+pagename); + }, + }); setTimeout( "loadContentRefresh('"+pagename+"&refresh="+document.getElementById('refreshinterval').value+"')", document.getElementById('refreshinterval').value*1000 ); } } function capp(module) { - var cappCallback = { - success: function(o) { - if(o.responseText != '') { - if(o.responseText.indexOf('HEADER_REDIRECT:') > -1) { - var parts = o.responseText.split(':'); - loadContent(parts[1]); - } else { - alert(o.responseText); - } - } - loadMenus(); - }, - failure: function(o) { - alert('Ajax Request was not successful.'); - } - } - var submitFormObj = YAHOO.util.Connect.asyncRequest('GET', 'capp.php?mod='+module, cappCallback); + var submitFormObj = jQuery.ajax({ type: "GET", + url: "capp.php", + data: "mod="+module, + dataType: "html", + success: function(data, textStatus, jqXHR) { + if(jqXHR.responseText != '') { + if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) { + var parts = jqXHR.responseText.split(':'); + loadContent(parts[1]); + } else { + alert(jqXHR.responseText); + } + } + loadMenus(); + }, + error: function() { + reportError('Ajax Request was not successful.'+module); + }, + }); } function submitLoginForm(formname) { - - var submitFormCallback = { - success: function(o) { - if(o.responseText.indexOf('HEADER_REDIRECT:') > -1) { - var parts = o.responseText.split(':'); - //alert(parts[1]); - loadContent(parts[1]); - //redirect = parts[1]; - //window.setTimeout('loadContent(redirect)', 1000); - } else if (o.responseText.indexOf('LOGIN_REDIRECT:') > -1) { - // Go to the login page - document.location.href = 'index.php'; - } else { - document.getElementById('pageContent').innerHTML = o.responseText; - } - loadMenus(); - }, - failure: function(o) { - alert('Ajax Request was not successful.'); - } - } - //* Validate form. TODO: username and password with strip(); var frm = document.getElementById(formname); var userNameObj = frm.username; @@ -77,37 +68,60 @@ passwordObj.focus(); return; } - YAHOO.util.Connect.setForm(formname); - var submitFormObj = YAHOO.util.Connect.asyncRequest('POST', 'content.php', submitFormCallback); + var submitFormObj = jQuery.ajax({ type: "POST", + url: "content.php", + data: jQuery('#'+formname).serialize(), + dataType: "html", + success: function(data, textStatus, jqXHR) { + if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) { + var parts = jqXHR.responseText.split(':'); + //alert(parts[1]); + loadContent(parts[1]); + //redirect = parts[1]; + //window.setTimeout('loadContent(redirect)', 1000); + } else if (jqXHR.responseText.indexOf('LOGIN_REDIRECT:') > -1) { + // Go to the login page + document.location.href = 'index.php'; + } else { + jQuery('#pageContent').html(jqXHR.responseText); + } + loadMenus(); + }, + error: function() { + reportError('Ajax Request was not successful.110'); + }, + }); /* if(redirect != '') { loadContent(redirect); redirect = ''; } + document.getElementById('footer').innerHTML = 'Powered by <a href="http://www.ispconfig.org" target="_blank">ISPConfig</a>'; */ + } function submitForm(formname,target) { - - var submitFormCallback = { - success: function(o) { - if(o.responseText.indexOf('HEADER_REDIRECT:') > -1) { - var parts = o.responseText.split(':'); - //alert(parts[1]); - loadContent(parts[1]); - //redirect = parts[1]; - //window.setTimeout('loadContent(redirect)', 1000); - } else { - document.getElementById('pageContent').innerHTML = o.responseText; - } - }, - failure: function(o) { - alert('Ajax Request was not successful. 1'); - } - } - - YAHOO.util.Connect.setForm(formname); - var submitFormObj = YAHOO.util.Connect.asyncRequest('POST', target, submitFormCallback); + var submitFormObj = jQuery.ajax({ type: "POST", + url: target, + data: jQuery('#'+formname).serialize(), + dataType: "html", + success: function(data, textStatus, jqXHR) { + if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) { + var parts = jqXHR.responseText.split(':'); + //alert(parts[1]); + loadContent(parts[1]); + //redirect = parts[1]; + //window.setTimeout('loadContent(redirect)', 1000); + } else { + jQuery('#pageContent').html(jqXHR.responseText); + } + }, + error: function(jqXHR, textStatus, errorThrown) { + var parts = jqXHR.responseText.split(':'); + reportError('Ajax Request was not successful. 111'); + }, + }); /* if(redirect != '') { loadContent(redirect); @@ -116,38 +130,39 @@ */ } -function submitUploadForm(formname,target) { - - var submitFormCallback = { - success: function(o) { - if(o.responseText.indexOf('HEADER_REDIRECT:') > -1) { - var parts = o.responseText.split(':'); - //alert(parts[1]); - loadContent(parts[1]); - //redirect = parts[1]; - //window.setTimeout('loadContent(redirect)', 1000); - } else { - document.getElementById('pageContent').innerHTML = o.responseText; - } - }, - upload: function(o) { - if(o.responseText.indexOf('HEADER_REDIRECT:') > -1) { - var parts = o.responseText.split(':'); - //alert(parts[1]); - loadContent(parts[1]); - //redirect = parts[1]; - //window.setTimeout('loadContent(redirect)', 1000); - } else { - document.getElementById('pageContent').innerHTML = o.responseText; - } - }, - failure: function(o) { - alert('Ajax Request was not successful. 1'); +function submitUploadForm(formname,target) { + var handleResponse = function(loadedFrame) { + var response, responseStr = loadedFrame.contentWindow.document.body.innerHTML; + + try { + response = JSON.parse(responseStr); + } catch(e) { + response = responseStr; } - } + var msg = ''; + var okmsg = jQuery('#OKMsg',response).html(); + if(okmsg){ + msg = '<div id="OKMsg">'+okmsg+'</div>'; + } + var errormsg = jQuery('#errorMsg',response).html(); + if(errormsg){ + msg = msg+'<div id="errorMsg">'+errormsg+'</div>'; + } + return msg; + + }; - YAHOO.util.Connect.setForm(formname,true); - var submitFormObj = YAHOO.util.Connect.asyncRequest('POST', target, submitFormCallback); + var frame_id = 'ajaxUploader-iframe-' + Math.round(new Date().getTime() / 1000); + jQuery('body').after('<iframe width="0" height="0" style="display:none;" name="'+frame_id+'" id="'+frame_id+'"/>'); + jQuery('input[type="file"]').closest("form").attr({target: frame_id, action: target}).submit(); + jQuery('#'+frame_id).load(function() { + var msg = handleResponse(this); + jQuery('#errorMsg').remove(); + jQuery('#OKMsg').remove(); + jQuery('input[name="id"]').before(msg); + jQuery(this).remove(); + }); + /* if(redirect != '') { loadContent(redirect); @@ -157,87 +172,88 @@ } function loadContent(pagename) { - var pageContentCallback2 = { - success: function(o) { - if(o.responseText.indexOf('HEADER_REDIRECT:') > -1) { - var parts = o.responseText.split(':'); - loadContent(parts[1]); - } else if (o.responseText.indexOf('URL_REDIRECT:') > -1) { - var newUrl= o.responseText.substr(o.responseText.indexOf('URL_REDIRECT:') + "URL_REDIRECT:".length); - document.location.href = newUrl; - } else { - document.getElementById('pageContent').innerHTML = o.responseText; - } - }, - failure: function(o) { - alert('Ajax Request was not successful.'); - } - } - - - var pageContentObject2 = YAHOO.util.Connect.asyncRequest('GET', pagename, pageContentCallback2); + var pageContentObject2 = jQuery.ajax({ type: "GET", + url: pagename, + dataType: "html", + success: function(data, textStatus, jqXHR) { + if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) { + var parts = jqXHR.responseText.split(':'); + loadContent(parts[1]); + } else if (jqXHR.responseText.indexOf('URL_REDIRECT:') > -1) { + var newUrl= jqXHR.responseText.substr(jqXHR.responseText.indexOf('URL_REDIRECT:') + "URL_REDIRECT:".length); + document.location.href = newUrl; + } else { + //document.getElementById('pageContent').innerHTML = jqXHR.responseText; + //var reponse = jQuery(jqXHR.responseText); + //var reponseScript = reponse.filter("script"); + //jQuery.each(reponseScript, function(idx, val) { eval(val.text); } ); + jQuery('#pageContent').html(jqXHR.responseText); + } + + }, + error: function() { + reportError('Ajax Request was not successful. 113'); + }, + }); } function loadInitContent() { - - var pageContentCallback = { - success: function(o) { - if(o.responseText.indexOf('HEADER_REDIRECT:') > -1) { - var parts = o.responseText.split(":"); - loadContent(parts[1]); - } else { - document.getElementById('pageContent').innerHTML = o.responseText; - } - - /* - var items = document.getElementsByTagName('input'); - for(i=0;i<items.length;i++) { - //var oButton = new YAHOO.widget.Button(items[i].id); - if(items[i].type == 'button') { - //alert(items[i].id); - var oButton = new YAHOO.widget.Button(items[i].id); - oButton.addListener("click",submitLoginForm); - } - } - //var oButton = new YAHOO.widget.Button("submit"); - */ - }, - failure: function(o) { - alert('Ajax Request was not successful.'); - } - } - - var pageContentObject = YAHOO.util.Connect.asyncRequest('GET', 'content.php?s_mod=login&s_pg=index', pageContentCallback); + var pageContentObject = jQuery.ajax({ type: "GET", + url: "content.php", + data: "s_mod=login&s_pg=index", + dataType: "html", + success: function(data, textStatus, jqXHR) { + if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) { + var parts = jqXHR.responseText.split(":"); + loadContent(parts[1]); + } else { + jQuery('#pageContent').html(jqXHR.responseText); + } + }, + error: function() { + reportError('Ajax Request was not successful. 114'); + }, + }); loadMenus(); keepalive(); + setTimeout("setFocus()",1000); } +function setFocus() { + try { + document.pageForm.username.focus(); + } catch (e) { + } +} + + function loadMenus() { + var sideNavObject = jQuery.ajax({ type: "GET", + url: "nav.php", + data: "nav=side", + dataType: "html", + success: function(data, textStatus, jqXHR) { + jQuery('#sideNav').html(jqXHR.responseText); + }, + error: function() { + reportError('Ajax Request was not successful. 115'); + }, + }); - var sideNavCallback = { - success: function(o) { - document.getElementById('sideNav').innerHTML = o.responseText; - }, - failure: function(o) { - alert('Ajax Request was not successful.'); - } - } - - var sideNavObject = YAHOO.util.Connect.asyncRequest('GET', 'nav.php?nav=side', sideNavCallback); - - var topNavCallback = { - success: function(o) { - document.getElementById('topNav').innerHTML = o.responseText; - }, - failure: function(o) { - alert('Ajax Request was not successful.'); - } - } - - var topNavObject = YAHOO.util.Connect.asyncRequest('GET', 'nav.php?nav=top', topNavCallback); + var topNavObject = jQuery.ajax({ type: "GET", + url: "nav.php", + data: "nav=top", + dataType: "html", + success: function(data, textStatus, jqXHR) { + jQuery('#topNav').html(jqXHR.responseText); + }, + error: function(o) { + reportError('Ajax Request was not successful. 116'); + }, + }); } @@ -246,13 +262,6 @@ document.pageForm.next_tab.value = tab; submitForm('pageForm',target); } - - - -function reportError(request) - { - alert('Sorry. There was an error.'); - } function del_record(link,confirmation) { if(window.confirm(confirmation)) { @@ -261,30 +270,52 @@ } function loadContentInto(elementid,pagename) { - var itemContentCallback = { - success: function(o) { - document.getElementById(elementid).innerHTML = o.responseText; - }, - failure: function(o) { - alert('Ajax Request was not successful.'); - } - } - + var pageContentObject2 = jQuery.ajax({ type: "GET", + url: pagename, + dataType: "html", + success: function(data, textStatus, jqXHR) { + jQuery('#'+elementid).html(jqXHR.responseText); + }, + error: function() { + reportError('Ajax Request was not successful. 118'); + }, + }); +} - var pageContentObject2 = YAHOO.util.Connect.asyncRequest('GET', pagename, itemContentCallback); +function loadOptionInto(elementid,pagename) { + var pageContentObject2 = jQuery.ajax({ type: "GET", + url: pagename, + dataType: "html", + success: function(data, textStatus, jqXHR) { + var teste = jqXHR.responseText; + var elemente = teste.split('#'); + el=document.getElementById(elementid); + el.innerHTML=''; + for (var i = 0; i < elemente.length; ++i){ + + var foo2 = document.createElement("option"); + foo2.appendChild(document.createTextNode(elemente[i])); + foo2.value=elemente[i]; + el.appendChild(foo2); + } + }, + error: function() { + reportError('Ajax Request was not successful. 119'); + }, + }); } function keepalive() { - var pageContentCallbackKeepalive = { - success: function(o) { - setTimeout( keepalive, 1000000 ); - }, - failure: function(o) { - alert('Sorry. There was an error.'); - } - } - - var pageContentObject3 = YAHOO.util.Connect.asyncRequest('GET', 'keepalive.php', pageContentCallbackKeepalive); + var pageContentObject3 = jQuery.ajax({ type: "GET", + url: "keepalive.php", + dataType: "html", + success: function(data, textStatus, jqXHR) { + setTimeout( keepalive, 1000000 ); + }, + error: function() { + reportError('Session expired. Please login again.'); + }, + }); //setTimeout( keepalive, 1000000 ); } @@ -410,33 +441,53 @@ } function addAdditionalTemplate(){ - var tpl_add = document.getElementById('template_additional').value; - var tpl_list = document.getElementById('template_additional_list').innerHTML; - var addTemplate = document.getElementById('tpl_add_select').value.split('|',2); - var addTplId = addTemplate[0]; - var addTplText = addTemplate[1]; - var newVal = tpl_add + '/' + addTplId + '/'; - newVal = newVal.replace('//', '/'); - var newList = tpl_list + '<br>' + addTplText; - newList = newList.replace('<br><br>', '<br>'); - document.getElementById('template_additional').value = newVal; - document.getElementById('template_additional_list').innerHTML = newList; - alert('additional template ' + addTplText + ' added to customer'); + var tpl_add = document.getElementById('template_additional').value; + + var tpl_list = document.getElementById('template_additional_list').innerHTML; + var addTemplate = document.getElementById('tpl_add_select').value.split('|',2); + var addTplId = addTemplate[0]; + var addTplText = addTemplate[1]; + if(addTplId > 0) { + var newVal = tpl_add + '/' + addTplId + '/'; + newVal = newVal.replace('//', '/'); + var newList = tpl_list + '<br>' + addTplText; + newList = newList.replace('<br><br>', '<br>'); + document.getElementById('template_additional').value = newVal; + document.getElementById('template_additional_list').innerHTML = newList; + alert('additional template ' + addTplText + ' added to customer'); + } else { + alert('no additional template selcted'); + } } function delAdditionalTemplate(){ - var tpl_add = document.getElementById('template_additional').value; - var tpl_list = document.getElementById('template_additional_list').innerHTML; - var addTemplate = document.getElementById('tpl_add_select').value.split('|',2); - var addTplId = addTemplate[0]; - var addTplText = addTemplate[1]; - var newVal = tpl_add; - newVal = newVal.replace(addTplId, ''); - newVal = newVal.replace('//', '/'); - var newList = tpl_list.replace(addTplText, ''); - newList = newList.replace('<br><br>', '<br>'); - document.getElementById('template_additional').value = newVal; - document.getElementById('template_additional_list').innerHTML = newList; - alert('additional template ' + addTplText + ' deleted from customer'); + var tpl_add = document.getElementById('template_additional').value; + if(tpl_add != '') { + var tpl_list = document.getElementById('template_additional_list').innerHTML; + var addTemplate = document.getElementById('tpl_add_select').value.split('|',2); + var addTplId = addTemplate[0]; + var addTplText = addTemplate[1]; + var newVal = tpl_add; + newVal = newVal.replace(addTplId, ''); + newVal = newVal.replace('//', '/'); + var newList = tpl_list.replace(addTplText, ''); + newList = newList.replace('<br><br>', '<br>'); + document.getElementById('template_additional').value = newVal; + document.getElementById('template_additional_list').innerHTML = newList; + alert('additional template ' + addTplText + ' deleted from customer'); + } else { + alert('no additional template selcted'); + } + } +function getInternetExplorerVersion() { + var rv = -1; // Return value assumes failure. + if (navigator.appName == 'Microsoft Internet Explorer') { + var ua = navigator.userAgent; + var re = new RegExp("MSIE ([0-9]{1,}[\.0-9]{0,})"); + if (re.exec(ua) != null) + rv = parseFloat(RegExp.$1); + } + return rv; +} -- Gitblit v1.9.1