mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-01-07 02:31:40 +09:00
git-svn-id: http://xe-core.googlecode.com/svn/trunk@193 201d5d3c-b55e-5fd7-737f-ddc643e51545
This commit is contained in:
parent
0a49ee5406
commit
0b38226b7a
14 changed files with 414 additions and 202 deletions
|
|
@ -88,12 +88,29 @@
|
|||
|
||||
// extend_filter가 있을 경우 해당 method를 호출하여 결과를 받음
|
||||
if($extend_filter) {
|
||||
|
||||
// extend_filter는 module.method 로 지칭되어 이를 분리
|
||||
list($module_name, $method) = explode('.',$extend_filter);
|
||||
|
||||
// 모듈 이름과 method가 있을 경우 진행
|
||||
if($module_name&&$method) {
|
||||
// 해당 module의 model 객체를 받음
|
||||
$oExtendFilter = &getModel($module_name);
|
||||
|
||||
// method가 존재하면 실행
|
||||
if(method_exists($oExtendFilter, $method)) {
|
||||
$extend_filter_obj = call_user_method($method, $oExtendFilter, true);
|
||||
// 결과를 받음
|
||||
$extend_filter_list = call_user_method($method, $oExtendFilter, true);
|
||||
$extend_filter_count = count($extend_filter_list);
|
||||
|
||||
// 결과에서 lang값을 이용 문서 변수에 적용
|
||||
for($i=0;$i<$extend_filter_count;$i++) {
|
||||
$name = $extend_filter_list[$i]->name;
|
||||
$lang_value = $extend_filter_list[$i]->lang;
|
||||
if($lang_value) $lang->{$name} = $lang_value;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -102,6 +119,7 @@
|
|||
|
||||
// 언어 입력을 위한 사용되는 필드 조사
|
||||
$target_list = array();
|
||||
$target_type_list = array();
|
||||
|
||||
// js function 을 만들기 시작
|
||||
$js_doc = sprintf("function %s(fo_obj) {\n", $filter_name);
|
||||
|
|
@ -126,21 +144,69 @@
|
|||
);
|
||||
|
||||
if(!in_array($target, $target_list)) $target_list[] = $target;
|
||||
if(!$target_type_list[$target]) $target_type_list[$target] = $filter;
|
||||
}
|
||||
}
|
||||
|
||||
// extend_filter_item 체크
|
||||
for($i=0;$i<$extend_filter_count;$i++) {
|
||||
$filter_item = $extend_filter_list[$i];
|
||||
$target = trim($filter_item->name);
|
||||
if(!$target) continue;
|
||||
$type = $filter_item->type;
|
||||
$required = $filter_item->required?'true':'false';
|
||||
|
||||
// extend filter item의 type으로 filter를 구함
|
||||
switch($type) {
|
||||
case 'homepage' :
|
||||
$filter = 'homepage';
|
||||
break;
|
||||
case 'email_address' :
|
||||
$filter = 'email';
|
||||
break;
|
||||
default :
|
||||
$filter = '';
|
||||
break;
|
||||
}
|
||||
|
||||
$js_doc .= sprintf(
|
||||
"\toFilter.addFieldItem(\"%s\",%s,%s,%s,\"%s\",\"%s\");\n",
|
||||
$target, $required, 0, 0, '', $filter
|
||||
);
|
||||
|
||||
if(!in_array($target, $target_list)) $target_list[] = $target;
|
||||
if(!$target_type_list[$target]) $target_type_list[$target] = $type;
|
||||
|
||||
}
|
||||
|
||||
// 데이터를 만들기 위한 parameter script 생성
|
||||
$parameter_count = count($parameter_param);
|
||||
if($parameter_count) {
|
||||
// 기본 필터 내용의 parameter로 구성
|
||||
foreach($parameter_param as $key =>$param) {
|
||||
$attrs = $param->attrs;
|
||||
$name = trim($attrs->name);
|
||||
$target = trim($attrs->target);
|
||||
if(!$name || !$target) continue;
|
||||
$target = htmlentities($target,ENT_QUOTES);
|
||||
|
||||
$js_doc .= sprintf(
|
||||
"\toFilter.addParameterItem(\"%s\",\"%s\");\n",
|
||||
$name, $target
|
||||
"\toFilter.addParameterItem(\"%s\",\"%s\");\n",
|
||||
$name, $target
|
||||
);
|
||||
if(!in_array($name, $target_list)) $target_list[] = $name;
|
||||
}
|
||||
|
||||
// extend_filter_item 체크
|
||||
for($i=0;$i<$extend_filter_count;$i++) {
|
||||
$filter_item = $extend_filter_list[$i];
|
||||
$target = $name = trim($filter_item->name);
|
||||
if(!$name || !$target) continue;
|
||||
$target = htmlentities($target,ENT_QUOTES);
|
||||
|
||||
$js_doc .= sprintf(
|
||||
"\toFilter.addParameterItem(\"%s\",\"%s\");\n",
|
||||
$name, $target
|
||||
);
|
||||
if(!in_array($name, $target_list)) $target_list[] = $name;
|
||||
}
|
||||
|
|
@ -159,14 +225,24 @@
|
|||
$js_doc .= "}\n";
|
||||
|
||||
// form 필드 lang 값을 기록
|
||||
$target_cnt = count($target_list);
|
||||
for($i=0;$i<$target_cnt;$i++) {
|
||||
$target_count = count($target_list);
|
||||
for($i=0;$i<$target_count;$i++) {
|
||||
$target = $target_list[$i];
|
||||
$js_doc .= sprintf("alertMsg[\"%s\"] = \"%s\"\n", $target, str_replace("\"","\\\"",$lang->{$target}));
|
||||
if(!$lang->{$target}) $lang->{$target} = $target;
|
||||
$js_doc .= sprintf("alertMsg[\"%s\"] = \"%s\";\n", $target, str_replace("\"","\\\"",$lang->{$target}));
|
||||
}
|
||||
|
||||
// target type을 기록
|
||||
$target_type_count = count($target_type_list);
|
||||
if($target_type_count) {
|
||||
foreach($target_type_list as $target => $type) {
|
||||
$js_doc .= sprintf("target_type_list[\"%s\"] = \"%s\";\n", $target, $type);
|
||||
}
|
||||
}
|
||||
|
||||
// 에러 메세지를 기록
|
||||
foreach($lang->filter as $key => $val) {
|
||||
if(!$val) $val = $key;
|
||||
$js_doc .= sprintf("alertMsg[\"%s\"] = \"%s\";\n", $key, str_replace("\"","\\\"",$val));
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -5,6 +5,7 @@
|
|||
**/
|
||||
|
||||
var alertMsg = new Array();
|
||||
var target_type_list = new Array();
|
||||
|
||||
/**
|
||||
* @function filterAlertMessage
|
||||
|
|
@ -26,7 +27,6 @@ function filterAlertMessage(ret_obj) {
|
|||
* @brief form elements, module/act, callback_user_func을 이용하여 서버에 ajax로 form 데이터를 넘기고 결과를 받아오는 js class
|
||||
**/
|
||||
function XmlJsFilter(form_object, module, act, callback_user_func) {
|
||||
|
||||
this.field = new Array();
|
||||
this.parameter = new Array();
|
||||
this.response = new Array();
|
||||
|
|
@ -36,6 +36,7 @@ function XmlJsFilter(form_object, module, act, callback_user_func) {
|
|||
this.act = act;
|
||||
this.user_func = callback_user_func;
|
||||
|
||||
this.setFocus = XmlJsFilterSetFocus;
|
||||
this.addFieldItem = XmlJsFilterAddFieldItem;
|
||||
this.addParameterItem = XmlJsFilterAddParameterItem;
|
||||
this.addResponseItem = XmlJsFilterAddResponseItem;
|
||||
|
|
@ -47,6 +48,21 @@ function XmlJsFilter(form_object, module, act, callback_user_func) {
|
|||
this.proc = XmlJsFilterProc;
|
||||
}
|
||||
|
||||
function XmlJsFilterSetFocus(target_name) {
|
||||
var obj = this.fo_obj[target_name];
|
||||
if(typeof(obj)=='undefined' || !obj) return;
|
||||
|
||||
var length = obj.length;
|
||||
try {
|
||||
if(typeof(length)!='undefined') {
|
||||
obj[0].focus();
|
||||
} else {
|
||||
obj.focus();
|
||||
}
|
||||
} catch(e) {
|
||||
}
|
||||
}
|
||||
|
||||
function XmlJsFilterAddFieldItem(target, required, minlength, maxlength, equalto, filter) {
|
||||
var obj = new Array(target, required, minlength, maxlength, equalto, filter);
|
||||
this.field[this.field.length] = obj;
|
||||
|
|
@ -63,84 +79,97 @@ function XmlJsFilterAddResponseItem(name) {
|
|||
|
||||
function XmlJsFilterGetValue(target_name) {
|
||||
var obj = this.fo_obj[target_name];
|
||||
if(typeof(obj)=='undefined') return '';
|
||||
if(typeof(obj)=='undefined' || !obj) return '';
|
||||
var value = '';
|
||||
var length = obj.length;
|
||||
var type = obj.type;
|
||||
|
||||
if(length) type = obj[0].type;
|
||||
if((typeof(type)=='undefined'||!type) && typeof(length)!='undefined' && typeof(obj[0])!='undefined' && length>0) type = obj[0].type;
|
||||
else length = 0;
|
||||
|
||||
switch(type) {
|
||||
case 'checkbox' :
|
||||
if(typeof(length)!='undefined') {
|
||||
value_list = new Array();
|
||||
for(var i=0;i<obj.length;i++) {
|
||||
if(obj[i].checked) value_list[value_list.length] = obj[i].value;
|
||||
}
|
||||
value = value_list.join(",");
|
||||
} else {
|
||||
if(obj.checked) value = obj.value;
|
||||
else value = '';
|
||||
}
|
||||
break;
|
||||
case 'radio' :
|
||||
if(typeof(length)!='undefined') {
|
||||
for(var i=0;i<obj.length;i++) {
|
||||
if(obj[i].checked) value = obj[i].value;
|
||||
}
|
||||
} else {
|
||||
if(obj.checked) value = obj.value;
|
||||
else value = '';
|
||||
}
|
||||
break;
|
||||
case 'select' :
|
||||
case 'select-one' :
|
||||
if(obj.options.length>0) {
|
||||
value = obj.options[obj.selectedIndex].value;
|
||||
}
|
||||
break;
|
||||
default :
|
||||
value = obj.value;
|
||||
break;
|
||||
case 'checkbox' :
|
||||
if(length>0) {
|
||||
value_list = new Array();
|
||||
for(var i=0;i<length;i++) {
|
||||
if(obj[i].checked) value_list[value_list.length] = obj[i].value;
|
||||
}
|
||||
value = value_list.join('|@|');
|
||||
} else {
|
||||
if(obj.checked) value = obj.value;
|
||||
else value = '';
|
||||
}
|
||||
break;
|
||||
case 'radio' :
|
||||
if(length>0) {
|
||||
for(var i=0;i<length;i++) {
|
||||
if(obj[i].checked) value = obj[i].value;
|
||||
}
|
||||
} else {
|
||||
if(obj.checked) value = obj.value;
|
||||
else value = '';
|
||||
}
|
||||
break;
|
||||
case 'select' :
|
||||
case 'select-one' :
|
||||
if(obj.selectedIndex>=0) value = obj.options[obj.selectedIndex].value;
|
||||
break;
|
||||
default :
|
||||
if(length>0 && target_type_list[target_name]) {
|
||||
switch(target_type_list[target_name]) {
|
||||
case 'tel' :
|
||||
var val1 = obj[0].value;
|
||||
var val2 = obj[1].value;
|
||||
var val3 = obj[2].value;
|
||||
if(val1&&val2&&val3) {
|
||||
value = val1+'|@|'+val2+'|@|'+val3;
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
} else {
|
||||
value = obj.value;
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
if(typeof(value)=='undefined'||!value) return '';
|
||||
return value.trim();
|
||||
}
|
||||
|
||||
function XmlJsFilterExecuteFilter(filter, value) {
|
||||
switch(filter) {
|
||||
case "email" :
|
||||
case "email_address" :
|
||||
var regx = /^[_0-9a-zA-Z-]+(\.[_0-9a-zA-Z-]+)*@[0-9a-zA-Z-]+(\.[0-9a-zA-Z-]+)*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "userid" :
|
||||
case "user_id" :
|
||||
var regx = /^[a-zA-Z]+([_0-9a-zA-Z]+)*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "homepage" :
|
||||
var regx = /(^[_0-9a-zA-Z-]+(\.[_0-9a-zA-Z-]+)*@[0-9a-zA-Z-]+(\.[0-9a-zA-Z-]+)*$)/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "korean" :
|
||||
var regx = /^[가-힣]*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "korean_number" :
|
||||
var regx = /^[가-힣0-9]*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "alpha" :
|
||||
var regx = /^[a-zA-Z]*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "alpha_number" :
|
||||
var regx = /^[a-zA-Z0-9]*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "number" :
|
||||
return !isNaN(value);
|
||||
case "email" :
|
||||
case "email_address" :
|
||||
var regx = /^[_0-9a-zA-Z-]+(\.[_0-9a-zA-Z-]+)*@[0-9a-zA-Z-]+(\.[0-9a-zA-Z-]+)*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "userid" :
|
||||
case "user_id" :
|
||||
var regx = /^[a-zA-Z]+([_0-9a-zA-Z]+)*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "homepage" :
|
||||
var regx = /^(http|https|ftp|mms):\/\/[0-9a-z-]+(\.[_0-9a-z-\/\~]+)+(:[0-9]{2,4})*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "korean" :
|
||||
var regx = /^[가-힣]*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "korean_number" :
|
||||
var regx = /^[가-힣0-9]*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "alpha" :
|
||||
var regx = /^[a-zA-Z]*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "alpha_number" :
|
||||
var regx = /^[a-zA-Z0-9]*$/;
|
||||
return regx.test(value);
|
||||
break;
|
||||
case "number" :
|
||||
return !isNaN(value);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
@ -153,49 +182,47 @@ function XmlJsFilterAlertMsg(target, msg_code, minlength, maxlength) {
|
|||
|
||||
var msg = "";
|
||||
if(typeof(alertMsg[msg_code])!='undefined') {
|
||||
if(alertMsg[msg_code].indexOf('%s')>=0) msg = alertMsg[msg_code].replace('%s',target_msg);
|
||||
else msg = target_msg+alertMsg[msg_code];
|
||||
if(alertMsg[msg_code].indexOf('%s')>=0) msg = alertMsg[msg_code].replace('%s',target_msg);
|
||||
else msg = target_msg+alertMsg[msg_code];
|
||||
} else {
|
||||
msg = msg_code;
|
||||
msg = msg_code;
|
||||
}
|
||||
|
||||
if(typeof(minlength)!='undefined' && typeof(maxlength)!='undefined') msg += "("+minlength+"~"+maxlength+")";
|
||||
|
||||
alert(msg);
|
||||
try {
|
||||
this.fo_obj[target].focus();
|
||||
} catch(e) {
|
||||
}
|
||||
this.setFocus(target);
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
function XmlJsFilterCheckFieldItem() {
|
||||
for(var i=0; i<this.field.length;i++) {
|
||||
var item = this.field[i];
|
||||
var target = item[0];
|
||||
var required = item[1];
|
||||
var minlength = item[2];
|
||||
var maxlength = item[3];
|
||||
var equalto = item[4];
|
||||
var filter = item[5].split(",");
|
||||
var item = this.field[i];
|
||||
var target = item[0];
|
||||
var required = item[1];
|
||||
var minlength = item[2];
|
||||
var maxlength = item[3];
|
||||
var equalto = item[4];
|
||||
var filter = item[5].split(",");
|
||||
|
||||
var value = this.getValue(target);
|
||||
if(!required && !value) return true;
|
||||
if(required && !value) return this.alertMsg(target,'isnull');
|
||||
var value = this.getValue(target);
|
||||
if(!required && !value) return true;
|
||||
if(required && !value) return this.alertMsg(target,'isnull');
|
||||
|
||||
if(minlength>0 && maxlength>0 && (value.length < minlength || value.length > maxlength)) return this.alertMsg(target, 'outofrange', minlength, maxlength);
|
||||
if(minlength>0 && maxlength>0 && (value.length < minlength || value.length > maxlength)) return this.alertMsg(target, 'outofrange', minlength, maxlength);
|
||||
|
||||
if(equalto) {
|
||||
var equalto_value = this.getValue(equalto);
|
||||
if(equalto_value != value) return this.alertMsg(target, 'equalto');
|
||||
}
|
||||
|
||||
if(filter.length && filter[0]) {
|
||||
for(var j=0;j<filter.length;j++) {
|
||||
var filter_item = filter[j];
|
||||
if(!this.executeFilter(filter_item, value)) return this.alertMsg(target, "invalid_"+filter_item);
|
||||
if(equalto) {
|
||||
var equalto_value = this.getValue(equalto);
|
||||
if(equalto_value != value) return this.alertMsg(target, 'equalto');
|
||||
}
|
||||
|
||||
if(filter.length && filter[0]) {
|
||||
for(var j=0;j<filter.length;j++) {
|
||||
var filter_item = filter[j];
|
||||
if(!this.executeFilter(filter_item, value)) return this.alertMsg(target, "invalid_"+filter_item);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
|
@ -203,21 +230,21 @@ function XmlJsFilterCheckFieldItem() {
|
|||
function XmlJsFilterGetParameterParam() {
|
||||
var prev_name = '';
|
||||
if(this.parameter.length<1) {
|
||||
for(var i=0;i<this.fo_obj.length;i++) {
|
||||
var name = this.fo_obj[i].name;
|
||||
if(typeof(name)=='undefined'||!name||name==prev_name) continue;
|
||||
this.addParameterItem(name, name);
|
||||
prev_name = name;
|
||||
}
|
||||
for(var i=0;i<this.fo_obj.length;i++) {
|
||||
var name = this.fo_obj[i].name;
|
||||
if(typeof(name)=='undefined'||!name||name==prev_name) continue;
|
||||
this.addParameterItem(name, name);
|
||||
prev_name = name;
|
||||
}
|
||||
}
|
||||
|
||||
var params = new Array();
|
||||
for(var i=0; i<this.parameter.length;i++) {
|
||||
var item = this.parameter[i];
|
||||
var param = item[0];
|
||||
var target = item[1];
|
||||
var value = this.getValue(target);
|
||||
params[param] = value;
|
||||
var item = this.parameter[i];
|
||||
var param = item[0];
|
||||
var target = item[1];
|
||||
var value = this.getValue(target);
|
||||
params[param] = value;
|
||||
}
|
||||
return params;
|
||||
}
|
||||
|
|
@ -232,10 +259,9 @@ function XmlJsFilterProc(confirm_msg) {
|
|||
var response = this.response;
|
||||
if(confirm_msg && !confirm(confirm_msg)) return false;
|
||||
if(!this.act) {
|
||||
this.user_func(this.fo_obj, params);
|
||||
return true;
|
||||
this.user_func(this.fo_obj, params);
|
||||
return true;
|
||||
}
|
||||
|
||||
exec_xml(this.module, this.act, params, this.user_func, response, params);
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -18,7 +18,7 @@
|
|||
/**
|
||||
* @brief debug mode = true 일때 files/_debug_message.php 에 디버그 내용이 쌓임
|
||||
**/
|
||||
define('__DEBUG__', true);
|
||||
define('__DEBUG__', false);
|
||||
if(__DEBUG__) {
|
||||
|
||||
// php5이상이면 error handling을 handleError() 로 set
|
||||
|
|
|
|||
|
|
@ -131,16 +131,25 @@
|
|||
* @return object
|
||||
**/
|
||||
function delObjectVars($target_obj, $del_obj) {
|
||||
if(count(get_object_vars($target_obj))<1) return;
|
||||
if(count(get_object_vars($del_obj))<1) clone($target_obj);
|
||||
if(!is_object($target_obj)) return;
|
||||
if(!is_object($del_obj)) return;
|
||||
|
||||
if(is_object($target_var)) $var = clone($target_var);
|
||||
$target_vars = get_object_vars($target_obj);
|
||||
$del_vars = get_object_vars($del_obj);
|
||||
|
||||
foreach($del_obj as $key => $val) {
|
||||
unset($var->{$var_name});
|
||||
$target = array_keys($target_vars);
|
||||
$del = array_keys($del_vars);
|
||||
if(!count($target)||!count($del)) return $target_obj;
|
||||
|
||||
$return_obj = NULL;
|
||||
|
||||
$target_count = count($target);
|
||||
for($i=0;$i<$target_count;$i++) {
|
||||
$target_key = $target[$i];
|
||||
if(!in_array($target_key, $del)) $return_obj->{$target_key} = $target_obj->{$target_key};
|
||||
}
|
||||
|
||||
return $var;
|
||||
return $return_obj;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
|||
|
|
@ -36,7 +36,7 @@
|
|||
$lang->column_type_list['checkbox'] = '다중 선택 (checkbox)';
|
||||
$lang->column_type_list['select'] = '단일 선택 (select)';
|
||||
$lang->column_type_list['kr_zip'] = '한국주소 (zip)';
|
||||
$lang->column_type_list['jp_zip'] = '일본주소 (zip)';
|
||||
//$lang->column_type_list['jp_zip'] = '일본주소 (zip)';
|
||||
$lang->column_name = '입력항목 이름';
|
||||
$lang->column_title = '입력항목 제목';
|
||||
$lang->default_value = '기본 값';
|
||||
|
|
|
|||
|
|
@ -71,6 +71,14 @@
|
|||
function procInsert() {
|
||||
// 일단 입력된 값들을 모두 받아서 db 입력항목과 그외 것으로 분리
|
||||
$args = Context::gets('member_srl','user_id','user_name','nick_name','email_address','password','allow_mailing','denied','is_admin','signature','profile_image','image_nick','image_mark','description','group_srl_list');
|
||||
$all_args = Context::getRequestVars();
|
||||
unset($all_args->page);
|
||||
unset($all_args->module);
|
||||
unset($all_args->act);
|
||||
|
||||
// 모든 request argument에서 필수 정보만 제외 한 후 추가 데이터로 입력
|
||||
$extra_vars = delObjectVars($all_args, $args);
|
||||
$args->extra_vars = serialize($extra_vars);
|
||||
|
||||
// member_srl이 넘어오면 원 회원이 있는지 확인
|
||||
if($args->member_srl) {
|
||||
|
|
|
|||
|
|
@ -7,6 +7,13 @@
|
|||
|
||||
class memberModel extends member {
|
||||
|
||||
/**
|
||||
* @brief 자주 호출될거라 예상되는 데이터는 내부적으로 가지고 있자...
|
||||
**/
|
||||
var $member_info = NULL;
|
||||
var $member_groups = NULL;
|
||||
var $join_form_list = NULL;
|
||||
|
||||
/**
|
||||
* @brief 초기화
|
||||
**/
|
||||
|
|
@ -37,34 +44,54 @@
|
|||
* @brief user_id에 해당하는 사용자 정보 return
|
||||
**/
|
||||
function getMemberInfoByUserID($user_id) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
if(!$this->member_info[$member_srl]) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
|
||||
$args->user_id = $user_id;
|
||||
$output = $oDB->executeQuery('member.getMemberInfo', $args);
|
||||
if(!$output) return $output;
|
||||
$args->user_id = $user_id;
|
||||
$output = $oDB->executeQuery('member.getMemberInfo', $args);
|
||||
if(!$output) return $output;
|
||||
|
||||
$member_info = $output->data;
|
||||
$member_info->group_list = $this->getMemberGroups($member_info->member_srl);
|
||||
$member_info = $this->arrangeMemberInfo($output->data);
|
||||
$member_info->group_list = $this->getMemberGroups($member_info->member_srl);
|
||||
|
||||
return $member_info;
|
||||
$this->member_info[$$member_info->member_srl] = $member_info;
|
||||
}
|
||||
return $this->member_info[$member_srl];
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief member_srl로 사용자 정보 return
|
||||
**/
|
||||
function getMemberInfoByMemberSrl($member_srl) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
if(!$this->member_info[$member_srl]) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
|
||||
$args->member_srl = $member_srl;
|
||||
$output = $oDB->executeQuery('member.getMemberInfoByMemberSrl', $args);
|
||||
if(!$output) return $output;
|
||||
$args->member_srl = $member_srl;
|
||||
$output = $oDB->executeQuery('member.getMemberInfoByMemberSrl', $args);
|
||||
if(!$output) return $output;
|
||||
|
||||
$member_info = $output->data;
|
||||
$member_info->group_list = $this->getMemberGroups($member_info->member_srl);
|
||||
$member_info = $this->arrangeMemberInfo($output->data);
|
||||
$member_info->group_list = $this->getMemberGroups($member_info->member_srl);
|
||||
|
||||
return $member_info;
|
||||
$this->member_info[$member_srl] = $member_info;
|
||||
}
|
||||
return $this->member_info[$member_srl];
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief 사용자 정보 중 extra_vars를 알맞게 편집
|
||||
**/
|
||||
function arrangeMemberInfo($info) {
|
||||
$extra_vars = unserialize($info->extra_vars);
|
||||
unset($info->extra_vars);
|
||||
if(!$extra_vars) return $info;
|
||||
foreach($extra_vars as $key => $val) {
|
||||
if(eregi('\|\@\|', $val)) $val = explode('|@|', $val);
|
||||
if(!$info->{$key}) $info->{$key} = $val;
|
||||
}
|
||||
return $info;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -138,20 +165,23 @@
|
|||
* @brief member_srl이 속한 group 목록을 가져옴
|
||||
**/
|
||||
function getMemberGroups($member_srl) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
if(!$this->member_groups[$member_srl]) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
|
||||
$args->member_srl = $member_srl;
|
||||
$output = $oDB->executeQuery('member.getMemberGroups', $args);
|
||||
if(!$output->data) return;
|
||||
$args->member_srl = $member_srl;
|
||||
$output = $oDB->executeQuery('member.getMemberGroups', $args);
|
||||
if(!$output->data) return;
|
||||
|
||||
$group_list = $output->data;
|
||||
if(!is_array($group_list)) $group_list = array($group_list);
|
||||
$group_list = $output->data;
|
||||
if(!is_array($group_list)) $group_list = array($group_list);
|
||||
|
||||
foreach($group_list as $group) {
|
||||
$result[$group->group_srl] = $group->title;
|
||||
foreach($group_list as $group) {
|
||||
$result[$group->group_srl] = $group->title;
|
||||
}
|
||||
$this->member_groups[$member_srl] = $result;
|
||||
}
|
||||
return $result;
|
||||
return $this->member_groups[$member_srl];
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -204,42 +234,64 @@
|
|||
* 이 인자값이 true일 경우 filter 타입에 맞는 형태의 object로 결과를 return하여야 한다.
|
||||
**/
|
||||
function getJoinFormList($filter_response = false) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
global $lang;
|
||||
|
||||
// list_order 컬럼의 정렬을 위한 인자 세팅
|
||||
$args->sort_index = "list_order";
|
||||
$output = $oDB->executeQuery('member.getJoinFormList', $args);
|
||||
if(!$this->join_form_list) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
|
||||
// 결과 데이터가 없으면 NULL return
|
||||
$join_form_list = $output->data;
|
||||
if(!$join_form_list) return NULL;
|
||||
// list_order 컬럼의 정렬을 위한 인자 세팅
|
||||
$args->sort_index = "list_order";
|
||||
$output = $oDB->executeQuery('member.getJoinFormList', $args);
|
||||
|
||||
// default_value의 경우 DB에 array가 serialize되어 입력되므로 unserialize가 필요
|
||||
if(!is_array($join_form_list)) $join_form_list = array($join_form_list);
|
||||
$join_form_count = count($join_form_list);
|
||||
for($i=0;$i<$join_form_count;$i++) {
|
||||
$member_join_form_srl = $join_form_list[$i]->member_join_form_srl;
|
||||
$column_type = $join_form_list[$i]->column_type;
|
||||
$default_value = $join_form_list[$i]->default_value;
|
||||
// 결과 데이터가 없으면 NULL return
|
||||
$join_form_list = $output->data;
|
||||
if(!$join_form_list) return NULL;
|
||||
|
||||
if(in_array($column_type, array('checkbox','select'))) {
|
||||
$join_form_list[$i]->default_value = unserialize($default_value);
|
||||
if(!$join_form_list[$i]->default_value[0]) $join_form_list[$i]->default_value = '';
|
||||
} else {
|
||||
$join_form_list[$i]->default_value = '';
|
||||
// default_value의 경우 DB에 array가 serialize되어 입력되므로 unserialize가 필요
|
||||
if(!is_array($join_form_list)) $join_form_list = array($join_form_list);
|
||||
$join_form_count = count($join_form_list);
|
||||
for($i=0;$i<$join_form_count;$i++) {
|
||||
$member_join_form_srl = $join_form_list[$i]->member_join_form_srl;
|
||||
$column_type = $join_form_list[$i]->column_type;
|
||||
$column_name = $join_form_list[$i]->column_name;
|
||||
$column_title = $join_form_list[$i]->column_title;
|
||||
$default_value = $join_form_list[$i]->default_value;
|
||||
|
||||
// 언어변수에 추가
|
||||
$lang->extend_vars[$column_name] = $column_title;
|
||||
|
||||
// checkbox, select등 다수 데이터 형식일 경우 unserialize해줌
|
||||
if(in_array($column_type, array('checkbox','select'))) {
|
||||
$join_form_list[$i]->default_value = unserialize($default_value);
|
||||
if(!$join_form_list[$i]->default_value[0]) $join_form_list[$i]->default_value = '';
|
||||
} else {
|
||||
$join_form_list[$i]->default_value = '';
|
||||
}
|
||||
|
||||
$list[$member_join_form_srl] = $join_form_list[$i];
|
||||
}
|
||||
|
||||
$list[$member_join_form_srl] = $join_form_list[$i];
|
||||
$this->join_form_list = $list;
|
||||
}
|
||||
|
||||
// filter_response가 true일 경우 object 스타일을 구함
|
||||
if($filter_response) {
|
||||
if($filter_response && count($this->join_form_list)) {
|
||||
|
||||
foreach($this->join_form_list as $key => $val) {
|
||||
if($val->is_active != 'Y') continue;
|
||||
unset($obj);
|
||||
$obj->type = $val->column_type;
|
||||
$obj->name = $val->column_name;
|
||||
$obj->lang = $val->column_title;
|
||||
$obj->required = $val->required=='Y'?true:false;
|
||||
$filter_output[] = $obj;
|
||||
}
|
||||
return $filter_output;
|
||||
|
||||
}
|
||||
|
||||
|
||||
// 결과 리턴
|
||||
return $list;
|
||||
return $this->join_form_list;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -269,16 +321,19 @@
|
|||
* @brief 금지 아이디 목록 가져오기
|
||||
**/
|
||||
function getDeniedIDList() {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
if(!$this->denied_id_list) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
|
||||
$args->sort_index = "list_order";
|
||||
$args->page = Context::get('page');
|
||||
$args->list_count = 40;
|
||||
$args->page_count = 10;
|
||||
$args->sort_index = "list_order";
|
||||
$args->page = Context::get('page');
|
||||
$args->list_count = 40;
|
||||
$args->page_count = 10;
|
||||
|
||||
$output = $oDB->executeQuery('member.getDeniedIDList', $args);
|
||||
return $output;
|
||||
$output = $oDB->executeQuery('member.getDeniedIDList', $args);
|
||||
$this->denied_id_list = $output;
|
||||
}
|
||||
return $this->denied_id_list;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
|||
|
|
@ -21,9 +21,9 @@
|
|||
// member_srl이 있으면 미리 체크하여 member_info 세팅
|
||||
$member_srl = Context::get('member_srl');
|
||||
if($member_srl) {
|
||||
$member_info = $oMemberModel->getMemberInfoByMemberSrl($member_srl);
|
||||
if(!$member_info) Context::set('member_srl','');
|
||||
else Context::set('member_info',$member_info);
|
||||
$this->member_info = $oMemberModel->getMemberInfoByMemberSrl($member_srl);
|
||||
if(!$this->member_info) Context::set('member_srl','');
|
||||
else Context::set('member_info',$this->member_info);
|
||||
}
|
||||
|
||||
// group 목록 가져오기
|
||||
|
|
@ -60,6 +60,17 @@
|
|||
* @brief 회원 정보 출력
|
||||
**/
|
||||
function dispMemberInfo() {
|
||||
// 추가 가입폼 목록을 받음
|
||||
$oMemberModel = &getModel('member');
|
||||
$extend_form_list = $oMemberModel->getJoinFormlist();
|
||||
if($extend_form_list) {
|
||||
foreach($extend_form_list as $srl => $item) {
|
||||
$column_name = $item->column_name;
|
||||
$value = $this->member_info->{$column_name};
|
||||
$extend_form_list[$srl]->value = $this->member_info->{$column_name};
|
||||
}
|
||||
Context::set('extend_form_list', $extend_form_list);
|
||||
}
|
||||
$this->setTemplateFile('member_info');
|
||||
}
|
||||
|
||||
|
|
@ -70,7 +81,14 @@
|
|||
// 추가 가입폼 목록을 받음
|
||||
$oMemberModel = &getModel('member');
|
||||
$extend_form_list = $oMemberModel->getJoinFormlist();
|
||||
if($extend_form_list) Context::set('extend_form_list', $extend_form_list);
|
||||
if($extend_form_list) {
|
||||
foreach($extend_form_list as $srl => $item) {
|
||||
$column_name = $item->column_name;
|
||||
$value = $this->member_info->{$column_name};
|
||||
$extend_form_list[$srl]->value = $this->member_info->{$column_name};
|
||||
}
|
||||
Context::set('extend_form_list', $extend_form_list);
|
||||
}
|
||||
|
||||
// 템플릿 파일 지정
|
||||
$this->setTemplateFile('insert_member');
|
||||
|
|
|
|||
|
|
@ -22,5 +22,6 @@
|
|||
<column name="last_login" var="last_login" />
|
||||
<column name="is_admin" var="is_admin" default="N" />
|
||||
<column name="description" var="description" />
|
||||
<column name="extra_vars" var="extra_vars" />
|
||||
</columns>
|
||||
</query>
|
||||
|
|
|
|||
|
|
@ -17,6 +17,7 @@
|
|||
<column name="denied" var="denied" default="N" />
|
||||
<column name="is_admin" var="is_admin" default="N" />
|
||||
<column name="description" var="description" />
|
||||
<column name="extra_vars" var="extra_vars" />
|
||||
</columns>
|
||||
<conditions>
|
||||
<condition operation="equal" column="member_srl" var="member_srl" notnull="notnull" filter="number"/>
|
||||
|
|
|
|||
|
|
@ -17,8 +17,6 @@
|
|||
<column name="regdate" type="date" />
|
||||
<column name="last_login" type="date" />
|
||||
<column name="is_admin" type="char" size="1" default="N" />
|
||||
<column name="level" type="number" size="11" default="1" />
|
||||
<column name="exp" type="number" size="11" default="0" />
|
||||
<column name="description" type="text" />
|
||||
<column name="extra_vars" type="text" />
|
||||
</table>
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
<filter name="insert" module="member" act="procInsert" extend_filter="member.getJoinFormList">
|
||||
<filter name="insert" module="member" act="procInsert" extend_filter="member.getJoinFormList" confirm_msg_code="confirm_submit">
|
||||
<form>
|
||||
<node target="user_id" required="true" minlength="3" maxlength="20" filter="userid" />
|
||||
<node target="user_name" required="true" minlength="2" maxlength="20" />
|
||||
|
|
|
|||
|
|
@ -114,42 +114,42 @@
|
|||
<!--@if($val->is_active=='Y')-->
|
||||
<tr>
|
||||
<th rowspan="2">
|
||||
<!--@if($val->required)-->
|
||||
<!--@if($val->required=='Y')-->
|
||||
*
|
||||
<!--@end-->
|
||||
{$val->column_title}
|
||||
</th>
|
||||
<td>
|
||||
<!--@if($val->column_type == 'text')-->
|
||||
<input type="text" name="{$val->column_name}" value="" />
|
||||
<input type="text" name="{$val->column_name}" value="{$val->value}" />
|
||||
<!--@elseif($val->column_type == 'homepage')-->
|
||||
http://<input type="text" name="{$val->column_name}" value="" />
|
||||
<input type="text" name="{$val->column_name}" value="{$val->value}" />
|
||||
<!--@elseif($val->column_type == 'email_address')-->
|
||||
<input type="text" name="{$val->column_name}_id" value="" />@<input type="text" name="{$val->column_name}_host" value="" />
|
||||
<input type="text" name="{$val->column_name}" value="{$val->value}" />
|
||||
<!--@elseif($val->column_type == 'tel')-->
|
||||
<input type="text" name="{$val->column_name}[0]" value="" size="4" />-
|
||||
<input type="text" name="{$val->column_name}[1]" value="" size="4" />-
|
||||
<input type="text" name="{$val->column_name}[2]" value="" size="4" />
|
||||
<input type="text" name="{$val->column_name}" value="{$val->value[0]}" size="4" />-
|
||||
<input type="text" name="{$val->column_name}" value="{$val->value[1]}" size="4" />-
|
||||
<input type="text" name="{$val->column_name}" value="{$val->value[2]}" size="4" />
|
||||
<!--@elseif($val->column_type == 'textarea')-->
|
||||
<textarea name="{$val->column_name}"></textarea>
|
||||
<textarea name="{$val->column_name}">{$val->value}</textarea>
|
||||
<!--@elseif($val->column_type == 'checkbox')-->
|
||||
<!--@if($val->default_value)-->
|
||||
<!--@foreach($val->default_value as $v)-->
|
||||
<input type="checkbox" value="{$v}" /> {$v}
|
||||
<input type="checkbox" name="{$val->column_name}" value="{$v}" <!--@if(is_array($val->value)&&in_array($v, $val->value))-->checked="true"<!--@end-->/> {$v}
|
||||
<!--@end-->
|
||||
<!--@end-->
|
||||
<!--@elseif($val->column_type == 'select')-->
|
||||
<select name="{$val->column_name}">
|
||||
<!--@if($val->default_value)-->
|
||||
<!--@foreach($val->default_value as $v)-->
|
||||
<option value="{$v}">{$v}</option>
|
||||
<option value="{$v}" <!--@if($v == $val->value)-->selected="true"<!--@end-->>{$v}</option>
|
||||
<!--@end-->
|
||||
<!--@end-->
|
||||
</select>
|
||||
<!--@elseif($val->column_type == 'kr_zip')-->
|
||||
<input type="text" name="{$val->column_name}" value="" />
|
||||
<input type="text" name="{$val->column_name}" value="{$val->value}" />
|
||||
<!--@elseif($val->column_type == 'jp_zip')-->
|
||||
<input type="text" name="{$val->column_name}" value="" />
|
||||
<input type="text" name="{$val->column_name}" value="{$val->value}" />
|
||||
<!--@end-->
|
||||
|
||||
</td>
|
||||
|
|
@ -165,7 +165,11 @@
|
|||
<table border="1">
|
||||
<tr>
|
||||
<td colspan="2">
|
||||
<input type="button" value="{$lang->cmd_cancel}" onclick="location.href='{getUrl('act','','member_srl','')}';return false;" />
|
||||
<!--@if($member_srl)-->
|
||||
<input type="button" value="{$lang->cmd_cancel}" onclick="location.href='{getUrl('act','dispMemberInfo')}';return false;" />
|
||||
<!--@else-->
|
||||
<input type="button" value="{$lang->cmd_cancel}" onclick="location.href='{getUrl('act','dispMemberList')}';return false;" />
|
||||
<!--@end-->
|
||||
<input type="submit" value="{$lang->cmd_registration}" accesskey="s" />
|
||||
</td>
|
||||
</tr>
|
||||
|
|
|
|||
|
|
@ -37,6 +37,22 @@
|
|||
<!--@end-->
|
||||
</td>
|
||||
</tr>
|
||||
<!--@if($extend_form_list)-->
|
||||
<!--@foreach($extend_form_list as $key => $val)-->
|
||||
<tr>
|
||||
<th>{$val->column_title}</th>
|
||||
<td>
|
||||
<!--@if($val->column_type=='tel')-->
|
||||
{implode("-",$val->value)}
|
||||
<!--@elseif($val->column_type=='checkbox')-->
|
||||
{implode(",",$val->value)}
|
||||
<!--@else-->
|
||||
{$val->value}
|
||||
<!--@end-->
|
||||
</td>
|
||||
</tr>
|
||||
<!--@end-->
|
||||
<!--@end-->
|
||||
<tr>
|
||||
<th>{$lang->description}</th>
|
||||
<td>{$member_info->description}</td>
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue