/// 에러메시지 포멧 정의 ///
var NO_BLANK = "{name+을를} 입력하여 주십시오.";
var NO_CHECK = "{name+을를} 선택하여 주십시오.";
var NOT_VALID = "{name+이가} 올바르지 않습니다.";
var TOO_LONG = "{name}의 길이가 초과되었습니다. (최대 {maxbyte}바이트)";
var SPACE = (navigator.appVersion.indexOf("MSIE")!=-1) ? "          " : "";

// form.js 버젼 표기
var form_js = {
	Version: '1.0 r090506'
};

/// 스트링 객체에 메소드 추가 ///
String.prototype.space = function(str) {
	str = this != window ? this : str; 
	var strTemp = '';
	str.split('\n').each(function(line) { strTemp += line+(navigator.userAgent.match(/MSIE/)?'          ':'')+'\n'});
	return strTemp;
}

String.prototype.alert = function(str) {
	str = this != window ? this : str; 
	alert(str.space());
}

String.prototype.confirm = function(str) {
	str = this != window ? this : str; 
	return confirm(str.space());
}

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;
	for(var i=0, len=0; i<str.length; i++) {
		var chr = str.charAt(i);
		if(escape(chr).length > 4) len += 2;
		else if(chr != '\r') len++;
	}
	return len;
}

String.prototype.number_format = function() {
	var num = this.replace(/,/g,'');
	return num.replace(/(\d)(?=(?:\d{3})+(?!\d))/g,'$1,');
}

Array.prototype.shuffle = function() { 
	return this.concat().sort(function() {
		return Math.random() - Math.random();
	});
}

function in_array(value, array, similar) {
	for(var i=0; i<array.length; i++) {
		if(similar==true) {
			if(value.indexOf(array[i]) != -1) return true; // 비슷한 값
		} else {
			if(array[i]==value) return true; // 동일한 값
		}
	}
	return false;
}

function josa(str,tail) {
	return (str.hasFinalConsonant()) ? tail.substring(0,1) : tail.substring(1,2);
}

function checkMultiBox(el) {
	var obj = document.getElementsByName(el.name);
	for (var i=0; i<obj.length; i++) if(obj[i].checked==true) return true;
	return false;
}

