source: branches/version-2_13-dev/data/class/helper/SC_Helper_Purchase.php @ 22856

Revision 22856, 47.5 KB checked in by Seasoft, 11 years ago (diff)

#2043 (typo修正・ソース整形・ソースコメントの改善 for 2.13.0)

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