웹마스터 팁

지난 번에 이어서 사용자 정의 변수 중에 전화번호를 국내에 한정 짓거나,

시간입력을 jQuery 의 timepicker 를 쓰지 않고 입력할 수 있게끔 아예 정의에 넣어버려서

타잎을 결정할 때에 시간입력을 선택하는 방법을 알아보겠습니다.


이렇게 하면 사용자 정의를 활용해서


사용자 정의를 활용하여 폼 형식으로 개발하는 무식한 방법(2)


사용자 변수를 입맛대로 형태 만들고 쑤셔 넣기



일단 가장 쉽게 전화번호부터 접근해보겠습니다.


능력이 되시는 분들은 jQuery 와 혼용해서 쓰면 가장 좋구요 ^^;


자 일단,


(XE설치경로)/classes/extravar/Extravar.class.php를 열어줍니다.

이제부터 설명하는 모든 문서는 저장시에 UTF-8 로 저장해야 합니다.

처음에 열면 ANSI 로 되어 있을 건데요, 한글 다 깨집니다 -_-;


찾아보면,


// Phone Number
case 'tel' :
 $buff[] = '<input type="text" name="' . $column_name . '[]" value="' . $value[0] . '" size="4" maxlength="4" class="tel" />';
 $buff[] = '<input type="text" name="' . $column_name . '[]" value="' . $value[1] . '" size="4" maxlength="4" class="tel" />';
 $buff[] = '<input type="text" name="' . $column_name . '[]" value="' . $value[2] . '" size="4" maxlength="4" class="tel" />';
break;


이렇게 나온 부분이 있을 것입니다.

이해하기 쉬운 코드인데요, $buff[] 가 3개 있는 이유는 전화번호를 구별코드(지방/핸드폰/인터넷폰) 으로 해주고,

뒤에 2개는 국번과 번호입니다.


여기서 잠시 생각할 것은 어딘가 입력 필드의 갯수를 바꾸는 경우 또 손을 대어야 하는 구나 하는 정도입니다.


맨 첫줄을 다음처럼 바꿔줍니다.


//$buff[] = '<input type="text" name="' . $column_name . '[]" value="' . $value[0] . '" size="4" maxlength="4" class="tel" />'; //이 부분을 주석 처리


일단 주석으로 처리한 후에 (지워도 무방하지만, 언제나 원본 소스를 보존하는 게 낫겠죠)



$buff[] = '<select name="' . $column_name . '[]" class="select"><option value="">선택</option><option value="010">010</option><option value="011">011</option><option value="016">016</option><option value="017">017</option><option value="018">018</option><option value="019">019</option><option value="02">02</option><option value="031">031</option><option value="032">032</option><option value="033">033</option><option value="041">041</option><option value="042">042</option><option value="043">043</option><option value="051">051</option><option value="052">052</option><option value="053">053</option><option value="054">054</option><option value="055">055</option><option value="061">061</option><option value="062">062</option><option value="064">064</option><option value="070">070</option></select>';


이렇게 바꿔주는 거죠.


보면 사실 별 것 아닙니다.

' 와 " 만 잘 구별해서 사용하면 되고 구별번호를 아예 선택하게 바꿔준 것이죠.

더 있을 지도 모르겠지만; 일단 그냥 찾아본 그대로 넣었습니다.


마찬가지로 정규표현식 등을 도입해서 숫자를 3개이상 4개이하로 국번을 지정도 가능하구요,

번호는 무조건 숫자 네자리를 입력하게 해줄 수도 있습니다.


맨 처음의 

<option value="">선택</option> 


부분에서 value="" 이렇게 해주는 이유가 있습니다.

보통 value="선택" 이렇게 해줄 수도 있는데, 이러면 필수 입력 코드에 "선택" 이라는 값이 들어가 버리기 때문에,

항상 입력되어 있는 것으로 오해를 하고 넘어가죠. 그래서 그냥 "" 를 밸류로 해준 것입니다.

선택을 해야만 값이 입력되는 거죠.


XE 에서 사용자 정의 형식은 말이 이메일, 전화번호이지 아무거나 때려 박기만 하면 넘어갑니다.

jQuery 로 날짜처럼 그냥 나오던가 하는 것도 없죠.

(실상 날짜도 그냥 아무렇게나 타자로 때려박을 수도 있습니다)

그래서 앞에서 정말 대충 짰구나 하는 것이고, 코딩을 하시는 분들이나, 디자인을 통해 홈피를 만들어 주시는 그런 분들은

XE 를 쓰면 안된다는 생각을 했습니다.

너무 대충 만들어진 코드를 넣는 것 같잖아요.





