/**
* 파일명: lib.validate.js
* 설  명: 폼 체크, 값 표준화
* 작성자: jstoy project
* 날  짜: 2003-10-28
*   lainTT (2003-11-20) : FormChecker Class의 함수 prototype화 & 전역변수를 클래스 안으로...-_-;
***********************************************
*/

/**
* <pre>
* 폼 체크 trigger 함수
* </pre>
*
* @param Form Object
* @return boolean
*/

var __lang__ = GetCookie("__LANG__");
if(__lang__ == null) __lang__ = "fr";

function validate(form) {
    var result;
    var checker = new FormChecker(form);

    result = checker.go();
    checker.destroy();
    return result;
}

function validate_init() {
    for (var i=0; i<document.forms.length; i++) {
        var formObj = document.forms[i];
        if (document.forms[i].getAttribute('VALIDATE') != null) {
            // pre_validate를 사용하지 않는다면 이 아랫줄을 주석처리합니다.
            new FormLoader(formObj);
            formObj.submitAction = formObj.onsubmit;
            formObj.onsubmit = function() {
                formObj.submitAction;
                return validate(this);
            }
        }
    }
}

FormChecker = function(form) {
    /**
    * <pre>
    * 미리 정의된 에러 메시지들
    * </pre>
    */

    if(__lang__ == "fr") {
		this.FORM_ERROR_MSG = {
		   //common   : "입력하신 내용이 규칙에 어긋납니다.\n규칙에 어긋나는 내용을 바로잡아주세요.",
			common	: "",
			required : "est un champ obligatoire.",
			notequal : "les champs ne correspondent pas.",
			invalid  : "le format est invalide.",
			denied   : "le format xxx n'est pas autorisé.",
			minbyte  : "Le fichier) doit avoir une taille minimale de {minbyte} Byte.",
			maxbyte  : "Le fichier ne peut pas dépasser une taille maxmale de {maxbyte} Byte.",
			minsize  : "Le valeur minimale doit être supérieure à {minsize}.",
			maxsize  : "La valeur maximale doit être inférieure à {maxsize}.",
			fixbyte  : "La longueur doit être de {fixbyte}."
		}
    }
    if(__lang__ == "en") {
		this.FORM_ERROR_MSG = {
		   //common   : "입력하신 내용이 규칙에 어긋납니다.\n규칙에 어긋나는 내용을 바로잡아주세요.",
			common	: "",
			required : "is required field.",
			notequal : "항목은 서로 일치하지 않습니다.(en)",
			invalid  : "항목은 입력 형식에 어긋납니다.(en)",
			denied   : "항목은 업로드가 제한된 파일입니다.(en)",
			minbyte  : "항목은 길이가 {minbyte}Byte 이상이어야 합니다.(en)",
			maxbyte  : "항목은 길이가 {maxbyte}Byte를 초과할 수 없습니다.(en)",
			minsize  : "항목은 값이 {minsize} 이상이어야 합니다.(en)",
			maxsize  : "항목은 값이 {maxsize} 이하이어야 합니다.(en)",
			fixbyte  : "항목은 길이가 {fixbyte}Byte 이어야 합니다.(en)"
		}
    }
    if(__lang__ == "kr") {
		this.FORM_ERROR_MSG = {
		   //common   : "입력하신 내용이 규칙에 어긋납니다.\n규칙에 어긋나는 내용을 바로잡아주세요.",
			common	: "",
			required : "항목은 반드시 입력하셔야 합니다.",
			notequal : "항목은 서로 일치하지 않습니다.",
			invalid  : "항목은 입력 형식에 어긋납니다.",
			denied   : "항목은 업로드가 제한된 파일입니다.",
			minbyte  : "항목은 길이가 {minbyte}Byte 이상이어야 합니다.",
			maxbyte  : "항목은 길이가 {maxbyte}Byte를 초과할 수 없습니다.",
			minsize  : "항목은 값이 {minsize} 이상이어야 합니다.",
			maxsize  : "항목은 값이 {maxsize} 이하이어야 합니다.",
			fixbyte  : "항목은 길이가 {fixbyte}Byte 이어야 합니다."
		}
    }

    /**
    * <pre>
    * 폼 체크 함수 매핑
    * </pre>
    */
    this.VALIDATE_FUNCTION = {
       email   : this.func_isValidEmail,
       phone   : this.func_isValidPhone,
       userid  : this.func_isValidUserid,
       hangul  : this.func_hasHangul,
       number  : this.func_isNumeric,
       engonly : this.func_alphaOnly,
       jumin   : this.func_isValidJumin,
       bizno   : this.func_isValidBizNo
    }

    /**
    * <pre>
    * 에러 출력 플래그
    * </pre>
    */
    this.ERROR_MODE_FLAG = {
       all         : 1,         // 전체 에러를 표시
       one         : 2,         // 처음에 걸린 에러 하나만 표시
       one_per_obj : 3          // 한 object당 처음의 에러 표시
    }

    this.form      = form;
    this.isErr     = false;
    this.errMsg    = (this.FORM_ERROR_MSG["common"] != "") ? this.FORM_ERROR_MSG["common"] + "\n\n" : "";
    this.errObj    = "";
    this.curObj    = "";
    this.errMode   = this.ERROR_MODE_FLAG["one"];  // 에러메시지 출력모드
}

