source: branches/feature-module-update/data/class/pages/admin/system/LC_Page_Admin_System.php @ 15585

Revision 15585, 3.5 KB checked in by adachi, 15 years ago (diff)

クラス化対応

  • Property svn:mime-type set to text/plain
Line 
1<?php
2/*
3 * Copyright(c) 2000-2007 LOCKON CO.,LTD. All Rights Reserved.
4 *
5 * http://www.lockon.co.jp/
6 */
7
8// {{{ requires
9require_once(CLASS_PATH . "pages/LC_Page.php");
10
11/**
12 * システム管理 のページクラス.
13 *
14 * @package Page
15 * @author LOCKON CO.,LTD.
16 * @version $Id:$
17 */
18class LC_Page_Admin_System extends LC_Page {
19
20    // }}}
21    // {{{ functions
22
23    /**
24     * Page を初期化する.
25     *
26     * @return void
27     */
28    function init() {
29        parent::init();
30
31        $this->list_data    = '';  // テーブルデータ取得用
32        $this->tpl_disppage = '';  // 表示中のページ番号
33        $this->tpl_strnavi  = '';
34        $this->tpl_mainpage = 'system/index.tpl';
35        $this->tpl_subnavi  = 'system/subnavi.tpl';
36        $this->tpl_mainno   = 'system';
37        $this->tpl_subno    = 'index';
38        $this->tpl_onload   = 'fnGetRadioChecked();';
39        $this->tpl_subtitle = 'メンバー管理';
40
41        $masterData = new SC_DB_MasterData_Ex();
42        $this->arrAUTHORITY = $masterData->getMasterData('mtb_authority');
43    }
44
45    /**
46     * Page のプロセス.
47     *
48     * @return void
49     */
50    function process() {
51        $objView  = new SC_AdminView();
52        $objSess  = new SC_Session();
53
54        // 認証可否の判定
55        SC_Utils_Ex::sfIsSuccess($objSess);
56
57        // ADMIN_ID以外の管理者件数を取得
58        $linemax = $this->getMemberCount("del_flg <> 1 AND member_id <> " . ADMIN_ID);
59
60        // ADMIN_ID以外で稼動中の管理者件数を取得
61        $this->workmax
62            = $this->getMemberCount("work = 1 AND del_flg <> 1 AND member_id <> " . ADMIN_ID);
63
64        // ページ送りの処理
65        $pageno = isset($_GET['pageno']) ? $_GET['pageno'] : 1;
66        $objNavi = new SC_PageNavi($pageno, $linemax, MEMBER_PMAX, "fnMemberPage", NAVI_PMAX);
67        $this->tpl_strnavi  = $objNavi->strnavi;
68        $this->tpl_disppage = $objNavi->now_page;
69        $this->tpl_pagemax  = $objNavi->max_page;
70
71        // 取得範囲を指定(開始行番号、行数のセット)して管理者データを取得
72        $this->list_data = $this->getMemberData($objNavi->start_row);
73
74        $objView->assignobj($this);
75        $objView->display(MAIN_FRAME);
76    }
77
78    /**
79     * デストラクタ.
80     *
81     * @return void
82     */
83    function destroy() {
84        parent::destroy();
85    }
86
87    /**
88     * dtb_memberからWHERE句に該当する件数を取得する.
89     *
90     * @access private
91     * @param string $where WHERE句
92     * @return integer 件数
93     */
94     function getMemberCount($where) {
95        $objQuery = new SC_Query();
96        $table = 'dtb_member';
97        return $objQuery->count($table, $where);
98     }
99
100    /**
101     * 開始行番号、行数を指定して管理者データを取得する.
102     *
103     * @access private
104     * @param integer $startno 開始行番号
105     * @return array 管理者データの連想配列
106     */
107    function getMemberData($startno) {
108        $objSql = new SC_SelectSql();
109        $objSql->setSelect("SELECT member_id,name,department,login_id,authority,rank,work FROM dtb_member");
110        $objSql->setOrder("rank DESC");
111        $objSql->setWhere("del_flg <> 1 AND member_id <> ". ADMIN_ID);
112        $objSql->setLimitOffset(MEMBER_PMAX, $startno);
113
114        $objQuery = new SC_Query();
115        $arrMemberData = $objQuery->getAll($objSql->getSql());
116
117        return $arrMemberData;
118     }
119}
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143?>
Note: See TracBrowser for help on using the repository browser.