아무튼, 이번에는 시간입력 부분을 타잎으로 설정해보겠습니다.


먼저, 형식 리스트에 시간입력을 선택가능하게 해야하죠.


그러려니까 language 를 설정해두는 xml 파일에 먼저 쑤셔넣어야 하겠죠.


(XE설치경로)/common/lang/lang.xml 를 열어줍니다.



<item name="column_type_list" type="array">

부분을 찾아줍니다.


거기에 보면,


<item name="date">

<value xml:lang="ko"><![CDATA[일자(연월일)]]></value>

<value xml:lang="en"><![CDATA[date(yyyy/mm/dd)]]></value>

<value xml:lang="jp"><![CDATA[日付(年月日)]]></value>

<value xml:lang="zh-CN"><![CDATA[日期(年月日)]]></value>

<value xml:lang="zh-TW"><![CDATA[日期(年月日)]]></value>

<value xml:lang="fr"><![CDATA[Jour(yyyy/mm/dd)]]></value>

<value xml:lang="de"><![CDATA[Datum(dd / mm /jjjj)]]></value>

<value xml:lang="ru"><![CDATA[Дата(гггг / мм / дд)]]></value>

<value xml:lang="es"><![CDATA[fecha(dd/mm/aaaa)]]></value>

<value xml:lang="tr"><![CDATA[tarih(gg/aa/yyyy)]]></value>

<value xml:lang="vi"><![CDATA[Ngày(yyyy/mm/dd)]]></value>

<value xml:lang="mn"><![CDATA[Онсар (Жил сар өдөр)]]></value>

</item>



이런 식으로 되어 있는 부분이 날짜 형식입니다.

그 밑에 비슷하게 형식을 만드는 거죠.

ko 만 정의해도 별 문제는 없지만, 어찌되었든 모든 언어에 대응하게 만들려면 다 넣어야죠.

문제는 제가 외국어를 저렇게나 많이 알지는 못한다는 거 ㅠㅠ


시간인데 time 이나 datetime 은 XE 에서 쓰니까 (물론 형식 지원은 제대로 안합니다만)

아무튼 시간 입력 부분이니까 what_time 을 쓰기로 합니다.



<item name="what_time">

<value xml:lang="ko"><![CDATA[시간(00시00분)]]></value>

<value xml:lang="en"><![CDATA[time(hh/mm)]]></value>

<value xml:lang="jp"><![CDATA[時刻(時分)]]></value>

<value xml:lang="zh-CN"><![CDATA[时间(時分)]]></value>

<value xml:lang="zh-TW"><![CDATA[时间(時分)]]></value>

<value xml:lang="fr"><![CDATA[Heure(hh/mm)]]></value>

<value xml:lang="de"><![CDATA[Zeit(hh / mm)]]></value>

<value xml:lang="ru"><![CDATA[время(гггг / мм / дд)]]></value>

<value xml:lang="es"><![CDATA[hora(hh/mm)]]></value>

<value xml:lang="tr"><![CDATA[zaman(hh/mm)]]></value>

<value xml:lang="vi"><![CDATA[thời(hh/mm)]]></value>

<value xml:lang="mn"><![CDATA[цаг (hh / mm)]]></value>

</item>



이제 이렇게 시간(00시00분) 을 추가하는 거죠.

절대적으로 외국어는 스스로 점검하세요. 대충 넣은 거라서;;;


음, 갑자기 생각을 바꿨습니다.

24시간보다는 오전 오후로 하는 게 낫겠네요.

왜냐면 -_-; 셀렉하게 만들까 하는데 01~24 보다는 01~12 가 짧습니다;;;


일단 이렇게 해준 후에,


(XE설치경로)/classes/extravar/Extravar.class.php를 다시 열어줍니다.


//case 'date' :

//case 'email_address' :

//case 'text' :

//case 'textarea' :

default :

return htmlspecialchars($value, ENT_COMPAT | ENT_HTML401, 'UTF-8', false);

}

}



이 부분을 찾아갑니다.

그래서 이 부분 위에 다음 코드를 추가하죠.




case 'what_time' : //WEDIF Reminisce 사용자 변수 종류 추가

if(is_array($value))

{

$values = $value;

}

elseif(strpos($value, '|@|') !== FALSE)

{

$values = explode('|@|', $value);

}

elseif(strpos($value, ',') !== FALSE)

{

$values = explode(',', $value);

}


return $values;


//case 'date' :

//case 'email_address' :

//case 'text' :

//case 'textarea' :

default :

return htmlspecialchars($value, ENT_COMPAT | ENT_HTML401, 'UTF-8', false);

}

}



그럼 이렇게 될 건데요,