FormChecker.prototype.go = function() {
    for (var i = 0; i < this.form.elements.length; i++) {
        var el = this.form.elements[i];
        if (el.tagName.toLowerCase() == "fieldset" || el.tagName.toLowerCase() == "object")
            continue;

        if (el.getAttribute("HNAME") == null || el.getAttribute("HNAME") == "")
            el.setAttribute("HNAME", el.getAttribute("NAME"));

		var trim    = el.getAttribute("TRIM");
        var minbyte = el.getAttribute("MINBYTE");
        var maxbyte = el.getAttribute("MAXBYTE");
        var minsize = el.getAttribute("MINSIZE");
        var maxsize = el.getAttribute("MAXSIZE");
        var fixbyte = el.getAttribute("FIXBYTE");
        var option  = el.getAttribute("OPTION");
        var match   = el.getAttribute("MATCH");
        var delim    = el.getAttribute("DELIM");
        var glue    = el.getAttribute("GLUE");
        var pattern = el.getAttribute("PATTERN");
		var allow = el.getAttribute("ALLOW");
		var deny = el.getAttribute("DENY");

        if (el.type == "text") {
            switch (trim) {
                case "ltrim": el.value = el.value.ltrim(); break;
                case "rtrim": el.value = el.value.rtrim(); break;
                case "notrim": break;
                default:      el.value = el.value.trim();  break;
            }
        }
        if (el.getAttribute("REQUIRED") != null) {
            switch (el.type) {
                case "file": case "text": case "textarea": case "password": case "hidden":
                    if (el.value == null || el.value == "") this.addError(el,"required");
                    break;
                case "select-one":
                    if (el[el.selectedIndex].value == null || el[el.selectedIndex].value == "") this.addError(el,"required");
                    break;
                case "radio":
                    var elCheck = this.form.elements[el.name];
                    for (var j = 0, isChecked = false; j < elCheck.length; j++) {
                        if (elCheck[j].checked == true) isChecked = true;
                    }
                    if (isChecked == false) this.addError(el,"required");
                    break;
                case "checkbox":
                    if (el.checked == false) this.addError(el,"required");
                    break;
            }
        }
        if (el.type == "text" || el.type == "password") {
            if (minbyte != null) {
                if (el.value.bytes() < parseInt(minbyte)) this.addError(el,"minbyte");
            }
            if (maxbyte != null) {
                if (el.value.bytes() > parseInt(maxbyte)) this.addError(el,"maxbyte");
            }
            if (fixbyte != null) {
                if (el.value.bytes() != parseInt(fixbyte)) this.addError(el,"fixbyte");
            }
            if (match && (el.value != this.form.elements[match].value)) {
                this.addError(el,"notequal");
            }
            if (el.value && option != null) {
                if (glue != null) {
                    var _value = new Array(el.value);
					var glue_arr = glue.split(",");
                    for (var j = 0; j < glue_arr.length; j++) {
                        _value[j+1] = this.form.elements[glue_arr[j]].value;

                    }
                    var value = _value.join(delim == null ? "" : delim);
                    var tmp_msg = this.VALIDATE_FUNCTION[option](el, value);
                    if (tmp_msg != true) this.addError(el,tmp_msg);
                } else {
                    var tmp_msg = this.VALIDATE_FUNCTION[option](el);
                    if (tmp_msg != true) this.addError(el,tmp_msg);
                }
            }
            if (pattern != null) {
                pattern = new RegExp(pattern);
                if (!pattern.test(el.value)) this.addError(el,'invalid');
            }
            if (minsize != null) {
				var p = new RegExp(/^-?[0-9]+$/);
				if (!p.test(el.value)) this.addError(el,'minsize');
				else if (parseInt(el.value) < parseInt(minsize)) this.addError(el,"minsize");
            }
            if (maxsize != null) {
				var p = new RegExp(/^-?[0-9]+$/);
				if (!p.test(el.value)) this.addError(el,'maxsize');
				else if (parseInt(el.value) > parseInt(maxsize)) this.addError(el,"maxsize");
            }
        }
        if (el.type == "file") {
            if (el.value && allow != null && allow != "") {
                pattern = new RegExp("(" + allow.replace(",", "|") + ")$");
                if (!pattern.test(el.value)) this.addError(el,'denied');
			}
            if (el.value && deny != null && deny != "") {
                pattern = new RegExp("(" + deny.replace(",", "|") + ")$");
                if (pattern.test(el.value)) this.addError(el,'denied');
			}
		}
    }
    return !this.isErr;
}

