source: branches/sol/dev02/data/class/pages/admin/products/LC_Page_Admin_Products_ProductClass.php @ 17178

Revision 17178, 18.3 KB checked in by kishida, 15 years ago (diff)

商品詳細、商品コードをキャッシュするようにする

  • Property svn:eol-style set to LF
  • Property svn:keywords set to "Id Revision Date"
Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2007 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_PATH . "pages/LC_Page.php");
26
27/**
28 * 商品登録(規格)のページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id$
33 */
34class LC_Page_Admin_Products_ProductClass extends LC_Page {
35
36    // }}}
37    // {{{ functions
38
39    /**
40     * Page を初期化する.
41     *
42     * @return void
43     */
44    function init() {
45        parent::init();
46        $this->tpl_mainpage = 'products/product_class.tpl';
47        $this->tpl_subnavi = 'products/subnavi.tpl';
48        $this->tpl_mainno = 'products';
49        $this->tpl_subno = 'product';
50        $this->tpl_subtitle = '商品登録';
51
52        $masterData = new SC_DB_MasterData_Ex();
53        $this->arrSRANK = $masterData->getMasterData("mtb_srank");
54        $this->arrDISP = $masterData->getMasterData("mtb_disp");
55        $this->arrCLASS = $masterData->getMasterData("mtb_class");
56        $this->arrSTATUS = $masterData->getMasterData("mtb_status");
57        $this->tpl_onload = "";
58    }
59
60    /**
61     * Page のプロセス.
62     *
63     * @return void
64     */
65    function process() {
66        $objView = new SC_AdminView();
67        // 認証可否の判定
68        $objSess = new SC_Session();
69        SC_Utils_Ex::sfIsSuccess($objSess);
70
71        // 検索パラメータの引き継ぎ
72        foreach ($_POST as $key => $val) {
73            if (ereg("^search_", $key)) {
74                $this->arrSearchHidden[$key] = $val;
75            }
76        }
77
78        $this->tpl_product_id =
79            isset($_POST['product_id']) ? $_POST['product_id'] : "" ;
80
81        $this->tpl_pageno = isset($_POST['pageno']) ? $_POST['pageno'] : "";
82
83        if (!isset($_POST['mode'])) $_POST['mode'] = "";
84
85        switch($_POST['mode']) {
86            // 規格削除要求
87        case 'delete':
88            $objQuery = new SC_Query();
89
90            $objQuery->setLimitOffset(1);
91            $where = "product_id = ? AND NOT (classcategory_id1 = 0 AND classcategory_id2 = 0)";
92            $objQuery->setOrder("rank1 DESC, rank2 DESC");
93            $arrRet = $objQuery->select("*", "vw_cross_products_class AS crs_prd", $where, array($_POST['product_id']));
94
95            if(count($arrRet) > 0) {
96
97                $sqlval['product_id'] = $arrRet[0]['product_id'];
98                $sqlval['classcategory_id1'] = '0';
99                $sqlval['classcategory_id2'] = '0';
100                $sqlval['product_code'] = $arrRet[0]['product_code'];
101                $sqlval['stock'] = $arrRet[0]['stock'];
102                $sqlval['price01'] = $arrRet[0]['price01'];
103                $sqlval['price02'] = $arrRet[0]['price02'];
104                $sqlval['creator_id'] = $_SESSION['member_id'];
105                $sqlval['create_date'] = "now()";
106                $sqlval['update_date'] = "now()";
107
108                $objQuery->begin();
109                $where = "product_id = ?";
110                $objQuery->delete("dtb_products_class", $where, array($_POST['product_id']));
111                $objQuery->insert("dtb_products_class", $sqlval);
112
113                $objQuery->commit();
114            }
115
116            $this->lfProductClassPage();   // 規格登録ページ
117            break;
118
119            // 編集要求
120        case 'pre_edit':
121            $objQuery = new SC_Query();
122            $where = "product_id = ? AND NOT(classcategory_id1 = 0 AND classcategory_id2 = 0) ";
123            $ret = $objQuery->count("dtb_products_class", $where, array($_POST['product_id']));
124
125            if($ret > 0) {
126                // 規格組み合わせ一覧の取得(DBの値を優先する。)
127                $this->arrClassCat = $this->lfGetClassCatListEdit($_POST['product_id']);
128            }
129
130            $this->lfProductClassPage();   // 規格登録ページ
131            break;
132            // 規格組み合わせ表示
133        case 'disp':
134            $this->arrForm['select_class_id1'] = $_POST['select_class_id1'];
135            $this->arrForm['select_class_id2'] = $_POST['select_class_id2'];
136
137            $this->arrErr = $this->lfClassError();
138            if (count($this->arrErr) == 0) {
139                // 規格組み合わせ一覧の取得
140                $this->arrClassCat = $this->lfGetClassCatListDisp($_POST['select_class_id1'], $_POST['select_class_id2']);
141            }
142
143            $this->lfProductClassPage();   // 規格登録ページ
144            break;
145            // 規格登録要求
146        case 'edit':
147            // 入力値の変換
148            $this->arrForm = $this->lfConvertParam($_POST);
149            // エラーチェック
150            $this->arrErr = $this->lfProductClassError($this->arrForm);
151
152            if(count($this->arrErr) == 0) {
153                // 確認ページ設定
154                $this->tpl_mainpage = 'products/product_class_confirm.tpl';
155                $this->lfProductConfirmPage(); // 確認ページ表示
156            } else {
157                // 規格組み合わせ一覧の取得
158                $this->arrClassCat = $this->lfGetClassCatListDisp($_POST['class_id1'], $_POST['class_id2'], false);
159                $this->lfProductClassPage();   // 規格登録ページ
160            }
161            break;
162            // 確認ページからの戻り
163        case 'confirm_return':
164            // フォームパラメータの引き継ぎ
165            $this->arrForm = $_POST;
166            // 規格の選択情報は引き継がない。
167            $this->arrForm['select_class_id1'] = "";
168            $this->arrForm['select_class_id2'] = "";
169            // 規格組み合わせ一覧の取得(デフォルト値は出力しない)
170            $this->arrClassCat = $this->lfGetClassCatListDisp($_POST['class_id1'], $_POST['class_id2'], false);
171            $this->lfProductClassPage();   // 規格登録ページ
172            break;
173        case 'complete':
174            // 完了ページ設定
175            $this->tpl_mainpage = 'products/product_class_complete.tpl';
176            // 商品規格の登録
177            $this->lfInsertProductClass($_POST, $_POST['product_id']);
178            break;
179        default:
180            $this->lfProductClassPage();   // 規格登録ページ
181            break;
182        }
183
184        $objView->assignobj($this);
185        $objView->display(MAIN_FRAME);
186    }
187
188    /**
189     * デストラクタ.
190     *
191     * @return void
192     */
193    function destroy() {
194        parent::destroy();
195    }
196
197    /* 規格登録ページ表示用 */
198    function lfProductClassPage() {
199        $objDb = new SC_Helper_DB_Ex();
200
201        $this->arrHidden = $_POST;
202        $this->arrHidden['select_class_id1'] = "";
203        $this->arrHidden['select_class_id2'] = "";
204        $arrClass = $objDb->sfGetIDValueList("dtb_class", 'class_id', 'name');
205
206        // 規格分類が登録されていない規格は表示しないようにする。
207        $arrClassCatCount = SC_Utils_Ex::sfGetClassCatCount();
208
209        foreach($arrClass as $key => $val) {
210            if($arrClassCatCount[$key] > 0) {
211                $this->arrClass[$key] = $arrClass[$key];
212            }
213        }
214
215        // 商品名を取得
216        $objQuery = new SC_Query();
217        $product_name = $objQuery->getOne("SELECT name FROM dtb_products WHERE product_id = ?", array($_POST['product_id']));
218        $this->arrForm['product_name'] = $product_name;
219    }
220
221    function lfSetDefaultClassCat($objQuery, $product_id, $max) {
222
223        // デフォルト値の読込
224        $col = "product_code, price01, price02, stock, stock_unlimited";
225        $arrRet = $objQuery->select($col, "dtb_products_class", "product_id = ? AND classcategory_id1 = 0 AND classcategory_id2 = 0", array($product_id));;
226
227        if(count($arrRet) > 0) {
228            $no = 1;
229            for($cnt = 0; $cnt < $max; $cnt++) {
230                $this->arrForm["product_code:".$no] = $arrRet[0]['product_code'];
231                $this->arrForm['stock:'.$no] = $arrRet[0]['stock'];
232                $this->arrForm['price01:'.$no] = $arrRet[0]['price01'];
233                $this->arrForm['price02:'.$no] = $arrRet[0]['price02'];
234                $this->arrForm['stock_unlimited:'.$no] = $arrRet[0]['stock_unlimited'];
235                $no++;
236            }
237        }
238    }
239
240    /* 規格組み合わせ一覧の取得 */
241    function lfGetClassCatListDisp($class_id1, $class_id2, $default = true) {
242        $objQuery = new SC_Query();
243
244        if($class_id2 != "") {
245            // 規格1と規格2
246            $sql = "SELECT * ";
247            $sql.= "FROM vw_cross_class AS crs_cls ";
248            $sql.= "WHERE class_id1 = ? AND class_id2 = ? ORDER BY rank1 DESC, rank2 DESC;";
249            $arrRet = $objQuery->getall($sql, array($class_id1, $class_id2));
250        } else {
251            // 規格1のみ
252            $sql = "SELECT * ";
253            $sql.= "FROM vw_cross_class AS crs_cls ";
254            $sql.= "WHERE class_id1 = ? AND class_id2 = 0 ORDER BY rank1 DESC;";
255            $arrRet = $objQuery->getall($sql, array($class_id1));
256
257        }
258
259        $max = count($arrRet);
260
261        if($default) {
262            // デフォルト値を設定
263            $this->lfSetDefaultClassCat($objQuery, $_POST['product_id'], $max);
264        }
265
266        $this->arrForm["class_id1"] = $arrRet[0]['class_id1'];
267        $this->arrForm["class_id2"] = $arrRet[0]['class_id2'];
268        $this->tpl_onload.= "fnCheckAllStockLimit('$max', '" . DISABLED_RGB . "');";
269
270        return $arrRet;
271    }
272
273    /* 規格組み合わせ一覧の取得(編集画面) */
274    function lfGetClassCatListEdit($product_id) {
275        // 既存編集の場合
276        $objQuery = new SC_Query();
277
278        $col = "class_id1, class_id2, name1, name2, rank1, rank2, ";
279        $col.= "product_class_id, product_id, T1_classcategory_id AS classcategory_id1, T2_classcategory_id AS classcategory_id2, ";
280        $col.= "product_code, stock, stock_unlimited, sale_limit, price01, price02, status";
281
282        $sql = "SELECT $col FROM ";
283        $sql.= "( ";
284        $sql.= "SELECT T1.class_id AS class_id1, T2.class_id AS class_id2, T1.classcategory_id AS T1_classcategory_id, T2.classcategory_id AS T2_classcategory_id, T1.name AS name1, T2.name AS name2, T1.rank AS rank1, T2.rank AS rank2 ";
285        $sql.= "FROM dtb_classcategory AS T1, dtb_classcategory AS T2 ";
286        $sql.= "WHERE T1.class_id IN (SELECT class_id1 FROM vw_cross_products_class AS crs_prd WHERE product_id = ? GROUP BY class_id1, class_id2) AND T2.class_id IN (SELECT class_id2 FROM vw_cross_products_class AS crs_prd WHERE product_id = ? GROUP BY class_id1, class_id2)";
287        $sql.= ") AS T1 ";
288
289        $sql.= "LEFT JOIN (SELECT * FROM dtb_products_class WHERE product_id = ?) AS T3 ";
290        $sql.= "ON T1_classcategory_id = T3.classcategory_id1 AND T2_classcategory_id = T3.classcategory_id2 ";
291        $sql.= "ORDER BY rank1 DESC, rank2 DESC";
292
293        $arrList =  $objQuery->getAll($sql, array($product_id, $product_id, $product_id));
294
295        $this->arrForm["class_id1"] = $arrList[0]['class_id1'];
296        $this->arrForm["class_id2"] = $arrList[0]['class_id2'];
297
298        $max = count($arrList);
299
300        // デフォルト値を設定
301        $this->lfSetDefaultClassCat($objQuery, $product_id, $max);
302
303        $no = 1;
304
305        for($cnt = 0; $cnt < $max; $cnt++) {
306            $this->arrForm["classcategory_id1:".$no] = $arrList[$cnt]['classcategory_id1'];
307            $this->arrForm["classcategory_id2:".$no] = $arrList[$cnt]['classcategory_id2'];
308            if($arrList[$cnt]['product_id'] != "") {
309                $this->arrForm["product_code:".$no] = $arrList[$cnt]['product_code'];
310                $this->arrForm['stock:'.$no] = $arrList[$cnt]['stock'];
311                $this->arrForm['stock_unlimited:'.$no] = $arrList[$cnt]['stock_unlimited'];
312                $this->arrForm['price01:'.$no] = $arrList[$cnt]['price01'];
313                $this->arrForm['price02:'.$no] = $arrList[$cnt]['price02'];
314                // JavaScript初期化用文字列
315                $line.= "'check:".$no."',";
316            }
317            $no++;
318        }
319
320        $line = ereg_replace(",$", "", $line);
321        $this->tpl_javascript = "list = new Array($line);";
322        $color = DISABLED_RGB;
323        $this->tpl_onload.= "fnListCheck(list); fnCheckAllStockLimit('$max', '$color');";
324
325        return $arrList;
326    }
327
328    /* 規格の登録 */
329    function lfInsertProductClass($arrList, $product_id) {
330        $objQuery = new SC_Query();
331
332        $objQuery->begin();
333
334        // 既存規格の削除
335        $where = "product_id = ?";
336        $objQuery->delete("dtb_products_class", $where, array($product_id));
337        // 在庫の削除
338        $objQuery->delete("dtb_stock", $where, array($product_id));
339       
340        $cnt = 1;
341        // すべての規格を登録する。
342        while($arrList["classcategory_id1:".$cnt] != "") {
343            if($arrList["check:".$cnt] == 1) {
344                $sqlval['product_id'] = $product_id;
345                $sqlval['classcategory_id1'] = $arrList["classcategory_id1:".$cnt];
346                $sqlval['classcategory_id2'] = $arrList["classcategory_id2:".$cnt];
347                $sqlval['product_code'] = $arrList["product_code:".$cnt];
348                $sqlval['stock'] = $arrList["stock:".$cnt];
349                $sqlval['stock_unlimited'] = $arrList["stock_unlimited:".$cnt];
350                $sqlval['price01'] = $arrList['price01:'.$cnt];
351                $sqlval['price02'] = $arrList['price02:'.$cnt];
352                $sqlval['creator_id'] = $_SESSION['member_id'];
353                $sqlval['create_date'] = "now()";
354                $sqlval['update_date'] = "now()";
355                // INSERTの実行
356                $objQuery->insert("dtb_products_class", $sqlval);
357               
358                // 在庫テーブルを作成する
359                $where = '';
360                $stock_where = array();
361                $stock_sqlval = array();
362                $where = 'product_id = ? AND classcategory_id1 = ? AND classcategory_id2 = ?';
363                $tmp_product_class_id = $objQuery->select('product_class_id', 'dtb_products_class', $where, array($product_id, $sqlval['classcategory_id1'], $sqlval['classcategory_id2']));
364               
365                $stock_sqlval['product_class_id'] = $tmp_product_class_id[0]['product_class_id'];
366                $stock_sqlval['product_id'] = $product_id;
367                $stock_sqlval['stock'] = $arrList["stock"];
368                $objQuery->insert("dtb_stock", $stock_sqlval);
369               
370            }
371            $cnt++;
372        }
373
374        $objQuery->commit();
375    }
376
377    // 規格選択エラーチェック
378    function lfClassError() {
379        $objErr = new SC_CheckError();
380        $objErr->doFunc(array("規格1", "select_class_id1"), array("EXIST_CHECK"));
381        $objErr->doFunc(array("規格", "select_class_id1", "select_class_id2"), array("TOP_EXIST_CHECK"));
382        $objErr->doFunc(array("規格1", "規格2", "select_class_id1", "select_class_id2"), array("DIFFERENT_CHECK"));
383        return $objErr->arrErr;
384    }
385
386    /* 取得文字列の変換 */
387    function lfConvertParam($array) {
388        /*
389         *  文字列の変換
390         *  K :  「半角(ハンカク)片仮名」を「全角片仮名」に変換
391         *  C :  「全角ひら仮名」を「全角かた仮名」に変換
392         *  V :  濁点付きの文字を一文字に変換。"K","H"と共に使用します
393         *  n :  「全角」数字を「半角(ハンカク)」に変換
394         */
395
396        $no = 1; // FIXME 未定義変数の修正
397        while($array["classcategory_id1:".$no] != "") {
398            $arrConvList["product_code:".$no] = "KVa";
399            $arrConvList["price01:".$no] = "n";
400            $arrConvList["price02:".$no] = "n";
401            $arrConvList["stock:".$no] = "n";
402            $no++;
403        }
404
405        // 文字変換
406        foreach ($arrConvList as $key => $val) {
407            // POSTされてきた値のみ変換する。
408            if(isset($array[$key])) {
409                $array[$key] = mb_convert_kana($array[$key] ,$val);
410            }
411        }
412        return $array;
413    }
414
415    // 商品規格エラーチェック
416    function lfProductClassError($array) {
417        $objErr = new SC_CheckError($array);
418        $no = 1; // FIXME 未定義変数の修正
419        while($array["classcategory_id1:".$no] != "") {
420            if($array["check:".$no] == 1) {
421                $objErr->doFunc(array("商品コード", "product_code:".$no, STEXT_LEN), array("MAX_LENGTH_CHECK"));
422                $objErr->doFunc(array(NORMAL_PRICE_TITLE, "price01:".$no, PRICE_LEN), array("ZERO_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
423                $objErr->doFunc(array(SALE_PRICE_TITLE, "price02:".$no, PRICE_LEN), array("EXIST_CHECK", "ZERO_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
424
425                if($array["stock_unlimited:".$no] != '1') {
426                    $objErr->doFunc(array("在庫数", "stock:".$no, AMOUNT_LEN), array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
427                }
428            }
429            if(count($objErr->arrErr) > 0) {
430                $objErr->arrErr["error:".$no] = $objErr->arrErr["product_code:".$no];
431                $objErr->arrErr["error:".$no].= $objErr->arrErr["price01:".$no];
432                $objErr->arrErr["error:".$no].= $objErr->arrErr["price02:".$no];
433                $objErr->arrErr["error:".$no].= $objErr->arrErr["stock:".$no];
434            }
435            $no++;
436        }
437        return $objErr->arrErr;
438    }
439
440    /* 確認ページ表示用 */
441    function lfProductConfirmPage() {
442        $objDb = new SC_Helper_DB_Ex();
443        $this->arrForm['mode'] = 'complete';
444        $this->arrClass = $objDb->sfGetIDValueList("dtb_class", 'class_id', 'name');
445        $cnt = 0;
446        $check = 0;
447        $no = 1;
448        while($_POST["classcategory_id1:".$no] != "") {
449            if($_POST["check:".$no] != "") {
450                $check++;
451            }
452            $no++;
453            $cnt++;
454        }
455        $this->tpl_check = $check;
456        $this->tpl_count = $cnt;
457    }
458}
459?>
Note: See TracBrowser for help on using the repository browser.