/****************************************************
 * Funciones de submit
 ****************************************************/

function FormSubmitter(formName, formCbs)
{
	this.formName = formName;
	this.form = document[formName];
	this.formCbs = formCbs;
}

function bloqueaWindow(){
	Dialog.info("Enviando datos, por favor espere ...",
               {windowParameters: {className:"alphacube",width:250, height:100}, showProgress: true});
}
/**
 * Comproba los datos antes de ejecutar la acción.
 * Se suele utilizar para modificar un registro desde la ficha.
 */
FormSubmitter.prototype.valida_busca = function(accion)
{
	
	this.form.accion.value = accion;
	this.form.issearch.value = 1;
	oFormCallbacks.validateInServerForm();
	return false;
	
	if (this.formCbs.isValidAlert() && this.formCbs.isCompleteAlert()) {
		this.form.accion.value = accion;
		this.form.issearch.value = 1;
		this.formCbs.submit();
		this.form.submit();
		//return true;
	}
	return false;
}

/**
 * Comproba los datos antes de ejecutar la acción.
 * Se suele utilizar para modificar un registro desde la ficha.
 */
FormSubmitter.prototype.valida_ejecuta = function(accion)
{
	bloqueaWindow();
	this.form.accion.value = accion;
	oFormCallbacks.validateInServerForm();
	return false;
}

/**
 * Comproba los datos antes de ejecutar la acción.
 * Se suele utilizar para modificar un registro desde la ficha.
 */
FormSubmitter.prototype.valida_ejecuta_tab = function(accion,regMatch)
{
	this.form.accion.value = accion;
	oFormCallbacks.validateInServerForm(regMatch);
	return false;
}


/**
 * Ejecuta la acción sin confirmación ni comprobación.
 * Sin pasar el id: se suele utilizar para volver al listado.
 * Pasando el id: Se suele utilizar para ir del listado a una ficha.
 */
FormSubmitter.prototype.ejecuta = function(accion, id)
{
	this.form.accion.value = accion;
	this.form.id.value = id;
	this.form.submit();
}

FormSubmitter.prototype.ejecutaInNewWindow = function(accion, id)
{
	var odlAccion = this.form.accion.value;
	var oldId = this.form.id.value;

	this.form.target = "_blank";
	this.form.accion.value = accion;
	this.form.id.value = id;
	this.form.submit();
	this.form.target = "_self";

	this.form.accion.value = odlAccion;
	this.form.id.value = oldId;
	
}


FormSubmitter.prototype.ejecutaInNewWindowNewDest = function(accionNew, id, newUrl)
{
	var odlAccion = this.form.accion.value;
	var oldId = this.form.id.value;
	
	this.form.action = newUrl;
	this.form.target = "_blank";
	this.form.accion.value = accionNew;
	this.form.id.value = id;
	this.form.submit();
	this.form.target = "_self";
	this.form.action = '';
	
	this.form.accion.value = odlAccion;
	this.form.id.value = oldId;
	
}

/**
 * Cambia el target del form.
 */
FormSubmitter.prototype.setTarget = function(dest)
{
	this.form.action = dest;
	
}

/**
 * Pide una confirmación antes de ejecutar la acción.
 * Sin pasar id: Se suele utilizar para eliminar un registro desde la ficha.
 * Pasando un id: Se suele utilizar para eliminar un registro desde el listado.
 */
FormSubmitter.prototype.confirma = function(accion, id)
{
	var accionTest = accion;
	if (accion.indexOf('.') > 0) {
		accionTest = accion.split('.');
		accionTest = accionTest[1];
	}
	
	if (accionTest.substr(0,3) == "del") {
		//"Confirme que desea eliminar el registro.";
		msg = MENSAJES['confirmDel'];
	}
	
	if (accionTest.substr(0,4) == "send") {
		//"Confirme que desea enviar el registro";
		msg = MENSAJES['confirmSend'];
	}
	
	Dialog.confirm(msg, 
		{windowParameters: {className:"alphacube",width:300}, okLabel: "OK", 
		buttonClass: "myButtonClass",
		id: "msgAlert",
		cancel:function(win) {return false;},
		ok:function(win) {s.ejecuta(accion, id); return true;}
		});
	return false;
	
	/*
	if ( confirm(msg) ) {
		this.ejecuta(accion, id);
		return true;
	} else {
		return false;
	}
	*/
}