FormChecker.prototype.destroy = function() {
    if (this.isErr == true) {
        alert(this.errMsg);
        if (this.errObj.getAttribute("delete") != null)
            this.errObj.value = "";
        if (this.errObj.getAttribute("select") != null)
            this.errObj.select();
        if (this.errObj.getAttribute("nofocus") == null && this.errObj.type != "hidden")
            this.errObj.focus();
    }
    this.errMsg = "";
    this.errObj = "";
}

FormChecker.prototype.addError = function(el, type) {
    var pattern = /\{([a-zA-Z0-9_]+)\}/i;
    var msg = (this.FORM_ERROR_MSG[type]) ? this.FORM_ERROR_MSG[type] : type;
	if (el.getAttribute("errmsg") != null) msg = el.getAttribute("errmsg");
    
    if (pattern.test(msg) == true) {
        while (pattern.exec(msg)) msg = msg.replace(pattern, el.getAttribute(RegExp.$1));
    }

    if (!this.errObj || this.errMode != this.ERROR_MODE_FLAG["one"]) {
        if (this.curObj == el.name && el.getAttribute("errmsg") == null) {
            if (this.errMode == this.ERROR_MODE_FLAG["all"]) {
                this.errMsg += "   - "+ msg +"\n";
			}
        } else if (this.curObj != el.name) {
            if (this.curObj) {
                    this.errMsg += "\n";
			}
			if (el.getAttribute("errmsg") != null) {
				this.errMsg += el.getAttribute("errmsg");
			} else {
				this.errMsg += "["+ el.getAttribute("hname") +"] "+ msg +"\n";
			}
			//el.style.backgroundColor = "yellow";
        }
    }

	if (!this.errObj) this.errObj = el;
    this.curObj = el.name;
    this.isErr = true;
    return;
}

/// 패턴 검사 함수들 ///
FormChecker.prototype.func_isValidEmail = function(el,value) {
   var value = value ? value : el.value;
   var pattern = /^[_a-zA-Z0-9-\.]+@[_\.a-zA-Z0-9-]+\.[a-zA-Z]+$/;
   return (pattern.test(value)) ? true : "invalid";
}

/*
FormChecker.prototype.func_isValidUserid = function(el) {
   var pattern = /^[a-zA-Z]{1}[a-zA-Z0-9_]{3,14}$/;
   return (pattern.test(el.value)) ? true : "영문4자이상 15자 미만,\n 영문,숫자, _ 문자만 사용할 수 있습니다";
}
*/

FormChecker.prototype.func_isValidUserid = function(el) {
	if(__lang__ == "fr") var msg = "6자이상 15자 미만,\n영문, 숫자, _ 문자만 사용할 수 있습니다.(fr)";
	if(__lang__ == "en") var msg = "6자이상 15자 미만,\n영문, 숫자, _ 문자만 사용할 수 있습니다.(en)";
	if(__lang__ == "kr") var msg = "6자이상 15자 미만,\n영문, 숫자, _ 문자만 사용할 수 있습니다.";
	var pattern = /^[a-zA-Z0-9_]{6,14}$/;
	return (pattern.test(el.value)) ? true : msg;
}

