source: branches/version-2_12-multilang/data/class/pages/admin/products/LC_Page_Admin_Products_Maker.php @ 22426

Revision 22426, 9.3 KB checked in by kim, 8 years ago (diff)

#2060 メッセージIDの振り直し PARAM系
PARAM_LABEL_KEYWORDS~PARAM_LABEL_CUSTOMER_POINT
統合
PARAM_LABEL_MANUFACTURERとPARAM_LABEL_MAKER_NAME
PARAM_LABEL_ITEMPAGEとPARAM_LABEL_PAGE_NO

  • 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-2012 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 = t('TPL_MAINTITLE_007');
49        $this->tpl_subtitle = t('LC_Page_Admin_Products_Maker_001');
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
70        $objFormParam = new SC_FormParam_Ex();
71
72        // パラメーター情報の初期化
73        $this->lfInitParam($objFormParam);
74
75        // POST値をセット
76        $objFormParam->setParam($_POST);
77
78        // POST値の入力文字変換
79        $objFormParam->convParam();
80
81        //maker_idを変数にセット
82        $maker_id = $objFormParam->getValue('maker_id');
83
84        // 変換後のPOST値を取得
85        $this->arrForm  = $objFormParam->getHashArray();
86
87        // モードによる処理切り替え
88        switch ($this->getMode()) {
89
90            // 編集処理
91            case 'edit':
92            // 入力文字の変換
93
94                // エラーチェック
95                $this->arrErr = $this->lfCheckError($this->arrForm, $objFormParam);
96                if (count($this->arrErr) <= 0) {
97                    if ($this->arrForm['maker_id'] == '') {
98                        // メーカー情報新規登録
99                        $this->lfInsert($this->arrForm);
100                    } else {
101                        // メーカー情報編集
102                        $this->lfUpdate($this->arrForm);
103                    }
104
105                    // 再表示
106                    $this->objDisplay->reload();
107                } else {
108                    // POSTデータを引き継ぐ
109                    $this->tpl_maker_id = $this->arrForm['maker_id'];
110                }
111                break;
112
113            // 編集前処理
114            case 'pre_edit':
115                $this->arrForm = $this->lfPreEdit($this->arrForm, $this->arrForm['maker_id']);
116                $this->tpl_maker_id = $this->arrForm['maker_id'];
117                break;
118
119            // メーカー順変更
120            case 'up':
121            case 'down':
122                $this->lfRankChange($this->arrForm['maker_id'], $this->getMode());
123
124                // リロード
125                SC_Response_Ex::reload();
126                break;
127
128            // 削除
129            case 'delete':
130                $this->lfDelete($this->arrForm['maker_id']);
131
132                // リロード
133                SC_Response_Ex::reload();
134                break;
135
136            default:
137                break;
138        }
139
140        // メーカー情報読み込み
141        $this->arrMaker = $this->lfDisp();
142        // POSTデータを引き継ぐ
143        $this->tpl_maker_id = $maker_id;
144
145    }
146
147    /**
148     * デストラクタ.
149     *
150     * @return void
151     */
152    function destroy() {
153        parent::destroy();
154    }
155
156    /**
157     * パラメーター情報の初期化を行う.
158     *
159     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
160     * @return void
161     */
162    function lfInitParam(&$objFormParam) {
163        $objFormParam->addParam(t('PARAM_LABEL_MAKER_ID'), 'maker_id', INT_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
164        $objFormParam->addParam(t('c_Manufacturer name_01'), 'name', SMTEXT_LEN, 'KVa', array('EXIST_CHECK','SPTAB_CHECK','MAX_LENGTH_CHECK'));
165    }
166
167    /**
168     * メーカー情報表示.
169     *
170     * @return array $arrMaker メーカー情報
171     */
172    function lfDisp() {
173        $objQuery =& SC_Query_Ex::getSingletonInstance();
174
175        // 削除されていないメーカー情報を表示する
176        $where = 'del_flg = 0';
177        $objQuery->setOrder('rank DESC');
178        $arrMaker = array();
179        $arrMaker = $objQuery->select('maker_id, name', 'dtb_maker', $where);
180        return $arrMaker;
181    }
182
183    /**
184     * メーカー情報新規登録.
185     *
186     * @param array $arrForm メーカー情報
187     * @return void
188     */
189    function lfInsert(&$arrForm) {
190        $objQuery =& SC_Query_Ex::getSingletonInstance();
191
192        // INSERTする値を作成する
193        $sqlval['name'] = $arrForm['name'];
194        $sqlval['rank'] = $objQuery->max('rank', 'dtb_maker') + 1;
195        $sqlval['creator_id'] = $_SESSION['member_id'];
196        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
197        $sqlval['create_date'] = 'CURRENT_TIMESTAMP';
198        $sqlval['maker_id'] = $objQuery->nextVal('dtb_maker_maker_id');
199
200        // INSERTの実行
201        $objQuery->insert('dtb_maker', $sqlval);
202    }
203
204    /**
205     * メーカー情報更新.
206     *
207     * @param array $arrForm メーカー情報
208     * @return void
209     */
210    function lfUpdate(&$arrForm) {
211        $objQuery =& SC_Query_Ex::getSingletonInstance();
212
213        // UPDATEする値を作成する
214        $sqlval['name'] = $arrForm['name'];
215        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
216        $where = 'maker_id = ?';
217
218        // UPDATEの実行
219        $objQuery->update('dtb_maker', $sqlval, $where, array($arrForm['maker_id']));
220    }
221
222    /**
223     * メーカー情報削除.
224     *
225     * @param integer $maker_id メーカーID
226     * @return void
227     */
228    function lfDelete($maker_id) {
229        $objDb = new SC_Helper_DB_Ex();
230        $objDb->sfDeleteRankRecord('dtb_maker', 'maker_id', $maker_id, '', true);
231    }
232
233    /**
234     * メーカー情報順番変更.
235     *
236     * @param  integer $maker_id メーカーID
237     * @param  string  $mode up か down のモードを示す文字列
238     * @return void
239     */
240    function lfRankChange($maker_id, $mode) {
241        $objDb = new SC_Helper_DB_Ex();
242
243        switch ($mode) {
244            case 'up':
245                $objDb->sfRankUp('dtb_maker', 'maker_id', $maker_id);
246                break;
247
248            case 'down':
249                $objDb->sfRankDown('dtb_maker', 'maker_id', $maker_id);
250                break;
251
252            default:
253                break;
254        }
255    }
256
257    /**
258     * メーカー情報編集前処理.
259     *
260     * @param array   $arrForm メーカー情報
261     * @param integer $maker_id メーカーID
262     * @return array  $arrForm メーカー名を追加
263     */
264    function lfPreEdit(&$arrForm, $maker_id) {
265        $objQuery =& SC_Query_Ex::getSingletonInstance();
266
267        // 編集項目を取得する
268        $where = 'maker_id = ?';
269        $arrMaker = array();
270        $arrMaker = $objQuery->select('name', 'dtb_maker', $where, array($maker_id));
271        $arrForm['name'] = $arrMaker[0]['name'];
272
273        return $arrForm;
274    }
275
276    /**
277     * 入力エラーチェック.
278     *
279     * @param  array $arrForm メーカー情報
280     * @return array $objErr->arrErr エラー内容
281     */
282    function lfCheckError(&$arrForm, &$objFormParam) {
283
284        $arrErr = $objFormParam->checkError();
285        if (!empty($arrErr)) {
286            return $arrErr;
287        }
288
289        // maker_id の正当性チェック
290        if (!empty($arrForm['maker_id'])) {
291            $objDb = new SC_Helper_DB_Ex();
292            if (!SC_Utils_Ex::sfIsInt($arrForm['maker_id'])
293                || SC_Utils_Ex::sfIsZeroFilling($arrForm['maker_id'])
294                || !$objDb->sfIsRecord('dtb_maker', 'maker_id', array($arrForm['maker_id']))
295            ) {
296                // maker_idが指定されていて、且つその値が不正と思われる場合はエラー
297                $arrErr['maker_id'] = t('LC_Page_Admin_Products_Maker_002');
298            }
299        }
300        if (!isset($arrErr['name'])) {
301            $objQuery =& SC_Query_Ex::getSingletonInstance();
302            $arrMaker = array();
303            $arrMaker = $objQuery->select('maker_id, name', 'dtb_maker', 'del_flg = 0 AND name = ?', array($arrForm['name']));
304
305            // 編集中のレコード以外に同じ名称が存在する場合
306            if ($arrMaker[0]['maker_id'] != $arrForm['maker_id'] && $arrMaker[0]['name'] == $arrForm['name']) {
307                $arrErr['name'] = t('LC_Page_Admin_Products_Maker_003');
308            }
309        }
310
311        return $arrErr;
312    }
313}
Note: See TracBrowser for help on using the repository browser.