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

Revision 19927, 24.3 KB checked in by nanasess, 11 years ago (diff)

#843(複数配送先の指定)

  • 複数配送設定のページで, カートの内容を再計算するよう修正
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        foreach ($cartKeys as $cartKey) {
107            // 初回のみカートの内容を保存
108            $objCartSess->saveCurrentCart($uniqid, $cartKey);
109            /*
110             * POSTのユニークIDとセッションのユニークIDを比較
111             *(ユニークIDがPOSTされていない場合はスルー)
112             */
113            if(!SC_SiteSession::checkUniqId()) {
114                // エラーページの表示
115                // XXX $objSiteSess インスタンスは未使用?
116                SC_Utils_Ex::sfDispSiteError(CANCEL_PURCHASE, $objSiteSess);
117            }
118
119            // カート内が空でないか || 購入ボタンを押してから変化がないか
120            $quantity = $objCartSess->getTotalQuantity($cartKey);
121            if($objCartSess->checkChangeCart($cartKey) || !($quantity > 0)) {
122                // カート情報表示に強制移動する
123                if (Net_UserAgent_Mobile::isMobile()) {
124                    header("Location: ". MOBILE_CART_URL_PATH
125                           . "?" . session_name() . "=" . session_id());
126                } else {
127                    header("Location: ".CART_URL_PATH);
128                }
129                exit;
130            }
131        }
132    }
133
134    /**
135     * 受注一時情報を取得する.
136     *
137     * @param integer $uniqId 受注一時情報ID
138     * @return array 受注一時情報の配列
139     */
140    function getOrderTemp($uniqId) {
141        $objQuery =& SC_Query::getSingletonInstance();
142        return $objQuery->getRow("*", "dtb_order_temp", "order_temp_id = ?",
143                                 array($uniqId));
144    }
145
146    /**
147     * 受注一時情報を保存する.
148     *
149     * 既存のデータが存在しない場合は新規保存. 存在する場合は更新する.
150     * 既存のデータが存在せず, ユーザーがログインしている場合は,
151     * 会員情報をコピーする.
152     *
153     * @param integer $uniqId 受注一時情報ID
154     * @param array $params 登録する受注情報の配列
155     * @param SC_Customer $objCustomer SC_Customer インスタンス
156     * @return array void
157     */
158    function saveOrderTemp($uniqId, $params, &$objCustomer) {
159        if (SC_Utils_Ex::isBlank($uniqId)) {
160            return;
161        }
162
163        $objQuery =& SC_Query::getSingletonInstance();
164        // 存在するカラムのみを対象とする
165        $cols = $objQuery->listTableFields('dtb_order_temp');
166        foreach ($params as $key => $val) {
167            if (in_array($key, $cols)) {
168                $sqlval[$key] = $val;
169            }
170        }
171
172        $sqlval['session'] = serialize($_SESSION);
173        $exists = $this->getOrderTemp($uniqId);
174        if (SC_Utils_Ex::isBlank($exists)) {
175            $this->copyFromCustomer($sqlval, $objCustomer);
176            $sqlval['order_temp_id'] = $uniqId;
177            $sqlval['create_date'] = "now()";
178            $objQuery->insert("dtb_order_temp", $sqlval);
179        } else {
180            $objQuery->update("dtb_order_temp", $sqlval, 'order_temp_id = ?',
181                              array($uniqId));
182        }
183    }
184
185    /**
186     * セッションの配送情報を取得する.
187     */
188    function getShippingTemp() {
189        return $_SESSION['shipping'];
190    }
191
192    /**
193     * 配送商品を設定する.
194     */
195    function setShipmentItemTemp($otherDelivId, $productClassId, $quantity) {
196        $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['shipping_id'] = $otherDelivId;
197        $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['product_class_id'] = $productClassId;
198        $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['quantity'] += $quantity;
199
200        $objProduct = new SC_Product();
201        if (empty($_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['productsClass'])) {
202            $product =& $objProduct->getDetailAndProductsClass($productClassId);
203            $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['productsClass'] = $product;
204        }
205        $incTax = SC_Helper_DB_Ex::sfCalcIncTax($_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['productsClass']['price02']);
206        $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['total_inctax'] = $incTax * $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['quantity'];
207    }
208
209    /**
210     * 配送商品の情報でカートを更新する.
211     */
212    function shippingItemTempToCart(&$objCartSession) {
213        $shipmentItems = array();
214
215        foreach (array_keys($_SESSION['shipping']) as $otherDelivId) {
216            foreach (array_keys($_SESSION['shipping'][$otherDelivId]['shipment_item']) as $productClassId) {
217                $shipmentItems[$productClassId] += $_SESSION['shipping'][$otherDelivId]['shipment_item'][$productClassId]['quantity'];
218           }
219        }
220        foreach ($shipmentItems as $productClassId => $quantity) {
221            $objCartSession->setProductValue($productClassId, 'quantity',
222                                             $quantity,$objCartSession->getKey());
223        }
224    }
225
226    /**
227     * 複数配送指定の購入かどうか.
228     *
229     * @return boolean 複数配送指定の購入の場合 true
230     */
231    function isMultiple() {
232        return (count($this->getShippingTemp()) > 1);
233    }
234
235    /**
236     * 配送情報をセッションに保存する.
237     */
238    function saveShippingTemp(&$src, $otherDelivId = 0) {
239        if (empty($_SESSION['shipping'][$otherDelivId])) {
240            $_SESSION['shipping'][$otherDelivId] = $src;
241        } else {
242            $_SESSION['shipping'][$otherDelivId] = array_merge($_SESSION['shipping'][$otherDelivId], $src);
243        }
244    }
245
246    /**
247     * セッションの配送情報を破棄する.
248     */
249    function unsetShippingTemp() {
250        unset($_SESSION['shipping']);
251    }
252
253    /**
254     * 会員情報を受注情報にコピーする.
255     *
256     * ユーザーがログインしていない場合は何もしない.
257     * 会員情報を $dest の order_* へコピーする.
258     * customer_id は強制的にコピーされる.
259     *
260     * @param array $dest コピー先の配列
261     * @param SC_Customer $objCustomer SC_Customer インスタンス
262     * @param string $prefix コピー先の接頭辞. デフォルト order
263     * @param array $keys コピー対象のキー
264     * @return void
265     */
266    function copyFromCustomer(&$dest, &$objCustomer, $prefix = 'order',
267                              $keys = array('name01', 'name02', 'kana01', 'kana02',
268                                            'sex', 'zip01', 'zip02', 'pref',
269                                            'addr01', 'addr02',
270                                            'tel01', 'tel02', 'tel03', 'job',
271                                            'birth', 'email')) {
272        if ($objCustomer->isLoginSuccess(true)) {
273
274            foreach ($keys as $key) {
275                if (in_array($key, $keys)) {
276                    $dest[$prefix . '_' . $key] = $objCustomer->getValue($key);
277                }
278            }
279
280            if (Net_UserAgent_Mobile::isMobile()
281                && in_array('email', $keys)) {
282                $email_mobile = $objCustomer->getValue('email_mobile');
283                if (empty($email_mobile)) {
284                    $dest[$prefix . '_email'] = $objCustomer->getValue('email');
285                } else {
286                    $dest[$prefix . '_email'] = $email_mobile;
287                }
288            }
289
290            $dest['customer_id'] = $objCustomer->getValue('customer_id');
291            $dest['update_date'] = 'Now()';
292        }
293    }
294
295    /**
296     * 受注情報を配送情報にコピーする.
297     *
298     * 受注情報($src)を $dest の order_* へコピーする.
299     *
300     * TODO 汎用的にして SC_Utils へ移動
301     *
302     * @param array $dest コピー先の配列
303     * @param array $src コピー元の配列
304     * @param array $keys コピー対象のキー
305     * @param string $prefix コピー先の接頭辞. デフォルト shipping
306     * @param string $src_prefix コピー元の接頭辞. デフォルト order
307     * @return void
308     */
309    function copyFromOrder(&$dest, $src,
310                           $prefix = 'shipping', $src_prefix = 'order',
311                           $keys = array('name01', 'name02', 'kana01', 'kana02',
312                                         'sex', 'zip01', 'zip02', 'pref',
313                                         'addr01', 'addr02',
314                                         'tel01', 'tel02', 'tel03')) {
315        if (!SC_Utils_Ex::isBlank($prefix)) {
316            $prefix = $prefix . '_';
317        }
318        if (!SC_Utils_Ex::isBlank($src_prefix)) {
319            $src_prefix = $src_prefix . '_';
320        }
321        foreach ($keys as $key) {
322            if (in_array($key, $keys)) {
323                $dest[$prefix . $key] = $src[$src_prefix . $key];
324            }
325        }
326    }
327
328    /**
329     * 購入金額に応じた支払方法を取得する.
330     *
331     * @param integer $total 購入金額
332     * @param array $productClassIds 購入する商品規格IDの配列
333     * @return array 購入金額に応じた支払方法の配列
334     */
335    function getPayment($total, $productClassIds) {
336        // 有効な支払方法を取得
337        $objProduct = new SC_Product();
338        $paymentIds = $objProduct->getEnablePaymentIds($productClassIds);
339
340        $objQuery =& SC_Query::getSingletonInstance();
341
342        // 削除されていない支払方法を取得
343        $where = 'del_flg = 0 AND payment_id IN (' . implode(', ', array_pad(array(), count($paymentIds), '?')) . ')';
344        $objQuery->setOrder("rank DESC");
345        $payments = $objQuery->select("payment_id, payment_method, rule, upper_rule, note, payment_image", "dtb_payment", $where, $paymentIds);
346
347        foreach ($payments as $data) {
348            // 下限と上限が設定されている
349            if (strlen($data['rule']) != 0 && strlen($data['upper_rule']) != 0) {
350                if ($data['rule'] <= $total_inctax && $data['upper_rule'] >= $total_inctax) {
351                    $arrPayment[] = $data;
352                }
353            }
354            // 下限のみ設定されている
355            elseif (strlen($data['rule']) != 0) {
356                if($data['rule'] <= $total_inctax) {
357                    $arrPayment[] = $data;
358                }
359            }
360            // 上限のみ設定されている
361            elseif (strlen($data['upper_rule']) != 0) {
362                if($data['upper_rule'] >= $total_inctax) {
363                    $arrPayment[] = $data;
364                }
365            }
366            // いずれも設定なし
367            else {
368                $arrPayment[] = $data;
369            }
370          }
371        return $arrPayment;
372    }
373
374    /**
375     * お届け日一覧を取得する.
376     */
377    function getDelivDate(&$objCartSess, $productTypeId) {
378        $cartList = $objCartSess->getCartList($productTypeId);
379        $delivDateIds = array();
380        foreach ($cartList as $item) {
381            $delivDateIds[] = $item['productsClass']['deliv_date_id'];
382        }
383        $max_date = max($delivDateIds);
384        //発送目安
385        switch($max_date) {
386        //即日発送
387        case '1':
388            $start_day = 1;
389            break;
390            //1-2日後
391        case '2':
392            $start_day = 3;
393            break;
394            //3-4日後
395        case '3':
396            $start_day = 5;
397            break;
398            //1週間以内
399        case '4':
400            $start_day = 8;
401            break;
402            //2週間以内
403        case '5':
404            $start_day = 15;
405            break;
406            //3週間以内
407        case '6':
408            $start_day = 22;
409            break;
410            //1ヶ月以内
411        case '7':
412            $start_day = 32;
413            break;
414            //2ヶ月以降
415        case '8':
416            $start_day = 62;
417            break;
418            //お取り寄せ(商品入荷後)
419        case '9':
420            $start_day = "";
421            break;
422        default:
423            //お届け日が設定されていない場合
424            $start_day = "";
425        }
426        //お届け可能日のスタート値から、お届け日の配列を取得する
427        $arrDelivDate = $this->getDateArray($start_day, DELIV_DATE_END_MAX);
428        return $arrDelivDate;
429    }
430
431    /**
432     * お届け可能日のスタート値から, お届け日の配列を取得する.
433     */
434    function getDateArray($start_day, $end_day) {
435        $masterData = new SC_DB_MasterData();
436        $arrWDAY = $masterData->getMasterData("mtb_wday");
437        //お届け可能日のスタート値がセットされていれば
438        if($start_day >= 1) {
439            $now_time = time();
440            $max_day = $start_day + $end_day;
441            // 集計
442            for ($i = $start_day; $i < $max_day; $i++) {
443                // 基本時間から日数を追加していく
444                $tmp_time = $now_time + ($i * 24 * 3600);
445                list($y, $m, $d, $w) = split(" ", date("Y m d w", $tmp_time));
446                $val = sprintf("%04d/%02d/%02d(%s)", $y, $m, $d, $arrWDAY[$w]);
447                $arrDate[$val] = $val;
448            }
449        } else {
450            $arrDate = false;
451        }
452        return $arrDate;
453    }
454
455    /**
456     * 商品種別ID からお届け時間の配列を取得する.
457     */
458    function getDelivTime($productTypeId) {
459        $objQuery =& SC_Query::getSingletonInstance();
460        $from = <<< __EOS__
461                 dtb_deliv T1
462            JOIN dtb_delivtime T2
463              ON T1.deliv_id = T2. deliv_id
464__EOS__;
465            $objQuery->setOrder("time_id");
466            $where = "deliv_id = ?";
467            $results = $objQuery->select("time_id, deliv_time", $from,
468                                         "product_type_id = ?", array($productTypeId));
469            $arrDelivTime = array();
470            foreach ($results as $val) {
471                $arrDelivTime[$val['time_id']] = $val['deliv_time'];
472            }
473            return $arrDelivTime;
474    }
475
476    /**
477     * 商品種別ID から配送業者ID を取得する.
478     */
479    function getDeliv($productTypeId) {
480        $objQuery =& SC_Query::getSingletonInstance();
481        return $objQuery->get("deliv_id", "dtb_deliv", "product_type_id = ?",
482                                 array($productTypeId));
483    }
484
485    /**
486     * 配送情報を登録する.
487     */
488    function registerShipping($orderId, $params) {
489        $objQuery =& SC_Query::getSingletonInstance();
490
491        $cols = $objQuery->listTableFields('dtb_shipping');
492
493        foreach ($params as $shipping_id => $shipping_val) {
494            // 存在するカラムのみ INSERT
495            foreach ($shipping_val as $key => $val) {
496                if (in_array($key, $cols)) {
497                    $sqlval[$key] = $val;
498                }
499            }
500
501            // 配送日付を timestamp に変換
502            if (!SC_Utils_Ex::isBlank($sqlval['shipping_date'])) {
503                $d = mb_strcut($sqlval["shipping_date"], 0, 10);
504                $arrDate = split("/", $d);
505                $ts = mktime(0, 0, 0, $arrDate[1], $arrDate[2], $arrDate[0]);
506                $sqlval['shipping_date'] = date("Y-m-d", $ts);
507            }
508
509            $sqlval['order_id'] = $orderId;
510            $sqlval['shipping_id'] = $shipping_id;
511            $sqlval['create_date'] = 'Now()';
512            $sqlval['update_date'] = 'Now()';
513            $objQuery->insert("dtb_shipping", $sqlval);
514        }
515    }
516
517    /**
518     * 配送商品を登録する.
519     */
520    function registerShipmentItem($orderId, $shippingId, $params) {
521        $objQuery =& SC_Query::getSingletonInstance();
522        $objProduct = new SC_Product();
523        foreach ($params as $productClassId => $val) {
524            $d = $objProduct->getDetailAndProductsClass($productClassId);
525            $sqlval['order_id'] = $orderId;
526            $sqlval['shipping_id'] = $shippingId;
527            $sqlval['product_class_id'] = $productClassId;
528            $sqlval['product_name'] = $d['name'];
529            $sqlval['product_code'] = $d['product_code'];
530            $sqlval['classcategory_name1'] = $d['classcategory_name1'];
531            $sqlval['classcategory_name2'] = $d['classcategory_name2'];
532            $sqlval['price'] = $d['price'];
533            $sqlval['quantity'] = $val['quantity'];
534            $objQuery->insert("dtb_shipment_item", $sqlval);
535        }
536    }
537
538    /**
539     * 受注情報を登録する.
540     *
541     * 引数の受注情報を受注テーブル及び受注詳細テーブルに登録する.
542     * 登録後, 受注一時テーブルに削除フラグを立て, カートの内容を削除する.
543     *
544     * TODO ダウンロード商品の場合の扱いを検討
545     *
546     * @param array $orderParams 登録する受注情報の配列
547     * @param SC_CartSession $objCartSession カート情報のインスタンス
548     * @param integer $cartKey 登録を行うカート情報のキー
549     * @param integer 受注ID
550     */
551    function registerOrder($orderParams, &$objCartSession, $cartKey) {
552        $objQuery =& SC_Query::getSingletonInstance();
553
554        // 別のお届け先を指定が無ければ, お届け先に登録住所をコピー
555        /* FIXME
556        if ($orderParams['deliv_check'] == "-1") {
557            $keys = array('name01', 'name02', 'kana01', 'kana02', 'pref', 'zip01',
558                          'zip02', 'addr01', 'addr02', 'tel01', 'tel02', 'tel03');
559            foreach ($keys as $key) {
560                $orderParams['deliv_' . $key] = $orderParams['order_' . $key];
561            }
562        }
563        */
564        // 不要な変数を unset
565        $unsets = array('mailmaga_flg', 'deliv_check', 'point_check', 'password',
566                        'reminder', 'reminder_answer', 'mail_flag', 'session');
567        foreach ($unsets as $unset) {
568            unset($orderParams[$unset]);
569        }
570
571        // ポイントは別登録
572        $addPoint = $orderParams['add_point'];
573        $usePoint = $orderParams['use_point'];
574        $orderParams['add_point'] = 0;
575        $orderParams['use_point'] = 0;
576
577        // 注文ステータスの指定が無い場合は新規受付
578        if(SC_Utils_Ex::isBlank($orderParams['status'])) {
579            $orderParams['status'] = ORDER_NEW;
580        }
581
582        $orderParams['create_date'] = 'Now()';
583        $orderParams['update_date'] = 'Now()';
584
585        $objQuery->insert("dtb_order", $orderParams);
586
587        // 受注.対応状況の更新
588        SC_Helper_DB_Ex::sfUpdateOrderStatus($orderParams['order_id'],
589                                             null, $addPoint, $usePoint);
590
591        // 詳細情報を取得
592        $cartItems = $objCartSession->getCartList($cartKey);
593
594        // 既に存在する詳細レコードを消しておく。
595        $objQuery->delete("dtb_order_detail", "order_id = ?",
596                          array($orderParams['order_id']));
597
598        $objProduct = new SC_Product();
599        foreach ($cartItems as $item) {
600            $p =& $item['productsClass'];
601            $detail['order_id'] = $orderParams['order_id'];
602            $detail['product_id'] = $p['product_id'];
603            $detail['product_class_id'] = $p['product_class_id'];
604            $detail['product_name'] = $p['name'];
605            $detail['product_code'] = $p['product_code'];
606            $detail['classcategory_name1'] = $p['classcategory_name1'];
607            $detail['classcategory_name2'] = $p['classcategory_name2'];
608            $detail['point_rate'] = $item['point_rate'];
609            $detail['price'] = $item['price'];
610            $detail['quantity'] = $item['quantity'];
611
612            // 在庫の減少処理
613            if (!$objProduct->reduceStock($p['product_class_id'], $item['quantity'])) {
614                $objQuery->rollback();
615                SC_Utils_Ex::sfDispSiteError(SOLD_OUT, "", true);
616            }
617            $objQuery->insert("dtb_order_detail", $detail);
618        }
619
620        $objQuery->update("dtb_order_temp", array('del_flg' => 1),
621                          "order_temp_id = ?",
622                          array(SC_SiteSession::getUniqId()));
623
624        $objCartSession->delAllProducts($cartKey);
625        SC_SiteSession::unsetUniqId();
626        return $orderParams['order_id'];
627    }
628
629    /**
630     * 受注完了メールを送信する.
631     *
632     * HTTP_USER_AGENT の種別により, 携帯電話の場合は携帯用の文面,
633     * PC の場合は PC 用の文面でメールを送信する.
634     *
635     * @param integer $orderId 受注ID
636     * @return void
637     */
638    function sendOrderMail($orderId) {
639        $mailHelper = new SC_Helper_Mail_Ex();
640        $mailHelper->sfSendOrderMail($orderId,
641                                     SC_MobileUserAgent::isMobile() ? 2 : 1);
642    }
643}
Note: See TracBrowser for help on using the repository browser.