/// ¿¡·¯¸Þ½ÃÁö Æ÷¸ä Á¤ÀÇ ///
var NO_BLANK = "{name+Àº´Â} ÇÊ¼öÇ×¸ñÀÔ´Ï´Ù. ¹Ýµå½Ã ÀÔ·ÂÇÏ½Ê½Ã¿ä.";
var NOT_VALID = "{name+ÀÌ°¡} ¿Ã¹Ù¸£Áö ¾Ê½À´Ï´Ù. ´Ù½Ã ÇÑ ¹ø È®ÀÎÇØ ÁÖ½Ê½Ã¿ä.";
var TOO_LONG = "{name}ÀÇ ±æÀÌ°¡ ÃÊ°úµÇ¾ú½À´Ï´Ù.";

/// ½ºÆ®¸µ °´Ã¼¿¡ ¸Þ¼Òµå Ãß°¡ ///
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 validate(form) {

  for (i = 0; i < form.elements.length; i++ ) {
    var el = form.elements[i];
    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"))) {
        maxbyte = el.getAttribute("MAXBYTE");
        return doError(el,TOO_LONG);
      }
    }

    if (el.getAttribute("OPTION") != null && el.value != "") {
      if (!funcs[el.getAttribute("OPTION")](el)) return false;
    }
  }
  return true;
}

function doError(el,type) {
  var pattern = /{([a-zA-Z0-9_]+)\+?([°¡-ÆR]{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));

  focusType = el.getAttribute("FTYPE");
  if (focusType == null || focusType == "focus")
  {
    el.focus();
  }
  else if (focusType == "select")
  {
    el.select();
  }
  else if (focusType == "delete")
  {
    el.value = "";
  }
  else if (focusType == "none")
  {
  }

  return false;
}

/// Æ¯¼ö ÆÐÅÏ °Ë»ç ÇÔ¼ö ¸ÅÇÎ ///
var funcs = new Array();
funcs['email'] = isValidEmail;
funcs['phone'] = isValidPhone;
funcs['userid'] = isValidUserid;
funcs['hangul'] = hasHangul;
funcs['hangul_name'] = hasHangulName;
funcs['number'] = isNumeric;
funcs['engonly'] = alphaOnly;
funcs['jumin'] = isValidJumin;
funcs['bizno'] = isValidBizNo;
funcs['num_per_page'] = isNumeric;
funcs['page_per_block'] = isNumeric;
funcs['table_width'] = isNumeric;
funcs['new_time'] = isNumeric;
funcs['jumin2'] = isValidJumin2;

/// ÆÐÅÏ °Ë»ç ÇÔ¼öµé ///
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-Z0-9_]{5,10}$/;
  return (pattern.test(el.value)) ? true : doError(el,"{name+Àº´Â} 5ÀÚÀÌ»ó 11ÀÚ ¹Ì¸¸ÀÌ¾î¾ß ÇÏ°í,\n ¿µ¹®,¼ýÀÚ, _ ¹®ÀÚ¸¸ »ç¿ëÇÒ ¼ö ÀÖ½À´Ï´Ù");
}

function hasHangul(el) {
  var pattern = /[°¡-ÆR]/;
  return (pattern.test(el.value)) ? true : doError(el,"{name+Àº´Â} ¹Ýµå½Ã ÇÑ±ÛÀ» Æ÷ÇÔÇØ¾ß ÇÕ´Ï´Ù");
}

function hasHangulName(el) {
  var pattern = /[°¡-ÆR]{2,4}/;
  return (pattern.test(el.value)) ? true : doError(el,"{name+Àº´Â} ¹Ýµå½Ã ÇÑ±ÛÀ» 2ÀÚ ÀÌ»ó Æ÷ÇÔÇØ¾ß ÇÕ´Ï´Ù");
}

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 isValidJumin(el) {
    var pattern = /^([0-9]{6})-?([0-9]{7})$/;
  var num = 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 (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 isValidJumin2(el) {
    var pattern = /^([0-9]{6})-?([0-9]{7})$/;
  var j1 = document.MakeForm.jumin1.value;
  var j2 = document.MakeForm.jumin2.value;
  //var num = el.value;
  var num = j1 + j2;
    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);
  }
}

/***********************************************************************************************************************************/

