source: branches/comu-ver2/data/class/pages/products/LC_Page_Products_List.php @ 18187

Revision 18187, 28.8 KB checked in by ramrun, 12 years ago (diff)

#261 設定見直し

  • 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-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:LC_Page_Products_List.php 15532 2007-08-31 14:39:46Z nanasess $
33 */
34class LC_Page_Products_List extends LC_Page {
35
36    // {{{ properties
37
38    /** テンプレートクラス名1 */
39    var $tpl_class_name1;
40
41    /** テンプレートクラス名2 */
42    var $tpl_class_name2;
43
44    /** JavaScript テンプレート */
45    var $tpl_javascript;
46
47    // }}}
48    // {{{ functions
49
50    /**
51     * Page を初期化する.
52     *
53     * @return void
54     */
55    function init() {
56        parent::init();
57
58        $masterData = new SC_DB_MasterData_Ex();
59        $this->arrSTATUS = $masterData->getMasterData("mtb_status");
60        $this->arrSTATUS_IMAGE = $masterData->getMasterData("mtb_status_image");
61        $this->arrDELIVERYDATE = $masterData->getMasterData("mtb_delivery_date");
62        $this->arrPRODUCTLISTMAX = $masterData->getMasterData("mtb_product_list_max");
63
64        $this->tpl_class_name1 = array();
65        $this->tpl_class_name2 = array();
66    }
67
68    /**
69     * Page のプロセス.
70     *
71     * @return void
72     */
73    function process() {
74        // カテゴリIDの正当性チェック
75        $this->lfCheckCategoryId();
76
77        $objView = new SC_SiteView();
78        $conn = new SC_DBConn();
79        $objDb = new SC_Helper_DB_Ex();
80
81        //表示件数の選択
82        if(isset($_POST['disp_number'])
83           && SC_Utils_Ex::sfIsInt($_POST['disp_number'])) {
84            $this->disp_number = $_POST['disp_number'];
85        } else {
86            //最小表示件数を選択
87            $this->disp_number = current(array_keys($this->arrPRODUCTLISTMAX));
88        }
89
90        //表示順序の保存
91        $this->orderby = isset($_POST['orderby']) ? $_POST['orderby'] : "";
92
93        // GETのカテゴリIDを元に正しいカテゴリIDを取得する。
94        $arrCategory_id = $objDb->sfGetCategoryId("", $_GET['category_id']);
95
96        if (!isset($_GET['mode'])) $_GET['mode'] = "";
97        if (!isset($_GET['name'])) $_GET['name'] = "";
98        if (!isset($_POST['orderby'])) $_POST['orderby'] = "";
99        if (empty($arrCategory_id)) $arrCategory_id = array("0");
100
101        // タイトル編集
102        $tpl_subtitle = "";
103        if ($_GET['mode'] == 'search') {
104            $tpl_subtitle = "検索結果";
105        } elseif (empty($arrCategory_id[0])) {
106            $tpl_subtitle = "全商品";
107        } else {
108            $arrCat = $objDb->sfGetCat($arrCategory_id[0]);
109            $tpl_subtitle = $arrCat['name'];
110        }
111
112        $objQuery = new SC_Query();
113        $count = $objQuery->count("dtb_best_products", "category_id = ?", $arrCategory_id);
114
115        // 以下の条件でBEST商品を表示する
116        // ・BEST最大数の商品が登録されている。
117        // ・カテゴリIDがルートIDである。
118        // ・検索モードでない。
119        if(($count >= BEST_MIN) && $this->lfIsRootCategory($arrCategory_id[0]) && ($_GET['mode'] != 'search') ) {
120            // 商品TOPの表示処理
121            $this->arrBestItems = SC_Utils_Ex::sfGetBestProducts($conn, $arrCategory_id[0]);
122            $this->BEST_ROOP_MAX = ceil((BEST_MAX-1)/2);
123        } else {
124            if ($_GET['mode'] == 'search' && strlen($_GET['category_id']) == 0 ){
125                // 検索時にcategory_idがGETに存在しない場合は、仮に埋めたIDを空白に戻す
126                $arrCategory_id = array(0);
127            }
128
129            // 商品一覧の表示処理
130            $this->lfDispProductsList($arrCategory_id[0], $_GET['name'], $_GET['maker_id'], $this->disp_number, $_POST['orderby']);
131
132            // 検索条件を画面に表示
133            // カテゴリー検索条件
134            if (strlen($_GET['category_id']) == 0) {
135                $arrSearch['category'] = "指定なし";
136            }else{
137                $arrCat = $conn->getOne("SELECT category_name FROM dtb_category WHERE category_id = ?", $arrCategory_id);
138                $arrSearch['category'] = $arrCat;
139            }
140
141            // メーカー検索条件
142            if (strlen($_GET['maker_id']) == 0) {
143                $arrSearch['maker'] = "指定なし";
144            }else{
145                $arrSearch['maker'] = $name = $conn->getOne("SELECT name FROM dtb_maker WHERE maker_id = ?", $_GET['maker_id']);
146            }
147
148            // 商品名検索条件
149            if ($_GET['name'] === "") {
150                $arrSearch['name'] = "指定なし";
151            }else{
152                $arrSearch['name'] = $_GET['name'];
153            }
154        }
155
156        // レイアウトデザインを取得
157        $layout = new SC_Helper_PageLayout_Ex();
158        $layout->sfGetPageLayout($this, false, "products/list.php");
159
160        if(isset($_POST['mode']) && $_POST['mode'] == "cart"
161           && $_POST['product_id'] != "") {
162
163            // 値の正当性チェック
164            if(!SC_Utils_Ex::sfIsInt($_POST['product_id']) || !$objDb->sfIsRecord("dtb_products", "product_id", $_POST['product_id'], "del_flg = 0 AND status = 1")) {
165                SC_Utils_Ex::sfDispSiteError(PRODUCT_NOT_FOUND);
166            } else {
167                // 入力値の変換
168                $this->arrErr = $this->lfCheckError($_POST['product_id']);
169                if(count($this->arrErr) == 0) {
170                    $objCartSess = new SC_CartSession();
171                    $classcategory_id = "classcategory_id". $_POST['product_id'];
172                    $classcategory_id1 = $_POST[$classcategory_id. '_1'];
173                    $classcategory_id2 = $_POST[$classcategory_id. '_2'];
174                    $quantity = "quantity". $_POST['product_id'];
175                    // 規格1が設定されていない場合
176                    if(!$this->tpl_classcat_find1[$_POST['product_id']]) {
177                        $classcategory_id1 = '0';
178                    }
179                    // 規格2が設定されていない場合
180                    if(!$this->tpl_classcat_find2[$_POST['product_id']]) {
181                        $classcategory_id2 = '0';
182                    }
183                    $objCartSess->setPrevURL($_SERVER['REQUEST_URI']);
184                    $objCartSess->addProduct(array($_POST['product_id'], $classcategory_id1, $classcategory_id2), $_POST[$quantity]);
185                    $this->sendRedirect($this->getLocation(URL_CART_TOP));
186                    exit;
187                }
188            }
189        }
190
191        $this->tpl_subtitle = $tpl_subtitle;
192
193        // 支払方法の取得
194        $this->arrPayment = $this->lfGetPayment();
195        // 入力情報を渡す
196        $this->arrForm = $_POST;
197
198        $this->lfConvertParam();
199
200        $this->category_id = $arrCategory_id[0];
201        $this->arrSearch = $arrSearch;
202
203        $objView->assignobj($this);
204        $objView->display(SITE_FRAME);
205    }
206
207    /**
208     * モバイルページを初期化する.
209     *
210     * @return void
211     */
212    function mobileInit() {
213        $this->init();
214    }
215
216    /**
217     * Page のプロセス(モバイル).
218     *
219     * FIXME スパゲッティ...
220     *
221     * @return void
222     */
223    function mobileProcess() {
224        // カテゴリIDの正当性チェック
225        $this->lfCheckCategoryId();
226
227        $objView = new SC_MobileView();
228        $conn = new SC_DBConn();
229        $objDb = new SC_Helper_DB_Ex();
230
231        //表示件数の選択
232        if(isset($_REQUEST['disp_number'])
233           && SC_Utils_Ex::sfIsInt($_REQUEST['disp_number'])) {
234            $this->disp_number = $_REQUEST['disp_number'];
235        } else {
236            //最小表示件数を選択
237            $this->disp_number = current(array_keys($this->arrPRODUCTLISTMAX));
238        }
239
240        //表示順序の保存
241        $this->orderby = isset($_REQUEST['orderby']) ? $_REQUEST['orderby'] : "";
242
243        // GETのカテゴリIDを元に正しいカテゴリIDを取得する。
244        $arrCategory_id = $objDb->sfGetCategoryId("", $_GET['category_id']);
245
246
247        // タイトル編集
248        $tpl_subtitle = "";
249        $tpl_search_mode = false;
250
251        if (!isset($_GET['mode'])) $_GET['mode'] = "";
252        if (!isset($_POST['mode'])) $_POST['mode'] = "";
253        if (!isset($_GET['name'])) $_GET['name'] = "";
254        if (!isset($_REQUEST['orderby'])) $_REQUEST['orderby'] = "";
255        if (empty($arrCategory_id)) $arrCategory_id = array("0");
256
257        if($_GET['mode'] == 'search'){
258            $tpl_subtitle = "検索結果";
259            $tpl_search_mode = true;
260        }elseif (empty($arrCategory_id[0])) {
261            $tpl_subtitle = "全商品";
262        }else{
263            $arrCat = $objDb->sfGetCat($arrCategory_id[0]);
264            $tpl_subtitle = $arrCat['name'];
265        }
266
267        $objQuery = new SC_Query();
268        $count = $objQuery->count("dtb_best_products", "category_id = ?", $arrCategory_id);
269
270        // 以下の条件でBEST商品を表示する
271        // ・BEST最大数の商品が登録されている。
272        // ・カテゴリIDがルートIDである。
273        // ・検索モードでない。
274        if(($count >= BEST_MIN) && $this->lfIsRootCategory($arrCategory_id[0]) && ($_GET['mode'] != 'search') ) {
275            // 商品TOPの表示処理
276
277            $this->arrBestItems = SC_Utils_Ex::sfGetBestProducts($conn, $arrCategory_id[0]);
278            $this->BEST_ROOP_MAX = ceil((BEST_MAX-1)/2);
279        } else {
280            if ($_GET['mode'] == 'search' && strlen($_GET['category_id']) == 0 ){
281                // 検索時にcategory_idがGETに存在しない場合は、仮に埋めたIDを空白に戻す
282                $arrCategory_id = array("");
283            }
284
285            // 商品一覧の表示処理
286            $this->lfDispProductsList($arrCategory_id[0], $_GET['name'], $_GET['maker_id'], $this->disp_number, $_REQUEST['orderby']);
287
288            // 検索条件を画面に表示
289            // カテゴリー検索条件
290            if (strlen($_GET['category_id']) == 0) {
291                $arrSearch['category'] = "指定なし";
292            }else{
293                $arrCat = $conn->getOne("SELECT category_name FROM dtb_category WHERE category_id = ?",array($category_id));
294                $arrSearch['category'] = $arrCat;
295            }
296
297            // 商品名検索条件
298            if ($_GET['name'] === "") {
299                $arrSearch['name'] = "指定なし";
300            }else{
301                $arrSearch['name'] = $_GET['name'];
302            }
303        }
304
305        if($_POST['mode'] == "cart" && $_POST['product_id'] != "") {
306            // 値の正当性チェック
307            if(!SC_Utils_Ex::sfIsInt($_POST['product_id']) || !SC_Utils_Ex::sfIsRecord("dtb_products", "product_id", $_POST['product_id'], "del_flg = 0 AND status = 1")) {
308                SC_Utils_Ex::sfDispSiteError(PRODUCT_NOT_FOUND, "", false, "", true);
309            } else {
310                // 入力値の変換
311                $this->arrErr = $this->lfCheckError($_POST['product_id']);
312                if(count($this->arrErr) == 0) {
313                    $objCartSess = new SC_CartSession();
314                    $classcategory_id = "classcategory_id". $_POST['product_id'];
315                    $classcategory_id1 = $_POST[$classcategory_id. '_1'];
316                    $classcategory_id2 = $_POST[$classcategory_id. '_2'];
317                    $quantity = "quantity". $_POST['product_id'];
318                    // 規格1が設定されていない場合
319                    if(!$this->tpl_classcat_find1[$_POST['product_id']]) {
320                        $classcategory_id1 = '0';
321                    }
322                    // 規格2が設定されていない場合
323                    if(!$this->tpl_classcat_find2[$_POST['product_id']]) {
324                        $classcategory_id2 = '0';
325                    }
326                    $objCartSess->setPrevURL($_SERVER['REQUEST_URI']);
327                    $objCartSess->addProduct(array($_POST['product_id'], $classcategory_id1, $classcategory_id2), $_POST[$quantity]);
328                    $this->sendRedirect(MOBILE_URL_CART_TOP, array(session_name() => session_id()));
329                    exit;
330                }
331            }
332        }
333
334
335        // ページ送り機能用のURLを作成する。
336        $objURL = new Net_URL($_SERVER['PHP_SELF']);
337        foreach ($_REQUEST as $key => $value) {
338            if ($key == session_name() || $key == 'pageno') {
339                continue;
340            }
341            $objURL->addQueryString($key, mb_convert_encoding($value, 'SJIS', CHAR_CODE));
342        }
343
344        if ($this->objNavi->now_page > 1) {
345            $objURL->addQueryString('pageno', $this->objNavi->now_page - 1);
346            $this->tpl_previous_page = $objURL->path . '?' . $objURL->getQueryString();
347        }
348        if ($this->objNavi->now_page < $this->objNavi->max_page) {
349            $objURL->addQueryString('pageno', $this->objNavi->now_page + 1);
350            $this->tpl_next_page = $objURL->path . '?' . $objURL->getQueryString();
351        }
352
353        $this->tpl_subtitle = $tpl_subtitle;
354        $this->tpl_search_mode = $tpl_search_mode;
355
356        // 支払方法の取得
357        $this->arrPayment = $this->lfGetPayment();
358        // 入力情報を渡す
359        $this->arrForm = $_POST;
360
361        $this->category_id = $arrCategory_id[0];
362        $this->arrSearch = $arrSearch;
363        $this->tpl_mainpage = MOBILE_TEMPLATE_DIR . "products/list.tpl";
364
365        $objView->assignobj($this);
366        $objView->display(SITE_FRAME);
367    }
368
369    /**
370     * デストラクタ.
371     *
372     * @return void
373     */
374    function destroy() {
375        parent::destroy();
376    }
377
378    /* カテゴリIDの正当性チェック */
379    function lfCheckCategoryId() {
380        $objDb = new SC_Helper_DB_Ex();
381        $category_id = $_POST['category_id'] ? $_POST['category_id'] : $_GET['category_id'];
382        if (!defined('MOBILE_SITE') && !isset($_REQUEST['category_id']))
383            SC_Utils_Ex::sfDispSiteError(CATEGORY_NOT_FOUND);
384        if ($category_id
385                && (!SC_Utils_Ex::sfIsInt($category_id)
386                || SC_Utils_Ex::sfIsZeroFilling($category_id)
387                || !$objDb->sfIsRecord('dtb_category', 'category_id', (array)$category_id, 'del_flg = 0')))
388            SC_Utils_Ex::sfDispSiteError(CATEGORY_NOT_FOUND);
389    }
390
391    /* カテゴリIDがルートかどうかの判定 */
392    function lfIsRootCategory($category_id) {
393        $objQuery = new SC_Query();
394        $level = $objQuery->get("dtb_category", "level", "category_id = ?", array($category_id));
395        if($level == 1) {
396            return true;
397        }
398        return false;
399    }
400
401    /* 商品一覧の表示 */
402    function lfDispProductsList($category_id, $name, $maker_id, $disp_num, $orderby) {
403
404        $objQuery = new SC_Query();
405        $objDb = new SC_Helper_DB_Ex();
406        $this->tpl_pageno = @$_GET['pageno'];
407        $arrval = array();
408        $arrval_order = array();
409        $arrval_category = array();
410       
411        // カテゴリからのWHERE文字列取得
412        if ( $category_id ) {
413            list($where_category, $arrval_category) = $objDb->sfGetCatWhere($category_id);
414        }
415       
416        // ▼対象商品IDの抽出
417        // 商品検索条件の作成(未削除、表示)
418        $where = "del_flg = 0 AND status = 1 ";
419       
420        // 在庫無し商品の非表示
421        if (NOSTOCK_HIDDEN === true) {
422            $where .= ' AND (stock_max >= 1 OR stock_unlimited_max = 1)';
423        }
424       
425        if (strlen($where_category) >= 1) {
426            $where.= " AND $where_category";
427            $arrval = array_merge($arrval, $arrval_category);
428        }
429
430        // 商品名をwhere文に
431        $name = ereg_replace(",", "", $name);// XXX
432        // 全角スペースを半角スペースに変換
433        $name = str_replace(' ', ' ', $name);
434        // スペースでキーワードを分割
435        $names = preg_split("/ +/", $name);
436        // 分割したキーワードを一つずつwhere文に追加
437        foreach ($names as $val) {
438            if ( strlen($val) > 0 ){
439                $where .= " AND ( name ILIKE ? OR comment3 ILIKE ?) ";
440                $ret = SC_Utils_Ex::sfManualEscape($val);
441                $arrval[] = "%$ret%";
442                $arrval[] = "%$ret%";
443            }
444        }
445
446        // メーカーらのWHERE文字列取得
447        if ( $maker_id ) {
448            $where .= " AND maker_id = ? ";
449            $arrval[] = $maker_id;
450        }
451       
452        $arrProduct_id = $objQuery->getCol('vw_products_allclass AS allcls', 'DISTINCT product_id', $where, $arrval);
453        // ▲対象商品IDの抽出
454       
455        // 行数の取得
456        $linemax = count($arrProduct_id);
457
458        $this->tpl_linemax = $linemax;   // 何件が該当しました。表示用
459
460        // ページ送りの取得
461        $this->objNavi = new SC_PageNavi($this->tpl_pageno, $linemax, $disp_num, "fnNaviPage", NAVI_PMAX);
462        $strnavi = $this->objNavi->strnavi;
463        $strnavi = preg_replace('/list\.php.*?\'([0-9]+)\'.*?\"/', 'list.php?category_id=' . $category_id . '&amp;pageno=$1"', $strnavi);
464 
465        // 表示文字列
466        $this->tpl_strnavi = empty($strnavi) ? "&nbsp;" : $strnavi;
467        $startno = $this->objNavi->start_row;                 // 開始行
468       
469        // ▼商品詳細取得
470        $col = <<< __EOS__
471             product_id
472            ,product_code_min
473            ,product_code_max
474            ,name
475            ,comment1
476            ,comment2
477            ,comment3
478            ,main_list_comment
479            ,main_image
480            ,main_list_image
481            ,price01_min
482            ,price01_max
483            ,price02_min
484            ,price02_max
485            ,stock_min
486            ,stock_max
487            ,stock_unlimited_min
488            ,stock_unlimited_max
489            ,point_rate
490            ,sale_limit
491            ,sale_unlimited
492            ,deliv_date_id
493            ,deliv_fee
494            ,status
495            ,product_flag
496            ,del_flg
497__EOS__;
498       
499        $from = "vw_products_allclass_detail AS alldtl";
500       
501        // WHERE 句
502        $where = '0=0';
503        if (is_array($arrProduct_id) && !empty($arrProduct_id)) {
504            $where .= ' AND product_id IN (' . implode(',', $arrProduct_id) . ')';
505        } else {
506            // 一致させない
507            $where .= ' AND 0<>0';
508        }
509       
510        //表示順序
511        switch($orderby) {
512
513            //販売価格順
514            case 'price':
515                $order = "price02_min, product_id";
516                break;
517
518            //新着順
519            case 'date':
520                $order = "create_date DESC, product_id";
521                break;
522
523            default:
524                if (strlen($where_category) >= 1) {
525                    $dtb_product_categories = "(SELECT * FROM dtb_product_categories WHERE $where_category)";
526                    $arrval_order = array_merge($arrval_category, $arrval_category);
527                } else {
528                    $dtb_product_categories = 'dtb_product_categories';
529                }
530                $order = <<< __EOS__
531                    (
532                        SELECT
533                             T3.rank
534                        FROM
535                            $dtb_product_categories T2
536                            JOIN dtb_category T3
537                                USING (category_id)
538                        WHERE T2.product_id = alldtl.product_id
539                        ORDER BY T3.rank DESC, T2.rank DESC
540                        LIMIT 1
541                    ) DESC
542                    ,(
543                        SELECT
544                            T2.rank
545                        FROM
546                            $dtb_product_categories T2
547                            JOIN dtb_category T3
548                                USING (category_id)
549                        WHERE T2.product_id = alldtl.product_id
550                        ORDER BY T3.rank DESC, T2.rank DESC
551                        LIMIT 1
552                    ) DESC
553                    ,product_id
554__EOS__;
555                break;
556        }
557       
558        // 取得範囲の指定(開始行番号、行数のセット)
559        $objQuery->setlimitoffset($disp_num, $startno);
560        // 表示順序
561        $objQuery->setorder($order);
562       
563        // 検索結果の取得
564        $this->arrProducts = $objQuery->select($col, $from, $where, $arrval_order);
565        // ▲商品詳細取得
566       
567        // 規格名一覧
568        $arrClassName = $objDb->sfGetIDValueList("dtb_class", "class_id", "name");
569        // 規格分類名一覧
570        $arrClassCatName = $objDb->sfGetIDValueList("dtb_classcategory", "classcategory_id", "name");
571        // 規格セレクトボックス設定
572        if($disp_num == 15) {
573            for($i = 0; $i < count($this->arrProducts); $i++) {
574                $this->lfMakeSelect($this->arrProducts[$i]['product_id'], $arrClassName, $arrClassCatName);
575                // 購入制限数を取得
576                $this->lfGetSaleLimit($this->arrProducts[$i]);
577            }
578        }
579    }
580
581    /* 規格セレクトボックスの作成 */
582    function lfMakeSelect($product_id, $arrClassName, $arrClassCatName) {
583
584        $classcat_find1 = false;
585        $classcat_find2 = false;
586        // 在庫ありの商品の有無
587        $stock_find = false;
588
589        // 商品規格情報の取得
590        $arrProductsClass = $this->lfGetProductsClass($product_id);
591
592        // 規格1クラス名の取得
593        $this->tpl_class_name1[$product_id] =
594            isset($arrClassName[$arrProductsClass[0]['class_id1']])
595            ? $arrClassName[$arrProductsClass[0]['class_id1']]
596            : "";
597
598        // 規格2クラス名の取得
599        $this->tpl_class_name2[$product_id] =
600            isset($arrClassName[$arrProductsClass[0]['class_id2']])
601            ? $arrClassName[$arrProductsClass[0]['class_id2']]
602            : "";
603
604        // すべての組み合わせ数
605        $count = count($arrProductsClass);
606
607        $classcat_id1 = "";
608
609        $arrSele = array();
610        $arrList = array();
611
612        $list_id = 0;
613        $arrList[0] = "\tlist". $product_id. "_0 = new Array('選択してください'";
614        $arrVal[0] = "\tval". $product_id. "_0 = new Array(''";
615
616        for ($i = 0; $i < $count; $i++) {
617            // 在庫のチェック
618            if($arrProductsClass[$i]['stock'] <= 0 && $arrProductsClass[$i]['stock_unlimited'] != '1') {
619                continue;
620            }
621
622            $stock_find = true;
623
624            // 規格1のセレクトボックス用
625            if($classcat_id1 != $arrProductsClass[$i]['classcategory_id1']){
626                $arrList[$list_id].=");\n";
627                $arrVal[$list_id].=");\n";
628                $classcat_id1 = $arrProductsClass[$i]['classcategory_id1'];
629                $arrSele[$classcat_id1] = $arrClassCatName[$classcat_id1];
630                $list_id++;
631
632                $arrList[$list_id] = "";
633                $arrVal[$list_id] = "";
634            }
635
636            // 規格2のセレクトボックス用
637            $classcat_id2 = $arrProductsClass[$i]['classcategory_id2'];
638
639            // セレクトボックス表示値
640            if($arrList[$list_id] == "") {
641                $arrList[$list_id] = "\tlist". $product_id. "_". $list_id. " = new Array('選択してください', '". $arrClassCatName[$classcat_id2]. "'";
642            } else {
643                $arrList[$list_id].= ", '".$arrClassCatName[$classcat_id2]."'";
644            }
645
646            // セレクトボックスPOST値
647            if($arrVal[$list_id] == "") {
648                $arrVal[$list_id] = "\tval". $product_id. "_". $list_id. " = new Array('', '". $classcat_id2. "'";
649            } else {
650                $arrVal[$list_id].= ", '".$classcat_id2."'";
651            }
652        }
653
654        $arrList[$list_id].=");\n";
655        $arrVal[$list_id].=");\n";
656
657        // 規格1
658        $this->arrClassCat1[$product_id] = $arrSele;
659
660        $lists = "\tlists".$product_id. " = new Array(";
661        $no = 0;
662        foreach($arrList as $val) {
663            $this->tpl_javascript.= $val;
664            if ($no != 0) {
665                $lists.= ",list". $product_id. "_". $no;
666            } else {
667                $lists.= "list". $product_id. "_". $no;
668            }
669            $no++;
670        }
671        $this->tpl_javascript.= $lists.");\n";
672
673        $vals = "\tvals".$product_id. " = new Array(";
674        $no = 0;
675        foreach($arrVal as $val) {
676            $this->tpl_javascript.= $val;
677            if ($no != 0) {
678                $vals.= ",val". $product_id. "_". $no;
679            } else {
680                $vals.= "val". $product_id. "_". $no;
681            }
682            $no++;
683        }
684        $this->tpl_javascript.= $vals.");\n";
685
686        // 選択されている規格2ID
687        $classcategory_id = "classcategory_id". $product_id;
688
689        $classcategory_id_2 = $classcategory_id . "_2";
690        if (!isset($classcategory_id_2)) $classcategory_id_2 = "";
691        if (!isset($_POST[$classcategory_id_2]) || !is_numeric($_POST[$classcategory_id_2])) $_POST[$classcategory_id_2] = "";
692
693        $this->tpl_onload .= "lnSetSelect('" . $classcategory_id ."_1', "
694            . "'" . $classcategory_id_2 . "',"
695            . "'" . $product_id . "',"
696            . "'" . $_POST[$classcategory_id_2] ."'); ";
697
698        // 規格1が設定されている
699        if($arrProductsClass[0]['classcategory_id1'] != '0') {
700            $classcat_find1 = true;
701        }
702
703        // 規格2が設定されている
704        if($arrProductsClass[0]['classcategory_id2'] != '0') {
705            $classcat_find2 = true;
706        }
707
708        $this->tpl_classcat_find1[$product_id] = $classcat_find1;
709        $this->tpl_classcat_find2[$product_id] = $classcat_find2;
710        $this->tpl_stock_find[$product_id] = $stock_find;
711    }
712
713    /* 商品規格情報の取得 */
714    function lfGetProductsClass($product_id) {
715        $arrRet = array();
716        if(SC_Utils_Ex::sfIsInt($product_id)) {
717            // 商品規格取得
718            $objQuery = new SC_Query();
719            $col = "product_class_id, classcategory_id1, classcategory_id2, class_id1, class_id2, stock, stock_unlimited";
720            $table = "vw_product_class AS prdcls";
721            $where = "product_id = ?";
722            $objQuery->setorder("rank1 DESC, rank2 DESC");
723            $arrRet = $objQuery->select($col, $table, $where, array($product_id));
724        }
725        return $arrRet;
726    }
727
728    /* 入力内容のチェック */
729    function lfCheckError($id) {
730
731        // 入力データを渡す。
732        $objErr = new SC_CheckError();
733
734        $classcategory_id1 = "classcategory_id". $id. "_1";
735        $classcategory_id2 = "classcategory_id". $id. "_2";
736        $quantity = "quantity". $id;
737        // 複数項目チェック
738        if ($this->tpl_classcat_find1[$id]) {
739            $objErr->doFunc(array("規格1", $classcategory_id1, INT_LEN), array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
740        }
741        if ($this->tpl_classcat_find2[$id]) {
742            $objErr->doFunc(array("規格2", $classcategory_id2, INT_LEN), array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
743        }
744        $objErr->doFunc(array("数量", $quantity, INT_LEN), array("EXIST_CHECK", "ZERO_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
745
746        return $objErr->arrErr;
747    }
748
749    // 購入制限数の設定
750    function lfGetSaleLimit($product) {
751        //在庫が無限または購入制限値が設定値より大きい場合
752        if($product['sale_unlimited'] == 1 || $product['sale_limit'] > SALE_LIMIT_MAX) {
753            $this->tpl_sale_limit[$product['product_id']] = SALE_LIMIT_MAX;
754        } else {
755            $this->tpl_sale_limit[$product['product_id']] = $product['sale_limit'];
756        }
757    }
758
759    //支払方法の取得
760    //payment_id    1:代金引換 2:銀行振り込み 3:現金書留
761    function lfGetPayment() {
762        $objQuery = new SC_Query;
763        $col = "payment_id, rule, payment_method";
764        $from = "dtb_payment";
765        $where = "del_flg = 0";
766        $order = "payment_id";
767        $objQuery->setorder($order);
768        $arrRet = $objQuery->select($col, $from, $where);
769        return $arrRet;
770    }
771
772    function lfconvertParam () {
773        foreach ($this->arrForm as $key => $value) {
774            if (preg_match('/^quantity[0-9]+/', $key)) {
775                 $this->arrForm[$key]
776                    = htmlspecialchars($this->arrForm[$key], ENT_QUOTES, CHAR_CODE);
777            }
778        }
779    }
780}
781?>
Note: See TracBrowser for help on using the repository browser.