FormSubmitter.prototype.autoSave = function(accion, id)
{

	msg = MENSAJES['confirmAutoSave'];
	
	Dialog.confirm(msg, 
		{windowParameters: {className:"alphacube",width:300}, okLabel: "OK", 
		buttonClass: "myButtonClass",
		id: "msgAlert",
		cancel:function(win) {return false;},
		ok:function(win) {s.valida_ejecuta(accion, id); return true;}
		});
	return false;
	/*
	if ( confirm(msg) ) {
		this.valida_ejecuta(accion, id);
		return true;
	} else {
		return false;
	}
	*/
}


/**
 * Pide una confirmación antes de eliminar una foto.
 */
FormSubmitter.prototype.eliminar_foto = function(memname)
{
	if ( confirm(MENSAJES['confirmDelFile']) ) {
		this.form.accion.value = "delfoto:" + memname;
		this.form.submit();
	}
}

FormSubmitter.prototype.eliminar_fotoAjax = function(memname)
{
	var msg = MENSAJES['confirmDelFile'];
	var formu = this.form;
	Dialog.confirm(msg, 
		{windowParameters: {className:"alphacube",width:300}, okLabel: "OK", 
		buttonClass: "myButtonClass",
		id: "msgAlert",
		cancel:function(win) {return false;},
		ok:function(win) {
				formu.accion.value = "ajaxDelfoto:" + memname;
				var valsForm = ''; //Form.serialize(document.f);
				valsForm = 'accion=' + "ajaxDelfoto:" + memname;
				valsForm += '&id=' + formu.id.value;
				valsForm += '&' + memname + '=' + formu.elements[memname].value;
				
				var opt = {
						// Use POST
						method: 'post',
						asynchronous:true,
						// Send this lovely data
						postBody: valsForm,
						// Handle successful response
						onSuccess: function(t) {
							document.f.elements[memname].value = 0;
							new Effect.BlindUp('contenedor_' + memname, {duration:0.3});
							new Insertion.Bottom(document.body,t.responseText);
							}
					};
				new Ajax.Request(formu.action, opt);
				return true;
			}
		});
	return false;
}

/**
 * Pide una confirmación antes de eliminar una foto.
 */
FormSubmitter.prototype.eliminar_file = function(memname)
{
	if ( confirm(MENSAJES['confirmDelFile']) ) {
		this.form.accion.value = "delfile:" + memname;
		this.form.submit();
	}
}

FormSubmitter.prototype.eliminar_fileAjax = function(memname)
{
	var msg = MENSAJES['confirmDelFile'];
	var formu = this.form;
	Dialog.confirm(msg, 
		{windowParameters: {className:"alphacube",width:300}, okLabel: "OK", 
		buttonClass: "myButtonClass",
		id: "msgAlert",
		cancel:function(win) {return false;},
		ok:function(win) {
				var oldAccion = formu.accion.value;
				formu.accion.value = "ajaxDelfile:" + memname;
				var valsForm = Form.serialize(document.f);
				valsForm = valsForm.split('accion_').join('boton_');
				//var valsForm = ''; //Form.serialize(document.f);
				//valsForm = 'accion=' + "ajaxDelfile:" + memname;
				//valsForm += '&id=' + this.form.id.value;
				//valsForm += '&' + memname + '=' + this.form.elements[memname].value;
				formu.accion.value = oldAccion;
				//alert(valsForm);
				var opt = {
						// Use POST
						method: 'post',
						asynchronous:true,
						// Send this lovely data
						postBody: valsForm,
						// Handle successful response
						onSuccess: function(t) {
							//alert(t.responseText);
							document.f.elements['F_' + memname].value = '';
							new Effect.BlindUp('contenedor_' + memname);
							// $('contenedor_' + memname).style.display = 'none';
							
						}
					};
				new Ajax.Request(formu.action, opt);
				return true;
			}
		});
	return false;
}

/**
 * Recarga la página ajustando el orden de la columna 'by'.
 */
FormSubmitter.prototype.paginate = function(by)
{
	var currBy = this.form.orderBy.value;
	if (currBy == by) {
		this.form.orderDir.value =
			(this.form.orderDir.value == 'DESC') ? 'ASC' : 'DESC';
	} else {
		this.form.orderDir.value = 'ASC';
	}
	this.form.orderBy.value = by;
	
	this.form.submit();
}