/***************** sample form ******************************************************************************************************
<script language="javascript" src="inc/raymond.js"></script>
<form name="test" action="script.php" method="post" onSubmit="return validate(this)">
<input type="hidden" name="test" value="" FTYPE="none"> <!-- Æ÷Ä¿½º ÇüÅÂ -->
ÀÌ¸§ : <input type='text' name="username" size='13' hname='ÀÌ¸§'  maxbyte='10' REQUIRED>&nbsp;<br>
email : <input type='text' name="email" size='40' hname='ÀÌ¸ÞÀÏ'  maxbyte='40' option='email' REQUIRED>&nbsp;<br>
ÁÖ¹Î¹øÈ£ : <input type='text' name="jumin" size='13' maxlength='13' hname='ÁÖ¹Î¹øÈ£'  maxbyte='13' option="jumin" REQUIRED>&nbsp;<br>
<input type=image src='images/write.gif' onClick='submit' align=absmiddle>
</FORM>
************************************************************************************************************************************/

function popup(url,name,width,height,scrollbars) {
	var top = (screen.height - height) / 2;
	var left = (screen.width - width) / 2;
	window.open(url,name,"top="+top+"; left="+left+"; width="+width+"; height="+height+"; scrollbars="+scrollbars);
}


// Textarea ±ÛÀÚ¼ö Á¦ÇÑ
function fc_chk_byte(memo,ari_max) 
{ 

var ls_str = memo.value; // ÀÌº¥Æ®°¡ ÀÏ¾î³­ ÄÁÆ®·ÑÀÇ value °ª 
var li_str_len = ls_str.length; // ÀüÃ¼±æÀÌ 

// º¯¼öÃÊ±âÈ­ 
var li_max = ari_max; // Á¦ÇÑÇÒ ±ÛÀÚ¼ö Å©±â 
var i = 0; // for¹®¿¡ »ç¿ë 
var li_byte = 0; // ÇÑ±ÛÀÏ°æ¿ì´Â 2 ±×¹Ü¿¡´Â 1À» ´õÇÔ 
var li_len = 0; // substringÇÏ±â À§ÇØ¼­ »ç¿ë 
var ls_one_char = ""; // ÇÑ±ÛÀÚ¾¿ °Ë»çÇÑ´Ù 
var ls_str2 = ""; // ±ÛÀÚ¼ö¸¦ ÃÊ°úÇÏ¸é Á¦ÇÑÇÒ¼ö ±ÛÀÚÀü±îÁö¸¸ º¸¿©ÁØ´Ù. 

for(i=0; i< li_str_len; i++) 
{ 
// ÇÑ±ÛÀÚÃßÃâ 
ls_one_char = ls_str.charAt(i); 

// ÇÑ±ÛÀÌ¸é 2¸¦ ´õÇÑ´Ù. 
if (escape(ls_one_char).length > 4) 
{ 
li_byte += 2; 
} 
// ±×¹ÜÀÇ °æ¿ì´Â 1À» ´õÇÑ´Ù. 
else 
{ 
li_byte++; 
} 

// ÀüÃ¼ Å©±â°¡ li_max¸¦ ³ÑÁö¾ÊÀ¸¸é 
if(li_byte <= li_max) 
{ 
li_len = i + 1; 
} 
} 

// ÀüÃ¼±æÀÌ¸¦ ÃÊ°úÇÏ¸é 
if(li_byte > li_max) 
{ 
alert(" ±ÛÀÚ " + li_max +" byte¸¦ ÃÊ°ú ÀÔ·ÂÇÒ¼ö ¾ø½À´Ï´Ù. \n ÃÊ°úµÈ ³»¿ëÀº ÀÚµ¿À¸·Î »èÁ¦ µË´Ï´Ù. "); 
ls_str2 = ls_str.substr(0, li_len); 
memo.value = ls_str2; 

} 
memo.focus(); 
} 

function fc_chk2() 
{ 
if(event.keyCode == 13) 
event.returnValue=false; 
} 