var submit_is = {};
function validate(form, skip) {

	var re = util.dupl_select_check();
	if(!re) return false;

	var editor_is = "";
	if(editor_use=='yes') {
		var editor_is = netk_editor.form_action(form); // : 정보저장시 editor실행
		if(editor_is=='no') return false;
	}

	for (var i=0; i<form.length; i++) {
		try {
			var el = form[i];
			var type = form[i].getAttribute("type");
			//if(el.tagName=='textarea' && (!type || type=='editor')) continue;
			if(el.tagName.match(/fieldset/i) || el.disabled===true) continue;
			if(skip && in_array(el.name, skip.split('|'), true)===true) continue;
			if(el.type.toLowerCase() != "file" && el.getAttribute("NOTRIM")==null && el.value) el.value = el.value.trim(); // 수정 :: 파폭 보안 문제

			// 첨부파일 필터링 설정시
			if(el.type.toLowerCase() == "file" && el.value && (el.getAttribute("filter")!=null || el.getAttribute("antifilter")!=null)) {
				var file_infos = el.value.split('.');
				var _ext = file_infos[file_infos.length-1].toLowerCase();
				if(el.getAttribute("antifilter")!=null && in_array(_ext, el.getAttribute("antifilter").split(','))) {
					return doError(el,"선택하신 {name+은는} 첨부할 수 없습니다.("+el.getAttribute("antifilter")+" 파일은 첨부불가)");
				}
				else if(!in_array(_ext, el.getAttribute("filter").split(','))) {
					return doError(el,"선택하신 {name+은는} 첨부할 수 없습니다.("+el.getAttribute("filter")+" 파일만 첨부가능)");
				}
			}

			// 기타 필드에 필터링 설정시 - 08.03.21 추가
			if(el.getAttribute("antifilter")!=null) {
				var filters = el.getAttribute("antifilter").split(',');
				var _contents = el.value.replace(/ /g,'').replace(/&nbsp;/g,''); // 공백문자 제거
				for(var x=0; x<filters.length; x++) {
					if(_contents.indexOf(filters[x])!=-1) {
						return doError(el, "{name}에는 '"+filters[x]+"'를 입력할 수 없습니다.");
					}
				}
			}

			var PATTERN = el.getAttribute("PATTERN");
			var minbyte = el.getAttribute("MINBYTE");
			var maxbyte = el.getAttribute("MAXBYTE");
			var minval = el.getAttribute("MINVAL");
			var not_needed = el.getAttribute("not_needed");
			var maxval = el.getAttribute("MAXVAL");
			var option = el.getAttribute("OPTION");
			var ignore0 = el.getAttribute("IGNORE0");
			var match = el.getAttribute("MATCHING"); // 수정 :: Prototype JS 와 충돌하여 'MATCH' 에서 'MATCHING' 으로 변경
			var glue = el.getAttribute("GLUE");
			var unit = el.getAttribute("UNIT");
			var regexp = eval(el.getAttribute("regexp"));
			var check_name = el.getAttribute("check_name");
			var check_tag = el.getAttribute("check_tag"); if(check_tag!=null) check_tag = check_tag.toLowerCase();
			var message = el.getAttribute("message");
			var hname = el.getAttribute("hname");

			if(not_needed!=null) el.getAttribute("NEEDED") = null;

			if(check_name!=null) {

				if(in_array(check_tag, ['radio', 'checkbox'])) {
					var msg = check_name_func(el, form);
					if(msg) {
						doError(el,msg[1]);
						if(msg[0]) msg[0].focus();
						return false;
					}
					continue;
				} else if(el.getAttribute("NEEDED")!=null) {
					var is_len = 0;
					$(form).find("[name='"+check_name+"']").each(function(){
						if($(this).val()) is_len++;
					});
					if(is_len<=0) {
						$(el).attr("needed", "needed");
						doError(el, message);
						$(form).find("[name='"+check_name+"']").eq(0)[0].focus();
						return false;
					} else {
						$(el).removeAttr("needed");
					}
				}
			}

			if(type && el.tagName.toLowerCase()=='textarea' && type.toLowerCase()=='editor' && editor_is) {
				if(message) alert(message);
				if(hname) doError(el,NO_BLANK);
				if(enum_editor=='summernote') {
					$("#"+editor_is).summernote('focus', true);
				} else {
					if(editor_is) editor_is.focus();
				}
				return false;
			}

			var or = el.getAttribute("OR"); // 추가 :: 둘 중 하나의 값을 입력 받고자 하는 경우(이경우, REQUIRED 는 사용하지 말 것)
			if(unit == null) unit = '';

			if (el.getAttribute("NEEDED") != null) {
				if(el.getAttribute('nofocus')==null && el.style.display=='none') continue; // 2009.05.06 추가
				var ERR_MSG = (el.getAttribute("MESSAGE") != null) ? el.getAttribute("MESSAGE") : null;
				if ((el.type.toLowerCase() == "radio" || el.type.toLowerCase() == "checkbox" || (el.type.toLowerCase() == "file" && !el.value)) && !checkMultiBox(el)) return (ERR_MSG) ? doError(el, ERR_MSG) : doError(el, NO_CHECK);
				if (el.tagName.toLowerCase() == "select" && (el.value == null || el.value == "")) return (ERR_MSG) ? doError(el,ERR_MSG) : doError(el,NO_CHECK);
				if (el.value == null || el.value == "" || (ignore0==null && el.value == "0") || (el.getAttribute("DEFAULT")!=null && el.value == el.getAttribute("DEFAULT"))) return (ERR_MSG) ? doError(el,ERR_MSG) : doError(el,NO_BLANK);
			}
		}
		catch(e) {
			//alert(e.message+form[i].name+":"+form[i].checked +":"+ form[i].value);
		}

		if (minbyte != null && el.value != "" && el.value.bytes() < parseInt(minbyte)) {
			if(unit=='') unit = "바이트";
			return doError(el,"{name+은는} 최소 "+new String(minbyte).number_format()+unit+" 이상 입력하셔야 합니다.");
		}
		if (maxbyte != null && el.value != "" && el.value.bytes() > parseInt(maxbyte)) {
			if(unit=='') unit = "바이트";
			doError(el,"{name+은는} 최대 "+new String(maxbyte).number_format()+unit+" 이하로 입력하셔야 합니다.");
			el.value = el.value.substring(0,parseInt(maxbyte));
			return false;
		}

		if (minval != null && el.value != "" && el.value < parseInt(minval)) return doError(el,"{name+은는} 최하 "+new String(minval).number_format()+unit+" 이상 입력하셔야 합니다.");
		if (maxval != null && el.value != "" && el.value > parseInt(maxval)) return doError(el,"{name+은는} 최고 "+new String(maxval).number_format()+unit+" 이하로 입력하셔야 합니다.");
		if (PATTERN != null && el.value != "" && !PATTERN(el,pattern)) return false;
		if (match != null && (el.value != form[match].value)) return doError(el,"{name+이가} 일치하지 않습니다.");

		if (or != null && (el.value == null || el.value == "") && (form[or].value==null || form[or].value == "")) {
			var name2 = (hname = form[or].getAttribute("HNAME")) ? hname : form[or].getAttribute("NAME");
			return doError(el,"{name+} 또는 "+name2+" 중 하나는 입력하셔야 합니다.");
		}

		if (option != null && el.value != "") {
			if (el.getAttribute('SPAN') != null) {
				var _value = new Array();
				for (var span=0; span<el.getAttribute('SPAN');span++ ) _value[span] = form[i+span].value;
				var value = _value.join(glue == null ? '' : glue);
				if (!funcs[option](el,value)) return false;
			} else {
				try{ if (!funcs[option](el)) return false; } catch(e) {} // 수정 :: 익스7에서 'runtime' 오류 발생으로 변경
			}
		}

		if(regexp && !regexp.test(el.value)) return doError(el,"{name+} 은 숫자나 영문만 사용 가능합니다.");
	}

	if(submit_is[form.name]===true) {
		alert("처리중입니다. 잠시만 기다리시면 처리가 완료됩니다.");
		return false;
	}
	submit_is[form.name] = true;
	setTimeout(function(){
		submit_is[form.name] = false;
	},1000);

	return true;
}

