source: branches/feature-module-update/data/class/pages/shopping/LC_Page_Shopping_Payment.php @ 16386

Revision 16386, 19.2 KB checked in by nanasess, 15 years ago (diff)
  • デグレ修正
  • リファクタリング
  • 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 * Copyright(c) 2000-2007 LOCKON CO.,LTD. All Rights Reserved.
4 *
5 * http://www.lockon.co.jp/
6 */
7
8// {{{ requires
9require_once(CLASS_PATH . "pages/LC_Page.php");
10
11/**
12 * 支払い方法選択 のページクラス.
13 *
14 * @package Page
15 * @author LOCKON CO.,LTD.
16 * @version $Id:LC_Page_Shopping_Payment.php 15532 2007-08-31 14:39:46Z nanasess $
17 */
18class LC_Page_Shopping_Payment extends LC_Page {
19
20    // {{{ properties
21
22    /** フォームパラメータの配列 */
23    var $objFormParam;
24
25    /** 顧客情報のインスタンス */
26    var $objCustomer;
27
28    // }}}
29    // {{{ functions
30
31    /**
32     * Page を初期化する.
33     *
34     * @return void
35     */
36    function init() {
37        parent::init();
38        $this->tpl_css = URL_DIR.'css/layout/shopping/pay.css';
39        $this->tpl_mainpage = 'shopping/payment.tpl';
40        $this->tpl_column_num = 1;
41        $this->tpl_onload = 'fnCheckInputPoint();';
42        $this->tpl_title = "お支払方法・お届け時間等の指定";
43
44        $this->allowClientCache();
45    }
46
47    /**
48     * Page のプロセス.
49     *
50     * @return void
51     */
52    function process() {
53        $objView = new SC_SiteView();
54        $objSiteSess = new SC_SiteSession();
55        $objCartSess = new SC_CartSession();
56        $objCampaignSess = new SC_CampaignSession();
57        $objDb = new SC_Helper_DB_Ex();
58        $this->objCustomer = new SC_Customer();
59        $objSiteInfo = $objView->objSiteInfo;
60        $arrInfo = $objSiteInfo->data;
61
62        // パラメータ管理クラス
63        $this->objFormParam = new SC_FormParam();
64        // パラメータ情報の初期化
65        $this->lfInitParam();
66        // POST値の取得
67        $this->objFormParam->setParam($_POST);
68
69        // ユーザユニークIDの取得と購入状態の正当性をチェック
70        $uniqid = SC_Utils_Ex::sfCheckNormalAccess($objSiteSess, $objCartSess);
71        // ユニークIDを引き継ぐ
72        $this->tpl_uniqid = $uniqid;
73
74        // 会員ログインチェック
75        if($this->objCustomer->isLoginSuccess()) {
76            $this->tpl_login = '1';
77            $this->tpl_user_point = $this->objCustomer->getValue('point');
78            //戻り先URL
79            $this->tpl_back_url = URL_DELIV_TOP;
80        } else {
81            $this->tpl_back_url = URL_SHOP_TOP . "?from=nonmember";
82        }
83
84        // 金額の取得 (購入途中で売り切れた場合にはこの関数内にてその商品の個数が0になる)
85        $objDb->sfTotalCart($this, $objCartSess, $arrInfo);
86
87        if (empty($arrData)) $arrData = array();
88        $this->arrData = $objDb->sfTotalConfirm($arrData, $this, $objCartSess, $arrInfo);
89
90        // カート内の商品の売り切れチェック
91        $objCartSess->chkSoldOut($objCartSess->getCartList());
92
93        if (!isset($_POST['mode'])) $_POST['mode'] = "";
94
95        switch($_POST['mode']) {
96        case 'confirm':
97            // 入力値の変換
98            $this->objFormParam->convParam();
99            $this->arrErr = $this->lfCheckError($this->arrData );
100            // 入力エラーなし
101            if(count($this->arrErr) == 0) {
102                // DBへのデータ登録
103                $this->lfRegistData($uniqid);
104                // 正常に登録されたことを記録しておく
105                $objSiteSess->setRegistFlag();
106                // 確認ページへ移動
107                $this->sendRedirect($this->getLocation(URL_SHOP_CONFIRM, array(), true));
108                exit;
109            }else{
110                // ユーザユニークIDの取得
111                $uniqid = $objSiteSess->getUniqId();
112                // 受注一時テーブルからの情報を格納
113                $this->lfSetOrderTempData($uniqid);
114            }
115            break;
116        // 前のページに戻る
117        case 'return':
118            // 非会員の場合
119            // 正常な推移であることを記録しておく
120            $objSiteSess->setRegistFlag();
121            $this->sendRedirect(URL_SHOP_TOP);
122            exit;
123            break;
124        // 支払い方法が変更された場合
125        case 'payment':
126            // ここのbreakは、意味があるので外さないで下さい。
127            break;
128        default:
129            // 受注一時テーブルからの情報を格納
130            $this->lfSetOrderTempData($uniqid);
131            break;
132        }
133
134        // 店舗情報の取得
135        $arrInfo = $objSiteInfo->data;
136        // 購入金額の取得得
137        $total_pretax = $objCartSess->getAllProductsTotal($arrInfo);
138        // 支払い方法の取得
139        $this->arrPayment = $this->lfGetPayment($total_pretax);
140        // 配送時間の取得
141        $arrRet = $objDb->sfGetDelivTime($this->objFormParam->getValue('payment_id'));
142        $this->arrDelivTime = SC_Utils_Ex::sfArrKeyValue($arrRet, 'time_id', 'deliv_time');
143
144        // 配送日一覧の取得
145        $this->arrDelivDate = $this->lfGetDelivDate();
146
147        $this->arrForm = $this->objFormParam->getFormParamList();
148
149        $objView->assignobj($this);
150        // フレームを選択(キャンペーンページから遷移なら変更)
151        $objCampaignSess->pageView($objView);
152    }
153
154    /**
155     * モバイルページを初期化する.
156     *
157     * @return void
158     */
159    function mobileInit() {
160        $this->init();
161    }
162
163    /**
164     * Page のプロセス(モバイル).
165     *
166     * @return void
167     */
168    function mobileProcess() {
169        $objView = new SC_MobileView();
170        $objSiteSess = new SC_SiteSession();
171        $objCartSess = new SC_CartSession();
172        $this->objCustomer = new SC_Customer();
173        $objDb = new SC_Helper_DB_Ex();
174        $objSiteInfo = $objView->objSiteInfo;
175        $arrInfo = $objSiteInfo->data;
176
177        // パラメータ管理クラス
178        $this->objFormParam = new SC_FormParam();
179        // パラメータ情報の初期化
180        $this->lfInitParam();
181        // POST値の取得
182        $this->objFormParam->setParam($_POST);
183
184        // ユーザユニークIDの取得と購入状態の正当性をチェック
185        $uniqid = SC_Utils_Ex::sfCheckNormalAccess($objSiteSess, $objCartSess);
186        // ユニークIDを引き継ぐ
187        $this->tpl_uniqid = $uniqid;
188
189        // 会員ログインチェック
190        if($this->objCustomer->isLoginSuccess(true)) {
191            $this->tpl_login = '1';
192            $this->tpl_user_point = $this->objCustomer->getValue('point');
193        }
194
195        // 金額の取得 (購入途中で売り切れた場合にはこの関数内にてその商品の個数が0になる)
196        $objDb->sfTotalCart($this, $objCartSess, $arrInfo);
197        if (empty($arrData)) $arrData = array();
198        $this->arrData = $objDb->sfTotalConfirm($arrData, $this, $objCartSess, $arrInfo);
199
200        // カー都内の商品の売り切れチェック
201        $objCartSess->chkSoldOut($objCartSess->getCartList(), true);
202
203        if (!isset($_POST['mode'])) $_POST['mode'] = "";
204
205        // 戻るボタンの処理
206        if (!empty($_POST['return'])) {
207            switch ($_POST['mode']) {
208            case 'confirm':
209                $_POST['mode'] = 'payment';
210                break;
211            default:
212                // 正常な推移であることを記録しておく
213                $objSiteSess->setRegistFlag();
214                $this->sendRedirect(MOBILE_URL_SHOP_TOP, true);
215                exit;
216            }
217        }
218
219        switch($_POST['mode']) {
220            // 支払い方法指定 → 配達日時指定
221        case 'deliv_date':
222            // 入力値の変換
223            $this->objFormParam->convParam();
224            $this->arrErr = $this->lfCheckError($this->arrData);
225            if (!isset($this->arrErr['payment_id'])) {
226                // 支払い方法の入力エラーなし
227                $this->tpl_mainpage = 'shopping/deliv_date.tpl';
228                $this->tpl_title = "配達日時指定";
229                break;
230            } else {
231                // ユーザユニークIDの取得
232                $uniqid = $objSiteSess->getUniqId();
233                // 受注一時テーブルからの情報を格納
234                $this->lfSetOrderTempData($uniqid);
235            }
236            break;
237        case 'confirm':
238            // 入力値の変換
239            $this->objFormParam->convParam();
240            $this->arrErr = $this->lfCheckError($this->arrData );
241            // 入力エラーなし
242            if(count($this->arrErr) == 0) {
243                // DBへのデータ登録
244                $this->lfRegistData($uniqid);
245                // 正常に登録されたことを記録しておく
246                $objSiteSess->setRegistFlag();
247                // 確認ページへ移動
248                $this->sendRedirect($this->getLocation(MOBILE_URL_SHOP_CONFIRM), true);
249                exit;
250            }else{
251                // ユーザユニークIDの取得
252                $uniqid = $objSiteSess->getUniqId();
253                // 受注一時テーブルからの情報を格納
254                $this->lfSetOrderTempData($uniqid);
255                if (!isset($this->arrErr['payment_id'])) {
256                    // 支払い方法の入力エラーなし
257                    $this->tpl_mainpage = 'shopping/deliv_date.tpl';
258                    $this->tpl_title = "配達日時指定";
259                }
260            }
261            break;
262            // 前のページに戻る
263        case 'return':
264            // 非会員の場合
265            // 正常な推移であることを記録しておく
266            $objSiteSess->setRegistFlag();
267            $this->sendRedirect(MOBILE_URL_SHOP_TOP, true);
268            exit;
269            break;
270            // 支払い方法が変更された場合
271        case 'payment':
272            // ここのbreakは、意味があるので外さないで下さい。
273            break;
274        default:
275            // 受注一時テーブルからの情報を格納
276            $this->lfSetOrderTempData($uniqid);
277            break;
278        }
279
280        // 店舗情報の取得
281        $arrInfo = $objSiteInfo->data;
282        // 購入金額の取得得
283        $total_pretax = $objCartSess->getAllProductsTotal($arrInfo);
284        // 支払い方法の取得
285        $this->arrPayment = $this->lfGetPayment($total_pretax);
286        // 配送時間の取得
287        $arrRet = $objDb->sfGetDelivTime($this->objFormParam->getValue('payment_id'));
288        $this->arrDelivTime = SC_Utils_Ex::sfArrKeyValue($arrRet, 'time_id', 'deliv_time');
289
290        // 配送日一覧の取得
291        $this->arrDelivDate = $this->lfGetDelivDate();
292
293        $this->arrForm = $this->objFormParam->getFormParamList();
294
295        $objView->assignobj($this);
296        $objView->display(SITE_FRAME);
297    }
298
299    /**
300     * デストラクタ.
301     *
302     * @return void
303     */
304    function destroy() {
305        parent::destroy();
306    }
307
308    /* パラメータ情報の初期化 */
309    function lfInitParam() {
310        $this->objFormParam->addParam("お支払い方法", "payment_id", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
311        $this->objFormParam->addParam("ポイント", "use_point", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK", "ZERO_START"));
312        $this->objFormParam->addParam("配達時間", "deliv_time_id", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
313        $this->objFormParam->addParam("ご質問", "message", LTEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
314        $this->objFormParam->addParam("ポイントを使用する", "point_check", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), '2');
315        $this->objFormParam->addParam("配達日", "deliv_date", STEXT_LEN, "KVa", array("MAX_LENGTH_CHECK"));
316    }
317
318    function lfGetPayment($total_pretax) {
319        $objQuery = new SC_Query();
320        $objQuery->setorder("rank DESC");
321        //削除されていない支払方法を取得
322        $arrRet = $objQuery->select("payment_id, payment_method, rule, upper_rule, note, payment_image", "dtb_payment", "del_flg = 0 AND deliv_id IN (SELECT deliv_id FROM dtb_deliv WHERE del_flg = 0) ");
323        //利用条件から支払可能方法を判定
324        foreach($arrRet as $data) {
325            //下限と上限が設定されている
326            if($data['rule'] > 0 && $data['upper_rule'] > 0) {
327                if($data['rule'] <= $total_pretax && $data['upper_rule'] >= $total_pretax) {
328                    $arrPayment[] = $data;
329                }
330            //下限のみ設定されている
331            } elseif($data['rule'] > 0) {
332                if($data['rule'] <= $total_pretax) {
333                    $arrPayment[] = $data;
334                }
335            //上限のみ設定されている
336            } elseif($data['upper_rule'] > 0) {
337                if($data['upper_rule'] >= $total_pretax) {
338                    $arrPayment[] = $data;
339                }
340            //設定なし
341            } else {
342                $arrPayment[] = $data;
343            }
344        }
345        return $arrPayment;
346    }
347
348    /* 入力内容のチェック */
349    function lfCheckError($arrData) {
350        // 入力データを渡す。
351        $arrRet =  $this->objFormParam->getHashArray();
352        $objErr = new SC_CheckError($arrRet);
353        $objErr->arrErr = $this->objFormParam->checkError();
354
355        if (!isset($_POST['point_check'])) $_POST['point_check'] = "";
356
357        if($_POST['point_check'] == '1') {
358            $objErr->doFunc(array("ポイントを使用する", "point_check"), array("EXIST_CHECK"));
359            $objErr->doFunc(array("ポイント", "use_point"), array("EXIST_CHECK"));
360            $max_point = $this->objCustomer->getValue('point');
361            if($max_point == "") {
362                $max_point = 0;
363            }
364            // FIXME mobile 互換のため br は閉じない...
365            if($arrRet['use_point'] > $max_point) {
366                $objErr->arrErr['use_point'] = "※ ご利用ポイントが所持ポイントを超えています。<br>";
367            }
368            if(($arrRet['use_point'] * POINT_VALUE) > $arrData['subtotal']) {
369                $objErr->arrErr['use_point'] = "※ ご利用ポイントがご購入金額を超えています。<br>";
370            }
371        }
372        return $objErr->arrErr;
373    }
374
375    /* 支払い方法文字列の取得 */
376    function lfGetPaymentInfo($payment_id) {
377        $objQuery = new SC_Query();
378        $where = "payment_id = ?";
379        $arrRet = $objQuery->select("payment_method, charge", "dtb_payment", $where, array($payment_id));
380        return (array($arrRet[0]['payment_method'], $arrRet[0]['charge']));
381    }
382
383    /* 配送時間文字列の取得 */
384    function lfGetDelivTimeInfo($time_id) {
385        $objQuery = new SC_Query();
386        $where = "time_id = ?";
387        $arrRet = $objQuery->select("deliv_id, deliv_time", "dtb_delivtime", $where, array($time_id));
388        return (array($arrRet[0]['deliv_id'], $arrRet[0]['deliv_time']));
389    }
390
391    /* DBへデータの登録 */
392    function lfRegistData($uniqid) {
393        $arrRet = $this->objFormParam->getHashArray();
394        $sqlval = $this->objFormParam->getDbArray();
395        // 登録データの作成
396        $sqlval['order_temp_id'] = $uniqid;
397        $sqlval['update_date'] = 'Now()';
398
399        if($sqlval['payment_id'] != "") {
400            list($sqlval['payment_method'], $sqlval['charge']) = $this->lfGetPaymentInfo($sqlval['payment_id']);
401        } else {
402            $sqlval['payment_id'] = '0';
403            $sqlval['payment_method'] = "";
404        }
405
406        if($sqlval['deliv_time_id'] != "") {
407            list($sqlval['deliv_id'], $sqlval['deliv_time']) = $this->lfGetDelivTimeInfo($sqlval['deliv_time_id']);
408        } else {
409            $sqlval['deliv_time_id'] = '0';
410            $sqlval['deliv_id'] = '0';
411            $sqlval['deliv_time'] = "";
412        }
413
414        // 使用ポイントの設定
415        if($sqlval['point_check'] != '1') {
416            $sqlval['use_point'] = 0;
417        }
418
419        $objDb = new SC_Helper_DB_Ex();
420        $objDb->sfRegistTempOrder($uniqid, $sqlval);
421    }
422
423    /* 配達日一覧を取得する */
424    function lfGetDelivDate() {
425        $objCartSess = new SC_CartSession();
426        $objQuery = new SC_Query();
427        // 商品IDの取得
428        $max = $objCartSess->getMax();
429        for($i = 1; $i <= $max; $i++) {
430            if($_SESSION[$objCartSess->key][$i]['id'][0] != "") {
431                $arrID['product_id'][$i] = $_SESSION[$objCartSess->key][$i]['id'][0];
432            }
433        }
434        if(count($arrID['product_id']) > 0) {
435            $id = implode(",", $arrID['product_id']);
436            //商品から発送目安の取得
437            $deliv_date = $objQuery->get("dtb_products", "MAX(deliv_date_id)", "product_id IN (".$id.")");
438            //発送目安
439            switch($deliv_date) {
440            //即日発送
441            case '1':
442                $start_day = 1;
443                break;
444            //1-2日後
445            case '2':
446                $start_day = 3;
447                break;
448            //3-4日後
449            case '3':
450                $start_day = 5;
451                break;
452            //1週間以内
453            case '4':
454                $start_day = 8;
455                break;
456            //2週間以内
457            case '5':
458                $start_day = 15;
459                break;
460            //3週間以内
461            case '6':
462                $start_day = 22;
463                break;
464            //1ヶ月以内
465            case '7':
466                $start_day = 32;
467                break;
468            //2ヶ月以降
469            case '8':
470                $start_day = 62;
471                break;
472            //お取り寄せ(商品入荷後)
473            case '9':
474                $start_day = "";
475                break;
476            default:
477                //お届け日が設定されていない場合
478                $start_day = "";
479                break;
480            }
481            //配達可能日のスタート値から、配達日の配列を取得する
482            $arrDelivDate = $this->lfGetDateArray($start_day, DELIV_DATE_END_MAX);
483        }
484        return $arrDelivDate;
485    }
486
487    //配達可能日のスタート値から、配達日の配列を取得する
488    function lfGetDateArray($start_day, $end_day) {
489        $masterData = new SC_DB_MasterData();
490        $arrWDAY = $masterData->getMasterData("mtb_wday");
491        //配達可能日のスタート値がセットされていれば
492        if($start_day >= 1) {
493            $now_time = time();
494            $max_day = $start_day + $end_day;
495            // 集計
496            for ($i = $start_day; $i < $max_day; $i++) {
497                // 基本時間から日数を追加していく
498                $tmp_time = $now_time + ($i * 24 * 3600);
499                list($y, $m, $d, $w) = split(" ", date("y m d w", $tmp_time));
500                $val = sprintf("%02d/%02d/%02d(%s)", $y, $m, $d, $arrWDAY[$w]);
501                $arrDate[$val] = $val;
502            }
503        } else {
504            $arrDate = false;
505        }
506        return $arrDate;
507    }
508
509    //一時受注テーブルからの情報を格納する
510    function lfSetOrderTempData($uniqid) {
511
512        $objQuery = new SC_Query();
513        $col = "payment_id, use_point, deliv_time_id, message, point_check, deliv_date";
514        $from = "dtb_order_temp";
515        $where = "order_temp_id = ?";
516        $arrRet = $objQuery->select($col, $from, $where, array($uniqid));
517        // DB値の取得
518        $this->objFormParam->setParam($arrRet[0]);
519        return $this->objFormParam;
520    }
521}
522?>
Note: See TracBrowser for help on using the repository browser.