﻿
////////////////////////////////////////////////////////////////////////
/*********************************************
* 파일명: lib.validate.js
* 기능: 유연한 자동 폼 검사기
* 만든이: 거친마루 <comfuture@maniacamp.com>
* 날짜: 2002-10-01
* == change log ==
* 2003-10-02 여러칸으로 나눠진 항목에 대한 검사기능 추가
* 2003-10-02 패스워드등 두개 항목에 대한 비교 기능 추가
* 2004-01-07 radio 및 check박스가 하나일경우 문제 수정
* 2005-01-29 input text 값이 일정 범위인지 체크 minnum ~ maxnum
**********************************************/

var FldDefaultColor;
var FildBackColor;
/// 에러메시지 포멧 정의 ///
// var NO_BLANK = "{name+은는} 필수항목입니다";
var NO_BLANK = "  [{name}] is a required field...";
var NOT_VALID = "Invalid  Number... ";
// var TOO_LONG = "{name}의 길이가 초과되었습니다 (최대 {maxbyte}바이트)";

/// 스트링 객체에 메소드 추가 ///
String.prototype.trim = function(str) {
    str = this != window ? this : str;
    return str.replace(/^\s+/g,'').replace(/\s+$/g,'');
}

String.prototype.hasFinalConsonant = function(str) {
    str = this != window ? this : str;
    var strTemp = str.substr(str.length-1);
    return ((strTemp.charCodeAt(0)-16)%28!=0);
}

String.prototype.bytes = function(str) {
    str = this != window ? this : str;
	var len = 0; //bug. 이 한줄때문에 고생을.. 넣어주세요. -_-;;
    for(j=0; j<str.length; j++) {
        var chr = str.charAt(j);
        len += (chr.charCodeAt() > 128) ? 2 : 1
    }
    return len;
}

function validate(mfrm) {
	var len =0;
	
	len = mfrm.elements.length;
   
	for (i = 0; i < len ; i++ ) {
        var el = mfrm.elements[i];
      
        if (el.tagName == "OBJECT") continue;
        if (el.tagName == "FIELDSET") continue;

        el.value = el.value.trim();

        var minbyte = el.getAttribute("MINBYTE");
        var maxbyte = el.getAttribute("MAXBYTE");
		var minnum = el.getAttribute("MINNUM");
		var maxnum = el.getAttribute("MAXNUM");
        var option = el.getAttribute("OPTION");
        var match = el.getAttribute("MATCH");
        var glue = el.getAttribute('GLUE');
        var PATTERN = el.getAttribute('PATTERN');

        if (el.getAttribute("REQUIRED") != null) {
            if (el.type.toLowerCase() == "radio" || el.type.toLowerCase() == "checkbox")
            {
                if(!chkRadio(mfrm,el)) return doError(el,NO_BLANK);
            }
            if (el.value == null || el.value == "") {
                return doError(el,NO_BLANK);
            }
        }

        if (PATTERN != null && el.value != "") {
            if (!PATTERN(el,pattern)) return false;
        }

        if (minbyte != null) {
            if (el.value.bytes() < parseInt(minbyte)) {
                return doError(el,"{name+은는} 최소 "+minbyte+"바이트 이상 입력해야 합니다.");
            }
        }

        if (maxbyte != null && el.value != "") {
            if (el.value.bytes() > parseInt(maxbyte)) {
                return doError(el,"{name}의 길이가 초과되었습니다 (최대 "+maxbyte+"바이트)");
            }
        }

        if (minnum != null) {
            if (parseInt(el.value, 10) < parseInt(minnum)) {
                return doError(el,"{name+은는} 최소 "+minnum+" 이상 입력해야 합니다.");
            }
        }

        if (maxnum != null && el.value != "") {
            if (parseInt(el.value, 10) > parseInt(maxnum)) {
                return doError(el,"{name}의 값이 초과되었습니다 (최대 "+maxnum+")");
            }
        }

        if (match && (el.value != mfrm.elements[match].value)) return doError(el,"{name+이가} 일치하지 않습니다");

        if (funcs[option] && option != null && el.value != "") {
            if (el.getAttribute('SPAN') != null) {
                var _value = new Array();
                for (span=0; span<el.getAttribute('SPAN');span++ ) {
                    _value[span] = mfrm.elements[i+span].value;
                }
                var value = _value.join(glue == null ? '' : glue);
                if (!funcs[option](el,value)) return false;
            } else {
                if (!funcs[option](el)) return false;
            }
        }


    }
    return true;
}

function josa(str,tail) {
    return (str.hasFinalConsonant()) ? tail.substring(0,1) : tail.substring(1,2);
}

