/**
* 파일명: lib.validate.js
* 설  명: 폼 체크, 값 표준화
* 작성자: jstoy project
* 날  짜: 2003-10-28
*   lainTT (2003-11-20) : FormChecker Class의 함수 prototype화 & 전역변수를 클래스 안으로.
*   gggl.ko (2007-06-28) : 파일타입기능 추가, 라디오버튼 및 체크박스 단일일 경우의 빈값 체크 에러 수정
***********************************************
*/

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

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



	
	/* * /
	//국문
    this.FORM_ERROR_MSG = {
       common	: "입력하신 내용이 규칙에 어긋납니다.\n규칙에 어긋나는 내용을 바로잡아주세요.",
       required	: "값이 입력되지 않았습니다.",
       notequal	: "입력값이 일치하지 않습니다.",
       invalid		: "입력값이 형식에 벗어납니다.",
       minbyte		: "입력값의 길이가 {minbyte}자(영문기준) 이상이어야 합니다.",
       maxbyte	: "입력값의 길이가 {maxbyte}자(영문기준)를 초과할 수 없습니다.",
	   extNotFile : "입력 파일이 지정된 파일 형식이 아닙니다."
    }
	/* */

	//영문
    this.FORM_ERROR_MSG = {
       common	: "inputs crosses each other in rule.",
       required	: "not input.",
       notequal	: "does not agree.",
       invalid		: "escapes in format.",
       minbyte		: "The length of input value {minbyte} people (English standard) is above and it does.",
       maxbyte	: "The length of input value {maxbyte} people (English standard) it will not be able to exceed .",
	   extNotFile : "Is not the file format where the input file is designated."
    }
	/* */




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

	/** 2007-04-18 gggl.ko
	*	<pre>
	*	파일 폼 타입 체크 및 함수 매핑
	*	</pre>
	*/
	this.FILE_FUNCTION = {
       fileType   : this.func_isValidFileType
    }



    /**
    * <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.errMsg    = "";
    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"));

        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");
		var file	=	el.getAttribute("FILE");

		

        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: if (el.value != null) {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];			
				
					//단일 항목일 경우와 다중항목일 경우 분리 2007-06-28 gggl.ko
					if (isNaN(elCheck.length) == true) {

							if (elCheck.checked == true) {
									isChecked = true;
							} else {
									isChecked = false;
							}

							if (isChecked == false) this.addError(el,"required");
							break;
					} else {
							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;
					}
            }
        }


		/* 2007-04-18 gggl.ko 파일타입 체크 */

		if (elType == "file") {
					
			         var tmp_msg = this.FILE_FUNCTION["fileType"](el);
                    if (tmp_msg != true) this.addError(el,tmp_msg);
		}

		/* *************************************************************** */

        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) {
                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);
                }
            }

        }




    }
    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.focus();
		}
    }
    this.errMsg = "";
    this.errObj = "";
}

FormChecker.prototype.addError = function(el, type) {
    var pattern = /\{([a-zA-Z0-9_]+)\}/i;
    var message = (this.FORM_ERROR_MSG[type]) ? this.FORM_ERROR_MSG[type] : type;
	var errMsgUserSetChk = "N";
	//2007-06-16 gggl.ko xml 연동 message 출력폭 확대
	//차후 함수인지 구분하여 체크함.
    if (el.getAttribute("errmsg") != null) {
		try {
			message = eval(el.getAttribute("errmsg"));	
		}
		catch (e) {
			message = el.getAttribute("errmsg");
		}
		errMsgUserSetChk = "Y";
	}
		
    if (pattern.test(message) == true) {
        while (pattern.exec(message)) message = message.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 += "   - "+ message +"\n";
            } else if (this.curObj != el.name) {
                if (this.curObj)
                    this.errMsg += "\n";
           
			//this.errMsg += "["+ el.getAttribute("hname") +"]\n   - "+ message +"\n";
			if (errMsgUserSetChk == "N") {
						this.errMsg += el.getAttribute("hname") + " " + message;
			} else {
						this.errMsg +=  message;
			}
           
		   // this.errMsg += message;
        }
    }
    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_]{4,11}$/;
   return (pattern.test(el.value)) ? true : "Please use more than 5 but less than 12 letters and numbers.";//"5자이상 12자 미만,\n 영문,숫자, _ 문자만 사용할 수 있습니다"
}

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

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 : "Please use only numbers.";//"반드시 숫자로만 입력해야 합니다";
}

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

/* 2007-04-18 gggl.ko 파일폼 체크 추가 */
FormChecker.prototype.func_isValidFileType= function(el) {

var j,imageExtArr,audioExtArr,movieExtArr,docExtArr

var imageExt		= "bmp,jpg,jpeg,gif,scr,jp2,png,wmf,pic,swf";
var audioExt			= "wma,mp2,mp3,wav,mid,cda,asx,ogg";
var movieExt		= "avi,mpg,mpeg,asf,wmv,flv,mov,m3u";
var documentExt	= "txt,doc,hwp,pdf,htm,html,ppt,gul,url,xml";

imageExtArr			=		imageExt.split(",");
audioExtArr			=		audioExt.split(",");
movieExtArr			=		movieExt.split(",");
documentExtArr	=		documentExt.split(",");

		try {
			
								/*	el.file  값,	---	  ex) img, doc 에 따른 예외처리.	*/
								var elValue = el.value.toLowerCase();

										if (elValue){

													//3글자면 단일 확장자 체크함.
													if (el.file.length == 3) {
																	if (elValue.indexOf("."+el.file.toLowerCase()) != -1 ) {
																			return true;
																	}	
													} else {

															for (j=0;j < eval(el.file+"ExtArr").length; j++) {		
																	if (elValue.indexOf("."+eval(el.file+"ExtArr")[j]) != -1 ) {
																			return true;
																	}	
															}
													}

													//파일타입은 셀렉 잡을 필요없음 2007-04-18 gggl.ko
													el.select = null;
													return "extNotFile";

										} else {
													return true;
										}
		}
		catch (e) {
			return true;
		}
}



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