git-svn-id: http://xe-core.googlecode.com/svn/trunk@193 201d5d3c-b55e-5fd7-737f-ddc643e51545

This commit is contained in:
zero 2007-02-27 10:15:56 +00:00
parent 0a49ee5406
commit 0b38226b7a
14 changed files with 414 additions and 202 deletions

View file

@ -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 = '기본 값';

View file

@ -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) {

View file

@ -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;
}
/**

View file

@ -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');

View file

@ -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>

View file

@ -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"/>

View file

@ -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>

View file

@ -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" />

View file

@ -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>

View file

@ -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>