function doError(el,type,action) {
   var pattern = /{([a-zA-Z0-9_]+)\+?([가-힝]{2})?}/;
   var name = (hname = el.getAttribute("HNAME")) ? hname : el.getAttribute("NAME");
   pattern.exec(type);
   var tail = (RegExp.$2) ? josa(eval(RegExp.$1),RegExp.$2) : "";

   var error = (herror = el.getAttribute("HERROR")) ? herror : type.replace(pattern,eval(RegExp.$1) + tail);

   alert(error);

   if(el.getAttribute("SELECT") != null) el.select();
   if(el.getAttribute("DELETE") != null) el.value = "";
   if(el.getAttribute("NOFOCUS") == null) el.focus();
   //el.value = "";
   return false;
}

function chkRadio(mfrm,field){
	fieldname = eval(mfrm.name+'.'+field.name);
	if(fieldname.isMultiLine == false) {
		if(fieldname.checked)	return true;
	} else {
	    for (j=0;j<fieldname.length;j++) {
	        if (fieldname[j].checked) return true
	    }
	}
    return false;
}

/// 특수 패턴 검사 함수 매핑 ///
var funcs = new Array();
funcs['http'] = isValidHttp;	// http://www.daum.net
funcs['email'] = isValidEmail;	// E-Mail
funcs['phone'] = isValidPhone;	// 전화번호
funcs['userid'] = isValidUserid; // User ID
funcs['koronly'] = isKorean;	// 한글 Only
funcs['number'] = isNumeric;	// 숫자 Only
funcs['engonly'] = alphaOnly;	// Alphabet Only
funcs['ssn'] = isValidSSN;	// 주민 번호
funcs['bizno'] = isValidBizNo;	// 사업자 등록번호
funcs['score'] = isValidScore;	// 소숫점2자리
funcs['upper'] = isValidUpper;	// 대문자
funcs['lower'] = isValidLower;	// 소문자
funcs['firstup'] = isValidFirstup;	// 첫글자만 대문자
funcs['limit'] = isValidLimit;	// 금지된 E-Mail
funcs['phonenum'] = isPhone;	// 전화번호, 사업자번호
funcs['point'] = isPoint;	// 점수
funcs['cpf'] = isValidCPF;   // CPF 번호(브라질 버전 추가)

/// 패턴 검사 함수들 ///
function PATTERN(el,pattern) {
    pattern = eval("/"+pattern+"$/")
    return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 형식에 맞지 않습니다.");
}

function isValidHttp(el,value) {
    var value = value ? value : el.value;
    var pattern = /^http:\/\/[\.a-zA-Z0-9-]+\.[\.a-zA-Z0-9-]+\.[a-zA-Z]+$/;
    return (pattern.test(value)) ? true : doError(el,NOT_VALID);
}

function isValidEmail(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 : doError(el,NOT_VALID);
}

function isValidUserid(el) {
    //var pattern = /^[a-zA-Z]{1}[a-zA-Z0-9_]{4,11}$/;
    var pattern = /[a-zA-Z0-9_]{5,12}$/;
    return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 5자이상 12자 미만이어야 하고,\n 영문,숫자, _ 문자만 사용할 수 있습니다");
}

function isValidDate(el) {
    var pattern = /^[-0-9]+$/;
    return (pattern.test(el.value)) ? true : doError(el,"{name+은는} yyyy-mm-dd 형식으로 입력해주십시요");
}

function isKorean(el) {
    var pattern = /^[가-힝]*$/;
    return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 반드시 한글로 입력해야 합니다");
}

function alphaOnly(el) {
    var pattern = /^[a-zA-Z]+$/;
    return (pattern.test(el.value)) ? true : doError(el,NOT_VALID);
}

function isNumeric(el) {
    var pattern = /^[0-9]+$/;
    return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 반드시 숫자로만 입력해야 합니다");
}

function isPhone(el) {
    var pattern = /^[-0-9]+$/;
    return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 반드시 숫자와 '-'으로만 입력해야 합니다");
}

function isPoint(el) {
    var pattern = /^[.0-9]+$/;
    return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 반드시 숫자와 '.'으로만 입력해야 합니다");
}

function isValidSSN(el,value) {
    var pattern = /^([0-9]{6})-?([0-9]{7})$/;
    var num = value ? value : el.value;
    if (!pattern.test(num)) return doError(el,NOT_VALID);
    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 doError(el,NOT_VALID);
        sum += (num.charCodeAt(i) - 0x30) * (bases.charCodeAt(i) - 0x30);
    }
    var mod = sum % 11;
    return ((11 - mod) % 10 == last) ? true : doError(el,NOT_VALID);
}

