/**
* Common Scripts
*/


/**
* 입력값이 NULL인지 체크

*/
function isNull(input) {
    if (input.value == null || input.value == "") {
        return true;
    }
    return false;
}

/**
* 입력값에 스페이스 이외의 의미있는 값이 있는지 체크

* ex) if (isEmpty(form.keyword)) {
*         alert("검색조건을 입력하세요.");
*     }
*/
function isEmpty(input) {
    if (input.value == null || input.value.replace(/ /gi,"") == "") {
        return true;
    }
    return false;
}

/**
* 입력값에 특정 문자(chars)가 있는지 체크
* 특정 문자를 허용하지 않으려 할 때 사용
* ex) if (containsChars(form.name,"!,*&^%$#@~;")) {
*         alert("이름 필드에는 특수 문자를 사용할 수 없습니다.");
*     }
*/
function containsChars(input,chars) {
    for (var inx = 0; inx < input.value.length; inx++) {
       if (chars.indexOf(input.value.charAt(inx)) != -1)
           return true;
    }
    return false;
}

/**
* 입력값이 특정 문자(chars)만으로 되어있는지 체크

* 특정 문자만 허용하려 할 때 사용
* ex) if (!containsCharsOnly(form.blood,"ABO")) {
*         alert("혈액형 필드에는 A,B,O 문자만 사용할 수 있습니다.");
*     }
*/
function containsCharsOnly(input,chars) {
    for (var inx = 0; inx < input.value.length; inx++) {
       if (chars.indexOf(input.value.charAt(inx)) == -1)
           return false;
    }
    return true;
}

/**
* 입력값이 알파벳인지 체크

* 아래 isAlphabet() 부터 isNumComma()까지의 메소드가
* 자주 쓰이는 경우에는 var chars 변수를 
* global 변수로 선언하고 사용하도록 한다.
* ex) var uppercase = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
*     var lowercase = "abcdefghijklmnopqrstuvwxyz"; 
*     var number    = "0123456789";
*     function isAlphaNum(input) {
*         var chars = uppercase + lowercase + number;
*         return containsCharsOnly(input,chars);
*     }
*/
function isAlphabet(input) {
    var chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
    return containsCharsOnly(input,chars);
}

/**
* 입력값이 알파벳 대문자인지 체크

*/
function isUpperCase(input) {
    var chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
    return containsCharsOnly(input,chars);
}

/**
* 입력값이 알파벳 소문자인지 체크
*/
function isLowerCase(input) {
    var chars = "abcdefghijklmnopqrstuvwxyz";
    return containsCharsOnly(input,chars);
}

/**
* 입력값에 숫자만 있는지 체크

*/
function isNumber(input) {
    var chars = "0123456789";
    return containsCharsOnly(input,chars);
}

/**
* 입력값이 알파벳,숫자로 되어있는지 체크

*/
function isAlphaNum(input) {
    var chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
    return containsCharsOnly(input,chars);
}

/**
* 입력값이 숫자,대시(-)로 되어있는지 체크
*/
function isNumDash(input) {
    var chars = "-0123456789";
    return containsCharsOnly(input,chars);
}

/**
* 입력값이 숫자,콤마(,)로 되어있는지 체크

*/
function isNumComma(input) {
    var chars = ",0123456789";
    return containsCharsOnly(input,chars);
}

/**
* 입력값이 사용자가 정의한 포맷 형식인지 체크

* 자세한 format 형식은 자바스크립트의 ''regular expression''을 참조
*/
function isValidFormat(input,format) {
    if (input.value.search(format) != -1) {
        return true; // file://올바른 포맷 형식
    }
    return false;
}

/**
* 입력값이 이메일 형식인지 체크
* ex) if (!isValidEmail(form.email)) {
*         alert("올바른 이메일 주소가 아닙니다.");
*     }
*/
function isValidEmail(input) {
//    var format = /^(\S+)@(\S+)\.([A-Za-z]+)$/;
    var format = /^((\w|[\-\.])+)@((\w|[\-\.])+)\.([A-Za-z]+)$/;
    return isValidFormat(input,format);
}

