From 8edabf647814a012307bbf68628e4656ecf89eff Mon Sep 17 00:00:00 2001
From: Marius Cramer <m.cramer@pixcept.de>
Date: Wed, 30 Apr 2014 14:12:28 -0400
Subject: [PATCH] Merge remote-tracking branch 'ispc/master'

---
 interface/web/js/scrigo.js.php |  328 +++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 258 insertions(+), 70 deletions(-)

diff --git a/interface/web/js/scrigo.js.php b/interface/web/js/scrigo.js.php
index e550b47..6ac4510 100644
--- a/interface/web/js/scrigo.js.php
+++ b/interface/web/js/scrigo.js.php
@@ -1,48 +1,140 @@
 <?php
-	session_start();
-	include('../../lib/config.inc.php');
-	$lang = (isset($_SESSION['s']['language']) && $_SESSION['s']['language'] != '')?$_SESSION['s']['language']:'en';
-	include_once(ISPC_ROOT_PATH.'/web/strengthmeter/lib/lang/'.$lang.'_strengthmeter.lng');
+session_start();
+include '../../lib/config.inc.php';
+header('Content-Type: text/javascript; charset=utf-8'); // the config file sets the content type header so we have to override it here!
+require_once '../../lib/app.inc.php';
+$lang = (isset($_SESSION['s']['language']) && $_SESSION['s']['language'] != '')?$_SESSION['s']['language']:'en';
+include_once ISPC_ROOT_PATH.'/web/strengthmeter/lib/lang/'.$lang.'_strengthmeter.lng';
+
+$app->uses('ini_parser,getconf');
+$server_config_array = $app->getconf->get_global_config();
 ?>
 var pageFormChanged = false;
 var tabChangeWarningTxt = '';
 var tabChangeDiscardTxt = '';
 var tabChangeWarning = false;
 var tabChangeDiscard = false;
+var requestsRunning = 0;
+var indicatorPaddingH = -1;
+var indicatorPaddingW = -1;
+var indicatorCompleted = false;
+var registeredHooks = new Array();
 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 
