/**
* Librerias Javascript - AJAX
* Autor: Jorge Casas [jorgecasas@iternova.net]
* Version: 2.0.1
* Modificado: 20090716
**/
/** XHConn - Simple XMLHTTP Interface - 2005-04-08        **/
function XHConn(){
	var xmlhttp, bComplete = false;
	try { 
		xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); 
	}catch (e) {
		try { 
			xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); 
		}catch (e) {
			try { 
				xmlhttp = new XMLHttpRequest(); 
			}catch (e) { 
				xmlhttp = false; 
			}
		}
	}
	if (!xmlhttp) return null;
	this.connect = function(sURL, sMethod, sVars, fnDone){
		if (!xmlhttp) return false;
		bComplete = false;
		sMethod = sMethod.toUpperCase();
	
		try {
			if (sMethod == "GET"){
				xmlhttp.open(sMethod, sURL+"?"+sVars, true);
				sVars = "";
			}else{
				xmlhttp.open(sMethod, sURL, true);
				xmlhttp.setRequestHeader("Method", "POST "+sURL+" HTTP/1.1");
				xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
			}
			xmlhttp.onreadystatechange = function(){
		        if (xmlhttp.readyState == 4 && !bComplete){
		          bComplete = true;
		          fnDone(xmlhttp);
				}
			};
			xmlhttp.send(sVars);
		}catch(z) {
			return false;
		}
	return true;
	};
	return this;
}
function openPopUp(url,titulo,sizex,sizey){
	cont=1;     //esta variable es por si hay que abrir mas de 1 popup
	popUp=window.open(url,titulo + " [" + cont + "]","width="+sizex+", height="+sizey+",menubar=no,scrollbars=no,status=no,titlebar=no");
	popUp.moveTo((screen.width-sizex)/2,(screen.height-sizey)/2);
	cont++;
}
function cargar_contenido_div(target,url,showloading){
	if (typeof(showloading)=="undefined" || showloading=="true"){
		//cambiamos el contenido del div que tiene id=target por Cargando....
		document.getElementById(target).innerHTML = '<div class=\"load\"><img src=\"images/ajaxloading.gif\" alt=\"+\" class=\"floatleft\" /> Cargando...</div>';
	}
	//creamos la conexion ajax entre servidor y cliente, usando XHConn
	var myConn = new XHConn();
	if (!myConn) alert("XMLHTTP no esta disponible. Intentalo con un navegador mas reciente.");
	//cuando terminemos de hacer las cosas, el servidor respondera, y cargara su respuesta
	// en el div que tenga como id=target
	var finalizado = function (oXML) {
        document.getElementById(target).innerHTML = oXML.responseText;
	};
	//Nos conectamos al servidor mediante Ajax, enviando a la url 
	//(pagina de respuesta del servidor, que ya lleva los parametros via get en la url)
	//Los parametros GET van en el campo URL, por lo que el tercer parametro se deja en blanco
	//Una vez que nos responda el servidor nos devolvera los resultados en el campo finalizado
	myConn.connect(url, "GET", "", finalizado);
}
function ajax_send_post(url,paramkey,paramvalue){
	//Envia parametros de un formulario por POST al servidor (p.e. para modificar variables de sesion en el servidor)
	var myConn = new XHConn();
	if (!myConn) alert("XMLHTTP no esta disponible. Intentalo con un navegador mas reciente.");
	//cuando terminemos de hacer las cosas, el servidor respondera,pero no hacemos nada
	var finalizado = function (oXML) {};
	//nos conectamos al servidor mediante Ajax, enviando a la url (pagina de respuesta del servidor) mediante POST los parametros con sus correspondientes valores
	myConn.connect(url, "POST", "&" + paramkey + "=" + paramvalue, finalizado);
}
function cargar_contenido_div_post(target,url,div,campoid,showloading){
	if (typeof(showloading)=="undefined" || showloading=="true"){
		//cambiamos el contenido del div que tiene id=target por Cargando....
		document.getElementById(target).innerHTML = '<div class=\"load\"><img src=\"images/ajaxloading.gif\" alt=\"+\" class=\"floatleft\" /> Cargando...</div>';
	}
	//creamos la conexion ajax entre servidor y cliente, usando XHConn
	var myConn = new XHConn();
	if (!myConn) alert("XMLHTTP no esta disponible. Intentalo con un navegador mas reciente.");
	//cogemos el valor del campo del formulario que tenga el id=campoid
	var valorcampo = document.getElementById(campoid).value;
	//cuando terminemos de hacer las cosas, el servidor respondera, y cargara su respuesta
	// en el div que tenga como id=target
	var finalizado = function (oXML) { 
		document.getElementById(target).innerHTML = oXML.responseText; 
	};
	//nos conectamos al servidor mediante Ajax, enviando a la url (pagina de respuesta del servidor)
	//mediante POST los parametros con sus correspondientes valores, y una vez que nos responda el servidor
	//nos devolvera los resultados en el campo finalizado
	myConn.connect(url, "POST", "divID=" + div + "&codeID=" + valorcampo, finalizado);
}
function cargar_contenido_div_post_params(target,url,div,campoid,extraparam,extravalue,showloading){
	if (typeof(showloading)=="undefined" || showloading=="true"){
		//cambiamos el contenido del div que tiene id=target por Cargando....
		document.getElementById(target).innerHTML = '<div class=\"load\"><img src=\"images/ajaxloading.gif\" alt=\"+\" class=\"floatleft\" /> Cargando...</div>';
	}
	//creamos la conexion ajax entre servidor y cliente, usando XHConn
    var myConn = new XHConn();
    if (!myConn) alert("XMLHTTP no esta disponible. Intentalo con un navegador mas reciente.");
    //cogemos el valor del campo del formulario que tenga el id=campoid
    var valorcampo = document.getElementById(campoid).value;
    //cuando terminemos de hacer las cosas, el servidor respondera, y cargara su respuesta
    // en el div que tenga como id=target
    var finalizado = function (oXML) { 
        document.getElementById(target).innerHTML = oXML.responseText; 
    };
    //nos conectamos al servidor mediante Ajax, enviando a la url (pagina de respuesta del servidor)
    //mediante POST los parametros con sus correspondientes valores, y una vez que nos responda el servidor
    //nos devolvera los resultados en el campo finalizado
    myConn.connect(url, "POST", "divID=" + div + "&codeID=" + valorcampo + "&" + extraparam + "=" + extravalue, finalizado);
}
function cargar_contenido_div_2post(target,url,div,campoid1,campoid2,showloading){
	if (typeof(showloading)=="undefined" || showloading=="true"){
		//cambiamos el contenido del div que tiene id=target por Cargando....
		document.getElementById(target).innerHTML = '<div class=\"load\"><img src=\"images/ajaxloading.gif\" alt=\"+\" class=\"floatleft\" /> Cargando...</div>';
	}
	//creamos la conexion ajax entre servidor y cliente, usando XHConn
	var myConn = new XHConn();
	if (!myConn) alert("XMLHTTP no esta disponible. Intentalo con un navegador mas reciente.");
	//cogemos el valor del campo del formulario que tenga el id=campoid
	var valorcampo1 = document.getElementById(campoid1).value;
	var valorcampo2 = document.getElementById(campoid2).value;
	//cuando terminemos de hacer las cosas, el servidor respondera, y cargara su respuesta
	// en el div que tenga como id=target
	var finalizado = function (oXML) { 
		document.getElementById(target).innerHTML = oXML.responseText; 
	};
	//nos conectamos al servidor mediante Ajax, enviando a la url (pagina de respuesta del servidor)
	//mediante POST los parametros con sus correspondientes valores, y una vez que nos responda el servidor
	//nos devolvera los resultados en el campo finalizado
	myConn.connect(url, "POST", "divID=" + div + "&"+campoid1+ "=" + valorcampo1+ "&"+campoid2+ "=" + valorcampo2, finalizado);
}