function isValidCPF(el,value) {
	var CPF = el.value ; 
	
	if (CPF.length != 11 || CPF == "00000000000" || CPF == "11111111111" ||
			CPF == "22222222222" ||        CPF == "33333333333" || CPF == "44444444444" ||
			CPF == "55555555555" || CPF == "66666666666" || CPF == "77777777777" ||
			CPF == "88888888888" || CPF == "99999999999")
			return  doError(el,NOT_VALID);

	sum = 0;
	
	for(i=0; i < 9; i ++)
	{
		sum += parseInt(CPF.charAt(i)) * (10 - i);
	}

	rest = 11 - (sum % 11);

	if (rest == 10 || rest == 11)
		rest = 0;

	if (rest != parseInt(CPF.charAt(9)))
				return  doError(el,NOT_VALID);
	
	sum = 0;
	for (i = 0; i < 10; i ++)
	{
		sum += parseInt(CPF.charAt(i)) * (11 - i);
	}

	rest = 11 - (sum % 11);

	if (rest == 10 || rest == 11)
		rest = 0;
		
	if (rest != parseInt(CPF.charAt(10)))
		return doError(el,NOT_VALID);

	return true;
}

function isValidBizNo(el, value) {
    var pattern = /([0-9]{3})-?([0-9]{2})-?([0-9]{5})/;
    var num = value ? value : el.value;
    if (!pattern.test(num)) return doError(el,NOT_VALID);
    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 : doError(el,NOT_VALID);
}

function isValidPhone(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 == "010" || 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 doError(el,NOT_VALID);
    }
}

// 대문자
function isValidUpper(el) {
    var pattern = /^[A-Z]+$/;
    return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 반드시 대문자로만 입력해야 합니다");
}
// 소문자
function isValidLower(el) {
    var pattern = /^[a-z]+$/;
    return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 반드시 소문자로만 입력해야 합니다");
}
//첫글자만 대문자
function isValidFirstup(el) {
    var pattern = /^[A-Z]{1}[a-zA-Z0-9_]+$/;
    return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 반드시 첫글자는 대문자로만 입력해야 합니다");
}
//소숫점 2자리까지
function isValidScore(el) {;
    var pattern = /^([0-9]{1,2})\.([0-9]{1,2})$/;
    return (pattern.test(el.value)) ? true : doError(el,"점수 입력이 올바르지 않습니다.");
}
//특정한 계정 입력불가
function isValidLimit(el,value) {
    // 금지할 도메인을 입력 하세요
		var invalidaddress=new Array()
		invalidaddress[0]="daum"
		invalidaddress[1]="hanmail"

    var value = value ? value : el.value;
    var pattern = /^[_a-zA-Z0-9-\.]+@[\.a-zA-Z0-9-]+\.[a-zA-Z]+$/;

    var invalidcheck=0;

		if (pattern.test(value)){
			var tempstring=value.split("@")
			tempstring=tempstring[1].split(".")
			for (i=0;i<invalidaddress.length;i++){
				if (tempstring[0]==invalidaddress[i])
					invalidcheck=1
			}
			if (invalidcheck!=1)
				return true;
			else{
				return doError(el,"입력된 계정은 금지된 계정입니다.");
			}
		}else{
			return doError(el,NOT_VALID);
		}
}

var init_true;

function Initialized()
{
    init_true = true;

    for (var i = 0; i < document.forms.length; i++) {
        // onsubmit 이벤트가 있다면 저장해 놓는다.
/*        if (document.forms[i].onsubmit) document.forms[i].oldsubmit = document.forms[i].onsubmit;
            document.forms[i].onsubmit = validate(document.forms[i]); */

        for (var j = 0; j < document.forms[i].elements.length; j++) {
            // 필수 입력일 경우는 * 배경이미지를 준다.
            //document.forms[i].elements[j].style.backgroundColor = FldDefaultColor ? FldDefaultColor : '#DDFFFF';

            if (document.forms[i].elements[j].getAttribute("REQUIRED") != null) {
                if (document.forms[i].elements[j].getAttribute("NOCOLOR") == null) {
                    document.forms[i].elements[j].style.backgroundColor = FildBackColor ? FildBackColor : '#FFEEEE';
                    //document.forms[i].elements[j].className = "required";
                    //document.forms[i].elements[j].style.backgroundPosition = "top right";
                    //document.forms[i].elements[j].style.backgroundRepeat = "no-repeat";
                }
            }
        }
    }
}
window.onload = Initialized;

///////////////////// 스크립트 끝 /////////////////////////////////

