/* Marc Boronat                                                               */

var regExps = new Array();
regExps["text"] = new RegExp("(.)+");
regExps["number"] = new RegExp("^([0-9]+[- /.]*?)+$");
regExps["date"] = new RegExp("^(0?[1-9]|[12][0-9]|3[01])[- /.](0?[1-9]|1[012])[- /.](19|20)?[0-9]{2}$");
regExps["email"] = new RegExp("^([a-zA-Z0-9_.-])+@(([a-zA-Z0-9-])+.)+([a-zA-Z0-9]{2,4})+$");
regExps["compulsory"] = new RegExp("(.)+");
regExps["superficial"] = new RegExp("(.)*?");

/* ---------------------------------------------------- */

var contacto_nm = new Array();
contacto_nm[0] = "name";
contacto_nm[1] = "email";
contacto_nm[2] = "message";

var contacto_rx = new Array();
contacto_rx[0] = "text";
contacto_rx[1] = "email";
contacto_rx[2] = "text";

function checkRegex(str, rxp) {
    if(str.search(rxp)==-1){
        return false;
    } else {
        return true;
    }
}

function validate(formName, formArr, regexArr) {

    var validated = true

    for(var i=0; i<formArr.length; i++) {
        var theLmnt = document.getElementById(formArr[i]);
        var theCheck = checkRegex(theLmnt.value, regExps[regexArr[i]]);
        if(theCheck == false) {
            validated = false;
            theLmnt.style.color = "#96238A";
        } else {
            theLmnt.style.color = "inherit";
        }
    }

    if (validated == false) {
        alert("Por favor, revise los campos violeta o vacíos.");
    } else if (validated == true) {
        alert("Su mensaje ha sido enviado.");
        document.forms[formName].submit();
    }

}
