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

Revision 19879, 15.2 KB checked in by Seasoft, 11 years ago (diff)

#893(SC_Response#reload を使うべきであろう箇所で SC_Response#sendRedirect を利用している)
#748(モバイル/スマートフォンのデザイン管理)

  • 削除できない不具合を改修
  • 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 * ターゲットID 0:未使用 1:レフトナビ 2:ライトナビ 3:イン画面上部 4:メイン画面下部  5:画面上部 6:画面下部 7:ヘッダより上 8:フッタより下 9:HEADタグ内 10:ヘッダ内部
31 * @package Page
32 * @author LOCKON CO.,LTD.
33 * @version $Id$
34 */
35class LC_Page_Admin_Design extends LC_Page_Admin {
36
37    // }}}
38    // {{{ functions
39
40    /**
41     * Page を初期化する.
42     *
43     * @return void
44     */
45    function init() {
46        parent::init();
47        $this->tpl_mainpage = 'design/index.tpl';
48        $this->tpl_subnavi = 'design/subnavi.tpl';
49        $this->tpl_subno = "layout";
50        $this->tpl_mainno = "design";
51        $this->tpl_subtitle = 'レイアウト設定';
52        $masterData = new SC_DB_MasterData_Ex();
53        $this->arrTarget = $masterData->getMasterData("mtb_target");
54    }
55
56    /**
57     * Page のプロセス.
58     *
59     * @return void
60     */
61    function process() {
62        $this->action();
63        $this->sendResponse();
64    }
65
66    /**
67     * Page のアクション.
68     *
69     * TODO パラメータの数値チェック
70     *
71     * @return void
72     */
73    function action() {
74        $objLayout = new SC_Helper_PageLayout_Ex();
75        $objQuery =& SC_Query::getSingletonInstance();
76
77        // 認証可否の判定
78        $objSess = new SC_Session();
79        SC_Utils_Ex::sfIsSuccess($objSess);
80
81        // ページIDを取得
82        if (isset($_REQUEST['page_id']) && is_numeric($_REQUEST['page_id'])) {
83            $page_id = $_REQUEST['page_id'];
84        } else {
85            $page_id = 1; // FIXME $_REQUEST['page_id'] を受け取れない不具合時に不正処理が行なわれる原因となった
86        }
87        // 端末種別IDを取得
88        if (isset($_REQUEST['device_type_id'])
89            && is_numeric($_REQUEST['device_type_id'])) {
90            $device_type_id = $_REQUEST['device_type_id'];
91        } else {
92            $device_type_id = DEVICE_TYPE_PC;
93        }
94
95        // 編集可能ページを取得
96        $this->arrEditPage = $objLayout->lfGetPageData("page_id <> 0 AND device_type_id = ?", array($device_type_id));
97
98        // レイアウト情報を取得
99        $arrBlocPos = $objLayout->lfGetNaviData($page_id, $device_type_id);
100
101        // データの存在チェックを行う
102        $arrPageData = $objLayout->lfGetPageData("page_id = ? AND device_type_id = ?", array($page_id, $device_type_id));
103
104        if (count($arrPageData) <= 0) {
105            $this->exists_page = 0;
106        }else{
107            $this->exists_page = 1;
108        }
109
110        // メッセージ表示
111        if (isset($_GET['msg']) && $_GET['msg'] == "on") {
112            $this->complate_msg="alert('登録が完了しました。');";
113        }
114
115        // ブロックを取得
116        $arrBloc = $objQuery->select("*", "dtb_bloc", "device_type_id = ?", array($device_type_id));
117
118        if (!isset($_POST['mode'])) $_POST['mode'] = "";
119
120        switch ($_POST['mode']) {
121        // 新規ブロック作成
122        case 'new_bloc':
123            SC_Response_Ex::sendRedirect('bloc.php', array("device_type_id" => $device_type_id));
124            exit;
125            break;
126
127        // 新規ページ作成
128        case 'new_page':
129            SC_Response_Ex::sendRedirect('main_edit.php', array("device_type_id" => $device_type_id));
130            exit;
131            break;
132
133        case 'confirm':
134        case 'preview':
135            $page_id = $_POST['page_id'];
136            if ($_POST['mode'] == 'preview') {
137                $page_id = '0';
138            }
139
140            // 更新用にデータを整える
141            $arrUpdBlocData = array();
142
143            // delete実行
144            $arrRet = $objQuery->delete("dtb_blocposition",
145                                        "page_id = ? AND device_type_id = ?",
146                                        array($page_id, $device_type_id));
147
148            $arrTargetFlip = array_flip($this->arrTarget);
149
150            // POSTのデータを使いやすいように修正
151            for ($upd_cnt = 1; $upd_cnt <= $_POST['bloc_cnt']; $upd_cnt++) {
152                if (!isset($_POST['id_'.$upd_cnt])) {
153                    break;
154                }
155
156                // ブロック名称
157                $arrUpdBlocData[$upd_cnt]['name']       = $_POST['name_'.$upd_cnt];
158                // ブロックID
159                $arrUpdBlocData[$upd_cnt]['id']         = $_POST['id_'.$upd_cnt];
160                // ターゲットID
161                $arrUpdBlocData[$upd_cnt]['target_id']  = $arrTargetFlip[$_POST['target_id_'.$upd_cnt]];
162                // TOP座標
163                $arrUpdBlocData[$upd_cnt]['top']        = $_POST['top_'.$upd_cnt];
164                // 全ページ適用か
165                $arrUpdBlocData[$upd_cnt]['anywhere']   = $_POST['anywhere_'.$upd_cnt];
166                // 更新URL
167                $arrUpdBlocData[$upd_cnt]['update_url'] = $_SERVER['HTTP_REFERER'];
168            }
169
170
171            // ブロックの順序を取得し、更新を行う
172            foreach ($arrUpdBlocData as $key => $val) {
173                if ($arrUpdBlocData[$key]['target_id'] == TARGET_ID_UNUSED) {
174                    continue;
175                }
176
177                // ブロックの順序を取得
178                $arrUpdBlocData[$key]['bloc_row'] = $this->lfGetRowID($arrUpdBlocData, $val);
179
180                // insertデータ生成
181                $arrInsData = array('device_type_id' => $device_type_id,
182                                    'page_id' => $page_id,
183                                    'target_id' => $arrUpdBlocData[$key]['target_id'],
184                                    'bloc_id' => $arrUpdBlocData[$key]['id'],
185                                    'bloc_row' => $arrUpdBlocData[$key]['bloc_row'],
186                                    'anywhere' => $arrUpdBlocData[$key]['anywhere'] ? 1 : 0);
187                $count = $objQuery->getOne("SELECT COUNT(*) FROM dtb_blocposition WHERE anywhere = 1 AND bloc_id = ? AND device_type_id = ?",
188                                           array($arrUpdBlocData[$key]['id'], $device_type_id));
189
190                if ($arrUpdBlocData[$key]['anywhere'] == 1) {
191                    $count = $objQuery->getOne("SELECT COUNT(*) FROM dtb_blocposition WHERE anywhere = 1 AND bloc_id = ? AND device_type_id = ?",
192                                               array($arrUpdBlocData[$key]['id'], $device_type_id));
193                    if ($count != 0) {
194                        continue;
195                    }
196                } else {
197                    if ($count > 0) {
198                        $objQuery->query("DELETE FROM dtb_blocposition WHERE anywhere = 1 AND bloc_id = ? AND device_type_id = ?",
199                                         array($arrUpdBlocData[$key]['id'], $device_type_id));
200                    }
201                }
202                // SQL実行
203                $arrRet = $objQuery->insert("dtb_blocposition", $arrInsData);
204            }
205
206            // プレビュー処理
207            if ($_POST['mode'] == 'preview') {
208                $this->lfSetPreData($arrPageData, $objLayout);
209
210                $_SESSION['preview'] = "ON";
211
212                SC_Response_Ex::sendRedirectFromUrlPath('preview/' . DIR_INDEX_URL, array("filename" => $arrPageData[0]["filename"]));
213                exit;
214
215            } else {
216                $arrQueryString = array("device_type_id" => $device_type_id, "page_id" => $page_id, "msg" => "on");
217                SC_Response_Ex::reload($arrQueryString, true);
218                exit;
219            }
220        break;
221
222        // データ削除処理
223        case 'delete':
224            //ベースデータでなければファイルを削除
225            if (!$objLayout->lfCheckBaseData($page_id, $device_type_id)) {
226                $objLayout->lfDelPageData($page_id, $device_type_id);
227                SC_Response_Ex::reload(array('device_type_id' => $device_type_id), true);
228                exit;
229            }
230        break;
231
232        default:
233        }
234
235        // ブロック情報を画面配置用に編集
236        $tpl_arrBloc = array();
237        $cnt = 0;
238        // 使用されているブロックデータを生成
239        foreach($arrBlocPos as $key => $val){
240            if ($val['page_id'] == $page_id) {
241                $tpl_arrBloc = $this->lfSetBlocData($arrBloc, $val, $tpl_arrBloc, $cnt);
242                $cnt++;
243            }
244        }
245        // 未使用のブロックデータを追加
246        foreach($arrBloc as $key => $val){
247            if (!$this->lfChkBloc($val, $tpl_arrBloc)) {
248                $val['target_id'] = TARGET_ID_UNUSED; // 未使用に追加する
249                $tpl_arrBloc = $this->lfSetBlocData($arrBloc, $val, $tpl_arrBloc, $cnt);
250                $cnt++;
251            }
252        }
253
254        $this->tpl_arrBloc = $tpl_arrBloc;
255        $this->bloc_cnt = count($tpl_arrBloc);
256        $this->page_id = $page_id;
257        $this->device_type_id = $device_type_id;
258
259        // ページ名称を取得
260        $arrPageData = $objLayout->lfGetPageData('page_id = ? AND device_type_id = ?', array($page_id, $device_type_id));
261        $this->arrPageData = $arrPageData[0];
262
263        global $GLOBAL_ERR;
264        $errCnt = 0;
265        if ($GLOBAL_ERR != "") {
266            $arrGlobalErr = explode("\n",$GLOBAL_ERR);
267            $errCnt = count($arrGlobalErr) - 8;
268            if ($errCnt < 0 ) {
269                $errCnt = 0;
270            }
271        }
272        $this->errCnt = $errCnt;
273    }
274
275    /**
276     * デストラクタ.
277     *
278     * @return void
279     */
280    function destroy() {
281        parent::destroy();
282    }
283
284    /**
285     * ブロック情報の配列を生成する.
286     *
287     * @param array $arrBloc Bloc情報
288     * @param array $tpl_arrBloc データをセットする配列
289     * @param array $val DBから取得したブロック情報
290     * @param integer $cnt 配列番号
291     * @return array データをセットした配列
292     */
293    function lfSetBlocData($arrBloc, $val, $tpl_arrBloc, $cnt) {
294
295        $tpl_arrBloc[$cnt]['target_id'] = $this->arrTarget[$val['target_id']];
296        $tpl_arrBloc[$cnt]['bloc_id'] = $val['bloc_id'];
297        $tpl_arrBloc[$cnt]['bloc_row'] =
298        isset($val['bloc_row']) ? $val['bloc_row'] : "";
299        $tpl_arrBloc[$cnt]['anywhere'] = $val['anywhere'];
300        if($val['anywhere'] == 1){
301            $tpl_arrBloc[$cnt]['anywhere_selected'] = 'checked="checked"';
302        }
303        foreach($arrBloc as $bloc_key => $bloc_val){
304            if ($bloc_val['bloc_id'] == $val['bloc_id']) {
305                $bloc_name = $bloc_val['bloc_name'];
306                break;
307            }
308        }
309        $tpl_arrBloc[$cnt]['name'] = $bloc_name;
310
311        return $tpl_arrBloc;
312    }
313
314    /**
315     * ブロックIDが配列に追加されているかのチェックを行う.
316     *
317     * @param array $arrBloc Bloc情報
318     * @param array $arrChkData チェックを行うデータ配列
319     * @return bool 存在する場合 true
320     */
321    function lfChkBloc($arrBloc, $arrChkData) {
322        foreach($arrChkData as $key => $val){
323            if ($val['bloc_id'] === $arrBloc['bloc_id'] ) {
324                // 配列に存在すればTrueを返す
325                return true;
326            }
327        }
328
329        // 配列に存在しなければFlaseを返す
330        return false;
331    }
332
333    /**
334     * ブロックIDが何番目に配置されているかを調べる.
335     *
336     * @param array $arrUpdData 更新情報
337     * @param array $arrObj チェックを行うデータ配列
338     * @return integer 順番
339     */
340    function lfGetRowID($arrUpdData, $arrObj){
341        $no = 0; // カウント用(同じデータが必ず1件あるので、初期値は0)
342
343        // 対象データが何番目に配置されているのかを取得する。
344        foreach ($arrUpdData as $key => $val) {
345            if ($val['target_id'] === $arrObj['target_id'] and $val['top'] <= $arrObj['top']){
346                $no++;
347            }
348        }
349        // 番号を返す
350        return $no;
351    }
352
353    /**
354     * プレビューするデータを DB に保存する.
355     *
356     * FIXME
357     *
358     * @param array $arrPageData ページ情報の配列
359     * @return void
360     */
361    function lfSetPreData($arrPageData, &$objLayout){
362        $objQuery = new SC_Query();     // DB操作オブジェクト
363        $sql = "";                      // データ更新SQL生成用
364        $ret = "";                      // データ更新結果格納用
365        $arrUpdData = array();          // 更新データ生成用
366        $filename = $arrPageData[0]['filename'];
367
368        $arrPreData = $objLayout->lfgetPageData(" page_id = ? " , array("0"));
369
370        // XXX tplファイルの削除
371        $del_tpl = USER_REALDIR . "templates/" . $filename . '.tpl';
372
373        if (file_exists($del_tpl)){
374            unlink($del_tpl);
375        }
376
377        // filename が空の場合にはMYページと判断
378        if($filename == ""){
379            $tplfile = TEMPLATE_REALDIR . "mypage/index";
380            $filename = 'mypage';
381        } else {
382            $tplfile = TEMPLATE_REALDIR . $filename;
383        }
384
385        // プレビュー用tplファイルのコピー
386        $copyTo = USER_REALDIR . "templates/preview/" . TEMPLATE_NAME . "/" . $filename . ".tpl";
387
388        if (!is_dir(dirname($copyTo))) {
389            mkdir(dirname($copyTo));
390        }
391
392        copy($tplfile . ".tpl", $copyTo);
393
394        // 更新データの取得
395        $sql = "select page_id,page_name, header_chk, footer_chk from dtb_pagelayout where page_id = ? OR page_id = (SELECT page_id FROM dtb_blocposition WHERE anywhere = 1)" ;
396
397        $ret = $objQuery->getAll($sql, array($arrPageData[0]['page_id']));
398
399        // dbデータのコピー
400        $sql = " update dtb_pagelayout set ";
401        $sql .= "     page_name = ?";
402        $sql .= "     ,header_chk = ?";
403        $sql .= "     ,footer_chk = ?";
404        $sql .= "     ,url = ?";
405        $sql .= "     ,tpl_dir = ?";
406        $sql .= "     ,filename = ?";
407//      $sql .= "     ,anywhere = ?";
408        $sql .= " where page_id = 0";
409        var_dump($ret);
410                echo("####<br/>\n\n".__LINE__ ." in file:".__FILE__."<br/>\n\n ####");
411
412        $arrUpdData = array($ret[0]['page_id']
413        ,$ret[0]['page_id']
414        ,$ret[0]['page_id']
415        ,USER_DIR . "templates/" . TEMPLATE_NAME . "/"
416        ,USER_DIR . "templates/" . TEMPLATE_NAME . "/"
417        ,$filename
418//      ,$ret[0]['anywhere']
419
420        );
421
422        $objQuery->query($sql,$arrUpdData);
423    }
424}
425?>
Note: See TracBrowser for help on using the repository browser.