source: branches/version-2_13-dev/data/class/pages/admin/order/LC_Page_Admin_Order_Disp.php @ 23546

Revision 23546, 18.4 KB checked in by shutta, 10 years ago (diff)

#2580 Copyrightを更新
Copyrightを2014に更新

Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2014 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
24require_once CLASS_EX_REALDIR . 'page_extends/admin/order/LC_Page_Admin_Order_Ex.php';
25
26/**
27 * 受注情報表示 のページクラス.
28 *
29 * @package Page
30 * @author LOCKON CO.,LTD.
31 * @version $Id: LC_Page_Admin_Order_Disp.php 20767 2011-03-22 10:07:32Z nanasess $
32 */
33class LC_Page_Admin_Order_Disp extends LC_Page_Admin_Order_Ex
34{
35    public $arrShippingKeys = array(
36        'shipping_id',
37        'shipping_name01',
38        'shipping_name02',
39        'shipping_kana01',
40        'shipping_kana02',
41        'shipping_company_name',
42        'shipping_tel01',
43        'shipping_tel02',
44        'shipping_tel03',
45        'shipping_fax01',
46        'shipping_fax02',
47        'shipping_fax03',
48        'shipping_country_id',
49        'shipping_zipcode',
50        'shipping_pref',
51        'shipping_zip01',
52        'shipping_zip02',
53        'shipping_addr01',
54        'shipping_addr02',
55        'shipping_date_year',
56        'shipping_date_month',
57        'shipping_date_day',
58        'time_id',
59    );
60
61    public $arrShipmentItemKeys = array(
62        'shipment_product_class_id',
63        'shipment_product_code',
64        'shipment_product_name',
65        'shipment_classcategory_name1',
66        'shipment_classcategory_name2',
67        'shipment_price',
68        'shipment_quantity',
69    );
70
71    /**
72     * Page を初期化する.
73     *
74     * @return void
75     */
76    public function init()
77    {
78        parent::init();
79        $this->tpl_mainpage = 'order/disp.tpl';
80        $this->tpl_mainno = 'order';
81        $this->tpl_subnavi = '';
82        $this->tpl_subno = '';
83        $this->tpl_subtitle = '受注情報表示';
84
85        $masterData = new SC_DB_MasterData_Ex();
86        $this->arrPref = $masterData->getMasterData('mtb_pref');
87        $this->arrORDERSTATUS = $masterData->getMasterData('mtb_order_status');
88        $this->arrDeviceType = $masterData->getMasterData('mtb_device_type');
89        $this->arrCountry = $masterData->getMasterData('mtb_country');
90        $this->arrSex = $masterData->getMasterData('mtb_sex');
91        $this->arrJob = $masterData->getMasterData('mtb_job');
92
93        // 支払い方法の取得
94        $this->arrPayment = SC_Helper_Payment_Ex::getIDValueList();
95
96        // 配送業者の取得
97        $this->arrDeliv = SC_Helper_Delivery_Ex::getIDValueList();
98    }
99
100    /**
101     * Page のプロセス.
102     *
103     * @return void
104     */
105    public function process()
106    {
107        $this->action();
108        $this->sendResponse();
109    }
110
111    /**
112     * Page のアクション.
113     *
114     * @return void
115     */
116    public function action()
117    {
118        $objPurchase = new SC_Helper_Purchase_Ex();
119        $objFormParam = new SC_FormParam_Ex();
120
121        // パラメータ情報の初期化
122        $this->lfInitParam($objFormParam);
123        $objFormParam->setParam($_REQUEST);
124        $objFormParam->convParam();
125        $order_id = $objFormParam->getValue('order_id');
126
127        // DBから受注情報を読み込む
128        $this->setOrderToFormParam($objFormParam, $order_id);
129
130        $this->arrForm = $objFormParam->getFormParamList();
131        $this->arrAllShipping = $objFormParam->getSwapArray(array_merge($this->arrShippingKeys, $this->arrShipmentItemKeys));
132        $this->tpl_shipping_quantity = count($this->arrAllShipping);
133        $this->arrDelivTime = SC_Helper_Delivery_Ex::getDelivTime($objFormParam->getValue('deliv_id'));
134        $this->arrInfo = SC_Helper_DB_Ex::sfGetBasisData();
135
136        $this->setTemplate($this->tpl_mainpage);
137    }
138
139    /**
140     * パラメータ情報の初期化を行う.
141     *
142     * @param  SC_FormParam $objFormParam SC_FormParam インスタンス
143     * @return void
144     */
145    public function lfInitParam(&$objFormParam)
146    {
147        // 検索条件のパラメータを初期化
148        parent::lfInitParam($objFormParam);
149
150        // お客様情報
151        $objFormParam->addParam('注文者 お名前(姓)', 'order_name01', STEXT_LEN, 'KVa', array('EXIST_CHECK', 'SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
152        $objFormParam->addParam('注文者 お名前(名)', 'order_name02', STEXT_LEN, 'KVa', array('EXIST_CHECK', 'SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
153        $objFormParam->addParam('注文者 お名前(フリガナ・姓)', 'order_kana01', STEXT_LEN, 'KVCa', array('EXIST_CHECK', 'SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
154        $objFormParam->addParam('注文者 お名前(フリガナ・名)', 'order_kana02', STEXT_LEN, 'KVCa', array('EXIST_CHECK', 'SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
155        $objFormParam->addParam('注文者 会社名', 'order_company_name', STEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
156        $objFormParam->addParam('メールアドレス', 'order_email', null, 'KVCa', array('NO_SPTAB', 'EMAIL_CHECK', 'EMAIL_CHAR_CHECK'));
157        if (FORM_COUNTRY_ENABLE) {
158            $objFormParam->addParam('国', 'order_country_id', INT_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK'));
159            $objFormParam->addParam('ZIPCODE', 'order_zipcode', STEXT_LEN, 'n', array('NO_SPTAB', 'SPTAB_CHECK', 'GRAPH_CHECK', 'MAX_LENGTH_CHECK'));
160        }
161        $objFormParam->addParam('郵便番号1', 'order_zip01', ZIP01_LEN, 'n', array('NUM_CHECK', 'NUM_COUNT_CHECK'));
162        $objFormParam->addParam('郵便番号2', 'order_zip02', ZIP02_LEN, 'n', array('NUM_CHECK', 'NUM_COUNT_CHECK'));
163        $objFormParam->addParam('都道府県', 'order_pref', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
164        $objFormParam->addParam('住所1', 'order_addr01', MTEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
165        $objFormParam->addParam('住所2', 'order_addr02', MTEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
166        $objFormParam->addParam('電話番号1', 'order_tel01', TEL_ITEM_LEN, 'n', array('MAX_LENGTH_CHECK' ,'NUM_CHECK'));
167        $objFormParam->addParam('電話番号2', 'order_tel02', TEL_ITEM_LEN, 'n', array('MAX_LENGTH_CHECK' ,'NUM_CHECK'));
168        $objFormParam->addParam('電話番号3', 'order_tel03', TEL_ITEM_LEN, 'n', array('MAX_LENGTH_CHECK' ,'NUM_CHECK'));
169        $objFormParam->addParam('性別', 'order_sex', TEL_ITEM_LEN, 'n', array('MAX_LENGTH_CHECK' ,'NUM_CHECK'));
170        $objFormParam->addParam('職業', 'order_job', TEL_ITEM_LEN, 'n', array('MAX_LENGTH_CHECK' ,'NUM_CHECK'));
171        $objFormParam->addParam('生年月日(年)', 'order_birth_year', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
172        $objFormParam->addParam('生年月日(月)', 'order_birth_month', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
173        $objFormParam->addParam('生年月日(日)', 'order_birth_day', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
174
175        // 受注商品情報
176        $objFormParam->addParam('値引き', 'discount', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
177        $objFormParam->addParam('送料', 'deliv_fee', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
178        $objFormParam->addParam('手数料', 'charge', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
179
180        // ポイント機能ON時のみ
181        if (USE_POINT !== false) {
182            $objFormParam->addParam('利用ポイント', 'use_point', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'));
183        }
184
185        $objFormParam->addParam('配送業者', 'deliv_id', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'));
186        $objFormParam->addParam('お支払い方法', 'payment_id', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'));
187        $objFormParam->addParam('対応状況', 'status', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'));
188        $objFormParam->addParam('お支払方法名称', 'payment_method');
189
190        // 受注詳細情報
191        $objFormParam->addParam('商品種別ID', 'product_type_id', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
192        $objFormParam->addParam('単価', 'price', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
193        $objFormParam->addParam('数量', 'quantity', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
194        $objFormParam->addParam('商品ID', 'product_id', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
195        $objFormParam->addParam('商品規格ID', 'product_class_id', INT_LEN, 'n', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
196        $objFormParam->addParam('ポイント付与率', 'point_rate');
197        $objFormParam->addParam('商品コード', 'product_code');
198        $objFormParam->addParam('商品名', 'product_name');
199        $objFormParam->addParam('規格名1', 'classcategory_name1');
200        $objFormParam->addParam('規格名2', 'classcategory_name2');
201        $objFormParam->addParam('メモ', 'note', MTEXT_LEN, 'KVa', array('MAX_LENGTH_CHECK'));
202        $objFormParam->addParam('削除用項番', 'delete_no', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
203        $objFormParam->addParam('消費税率', 'tax_rate');
204        $objFormParam->addParam('課税規則', 'tax_rule');
205
206        // DB読込用
207        $objFormParam->addParam('小計', 'subtotal');
208        $objFormParam->addParam('合計', 'total');
209        $objFormParam->addParam('支払い合計', 'payment_total');
210        $objFormParam->addParam('加算ポイント', 'add_point');
211        $objFormParam->addParam('お誕生日ポイント', 'birth_point');
212        $objFormParam->addParam('消費税合計', 'tax');
213        $objFormParam->addParam('最終保持ポイント', 'total_point');
214        $objFormParam->addParam('会員ID', 'customer_id', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
215        $objFormParam->addParam('会員ID', 'edit_customer_id', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
216        $objFormParam->addParam('現在のポイント', 'customer_point');
217        $objFormParam->addParam('受注前ポイント', 'point');
218        $objFormParam->addParam('注文番号', 'order_id');
219        $objFormParam->addParam('受注日', 'create_date');
220        $objFormParam->addParam('発送日', 'commit_date');
221        $objFormParam->addParam('備考', 'message');
222        $objFormParam->addParam('入金日', 'payment_date');
223        $objFormParam->addParam('端末種別', 'device_type_id');
224
225        // 複数情報
226        $objFormParam->addParam('配送ID', 'shipping_id', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), 0);
227        $objFormParam->addParam('お名前1', 'shipping_name01', STEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
228        $objFormParam->addParam('お名前2', 'shipping_name02', STEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
229        $objFormParam->addParam('お名前(フリガナ・姓)', 'shipping_kana01', STEXT_LEN, 'KVCa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
230        $objFormParam->addParam('お名前(フリガナ・名)', 'shipping_kana02', STEXT_LEN, 'KVCa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
231        $objFormParam->addParam('会社名', 'shipping_company_name', STEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
232        if (FORM_COUNTRY_ENABLE) {
233            $objFormParam->addParam('国', 'shipping_country_id', INT_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK'));
234            $objFormParam->addParam('ZIPCODE', 'shipping_zipcode', STEXT_LEN, 'n', array('NO_SPTAB', 'SPTAB_CHECK', 'GRAPH_CHECK', 'MAX_LENGTH_CHECK'));
235        }
236        $objFormParam->addParam('郵便番号1', 'shipping_zip01', ZIP01_LEN, 'n', array('NUM_CHECK', 'NUM_COUNT_CHECK'));
237        $objFormParam->addParam('郵便番号2', 'shipping_zip02', ZIP02_LEN, 'n', array('NUM_CHECK', 'NUM_COUNT_CHECK'));
238        $objFormParam->addParam('都道府県', 'shipping_pref', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
239        $objFormParam->addParam('住所1', 'shipping_addr01', MTEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
240        $objFormParam->addParam('住所2', 'shipping_addr02', MTEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
241        $objFormParam->addParam('電話番号1', 'shipping_tel01', TEL_ITEM_LEN, 'n', array('MAX_LENGTH_CHECK' ,'NUM_CHECK'));
242        $objFormParam->addParam('電話番号2', 'shipping_tel02', TEL_ITEM_LEN, 'n', array('MAX_LENGTH_CHECK' ,'NUM_CHECK'));
243        $objFormParam->addParam('電話番号3', 'shipping_tel03', TEL_ITEM_LEN, 'n', array('MAX_LENGTH_CHECK' ,'NUM_CHECK'));
244        $objFormParam->addParam('お届け時間ID', 'time_id', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
245        $objFormParam->addParam('お届け日(年)', 'shipping_date_year', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
246        $objFormParam->addParam('お届け日(月)', 'shipping_date_month', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
247        $objFormParam->addParam('お届け日(日)', 'shipping_date_day', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
248        $objFormParam->addParam('お届け日', 'shipping_date', STEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
249        $objFormParam->addParam('配送商品数量', 'shipping_product_quantity', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
250
251        $objFormParam->addParam('商品規格ID', 'shipment_product_class_id', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
252        $objFormParam->addParam('商品コード', 'shipment_product_code');
253        $objFormParam->addParam('商品名', 'shipment_product_name');
254        $objFormParam->addParam('規格名1', 'shipment_classcategory_name1');
255        $objFormParam->addParam('規格名2', 'shipment_classcategory_name2');
256        $objFormParam->addParam('単価', 'shipment_price', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
257        $objFormParam->addParam('数量', 'shipment_quantity', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), '0');
258
259        $objFormParam->addParam('商品項番', 'no', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
260        $objFormParam->addParam('追加商品規格ID', 'add_product_class_id', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
261        $objFormParam->addParam('修正商品規格ID', 'edit_product_class_id', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
262        $objFormParam->addParam('アンカーキー', 'anchor_key', STEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
263    }
264
265    /**
266     * 受注データを取得して, SC_FormParam へ設定する.
267     *
268     * @param  SC_FormParam $objFormParam SC_FormParam インスタンス
269     * @param  integer      $order_id     取得元の受注ID
270     * @return void
271     */
272    public function setOrderToFormParam(&$objFormParam, $order_id)
273    {
274        $objPurchase = new SC_Helper_Purchase_Ex();
275
276        // 受注詳細を設定
277        $arrOrderDetail = $objPurchase->getOrderDetail($order_id, false);
278        $objFormParam->setParam(SC_Utils_Ex::sfSwapArray($arrOrderDetail));
279
280        $arrShippingsTmp = $objPurchase->getShippings($order_id);
281        $arrShippings = array();
282        foreach ($arrShippingsTmp as $row) {
283            // お届け日の処理
284            if (!SC_Utils_Ex::isBlank($row['shipping_date'])) {
285                $ts = strtotime($row['shipping_date']);
286                $row['shipping_date_year'] = date('Y', $ts);
287                $row['shipping_date_month'] = date('n', $ts);
288                $row['shipping_date_day'] = date('j', $ts);
289            }
290            $arrShippings[$row['shipping_id']] = $row;
291        }
292        $objFormParam->setParam(SC_Utils_Ex::sfSwapArray($arrShippings));
293
294        /*
295         * 配送商品を設定
296         *
297         * $arrShipmentItem['shipment_(key)'][$shipping_id][$item_index] = 値
298         * $arrProductQuantity[$shipping_id] = 配送先ごとの配送商品数量
299         */
300        $arrProductQuantity = array();
301        $arrShipmentItem = array();
302        foreach ($arrShippings as $shipping_id => $arrShipping) {
303            $arrProductQuantity[$shipping_id] = count($arrShipping['shipment_item']);
304            foreach ($arrShipping['shipment_item'] as $item_index => $arrItem) {
305                foreach ($arrItem as $item_key => $item_val) {
306                    $arrShipmentItem['shipment_' . $item_key][$shipping_id][$item_index] = $item_val;
307                }
308            }
309        }
310        $objFormParam->setValue('shipping_product_quantity', $arrProductQuantity);
311        $objFormParam->setParam($arrShipmentItem);
312
313        /*
314         * 受注情報を設定
315         * $arrOrderDetail と項目が重複しており, $arrOrderDetail は連想配列の値
316         * が渡ってくるため, $arrOrder で上書きする.
317         */
318        $arrOrder = $objPurchase->getOrder($order_id);
319
320        // 生年月日の処理
321        if (!SC_Utils_Ex::isBlank($arrOrder['order_birth'])) {
322            $order_birth = substr($arrOrder['order_birth'], 0, 10);
323            $arrOrderBirth = explode("-", $order_birth);
324            $arrOrder['order_birth_year'] = intval($arrOrderBirth[0]);
325            $arrOrder['order_birth_month'] = intval($arrOrderBirth[1]);
326            $arrOrder['order_birth_day'] = intval($arrOrderBirth[2]);
327        }
328
329        $objFormParam->setParam($arrOrder);
330
331        // ポイントを設定
332        list($db_point, $rollback_point) = SC_Helper_DB_Ex::sfGetRollbackPoint(
333            $order_id, $arrOrder['use_point'], $arrOrder['add_point'], $arrOrder['status']
334        );
335        $objFormParam->setValue('total_point', $db_point);
336        $objFormParam->setValue('point', $rollback_point);
337
338        if (!SC_Utils_Ex::isBlank($objFormParam->getValue('customer_id'))) {
339            $arrCustomer = SC_Helper_Customer_Ex::sfGetCustomerDataFromId($objFormParam->getValue('customer_id'));
340            $objFormParam->setValue('customer_point', $arrCustomer['point']);
341        }
342    }
343}
Note: See TracBrowser for help on using the repository browser.