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

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