/*
<input 속성 설명
hname="명칭"		: 명칭
option="number"	: 일반적인 형식의 데이터 지정(email, phone, userid, hangul, engonly, jumin, bizno)
required					: 필수입력
minbyte="10"			: 최소길이
maxbyte="10"		: 최대길이
fixbyte=""				: 고정길이
equalobj					: 값이 같아야하는 항목의 name	 
*/

/// 에러 메세지 정의///
var NO_BLANK		= "{name+은는} 필수항목입니다.";
var NOT_VALID		= "{name}의 형식이 바르지 않습니다.";
var TOO_LONG		= "{name}의 길이가 최대 길이보다 깁니다.";
var TOO_SHORT		= "{name}의 길이가 최소 길이보다 짧습니다.";
var TOO_FIX			= "{name}의 길이가 맞지 않습니다.";
var NOT_PASS_CHECK = "{name}의 값이 일치하지 않습니다.";
var NOT_DOMAIN		= "{name}의 형식이 바르지 않습니다.";
var NOT_USERID		= "{name}의 형식이 바르지 않습니다.";

/********** 일반적인 데이터 형식 정의*******************/
var funcs			= new Array();
funcs['email']		= isValidEmail;
funcs['phone']		= isValidPhone;
funcs['tel']	= isValidTel;
funcs['userid']	= isValidUserid;
funcs['number']	= isNumeric;			
funcs['engonly']	= alphaOnly;
funcs['engname']	= alphaName;			
funcs['jumin']		= isValidJumin;			
funcs['bizno']		= isValidBizNo;			
funcs['hangul']		= hasHangul;
funcs['engaddress']	= notHangul;
funcs['domain']		= isValidDomain;		
funcs['ipaddress']	= isValidIPaddr;		
funcs['dnsname']	= isValidDNS;			
funcs['domaincheck']	= isValidDomaina;	
funcs['banknumber']	= isValidBank;			
funcs['alphanum']	= alphaNum;

/// START 검사함수정의/////////////////////////////////////////////////
function isValidDomaina(el) {

	var pattern = /^([a-zA-Z0-9]{1,})\.?([a-zA-Z0-9]{1,})\.?([a-zA-Z0-9]{1,})$/;
	return (pattern.test(el.value)) ? true : doError(el,NOT_VALID);
}

function isValidBank(el) {

	var pattern = /^[0-9\-]+$/;
	return (pattern.test(el.value)) ? true : doError(el,NOT_VALID);
}

function isValidDNS(el) {

	var pattern = /^([a-zA-Z0-9]{1})\.?$/;
	return (pattern.test(el.value)) ? true : doError(el,NOT_VALID);
}

