source: branches/version-2_5-dev/data/class/pages/admin/design/LC_Page_Admin_Design_Bloc.php @ 19832

Revision 19832, 11.1 KB checked in by Seasoft, 11 years ago (diff)

#714(パス指定によるリダイレクトの記述を簡潔にする) 共通処理実装、個別処理の一部を実装
#869(create_date, update_date 列の定義が、表やDBによるバラツキがある)

  • NOT NULL 制約により実装漏れに気づいたので修正

#893(SC_Response#reload を使うべきであろう箇所で SC_Response#sendRedirect を利用している)
#628(未使用処理・定義などの削除)

  • Property svn:eol-style set to LF
  • Property svn:keywords set to "Id Revision Date"
  • 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-2010 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_REALDIR . "pages/admin/LC_Page_Admin.php");
26
27/**
28 * ブロック編集 のページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id$
33 */
34class LC_Page_Admin_Design_Bloc extends LC_Page_Admin {
35
36    // }}}
37    // {{{ functions
38
39    /**
40     * Page を初期化する.
41     *
42     * @return void
43     */
44    function init() {
45        parent::init();
46        $this->tpl_mainpage = 'design/bloc.tpl';
47        $this->tpl_subnavi = 'design/subnavi.tpl';
48        $this->tpl_subno_edit = 'bloc';
49        $this->text_row = 13;
50        $this->tpl_subno = "bloc";
51        $this->tpl_mainno = "design";
52        $this->tpl_subtitle = 'ブロック設定';
53    }
54
55    /**
56     * Page のプロセス.
57     *
58     * @return void
59     */
60    function process() {
61        $this->action();
62        $this->sendResponse();
63    }
64
65    /**
66     * Page のアクション.
67     *
68     * FIXME テンプレートパスの取得方法を要修正
69     *
70     * @return void
71     */
72    function action() {
73
74        // 認証可否の判定
75        $objSess = new SC_Session();
76        SC_Utils_Ex::sfIsSuccess($objSess);
77
78        // ページIDを取得
79        if (isset($_REQUEST['bloc_id']) && is_numeric($_REQUEST['bloc_id'])) {
80            $bloc_id = $_REQUEST['bloc_id'];
81        } else {
82            $bloc_id = null;
83        }
84        $this->bloc_id = $bloc_id;
85
86        // 端末種別IDを取得
87        if (isset($_REQUEST['device_type_id'])
88            && is_numeric($_REQUEST['device_type_id'])) {
89            $device_type_id = $_REQUEST['device_type_id'];
90        } else {
91            $device_type_id = DEVICE_TYPE_PC;
92        }
93
94        $this->objLayout = new SC_Helper_PageLayout_Ex();
95        $package_path = $this->objLayout->getTemplatePath($device_type_id) . BLOC_DIR;
96
97        // ブロック一覧を取得
98        $this->arrBlocList = $this->lfgetBlocData("device_type_id = ?", array($device_type_id));
99
100        // bloc_id が指定されている場合にはブロックデータの取得
101        if ($bloc_id != '') {
102            $arrBlocData = $this->lfGetBlocData("bloc_id = ? AND device_type_id = ?",
103                                                array($bloc_id, $device_type_id));
104
105            $tplPath = $package_path . $arrBlocData[0]['filename'] . '.tpl';
106
107            // テンプレートファイルの読み込み
108            $arrBlocData[0]['tpl_data'] = file_get_contents($tplPath);
109            $this->arrBlocData = $arrBlocData[0];
110        }
111
112        // メッセージ表示
113        if (isset($_GET['msg']) && $_GET['msg'] == "on") {
114            // 完了メッセージ
115            $this->tpl_onload="alert('登録が完了しました。');";
116        }
117
118        if (!isset($_POST['mode'])) $_POST['mode'] = "";
119
120        switch($_POST['mode']) {
121        case 'preview':
122            // プレビューファイル作成
123            $prev_path = USER_INC_REALDIR . 'preview/bloc_preview.tpl';
124            // ディレクトリの作成
125            SC_Utils::sfMakeDir($prev_path);
126            $res = file_put_contents($new_bloc_path, $_POST['bloc_html']);
127            if ($res === false) {
128                SC_Utils_Ex::sfDispException();
129            }
130
131            // プレビューデータ表示
132            $this->preview = "on";
133            $this->arrBlocData['tpl_data'] = $_POST['bloc_html'];
134            $this->arrBlocData['tpl_path'] = $prev_path;
135            $this->arrBlocData['bloc_name'] = $_POST['bloc_name'];
136            $this->arrBlocData['filename'] = $_POST['filename'];
137            $this->text_row = $_POST['html_area_row'];
138            break;
139        case 'confirm':
140            $this->preview = "off";
141            // エラーチェック
142            $this->arrErr = $this->lfErrorCheck($_POST);
143
144            // エラーがなければ更新処理を行う
145            if (count($this->arrErr) == 0) {
146                // DBへデータを更新する
147                $this->lfEntryBlocData($_POST, $device_type_id);
148
149                // 旧ファイルの削除
150                if (file_exists($tplPath)) {
151                    unlink($tplPath);
152                }
153
154                // ファイル作成
155                $new_bloc_path = $package_path . $_POST['filename'] . ".tpl";
156                // ディレクトリの作成
157                SC_Utils::sfMakeDir($new_bloc_path);
158                $res = file_put_contents($new_bloc_path, $_POST['bloc_html']);
159                if ($res === false) {
160                    SC_Utils_Ex::sfDispException();
161                }
162
163                $arrBlocData = $this->lfGetBlocData("filename = ? AND device_type_id = ?",
164                                                    array($_POST['filename'], $device_type_id));
165
166                $bloc_id = $arrBlocData[0]['bloc_id'];
167                $arrQueryString = array(
168                    'bloc_id' => $bloc_id,
169                    'device_type_id' => $device_type_id,
170                    'msg' => 'on',
171                );
172                $this->objDisplay->reload($arrQueryString, true);
173                exit;
174            }else{
175                // エラーがあれば入力時のデータを表示する
176                $this->arrBlocData = $_POST;
177            }
178            break;
179        case 'delete':
180            $this->preview = "off";
181             // DBへデータを更新する
182            $objQuery = new SC_Query();     // DB操作オブジェクト
183            $sql = "";                      // データ更新SQL生成用
184            $ret = "";                      // データ更新結果格納用
185            $arrDelData = array();          // 更新データ生成用
186
187            // 更新データ生成
188            $arrUpdData = array($arrData['bloc_name'], BLOC_DIR . $arrData['filename'] . '.tpl', $arrData['filename']);
189
190            // bloc_id が空でない場合にはdeleteを実行
191            if ($_POST['bloc_id'] !== '') {
192                // SQL生成
193                $sql = " DELETE FROM dtb_bloc WHERE bloc_id = ? AND device_type_id = ?";
194                // SQL実行
195                $ret = $objQuery->query($sql,array($_POST['bloc_id'], $device_type_id));
196
197                // ページに配置されているデータも削除する
198                $sql = "DELETE FROM dtb_blocposition WHERE bloc_id = ? AND device_type_id = ?";
199                // SQL実行
200                $ret = $objQuery->query($sql,array($_POST['bloc_id'], $device_type_id));
201
202                // ファイルの削除
203                if (file_exists($tplPath)) {
204                    unlink($tplPath);
205                }
206            }
207            $this->objDisplay->reload(array("device_type_id" => $device_type_id), true);
208            exit;
209            break;
210        default:
211            if(isset($_POST['mode'])) {
212               GC_Utils::gfPrintLog("MODEエラー:".$_POST['mode']);
213            }
214            break;
215        }
216        $this->device_type_id = $device_type_id;
217    }
218
219    /**
220     * デストラクタ.
221     *
222     * @return void
223     */
224    function destroy() {
225        parent::destroy();
226    }
227
228    /**
229     * ブロック情報を取得する.
230     *
231     * @param string $where Where句文
232     * @param array $arrVal Where句の絞込条件値
233     * @return array ブロック情報
234     */
235    function lfgetBlocData($where = '', $arrVal = array()){
236        $objQuery =& SC_Query::getSingletonInstance();
237        $objQuery->setOrder("bloc_id");
238        return $objQuery->select("*", "dtb_bloc", $where, $arrVal);
239    }
240
241    /**
242     * ブロック情報を更新する.
243     *
244     * @param array $arrData 更新データ
245     * @param integer $device_type_id 端末種別ID
246     * @return integer 更新結果
247     */
248    function lfEntryBlocData($arrData, $device_type_id){
249        $objQuery = new SC_Query();     // DB操作オブジェクト
250        $sql = "";                      // データ更新SQL生成用
251        $ret = "";                      // データ更新結果格納用
252        $arrUpdData = array();          // 更新データ生成用
253        $arrChk = array();              // 排他チェック用
254
255        // 更新データ生成
256        $arrUpdData = array("bloc_name" => $arrData['bloc_name'],
257                            "tpl_path" => $arrData['filename'] . '.tpl',
258                            "filename" => $arrData['filename']);
259
260        // データが存在しているかチェックを行う
261        if($arrData['bloc_id'] !== ''){
262            $arrChk = $this->lfgetBlocData("bloc_id = ? AND device_type_id = ?",
263                                           array($arrData['bloc_id'], $device_type_id));
264        }
265
266        // bloc_id が空 若しくは データが存在していない場合にはINSERTを行う
267        if ($arrData['bloc_id'] === '' or !isset($arrChk[0])) {
268            // SQL生成
269            // FIXME device_type_id ごとの連番にする
270            $arrUpdData['bloc_id'] = $objQuery->nextVal('dtb_bloc_bloc_id');
271            $arrUpdData['device_type_id'] = $device_type_id;
272            $arrUpdData['update_date'] = "now()";
273            $ret = $objQuery->insert('dtb_bloc', $arrUpdData);
274        } else {
275            $ret = $objQuery->update('dtb_bloc', $arrUpdData, 'bloc_id = ? AND device_type_id = ?',
276                                     array($arrData['bloc_id'], $device_type_id));
277        }
278        return $ret;
279    }
280
281    /**
282     * 入力項目のエラーチェックを行う.
283     *
284     * @param array $arrData 入力データ
285     * @return array エラー情報
286     */
287    function lfErrorCheck($array) {
288        $objErr = new SC_CheckError($array);
289
290        $objErr->doFunc(array("ブロック名", "bloc_name", STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
291        $objErr->doFunc(array("ファイル名", "filename", STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "MAX_LENGTH_CHECK","FILE_NAME_CHECK"));
292
293        // 同一のファイル名が存在している場合にはエラー
294        if(!isset($objErr->arrErr['filename']) and $array['filename'] !== ''){
295            $arrChk = $this->lfgetBlocData("filename = ?", array($array['filename']));
296
297            if (count($arrChk[0]) >= 1 and $arrChk[0]['bloc_id'] != $array['bloc_id']) {
298                $objErr->arrErr['filename'] = '※ 同じファイル名のデータが存在しています。別の名称を付けてください。';
299            }
300        }
301
302        return $objErr->arrErr;
303    }
304}
305?>
Note: See TracBrowser for help on using the repository browser.