// pone a 0 el formulario dejando los hidden sin resetear
function resetForm(objForm)
{
	for(var i = 0;i < objForm.elements.length;i ++){
		var obj = objForm.elements[i];
		switch(obj.type){
			case "select-one":
				if(obj.name != 'regsPerPage'){
					obj.selectedIndex = 0;
				}
				break;
			case "select-multiple":
				obj.selectedIndex = -1;
				break;
			case "checkbox":
				obj.checked = false;
				break;
			case "text":
			case "file":
			case "textarea":
				obj.value = "";
				break;
		}
		
	}
	//return true;
}

/****************************************************
 * ChangeCallbacks
 ****************************************************/

/**
 * Colección de callback de cambios en la página
 */
function ChangeCallbacks()
{
	this.cbChange = new Array();
}

/**
 * Adición de un callback de cambio
 *
 * El callback se añade a la colección. Se llamará cada vez
 * que cambia un elemento, aunque no tenga nada que ver con
 * este callback. El callback es el encargado de hacer la
 * diferencia.
 *
 * @param Function un callback definido en la página
 * @param HtmlFormElement 
 */
ChangeCallbacks.prototype.addChangeCallback = function(callback)
{
	var pos = this.cbChange.length;
	this.cbChange[pos] = callback;
}
// Crea un objeto global
var oChangeCallbacks = new ChangeCallbacks();

/**
 * Callback de cambio general
 *
 * Esta función se registra para ser llamada cada vez 
 * que se cambia un elemento del formulario.
 */
function __formHasChanged(el) 
{ 
	if(document.f && document.f.is_modified) { 
		document.f.is_modified.value = 'cambiado'; 
	} 
}
// Registra el callback
oChangeCallbacks.addChangeCallback(__formHasChanged);

/*
function __autoCheck(el)
{
	oFormCallbacks.autoCheck(el.name);
}
oChangeCallbacks.addChangeCallback(__autoCheck);
*/

/**
 * Event Handler para los cambios
 *
 * Se añade a cada elemento del formulario con el código:
 * <input ... onchanged='changed(this)' />
 */
function changed(el)
{
	el = $(el);
	
	var arr = el.name.split("[");
	var	formElementName = arr[0];
	formElementName = formElementName.replace('Out','In');
	if(oFormCallbacks.configMembers[formElementName]){
		oFormCallbacks.configMembers[formElementName].validateInServer();
	}
}

function multiselSelect(elName,onOff)
{
	if(!onOff) onOff = true;
	var selFrom = document.f[elName + "[]"];
	var optFrom = selFrom.options;
	for(var f=0; f<optFrom.length; f++) {
		optFrom[f].selected = onOff;
	}
}


// Associated functions

/**
 * Change checkbox state when clicking on its label
 *
 * @param string name of the checkbox
 * @todo add the function in the 'onclick' of the label of the corresponding checkbox
 */
function toggleCheckboxOld(elName) {
	thisCheckbox = document.f[elName];
	thisCheckbox.checked = !(thisCheckbox.checked);
	changed(thisCheckbox);
}

function toggleCheckbox(elName,idDl) {
	if(idDl){
		var thisCheckbox = document.f[elName +'['+idDl+']'];
	}else{
		var thisCheckbox = document.f[elName];
	}
	if(checkIt('applewebkit')){
		thisCheckbox.checked = !(thisCheckbox.checked);
	}
	changed(thisCheckbox);
}
/**
 * Change radio button state when clicking on its label
 *
 * @param string name of the radio button group
 * @param string value of this particular radio button
 */
function setSelectedRadioButton(elName, radioValue) {
	radioArray = document.f[elName];
	if(!radioArray.length) {
		radioArray.checked = true;
		changed(radioArray);
		return;	
	}
	for (i = 0; i < radioArray.length; i++) {
		if (radioArray[i].value == radioValue) {
			radioArray[i].checked = true;
			break;
		}
	}
	changed(radioArray[i]);
}

/**
 * Shows a popup window with a calendar in flash
 *
 * @param string name of the form
 * @param string name of the field to receive the selected date
 */
