source: branches/version-2_5-dev/data/class/helper/SC_Helper_Purchase.php @ 20116

Revision 20116, 24.3 KB checked in by nanasess, 13 years ago (diff)
  • svn properties を再設定
  • 再設定用のスクリプト追加
  • 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-2010 LOCKON CO.,LTD. All Rights Reserved.
6 *
7 * http://www.lockon.co.jp/
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22 */
23
24/**
25 * 商品購入関連のヘルパークラス.
26 *
27 * TODO 購入時強制会員登録機能(#521)の実装を検討
28 * TODO dtb_customer.buy_times, dtb_customer.buy_total の更新
29 *
30 * @package Helper
31 * @author Kentaro Ohkouchi
32 * @version $Id$
33 */
34class SC_Helper_Purchase {
35
36    /**
37     * 受注を完了する.
38     *
39     * 下記のフローで受注を完了する.
40     *
41     * 1. トランザクションを開始する
42     * 2. カートの内容を検証する.
43     * 3. 受注一時テーブルから受注データを読み込む
44     * 4. ユーザーがログインしている場合はその他の発送先へ登録する
45     * 5. 受注データを受注テーブルへ登録する
46     * 6. トランザクションをコミットする
47     *
48     * 実行中に, 何らかのエラーが発生した場合, 処理を中止しエラーページへ遷移する
49     *
50     * 決済モジュールを使用する場合は受注ステータスを「決済処理中」に設定し,
51     * 決済完了後「新規受付」に変更すること
52     *
53     * @param integer $orderStatus 受注処理を完了する際に設定する受注ステータス
54     * @return void
55     */
56    function completeOrder($orderStatus = ORDER_NEW) {
57        $objQuery =& SC_Query::getSingletonInstance();
58        $objSiteSession = new SC_SiteSession();
59        $objCartSession = new SC_CartSession();
60        $objCustomer = new SC_Customer();
61        $customerId = $objCustomer->getValue('customer_id');
62
63        $objQuery->begin();
64        if (!$objSiteSession->isPrePage()) {
65            SC_Utils::sfDispSiteError(PAGE_ERROR, $objSiteSession);
66        }
67
68        $uniqId = $objSiteSession->getUniqId();
69        $this->verifyChangeCart($uniqId, $objCartSession);
70
71        $orderTemp = $this->getOrderTemp($uniqId);
72
73        $orderTemp['status'] = $orderStatus;
74        $orderId = $this->registerOrder($orderTemp, $objCartSession,
75                                        $objCartSession->getKey());
76        $shippingTemp =& $this->getShippingTemp();
77        if (count($shippingTemp) > 1) {
78            foreach ($shippingTemp as $shippingId => $val) {
79                $this->registerShipmentItem($orderId, $shippingId,
80                                            $val['shipment_item']);
81            }
82        }
83
84        $this->registerShipping($orderId, $shippingTemp);
85        $objQuery->commit();
86        $this->unsetShippingTemp();
87        $objCustomer->updateSession();
88    }
89
90    /**
91     * カートに変化が無いか検証する.
92     *
93     * ユニークIDとセッションのユニークIDを比較し, 異なる場合は
94     * エラー画面を表示する.
95     *
96     * カートが空の場合, 購入ボタン押下後にカートが変更された場合は
97     * カート画面へ遷移する.
98     *
99     * @param string $uniqId ユニークID
100     * @param SC_CartSession $objCartSession
101     * @return void
102     */
103    function verifyChangeCart($uniqId, &$objCartSession) {
104        $cartKeys = $objCartSession->getKeys();
105
106        // カート内が空でないか
107        if (SC_Utils_Ex::isBlank($cartKeys)) {
108            SC_Response_Ex::sendRedirect(CART_URLPATH);
109        }
110
111        foreach ($cartKeys as $cartKey) {
112            // 初回のみカートの内容を保存
113            $objCartSession->saveCurrentCart($uniqid, $cartKey);
114
115            /*
116             * POSTのユニークIDとセッションのユニークIDを比較
117             *(ユニークIDがPOSTされていない場合はスルー)
118             */
119            if(!SC_SiteSession::checkUniqId()) {
120                SC_Utils_Ex::sfDispSiteError(CANCEL_PURCHASE);
121            }
122
123            // 購入ボタンを押してから変化がないか
124            $quantity = $objCartSession->getTotalQuantity($cartKey);
125            if($objCartSession->checkChangeCart($cartKey) || !($quantity > 0)) {
126                SC_Response_Ex::sendRedirect(CART_URLPATH);
127                exit;
128            }
129        }
130    }
131
132    /**
133     * 受注一時情報を取得する.
134     *
135     * @param integer $uniqId 受注一時情報ID
136     * @return array 受注一時情報の配列
137     */
138    function getOrderTemp($uniqId) {
139        $objQuery =& SC_Query::getSingletonInstance();
140        return $objQuery->getRow("*", "dtb_order_temp", "order_temp_id = ?",
141                                 array($uniqId));
142    }
143
144    /**
145     * 受注一時情報を保存する.
146     *
147     * 既存のデータが存在しない場合は新規保存. 存在する場合は更新する.
148     * 既存のデータが存在せず, ユーザーがログインしている場合は,
149     * 会員情報をコピーする.
150     *
151     * @param integer $uniqId 受注一時情報ID
152     * @param array $params 登録する受注情報の配列
153     * @param SC_Customer $objCustomer SC_Customer インスタンス
154     * @return array void
155     */
156    function saveOrderTemp($uniqId, $params, &$objCustomer) {
157        if (SC_Utils_Ex::isBlank($uniqId)) {
158            return;
159        }
160        $params['device_type_id'] = SC_Display::detectDevice();
161        $objQuery =& SC_Query::getSingletonInstance();
162        // 存在するカラムのみを対象とする
163        $cols = $objQuery->listTableFields('dtb_order_temp');
164        foreach ($params as $key => $val) {
165            if (in_array($key, $cols)) {
166                $sqlval[$key] = $val;
167            }
168        }
169
170        $sqlval['session'] = serialize($_SESSION);
171        $exists = $this->getOrderTemp($uniqId);
172        if (SC_Utils_Ex::isBlank($exists)) {
173            $this->copyFromCustomer($sqlval, $objCustomer);
174            $sqlval['order_temp_id'] = $uniqId;
175            $sqlval['create_date'] = "now()";
176            $objQuery->insert("dtb_order_temp", $sqlval);
177        } else {
178            $objQuery->update("dtb_order_temp", $sqlval, 'order_temp_id = ?',
179                              array($uniqId));
180        }
181    }
182
183    /**
184     * セッションの配送情報を取得する.
185     */
186    function getShippingTemp() {
187        return $_SESSION['shipping'];
188    }
189
190    /**
191     * 配送商品を設定する.
192     */
193    function setShipmentItemTemp($otherDelivId, $productClassId, $quantity) {
194        $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['shipping_id'] = $otherDelivId;
195        $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['product_class_id'] = $productClassId;
196        $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['quantity'] += $quantity;
197
198        $objProduct = new SC_Product();
199        if (empty($_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['productsClass'])) {
200            $product =& $objProduct->getDetailAndProductsClass($productClassId);
201            $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['productsClass'] = $product;
202        }
203        $incTax = SC_Helper_DB_Ex::sfCalcIncTax($_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['productsClass']['price02']);
204        $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['total_inctax'] = $incTax * $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['quantity'];
205    }
206
207    /**
208     * 配送商品の情報でカートを更新する.
209     */
210    function shippingItemTempToCart(&$objCartSession) {
211        $shipmentItems = array();
212
213        foreach (array_keys($_SESSION['shipping']) as $otherDelivId) {
214            foreach (array_keys($_SESSION['shipping'][$otherDelivId]['shipment_item']) as $productClassId) {
215                $shipmentItems[$productClassId] += $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['quantity'];
216           }
217        }
218        foreach ($shipmentItems as $productClassId => $quantity) {
219            $objCartSession->setProductValue($productClassId, 'quantity',
220                                             $quantity,$objCartSession->getKey());
221        }
222    }
223
224    /**
225     * 配送先都道府県の配列を返す.
226     */
227    function getShippingPref() {
228        $results = array();
229        foreach ($_SESSION['shipping'] as $val) {
230            $results[] = $val['shipping_pref'];
231        }
232        return $results;
233    }
234
235    /**
236     * 複数配送指定の購入かどうか.
237     *
238     * @return boolean 複数配送指定の購入の場合 true
239     */
240    function isMultiple() {
241        return (count($this->getShippingTemp()) > 1);
242    }
243
244    /**
245     * 配送情報をセッションに保存する.
246     */
247    function saveShippingTemp(&$src, $otherDelivId = 0) {
248        if (empty($_SESSION['shipping'][$otherDelivId])) {
249            $_SESSION['shipping'][$otherDelivId] = $src;
250        } else {
251            $_SESSION['shipping'][$otherDelivId] = array_merge($_SESSION['shipping'][$otherDelivId], $src);
252        }
253    }
254
255    /**
256     * セッションの配送情報を破棄する.
257     */
258    function unsetShippingTemp() {
259        unset($_SESSION['shipping']);
260    }
261
262    /**
263     * 会員情報を受注情報にコピーする.
264     *
265     * ユーザーがログインしていない場合は何もしない.
266     * 会員情報を $dest の order_* へコピーする.
267     * customer_id は強制的にコピーされる.
268     *
269     * @param array $dest コピー先の配列
270     * @param SC_Customer $objCustomer SC_Customer インスタンス
271     * @param string $prefix コピー先の接頭辞. デフォルト order
272     * @param array $keys コピー対象のキー
273     * @return void
274     */
275    function copyFromCustomer(&$dest, &$objCustomer, $prefix = 'order',
276                              $keys = array('name01', 'name02', 'kana01', 'kana02',
277                                            'sex', 'zip01', 'zip02', 'pref',
278                                            'addr01', 'addr02',
279                                            'tel01', 'tel02', 'tel03', 'job',
280                                            'birth', 'email')) {
281        if ($objCustomer->isLoginSuccess(true)) {
282
283            foreach ($keys as $key) {
284                if (in_array($key, $keys)) {
285                    $dest[$prefix . '_' . $key] = $objCustomer->getValue($key);
286                }
287            }
288
289            if (Net_UserAgent_Mobile::isMobile()
290                && in_array('email', $keys)) {
291                $email_mobile = $objCustomer->getValue('email_mobile');
292                if (empty($email_mobile)) {
293                    $dest[$prefix . '_email'] = $objCustomer->getValue('email');
294                } else {
295                    $dest[$prefix . '_email'] = $email_mobile;
296                }
297            }
298
299            $dest['customer_id'] = $objCustomer->getValue('customer_id');
300            $dest['update_date'] = 'Now()';
301        }
302    }
303
304    /**
305     * 受注情報を配送情報にコピーする.
306     *
307     * 受注情報($src)を $dest の order_* へコピーする.
308     *
309     * TODO 汎用的にして SC_Utils へ移動
310     *
311     * @param array $dest コピー先の配列
312     * @param array $src コピー元の配列
313     * @param array $keys コピー対象のキー
314     * @param string $prefix コピー先の接頭辞. デフォルト shipping
315     * @param string $src_prefix コピー元の接頭辞. デフォルト order
316     * @return void
317     */
318    function copyFromOrder(&$dest, $src,
319                           $prefix = 'shipping', $src_prefix = 'order',
320                           $keys = array('name01', 'name02', 'kana01', 'kana02',
321                                         'sex', 'zip01', 'zip02', 'pref',
322                                         'addr01', 'addr02',
323                                         'tel01', 'tel02', 'tel03')) {
324        if (!SC_Utils_Ex::isBlank($prefix)) {
325            $prefix = $prefix . '_';
326        }
327        if (!SC_Utils_Ex::isBlank($src_prefix)) {
328            $src_prefix = $src_prefix . '_';
329        }
330        foreach ($keys as $key) {
331            if (in_array($key, $keys)) {
332                $dest[$prefix . $key] = $src[$src_prefix . $key];
333            }
334        }
335    }
336
337    /**
338     * 購入金額に応じた支払方法を取得する.
339     *
340     * @param integer $total 購入金額
341     * @param integer $deliv_id 配送業者ID
342     * @return array 購入金額に応じた支払方法の配列
343     */
344    function getPaymentsByPrice($total, $deliv_id) {
345
346        $arrPaymentIds = $this->getPayments($deliv_id);
347        $objQuery =& SC_Query::getSingletonInstance();
348
349        // 削除されていない支払方法を取得
350        $where = 'del_flg = 0 AND payment_id IN (' . implode(', ', array_pad(array(), count($arrPaymentIds), '?')) . ')';
351        $objQuery->setOrder("rank DESC");
352        $payments = $objQuery->select("payment_id, payment_method, rule, upper_rule, note, payment_image, charge", "dtb_payment", $where, $arrPaymentIds);
353
354        foreach ($payments as $data) {
355            // 下限と上限が設定されている
356            if (strlen($data['rule']) != 0 && strlen($data['upper_rule']) != 0) {
357                if ($data['rule'] <= $total_inctax && $data['upper_rule'] >= $total_inctax) {
358                    $arrPayment[] = $data;
359                }
360            }
361            // 下限のみ設定されている
362            elseif (strlen($data['rule']) != 0) {
363                if($data['rule'] <= $total_inctax) {
364                    $arrPayment[] = $data;
365                }
366            }
367            // 上限のみ設定されている
368            elseif (strlen($data['upper_rule']) != 0) {
369                if($data['upper_rule'] >= $total_inctax) {
370                    $arrPayment[] = $data;
371                }
372            }
373            // いずれも設定なし
374            else {
375                $arrPayment[] = $data;
376            }
377          }
378        return $arrPayment;
379    }
380
381    /**
382     * お届け日一覧を取得する.
383     */
384    function getDelivDate(&$objCartSess, $productTypeId) {
385        $cartList = $objCartSess->getCartList($productTypeId);
386        $delivDateIds = array();
387        foreach ($cartList as $item) {
388            $delivDateIds[] = $item['productsClass']['deliv_date_id'];
389        }
390        $max_date = max($delivDateIds);
391        //発送目安
392        switch($max_date) {
393        //即日発送
394        case '1':
395            $start_day = 1;
396            break;
397            //1-2日後
398        case '2':
399            $start_day = 3;
400            break;
401            //3-4日後
402        case '3':
403            $start_day = 5;
404            break;
405            //1週間以内
406        case '4':
407            $start_day = 8;
408            break;
409            //2週間以内
410        case '5':
411            $start_day = 15;
412            break;
413            //3週間以内
414        case '6':
415            $start_day = 22;
416            break;
417            //1ヶ月以内
418        case '7':
419            $start_day = 32;
420            break;
421            //2ヶ月以降
422        case '8':
423            $start_day = 62;
424            break;
425            //お取り寄せ(商品入荷後)
426        case '9':
427            $start_day = "";
428            break;
429        default:
430            //お届け日が設定されていない場合
431            $start_day = "";
432        }
433        //お届け可能日のスタート値から、お届け日の配列を取得する
434        $arrDelivDate = $this->getDateArray($start_day, DELIV_DATE_END_MAX);
435        return $arrDelivDate;
436    }
437
438    /**
439     * お届け可能日のスタート値から, お届け日の配列を取得する.
440     */
441    function getDateArray($start_day, $end_day) {
442        $masterData = new SC_DB_MasterData();
443        $arrWDAY = $masterData->getMasterData("mtb_wday");
444        //お届け可能日のスタート値がセットされていれば
445        if($start_day >= 1) {
446            $now_time = time();
447            $max_day = $start_day + $end_day;
448            // 集計
449            for ($i = $start_day; $i < $max_day; $i++) {
450                // 基本時間から日数を追加していく
451                $tmp_time = $now_time + ($i * 24 * 3600);
452                list($y, $m, $d, $w) = split(" ", date("Y m d w", $tmp_time));
453                $val = sprintf("%04d/%02d/%02d(%s)", $y, $m, $d, $arrWDAY[$w]);
454                $arrDate[$val] = $val;
455            }
456        } else {
457            $arrDate = false;
458        }
459        return $arrDate;
460    }
461
462    /**
463     * 配送業者IDからお届け時間の配列を取得する.
464     *
465     * @param integer $deliv_id 配送業者ID
466     * @return array お届け時間の配列
467     */
468    function getDelivTime($deliv_id) {
469        $objQuery =& SC_Query::getSingletonInstance();
470        $objQuery->setOrder('time_id');
471        $results = $objQuery->select('time_id, deliv_time',
472                                     'dtb_delivtime',
473                                     'deliv_id = ?', array($deliv_id));
474        $arrDelivTime = array();
475        foreach ($results as $val) {
476            $arrDelivTime[$val['time_id']] = $val['deliv_time'];
477        }
478        return $arrDelivTime;
479    }
480
481    /**
482     * 商品種別ID から配送業者を取得する.
483     *
484     * @param integer $product_type_id 商品種別ID
485     * @return array 配送業者の配列
486     */
487    function getDeliv($product_type_id) {
488        $objQuery =& SC_Query::getSingletonInstance();
489        $objQuery->setOrder('rank');
490        return $objQuery->select('*', 'dtb_deliv', 'product_type_id = ?',
491                                 array($product_type_id));
492    }
493
494    /**
495     * 配送業者ID から, 有効な支払方法IDを取得する.
496     *
497     * @param integer $deliv_id 配送業者ID
498     * @return array 有効な支払方法IDの配列
499     */
500    function getPayments($deliv_id) {
501        $objQuery =& SC_Query::getSingletonInstance();
502        $objQuery->setOrder('rank');
503        return $objQuery->getCol('payment_id', 'dtb_payment_options',
504                                 'deliv_id = ?',
505                                 array($deliv_id), MDB2_FETCHMODE_ORDERED);
506    }
507
508    /**
509     * 配送情報を登録する.
510     */
511    function registerShipping($orderId, $params) {
512        $objQuery =& SC_Query::getSingletonInstance();
513
514        $cols = $objQuery->listTableFields('dtb_shipping');
515
516        foreach ($params as $shipping_id => $shipping_val) {
517            // 存在するカラムのみ INSERT
518            foreach ($shipping_val as $key => $val) {
519                if (in_array($key, $cols)) {
520                    $sqlval[$key] = $val;
521                }
522            }
523
524            // 配送日付を timestamp に変換
525            if (!SC_Utils_Ex::isBlank($sqlval['shipping_date'])) {
526                $d = mb_strcut($sqlval["shipping_date"], 0, 10);
527                $arrDate = split("/", $d);
528                $ts = mktime(0, 0, 0, $arrDate[1], $arrDate[2], $arrDate[0]);
529                $sqlval['shipping_date'] = date("Y-m-d", $ts);
530            }
531
532            $sqlval['order_id'] = $orderId;
533            $sqlval['shipping_id'] = $shipping_id;
534            $sqlval['create_date'] = 'Now()';
535            $sqlval['update_date'] = 'Now()';
536            $objQuery->insert("dtb_shipping", $sqlval);
537        }
538    }
539
540    /**
541     * 配送商品を登録する.
542     */
543    function registerShipmentItem($orderId, $shippingId, $params) {
544        $objQuery =& SC_Query::getSingletonInstance();
545        $objProduct = new SC_Product();
546        foreach ($params as $productClassId => $val) {
547            $d = $objProduct->getDetailAndProductsClass($productClassId);
548            $sqlval['order_id'] = $orderId;
549            $sqlval['shipping_id'] = $shippingId;
550            $sqlval['product_class_id'] = $productClassId;
551            $sqlval['product_name'] = $d['name'];
552            $sqlval['product_code'] = $d['product_code'];
553            $sqlval['classcategory_name1'] = $d['classcategory_name1'];
554            $sqlval['classcategory_name2'] = $d['classcategory_name2'];
555            $sqlval['price'] = $d['price02'];
556            $sqlval['quantity'] = $val['quantity'];
557            $objQuery->insert("dtb_shipment_item", $sqlval);
558        }
559    }
560
561    /**
562     * 受注情報を登録する.
563     *
564     * 引数の受注情報を受注テーブル及び受注詳細テーブルに登録する.
565     * 登録後, 受注一時テーブルに削除フラグを立て, カートの内容を削除する.
566     *
567     * TODO ダウンロード商品の場合の扱いを検討
568     *
569     * @param array $orderParams 登録する受注情報の配列
570     * @param SC_CartSession $objCartSession カート情報のインスタンス
571     * @param integer $cartKey 登録を行うカート情報のキー
572     * @param integer 受注ID
573     */
574    function registerOrder($orderParams, &$objCartSession, $cartKey) {
575        $objQuery =& SC_Query::getSingletonInstance();
576
577        // 不要な変数を unset
578        $unsets = array('mailmaga_flg', 'deliv_check', 'point_check', 'password',
579                        'reminder', 'reminder_answer', 'mail_flag', 'session');
580        foreach ($unsets as $unset) {
581            unset($orderParams[$unset]);
582        }
583
584        // ポイントは別登録
585        $addPoint = $orderParams['add_point'];
586        $usePoint = $orderParams['use_point'];
587        $orderParams['add_point'] = 0;
588        $orderParams['use_point'] = 0;
589
590        // 注文ステータスの指定が無い場合は新規受付
591        if(SC_Utils_Ex::isBlank($orderParams['status'])) {
592            $orderParams['status'] = ORDER_NEW;
593        }
594
595        $orderParams['create_date'] = 'Now()';
596        $orderParams['update_date'] = 'Now()';
597
598        $objQuery->insert("dtb_order", $orderParams);
599
600        // 受注.対応状況の更新
601        SC_Helper_DB_Ex::sfUpdateOrderStatus($orderParams['order_id'],
602                                             null, $addPoint, $usePoint);
603
604        // 詳細情報を取得
605        $cartItems = $objCartSession->getCartList($cartKey);
606
607        // 既に存在する詳細レコードを消しておく。
608        $objQuery->delete("dtb_order_detail", "order_id = ?",
609                          array($orderParams['order_id']));
610
611        $objProduct = new SC_Product();
612        foreach ($cartItems as $item) {
613            $p =& $item['productsClass'];
614            $detail['order_id'] = $orderParams['order_id'];
615            $detail['product_id'] = $p['product_id'];
616            $detail['product_class_id'] = $p['product_class_id'];
617            $detail['product_name'] = $p['name'];
618            $detail['product_code'] = $p['product_code'];
619            $detail['classcategory_name1'] = $p['classcategory_name1'];
620            $detail['classcategory_name2'] = $p['classcategory_name2'];
621            $detail['point_rate'] = $item['point_rate'];
622            $detail['price'] = $item['price'];
623            $detail['quantity'] = $item['quantity'];
624
625            // 在庫の減少処理
626            if (!$objProduct->reduceStock($p['product_class_id'], $item['quantity'])) {
627                $objQuery->rollback();
628                SC_Utils_Ex::sfDispSiteError(SOLD_OUT, "", true);
629            }
630            $objQuery->insert("dtb_order_detail", $detail);
631        }
632
633        $objQuery->update("dtb_order_temp", array('del_flg' => 1),
634                          "order_temp_id = ?",
635                          array(SC_SiteSession::getUniqId()));
636
637        $objCartSession->delAllProducts($cartKey);
638        SC_SiteSession::unsetUniqId();
639        return $orderParams['order_id'];
640    }
641
642    /**
643     * 受注完了メールを送信する.
644     *
645     * HTTP_USER_AGENT の種別により, 携帯電話の場合は携帯用の文面,
646     * PC の場合は PC 用の文面でメールを送信する.
647     *
648     * @param integer $orderId 受注ID
649     * @return void
650     */
651    function sendOrderMail($orderId) {
652        $mailHelper = new SC_Helper_Mail_Ex();
653        $mailHelper->sfSendOrderMail($orderId,
654                                     SC_MobileUserAgent::isMobile() ? 2 : 1);
655    }
656}
Note: See TracBrowser for help on using the repository browser.