mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-01-08 03:01:43 +09:00
git-svn-id: http://xe-core.googlecode.com/svn/sandbox@2327 201d5d3c-b55e-5fd7-737f-ddc643e51545
185 lines
8.4 KiB
PHP
185 lines
8.4 KiB
PHP
<?php
|
|
/**
|
|
* @class guestbookAdminView
|
|
* @author zero (zero@nzeo.com)
|
|
* @brief guestbook 모듈의 admin view class
|
|
* 방명록 관리자 기능은 생성된 방명록의 목록, 신규 등록 및 수정, 권한과 스킨의 설정으로 이루어진다.
|
|
**/
|
|
|
|
class guestbookAdminView extends guestbook {
|
|
|
|
/**
|
|
* @brief 초기화
|
|
* 손쉬운 사용을 위해서 module_srl이 넘어올 경우 해당 방명록의 모듈 정보를 미리 구해서 세팅해 놓도록 한다.
|
|
* 각 method에서 하거나 별도의 method를 만들어서 호출하면 되지만 코드의 양을 줄이고 직관성을 높이기 위해서 설정한 코드이다.
|
|
**/
|
|
function init() {
|
|
// module_srl값을 구해온다.
|
|
$module_srl = Context::get('module_srl');
|
|
|
|
// 요청된 module_srl값이 없는데 현재 모듈의 module_srl값이 있다는 것은 방명록의 서비스 부분에서 설정링크를 통해서 바로 설정을 하는 경우이다.
|
|
if(!$module_srl && $this->module_srl) {
|
|
$module_srl = $this->module_srl;
|
|
Context::set('module_srl', $module_srl);
|
|
}
|
|
|
|
// module info를 구하기 위해 module model 객체 생성
|
|
$oModuleModel = &getModel('module');
|
|
|
|
// module_srl이 있다면 요청된 모듈의 정보를 미리 구해 놓음
|
|
if($module_srl) {
|
|
$module_info = $oModuleModel->getModuleInfoByModuleSrl($module_srl);
|
|
if(!$module_info) {
|
|
Context::set('module_srl','');
|
|
$this->act = 'list';
|
|
} else {
|
|
$this->module_info = $module_info;
|
|
Context::set('module_info',$module_info);
|
|
}
|
|
}
|
|
|
|
// 템플릿 경로 지정, 관리자 페이지를 위한 템플릿은 별도의 스킨 기능이 없이 ./modules/모듈/tpl/ 에 위치해 놓기에 바로 지정을 해 놓는다.
|
|
$template_path = sprintf("%stpl/",$this->module_path);
|
|
$this->setTemplatePath($template_path);
|
|
}
|
|
|
|
/**
|
|
* @brief 생성된 방명록들의 목록을 보여줌
|
|
* guestbook이라는 module명으로 등록된 모듈을 구하기 위해서 몇가지 설정을 한 후에 쿼리를 수행한다.
|
|
* 쿼리수행은 executeQuery(모듈명.쿼리아이디, 인자변수) 로 하게 되며 이 쿼리아이디에 해당하는 xml파일은 모듈의 queries디렉토리에 지정이 되어 있다.
|
|
*
|
|
* 이 특정 module의 목록은 module model객체에서 구할 수 있지만 검색등의 각 모듈마다 다른 조건 때문에 각 모듈별로 쿼리를 생성해 놓는다.
|
|
* 모든 모듈의 결과물(mid)는 modules 테이블에 저장이 된다.
|
|
**/
|
|
function dispGuestbookAdminContent() {
|
|
$args->sort_index = "module_srl"; ///< 정렬 순서는 모듈의 sequence값으로 하고 정렬은 역순. 즉 생성된 순으로 한다.
|
|
$args->page = Context::get('page'); ///< 현재 페이지를 설정
|
|
$args->list_count = 40; ///< 한페이지에 40개씩 보여주기로 고정.
|
|
$args->page_count = 10; ///< 페이지의 수는 10개로 제한.
|
|
$args->s_module_category_srl = Context::get('module_category_srl'); ///< 모듈분류값을 인자로 추가
|
|
$output = executeQuery('guestbook.getGuestbookList', $args); ///< guestbook.getGuesbookList 쿼리 실행 (./modules/guestbook/query/getGuestbookList.xml)
|
|
|
|
/**
|
|
* 템플릿에 쓰기 위해서 context::set
|
|
* xml query에 navigation이 있고 list_count가 정의되어 있으면 결과 변수에 아래 5가지의 값이 세팅이 된다.
|
|
**/
|
|
Context::set('total_count', $output->total_count);
|
|
Context::set('total_page', $output->total_page);
|
|
Context::set('page', $output->page);
|
|
Context::set('guestbook_list', $output->data);
|
|
Context::set('page_navigation', $output->page_navigation);
|
|
|
|
// 템플릿 파일 지정 (./modules/guestbook/tpl/index.html파일이 지정이 됨)
|
|
$this->setTemplateFile('index');
|
|
}
|
|
|
|
/**
|
|
* @brief 선택된 방명록의 정보 출력
|
|
**/
|
|
function dispGuestbookAdminGuestbookInfo() {
|
|
// module_srl 값이 없다면 그냥 index 페이지를 보여줌
|
|
if(!Context::get('module_srl')) return $this->dispGuestbookAdminContent();
|
|
|
|
// 레이아웃이 정해져 있다면 레이아웃 정보를 추가해줌(layout_title, layout)
|
|
if($this->module_info->layout_srl) {
|
|
$oLayoutModel = &getModel('layout');
|
|
$layout_info = $oLayoutModel->getLayout($this->module_info->layout_srl);
|
|
$this->module_info->layout = $layout_info->layout;
|
|
$this->module_info->layout_title = $layout_info->layout_title;
|
|
}
|
|
|
|
// 정해진 스킨이 있으면 해당 스킨의 정보를 구함
|
|
if($this->module_info->skin) {
|
|
$oModuleModel = &getModel('module');
|
|
$skin_info = $oModuleModel->loadSkinInfo($this->module_path, $this->module_info->skin);
|
|
$this->module_info->skin_title = $skin_info->title;
|
|
}
|
|
|
|
// 템플릿 파일 지정
|
|
$this->setTemplateFile('guestbook_info');
|
|
}
|
|
|
|
/**
|
|
* @brief 방명록 설정 폼 출력
|
|
**/
|
|
function dispGuestbookAdminInsertGuestbook() {
|
|
// 스킨 목록을 구해옴
|
|
$oModuleModel = &getModel('module');
|
|
$skin_list = $oModuleModel->getSkins($this->module_path);
|
|
Context::set('skin_list',$skin_list);
|
|
|
|
// 레이아웃 목록을 구해옴
|
|
$oLayoutMode = &getModel('layout');
|
|
$layout_list = $oLayoutMode->getLayoutList();
|
|
Context::set('layout_list', $layout_list);
|
|
|
|
// 템플릿 파일 지정
|
|
$this->setTemplateFile('guestbook_insert');
|
|
}
|
|
|
|
/**
|
|
* @brief 방명록 삭제 화면 출력
|
|
**/
|
|
function dispGuestbookAdminDeleteGuestbook() {
|
|
if(!Context::get('module_srl')) return $this->dispGuestbookAdminContent();
|
|
|
|
$module_info = Context::get('module_info');
|
|
|
|
// 해당 방명록에 입력된 전체 글의 갯수를 보여줌 (혹시 삭제 실수를 방지하기 위해서)
|
|
$oDocumentModel = &getModel('document');
|
|
$document_count = $oDocumentModel->getDocumentCount($module_info->module_srl);
|
|
$module_info->document_count = $document_count;
|
|
|
|
Context::set('module_info',$module_info);
|
|
|
|
// 템플릿 파일 지정
|
|
$this->setTemplateFile('guestbook_delete');
|
|
}
|
|
|
|
/**
|
|
* @brief 스킨 정보 보여줌
|
|
**/
|
|
function dispGuestbookAdminSkinInfo() {
|
|
|
|
// 현재 선택된 모듈의 스킨의 정보 xml 파일을 읽음
|
|
$module_info = Context::get('module_info');
|
|
$skin = $module_info->skin;
|
|
|
|
$oModuleModel = &getModel('module');
|
|
$skin_info = $oModuleModel->loadSkinInfo($this->module_path, $skin);
|
|
|
|
// skin_info에 extra_vars 값을 지정
|
|
if(count($skin_info->extra_vars)) {
|
|
foreach($skin_info->extra_vars as $key => $val) {
|
|
$name = $val->name;
|
|
$type = $val->type;
|
|
$value = $module_info->{$name};
|
|
if($type=="checkbox"&&!$value) $value = array();
|
|
$skin_info->extra_vars[$key]->value= $value;
|
|
}
|
|
}
|
|
|
|
Context::set('skin_info', $skin_info);
|
|
$this->setTemplateFile('skin_info');
|
|
}
|
|
|
|
/**
|
|
* @brief 권한 목록 출력
|
|
**/
|
|
function dispGuestbookAdminGrantInfo() {
|
|
// module_srl을 구함
|
|
$module_srl = Context::get('module_srl');
|
|
|
|
// module.xml에서 권한 관련 목록을 구해옴
|
|
$grant_list = $this->xml_info->grant;
|
|
Context::set('grant_list', $grant_list);
|
|
|
|
// 권한 그룹의 목록을 가져온다
|
|
$oMemberModel = &getModel('member');
|
|
$group_list = $oMemberModel->getGroups();
|
|
Context::set('group_list', $group_list);
|
|
|
|
$this->setTemplateFile('grant_list');
|
|
}
|
|
}
|
|
?>
|