function showCalendar(form,campo)
{
	var f = (document.forms[form].elements[campo].value);
	fecha = f.split("-");
	d = fecha[0];
	m = fecha[1]-1;
	y = fecha[2];
	win = newWindow('../inc/base/miniCal.php?y='+y+'&m='+m+'&d='+d+'&form='+form+'&campo='+campo,'Calendario',150,150,'');
}

/**
 * Fills the field with a given date
 *
 * @param string name of the form
 * @param string name of the field to receive the date
 * @param mixed date to put into field
 */
function setDate(form,campo,fecha)
{
	elInput = (document.forms[form].elements[campo]);
	
	fecha = fecha.split("-");
	var d = eval(fecha[0]);
	var m = eval(fecha[1]);
	var y = fecha[2];
	if(d<10) d = '0'+d;
	if(m<10) m = '0'+m;
 	elInput.value = d + '-' + m + '-' + y;
	elInput.focus();
	//campo = campo.substring(1,500);
	/*
	assignLabel(campo,"completed");
	
	var spanError = $('err_' + campo);
	if(spanError){
			new Effect.BlindUp(spanError,
    		{ duration: 0.2, afterFinish: function(element){ Element.remove(spanError); } });
		}
	*/
	if(elInput.onchange){
		elInput.onchange();
	}
}

function getFormValues()
{
	valsForm = {};
	objForm = document.f;
	for(var i = 0;i < objForm.elements.length;i ++){
		var obj = objForm.elements[i];
		switch(obj.type){
			case "select-one":
				val = obj.selectedIndex;
				break;
			case "radio":
				if(obj.checked == true){
					val = obj.value;
				}
				break;
			case "text":
			case "file":
			case "textarea":
				val = obj.value;
				break;
			case "select-multiple":
				numOptions = (obj.options.length);
				valArr = new Array;
				for (z = 0; z < numOptions; z++) {
					valArr[z] = obj.options[z].text;
				}
				val = valArr;
				break;
			default:
				val = null;
				break;
		}
		
		if(val != null){
			valsForm[obj.name] = val;
		}
	}
	return valsForm;
}

function checkFormChanges()
{
	newValuesForm = getFormValues();
	var formChanges = new Array;
	for (var i in oldValuesForm){
		if(oldValuesForm[i] != newValuesForm[i]){
			if(typeof oldValuesForm[i] == 'object'){
				valsOld = new Array;
				valsNew = new Array;
				cambiado = false;
				for (var h in oldValuesForm[i]){
					if(oldValuesForm[i][h] != newValuesForm[i][h]){
						valsOld[valsOld.length] = oldValuesForm[i][h];
						valsNew[valsNew.length] = newValuesForm[i][h];
						cambiado = true;
					}
				}
				if(cambiado ==true){
					formChanges[formChanges.length] = i + '\n  old:'+ valsOld +'\n  new:' + valsNew;
				}
			}else{
				formChanges[formChanges.length] = i + '\n  old:'+oldValuesForm[i] +'\n  new:' + newValuesForm[i];
			}
		}
	}
	//alert(formChanges.join('\n'));
}