function cargar_contenido_array_post(div,url,idFormulario,showloading){
	//esta función sirve para enviar por post varios campos de un formulario
	//la llamaremos anadiendo al final del fomulario, en vez de botón de aceptar clásic, uno de la forma:
	//<a href=\"".$link."\" onclick=\"cargar_contenido_array_post('".$divID1."','".$link2."','".$idFormulario."'); return false;\"><img src=\"images/forward.gif\" title=\"Anadir\" />Añadir al albarán</a>
	//de esta forma, recargará el div con identificador divID1 con la función reultante de llamar a link2, pasándole por post todos los campos del formulario
	//idFormulario es el identificador del formulario que deseamos enviar por post
	//en esta versión no funciona ni con selectarray ni con textarea
	if (typeof(showloading)=="undefined" || showloading=="true"){
		//cambiamos el contenido del div que tiene id=div por Cargando....
		document.getElementById(div).innerHTML = '<div class=\"load\"><img src=\"images/ajaxloading.gif\" alt=\"+\" class=\"floatleft\" /> Cargando...</div>';
	}
	//creamos la conexion ajax entre servidor y cliente, usando XHConn
	var myConn = new XHConn();
	if (!myConn) alert("XMLHTTP no esta disponible. Intentalo con un navegador mas reciente.");
	//cogemos el valor del campo del formulario que tenga el id=campoid
	
	var salida="";
	var formulario=document.getElementById(idFormulario);
	for (var i=0; i <formulario.elements.length;i++) {
		salida+="&"+formulario.elements[i].id+'='+encodeURI(getRadioButtonSelectedValue(formulario.elements[i]));
	}

	//cuando terminemos de hacer las cosas, el servidor respondera, y cargara su respuesta
	// en el div que tenga como id=div
	var finalizado = function (oXML) { 
		document.getElementById(div).innerHTML = oXML.responseText; 
	};
	//nos conectamos al servidor mediante Ajax, enviando a la url (pagina de respuesta del servidor)
	//mediante POST los parametros con sus correspondientes valores, y una vez que nos responda el servidor
	//nos devolvera los resultados en el campo finalizado
	myConn.connect(url, "POST", "divID=" + div + "&"+salida, finalizado);
}
function reloadDivPeriodically(divtarget,ajaxurl,refresh,showloading){
	if(refreshIdVM){clearTimeout(refreshIdVM);refreshIdVM=0;}
	cargar_contenido_div(divtarget,ajaxurl,showloading);
	refreshIdVM = setTimeout('cargar_contenido_div(\''+ divtarget+ '\',\''+ ajaxurl +'\',\''+showloading+'\'); reloadDivPeriodically(\''+ divtarget+ '\',\''+ ajaxurl +'\','+refresh+',\''+showloading+'\');', refresh);
}
function loadIframe(iframeName, url){if ( window.frames[iframeName]){window.frames[iframeName].location = url;return false;}return true;}
function get_url_param(name){name = name.replace(/[\[]/,"\\\[").replace(/[\]]/,"\\\]");var regexS = "[\\?&]"+name+"=([^&#]*)";var regex = new RegExp( regexS );var results = regex.exec( window.location.href );if(results==null)return "";else return results[1];}
function checkAll(field){var numElements = field.length;if (numElements == undefined) field.checked=true;else{for (i = 0; i < numElements; i++) field[i].checked = true;}}
function uncheckAll(field){var numElements = field.length;if (numElements == undefined) field.checked=false;else{for (i = 0; i < numElements; i++) field[i].checked = false;}}
function changeAll(field, fieldHijo) {if (field.checked == true) checkAll(fieldHijo);else uncheckAll(fieldHijo);}
function showcontent(id){document.getElementById(id).style.display = "block";}
function hidecontent(id){document.getElementById(id).style.display = "none";}
function toggle_visibility(id){var e = document.getElementById(id);if(e.style.display == 'block') e.style.display = 'none';else e.style.display = 'block';}
function getRadioButtonSelectedValue(ctrl){if(ctrl.length == undefined){return ctrl.value;}for(i=0;i<ctrl.length;i++)if(ctrl[i].checked) return ctrl[i].value;}
function getCheckBoxChecked(ctrl){if(ctrl.checked) return '1';else return '0';}
function ajaxFadeEffect(element){new Effect.Fade(element,{ duration:1});}
function ajaxAppearEffect(element){new Effect.Appear(element,{ duration:1});}
function confirmacion(url,question,answerok){var r=confirm(question); if (r==true){alert(answerok);location.href=url;}}
function getURLparam(param){ param=param.replace(/[\[]/,"\\\[").replace(/[\]]/,"\\\]");var regexS = "[\\?&]"+param+"=([^&#]*)";var regex=new RegExp( regexS ); var results = regex.exec( window.location.href ); if( results == null ) return ""; else return results[1];}
