source: branches/camp/camp-2_5-E/data/class/pages/admin/order/LC_Page_Admin_Order_Edit.php @ 19652

Revision 19652, 35.7 KB checked in by shutta, 12 years ago (diff)

setTemplate()のスペルミスを修正

  • Property svn:eol-style set to LF
  • Property svn:keywords set to "Id Revision Date"
  • 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// {{{ requires
25require_once(CLASS_PATH . "pages/admin/LC_Page_Admin.php");
26
27/* GMO決済モジュール連携用 */
28if (file_exists(MODULE_PATH . 'mdl_gmopg/inc/include.php') === TRUE) {
29    require_once(MODULE_PATH . 'mdl_gmopg/inc/include.php');
30}
31
32/* ペイジェント決済モジュール連携用 */
33if (file_exists(MODULE_PATH . 'mdl_paygent/include.php') === TRUE) {
34  require_once(MODULE_PATH . 'mdl_paygent/include.php');
35}
36
37/* F-REGI決済モジュール連携用 */
38if (file_exists(MODULE_PATH. 'mdl_fregi/LC_Page_Mdl_Fregi_Config.php') === TRUE) {
39    require_once(MODULE_PATH. 'mdl_fregi/LC_Page_Mdl_Fregi_Config.php');
40}
41
42/* SPS決済モジュール連携用 */
43if (file_exists(MODULE_PATH . 'mdl_sps/request.php') === TRUE) {
44    require_once(MODULE_PATH . 'mdl_sps/request.php');
45}
46
47
48/**
49 * 受注修正 のページクラス.
50 *
51 * @package Page
52 * @author LOCKON CO.,LTD.
53 * @version $Id$
54 */
55class LC_Page_Admin_Order_Edit extends LC_Page_Admin {
56
57    // {{{ properties
58
59    /** 表示モード */
60    var $disp_mode;
61
62    // }}}
63    // {{{ functions
64
65    /**
66     * Page を初期化する.
67     *
68     * @return void
69     */
70    function init() {
71        parent::init();
72        $this->tpl_mainpage = 'order/edit.tpl';
73        $this->tpl_subnavi = 'order/subnavi.tpl';
74        $this->tpl_mainno = 'order';
75        $this->tpl_subno = 'index';
76        $this->tpl_subtitle = '受注管理';
77        if (empty($_GET['order_id']) && empty($_POST['order_id'])) {
78            $this->tpl_subno = 'add';
79            $this->tpl_mode = 'add';
80            $this->tpl_subtitle = '新規受注入力';
81        }
82
83        $masterData = new SC_DB_MasterData_Ex();
84        $this->arrPref = $masterData->getMasterData("mtb_pref",
85                                 array("pref_id", "pref_name", "rank"));
86        $this->arrORDERSTATUS = $masterData->getMasterData("mtb_order_status");
87
88        /* ペイジェント決済モジュール連携用 */
89        if(function_exists("sfPaygentOrderPage")) {
90            $this->arrDispKind = sfPaygentOrderPage();
91        }
92
93        /* F-REGI決済モジュール連携用 */
94        if (file_exists(MODULE_PATH. 'mdl_fregi/LC_Page_Mdl_Fregi_Config.php') === TRUE) {
95            global $arrFregiPayment;
96            $this->arrFregiPayment = $arrFregiPayment;
97            global $arrFregiDispKind;
98            $this->arrFregiDispKind = $arrFregiDispKind;
99        }
100        $this->httpCacheControl('nocache');
101    }
102
103    /**
104     * Page のプロセス.
105     *
106     * @return void
107     */
108    function process() {
109        $this->action();
110        $this->sendResponse();
111    }
112
113    /**
114     * Page のアクション.
115     *
116     * @return void
117     */
118    function action() {
119        $objSess = new SC_Session();
120        $objDb = new SC_Helper_DB_Ex();
121        $objDate = new SC_Date(1901);
122        $this->arrYearDelivDate = $objDate->getYear('', date('Y'), '');
123        $this->arrMonthDelivDate = $objDate->getMonth(true);
124        $this->arrDayDelivDate = $objDate->getDay(true);
125
126        // パラメータ管理クラス
127        $this->objFormParam = new SC_FormParam();
128        // パラメータ情報の初期化
129        $this->lfInitParam();
130
131        // 認証可否の判定
132        SC_Utils_Ex::sfIsSuccess($objSess);
133
134        // 検索パラメータの引き継ぎ
135        foreach ($_POST as $key => $val) {
136            if (ereg("^search_", $key)) {
137                $this->arrSearchHidden[$key] = $val;
138            }
139        }
140
141        // 表示モード判定
142        if(isset($_GET['order_id']) &&
143            SC_Utils_Ex::sfIsInt($_GET['order_id'])) {
144            $this->disp_mode = true;
145            $order_id = $_GET['order_id'];
146        } else {
147            $order_id = $_POST['order_id'];
148        }
149        $this->tpl_order_id = $order_id;
150
151        // DBから受注情報を読み込む
152        $this->lfGetOrderData($order_id);
153
154        switch($_POST['mode']) {
155        case 'pre_edit':
156        case 'order_id':
157            break;
158        case 'edit':
159        case 'add':
160            // POST情報で上書き
161            $this->objFormParam->setParam($_POST);
162
163            // 入力値の変換
164            $this->objFormParam->convParam();
165            $this->arrErr = $this->lfCheckError();
166
167            if(count($this->arrErr) == 0) {
168                if ($_POST['mode'] == 'add') {
169                    $order_id = $this->lfRegistNewData();
170
171                    $this->tpl_order_id = $order_id;
172                    $this->tpl_mode = 'edit';
173
174                    $arrData['order_id'] = $order_id;
175                    $this->objFormParam->setParam($arrData);
176
177                    $text = "'新規受注を登録しました。'";
178                } else {
179                    $this->lfRegistData($_POST['order_id']);
180                    $text = "'受注履歴を編集しました。'";
181                }
182                // DBから受注情報を再読込
183                $this->lfGetOrderData($order_id);
184                $this->tpl_onload = "window.alert(".$text.");";
185            }
186            break;
187            // 再計算
188        case 'cheek':
189        //支払い方法の選択
190        case 'payment':
191            // POST情報で上書き
192            $this->objFormParam->setParam($_POST);
193            // 入力値の変換
194            $this->objFormParam->convParam();
195            $this->arrErr = $this->lfCheckError();
196            break;
197        /* ペイジェント決済モジュール連携用 */
198        case 'paygent_order':
199            $this->paygent_return = sfPaygentOrder($_POST['paygent_type'], $order_id);
200            break;
201        /* 商品削除*/
202        case 'delete_product':
203            $delete_no = $_POST['delete_no'];
204            foreach ($_POST AS $key=>$val) {
205                if (is_array($val)) {
206                    foreach ($val AS $k=>$v) {
207                        if ($k != $delete_no) {
208                            $arrData[$key][] = $v;
209                        }
210                    }
211                } else {
212                    $arrData[$key] = $val;
213                }
214            }
215            // 情報上書き
216            $this->objFormParam->setParam($arrData);
217            // 入力値の変換
218            $this->objFormParam->convParam();
219            $this->arrErr = $this->lfCheckError();
220            break;
221        /* 商品追加ポップアップより商品選択後、商品情報取得*/
222        case 'select_product_detail':
223            // POST情報で上書き
224            $this->objFormParam->setParam($_POST);
225            if (!empty($_POST['add_product_class_id'])) {
226                $this->lfInsertProduct($_POST['add_product_class_id']);
227            } elseif (!empty($_POST['edit_product_class_id'])) {
228                $this->lfUpdateProduct($_POST['edit_product_class_id'], $_POST['no']);
229            }
230            $arrData = $_POST;
231            foreach ($this->arrForm AS $key=>$val) {
232                if (is_array($val)) {
233                    $arrData[$key] = $this->arrForm[$key]['value'];
234                } else {
235                    $arrData[$key] = $val;
236                }
237            }
238            // 情報上書き
239            $this->objFormParam->setParam($arrData);
240            // 入力値の変換
241            $this->objFormParam->convParam();
242            $this->arrErr = $this->lfCheckError();
243            break;
244        /* 顧客検索ポップアップより顧客指定後、顧客情報取得*/
245        case 'search_customer':
246            // POST情報で上書き
247            $this->objFormParam->setParam($_POST);
248
249            // 検索結果から顧客IDを指定された場合、顧客情報をフォームに代入する
250            $this->lfSetCustomerInfo($_POST['edit_customer_id']);
251
252            break;
253        /* F-REGI決済モジュール連携用 */
254        case 'fregi_status':
255            $objFregiConfig = new LC_Page_Mdl_Fregi_Config();
256            $this->fregi_err = $objFregiConfig->getSaleInfo($order_id, $this->arrDisp);
257            $this->lfGetOrderData($order_id);
258            break;
259        case 'fregi_card':
260            $objFregiConfig = new LC_Page_Mdl_Fregi_Config();
261            $this->fregi_card_err = $objFregiConfig->setCardInfo($_POST['card_status'], $order_id, $this->arrDisp);
262            $this->lfGetOrderData($order_id);
263            break;
264        /* SPS決済モジュール連携用 */
265        case 'sps_request':
266            $objErr = new SC_CheckError($_POST);
267            $objErr->doFunc(array("年","sps_year"), array('EXIST_CHECK'));
268            $objErr->doFunc(array("月","sps_month"), array('EXIST_CHECK'));
269            $objErr->doFunc(array("日","sps_date"), array('EXIST_CHECK'));
270            $objErr->doFunc(array("売上・返金日", "sps_year", "sps_month", "sps_date"), array("CHECK_DATE"));
271            if ($objErr->arrErr) {
272                $this->arrErr = $objErr->arrErr;
273                break;
274            }
275            $sps_return = sfSpsRequest( $order_id, $_POST['request_type'] );
276            // DBから受注情報を再読込
277            $this->lfGetOrderData($order_id);
278            $this->tpl_onload = "window.alert('".$sps_return."');";
279            break;
280
281        /* GMOPG連携用 */
282        case 'gmopg_order_edit':
283            require_once(MODULE_PATH . 'mdl_gmopg/class/LC_Mdl_GMOPG_OrderEdit.php');
284            $objGMOOrderEdit = new LC_MDL_GMOPG_OrderEdit;
285            $this->gmopg_order_edit_result = $objGMOOrderEdit->proccess();
286            $this->lfGetOrderData($order_id);
287            break;
288        default:
289            break;
290        }
291
292        // 支払い方法の取得
293        $this->arrPayment = $objDb->sfGetIDValueList("dtb_payment", "payment_id", "payment_method");
294        // お届け時間の取得
295        $arrRet = $objDb->sfGetDelivTime($this->objFormParam->getValue('payment_id'));
296        $this->arrDelivTime = SC_Utils_Ex::sfArrKeyValue($arrRet, 'time_id', 'deliv_time');
297
298        $this->arrForm = $this->objFormParam->getFormParamList();
299        $this->product_count = count($this->arrForm['quantity']['value']);
300
301        // アンカーを設定
302        if (isset($_POST['anchor_key']) && !empty($_POST['anchor_key'])) {
303            $anchor_hash = "location.hash='#" . $_POST['anchor_key'] . "'";
304        } else {
305            $anchor_hash = "";
306        }
307        $this->tpl_onload .= $anchor_hash;
308
309        $objSiteInfo = new SC_SiteInfo();
310        $this->arrInfo = $objSiteInfo->data;
311
312        /**
313         * SPS決済 クレジット判定用処理
314         */
315        if (file_exists(MODULE_PATH . 'mdl_sps/request.php') === TRUE) {
316            $objQuery = new SC_Query();
317            $this->paymentType = $objQuery->getAll("SELECT module_code, memo03 FROM dtb_payment WHERE payment_id = ? ", array($this->arrForm["payment_id"]['value']));
318            $objDate = new SC_Date();
319            $objDate->setStartYear(RELEASE_YEAR);
320            $this->arrYear = $objDate->getYear();
321            $this->arrMonth = $objDate->getMonth();
322            $this->arrDay = $objDate->getDay();
323        }
324
325        // 表示モード判定
326        if(!$this->disp_mode) {
327            $this->setTemplate(MAIN_FRAME);
328        } else {
329            $this->setTemplate('order/disp.tpl');
330        }
331    }
332
333    /**
334     * デストラクタ.
335     *
336     * @return void
337     */
338    function destroy() {
339        parent::destroy();
340    }
341
342    /* パラメータ情報の初期化 */
343    function lfInitParam() {
344
345        // お客様情報
346        $this->objFormParam->addParam("顧客名1", "order_name01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
347        $this->objFormParam->addParam("顧客名2", "order_name02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
348        $this->objFormParam->addParam("顧客名カナ1", "order_kana01", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
349        $this->objFormParam->addParam("顧客名カナ2", "order_kana02", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
350        $this->objFormParam->addParam("メールアドレス", "order_email", MTEXT_LEN, "KVCa", array("NO_SPTAB", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
351        $this->objFormParam->addParam("郵便番号1", "order_zip01", ZIP01_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
352        $this->objFormParam->addParam("郵便番号2", "order_zip02", ZIP02_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
353        $this->objFormParam->addParam("都道府県", "order_pref", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
354        $this->objFormParam->addParam("住所1", "order_addr01", MTEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
355        $this->objFormParam->addParam("住所2", "order_addr02", MTEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
356        $this->objFormParam->addParam("電話番号1", "order_tel01", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
357        $this->objFormParam->addParam("電話番号2", "order_tel02", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
358        $this->objFormParam->addParam("電話番号3", "order_tel03", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
359
360        // お届け先情報
361        $this->objFormParam->addParam("お名前1", "deliv_name01", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
362        $this->objFormParam->addParam("お名前2", "deliv_name02", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
363        $this->objFormParam->addParam("お名前(フリガナ・姓)", "deliv_kana01", STEXT_LEN, "KVCa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
364        $this->objFormParam->addParam("お名前(フリガナ・名)", "deliv_kana02", STEXT_LEN, "KVCa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
365        $this->objFormParam->addParam("郵便番号1", "deliv_zip01", ZIP01_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
366        $this->objFormParam->addParam("郵便番号2", "deliv_zip02", ZIP02_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
367        $this->objFormParam->addParam("都道府県", "deliv_pref", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
368        $this->objFormParam->addParam("住所1", "deliv_addr01", MTEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
369        $this->objFormParam->addParam("住所2", "deliv_addr02", MTEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
370        $this->objFormParam->addParam("電話番号1", "deliv_tel01", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
371        $this->objFormParam->addParam("電話番号2", "deliv_tel02", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
372        $this->objFormParam->addParam("電話番号3", "deliv_tel03", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
373
374
375        // 受注商品情報
376        $this->objFormParam->addParam("値引き", "discount", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"), '0');
377        $this->objFormParam->addParam("送料", "deliv_fee", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"), '0');
378        $this->objFormParam->addParam("手数料", "charge", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
379
380        // ポイント機能ON時のみ
381        if (USE_POINT !== false) {
382            $this->objFormParam->addParam("利用ポイント", "use_point", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
383        }
384
385        $this->objFormParam->addParam("お支払い方法", "payment_id", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
386        $this->objFormParam->addParam("お届け時間ID", "deliv_time_id", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
387        $this->objFormParam->addParam("対応状況", "status", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
388        $this->objFormParam->addParam("お届け日", "deliv_date", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
389        $this->objFormParam->addParam("お支払方法名称", "payment_method");
390        $this->objFormParam->addParam("お届け時間", "deliv_time");
391
392        // 受注詳細情報
393        $this->objFormParam->addParam("単価", "price", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"), '0');
394        $this->objFormParam->addParam("数量", "quantity", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"), '0');
395        $this->objFormParam->addParam("商品ID", "product_id", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"), '0');
396        $this->objFormParam->addParam("商品規格ID", "product_class_id", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"), '0');
397        $this->objFormParam->addParam("ポイント付与率", "point_rate");
398        $this->objFormParam->addParam("商品コード", "product_code");
399        $this->objFormParam->addParam("商品名", "product_name");
400        $this->objFormParam->addParam("規格名1", "classcategory_name1");
401        $this->objFormParam->addParam("規格名2", "classcategory_name2");
402        $this->objFormParam->addParam("メモ", "note", MTEXT_LEN, "KVa", array("MAX_LENGTH_CHECK"));
403        // DB読込用
404        $this->objFormParam->addParam("小計", "subtotal");
405        $this->objFormParam->addParam("合計", "total");
406        $this->objFormParam->addParam("支払い合計", "payment_total");
407        $this->objFormParam->addParam("加算ポイント", "add_point");
408        $this->objFormParam->addParam("お誕生日ポイント", "birth_point");
409        $this->objFormParam->addParam("消費税合計", "tax");
410        $this->objFormParam->addParam("最終保持ポイント", "total_point");
411        $this->objFormParam->addParam("顧客ID", "customer_id");
412        $this->objFormParam->addParam("現在のポイント", "point");
413        $this->objFormParam->addParam("注文番号", "order_id");
414        $this->objFormParam->addParam("受注日", "create_date");
415        $this->objFormParam->addParam("発送日", "commit_date");
416        $this->objFormParam->addParam("備考", "message");
417        $this->objFormParam->addParam("入金日", "payment_date");
418    }
419
420    function lfGetOrderData($order_id) {
421        if(SC_Utils_Ex::sfIsInt($order_id)) {
422            // DBから受注情報を読み込む
423            $objQuery = new SC_Query();
424            $objDb = new SC_Helper_DB_Ex();
425            $where = "order_id = ?";
426            $arrRet = $objQuery->select("*", "dtb_order", $where, array($order_id));
427            $this->objFormParam->setParam($arrRet[0]);
428            list($point, $total_point) = $objDb->sfGetCustomerPoint($order_id, $arrRet[0]['use_point'], $arrRet[0]['add_point']);
429            $this->objFormParam->setValue('total_point', $total_point);
430            $this->objFormParam->setValue('point', $point);
431            $this->arrForm = $arrRet[0];
432
433            // 受注詳細データの取得
434            $arrRet = $this->lfGetOrderDetail($order_id);
435            $arrRet = SC_Utils_Ex::sfSwapArray($arrRet);
436            $this->arrForm = array_merge($this->arrForm, $arrRet);
437            $this->objFormParam->setParam($arrRet);
438
439            // その他支払い情報を表示
440            if($this->arrForm["memo02"] != "") $this->arrForm["payment_info"] = unserialize($this->arrForm["memo02"]);
441            if($this->arrForm["memo01"] == PAYMENT_CREDIT_ID){
442                $this->arrForm["payment_type"] = "クレジット決済";
443            }elseif($this->arrForm["memo01"] == PAYMENT_CONVENIENCE_ID){
444                $this->arrForm["payment_type"] = "コンビニ決済";
445            }else{
446                $this->arrForm["payment_type"] = "お支払い";
447            }
448            // 受注データを表示用配列に代入(各EC-CUBEバージョンと決済モジュールとのデータ連携保全のため)
449            $this->arrDisp = $this->arrForm;
450        }
451    }
452
453    // 受注詳細データの取得
454    function lfGetOrderDetail($order_id) {
455        $objQuery = new SC_Query();
456        $col = "product_id, product_class_id, product_code, product_name, classcategory_name1, classcategory_name2, price, quantity, point_rate";
457        $where = "order_id = ?";
458        $arrRet = $objQuery->select($col, "dtb_order_detail", $where, array($order_id));
459        return $arrRet;
460    }
461
462    /* 入力内容のチェック */
463    function lfCheckError() {
464        // 入力データを渡す。
465        $arrRet =  $this->objFormParam->getHashArray();
466        $objErr = new SC_CheckError($arrRet);
467        $objErr->arrErr = $this->objFormParam->checkError();
468
469        if (count($objErr->arrErr) >= 1) {
470            return $objErr->arrErr;
471        }
472
473        return $this->lfCheek();
474    }
475
476    /* 計算処理 */
477    function lfCheek() {
478        $objDb = new SC_Helper_DB_Ex();
479        $arrVal = $this->objFormParam->getHashArray();
480        $arrErr = array();
481
482        // 商品の種類数
483        $max = count($arrVal['quantity']);
484        $subtotal = 0;
485        $totalpoint = 0;
486        $totaltax = 0;
487        for($i = 0; $i < $max; $i++) {
488            // 小計の計算
489            $subtotal += SC_Helper_DB_Ex::sfPreTax($arrVal['price'][$i]) * $arrVal['quantity'][$i];
490            // 小計の計算
491            $totaltax += SC_Helper_DB_Ex::sfTax($arrVal['price'][$i]) * $arrVal['quantity'][$i];
492            // 加算ポイントの計算
493            $totalpoint += SC_Utils_Ex::sfPrePoint($arrVal['price'][$i], $arrVal['point_rate'][$i]) * $arrVal['quantity'][$i];
494        }
495
496        // 消費税
497        $arrVal['tax'] = $totaltax;
498        // 小計
499        $arrVal['subtotal'] = $subtotal;
500        // 合計
501        $arrVal['total'] = $subtotal - $arrVal['discount'] + $arrVal['deliv_fee'] + $arrVal['charge'];
502        // お支払い合計
503        $arrVal['payment_total'] = $arrVal['total'] - ($arrVal['use_point'] * POINT_VALUE);
504
505        // 加算ポイント
506        $arrVal['add_point'] = SC_Helper_DB_Ex::sfGetAddPoint($totalpoint, $arrVal['use_point']);
507
508        if (strlen($_POST['customer_id']) > 0){
509            list($arrVal['point'], $arrVal['total_point']) = $objDb->sfGetCustomerPointFromCid($_POST['customer_id'], $arrVal['use_point'], $arrVal['add_point']);
510        }else{
511            list($arrVal['point'], $arrVal['total_point']) = $objDb->sfGetCustomerPoint($_POST['order_id'], $arrVal['use_point'], $arrVal['add_point']);
512        }
513        if ($arrVal['total'] < 0) {
514            $arrErr['total'] = '合計額がマイナス表示にならないように調整して下さい。<br />';
515        }
516
517        if ($arrVal['payment_total'] < 0) {
518            $arrErr['payment_total'] = 'お支払い合計額がマイナス表示にならないように調整して下さい。<br />';
519        }
520        //新規追加受注のみ
521        if ($_POST['mode'] == "add") {
522            if ($arrVal['total_point'] < 0) {
523                    $arrErr['use_point'] = '最終保持ポイントがマイナス表示にならないように調整して下さい。<br />';
524            }
525        }
526
527        $this->objFormParam->setParam($arrVal);
528        return $arrErr;
529    }
530
531    /**
532     * DB更新処理
533     *
534     * @param integer $order_id 注文番号
535     * @return void
536     */
537    function lfRegistData($order_id) {
538        $objQuery = new SC_Query();
539
540        $sqlval = $this->lfMakeSqlvalForDtbOrder();
541
542        $where = "order_id = ?";
543
544        $objQuery->begin();
545
546        // 受注.対応状況の更新
547        SC_Helper_DB_Ex::sfUpdateOrderStatus($order_id, $sqlval['status'], $sqlval['add_point'], $sqlval['use_point']);
548        unset($sqlval['status']);
549        unset($sqlval['add_point']);
550        unset($sqlval['use_point']);
551
552        // 受注テーブルの更新
553        $objQuery->update("dtb_order", $sqlval, $where, array($order_id));
554
555        // 受注テーブルの名称列を更新
556        SC_Helper_DB_Ex::sfUpdateOrderNameCol($order_id);
557
558        $arrDetail = $this->objFormParam->getSwapArray(array("product_id", "product_class_id", "product_code", "product_name", "price", "quantity", "point_rate", "classcategory_name1", "classcategory_name2"));
559
560
561        // 変更しようとしている商品情報とDBに登録してある商品情報を比較することで、更新すべき数量を計算
562        $max = count($arrDetail);
563        $k = 0;
564        $arrStockData = array();
565        for($i = 0; $i < $max; $i++) {
566            if (!empty($arrDetail[$i]['product_id'])) {
567                $arrPreDetail = $objQuery->select('*', "dtb_order_detail", "order_id = ? AND product_class_id = ?", array($order_id, $arrDetail[$i]['product_class_id']));
568                if (!empty($arrPreDetail) && $arrPreDetail[0]['quantity'] != $arrDetail[$i]['quantity']) {
569                    // 数量が変更された商品
570                    $arrStockData[$k]['product_class_id'] = $arrDetail[$i]['product_class_id'];
571                    $arrStockData[$k]['quantity'] = $arrPreDetail[0]['quantity'] - $arrDetail[$i]['quantity'];
572                    ++$k;
573                } elseif (empty($arrPreDetail)) {
574                    // 新しく追加された商品 もしくは 違う商品に変更された商品
575                    $arrStockData[$k]['product_class_id'] = $arrDetail[$i]['product_class_id'];
576                    $arrStockData[$k]['quantity'] = -$arrDetail[$i]['quantity'];
577                    ++$k;
578                }
579                $objQuery->delete("dtb_order_detail", "order_id = ? AND product_class_id = ?", array($order_id, $arrDetail[$i]['product_class_id']));
580            }
581        }
582
583        // 上記の新しい商品のループでDELETEされなかった商品は、注文より削除された商品
584        $arrPreDetail = $objQuery->select('*', "dtb_order_detail", "order_id = ?", array($order_id));
585        foreach ($arrPreDetail AS $key=>$val) {
586            $arrStockData[$k]['product_class_id'] = $val['product_class_id'];
587            $arrStockData[$k]['quantity'] = $val['quantity'];
588            ++$k;
589        }
590
591        // 受注詳細データの初期化
592        $objQuery->delete("dtb_order_detail", $where, array($order_id));
593
594        // 受注詳細データの更新
595        $max = count($arrDetail);
596        for ($i = 0; $i < $max; $i++) {
597            $sqlval = array();
598            $sqlval['order_id'] = $order_id;
599            $sqlval['product_id']  = $arrDetail[$i]['product_id'];
600            $sqlval['product_class_id']  = $arrDetail[$i]['product_class_id'];
601            $sqlval['product_code']  = $arrDetail[$i]['product_code'];
602            $sqlval['product_name']  = $arrDetail[$i]['product_name'];
603            $sqlval['price']  = $arrDetail[$i]['price'];
604            $sqlval['quantity']  = $arrDetail[$i]['quantity'];
605            $sqlval['point_rate']  = $arrDetail[$i]['point_rate'];
606            $sqlval['classcategory_name1'] = $arrDetail[$i]['classcategory_name1'];
607            $sqlval['classcategory_name2'] = $arrDetail[$i]['classcategory_name2'];
608            $objQuery->insert("dtb_order_detail", $sqlval);
609        }
610
611        // 在庫数調整
612        $status = $sqlval['status'];
613        if (ORDER_DELIV != $status && ORDER_CANCEL != $status) {
614            $stock_sql = "UPDATE dtb_products_class SET stock = stock + ? WHERE product_class_id = ?";
615            foreach ($arrStockData AS $key=>$val) {
616                $stock_sqlval = array();
617                $stock_sqlval[] = $val['quantity'];
618                $stock_sqlval[] = $val['product_class_id'];
619
620                $objQuery->query($stock_sql, $stock_sqlval);
621            }
622        }
623
624        $objQuery->commit();
625    }
626
627    /**
628     * DB登録処理
629     *
630     * @return integer 注文番号
631     */
632    function lfRegistNewData() {
633        $objQuery = new SC_Query();
634
635        $sqlval = $this->lfMakeSqlvalForDtbOrder();
636
637        // ポイントは別登録
638        $addPoint = $sqlval['add_point'];
639        $usePoint = $sqlval['use_point'];
640        $sqlval['add_point'] = 0;
641        $sqlval['use_point'] = 0;
642
643        // customer_id
644        if ($sqlval["customer_id"] == "") {
645            $sqlval['customer_id'] = '0';
646        }
647
648        $sqlval['create_date'] = 'Now()';       // 受注日
649
650        $objQuery->begin();
651
652        // 受注テーブルの登録
653        $order_id = $objQuery->nextVal('dtb_order_order_id');
654        $sqlval['order_id'] = $order_id;
655        $objQuery->insert("dtb_order", $sqlval);
656
657
658        // 受注.対応状況の更新
659        SC_Helper_DB_Ex::sfUpdateOrderStatus($order_id, null, $addPoint, $usePoint);
660
661        // 受注テーブルの名称列を更新
662        SC_Helper_DB_Ex::sfUpdateOrderNameCol($order_id);
663
664        // 受注詳細データの更新
665        $arrDetail = $this->objFormParam->getSwapArray(array("product_id", "product_class_id", "product_code", "product_name", "price", "quantity", "point_rate", "classcategory_name1", "classcategory_name2"));
666        $objQuery->delete("dtb_order_detail", 'order_id = ?', array($order_id));
667
668        $max = count($arrDetail);
669        for ($i = 0; $i < $max; $i++) {
670            $sqlval = array();
671            $sqlval['order_id'] = $order_id;
672            $sqlval['product_id']  = $arrDetail[$i]['product_id'];
673            $sqlval['product_class_id']  = $arrDetail[$i]['product_class_id'];
674            $sqlval['product_code']  = $arrDetail[$i]['product_code'];
675            $sqlval['product_name']  = $arrDetail[$i]['product_name'];
676            $sqlval['price']  = $arrDetail[$i]['price'];
677            $sqlval['quantity']  = $arrDetail[$i]['quantity'];
678            $sqlval['point_rate']  = $arrDetail[$i]['point_rate'];
679            $sqlval['classcategory_name1'] = $arrDetail[$i]['classcategory_name1'];
680            $sqlval['classcategory_name2'] = $arrDetail[$i]['classcategory_name2'];
681
682            $objQuery->insert("dtb_order_detail", $sqlval);
683
684
685            // 在庫数減少処理
686            // 現在の実在庫数取得
687            $pre_stock = $objQuery->getOne("SELECT stock FROM dtb_products_class WHERE product_class_id = ?", array($arrDetail[$i]['product_class_id']));
688
689            $stock_sqlval = array();
690            $stock_sqlval['stock'] = intval($pre_stock - $arrDetail[$i]['quantity']);
691            if ($stock_sqlval['stock'] === 0) {
692                $stock_sqlval['stock'] = '0';
693        }
694
695            $st_params = array();
696            $st_params[] = $arrDetail[$i]['product_class_id'];
697
698            $objQuery->update("dtb_products_class", $stock_sqlval, 'product_class_id = ?', $st_params);
699        }
700        $objQuery->commit();
701
702        return $order_id;
703    }
704
705    function lfInsertProduct($product_class_id) {
706        $objProduct = new SC_Product();
707        $arrProduct = $this->lfGetProductsClass($objProduct->getDetailAndProductsClass($product_class_id));
708        $this->arrForm = $this->objFormParam->getFormParamList();
709        $existes = false;
710        $existes_key = NULL;
711        // 既に同じ商品がないか、確認する
712        if (!empty($this->arrForm['product_class_id']['value'])) {
713            foreach ($this->arrForm['product_class_id']['value'] AS $key=>$val) {
714                // 既に同じ商品がある場合
715                if ($val == $product_class_id) {
716                    $existes = true;
717                    $existes_key = $key;
718                }
719            }
720        }
721
722        if ($existes) {
723        // 既に同じ商品がある場合
724            ++$this->arrForm['quantity']['value'][$existes_key];
725        } else {
726        // 既に同じ商品がない場合
727            $this->lfSetProductData($arrProduct);
728        }
729    }
730
731    function lfUpdateProduct($product_class_id, $no) {
732        $objProduct = new SC_Product();
733        $arrProduct = $this->lfGetProductsClass($objProduct->getDetailAndProductsClass($product_class_id));
734        $this->arrForm = $this->objFormParam->getFormParamList();
735        $this->lfSetProductData($arrProduct, $no);
736    }
737
738    function lfSetProductData($arrProduct, $no = null) {
739        foreach ($arrProduct AS $key=>$val) {
740            if (!is_array($this->arrForm[$key]['value'])) {
741                unset($this->arrForm[$key]['value']);
742            }
743            if ($no === null) {
744                $this->arrForm[$key]['value'][] = $val;
745            } else {
746                $this->arrForm[$key]['value'][$no] = $val;
747            }
748        }
749    }
750
751    function lfGetProductsClass($productsClass) {
752        $arrProduct['price'] = $productsClass['price02'];
753        $arrProduct['quantity'] = 1;
754        $arrProduct['product_id'] = $productsClass['product_id'];
755        $arrProduct['product_class_id'] = $productsClass['product_class_id'];
756        $arrProduct['point_rate'] = $productsClass['point_rate'];
757        $arrProduct['product_code'] = $productsClass['product_code'];
758        $arrProduct['product_name'] = $productsClass['name'];
759        $arrProduct['classcategory_name1'] = $productsClass['classcategory_name1'];
760        $arrProduct['classcategory_name2'] = $productsClass['classcategory_name2'];
761
762        return $arrProduct;
763    }
764
765
766    /**
767     * 検索結果から顧客IDを指定された場合、顧客情報をフォームに代入する
768     * @param int $edit_customer_id 顧客ID
769     */
770    function lfSetCustomerInfo($edit_customer_id = ""){
771        // 顧客IDが指定されている場合のみ、処理を実行する
772        if( $edit_customer_id === "" ) return ;
773
774        // 検索で選択された顧客IDが入力されている場合
775        if( is_null($edit_customer_id) === false && 0 < strlen($edit_customer_id) && SC_Utils_Ex::sfIsInt($edit_customer_id) ){
776            $objQuery = new SC_Query();
777
778            // 顧客情報を取得する
779            $arrCustomerInfo = $objQuery->select('*', 'dtb_customer', 'customer_id = ? AND del_flg = 0', array($edit_customer_id));
780
781            // 顧客情報を取得する事が出来たら、テンプレートに値を渡す
782            if( 0 < count($arrCustomerInfo) && is_array($arrCustomerInfo) === true){
783                // カラム名にorder_を付ける(テンプレート側でorder_がついている為
784                foreach($arrCustomerInfo[0] as $index=>$customer_info){
785                    // customer_idにはorder_を付けないようにする
786                    $order_index = ($index == 'customer_id') ? $index : 'order_'.$index;
787                    $arrCustomer[$order_index] = $customer_info;
788                }
789            }
790
791            // hiddenに渡す
792            $this->edit_customer_id = $edit_customer_id;
793
794            // 受注日に現在の時刻を取得し、表示させる
795            $create_date = $objQuery->getAll('SELECT now() as create_date;');
796            $arrCustomer['create_date'] = $create_date[0]['create_date'];
797
798            // 情報上書き
799            $this->objFormParam->setParam($arrCustomer);
800            // 入力値の変換
801            $this->objFormParam->convParam();
802        }
803    }
804
805    /**
806     * 受注テーブルの登録・更新用データの共通部分を作成する
807     *
808     * @return array
809     */
810    function lfMakeSqlvalForDtbOrder() {
811
812        // 入力データを取得する
813        $sqlval = $this->objFormParam->getHashArray();
814        foreach ($sqlval as $key => $val) {
815            // 配列は登録しない
816            if (is_array($val)) {
817                unset($sqlval[$key]);
818            }
819        }
820
821        // 受注テーブルに書き込まない列を除去
822        unset($sqlval['total_point']);
823        unset($sqlval['point']);
824        unset($sqlval['commit_date']);
825
826        // 更新日時
827        $sqlval['update_date'] = 'Now()';
828
829        return $sqlval;
830   }
831}
832?>
Note: See TracBrowser for help on using the repository browser.