var MemberDedoLib = Class.create();
MemberDedoLib.prototype = {
   initialize: function(formElementName, pTipo, pFormat, pRequired, pErrorMsg, pEnabled, pExtraParam) {
		this.a_name = this.getMemberName(formElementName);
		
		this.element = $(this.a_name);
		this.a_tipo = pTipo;
		this.a_format = pFormat;
		this.a_required = pRequired;
		this.a_errorMsg = pErrorMsg;
		this.a_title = pErrorMsg;
		this.a_enabled = false;
		
		this.a_accesibleVal = '';
		if(Element.hasClassName(this.element,'accesibleVal')){
			this.a_accesibleVal = this.element.value;
		}
		if(pEnabled == '1') this.a_enabled = true;
	
		var paramsExtra = '0';
		if(pExtraParam) paramsExtra = pExtraParam;
		this.a_params = paramsExtra;
		
		
		this.hasError = false;
		// extras
		this.setLabel(this.a_name);
		//this.setSpanError(this.a_name);
		this.setElToInsert(this.a_name);
   },
   
   getMemberName: function(formElementName) {
		var arr = formElementName.split("[");
		formElementName = arr[0];
		formElementName = formElementName.replace('Out','In');
		return formElementName;
   },
   
   setLabel: function(nameMember) {
		this.label = $('L__' + nameMember);
   },
   
   setSpanError: function(nameMember) {
		this.spanError = $('err_' + nameMember);
   },
   getSpanError: function(nameMember) {
   		var idSpanError = 'err_' + nameMember;
		if((this.a_tipo == 'password')) idSpanError = 'err_' + this.elToInsert.id;
		
		if(!$(idSpanError)){
			var spanError = '<span id="' + idSpanError + '" class="errorField" style="display:none;"><\/span>';
			
			if(oFormCallbacks.config.errorPosition == 'after'){
				var anchoLabel = 0;
				if(this.label && this.a_tipo != 'foto' && this.a_tipo != 'check'){
					anchoLabel = Element.getDimensions(this.label).width;
				}
				spanError = '<div id="' + idSpanError + '" class="errorField" style="clear:left;display:none;padding-left:'+ anchoLabel + 'px;"><\/div>';
				new Insertion.After(this.elToInsert, spanError);
			}
			
			if(oFormCallbacks.config.errorPosition == 'before'){
				new Insertion.Before(this.elToInsert, spanError);
			}
			if(oFormCallbacks.config.errorPosition == 'top'){
				new Insertion.Top(this.elToInsert, spanError);
			}
			if(oFormCallbacks.config.errorPosition == 'bottom'){
				new Insertion.Bottom(this.label, spanError);
			}
		}
		
		this.spanError = $(idSpanError);
   },
   
   setElToInsert: function(member) {
		this.elToInsert = this.element;
		
		if(this.a_tipo == 'date'){
			this.elToInsert = $('cal_icon_' + member);
		}
		if(this.a_tipo == 'daterange'){
			this.elToInsert = $('H_' + member + '_1');
		}
		if(this.a_format == 'radio' || this.a_format == 'checks'){
			this.elToInsert = $('ul_' + member);
		}
		if(this.a_format == 'select' && (this.a_tipo == 'multienum' || this.a_tipo == 'multiforkey')){
			this.elToInsert = $('ins_' + member);
			this.setLabel(member.substr(0,member.length-2));
		}
		if(this.a_tipo == 'foto' || this.a_tipo == 'file'){
			this.elToInsert = $('ins_' + member);
		}
		if(this.a_format == 'autocomplete'){
			this.elToInsert = $('auto_' + member);
		}
		if(this.a_tipo == 'check'){
			this.elToInsert = $('L__' + member);
		}
		if(this.a_tipo == 'text' && this.a_format == 'FCK'){
			if($(member + '___Frame')){
				this.elToInsert = $(member + '___Frame');
			}
		}
		
		if((this.a_tipo == 'password')){
		
			var isRepassw = (this.a_name.substr(0,3) == 're_');
			if(isRepassw){
				this.elToInsert = this.element;
				this.label = $('L__' + this.a_name.substr(3,100));
			}else{
				var haveRepassw = $('re_'+this.a_name);
				if(haveRepassw){
					this.elToInsert = $('re_' + this.a_name);
				}else{
					this.elToInsert = this.element;
				}
			}
			// var spanError = $('err_' + elToInsert.id);
		}
   },
   
   onSubmitMember: function() {
		var valSerialize = '';
		var member = this.a_name;
		if(this.a_accesibleVal && $(member).value == this.a_accesibleVal){
			$(member).value = '';
		}
		if((this.a_tipo=='multienum' || this.a_tipo=='multiforkey') && this.a_format == 'select'){
			multiselSelect(member);
		}		
		if((this.a_tipo == 'foto' || this.a_tipo == 'file')){
			valSerialize = '&valSer_' + member + '=' + (this.element.value);
		}
		
		if((this.a_tipo=='text') && this.a_format == 'RTE'){
			// puede que este asi definido pero el navegador no soporte el RTE
			if($('hdn' + member)){
				updateRTE(member);
				var textoRte = $('hdn' + member).value;
				valSerialize += '&valSer_' + member + '=' + (textoRte);
			}
		}
		
		if((this.a_tipo=='text') && this.a_format == 'FCK'){
			// puede que este asi definido pero el navegador no soporte el RTE
			if(!(isSafari)){ 
					if(FCKeditorAPI.GetInstance(member).GetXHTML() != ''){
						this.element.value = 'OK';
						var textoRte = $(member).value;
					}
				}else{
					var textoRte = document.f.elements[member].value;
				}
			
			valSerialize += '&valSer_' + member + '=' + (textoRte);
			
		}
		
		return valSerialize;
   },
   
   validateInServer: function() {
   		if(this.a_enabled == false) return;
   		var member = this.a_name;
		var valSerialize = this.onSubmitMember();
		
		var valsForm = Form.serialize(document.f);
		
		var accesibleVal = '&a_accesibleVal=' + (this.a_accesibleVal);
		
		
		var opt = {
				// Use POST
				method: 'post',
				asynchronous:true,
				// Send this lovely data
				postBody: 'accionJS=validaMember&member='+member+'&a_format='+this.a_format+''+valSerialize+accesibleVal+'&a_tipo='+this.a_tipo+'&a_title='+this.a_title+'&a_required='+this.a_required + '&' + valsForm,
				// Handle successful response
				onSuccess: function(t) {
					//oFormCallbacks.configMembers[member].showResponse(t.responseText);
					this.showResponse(t.responseText);
					
				}.bind(this)
			};
		new Ajax.Request('../utilidades/validator.php', opt);	
   },
   
    showResponse: function(responseText) {
    	
		this.hasError = false;
		if(responseText == 'OKY'){
			if(this.spanError){
				new Effect.BlindUp(this.spanError,
				{ duration: 0.2, afterFinish: function(element){ Element.remove($(this.spanError.id));this.spanError = null;}.bind(this) });
			}
		}else{
			// alert(this.a_name);
			this.hasError = true;
			if(oFormCallbacks.config.showErrorsText){
				
				
				if(oFormCallbacks.config.errorPosition == 'alert'){
					alert(responseText.stripTags());
				}else{
					
					this.getSpanError(this.a_name);
					
					this.spanError.innerHTML = ' ' + responseText;
					
					new Effect.Appear(this.spanError);
				}		
			}
			
		}
		
		// falta asignar el label
		this.assignLabel();
   },
   
   assignLabel: function() {
   		var tipoLabel = (this.hasError == false) ? 'completed' : 'problem';
		Element.removeClassName(this.label,'completed');
		Element.removeClassName(this.label,'problem');
		Element.removeClassName(this.label,'optional');
		Element.addClassName(this.label,tipoLabel);
   }
};