/**
* 입력값이 전화번호 형식(숫자-숫자-숫자)인지 체크
*/
function isValidPhone(input) {
    var format = /^(\d+)-(\d+)-(\d+)$/;
    return isValidFormat(input,format);
}

/**
* 입력값의 바이트 길이를 리턴

* ex) if (getByteLength(form.title) > 100) {
*         alert("제목은 한글 50자(영문 100자) 이상 입력할 수 없습니다.");
*     }
* Author : Wonyoung Lee
*/
function getByteLength(input) {
    var byteLength = 0;
    for (var inx = 0; inx < input.value.length; inx++) {
        var oneChar = escape(input.value.charAt(inx));
        if ( oneChar.length == 1 ) {
            byteLength ++;
        } else if (oneChar.indexOf("%u") != -1) {
            byteLength += 2;
        } else if (oneChar.indexOf("%") != -1) {
            byteLength += oneChar.length/3;
        }
    }
    return byteLength;
}

/**
* 입력값에서 콤마를 없앤다.

*/
function removeComma(input) {
    return input.value.replace(/,/gi,"");
}

/**
* 선택된 라디오버튼이 있는지 체크

*/
function hasCheckedRadio(input) {
    if (input.length > 1) {
        for (var inx = 0; inx < input.length; inx++) {
            if (input[inx].checked) return true;
        }
    } else {
        if (input.checked) return true;
    }
    return false;
}

/**
* 선택된 체크박스가 있는지 체크

*/
function hasCheckedBox(input) {
    return hasCheckedRadio(input);
}




/**
* 툴팁 만들기 Start
*
* *) <ahref='#' {HERE!} >XX</a>
*    <img src="#" {HERE!} >
*
*    {HERE!} =>> onmouseover="showToolTip(this,'text','툴팁내용', 0 , 0)" onmouseout='clearToolTip()'
*/
function showToolTip( obj, tooltip_type , tooltipstr, addX, addY ) {
	showToolTipMake( obj, tooltip_type , tooltipstr, addX, addY, 0 );
}

/**
* 실제 툴팁을 만드는 함수,  마지막 인자로 width를 주면 고정된 사이즈의 툴팁이 만들어진다.
*/
function showToolTipMake( obj, tooltip_type , tooltipstr, addX, addY , width) {
	if( typeof tooltipDiv == "undefined" ) {
		tooltipDiv = document.createElement("div");
		tooltipDiv.id = "aboutjsp_tooltip";
		tooltipDiv.style.position = "absolute";
		tooltipDiv.style.display = "none";
		tooltipDiv.style.zIndex = 1111;
		document.body.appendChild( tooltipDiv );
	}

	if ( tooltip_type == '' ) tooltip_type = "text";
	// 툴팁 디자인 수정하는 부분

	var inStr = "";
	
	var str_width = "";
	if( width > 0 ) {
		str_width = " width='" + width + "' ";
	}
	

	if ( tooltip_type == "text" ) {
		inStr = "<table "+str_width+" cellpadding=0 cellspacing=0><tr><td  bgcolor='#FFFFFF' style='padding: 2px 2px 0 2px ;border:1px solid black;'>";
		inStr += tooltipstr ;
		inStr += "</td></tr></table>";

	}


	var layerX = 0;
	var layerY = 0;

	// 클릭버튼 좌표계산
	var objTmp = obj;

	layerX = objTmp.offsetWidth + addX;
	layerY = addY;
	while (objTmp) {
	    layerX += objTmp.offsetLeft;
	    layerY += objTmp.offsetTop;

	    objTmp = objTmp.offsetParent;
	}
	var ace_tooltip = $("aboutjsp_tooltip");
	ace_tooltip.innerHTML = inStr;
	ace_tooltip.style.zIndex = 1111;
	ace_tooltip.style.left = layerX +"px";
	ace_tooltip.style.top  = layerY + "px";
	ace_tooltip.style.display = "block";
}

/**
* 툴팁 지우기
*/
function clearToolTip(){
	$("aboutjsp_tooltip").style.display = "none";

}
