/**
* <pre>
* 폼 체크 trigger 함수
* </pre>
*
* @param Form Object
* @return boolean
*/
function validate(form, type) {
    var result;
    var checker = new FormChecker(form, type);

    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, type) {
    /**
    * <pre>
    * 미리 정의된 에러 메시지들
    * </pre>
    */
    this.FORM_ERROR_MSG = {
       common   : "입력하신 내용 중 아래 내용을 바로잡아주세요.",

       required : "반드시 입력하셔야 하는 사항입니다.",
       notequal : "입력된 내용이 일치하지 않습니다.",
       invalid  : "입력된 내용이 형식에 어긋납니다.",
       minbyte  : "입력된 내용의 길이가 {minbyte} 자 이상이어야 합니다.",
       maxbyte  : "입력된 내용의 길이가 {maxbyte} 자를 초과할 수 없습니다."
    }

    /**
    * <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,
		nick : this.func_isNickName
    }

    /**
    * <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" : "";
	this.errMsg = "";
    this.errObj    = "";
    this.curObj    = "";
    this.errMode   = this.ERROR_MODE_FLAG["one"];  // 에러메시지 출력모드
	this.type = true;	// 에러 출력모드(true: 일반경고창, false: 레이어창)
}

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"));

        if (el.type == "radio" || el.type == "checkbox") {
            var elType = "check";
        } else if (el.type == "file") {
            var elType = "file";
        } else if (el.tagName == "select") {
            var elType = "select";
        } else {
            var elType = "text";
        }
        var trim    = el.getAttribute("TRIM");
        var minbyte = el.getAttribute("MINBYTE");
        var maxbyte = el.getAttribute("MAXBYTE");
        var option  = el.getAttribute("OPTION");
        var match   = el.getAttribute("MATCH");
        var span    = el.getAttribute("SPAN");
        var glue    = el.getAttribute("GLUE");
        var pattern = el.getAttribute("PATTERN");

        if (elType == "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 (elType) {
                case "file": case "text":
                    if (el.value == null || el.value == "") this.addError(el,"required");
                    break;
                case "select":
                    if (el[el.selectedIndex].value == null || el[el.selectedIndex].value == "") this.addError(el,"required");
                    break;
                case "check":
                    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;
            }
        }
        if (elType == "text") {
            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 (match && (el.value != this.form.elements[match].value)) {
                this.addError(el,"notequal");
            }
            if (option != null && ( el.getAttribute("REQUIRED") != null || el.value != "") ) {
                if (span != null) {
                    var _value = new Array();
                    for (var j = 0; j < span; j++) {
                        _value[j] = this.form.elements[i + j].value;
                    }
                    var value = _value.join(glue == null ? "" : glue);
                    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');
            }
        }
    }
    return !this.isErr;
}

FormChecker.prototype.destroy = function() {
    if (this.isErr == true) {
		if (this.type)
			alert(this.errMsg);
		else
			alert_(this.FORM_ERROR_MSG["common"], this.errMsg, 460, 200);
        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.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";
            this.errMsg += el.getAttribute("hname") +"  : "+ msg +"\n";
        }
    }
    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,11}$/;
   return (pattern.test(el.value)) ? true : "5자이상( 2005년 7월 이전 가입자는 4자 이상 ) 12자 이하, 영문, 숫자, -, _ 문자만 사용할 수 있습니다";
}

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

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

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

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";
	else return true; // 임시로 오픈
    /*
	 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";
    }
}

FormChecker.prototype.func_isNickName = function(el) {
   var pattern = /^[가-힝a-zA-Z0-9_-]{1,16}$/;
   return (pattern.test(el.value)) ? true : "한글 2자이상 8자 이하 그리고 영문, 숫자, -, _ 문자만 사용할 수 있습니다";
}

/**
* 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;
}
