source: branches/version-2_12-dev/data/class/helper/SC_Helper_Purchase.php @ 22567

Revision 22567, 48.8 KB checked in by shutta, 9 years ago (diff)

#2043 (typo修正・ソース整形・ソースコメントの改善 for 2.12.4)
Zend Framework PHP 標準コーディング規約のコーディングスタイルへ準拠。
classおよびfunctionの開始波括弧「{」のスタイルを修正。

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
  • 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-2013 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/**
25 * 商品購入関連のヘルパークラス.
26 *
27 * TODO 購入時強制会員登録機能(#521)の実装を検討
28 * TODO dtb_customer.buy_times, dtb_customer.buy_total の更新
29 *
30 * @package Helper
31 * @author Kentaro Ohkouchi
32 * @version $Id$
33 */
34class SC_Helper_Purchase
35{
36
37    var $arrShippingKey = array(
38        'name01', 'name02', 'kana01', 'kana02',
39        'sex', 'zip01', 'zip02', 'pref', 'addr01', 'addr02',
40        'tel01', 'tel02', 'tel03', 'fax01', 'fax02', 'fax03',
41    );
42
43    /**
44     * 受注を完了する.
45     *
46     * 下記のフローで受注を完了する.
47     *
48     * 1. トランザクションを開始する
49     * 2. カートの内容を検証する.
50     * 3. 受注一時テーブルから受注データを読み込む
51     * 4. ユーザーがログインしている場合はその他の発送先へ登録する
52     * 5. 受注データを受注テーブルへ登録する
53     * 6. トランザクションをコミットする
54     *
55     * 実行中に, 何らかのエラーが発生した場合, 処理を中止しエラーページへ遷移する
56     *
57     * 決済モジュールを使用する場合は対応状況を「決済処理中」に設定し,
58     * 決済完了後「新規受付」に変更すること
59     *
60     * @param integer $orderStatus 受注処理を完了する際に設定する対応状況
61     * @return void
62     */
63    function completeOrder($orderStatus = ORDER_NEW)
64    {
65        $objQuery =& SC_Query_Ex::getSingletonInstance();
66        $objSiteSession = new SC_SiteSession_Ex();
67        $objCartSession = new SC_CartSession_Ex();
68        $objCustomer = new SC_Customer_Ex();
69        $customerId = $objCustomer->getValue('customer_id');
70
71        $objQuery->begin();
72        if (!$objSiteSession->isPrePage()) {
73            SC_Utils_Ex::sfDispSiteError(PAGE_ERROR, $objSiteSession);
74        }
75
76        $uniqId = $objSiteSession->getUniqId();
77        $this->verifyChangeCart($uniqId, $objCartSession);
78
79        $orderTemp = $this->getOrderTemp($uniqId);
80
81        $orderTemp['status'] = $orderStatus;
82        $cartkey = $objCartSession->getKey();
83        $order_id = $this->registerOrderComplete($orderTemp, $objCartSession, $cartkey);
84        $isMultiple = SC_Helper_Purchase::isMultiple();
85        $shippingTemp =& $this->getShippingTemp($isMultiple);
86        foreach ($shippingTemp as $shippingId => $val) {
87            $this->registerShipmentItem($order_id, $shippingId, $val['shipment_item']);
88        }
89
90        $this->registerShipping($order_id, $shippingTemp);
91        $objQuery->commit();
92
93        //会員情報の最終購入日、購入合計を更新
94        if ($customerId > 0) {
95            SC_Customer_Ex::updateOrderSummary($customerId);
96        }
97
98        $this->cleanupSession($order_id, $objCartSession, $objCustomer, $cartkey);
99
100        GC_Utils_Ex::gfPrintLog('order complete. order_id=' . $order_id);
101    }
102
103    /**
104     * 受注をキャンセルする.
105     *
106     * 受注完了後の受注をキャンセルする.
107     * この関数は, 主に決済モジュールにて, 受注をキャンセルする場合に使用する.
108     *
109     * 対応状況を引数 $orderStatus で指定した値に変更する.
110     * (デフォルト ORDER_CANCEL)
111     * 引数 $is_delete が true の場合は, 受注データを論理削除する.
112     * 商品の在庫数は, 受注前の在庫数に戻される.
113     *
114     * @param integer $order_id 受注ID
115     * @param integer $orderStatus 対応状況
116     * @param boolean $is_delete 受注データを論理削除する場合 true
117     * @return void
118     */
119    function cancelOrder($order_id, $orderStatus = ORDER_CANCEL, $is_delete = false)
120    {
121        $objQuery =& SC_Query_Ex::getSingletonInstance();
122        $in_transaction = $objQuery->inTransaction();
123        if (!$in_transaction) {
124            $objQuery->begin();
125        }
126
127        $arrParams = array();
128        $arrParams['status'] = $orderStatus;
129        if ($is_delete) {
130            $arrParams['del_flg'] = 1;
131        }
132
133        $this->registerOrder($order_id, $arrParams);
134
135        $arrOrderDetail = $this->getOrderDetail($order_id);
136        foreach ($arrOrderDetail as $arrDetail) {
137            $objQuery->update('dtb_products_class', array(),
138                              'product_class_id = ?', array($arrDetail['product_class_id']),
139                              array('stock' => 'stock + ?'), array($arrDetail['quantity']));
140        }
141        if (!$in_transaction) {
142            $objQuery->commit();
143        }
144    }
145
146    /**
147     * 受注をキャンセルし, カートをロールバックして, 受注一時IDを返す.
148     *
149     * 受注完了後の受注をキャンセルし, カートの状態を受注前の状態へ戻す.
150     * この関数は, 主に, 決済モジュールに遷移した後, 購入確認画面へ戻る場合に使用する.
151     *
152     * 対応状況を引数 $orderStatus で指定した値に変更する.
153     * (デフォルト ORDER_CANCEL)
154     * 引数 $is_delete が true の場合は, 受注データを論理削除する.
155     * 商品の在庫数, カートの内容は受注前の状態に戻される.
156     *
157     * @param integer $order_id 受注ID
158     * @param integer $orderStatus 対応状況
159     * @param boolean $is_delete 受注データを論理削除する場合 true
160     * @return string 受注一時ID
161     */
162    function rollbackOrder($order_id, $orderStatus = ORDER_CANCEL, $is_delete = false)
163    {
164        $objQuery =& SC_Query_Ex::getSingletonInstance();
165        $in_transaction = $objQuery->inTransaction();
166        if (!$in_transaction) {
167            $objQuery->begin();
168        }
169
170        $this->cancelOrder($order_id, $orderStatus, $is_delete);
171        $arrOrderTemp = $this->getOrderTempByOrderId($order_id);
172        $_SESSION = array_merge($_SESSION, unserialize($arrOrderTemp['session']));
173
174        $objSiteSession = new SC_SiteSession_Ex();
175        $objCartSession = new SC_CartSession_Ex();
176        $objCustomer = new SC_Customer_Ex();
177
178        // 新たに受注一時情報を保存する
179        $objSiteSession->unsetUniqId();
180        $uniqid = $objSiteSession->getUniqId();
181        $arrOrderTemp['del_flg'] = 0;
182        $this->saveOrderTemp($uniqid, $arrOrderTemp, $objCustomer);
183        $this->verifyChangeCart($uniqid, $objCartSession);
184        $objSiteSession->setRegistFlag();
185
186        if (!$in_transaction) {
187            $objQuery->commit();
188        }
189        return $uniqid;
190    }
191
192    /**
193     * カートに変化が無いか検証する.
194     *
195     * ユニークIDとセッションのユニークIDを比較し, 異なる場合は
196     * エラー画面を表示する.
197     *
198     * カートが空の場合, 購入ボタン押下後にカートが変更された場合は
199     * カート画面へ遷移する.
200     *
201     * @param string $uniqId ユニークID
202     * @param SC_CartSession $objCartSession
203     * @return void
204     */
205    function verifyChangeCart($uniqId, &$objCartSession)
206    {
207        $cartKey = $objCartSession->getKey();
208
209        // カート内が空でないか
210        if (SC_Utils_Ex::isBlank($cartKey)) {
211            SC_Response_Ex::sendRedirect(CART_URLPATH);
212            exit;
213        }
214
215        // 初回のみカートの内容を保存
216        $objCartSession->saveCurrentCart($uniqId, $cartKey);
217
218        /*
219         * POSTのユニークIDとセッションのユニークIDを比較
220         *(ユニークIDがPOSTされていない場合はスルー)
221         */
222        if (!SC_SiteSession_Ex::checkUniqId()) {
223            SC_Utils_Ex::sfDispSiteError(CANCEL_PURCHASE);
224            exit;
225        }
226
227        // 購入ボタンを押してから変化がないか
228        $quantity = $objCartSession->getTotalQuantity($cartKey);
229        if ($objCartSession->checkChangeCart($cartKey) || !($quantity > 0)) {
230            SC_Response_Ex::sendRedirect(CART_URLPATH);
231            exit;
232        }
233    }
234
235    /**
236     * 受注一時情報を取得する.
237     *
238     * @param integer $uniqId 受注一時情報ID
239     * @return array 受注一時情報の配列
240     */
241    function getOrderTemp($uniqId)
242    {
243        $objQuery =& SC_Query_Ex::getSingletonInstance();
244        return $objQuery->getRow('*', 'dtb_order_temp', 'order_temp_id = ?', array($uniqId));
245    }
246
247    /**
248     * 受注IDをキーにして受注一時情報を取得する.
249     *
250     * @param integer $order_id 受注ID
251     * @return array 受注一時情報の配列
252     */
253    function getOrderTempByOrderId($order_id)
254    {
255        $objQuery =& SC_Query_Ex::getSingletonInstance();
256        return $objQuery->getRow('*', 'dtb_order_temp', 'order_id = ?', array($order_id));
257    }
258
259    /**
260     * 受注一時情報を保存する.
261     *
262     * 既存のデータが存在しない場合は新規保存. 存在する場合は更新する.
263     *
264     * @param integer $uniqId 受注一時情報ID
265     * @param array $params 登録する受注情報の配列
266     * @param SC_Customer $objCustomer SC_Customer インスタンス
267     * @return void
268     */
269    function saveOrderTemp($uniqId, $params, &$objCustomer = NULL)
270    {
271        if (SC_Utils_Ex::isBlank($uniqId)) {
272            return;
273        }
274        $params['device_type_id'] = SC_Display_Ex::detectDevice();
275        $objQuery =& SC_Query_Ex::getSingletonInstance();
276        // 存在するカラムのみを対象とする
277        $cols = $objQuery->listTableFields('dtb_order_temp');
278        $sqlval = array();
279        foreach ($params as $key => $val) {
280            if (in_array($key, $cols)) {
281                $sqlval[$key] = $val;
282            }
283        }
284
285        $sqlval['session'] = serialize($_SESSION);
286        if (!empty($objCustomer)) {
287            // 注文者の情報を常に最新に保つ
288            $this->copyFromCustomer($sqlval, $objCustomer);
289        }
290        $exists = $this->getOrderTemp($uniqId);
291        if (SC_Utils_Ex::isBlank($exists)) {
292            $sqlval['order_temp_id'] = $uniqId;
293            $sqlval['create_date'] = 'CURRENT_TIMESTAMP';
294            $objQuery->insert('dtb_order_temp', $sqlval);
295        } else {
296            $objQuery->update('dtb_order_temp', $sqlval, 'order_temp_id = ?', array($uniqId));
297        }
298    }
299
300    /**
301     * 配送情報をセッションから取得する.
302     *
303     * @param bool $has_shipment_item 配送商品を保有している配送先のみ返す。
304     */
305    function getShippingTemp($has_shipment_item = false)
306    {
307        if ($has_shipment_item) {
308            $arrReturn = array();
309            foreach ($_SESSION['shipping'] as $key => $arrVal) {
310                if (count($arrVal['shipment_item']) == 0) continue;
311                $arrReturn[$key] = $arrVal;
312            }
313            return $arrReturn;
314        }
315
316        return $_SESSION['shipping'];
317    }
318
319    /**
320     * 配送商品をクリア(消去)する
321     *
322     * @param integer $shipping_id 配送先ID
323     * @return void
324     */
325    function clearShipmentItemTemp($shipping_id = null)
326    {
327        if (is_null($shipping_id)) {
328            foreach ($_SESSION['shipping'] as $key => $value) {
329                $this->clearShipmentItemTemp($key);
330            }
331        } else {
332            if (!isset($_SESSION['shipping'][$shipping_id])) return;
333            if (!is_array($_SESSION['shipping'][$shipping_id])) return;
334            unset($_SESSION['shipping'][$shipping_id]['shipment_item']);
335        }
336    }
337
338    /**
339     * 配送商品を設定する.
340     *
341     * @param integer $shipping_id 配送先ID
342     * @param integer $product_class_id 商品規格ID
343     * @param integer $quantity 数量
344     * @return void
345     */
346    function setShipmentItemTemp($shipping_id, $product_class_id, $quantity)
347    {
348        // 配列が長くなるので, リファレンスを使用する
349        $arrItems =& $_SESSION['shipping'][$shipping_id]['shipment_item'][$product_class_id];
350
351        $arrItems['shipping_id'] = $shipping_id;
352        $arrItems['product_class_id'] = $product_class_id;
353        $arrItems['quantity'] = $quantity;
354
355        $objProduct = new SC_Product_Ex();
356
357        // カート情報から読みこめば済むと思うが、一旦保留。むしろ、カート情報も含め、セッション情報を縮小すべきかもしれない。
358        /*
359        $objCartSession = new SC_CartSession_Ex();
360        $cartKey = $objCartSession->getKey();
361        // 詳細情報を取得
362        $cartItems = $objCartSession->getCartList($cartKey);
363        */
364
365        if (empty($arrItems['productsClass'])) {
366            $product =& $objProduct->getDetailAndProductsClass($product_class_id);
367            $arrItems['productsClass'] = $product;
368        }
369        $arrItems['price'] = $arrItems['productsClass']['price02'];
370        $inctax = SC_Helper_DB_Ex::sfCalcIncTax($arrItems['price']);
371        $arrItems['total_inctax'] = $inctax * $arrItems['quantity'];
372    }
373
374    /**
375     * 配送先都道府県の配列を返す.
376     */
377    function getShippingPref($is_multiple)
378    {
379        $results = array();
380        foreach (SC_Helper_Purchase_Ex::getShippingTemp($is_multiple) as $val) {
381            $results[] = $val['shipping_pref'];
382        }
383        return $results;
384    }
385
386    /**
387     * 複数配送指定の購入かどうか.
388     *
389     * @return boolean 複数配送指定の購入の場合 true
390     */
391    function isMultiple()
392    {
393        return count(SC_Helper_Purchase_Ex::getShippingTemp(true)) >= 2;
394    }
395
396    /**
397     * 配送情報をセッションに保存する.
398     *
399     * XXX マージする理由が不明(なんとなく便利な気はするけど)。分かる方コメントに残してください。
400     * @param array $arrSrc 配送情報の連想配列
401     * @param integer $shipping_id 配送先ID
402     * @return void
403     */
404    function saveShippingTemp($arrSrc, $shipping_id = 0)
405    {
406        // 配送商品は引き継がない
407        unset($arrSrc['shipment_item']);
408
409        if (!isset($_SESSION['shipping'][$shipping_id])) {
410            $_SESSION['shipping'][$shipping_id] = array();
411        }
412        $_SESSION['shipping'][$shipping_id] = array_merge($_SESSION['shipping'][$shipping_id], $arrSrc);
413        $_SESSION['shipping'][$shipping_id]['shipping_id'] = $shipping_id;
414    }
415
416    /**
417     * セッションの配送情報を破棄する.
418     *
419     * @deprecated 2.12.0 から EC-CUBE 本体では使用していない。
420     * @param integer $shipping_id 配送先ID
421     * @return void
422     */
423    function unsetShippingTemp()
424    {
425        SC_Helper_Purchase_Ex::unsetAllShippingTemp(true);
426    }
427
428    /**
429     * セッションの配送情報を全て破棄する
430     *
431     * @param bool $multiple_temp 複数お届け先の画面戻り処理用の情報も破棄するか
432     * @return void
433     */
434    static function unsetAllShippingTemp($multiple_temp = false)
435    {
436        unset($_SESSION['shipping']);
437        if ($multiple_temp) {
438            unset($_SESSION['multiple_temp']);
439        }
440    }
441
442    /**
443     * セッションの配送情報を個別に破棄する
444     *
445     * @param integer $shipping_id 配送先ID
446     * @return void
447     */
448    static function unsetOneShippingTemp($shipping_id)
449    {
450        unset($_SESSION['shipping'][$shipping_id]);
451    }
452
453    /**
454     * 会員情報を受注情報にコピーする.
455     *
456     * ユーザーがログインしていない場合は何もしない.
457     * 会員情報を $dest の order_* へコピーする.
458     * customer_id は強制的にコピーされる.
459     *
460     * @param array $dest コピー先の配列
461     * @param SC_Customer $objCustomer SC_Customer インスタンス
462     * @param string $prefix コピー先の接頭辞. デフォルト order
463     * @param array $keys コピー対象のキー
464     * @return void
465     */
466    function copyFromCustomer(&$dest, &$objCustomer, $prefix = 'order',
467        $keys = array('name01', 'name02', 'kana01', 'kana02',
468            'sex', 'zip01', 'zip02', 'pref', 'addr01', 'addr02',
469            'tel01', 'tel02', 'tel03', 'fax01', 'fax02', 'fax03',
470            'job', 'birth', 'email',
471        )
472    ) {
473        if ($objCustomer->isLoginSuccess(true)) {
474
475            foreach ($keys as $key) {
476                if (in_array($key, $keys)) {
477                    $dest[$prefix . '_' . $key] = $objCustomer->getValue($key);
478                }
479            }
480
481            if ((SC_Display_Ex::detectDevice() == DEVICE_TYPE_MOBILE)
482                && in_array('email', $keys)
483            ) {
484                $email_mobile = $objCustomer->getValue('email_mobile');
485                if (empty($email_mobile)) {
486                    $dest[$prefix . '_email'] = $objCustomer->getValue('email');
487                } else {
488                    $dest[$prefix . '_email'] = $email_mobile;
489                }
490            }
491
492            $dest['customer_id'] = $objCustomer->getValue('customer_id');
493            $dest['update_date'] = 'CURRENT_TIMESTAMP';
494        }
495    }
496
497    /**
498     * 受注情報を配送情報にコピーする.
499     *
500     * 受注情報($src)を $dest の order_* へコピーする.
501     *
502     * TODO 汎用的にして SC_Utils へ移動
503     *
504     * @param array $dest コピー先の配列
505     * @param array $src コピー元の配列
506     * @param array $arrKey コピー対象のキー
507     * @param string $prefix コピー先の接頭辞. デフォルト shipping
508     * @param string $src_prefix コピー元の接頭辞. デフォルト order
509     * @return void
510     */
511    function copyFromOrder(&$dest, $src, $prefix = 'shipping', $src_prefix = 'order', $arrKey = null)
512    {
513        if (is_null($arrKey)) {
514            $arrKey = $this->arrShippingKey;
515        }
516        if (!SC_Utils_Ex::isBlank($prefix)) {
517            $prefix = $prefix . '_';
518        }
519        if (!SC_Utils_Ex::isBlank($src_prefix)) {
520            $src_prefix = $src_prefix . '_';
521        }
522        foreach ($arrKey as $key) {
523            if (isset($src[$src_prefix . $key])) {
524                $dest[$prefix . $key] = $src[$src_prefix . $key];
525            }
526        }
527    }
528
529    /**
530     * 配送情報のみ抜き出す。
531     *
532     * @param string $arrSrc 元となる配列
533     * @return void
534     */
535    function extractShipping($arrSrc)
536    {
537        $arrKey = array();
538        foreach ($this->arrShippingKey as $key) {
539            $arrKey[] = 'shipping_' . $key;
540        }
541        return SC_Utils_Ex::sfArrayIntersectKeys($arrSrc, $arrKey);
542    }
543
544    /**
545     * 購入金額に応じた支払方法を取得する.
546     *
547     * @param integer $total 購入金額
548     * @param integer $deliv_id 配送業者ID
549     * @return array 購入金額に応じた支払方法の配列
550     */
551    function getPaymentsByPrice($total, $deliv_id)
552    {
553
554        $arrPaymentIds = SC_Helper_Delivery_Ex::getPayments($deliv_id);
555        if (SC_Utils_Ex::isBlank($arrPaymentIds)) {
556            return array();
557        }
558
559        $objQuery =& SC_Query_Ex::getSingletonInstance();
560
561        // 削除されていない支払方法を取得
562        $where = 'del_flg = 0 AND payment_id IN (' . SC_Utils_Ex::repeatStrWithSeparator('?', count($arrPaymentIds)) . ')';
563        $objQuery->setOrder('rank DESC');
564        $payments = $objQuery->select('payment_id, payment_method, rule_max, upper_rule, note, payment_image, charge', 'dtb_payment', $where, $arrPaymentIds);
565        $arrPayment = array();
566        foreach ($payments as $data) {
567            // 下限と上限が設定されている
568            if (strlen($data['rule_max']) != 0 && strlen($data['upper_rule']) != 0) {
569                if ($data['rule_max'] <= $total && $data['upper_rule'] >= $total) {
570                    $arrPayment[] = $data;
571                }
572            }
573            // 下限のみ設定されている
574            elseif (strlen($data['rule_max']) != 0) {
575                if ($data['rule_max'] <= $total) {
576                    $arrPayment[] = $data;
577                }
578            }
579            // 上限のみ設定されている
580            elseif (strlen($data['upper_rule']) != 0) {
581                if ($data['upper_rule'] >= $total) {
582                    $arrPayment[] = $data;
583                }
584            }
585            // いずれも設定なし
586            else {
587                $arrPayment[] = $data;
588            }
589        }
590        return $arrPayment;
591    }
592
593    /**
594     * お届け日一覧を取得する.
595     */
596    function getDelivDate(&$objCartSess, $productTypeId)
597    {
598        $cartList = $objCartSess->getCartList($productTypeId);
599        $delivDateIds = array();
600        foreach ($cartList as $item) {
601            $delivDateIds[] = $item['productsClass']['deliv_date_id'];
602        }
603        $max_date = max($delivDateIds);
604        //発送目安
605        switch ($max_date) {
606            //即日発送
607            case '1':
608                $start_day = 1;
609                break;
610                //1-2日後
611            case '2':
612                $start_day = 3;
613                break;
614                //3-4日後
615            case '3':
616                $start_day = 5;
617                break;
618                //1週間以内
619            case '4':
620                $start_day = 8;
621                break;
622                //2週間以内
623            case '5':
624                $start_day = 15;
625                break;
626                //3週間以内
627            case '6':
628                $start_day = 22;
629                break;
630                //1ヶ月以内
631            case '7':
632                $start_day = 32;
633                break;
634                //2ヶ月以降
635            case '8':
636                $start_day = 62;
637                break;
638                //お取り寄せ(商品入荷後)
639            case '9':
640                $start_day = '';
641                break;
642            default:
643                //お届け日が設定されていない場合
644                $start_day = '';
645                break;
646        }
647        //お届け可能日のスタート値から、お届け日の配列を取得する
648        $arrDelivDate = $this->getDateArray($start_day, DELIV_DATE_END_MAX);
649        return $arrDelivDate;
650    }
651
652    /**
653     * お届け可能日のスタート値から, お届け日の配列を取得する.
654     */
655    function getDateArray($start_day, $end_day)
656    {
657        $masterData = new SC_DB_MasterData_Ex();
658        $arrWDAY = $masterData->getMasterData('mtb_wday');
659        //お届け可能日のスタート値がセットされていれば
660        if ($start_day >= 1) {
661            $now_time = time();
662            $max_day = $start_day + $end_day;
663            // 集計
664            for ($i = $start_day; $i < $max_day; $i++) {
665                // 基本時間から日数を追加していく
666                $tmp_time = $now_time + ($i * 24 * 3600);
667                list($y, $m, $d, $w) = explode(' ', date('Y m d w', $tmp_time));
668                $val = sprintf('%04d/%02d/%02d(%s)', $y, $m, $d, $arrWDAY[$w]);
669                $arrDate[$val] = $val;
670            }
671        } else {
672            $arrDate = false;
673        }
674        return $arrDate;
675    }
676
677    /**
678     * 配送情報の登録を行う.
679     *
680     * $arrParam のうち, dtb_shipping テーブルに存在するカラムのみを登録する.
681     *
682     * TODO UPDATE/INSERT にする
683     *
684     * @param integer $order_id 受注ID
685     * @param array $arrParams 配送情報の連想配列
686     * @param boolean $convert_shipping_date yyyy/mm/dd(EEE) 形式の配送日付を変換する場合 true
687     * @return void
688     */
689    function registerShipping($order_id, $arrParams, $convert_shipping_date = true)
690    {
691        $objQuery =& SC_Query_Ex::getSingletonInstance();
692        $table = 'dtb_shipping';
693        $where = 'order_id = ?';
694        $objQuery->delete($table, $where, array($order_id));
695
696        foreach ($arrParams as $key => $arrShipping) {
697
698            $arrValues = $objQuery->extractOnlyColsOf($table, $arrShipping);
699
700            // 配送日付を timestamp に変換
701            if (!SC_Utils_Ex::isBlank($arrValues['shipping_date'])
702                && $convert_shipping_date) {
703                $d = mb_strcut($arrValues['shipping_date'], 0, 10);
704                $arrDate = explode('/', $d);
705                $ts = mktime(0, 0, 0, $arrDate[1], $arrDate[2], $arrDate[0]);
706                $arrValues['shipping_date'] = date('Y-m-d', $ts);
707            }
708
709            // 非会員購入の場合は shipping_id が存在しない
710            if (!isset($arrValues['shipping_id'])) {
711                $arrValues['shipping_id'] = $key;
712            }
713            $arrValues['order_id'] = $order_id;
714            $arrValues['create_date'] = 'CURRENT_TIMESTAMP';
715            $arrValues['update_date'] = 'CURRENT_TIMESTAMP';
716            $objQuery->insert($table, $arrValues);
717        }
718    }
719
720    /**
721     * 配送商品を登録する.
722     *
723     * @param integer $order_id 受注ID
724     * @param integer $shipping_id 配送先ID
725     * @param array $arrParams 配送商品の配列
726     * @return void
727     */
728    function registerShipmentItem($order_id, $shipping_id, $arrParams)
729    {
730        $objQuery =& SC_Query_Ex::getSingletonInstance();
731        $table = 'dtb_shipment_item';
732        $where = 'order_id = ? AND shipping_id = ?';
733        $objQuery->delete($table, $where, array($order_id, $shipping_id));
734
735        $objProduct = new SC_Product_Ex();
736        foreach ($arrParams as $arrValues) {
737            if (SC_Utils_Ex::isBlank($arrValues['product_class_id'])) {
738                continue;
739            }
740            $d = $objProduct->getDetailAndProductsClass($arrValues['product_class_id']);
741            $name = SC_Utils_Ex::isBlank($arrValues['product_name'])
742                ? $d['name']
743                : $arrValues['product_name'];
744
745            $code = SC_Utils_Ex::isBlank($arrValues['product_code'])
746                ? $d['product_code']
747                : $arrValues['product_code'];
748
749            $cname1 = SC_Utils_Ex::isBlank($arrValues['classcategory_name1'])
750                ? $d['classcategory_name1']
751                : $arrValues['classcategory_name1'];
752
753            $cname2 = SC_Utils_Ex::isBlank($arrValues['classcategory_name2'])
754                ? $d['classcategory_name2']
755                : $arrValues['classcategory_name2'];
756
757            $price = SC_Utils_Ex::isBlank($arrValues['price'])
758                ? $d['price']
759                : $arrValues['price'];
760
761            $arrValues['order_id'] = $order_id;
762            $arrValues['shipping_id'] = $shipping_id;
763            $arrValues['product_name'] = $name;
764            $arrValues['product_code'] = $code;
765            $arrValues['classcategory_name1'] = $cname1;
766            $arrValues['classcategory_name2'] = $cname2;
767            $arrValues['price'] = $price;
768
769            $arrExtractValues = $objQuery->extractOnlyColsOf($table, $arrValues);
770            $objQuery->insert($table, $arrExtractValues);
771        }
772    }
773
774    /**
775     * 受注登録を完了する.
776     *
777     * 引数の受注情報を受注テーブル及び受注詳細テーブルに登録する.
778     * 登録後, 受注一時テーブルに削除フラグを立てる.
779     *
780     * @param array $orderParams 登録する受注情報の配列
781     * @param SC_CartSession $objCartSession カート情報のインスタンス
782     * @param integer $cartKey 登録を行うカート情報のキー
783     * @param integer 受注ID
784     */
785    function registerOrderComplete($orderParams, &$objCartSession, $cartKey)
786    {
787        $objQuery =& SC_Query_Ex::getSingletonInstance();
788
789        // 不要な変数を unset
790        $unsets = array('mailmaga_flg', 'deliv_check', 'point_check', 'password',
791                        'reminder', 'reminder_answer', 'mail_flag', 'session');
792        foreach ($unsets as $unset) {
793            unset($orderParams[$unset]);
794        }
795
796        // 対応状況の指定が無い場合は新規受付
797        if (SC_Utils_Ex::isBlank($orderParams['status'])) {
798            $orderParams['status'] = ORDER_NEW;
799        }
800
801        $orderParams['create_date'] = 'CURRENT_TIMESTAMP';
802        $orderParams['update_date'] = 'CURRENT_TIMESTAMP';
803
804        $this->registerOrder($orderParams['order_id'], $orderParams);
805
806        // 詳細情報を取得
807        $cartItems = $objCartSession->getCartList($cartKey);
808
809        // 詳細情報を生成
810        $objProduct = new SC_Product_Ex();
811        $i = 0;
812        $arrDetail = array();
813        foreach ($cartItems as $item) {
814            $p =& $item['productsClass'];
815            $arrDetail[$i]['order_id'] = $orderParams['order_id'];
816            $arrDetail[$i]['product_id'] = $p['product_id'];
817            $arrDetail[$i]['product_class_id'] = $p['product_class_id'];
818            $arrDetail[$i]['product_name'] = $p['name'];
819            $arrDetail[$i]['product_code'] = $p['product_code'];
820            $arrDetail[$i]['classcategory_name1'] = $p['classcategory_name1'];
821            $arrDetail[$i]['classcategory_name2'] = $p['classcategory_name2'];
822            $arrDetail[$i]['point_rate'] = $item['point_rate'];
823            $arrDetail[$i]['price'] = $item['price'];
824            $arrDetail[$i]['quantity'] = $item['quantity'];
825            $arrDetail[$i]['tax_rate'] = $orderParams['order_tax_rate'];
826            $arrDetail[$i]['tax_rule'] = $orderParams['order_tax_rule'];
827
828            // 在庫の減少処理
829            if (!$objProduct->reduceStock($p['product_class_id'], $item['quantity'])) {
830                $objQuery->rollback();
831                SC_Utils_Ex::sfDispSiteError(SOLD_OUT, '', true);
832            }
833            $i++;
834        }
835        $this->registerOrderDetail($orderParams['order_id'], $arrDetail);
836
837        $objQuery->update('dtb_order_temp', array('del_flg' => 1),
838                          'order_temp_id = ?',
839                          array(SC_SiteSession_Ex::getUniqId()));
840
841
842
843        return $orderParams['order_id'];
844    }
845
846    /**
847     * 受注情報を登録する.
848     *
849     * 既に受注IDが存在する場合は, 受注情報を更新する.
850     * 引数の受注IDが, 空白又は null の場合は, 新しく受注IDを発行して登録する.
851     *
852     * @param integer $order_id 受注ID
853     * @param array $arrParams 受注情報の連想配列
854     * @return integer 受注ID
855     */
856    function registerOrder($order_id, $arrParams)
857    {
858        $table = 'dtb_order';
859        $where = 'order_id = ?';
860        $objQuery = SC_Query_Ex::getSingletonInstance();
861        $arrValues = $objQuery->extractOnlyColsOf($table, $arrParams);
862
863        $exists = $objQuery->exists($table, $where, array($order_id));
864        if ($exists) {
865
866            $this->sfUpdateOrderStatus($order_id, $arrValues['status'],
867                                       $arrValues['add_point'],
868                                       $arrValues['use_point'],
869                                       $arrValues);
870            $this->sfUpdateOrderNameCol($order_id);
871
872            $arrValues['update_date'] = 'CURRENT_TIMESTAMP';
873            $objQuery->update($table, $arrValues, $where, array($order_id));
874        } else {
875            if (SC_Utils_Ex::isBlank($order_id)) {
876                $order_id = $this->getNextOrderID();
877            }
878            /*
879             * 新規受付の場合は対応状況 null で insert し,
880             * sfUpdateOrderStatus で引数で受け取った値に変更する.
881             */
882            $status = $arrValues['status'];
883            $arrValues['status'] = null;
884            $arrValues['order_id'] = $order_id;
885            $arrValues['customer_id'] =
886                    SC_Utils_Ex::isBlank($arrValues['customer_id'])
887                    ? 0 : $arrValues['customer_id'];
888            $arrValues['create_date'] = 'CURRENT_TIMESTAMP';
889            $arrValues['update_date'] = 'CURRENT_TIMESTAMP';
890            $objQuery->insert($table, $arrValues);
891
892            $this->sfUpdateOrderStatus($order_id, $status,
893                                       $arrValues['add_point'],
894                                       $arrValues['use_point'],
895                                       $arrValues);
896            $this->sfUpdateOrderNameCol($order_id);
897
898        }
899        return $order_id;
900    }
901
902    /**
903     * 受注詳細情報を登録する.
904     *
905     * 既に, 該当の受注が存在する場合は, 受注情報を削除し, 登録する.
906     *
907     * @param integer $order_id 受注ID
908     * @param array $arrParams 受注情報の連想配列
909     * @return void
910     */
911    function registerOrderDetail($order_id, $arrParams)
912    {
913        $table = 'dtb_order_detail';
914        $where = 'order_id = ?';
915        $objQuery = SC_Query_Ex::getSingletonInstance();
916
917        $objQuery->delete($table, $where, array($order_id));
918        foreach ($arrParams as $arrDetail) {
919            $arrValues = $objQuery->extractOnlyColsOf($table, $arrDetail);
920            $arrValues['order_detail_id'] = $objQuery->nextVal('dtb_order_detail_order_detail_id');
921            $arrValues['order_id'] = $order_id;
922            $objQuery->insert($table, $arrValues);
923        }
924    }
925
926    /**
927     * 受注情報を取得する.
928     *
929     * @param integer $order_id 受注ID
930     * @param integer $customer_id 会員ID
931     * @return array 受注情報の配列
932     */
933    function getOrder($order_id, $customer_id = null)
934    {
935        $objQuery =& SC_Query_Ex::getSingletonInstance();
936        $where = 'order_id = ?';
937        $arrValues = array($order_id);
938        if (!SC_Utils_Ex::isBlank($customer_id)) {
939            $where .= ' AND customer_id = ?';
940            $arrValues[] = $customer_id;
941        }
942        return $objQuery->getRow('*', 'dtb_order', $where, $arrValues);
943    }
944
945    /**
946     * 受注詳細を取得する.
947     *
948     * @param integer $order_id 受注ID
949     * @param boolean $has_order_status 対応状況, 入金日も含める場合 true
950     * @return array 受注詳細の配列
951     */
952    function getOrderDetail($order_id, $has_order_status = true)
953    {
954        $objQuery =& SC_Query_Ex::getSingletonInstance();
955        $dbFactory  = SC_DB_DBFactory_Ex::getInstance();
956        $col = <<< __EOS__
957            T3.product_id,
958            T3.product_class_id as product_class_id,
959            T3.product_type_id AS product_type_id,
960            T2.product_code,
961            T2.product_name,
962            T2.classcategory_name1 AS classcategory_name1,
963            T2.classcategory_name2 AS classcategory_name2,
964            T2.price,
965            T2.quantity,
966            T2.point_rate,
967            T2.tax_rate,
968            T2.tax_rule,
969__EOS__;
970        if ($has_order_status) {
971            $col .= 'T1.status AS status, T1.payment_date AS payment_date,';
972
973        }
974        $col .= <<< __EOS__
975            CASE WHEN
976                EXISTS(
977                    SELECT * FROM dtb_products
978                    WHERE product_id = T3.product_id
979                        AND del_flg = 0
980                        AND status = 1
981                )
982                THEN '1'
983                ELSE '0'
984            END AS enable,
985__EOS__;
986        $col .= $dbFactory->getDownloadableDaysWhereSql('T1') . ' AS effective';
987        $from = <<< __EOS__
988            dtb_order T1
989            JOIN dtb_order_detail T2
990                ON T1.order_id = T2.order_id
991            LEFT JOIN dtb_products_class T3
992                ON T2.product_class_id = T3.product_class_id
993__EOS__;
994        $objQuery->setOrder('T2.order_detail_id');
995        return $objQuery->select($col, $from, 'T1.order_id = ?', array($order_id));
996    }
997
998    /**
999     * ダウンロード可能フラグを, 受注詳細に設定する.
1000     *
1001     * ダウンロード可能と判断されるのは, 以下の通り.
1002     *
1003     * 1. ダウンロード可能期限が期限内かつ, 入金日が入力されている
1004     * 2. 販売価格が 0 円である
1005     *
1006     * 受注詳細行には, is_downloadable という真偽値が設定される.
1007     * @param array 受注詳細の配列
1008     * @return void
1009     */
1010    function setDownloadableFlgTo(&$arrOrderDetail)
1011    {
1012        foreach ($arrOrderDetail as $key => $value) {
1013            // 販売価格が 0 円
1014            if ($arrOrderDetail[$key]['price'] == '0') {
1015                $arrOrderDetail[$key]['is_downloadable'] = true;
1016            }
1017            // ダウンロード期限内かつ, 入金日あり
1018            elseif ($arrOrderDetail[$key]['effective'] == '1'
1019                    && !SC_Utils_Ex::isBlank($arrOrderDetail[$key]['payment_date'])) {
1020                $arrOrderDetail[$key]['is_downloadable'] = true;
1021            } else {
1022                $arrOrderDetail[$key]['is_downloadable'] = false;
1023            }
1024        }
1025    }
1026
1027    /**
1028     * 配送情報を取得する.
1029     *
1030     * @param integer $order_id 受注ID
1031     * @param boolean $has_items 結果に配送商品も含める場合 true
1032     * @return array 配送情報の配列
1033     */
1034    function getShippings($order_id, $has_items = true)
1035    {
1036        $objQuery =& SC_Query_Ex::getSingletonInstance();
1037        $arrResults = array();
1038        $objQuery->setOrder('shipping_id');
1039        $arrShippings = $objQuery->select('*', 'dtb_shipping', 'order_id = ?',
1040                                          array($order_id));
1041        // shipping_id ごとの配列を生成する
1042        foreach ($arrShippings as $shipping) {
1043            foreach ($shipping as $key => $val) {
1044                $arrResults[$shipping['shipping_id']][$key] = $val;
1045            }
1046        }
1047
1048        if ($has_items) {
1049            foreach ($arrResults as $shipping_id => $value) {
1050                $arrResults[$shipping_id]['shipment_item']
1051                        =& $this->getShipmentItems($order_id, $shipping_id);
1052            }
1053        }
1054        return $arrResults;
1055    }
1056
1057    /**
1058     * 配送商品を取得する.
1059     *
1060     * @param integer $order_id 受注ID
1061     * @param integer $shipping_id 配送先ID
1062     * @param boolean $has_detail 商品詳細も取得する場合 true
1063     * @return array 商品規格IDをキーにした配送商品の配列
1064     */
1065    function getShipmentItems($order_id, $shipping_id, $has_detail = true)
1066    {
1067        $objQuery =& SC_Query_Ex::getSingletonInstance();
1068        $objProduct = new SC_Product_Ex();
1069        $arrResults = array();
1070        $arrItems = $objQuery->select('*', 'dtb_shipment_item',
1071                                      'order_id = ? AND shipping_id = ?',
1072                                      array($order_id, $shipping_id));
1073
1074        foreach ($arrItems as $key => $arrItem) {
1075            $product_class_id = $arrItem['product_class_id'];
1076
1077            foreach ($arrItem as $detailKey => $detailVal) {
1078                $arrResults[$key][$detailKey] = $detailVal;
1079            }
1080            // 商品詳細を関連づける
1081            if ($has_detail) {
1082                $arrResults[$key]['productsClass']
1083                    =& $objProduct->getDetailAndProductsClass($product_class_id);
1084            }
1085        }
1086        return $arrResults;
1087    }
1088
1089    /**
1090     * 受注完了メールを送信する.
1091     *
1092     * HTTP_USER_AGENT の種別により, 携帯電話の場合は携帯用の文面,
1093     * PC の場合は PC 用の文面でメールを送信する.
1094     *
1095     * @param integer $orderId 受注ID
1096     * @return void
1097     */
1098    function sendOrderMail($orderId)
1099    {
1100        $mailHelper = new SC_Helper_Mail_Ex();
1101        $template_id =
1102            SC_Display_Ex::detectDevice() == DEVICE_TYPE_MOBILE ? 2 : 1;
1103        $mailHelper->sfSendOrderMail($orderId, $template_id);
1104    }
1105
1106    /**
1107     * 受注.対応状況の更新
1108     *
1109     * 必ず呼び出し元でトランザクションブロックを開いておくこと。
1110     *
1111     * @param integer $orderId 注文番号
1112     * @param integer|null $newStatus 対応状況 (null=変更無し)
1113     * @param integer|null $newAddPoint 加算ポイント (null=変更無し)
1114     * @param integer|null $newUsePoint 使用ポイント (null=変更無し)
1115     * @param array $sqlval 更新後の値をリファレンスさせるためのパラメーター
1116     * @return void
1117     */
1118    function sfUpdateOrderStatus($orderId, $newStatus = null, $newAddPoint = null, $newUsePoint = null, &$sqlval = array())
1119    {
1120        $objQuery =& SC_Query_Ex::getSingletonInstance();
1121        $arrOrderOld = $objQuery->getRow('status, add_point, use_point, customer_id', 'dtb_order', 'order_id = ?', array($orderId));
1122
1123        // 対応状況が変更無しの場合、DB値を引き継ぐ
1124        if (is_null($newStatus)) {
1125            $newStatus = $arrOrderOld['status'];
1126        }
1127
1128        // 使用ポイント、DB値を引き継ぐ
1129        if (is_null($newUsePoint)) {
1130            $newUsePoint = $arrOrderOld['use_point'];
1131        }
1132
1133        // 加算ポイント、DB値を引き継ぐ
1134        if (is_null($newAddPoint)) {
1135            $newAddPoint = $arrOrderOld['add_point'];
1136        }
1137
1138        if (USE_POINT !== false) {
1139            // 会員.ポイントの加減値
1140            $addCustomerPoint = 0;
1141
1142            // ▼使用ポイント
1143            // 変更前の対応状況が利用対象の場合、変更前の使用ポイント分を戻す
1144            if ($this->isUsePoint($arrOrderOld['status'])) {
1145                $addCustomerPoint += $arrOrderOld['use_point'];
1146            }
1147
1148            // 変更後の対応状況が利用対象の場合、変更後の使用ポイント分を引く
1149            if ($this->isUsePoint($newStatus)) {
1150                $addCustomerPoint -= $newUsePoint;
1151            }
1152
1153            // ▲使用ポイント
1154
1155            // ▼加算ポイント
1156            // 変更前の対応状況が加算対象の場合、変更前の加算ポイント分を戻す
1157            if ($this->isAddPoint($arrOrderOld['status'])) {
1158                $addCustomerPoint -= $arrOrderOld['add_point'];
1159            }
1160
1161            // 変更後の対応状況が加算対象の場合、変更後の加算ポイント分を足す
1162            if ($this->isAddPoint($newStatus)) {
1163                $addCustomerPoint += $newAddPoint;
1164            }
1165            // ▲加算ポイント
1166
1167            if ($addCustomerPoint != 0) {
1168                // ▼会員テーブルの更新
1169                $objQuery->update('dtb_customer', array('update_date' => 'CURRENT_TIMESTAMP'),
1170                                  'customer_id = ?', array($arrOrderOld['customer_id']),
1171                                  array('point' => 'point + ?'), array($addCustomerPoint));
1172                // ▲会員テーブルの更新
1173
1174                // 会員.ポイントをマイナスした場合、
1175                if ($addCustomerPoint < 0) {
1176                    $sql = 'SELECT point FROM dtb_customer WHERE customer_id = ?';
1177                    $point = $objQuery->getOne($sql, array($arrOrderOld['customer_id']));
1178                    // 変更後の会員.ポイントがマイナスの場合、
1179                    if ($point < 0) {
1180                        // ロールバック
1181                        $objQuery->rollback();
1182                        // エラー
1183                        SC_Utils_Ex::sfDispSiteError(LACK_POINT);
1184                    }
1185                }
1186            }
1187        }
1188
1189        // ▼受注テーブルの更新
1190        if (empty($sqlval)) {
1191            $sqlval = array();
1192        }
1193
1194        if (USE_POINT !== false) {
1195            $sqlval['add_point'] = $newAddPoint;
1196            $sqlval['use_point'] = $newUsePoint;
1197        }
1198        // 対応状況が発送済みに変更の場合、発送日を更新
1199        if ($arrOrderOld['status'] != ORDER_DELIV && $newStatus == ORDER_DELIV) {
1200            $sqlval['commit_date'] = 'CURRENT_TIMESTAMP';
1201        }
1202        // 対応状況が入金済みに変更の場合、入金日を更新
1203        elseif ($arrOrderOld['status'] != ORDER_PRE_END && $newStatus == ORDER_PRE_END) {
1204            $sqlval['payment_date'] = 'CURRENT_TIMESTAMP';
1205        }
1206
1207        $sqlval['status'] = $newStatus;
1208        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
1209
1210        $dest = $objQuery->extractOnlyColsOf('dtb_order', $sqlval);
1211        $objQuery->update('dtb_order', $dest, 'order_id = ?', array($orderId));
1212        // ▲受注テーブルの更新
1213
1214        //会員情報の最終購入日、購入合計を更新
1215        if ($arrOrderOld['customer_id'] > 0 and $arrOrderOld['status'] != $newStatus) {
1216            SC_Customer_Ex::updateOrderSummary($arrOrderOld['customer_id']);
1217        }
1218    }
1219
1220    /**
1221     * 受注の名称列を更新する
1222     *
1223     * @param integer $order_id 更新対象の注文番号
1224     * @param boolean $temp_table 更新対象は「受注_Temp」か
1225     * @static
1226     */
1227    function sfUpdateOrderNameCol($order_id, $temp_table = false)
1228    {
1229        $objQuery =& SC_Query_Ex::getSingletonInstance();
1230
1231        if ($temp_table) {
1232            $tgt_table = 'dtb_order_temp';
1233            $sql_where = 'order_temp_id = ?';
1234        } else {
1235            $tgt_table = 'dtb_order';
1236            $sql_where = 'order_id = ?';
1237
1238            $sql_sub = <<< __EOS__
1239                SELECT deliv_time
1240                FROM dtb_delivtime
1241                WHERE time_id = dtb_shipping.time_id
1242                    AND deliv_id = (SELECT dtb_order.deliv_id FROM dtb_order WHERE order_id = dtb_shipping.order_id)
1243__EOS__;
1244            $objQuery->update('dtb_shipping', array(),
1245                              $sql_where,
1246                              array($order_id),
1247                              array('shipping_time' => "($sql_sub)"));
1248
1249        }
1250
1251        $objQuery->update($tgt_table, array(),
1252                          $sql_where,
1253                          array($order_id),
1254                          array('payment_method' =>
1255                                '(SELECT payment_method FROM dtb_payment WHERE payment_id = ' . $tgt_table . '.payment_id)'));
1256    }
1257
1258    /**
1259     * ポイント使用するかの判定
1260     *
1261     * $status が null の場合は false を返す.
1262     *
1263     * @param integer $status 対応状況
1264     * @return boolean 使用するか(会員テーブルから減算するか)
1265     */
1266    function isUsePoint($status)
1267    {
1268        if ($status == null) {
1269            return false;
1270        }
1271        switch ($status) {
1272            case ORDER_CANCEL:      // キャンセル
1273                return false;
1274            default:
1275                break;
1276        }
1277
1278        return true;
1279    }
1280
1281    /**
1282     * ポイント加算するかの判定
1283     *
1284     * @param integer $status 対応状況
1285     * @return boolean 加算するか
1286     */
1287    function isAddPoint($status)
1288    {
1289        switch ($status) {
1290            case ORDER_NEW:         // 新規注文
1291            case ORDER_PAY_WAIT:    // 入金待ち
1292            case ORDER_PRE_END:     // 入金済み
1293            case ORDER_CANCEL:      // キャンセル
1294            case ORDER_BACK_ORDER:  // 取り寄せ中
1295                return false;
1296
1297            case ORDER_DELIV:       // 発送済み
1298                return true;
1299
1300            default:
1301                break;
1302        }
1303
1304        return false;
1305    }
1306
1307    /**
1308     * セッションに保持している情報を破棄する.
1309     *
1310     * 通常、受注処理(completeOrder)完了後に呼び出され、
1311     * セッション情報を破棄する.
1312     *
1313     * 決済モジュール画面から確認画面に「戻る」場合を考慮し、
1314     * セッション情報を破棄しないカスタマイズを、モジュール側で
1315     * 加える機会を与える.
1316     *
1317     * $orderId が使われていない。
1318     *
1319     * @param integer $orderId 注文番号
1320     * @param SC_CartSession $objCartSession カート情報のインスタンス
1321     * @param SC_Customer $objCustomer SC_Customer インスタンス
1322     * @param integer $cartKey 登録を行うカート情報のキー
1323     */
1324    function cleanupSession($orderId, &$objCartSession, &$objCustomer, $cartKey)
1325    {
1326        // カートの内容を削除する.
1327        $objCartSession->delAllProducts($cartKey);
1328        SC_SiteSession_Ex::unsetUniqId();
1329
1330        // セッションの配送情報を破棄する.
1331        $this->unsetAllShippingTemp(true);
1332        $objCustomer->updateSession();
1333    }
1334
1335    /**
1336     * 単一配送指定用に配送商品を設定する
1337     *
1338     * @param SC_CartSession $objCartSession カート情報のインスタンス
1339     * @param integer $shipping_id 配送先ID
1340     * @return void
1341     */
1342    function setShipmentItemTempForSole(&$objCartSession, $shipping_id = 0)
1343    {
1344        $objCartSess = new SC_CartSession_Ex();
1345
1346        $this->clearShipmentItemTemp();
1347
1348        $arrCartList =& $objCartSession->getCartList($objCartSess->getKey());
1349        foreach ($arrCartList as $arrCartRow) {
1350            if ($arrCartRow['quantity'] == 0) continue;
1351            $this->setShipmentItemTemp($shipping_id, $arrCartRow['id'], $arrCartRow['quantity']);
1352        }
1353    }
1354
1355    /**
1356     * 新規受注の注文IDを返す
1357     *
1358     * @return integer
1359     */
1360    public function getNextOrderID()
1361    {
1362        $objQuery =& SC_Query_Ex::getSingletonInstance();
1363        return $objQuery->nextVal('dtb_order_order_id');
1364    }
1365}
Note: See TracBrowser for help on using the repository browser.