function radio_check_object(el) {
	var check_name = $(el).attr("check_name");
	var check_tag = $(el).attr("check_tag").toLowerCase();

	if(in_array(check_tag, ['radio', 'checkbox'])) {
		var check_name2 = check_tag=='radio' ? check_name : check_name+'[]';
		return $("input[name='"+check_name2+"']").eq(0);
	}
}

function doError(el,type,action) {
	if(type==undefined) type = NO_BLANK; // fixed
	var pattern = /{([a-zA-Z0-9_]+)\+?([가-힝]{2})?}/g;
	var name = (hname = el.getAttribute("HNAME")) ? hname : el.getAttribute("NAME");
	pattern.exec(type);
	try {
		var tail = (RegExp.$2) ? josa(eval(RegExp.$1),RegExp.$2) : '';
		alert((type.replace(pattern,eval(RegExp.$1) + tail)));
	}
	catch(e) { // checkbox 에서 오류가 발생할 가능성이 높다
		var message = el.getAttribute("message");
		if(message!=null) alert(message);
		else doError(el,NO_CHECK);
		return false;
	}
	if(action == "sel") el.select();
	else if(action == "del")	el.value = "";
	if(el.getAttribute("NOFOCUS") == null) {
		el.focus();
		if(el.getAttribute("DEFAULT")!=null) el.value = el.getAttribute("DEFAULT");
	}
	if(el.getAttribute("SETFOCUS") != null && el.getAttribute("SETFOCUS") !='') el.form[el.getAttribute("SETFOCUS")].focus();
	return false;
}