//================================================================
// ¹®ÀÚ¿­ ¹ÙÀÌÆ® ¾Ë¾Æ³»±â
//================================================================
function cm_get_byte(str) { //¹®ÀÚ¿­ÀÇ byte ±æÀÌ¸¦ ¾Ë¾Æ³¿(ÇÑ±Û 2byte·Î Ã³¸®)
    var i,m=str.length, re_count=0,val = 0;; 
    for(i=0;i<m;i++) { 
        val = escape(str.charAt(i)).length; 
        if(val>3) re_count++; 
        re_count++; 
    } return re_count; 
} 
function cm_get_byte_length(str,limit_byte){ //ÁöÁ¤µÈ ¹ÙÀÌÆ® ±æÀÌ¸¸Å­ÀÇ length¸¦ ¹ÝÈ¯, È¦¼ö·Î Â©¸®¸é -1ÀÇ ±æÀÌ¹ÝÈ¯
    var i,m=str.length, re_count=0,val = 0;; 
 var len_count = 0;
    for(i=0;re_count<limit_byte ;i++) { 
        val = escape(str.charAt(i)).length; 
  len_count++;
        if(val>3) re_count++; 
        re_count++; 
    } 
 if(re_count%2 == 1)  return (len_count-1); 
 else  return (len_count); 
} 

//================================================================
// ÀÔ·Â ±ÛÀÚ¹ÙÀÌÆ® Á¦ÇÑ (ÇÊ¼ö : ¹®ÀÚ¿­ ¹ÙÀÌÆ® ¾Ë¾Æ³»±â)
//  textarea¿¡ »ç¿ë
//================================================================
function input_textarea_limit_byte(ta,limit){
	var layout = document.createElement('table');
//	layout.border='2';	
	layout.style.padding='0px';
	layout.style.margin='0px';
	if(ta &&ta.style && ta.style.width){
		layout.style.width=ta.style.width
	}
	layout.border="0";
	layout.cellspacing="0";
	layout.cellpadding="0";
	var tr1 = layout.insertRow(-1);
	var td1 = tr1.insertCell(-1);
	td1.style.padding='0px';
	td1.style.textAlign='right';
	var tr2 = layout.insertRow(-1);
	var td2 = tr2.insertCell(-1);
	td2.style.padding='0px';
	td2.style.textAlign='right';	
	
	var txt_limit = document.createElement('input');
	txt_limit.type='text';
	txt_limit.style.borderStyle='none';
	txt_limit.style.textAlign='right';
	txt_limit.style.fontSize='10px';
	txt_limit.style.width='40px';	
	txt_limit.readOnly=true;
	txt_limit.value=0;
	var span_text1 = document.createElement('span');
	span_text1.innerHTML='Limit : ';
	var span_text2 = document.createElement('span');
	if(limit){
		span_text2.innerHTML=' byte /'+limit+' byte';	
	}else{
		span_text2.innerHTML=' byte ';
	}
	var div_title = document.createElement('div');
	div_title.style.fontSize='10px';
	div_title.appendChild(span_text1);
	div_title.appendChild(txt_limit);
	div_title.appendChild(span_text2);
if(ta.tagName.toString().toLowerCase()=='textarea'){	//textareaÀÏ °æ¿ì¸¸

	if(!ta.rows){ta.rows="3";}	
	var btn_0 = document.createElement('input');
	btn_0.type='button';
	btn_0.value='¡á';
	btn_0.style.fontSize="10px";
	btn_0.style.width="18px";
	btn_0.style.height="18px";
	btn_0.style.borderWidth="1px";
	btn_0.onclick=function(){
		this.blur();
		ta.rows='3';
	}
	var btn_p = btn_0.cloneNode(true);
	btn_p.value='¡å';
	btn_p.onclick=function(){
		this.blur();		
		ta.rows=parseInt(ta.rows)+2;
	}
	div_title.appendChild(btn_0);
	div_title.appendChild(btn_p);
	}
	
	ta.parentNode.insertBefore(layout,ta);
	td1.appendChild(div_title);
	td2.appendChild(ta);
	ta.onkeyup=function(){
		txt_limit.value= cm_get_byte(this.value)
		if(limit && txt_limit.value>limit){
			alert('Max Byte = '+limit);
			this.value = this.value.toString().substr(0,cm_get_byte_length(this.value,limit));
			txt_limit.value= cm_get_byte(this.value)
		}
	}

	//Ã³À½ Ã³¸®
		txt_limit.value= cm_get_byte(ta.value)	
	if(limit && txt_limit.value>limit){
		ta.value = ta.value.toString().substr(0,cm_get_byte_length(ta.value,limit));
	}
		txt_limit.value= cm_get_byte(ta.value)	
}

