source: branches/version-2_11-dev/data/class/pages/admin/products/LC_Page_Admin_Products_Maker.php @ 21185

Revision 21185, 9.1 KB checked in by shutta, 13 years ago (diff)

refs #800 (SQL標準関数を使用する)
CURRENT_TIMESTAMP を使用するように now() を置換。

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-httpd-php; charset=UTF-8
Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2011 LOCKON CO.,LTD. All Rights Reserved.
6 *
7 * http://www.lockon.co.jp/
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22 */
23
24// {{{ requires
25require_once CLASS_EX_REALDIR . 'page_extends/admin/LC_Page_Admin_Ex.php';
26
27/**
28 * メーカー登録 のページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id$
33 */
34class LC_Page_Admin_Products_Maker extends LC_Page_Admin_Ex {
35
36    // }}}
37    // {{{ functions
38
39    /**
40     * Page を初期化する.
41     *
42     * @return void
43     */
44    function init() {
45        parent::init();
46        $this->tpl_mainpage = 'products/maker.tpl';
47        $this->tpl_subno = 'maker';
48        $this->tpl_maintitle = '商品管理';
49        $this->tpl_subtitle = 'メーカー登録';
50        $this->tpl_mainno = 'products';
51    }
52
53    /**
54     * Page のプロセス.
55     *
56     * @return void
57     */
58    function process() {
59        $this->action();
60        $this->sendResponse();
61    }
62
63    /**
64     * Page のアクション.
65     *
66     * @return void
67     */
68    function action() {
69        $objFormParam = new SC_FormParam_Ex();
70
71        // パラメーター情報の初期化
72        $this->lfInitParam($objFormParam);
73
74        // POST値をセット
75        $objFormParam->setParam($_POST);
76
77        // POST値の入力文字変換
78        $objFormParam->convParam();
79
80        //maker_idを変数にセット
81        $maker_id = $objFormParam->getValue('maker_id');
82
83        // 変換後のPOST値を取得
84        $this->arrForm  = $objFormParam->getHashArray();
85
86        // モードによる処理切り替え
87        switch($this->getMode()) {
88
89        // 編集処理
90        case 'edit':
91        // 入力文字の変換
92
93            // エラーチェック
94            $this->arrErr = $this->lfErrorCheck($this->arrForm);
95            if(count($this->arrErr) <= 0) {
96                if($this->arrForm['maker_id'] == "") {
97                    // メーカー情報新規登録
98                    $this->lfInsert($this->arrForm);
99                } else {
100                    // メーカー情報編集
101                    $this->lfUpdate($this->arrForm);
102                }
103                // 再表示
104                $this->objDisplay->reload();
105            } else {
106                // POSTデータを引き継ぐ
107                $this->tpl_maker_id = $this->arrForm['maker_id'];
108            }
109            break;
110
111        // 編集前処理
112        case 'pre_edit':
113            $this->arrForm = $this->lfPreEdit($this->arrForm, $this->arrForm['maker_id']);
114            $this->tpl_maker_id = $this->arrForm['maker_id'];
115            break;
116
117        // メーカー順変更
118        case 'up':
119        case 'down':
120            $this->lfRankChange($this->arrForm['maker_id'], $this->getMode());
121            // リロード
122            SC_Response_Ex::reload();
123            break;
124
125        // 削除
126        case 'delete':
127            $this->lfDelete($this->arrForm['maker_id']);
128            // リロード
129            SC_Response_Ex::reload();
130            break;
131
132        default:
133            break;
134        }
135
136        // メーカー情報読み込み
137        $this->arrMaker = $this->lfDisp();
138        // POSTデータを引き継ぐ
139        $this->tpl_maker_id = $maker_id;
140
141    }
142
143    /**
144     * デストラクタ.
145     *
146     * @return void
147     */
148    function destroy() {
149        parent::destroy();
150    }
151
152    /**
153     * パラメーター情報の初期化を行う.
154     *
155     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
156     * @return void
157     */
158    function lfInitParam(&$objFormParam) {
159        $objFormParam->addParam("メーカーID", "maker_id", INT_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
160        $objFormParam->addParam("メーカー名", 'name', SMTEXT_LEN, 'KVa', array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
161    }
162
163    /**
164     * メーカー情報表示.
165     *
166     * @return array $arrMaker メーカー情報
167     */
168    function lfDisp() {
169        $objQuery =& SC_Query_Ex::getSingletonInstance();
170
171        // 削除されていないメーカー情報を表示する
172        $where = "del_flg = 0";
173        $objQuery->setOrder("rank DESC");
174        $arrMaker = array();
175        $arrMaker = $objQuery->select("maker_id, name", "dtb_maker", $where);
176        return $arrMaker;
177    }
178
179    /**
180     * メーカー情報新規登録.
181     *
182     * @param array $arrForm メーカー情報
183     * @return void
184     */
185    function lfInsert(&$arrForm) {
186        $objQuery =& SC_Query_Ex::getSingletonInstance();
187
188        // INSERTする値を作成する
189        $sqlval['name'] = $arrForm['name'];
190        $sqlval['rank'] = $objQuery->max('rank', "dtb_maker") + 1;
191        $sqlval['creator_id'] = $_SESSION['member_id'];
192        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
193        $sqlval['create_date'] = 'CURRENT_TIMESTAMP';
194        $sqlval['maker_id'] = $objQuery->nextVal('dtb_maker_maker_id');
195
196        // INSERTの実行
197        $objQuery->insert("dtb_maker", $sqlval);
198    }
199
200    /**
201     * メーカー情報更新.
202     *
203     * @param array $arrForm メーカー情報
204     * @return void
205     */
206    function lfUpdate(&$arrForm) {
207        $objQuery =& SC_Query_Ex::getSingletonInstance();
208
209        // UPDATEする値を作成する
210        $sqlval['name'] = $arrForm['name'];
211        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
212        $where = "maker_id = ?";
213
214        // UPDATEの実行
215        $objQuery->update("dtb_maker", $sqlval, $where, array($arrForm['maker_id']));
216    }
217
218    /**
219     * メーカー情報削除.
220     *
221     * @param integer $maker_id メーカーID
222     * @return void
223     */
224    function lfDelete($maker_id) {
225        $objDb = new SC_Helper_DB_Ex();
226        $objDb->sfDeleteRankRecord("dtb_maker", "maker_id", $maker_id, "", true);
227    }
228
229    /**
230     * メーカー情報順番変更.
231     *
232     * @param  integer $maker_id メーカーID
233     * @param  string  $mode up か down のモードを示す文字列
234     * @return void
235     */
236    function lfRankChange($maker_id, $mode) {
237        $objDb = new SC_Helper_DB_Ex();
238
239        switch($mode) {
240        case 'up':
241            $objDb->sfRankUp("dtb_maker", "maker_id", $maker_id);
242            break;
243
244        case 'down':
245            $objDb->sfRankDown("dtb_maker", "maker_id", $maker_id);
246            break;
247
248        default:
249            break;
250        }
251    }
252
253    /**
254     * メーカー情報編集前処理.
255     *
256     * @param array   $arrForm メーカー情報
257     * @param integer $maker_id メーカーID
258     * @return array  $arrForm メーカー名を追加
259     */
260    function lfPreEdit(&$arrForm, $maker_id) {
261        $objQuery =& SC_Query_Ex::getSingletonInstance();
262
263        // 編集項目を取得する
264        $where = "maker_id = ?";
265        $arrMaker = array();
266        $arrMaker = $objQuery->select('name', "dtb_maker", $where, array($maker_id));
267        $arrForm['name'] = $arrMaker[0]['name'];
268
269        return $arrForm;
270    }
271
272    /**
273     * 入力エラーチェック.
274     *
275     * @param  array $arrForm メーカー情報
276     * @return array $objErr->arrErr エラー内容
277     */
278    function lfErrorCheck(&$arrForm) {
279        $objErr = new SC_CheckError_Ex($arrForm);
280        $objErr->doFunc(array("メーカー名", 'name', SMTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
281
282        // maker_id の正当性チェック
283        if(!empty($arrForm['maker_id'])) {
284            $objDb = new SC_Helper_DB_Ex();
285            if(!SC_Utils_Ex::sfIsInt($arrForm['maker_id'])
286              || SC_Utils_Ex::sfIsZeroFilling($arrForm['maker_id'])
287              || !$objDb->sfIsRecord('dtb_maker', 'maker_id', array($arrForm['maker_id']))) {
288
289              // maker_idが指定されていて、且つその値が不正と思われる場合はエラー
290              $objErr->arrErr['maker_id'] = "※ メーカーIDが不正です<br />";
291            }
292        }
293        if(!isset($objErr->arrErr['name'])) {
294            $objQuery =& SC_Query_Ex::getSingletonInstance();
295            $arrMaker = array();
296            $arrMaker = $objQuery->select("maker_id, name", "dtb_maker", "del_flg = 0 AND name = ?", array($arrForm['name']));
297
298            // 編集中のレコード以外に同じ名称が存在する場合
299            if ($arrMaker[0]['maker_id'] != $arrForm['maker_id'] && $arrMaker[0]['name'] == $arrForm['name']) {
300                $objErr->arrErr['name'] = "※ 既に同じ内容の登録が存在します。<br />";
301            }
302        }
303
304        return $objErr->arrErr;
305    }
306}
307?>
Note: See TracBrowser for help on using the repository browser.