+	/* 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 registerHook(name, callback) {
+    if(!registeredHooks[name]) registeredHooks[name] = new Array();
+    var newindex = registeredHooks[name].length;
+    registeredHooks[name][newindex] = callback;
+}
+
+function callHook(name, params) {
+    if(!registeredHooks[name]) return;
+    for(var i = 0; i < registeredHooks[name].length; i++) {
+        var callback = registeredHooks[name][i];
+        callback(name, params);
+    }
+}
+
+function resetFormChanged() {
+    pageFormChanged = false;
+}
+
+function showLoadIndicator() {
+    document.body.style.cursor = 'wait';
+
+<?php
+if($server_config_array['misc']['use_loadindicator'] == 'y'){
+?>
+    requestsRunning += 1;
+
+    if(requestsRunning < 2) {
+        var indicator = jQuery('#ajaxloader');
+        if(indicator.length < 1) {
+            indicator = jQuery('<div id="ajaxloader" style="display: none;"></div>');
+            indicator.appendTo('body');
+        }
+        var parent = jQuery('#content');
+        if(parent.length < 1) return;
+        indicatorCompleted = false;
+
+        var atx = parent.offset().left + 150; //((parent.outerWidth(true) - indicator.outerWidth(true)) / 2);
+        var aty = parent.offset().top + 150;
+        indicator.css( {'left': atx, 'top': aty } ).fadeIn('fast', function() {
+            // check if loader should be hidden immediately
+            indicatorCompleted = true;
+            if(requestsRunning < 1) $(this).fadeOut('fast', function() { $(this).hide();});
+        });
+    }
+<?php
+}
+?>
+}
+
+function hideLoadIndicator() {
+    document.body.style.cursor = '';
+
+    requestsRunning -= 1;
+    if(requestsRunning < 1) {
+        requestsRunning = 0; // just for the case...
+        if(indicatorCompleted == true) jQuery('#ajaxloader').fadeOut('fast', function() { jQuery('#ajaxloader').hide(); } );
+    }
+}
+
+function onAfterContentLoad(url, data) {
+    if(!data) data = '';
+    else data = '&' + data;
+<?php
+if($server_config_array['misc']['use_combobox'] == 'y'){
+?>
+    $('#pageContent').find("select:not(.chosen-select)").combobox();
+    $('.chosen-select').chosen({no_results_text: "<?php echo $wb['globalsearch_noresults_text_txt']; ?>", width: '300px'});
+<?php
+}
+?>
+    callHook('onAfterContentLoad', {'url': url, 'data': data });
+}
+
 function loadContentRefresh(pagename) {
-	
+
   if(document.getElementById('refreshinterval').value > 0) {
-	var pageContentObject2 = jQuery.ajax({	type: "GET", 
+	var pageContentObject2 = jQuery.ajax({	type: "GET",
 											url: pagename,
 											data: "refresh="+document.getElementById('refreshinterval').value,
 											dataType: "html",
+											beforeSend: function() {
+												showLoadIndicator();
+											},
 											success: function(data, textStatus, jqXHR) {
+                                                hideLoadIndicator();
 												jQuery('#pageContent').html(jqXHR.responseText);
+                                                onAfterContentLoad(pagename, "refresh="+document.getElementById('refreshinterval').value);
                                                 pageFormChanged = false;
 											},
 											error: function() {
+                                                hideLoadIndicator();
 												reportError('Ajax Request was not successful.'+pagename);
 											}
 										});
-  	setTimeout( "loadContentRefresh('"+pagename+"&refresh="+document.getElementById('refreshinterval').value+"')", document.getElementById('refreshinterval').value*1000 );
+  	setTimeout( "loadContentRefresh('"+pagename+"&refresh="+document.getElementById('refreshinterval').value+"')", document.getElementById('refreshinterval').value*1000*60 );
   }
 }
 
 function capp(module, redirect) {
-	var submitFormObj = jQuery.ajax({		type: "GET", 
-											url: "capp.php", 
+	var submitFormObj = jQuery.ajax({		type: "GET",
+											url: "capp.php",
 											data: "mod="+module+((redirect != undefined) ? '&redirect='+redirect : ''),
 											dataType: "html",
+											beforeSend: function() {
+												showLoadIndicator();
+											},
 											success: function(data, textStatus, jqXHR) {
 												if(jqXHR.responseText != '') {
 													if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) {
@@ -56,8 +148,10 @@
 													}
 												}
 												loadMenus();
+                                                hideLoadIndicator();
 											},
 											error: function() {
+                                                hideLoadIndicator();
 												reportError('Ajax Request was not successful.'+module);
 											}
 									});
@@ -75,11 +169,19 @@
     if(passwordObj.value == ''){
         passwordObj.focus();
         return;
-    }   
-	var submitFormObj = jQuery.ajax({		type: "POST", 
+    }
+
+	$('#dummy_username').val(userNameObj.value);
+	$('#dummy_passwort').val(passwordObj.value);
+	$('#dummy_login_form').submit();
+
+	var submitFormObj = jQuery.ajax({		type: "POST",
 											url: "content.php",
 											data: jQuery('#'+formname).serialize(),
 											dataType: "html",
+											beforeSend: function() {
+												showLoadIndicator();
+											},
 											success: function(data, textStatus, jqXHR) {
 												if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) {
 													var parts = jqXHR.responseText.split(':');
@@ -92,11 +194,14 @@
 													document.location.href = 'index.php';
 												} else {
 													jQuery('#pageContent').html(jqXHR.responseText);
+                                                    onAfterContentLoad('content.php', jQuery('#'+formname).serialize());
                                                     pageFormChanged = false;
 												}
 												loadMenus();
+                                                hideLoadIndicator();
 											},
 											error: function() {
+                                                hideLoadIndicator();
 												reportError('Ajax Request was not successful.110');
 											}
 									});
@@ -107,14 +212,17 @@
 	}
 	document.getElementById('footer').innerHTML = 'Powered by <a href="http://www.ispconfig.org" target="_blank">ISPConfig</a>';
 	*/
