source: branches/version-2_12-multilang/data/class/helper/SC_Helper_Purchase.php @ 22205

Revision 22205, 50.7 KB checked in by m_uehara, 11 years ago (diff)

#2004 郵便番号を2カラムから1カラムに変更しました。

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