// : 체크박스 필요체크갯수에 맞게 체크가 되있지 않을때 발생하는 이벤트
function check_name_func(el, form) {
	var same_arr = {'down':'이하'};
	var check_name = el.getAttribute("check_name"); // : 체크할 태그명
	var check_tag = el.getAttribute("check_tag"); // : 체크type값
	var check_num = el.getAttribute("check_num"); // : 몇개까지 체크가능? [ checkbox에서 사용합니다. ]
	var same = el.getAttribute("same"); // : 갯수가 일치해야지만 넘어갑니다.
	var needed = el.getAttribute("needed");
	var message = el.getAttribute("message");
	var min = parseInt(el.getAttribute("min"));
	var check_is_num = 0;
	if(!check_name) return false;
	var obj = $(form).find("input[name='"+check_name+"']");
	var len = $(form).find("input[name='"+check_name+"']:checked").length;
	var count = 0;
	var focus_obj = '';
	check_num = check_num ? check_num : 1;

	if(len>0) {
		obj.each(function(i){
			if(in_array(check_tag, ['checkbox', 'radio']) && $(this)[0].checked===true) check_is_num++;
			if(in_array(check_tag, ['text']) && $(this)[0].value) check_is_num++;

			if(in_array(check_tag, ['text']) && !$(this)[0].value && !focus_obj) focus_obj = $(this)[0];
			if(in_array(check_tag, ['checkbox', 'radio']) && $(this)[0].checked===false && !focus_obj) focus_obj = $(this)[0];
		});
	}

	var msg_part = (in_array(check_tag, ['checkbox', 'radio'])) ? '체크' : '입력';
	var msg_part2 = same ? same_arr[same] : (same!=null ? '' : ' 이상');
	var obj = radio_check_object(el);
	
	if(!message) {
		switch(check_num>1 || (min>0 && min>check_is_num)) {
			case true:
				var msg = '{name+은는} '+number_format(check_num)+'개'+msg_part2+' '+msg_part+'해주시기 바랍니다.';
				if(obj) obj[0].focus();
				break;
			default:
				var msg = '{name+을를} '+msg_part+'해주시기 바랍니다.';
				if(obj) obj[0].focus();
				break;
		}
	} else {
		var msg = message;
	}




	switch(same!=null) {
		case true:
			switch(same) {
				case 'down':
					var chk = false;
					if(min>0 && min>check_is_num) chk = true;
					if(check_num<check_is_num) chk = true;
					if(chk===true && needed!=null) return [focus_obj, msg];
					break;
				default:
					if(check_num!=check_is_num && needed!=null) return [focus_obj, msg];
					break;
			}
			break;
		default:
			if(check_num>check_is_num && needed!=null) return [focus_obj, msg];
			break;
	}
}

/// 특수 패턴 검사 함수 매핑 ///
var funcs = new Array();
funcs['domain'] = isValidDomain;
funcs['email'] = isValidEmail;
funcs['hphone'] = isValidHPhone;
funcs['phone'] = isValidPhone;
funcs['phones'] = isValidPhones;
funcs['userid'] = isValidUserid;
funcs['userName'] = isValiduserName;
funcs['userpw'] = isValidUserpw;
funcs['userpw_special'] = isValidUserpw_special;
funcs['userpw2'] = isValidUserpw2;
funcs['hangul'] = hasHangul;
funcs['number'] = isNumeric;
funcs['float'] = isFloat;
funcs['engonly'] = alphaOnly;
funcs['normal'] = isSpecialCharacter;
funcs['jumin'] = isValidJumin;
funcs['bizno'] = isValidBizNo;

/// 패턴 검사 함수들 ///
function isBlank(el,value) { // 2008.07.12 추가
	var value = value ? value : el.value;
	return value.trim() ? true : doError(el,NO_BLANK);
}

