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

Revision 23024, 47.8 KB checked in by AMUAMU, 11 years ago (diff)

#2323 (税率対応)
#2235 (越境ECを想定した機能の追加)
#2234 (非会員お客様情報入力テンプレートと機能の共通化)
#2324 (会員登録、注文フォームに「会社名」フィールドを足す)
などの修正

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