//recortar espacios en blanco por los dos lados de un string
function trim(string) 
{ 
	return string.replace(/(^\s*)|(\s*$)/g,'') ; 
} 

//longitud en textarea
function calc_long(txt, maximo)
{
	var largo ;
	largo = txt.value.length ;
	if (largo > maximo) txt.value = txt.value.substring(0, maximo) ;
}

//checking email
function check_mail(str)
{
	var filter=/^([\w-]+(?:\.[\w-]+)*)@((?:[\w-]+\.)*\w[\w-]{0,66})\.([a-z]{2,6}(?:\.[a-z]{2})?)$/i ;
    if (filter.test(str)) return true ;
	else return false ;
}

//Abrir un PopUp
function open_popup(src, w, h) {
	window.open(src,"leyenda", "width="+w+",height="+h+"status=yes");
}

//miramos si algun radio button está checked
function algunRadioButtonChequeado(objRadio)
{
	for ( var i = 0; i < objRadio.length; i++ ) 
	{
		if (objRadio[i].checked) {
			return true;
		}
	}
	return false ;
}

//seleccionar una opción con value = <valor> del <desplegable> en cuestión
function selectOption(desplegable, valor)
{
    for(var i = 0 ; i < desplegable.options.length ; i++)
	{
	    //si el tamaño es 2 me da igual lo que venga en valor, LO SELECCIONAMOS...
        if(desplegable.options[i].value == valor)
		{  
		    desplegable.selectedIndex = i ;
		}
    }
    if(desplegable.options.length == 2) {
        desplegable.selectedIndex = 1 ;
    }
    if(desplegable.options.length == 1) {
        desplegable.selectedIndex = 0 ;
    }
}

//chequear todos los checkBox de un formulario
function CheckAllCheckBox(formulario, valorCheck, nombreCB)
{
	for (i = 0 ; i < formulario.elements.length ; i++)
    {   
		if (formulario.elements[i].type == "checkbox") formulario.elements[i].checked = valorCheck ;
	}    			
	return false ;

}

//Nos devuelve true si hay algun checkbox con nombre "nombreCB" chequeado
function algunoChecked(formulario, nombreCB)
{
    for (i = 0 ; i < formulario.elements.length ; i++)
    {   
        if (formulario.elements[i].type == "checkbox" && formulario.elements[i].name == nombreCB && formulario.elements[i].checked) return true ;
	}    			
	return false ;
}

//Encontrar un objeto cross-browser a partir de su id
function getObject(objname)
{
    var obj = null ;
    if (document.getElementById) {
        obj = document.getElementById(objname) ;
    } else {
        if (document.all) {
            obj = document.all[objname] ;
            }
        }

    return obj ;
}


function MM_openBrWindow(theURL,winName,features) { //v2.0 
    window.open(theURL,winName,features);
}

function MM_preloadImages() { //v3.0
  var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();
    var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)
    if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}
}

function MM_swapImgRestore() { //v3.0
  var i,x,a=document.MM_sr; for(i=0;a&&i<a.length&&(x=a[i])&&x.oSrc;i++) x.src=x.oSrc;
}

function MM_findObj(n, d) { //v4.01
  var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
    d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
  if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
  for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
  if(!x && d.getElementById) x=d.getElementById(n); return x;
}

function MM_swapImage() { //v3.0
  var i,j=0,x,a=MM_swapImage.arguments; document.MM_sr=new Array; for(i=0;i<(a.length-2);i+=3)
   if ((x=MM_findObj(a[i]))!=null){document.MM_sr[j++]=x; if(!x.oSrc) x.oSrc=x.src; x.src=a[i+2];}
}

function MM_validateForm() { //v4.0
  var i,p,q,nm,test,num,min,max,errors='',args=MM_validateForm.arguments;
  for (i=0; i<(args.length-2); i+=3) { test=args[i+2]; val=MM_findObj(args[i]);
    if (val) { nm=val.name; if ((val=val.value)!="") {
      if (test.indexOf('isEmail')!=-1) { p=val.indexOf('@');
        if (p<1 || p==(val.length-1)) errors+='- '+nm+' must contain an e-mail address.\n';
      } else if (test!='R') { num = parseFloat(val);
        if (isNaN(val)) errors+='- '+nm+' must contain a number.\n';
        if (test.indexOf('inRange') != -1) { p=test.indexOf(':');
          min=test.substring(8,p); max=test.substring(p+1);
          if (num<min || max<num) errors+='- '+nm+' must contain a number between '+min+' and '+max+'.\n';
    } } } else if (test.charAt(0) == 'R') errors += '- '+nm+' is required.\n'; }
  } if (errors) alert('The following error(s) occurred:\n'+errors);
  document.MM_returnValue = (errors == '');
}