function isValidDomain(el,value) {
	if(el.getAttribute('needed')==null) {
		var default_val = el.getAttribute('default');
		if(default_val!=null && el.value==default_val) return true;
	}
	var value = value ? value : el.value;
	var pattern = /^[_a-zA-Z가-힝0-9-]+\.[a-zA-Z가-힝0-9-\.]+[a-zA-Z]+$/;
	return (pattern.test(value.replace(/http:\/\//g, ''))) ? 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) { // 2008.07.14 doError 수정
	var pattern = /^[a-zA-Z]{1}[a-zA-Z0-9_]{3,14}$/;
	return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 영문 소문자로 시작하는 4~15자의 영문 소문자와 숫자의 조합만 사용할 수 있습니다.");
}

function isValiduserName(el) { // 2008.07.14 doError 수정
	var pattern = /[\"\'\!@#$%^&*()\[\]\{\}:;<>?\/,.+=|/g]/;
	return (pattern.test(el.value)) ? doError(el,"{name+은는} 특수문자를 사용할수 없습니다.") : true;
}

function isValidUserpw(el) { // 2008.07.14 doError 수정
	var pattern = /.{4,15}$/;
	return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 4~15자로 입력해주시기 바랍니다.");
}

function isValidUserpw_special(el) { // 2008.07.14 doError 수정
	var pattern = /^(?=.*[a-zA-Z0-9])(?=.*[~,!,@,#,$,%,^,&,*,\(,\),\[,\],\{,\},-,_,=,+,\\,|,:,;,",',<,>,?,\,,.,\/]).{4,15}$/;
	return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 8~15자의 영문자와 숫자와 특수문자의 조합만 사용할 수 있습니다.");
}

function isValidUserpw2(el) {
	var pattern = /^(?=.*[a-zA-Z])(?=.*[!@#$%^*+=-])(?=.*[0-9]).{8,15}$/;
	return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 8~15자의 영문자와 숫자와 특수문자의 조합만 사용할 수 있습니다.\n특수문자는 *[!@#$%^*+=-를 포함해야합니다.");
}

function hasHangul(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 isSpecialCharacter(el) {
	var pattern = /[a-zA-Z가-힝0-9]/;
	return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 특수문자를 입력할 수 없습니다.");
}

function isNumeric(el) {
	var pattern = /^[0-9]+$/;
	return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 반드시 숫자로만 입력해야 합니다.");
}

function isFloat(el) {
	var pattern = /^[0-9]+(\.[0-9]{1,4})?$/;
	return (pattern.test(el.value)) ? true : doError(el,"{name+은는} 반드시 정수 또는 소수 넷째 자리까지만 입력해야 합니다.");
}

function isValidJumin(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);

	/* 상위 계산방식에 걸리는 주민등록번호가 있을 경우에 아래와 같이 처리
	var num = value ? value : el.value;
	num = num.replace(/[^0-9]/g,'');
	num = num.substr(0,13);
	if(num.length<13) doError(el, NOT_VALID);
	else {
		num = num.replace(/([0-9]{6})([0-9]{7}$)/,"$1-$2"); 
		el.value = num;
		return true;
	}
	*/
}

function isValidBizNo(el, value) { 
	return true;
	var num = value ? value : el.value;

	// bizID는 숫자만 10자리로 해서 문자열로 넘긴다. 
	var checkID = new Array(1, 3, 7, 1, 3, 7, 1, 3, 5, 1); 
	var tmpBizID, i, chkSum=0, c2, remander; 
	bizID = num.replace(/-/gi,''); 

	for (i=0; i<=7; i++) chkSum += checkID[i] * bizID.charAt(i); 
	c2 = "0" + (checkID[8] * bizID.charAt(8)); 
	c2 = c2.substring(c2.length - 2, c2.length); 
	chkSum += Math.floor(c2.charAt(0)) + Math.floor(c2.charAt(1)); 
	remander = (10 - (chkSum % 10)) % 10 ; 

	return (Math.floor(bizID.charAt(9)) == remander) ? true : doError(el,NOT_VALID);
}

function isValidPhone(el,value) {
	var isKeyNum = false;
	try { isKeyNum = isKeyNumber(undefined, el) } catch(e) {}
	var pattern = isKeyNum ? /^([0-9]{2,4})-?([0-9]{4})-?([0-9]{0,4})$/ : /^([0]{1}[0-9]{1,3})-?([1-9]{1}[0-9]{2,3})-?([0-9]{4})$/;
	var num = value ? value : el.value;
	if (pattern.exec(num)) {
		var phones = new Array("02","031","032","033","041","042","043","051","052","053","054","055","061","062","063","064","070","080","0303","0502","0503","0504","0505","0506"); // ,"060" 제외
		if(isKeyNum || in_array(RegExp.$1, phones, false)) {
			if(el.getAttribute('NOGLUE')!=null) {
				el.value = RegExp.$1 + RegExp.$2 + RegExp.$3;
			} else if(!el.getAttribute('SPAN')) el.value = RegExp.$1 + "-" + RegExp.$2 + "-" + RegExp.$3;
			return true;
		}
	}
	return doError(el,NOT_VALID);
}

function isValidHPhone(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)) {
		var hphones = new Array("011","016","017","018","019","010");
		if(in_array(RegExp.$1, hphones, false)) {
			if(el.getAttribute('NOGLUE')!=null) {
				el.value = RegExp.$1 + RegExp.$2 + RegExp.$3;
			} else if(!el.getAttribute('SPAN')) el.value = RegExp.$1 + "-" + RegExp.$2 + "-" + RegExp.$3;
			return true;
		}
	}
	return doError(el,NOT_VALID);
}

function isValidPhones(el,value) {
	var isKeyNum = false;
	try { isKeyNum = isKeyNumber(undefined, el) } catch(e) {}
	var pattern = isKeyNum ? /^([0-9]{2,4})-?([0-9]{4})-?([0-9]{0,4})$/ : /^([0]{1}[0-9]{1,3})-?([1-9]{1}[0-9]{2,3})-?([0-9]{4})$/;
	var num = value ? value : el.value;
	if (pattern.exec(num)) {
		var phones = new Array("011","016","017","018","019","010","02","031","032","033","041","042","043","051","052","053","054","055","061","062","063","064","070","080","0303","0502","0503","0504","0505","0506"); // ,"060" 제외
		if(isKeyNum || in_array(RegExp.$1, phones, false)) {
			if(!el.getAttribute('SPAN')) el.value = RegExp.$1 + "-" + RegExp.$2 + "-" + RegExp.$3;
			return true;
		}
	}
	return doError(el,NOT_VALID);
}

// 대표/평생번호 체크 - 2008.12.04 추가
function isKeyNumber(event, el) {
	if(el==undefined) el = event!=undefined ? Event.element(event) : event;
	var item = $(el.getAttribute('keynum'));
	var pattern = /^([0-9]{3,4})+$/;
	var num = el.value;
	if (pattern.exec(num)) {
		// 아래 배열에 ○○○○-○○○○ 형태의 전화번호의 국번을 추가할 것
		var phones = new Array("1544","1577","1588","1644","1688");
		if(in_array(RegExp.$1, phones, false)) {
			item.style.display = "none";
			item.getElementsByTagName('input')[0].value = '';
			return true;
		}
	}
	item.style.display = "inline";
	return false;
}

// 대표/평생번호 체크 이벤트 생성 - 2008.12.04 / 2009.01.29 fixed
function setKeyNumber() {
	if(document.setKeyNumber==true) return true;
	var form = $A(document.getElementsByTagName('form'));
	form.each(function(frm) {
		var obj = (typeof(frm.id)=='object') ? frm.parentNode : frm;
		obj.setAttribute('id', '_keynum_form_');
		var tmp_phones = $(obj.id).getElementsBySelector('input[keynum]');
		tmp_phones.each(function(el) {
			Event.observe(el, 'keyup', isKeyNumber);
			isKeyNumber(undefined, el);
		});
		obj.removeAttribute('id');
	});
	document.setKeyNumber = true;
}


try {
	// 대표/평생번호 체크 이벤트 자동생성
	Event.observe(window, 'load', setKeyNumber);
}
catch(e) {
	//alert(e.message);
}
