function nuevoAjax()
{ 
	/* Crea el objeto AJAX. Esta funcion es generica para cualquier utilidad de este tipo, por
	lo que se puede copiar tal como esta aqui */
	var xmlhttp=false; 
	try 
	{ 
		// Creacion del objeto AJAX para navegadores no IE
		xmlhttp=new ActiveXObject("Msxml2.XMLHTTP"); 
	}
	catch(e)
	{ 
		try
		{ 
			// Creacion del objet AJAX para IE 
			xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); 
		} 
		catch(E) { xmlhttp=false; }
	}
	if (!xmlhttp && typeof XMLHttpRequest!='undefined') { xmlhttp=new XMLHttpRequest(); } 

	return xmlhttp; 
}



function traerDatos(layerUpdate,valor1)
{
	//Descripción de parametros
	//capa=nombre de la capa a actualizar
	

	// Obtendo la capa donde se muestran las respuestas del servidor
	var capa=document.getElementById(layerUpdate);
	var ajax=nuevoAjax();

	//mientras carga muestro el mensaje de cargando
	capa.innerHTML="<img src='images/cargando.gif' style='vertical-align:middle;'>&nbsp;Cargando...";
	//alert(layerUpdate + " xx " + valor1);
	switch (layerUpdate)
	{
		case "capaProductosLinea":
			//la llamada que hago para recuperar los datos
			ajax.open("POST", "ctl_servlet?_f=53&id="+valor1, true);
			break;
      
		case "capaGrupoTerapeutico":
			//la llamada que hago para recuperar los datos
			ajax.open("POST", "ctl_servlet?_f=63&id="+valor1, true);
			break;
      
		case "capaProductosGrupo":
			//la llamada que hago para recuperar los datos
			ajax.open("POST", "ctl_servlet?_f=64&id="+valor1, true);
			break;
      
		case "capaPrincipiosInicial":
			//la llamada que hago para recuperar los datos
			ajax.open("POST", "ctl_servlet?_f=41&id="+valor1, true);
			break;
      
		case "capaProductosPrincipio":
			//la llamada que hago para recuperar los datos
			ajax.open("POST", "ctl_servlet?_f=42&id="+valor1, true);
			break;      
		
		case "capaPresentacionHijos":
			//la llamada que hago para recuperar los datos
			ajax.open("POST", "ctl_servlet?_f=31&id="+valor1, true);
			break;
      
		case "capaProductosPresentacion":
			//la llamada que hago para recuperar los datos
			ajax.open("POST", "ctl_servlet?_f=32&id="+valor1, true);
			break;
      
		case "capaProvincias":
			//la llamada que hago para recuperar los datos
			ajax.open("POST", "ctl_servlet?_f=16&id="+valor1, true);
			break;
			
		case "capaTextoNoticia":
			ajax.open("POST", "ctl_servlet?_f=2&idNoticia="+valor1, true);
			break;
			
		case "capaTextoEvento":
			ajax.open("POST", "ctl_servlet?_f=7&idEvento="+valor1, true);
			break;
			
		case "capaTextoArticulo":
			ajax.open("POST", "ctl_servlet?_f=11&idArticulo="+valor1, true);
			break;		
      
		default:
			capa.innerHTML="<img src='img/cargando.gif' style='vertical-align:middle;'>&nbsp;Cargando...";
			ajax.open("POST", valor1, true);
			break;
			
	}


	ajax.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
	ajax.send("d="+layerUpdate);
	
	ajax.onreadystatechange=function()
	{
		if (ajax.readyState==4)
		{
			// Respuesta recibida. Coloco el texto plano en la capa correspondiente
     		 capa.innerHTML=ajax.responseText;
		}
	}
}

function traerDatos2(layerUpdate,valor1,valor2)
{
	//Descripción de parametros
	//capa=nombre de la capa a actualizar
	

	// Obtendo la capa donde se muestran las respuestas del servidor
	var capa=document.getElementById(layerUpdate);
	var ajax=nuevoAjax();

	//mientras carga muestro el mensaje de cargando
	capa.innerHTML="<img src='images/cargando.gif' style='vertical-align:middle;'>&nbsp;Cargando...";
	//alert(layerUpdate + " xx " + valor1+ " xx " + valor2);
	switch (layerUpdate)
	{
		case "capaProvincias":
			//la llamada que hago para recuperar los datos
			ajax.open("POST", "ctl_servlet?_f=16&id="+valor1+"&idprov="+valor2, true);
			break;
      
		default:
			capa.innerHTML="<img src='img/cargando.gif' style='vertical-align:middle;'>&nbsp;Cargando...";
			ajax.open("POST", valor1, true);
			break;
			
	}


	ajax.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
	ajax.send("d="+layerUpdate);
	
	ajax.onreadystatechange=function()
	{
		if (ajax.readyState==4)
		{
			// Respuesta recibida. Coloco el texto plano en la capa correspondiente
     		 capa.innerHTML=ajax.responseText;
		}
	}
}