/****************************************************
 * FormCallbacks
 ****************************************************/

/**
 * FormCallbacks
 * 
 * @param string nombre del formulario
 */
var FormCallbacks = Class.create();

// definimos la clase
FormCallbacks.prototype = {

   initialize: function(formName) {
		this.formName = formName;
		this.configMembers = {};
		this.config = {};
   },

   setConfig: function(pShowErrorsText,pErrorPosition) {
		this.config.showErrorsText = false;
		if(pShowErrorsText == '1') this.config.showErrorsText = true;
		this.config.errorPosition = pErrorPosition;
   },
   
   addValidateCallback: function(formElementName, pTipo, pFormat, pRequired, pErrorMsg, pEnabled, pExtraParam) {
		this.configMembers[formElementName] = new MemberDedoLib(formElementName, pTipo, pFormat, pRequired, pErrorMsg, pEnabled, pExtraParam);
   },
   
   enable: function(formElementName) {
		this.configMembers[formElementName].a_enabled = true;
   },
   
   disable: function(formElementName) {
		this.configMembers[formElementName].a_enabled = false;
   },
   
   observeForm: function() {
		var els = Form.getElements(document[this.formName]);
		for(var i = 0; i < els.length; i++)
		{
			
			if(els[i].type == 'hidden') continue;
			
			if(els[i].type == 'radio' || els[i].type == 'checkbox'){
				//Event.observe(els[i], "click", changed, false);
				els[i].onclick = function(){changed(this);};
			}else{
				if(els[i].type == 'select-multiple'){
					// en los multiples el changed se aplicara al mover de uno a otro en el script moveSelectBox.js
					continue;
				}
				
				//Event.observe(els[i], "change", changed, false);
				
				els[i].onchange = function(){changed(this);};
			}
		}
		
		// las etiquetas de los radio y checks
		var radiosChecks = document.getElementsByClassName("checkRadioInput");
		radiosChecks.each(function(value, index){
			// var elLabel = radiosChecks[index].nextSibling;
			
			var arr = (radiosChecks[index].id).split("__");
			var nombre = arr[0];
			var idDl = '';
			if(arr[1]){
				idDl = arr[1];
			}
			
			var els = document.getElementsByAttribute('for',(radiosChecks[index].id));
			var elLabel = els[0];
			
			if(radiosChecks[index].type == 'radio'){
				Event.observe(elLabel, "click", function() { setSelectedRadioButton(nombre,idDl); }, false);
			}else{
				Event.observe(elLabel, "click", function() { toggleCheckbox(nombre,idDl);return false; }, false);
			}
			
		});
   },
   validateInServerForm: function(regMatch) {
		var valSerialize = '';
		var serStr = '';
		var isTab = false;
		if(regMatch){
			var re = new RegExp(regMatch,"gm");
			isTab = true;
		}
		var serStr = '';
		for(var i in this.configMembers){
			if(isTab){
				if (!(i.match(re))) continue;
			}
			
			member = this.configMembers[i];
			if(!member.a_enabled) continue;
			
			valSerialize += member.onSubmitMember();
			serStr += i +'##';
			
    		['a_tipo','a_format','a_required','a_errorMsg','a_accesibleVal'].each( function(k) {
      			serStr += k +'|' + this.configMembers[i][k] + '||';
    		}.bind(this));
			
			serStr += '##';
			
		}
		
		var valsForm = Form.serialize(document.f);
			
		var opt = {
					// Use POST
					method: 'post',
					asynchronous:true,
					// Send this lovely data
					postBody: 'accionJS=validaForm&config='+serStr + valSerialize + '&' + valsForm,
					// Handle successful response
					onSuccess: function(t) {
						this.showResponseForm(t.responseText);
					}.bind(this)
				};
						

		new Ajax.Request('../utilidades/validator.php', opt);	
   },
   
   showResponseForm: function (res){
		var hasError = false;
		var partes = res.split("||");
		var focusFirst = '';
		for(var i = 0; i < partes.length; i++){
			if(partes[i] == '') continue;
			var campoValor = partes[i].split("|");
			
			if(campoValor[0] == '') continue;
			
			if(this.configMembers[campoValor[0]]){
				if(this.configMembers[campoValor[0]].a_format == 'radio'){
					var el = document.f.elements[campoValor[0]][0];
				}else{
					var el = document.f.elements[campoValor[0]];
				}
				
			}else{
				continue;
				alert(campoValor[0] + ' no esta en la config');
			}
			
			this.configMembers[campoValor[0]].showResponse(campoValor[1]);
			
			if(campoValor[1] != 'OKY'){
				if(focusFirst == '') focusFirst = el;
				hasError = true;
			}
		}
		
		if(hasError){
			//Field.focus(focusFirst);
			//Field.select(focusFirst); //focusFirst.focus();
			Dialog.closeInfo();
			var msg = MENSAJES['error_form'];
			Dialog.alert(msg, 
				 {windowParameters: {className:"alphacube",width:300, height:100}, okLabel: "OK", 
				  ok:function(win) { return true;}});
			//alert(MENSAJES['error_form']);
		}else{
			if(typeof(updateRTEs) == 'function') updateRTEs();
			s.form.submit();
		}
	},

   submit: function() {
		var oForm = document[this.formName];
		for(i in this.cbOnSubmit) {
			if (this.enabled[i])
				var msg = this.cbOnSubmit[i](i, oForm);
		}
   }
};	

// creamos el objeto
var oFormCallbacks = new FormCallbacks('f');


var isSafari = (/Konqueror|Safari|KHTML/.test(navigator.userAgent));
/****************************************************
 * MISC
 ****************************************************/

/**
 * Gets the value of the specified parameter in the cookie.
 *
 * @param string name of the desired parameter.
 * @return string value of that parameter or null if cookie does not exist.
 */
function getCookie(name)
{
    var dc = document.cookie;
    var prefix = name + "=";
    var begin = dc.indexOf("; " + prefix);
    if (begin == -1)
    {
        begin = dc.indexOf(prefix);
        if (begin != 0) return null;
    }
    else
    {
        begin += 2;
    }
    var end = document.cookie.indexOf(";", begin);
    if (end == -1)
    {
        end = dc.length;
    }
    return unescape(dc.substring(begin + prefix.length, end));
}