function isValidIPaddr(el) {

	var pattern = /^([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/;
	return (pattern.test(el.value)) ? true : doError(el,NOT_VALID);
}


function isValidEmail(el) {

	var pattern = /^[_a-zA-Z0-9-\.\-]+@[\.a-zA-Z0-9-\-]+\.[a-zA-Z\-]+$/;
	return (pattern.test(el.value)) ? true : doError(el,NOT_VALID);
}

function isValidUserid(el) {
	var pattern = /^[a-zA-Z]{1}[a-zA-Z0-9\-]{2,15}$/;
	return (pattern.test(el.value)) ? true : doError(el,NOT_USERID);
}

function alphaOnly(el) {

	var pattern = /^[a-zA-Z]+$/;
	return (pattern.test(el.value)) ? true : doError(el,NOT_VALID);
}

function alphaName(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 isValidTel(el) {//ﾀ・ｭｹ｣

	var pattern = /^[0-9\-]+$/;
	return (pattern.test(el.value)) ? true : doError(el,"\"{name}\"숫자만 입력 가능합니다.");
}

function isValidDomain(el) {

	var pattern = /^[^-]([a-z|A-Z|0-9\-]{0,})[a-z|A-Z|0-9]+$/;
	return (pattern.test(el.value)) ? true : doError(el,NOT_DOMAIN);
}


function isValidJumin(el) {
	var pattern = /^([0-9]{6})-?([0-9]{7})$/; 
	var num = el.value;
	if(num.length == 6){
		var objname = el.getAttribute("with");
		eval("num = num + el.form." + objname + ".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 (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 isValidBizNo(el) {

	var pattern = /([0-9]{3})-?([0-9]{2})-?([0-9]{5})/;
	var num = 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) {
	var pattern = /^([0]{1}[0-9]{1,2})+-([1-9]{1}[0-9]{2,3})+-([0-9]{4})$/;
	if (pattern.exec(el.value)) {
		if(RegExp.$1 == "011" || RegExp.$1 == "016" || RegExp.$1 == "017" || RegExp.$1 == "018" || RegExp.$1 == "019") {
			el.value = RegExp.$1 + "-" + RegExp.$2 + "-" + RegExp.$3;
		}
		return true;
	} else {
		return doError(el,NOT_VALID);
	}
}
function hasHangul(el) {
	var pattern = /^[가-힣]/;
	return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 반드시 한글을 포함해야 합니다");
}

function notHangul(el) {//한글 입력 안됨
	var pattern = /[가-힣]/;
	return (!pattern.test(el.value)) ? true : doError(el,"{name+은는} 한글은 입력하실 수 없습니다");
}
function alphaNum(el) {//알파벳 숫자만

	var pattern = /([a-z|A-Z|0-9])*/;
	return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 영문 또는 숫자만 입력 가능합니다.");
}

/// END 검사 함수 정의/////////////////////////////////////////////////


//에러 처리
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) : "";
	alert(type.replace(pattern,eval(RegExp.$1) + tail));
	if (action == "sel") {
		el.select();
	} else if (action == "del")	{
		el.value = "";
	}
	el.focus();
	return false;
}

/// 스트링 객체에 메소드 추가///
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);
}

function josa(str,tail) {
	return (str.hasFinalConsonant()) ? tail.substring(0,1) : tail.substring(1,2);
}

// 필수 항목에 클래스 지정
function requiredCheck(form) {
	for (var j = 0; j < form.elements.length; j++) {
		if (form.elements[j].getAttribute("required") != null) {
			form.elements[j].className                = "DINR";
			form.elements[j].style.backgroundPosition = "top right";
			form.elements[j].style.backgroundRepeat   = "no-repeat";
		}
	}
}

function validate(form){
	return validate_common_form(form);
}

function validate_common_form(form) {
	for (checki = 0; checki < form.elements.length; checki++ ) {
		var el = form.elements[checki];
		//el.value = el.value.trim();
		if (el.getAttribute("REQUIRED") != null) {
			if (el.value == null || el.value == "") return doError(el,NO_BLANK);
		}

		if (el.getAttribute("MAXBYTE") != null && el.value != "") {
			var len = 0;
			for(j=0; j<el.value.length; j++) {
				var str = el.value.charAt(j);
				len += (str.charCodeAt() > 128) ? 2 : 1
			}
			if (len > parseInt(el.getAttribute("MAXBYTE"))) {
				return doError(el,TOO_LONG);
			}
		}
		
		if (el.getAttribute("MINBYTE") != null && el.value != "") {
			var len = 0;
			for(j=0; j<el.value.length; j++) {
				var str = el.value.charAt(j);
				len += (str.charCodeAt() > 128) ? 2 : 1
			}
			if (len < parseInt(el.getAttribute("MINBYTE"))) {
				return doError(el,TOO_SHORT);
			}
		}
		
		if (el.getAttribute("FIXBYTE") != null && el.value != "") {
			var len = 0;
			for(j=0; j<el.value.length; j++) {
				var str = el.value.charAt(j);
				len += (str.charCodeAt() > 128) ? 2 : 1
			}
			if (len != parseInt(el.getAttribute("FIXBYTE"))) {
				return doError(el,TOO_FIX);
			}
		}

		if (el.getAttribute("OPTION") != null && el.value != "") {
			if (!funcs[el.getAttribute("OPTION")](el)) return false;
		}

		if (el.getAttribute("EQUALOBJ") != null && el.value != "") {
			var elname = el.getAttribute("EQUALOBJ");
			eval("var objvalue = form." + elname + ".value");
			if(objvalue != el.value) {
				return doError(el,NOT_PASS_CHECK);
			}
		}
	}
	return true;
}