위 코드를 추가하지 않고 억지로 앞에서처럼 형식만 만들어서 buff[1], buff[2], buff[3] ... 이렇게 넣어주면,

게시글에서 표시형태를 결정해줄 수가 없습니다.

필드간 구별을 


|@| 로 하게 되거든요.


즉, 08시 15분 이라고 나오게 하려 했는데,

08|@|15 이런 식으로 나오게 되는 거죠.



이제 표시형태를 지정하러 갑니다.



function getValueHTML()

{

$value = $this->_getTypeValue($this->type, $this->value);


switch($this->type)

{

case 'homepage' :

return ($value) ? (sprintf('<a href="%s" target="_blank">%s</a>', $value, strlen($value) > 60 ? substr($value, 0, 40) . '...' . substr($value, -10) : $value)) : "";


case 'email_address' :

return ($value) ? sprintf('<a href="mailto:%s">%s</a>', $value, $value) : "";


case 'tel' :

return sprintf('%s - %s - %s', $value[0], $value[1], $value[2]);

case 'textarea' :

return nl2br($value);

case 'date' :

return zdate($value, "Y-m-d");



이 부분을 찾아서,


case 'what_time' : //WEDIF Reminisce 사용자변수종류

return sprintf('%s  %s 시 %s 분', $value[0], $value[1], $value[2]);


여기에 case 'what_time' 을 추가해줍니다.


%s 뒤에 쓰고 싶은데로 쓰시면 되어요.


오전/오후, 시, 분 형식으로 넣을 거라서 저렇게 해줬습니다만, 2개 만들고 싶은 분은 2개 만들고,

3개 만들고 싶은 분은 3개 만드시면 됩니다.

하나 더 추가해서 나라입력까지 받으면 국제 시간도 얼마든 가능하겠죠.

약속시간 정하는 거니까 ^^;


뭐 처리 형태나, 형식지정도 다 해줬는데 문제는 정작 입력을 받아야 하는 곳을 손대지 않았습니다.



// date

case 'date' :

// datepicker javascript plugin load

Context::loadJavascriptPlugin('ui.datepicker');


$buff[] = '<input type="hidden" name="' . $column_name . '" value="' . $value . '" />'; 

$buff[] = '<input type="text" id="date_' . $column_name . '" value="' . zdate($value, 'Y-m-d') . '" class="date" />';

$buff[] = '<input type="button" value="' . Context::getLang('cmd_delete') . '" class="btn" id="dateRemover_' . $column_name . '" />';

$buff[] = '<script type="text/javascript">';

$buff[] = '//<![CDATA[';

$buff[] = '(function($){';

$buff[] = '$(function(){';

$buff[] = '  var option = { dateFormat: "yy-mm-dd", changeMonth:true, changeYear:true, gotoCurrent:false, yearRange:\'-0:+2\', onSelect:function(){';

$buff[] = '    $(this).prev(\'input[type="hidden"]\').val(this.value.replace(/-/g,""))}';

$buff[] = '  };';

$buff[] = '  $.extend(option,$.datepicker.regional[\'' . Context::getLangType() . '\']);';

$buff[] = '  $("#date_' . $column_name . '").datepicker(option);';

$buff[] = '  $("#dateRemover_' . $column_name . '").click(function(){';

$buff[] = '    $(this).siblings("input").val("");';

$buff[] = '    return false;';

$buff[] = '  })';

$buff[] = '});';

$buff[] = '})(jQuery);';

$buff[] = '//]]>';

$buff[] = '</script>';

break;



위 부분을 찾아갑니다.


case 'date' 를 검색해보면 좀 여러개 뜨는데 많지는 않으니까 검색해서,

실제로 입력을 받는 이 부분을 가시면 됩니다.

switch 구문만 봐도 그냥 마구 아무데나 껴 있고 코드 최적화는 안되어 있습니다.

저도 귀찮아서 그건 고치기 싫구요 -_-;

능력되면 줄여서 고치시고 코어 수정을 해서 github 에 공유를;;;



자 이 부분 아래에...


// what_time

case 'what_time' :

$buff[] = '<select name="' . $column_name . '[]" value="' . $value[0] . '" class="select"><option value="">오전/오후</option><option value="오전">오전</option><option value="오후">오후</option></select>';

$buff[] = '<select name="' . $column_name . '[]" value="' . $value[1] . '" class="select"><option value="">시간</option><option value="01">01</option><option value="02">02</option><option value="03">03</option><option value="04">04</option><option value="05">05</option><option value="06">06</option><option value="07">07</option><option value="08">08</option><option value="09">09</option><option value="10">10</option><option value="11">11</option><option value="12">12</option></select>';

$buff[] = '<select name="' . $column_name . '[]" value="' . $value[2] . '" class="select"><option value="">분</option><option value="00">00</option><option value="10">10</option><option value="20">20</option><option value="30">30</option><option value="40">40</option><option value="50">50</option></select>';

break;



이것을 넣어줍니다.


말씀드린 것처럼 위에 date 입력 부분처럼 jQuery 의 timepicker 를 쓰면 여러가지로 좋지만,

그런 거에 머리쓰기 싫은 분들은 그냥 저렇게 해주면 됩니다.


그리고 제 경우는 10분 간격으로 지정을 했는데, 5분 간격이든, 15분 간격이든 그건 설마 응용 가능하겠죠 -_-;

1분 간격? 하시려면 하셔도 됩니다. 60개만 하면 되는데요 뭘.

그리고 60개를 하는데 성공하면 -_-; 초도 넣을 수 있습니다~ 복사 한 번 더 해주는 센스가;;;


아무튼 이렇게 해주면 이제 제대로 사용가능한 거죠.



호응이 있으면;; (위디프를 선전해주시면 됩니다. 제가 웹쪽은 안 건들다가 웹쪽에 뛰어 들어서 ㅎㅎㅎ)


A 값을 선택 시에 B 값이 나오고, 체크 박스를 하나만 선택 가능하게 하거나...

약관 동의를 간단히 사용자 변수로 만드는 방법 등을 함께 해보죠.


고수분들에겐 전혀 쓸모 없는 예제이겠지만,

XE 초보분들에겐 여러가지 응용을 시작해보실 수 있는 가장 간단한 예제일 겁니다.


그럼 저는 일하러;;;



태그 연관 글
  1. [2017/06/17] 묻고답하기 contentextended 사용자정의 출력 시, select type 은 array 이로 나옵니다. by 리치김
  2. [2016/08/10] 묻고답하기 사용자정의(확장변수)에 입력하는 설명에 태그를 적용할 수 없을까요? by Xing *1
  3. [2016/07/22] 묻고답하기 덧글단 회원에게만 확장변수 공개 질문 입니다. by 크루미 *2
  4. [2016/04/02] 묻고답하기 게시판 사용자정의 이미지 첨부 by 김선희 *1
  5. [2016/03/25] 묻고답하기 확장변수로 새로운 카테고리(분류)를 만들고 싶습니다 by 진주빛쎄미
제목 글쓴이 날짜
홈페이지 제작 시, 개인정보관련/회원가입약관 처리에 대해서 [1] 양파F 2014.08.23
관리자 게시판 목록에서 브라우저 제목 클릭시 새창으로 뜨도록 수정 [2] sejin7940 2014.08.26
관리자페이지의 '서버정보출력'에 '절대경로' 가 출력되게 하는 방법 [3] sejin7940 2014.08.26
XE 알림센터 Lite 사용시에 쪽지나 호출에 대해서만 알림음을 적용하기 [17] SeungXE 2014.07.06
사용자 정의를 활용하여 폼 형식으로 개발하는 무식한 방법(2) [5] Reminisce 2014.08.22
사용자 정의를 활용하여 폼 형식으로 개발하는 무식한 방법(1) [6] Reminisce 2014.08.22
CafeXE (homepage 모듈) 메뉴노출 권한오류 수정안. Xiso 2014.08.22
사이트 디자인 설정에서 레이아웃 저장이 안될시 고치는 방법 [1] LoteM대한천자 2014.07.28
스케치북 게시판 메뉴얼 [1] socialskyo 2014.08.21
jquery 이미지 이펙트 플러그인 Ansi™ 2014.08.19
게시판의 관리자가 최고관리자의 글을 지울 수 없도록 하기 [1] file BJ람보 2014.08.18
이거 어디다 올려야 될 지 몰라 여기다 올립니다. 프로그래머님들 읽어보세요. [2] 유샤인 2014.06.10
외부 페이지 작업시 페이징 작업 함수 Happyphp 2014.08.12
관리자설정-> 관리자 메뉴설정 에서 삭제가 안 되는 현상 수정하는 방법 [1] sejin7940 2014.08.11
F12개발자도구를 열었을때 IE버젼이 낮게 나온다면 pezex 2014.08.11
글읽기 권한 없을때 회원가입창으로 유도하는 방법 (XE1.5수정) [10] sejin7940 2011.08.23
룰셋을 폼 필터처럼 Ajax로 사용하기 Lansi 2014.08.08
xe module, sample 생성기 [9] 천재ㅐ재 2014.07.24
네이버 SMTP로 인증메일 보내기 [12] Neder 2013.08.26
첨부파일 제한 등을 1M 이하인 K 단위로 제한할 수 있게 설정 [1] sejin7940 2014.08.07