-	
+
 }
 
 function submitForm(formname,target) {
-	var submitFormObj = jQuery.ajax({		type: "POST", 
+	var submitFormObj = jQuery.ajax({		type: "POST",
 											url: target,
 											data: jQuery('#'+formname).serialize(),
 											dataType: "html",
+											beforeSend: function() {
+												showLoadIndicator();
+											},
 											success: function(data, textStatus, jqXHR) {
 												if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) {
 													var parts = jqXHR.responseText.split(':');
@@ -124,10 +232,13 @@
 													//window.setTimeout('loadContent(redirect)', 1000);
 												} else {
 													jQuery('#pageContent').html(jqXHR.responseText);
+                                                    onAfterContentLoad(target, jQuery('#'+formname).serialize());
                                                     pageFormChanged = false;
 												}
+                                                hideLoadIndicator();
 											},
 											error: function(jqXHR, textStatus, errorThrown) {
+                                                hideLoadIndicator();
 												var parts = jqXHR.responseText.split(':');
 												reportError('Ajax Request was not successful. 111');
 											}
@@ -143,10 +254,13 @@
 function submitFormConfirm(formname,target,confirmation) {
 	var successMessage = arguments[3];
 	if(window.confirm(confirmation)) {
-		var submitFormObj = jQuery.ajax({	type: "POST", 
+		var submitFormObj = jQuery.ajax({	type: "POST",
 											url: target,
 											data: jQuery('#'+formname).serialize(),
 											dataType: "html",
+											beforeSend: function() {
+												showLoadIndicator();
+											},
 											success: function(data, textStatus, jqXHR) {
 												if(successMessage) alert(successMessage);
 												if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) {
@@ -157,10 +271,13 @@
 													//window.setTimeout('loadContent(redirect)', 1000);
 												} else {
 													jQuery('#pageContent').html(jqXHR.responseText);
+                                                    onAfterContentLoad(target, jQuery('#'+formname).serialize());
                                                     pageFormChanged = false;
 												}
+                                                hideLoadIndicator();
 											},
 											error: function(jqXHR, textStatus, errorThrown) {
+                                                hideLoadIndicator();
 												var parts = jqXHR.responseText.split(':');
 												reportError('Ajax Request was not successful. 111');
 											}
@@ -168,10 +285,10 @@
 	}
 }
 
-function submitUploadForm(formname,target) {		
+function submitUploadForm(formname,target) {
 	var handleResponse = function(loadedFrame) {
 		var response, responseStr = loadedFrame.contentWindow.document.body.innerHTML;
-		
+
 		try {
 			response = JSON.parse(responseStr);
 		} catch(e) {
@@ -187,9 +304,9 @@
 			msg = msg+'<div id="errorMsg">'+errormsg+'</div>';
 		}
 		return msg;
-		
+
     };
-	
+
 	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();
@@ -211,12 +328,12 @@
 
 function loadContent(pagename) {
   var params = arguments[1];
-  var pageContentObject2 = jQuery.ajax({	type: "GET", 
+  var pageContentObject2 = jQuery.ajax({	type: "GET",
 											url: pagename,
                                             data: (params ? params : null),
 											dataType: "html",
 											beforeSend: function() {
-												jQuery('#pageContent').html('<div id="ajaxloader"><img src="themes/default/images/ajax-loader.gif" /></div>');
+												showLoadIndicator();
 											},
 											success: function(data, textStatus, jqXHR) {
 												if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) {
@@ -230,12 +347,15 @@
 													//var reponse = jQuery(jqXHR.responseText);
 													//var reponseScript = reponse.filter("script");
 													//jQuery.each(reponseScript, function(idx, val) { eval(val.text); } );
-													
+
 													jQuery('#pageContent').html(jqXHR.responseText);
+                                                    onAfterContentLoad(pagename, (params ? params : null));
                                                     pageFormChanged = false;
 												}
+                                                hideLoadIndicator();
 											},
 											error: function() {
+                                                hideLoadIndicator();
 												reportError('Ajax Request was not successful. 113');
 											}
 									});
@@ -243,24 +363,30 @@
 
 
 function loadInitContent() {
-	var pageContentObject = jQuery.ajax({	type: "GET", 
+	var pageContentObject = jQuery.ajax({	type: "GET",
 											url: "content.php",
 											data: "s_mod=login&s_pg=index",
 											dataType: "html",
+											beforeSend: function() {
+												showLoadIndicator();
+											},
 											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);
+                                                    onAfterContentLoad('content.php', "s_mod=login&s_pg=index");
                                                     pageFormChanged = false;
 												}
+                                                hideLoadIndicator();
 											},
 											error: function() {
+                                                hideLoadIndicator();
 												reportError('Ajax Request was not successful. 114');
 											}
 										});
-  
+
   loadMenus();
   keepalive();
   setTimeout("setFocus()",1000);
@@ -276,40 +402,50 @@
 
 
 function loadMenus() {
-  var sideNavObject = jQuery.ajax({			type: "GET", 
+  var sideNavObject = jQuery.ajax({			type: "GET",
 											url: "nav.php",
 											data: "nav=side",
 											dataType: "html",
+											beforeSend: function() {
+												showLoadIndicator();
+											},
 											success: function(data, textStatus, jqXHR) {
+                                                hideLoadIndicator();
 												jQuery('#sideNav').html(jqXHR.responseText);
 											},
 											error: function() {
+                                                hideLoadIndicator();
 												reportError('Ajax Request was not successful. 115');
 											}
 									});
-	
-  var topNavObject = jQuery.ajax({			type: "GET", 
+
+  var topNavObject = jQuery.ajax({			type: "GET",
 											url: "nav.php",
 											data: "nav=top",
 											dataType: "html",
+											beforeSend: function() {
+												showLoadIndicator();
+											},
 											success: function(data, textStatus, jqXHR) {
+                                                hideLoadIndicator();
 												jQuery('#topNav').html(jqXHR.responseText);
 											},
 											error: function(o) {
+                                                hideLoadIndicator();
 												reportError('Ajax Request was not successful. 116');
 											}
 								});
 
 }
 
-function changeTab(tab,target) {
+function changeTab(tab,target,force) {
 	//document.forms[0].next_tab.value = tab;
 	document.pageForm.next_tab.value = tab;
-    
+
     var idel = jQuery('form#pageForm').find('[name="id"]');
     var id = null;
     if(idel.length > 0) id = idel.val();
-    if(tabChangeDiscard == 'y') {
+    if(tabChangeDiscard == 'y' && !force) {
         if((idel.length < 1 || id) && (pageFormChanged == false || window.confirm(tabChangeDiscardTxt))) {
             var next_tab = tab;
             if(id) loadContent(target, {'next_tab': next_tab, 'id': id});
@@ -331,7 +467,7 @@
         }
     }
 }
-	
+
 function del_record(link,confirmation) {
   if(window.confirm(confirmation)) {
           loadContent(link);
@@ -345,23 +481,32 @@
 }
 
 function loadContentInto(elementid,pagename) {
-  var pageContentObject2 = jQuery.ajax({	type: "GET", 
+  var pageContentObject2 = jQuery.ajax({	type: "GET",
 											url: pagename,
 											dataType: "html",
+											beforeSend: function() {
+//												showLoadIndicator();
+											},
 											success: function(data, textStatus, jqXHR) {
+//                                                hideLoadIndicator();
 												jQuery('#'+elementid).html(jqXHR.responseText);
 											},
 											error: function() {
+//                                                hideLoadIndicator();
 												reportError('Ajax Request was not successful. 118');
 											}
 										});
 }
 
 function loadOptionInto(elementid,pagename) {
-	var pageContentObject2 = jQuery.ajax({	type: "GET", 
+	var pageContentObject2 = jQuery.ajax({	type: "GET",
 											url: pagename,
 											dataType: "html",
+											beforeSend: function() {
+//												showLoadIndicator();
+											},
 											success: function(data, textStatus, jqXHR) {
+//                                                hideLoadIndicator();
 												var teste = jqXHR.responseText;
 												var elemente = teste.split('#');
 												el=document.getElementById(elementid);
@@ -375,13 +520,14 @@
 												}
 											},
 											error: function() {
+//                                                hideLoadIndicator();
 												reportError('Ajax Request was not successful. 119');
 											}
 										});
 }
 
 function keepalive() {
-	var pageContentObject3 = jQuery.ajax({	type: "GET", 
+	var pageContentObject3 = jQuery.ajax({	type: "GET",
 											url: "keepalive.php",
 											dataType: "html",
 											success: function(data, textStatus, jqXHR) {
@@ -395,8 +541,13 @@
 }
 
 
-
-var pass_minimum_length = 5;
+<?php
+$min_password_length = 5;
+if(isset($server_config_array['misc']['min_password_length'])) {
+	$min_password_length = $app->functions->intval($server_config_array['misc']['min_password_length']);
+}
+?>
+var pass_minimum_length = <?php echo $min_password_length; ?>;
 var pass_messages = new Array();
 
 var pass_message = new Array();
@@ -436,24 +587,24 @@
 		pass_result(0);
 		return;
 	}
-	
+
 	if (length < 5) {
 		pass_result(1);
 		return;
 	}
-	
+
 	if (pass_contains(password, "ABCDEFGHIJKLNMOPQRSTUVWXYZ")) {
 		points += 1;
 	}
-	
+
 	if (pass_contains(password, "0123456789")) {
 		points += 1;
 	}
-	
+
 	if (pass_contains(password, "`~!@#$%^&*()_+|\=-[]}{';:/?.>,<\" ")) {
 		points += 1;
 	}
-	
+
 	if (points == 0) {
 		if (length >= 5 && length <=6) {
 			pass_result(1);
@@ -515,45 +666,70 @@
 	return false;
 }
 
+var new_tpl_add_id = 0;
 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 tpl_add = jQuery('#template_additional').val();
+    var addTemplate = jQuery('#tpl_add_select').val().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');
+        var newVal = tpl_add.split('/');
+        new_tpl_add_id += 1;
+        var delbtn = jQuery('<a href="#"></a>').attr('class', 'button icons16 icoDelete').click(function(e) {
+            e.preventDefault();
+            delAdditionalTemplate($(this).parent().attr('rel'));
+        });
+        newVal[newVal.length] = 'n' + new_tpl_add_id + ':' + addTplId;
+	    jQuery('<li>' + addTplText + '</li>').attr('rel', 'n' + new_tpl_add_id).append(delbtn).appendTo('#template_additional_list ul');
+	    jQuery('#template_additional').val(newVal.join('/'));
+	    alert('additional template ' + addTplText + ' added to customer');
 	} else {
-	  alert('no additional template selcted');
+	    alert('no additional template selcted');
 	}
 }
 
-function delAdditionalTemplate(){
-	var tpl_add = document.getElementById('template_additional').value;
-	if(tpl_add != '') {
-		var tpl_list = document.getElementById('template_additional_list').innerHTML;
+function delAdditionalTemplate(tpl_id){
+    var tpl_add = jQuery('#template_additional').val();
+	if(tpl_id) {
+        // new style
+		var $el = jQuery('#template_additional_list ul').find('li[rel="' + tpl_id + '"]').eq(0); // only the first
+        var addTplText = $el.text();
+        $el.remove();
+
+		var oldVal = tpl_add.split('/');
+		var newVal = new Array();
+        for(var i = 0; i < oldVal.length; i++) {
+            var tmp = oldVal[i].split(':', 2);
+            if(tmp.length == 2 && tmp[0] == tpl_id) continue;
+            newVal[newVal.length] = oldVal[i];
+        }
+        jQuery('#template_additional').val(newVal.join('/'));
+		alert('additional template ' + addTplText + ' deleted from customer');
+    } else if(tpl_add != '') {
+        // old style
 		var addTemplate = document.getElementById('tpl_add_select').value.split('|',2);
 		var addTplId = addTemplate[0];
 		var addTplText = addTemplate[1];
+
+		jQuery('#template_additional_list ul').find('li:not([rel])').each(function() {
+            var text = jQuery(this).text();
+            if(text == addTplText) {
+                jQuery(this).remove();
+                return false;
+            }
+            return this;
+        });
+
 		var newVal = tpl_add;
-		newVal = newVal.replace(addTplId, '');
+        var repl = new RegExp('(^|\/)' + addTplId + '(\/|$)');
+		newVal = newVal.replace(repl, '');
 		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;
+		jQuery('#template_additional').val(newVal);
 		alert('additional template ' + addTplText + ' deleted from customer');
   } else {
   	alert('no additional template selcted');
   }
-  
+
 }
 
 function getInternetExplorerVersion() {
@@ -591,12 +767,19 @@
 	return password;
 }
 
+<?php
+$min_password_length = 10;
+if(isset($server_config_array['misc']['min_password_length'])) {
+	$min_password_length = $app->functions->intval($server_config_array['misc']['min_password_length']);
+}
+?>
+
 function generatePassword(passwordFieldID, repeatPasswordFieldID){
 	var oldPWField = jQuery('#'+passwordFieldID);
 	var newPWField = oldPWField.clone();
 	newPWField.attr('type', 'text').attr('id', 'tmp'+passwordFieldID).insertBefore(oldPWField);
 	oldPWField.remove();
-	var pword = password(10, false);
+	var pword = password(<?php echo $min_password_length ?>, false);
 	jQuery('#'+repeatPasswordFieldID).val(pword);
 	newPWField.attr('id', passwordFieldID).val(pword).trigger('keyup');
 }
@@ -638,7 +821,13 @@
 	var template = jQuery(this).siblings(':input');
 	template.insertAtCaret(placeholderText);
 });
-		
+
+jQuery('.addPlaceholderContent').live("click", function(){
+	var placeholderContentText = jQuery(this).find('.addPlaceholderContent').text();
+	var template2 = jQuery(this).siblings(':input');
+	template2.insertAtCaret(placeholderContentText);
+});
+
 jQuery.fn.extend({
 	insertAtCaret: function(myValue){
 		return this.each(function(i) {
@@ -665,4 +854,3 @@
 		})
 	}
 });
-

--
Gitblit v1.9.1