FormChecker.prototype.func_hasHangul = function(el) {
	if(__lang__ == "fr") var msg = "반드시 한글을 포함해야 합니다.(fr)";
	if(__lang__ == "en") var msg = "반드시 한글을 포함해야 합니다.(en)";
	if(__lang__ == "kr") var msg = "반드시 한글을 포함해야 합니다.";
	var pattern = /[가-힝]/;
	return (pattern.test(el.value)) ? true : msg;
}

FormChecker.prototype.func_alphaOnly = function(el) {
   var pattern = /^[a-zA-Z]+$/;
   return (pattern.test(el.value)) ? true : "invalid";
}

FormChecker.prototype.func_isNumeric = function(el) {
	if(__lang__ == "fr") var msg = "반드시 숫자로만 입력해야 합니다.(fr)";
	if(__lang__ == "en") var msg = "반드시 숫자로만 입력해야 합니다.(en)";
	if(__lang__ == "kr") var msg = "반드시 숫자로만 입력해야 합니다.";
	var pattern = /^-?[0-9]+$/;
	return (pattern.test(el.value)) ? true : msg;
}

FormChecker.prototype.func_isValidJumin = function(el,value) {
    var pattern = /^([0-9]{6})-?([0-9]{7})$/;
    var num = value ? value : el.value;
    if (!pattern.test(num)) return "invalid";
    num = RegExp.$1 + RegExp.$2;

    var sum = 0;
    var last = num.charCodeAt(12) - 0x30;
    var bases = "234567892345";
    for (var i=0; i<12; i++) {
        if (isNaN(num.substring(i,i+1))) return "invalid";
        sum += (num.charCodeAt(i) - 0x30) * (bases.charCodeAt(i) - 0x30);
    }
    var mod = sum % 11;
    return ((11 - mod) % 10 == last) ? true : "invalid";
}

FormChecker.prototype.func_isValidBizNo = function(el,value) {
    var pattern = /([0-9]{3})-?([0-9]{2})-?([0-9]{5})/;
    var num = value ? value : el.value;
    if (!pattern.test(num)) return "invalid";
    num = RegExp.$1 + RegExp.$2 + RegExp.$3;
    var cVal = 0;
    for (var i=0; i<8; i++) {
        var cKeyNum = parseInt(((_tmp = i % 3) == 0) ? 1 : ( _tmp  == 1 ) ? 3 : 7);
        cVal += (parseFloat(num.substring(i,i+1)) * cKeyNum) % 10;
    }
    var li_temp = parseFloat(num.substring(i,i+1)) * 5 + "0";
    cVal += parseFloat(li_temp.substring(0,1)) + parseFloat(li_temp.substring(1,2));
    return (parseInt(num.substring(9,10)) == 10-(cVal % 10)%10) ? true : "invalid";
}

FormChecker.prototype.func_isValidPhone = function(el,value) {
    var pattern = /^([0]{1}[0-9]{1,2})-?([1-9]{1}[0-9]{2,3})-?([0-9]{4})$/;
    var num = value ? value : el.value;
    if (pattern.exec(num)) {
        if(RegExp.$1 == "011" || RegExp.$1 == "016" || RegExp.$1 == "017" || RegExp.$1 == "018" || RegExp.$1 == "019") {
            if(!el.getAttribute("span"))
                el.value = RegExp.$1 + "-" + RegExp.$2 + "-" + RegExp.$3;
        }
        return true;
    } else {
        return "invalid";
    }
}

/**
* common prototype functions
*/
String.prototype.trim = function(str) {
    str = this != window ? this : str;
    return str.ltrim().rtrim();
}

String.prototype.ltrim = function(str) {
    str = this != window ? this : str;
    return str.replace(/^\s+/g,"");
}

String.prototype.rtrim = function(str) {
    str = this != window ? this : str;
    return str.replace(/\s+$/g,"");
}

String.prototype.bytes = function(str) {
    var len = 0;
    str = this != window ? this : str;
    for (j=0; j<str.length; j++) {
        var chr = str.charAt(j);
        len += (chr.charCodeAt() > 128) ? 2 : 1;
    }
    return len;
}

String.prototype.bytesCut = function(bytes) {
    var str = this;
    var len = 0;
    for (j=0; j<str.length; j++) {
        var chr = str.charAt(j);
        len += (chr.charCodeAt() > 128) ? 2 : 1;
        if (len > bytes) {
            str = str.substring(0, j);
            break;
        }
    }
    return str;
}

function autoNext(el, limit, next_el) {
	if(el.value.bytes() == 6) next_el.focus();
}
