source: branches/comu-ver2/data/class/pages/shopping/LC_Page_Shopping.php @ 18332

Revision 18332, 17.7 KB checked in by Seasoft, 14 years ago (diff)
  • お客様情報をお届け先へコピーする際に変換後の値を利用するように改修。
  • 無駄なテーブル更新を削減。
  • 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-2007 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/LC_Page.php");
26
27/**
28 * ショッピングログインのページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id:LC_Page_Shopping.php 15532 2007-08-31 14:39:46Z nanasess $
33 */
34class LC_Page_Shopping extends LC_Page {
35
36    // {{{ properties
37
38    /** フォームパラメータ */
39    var $objFormParam;
40
41    /** 年 */
42    var $year;
43
44    // }}}
45    // {{{ functions
46
47    /**
48     * Page を初期化する.
49     *
50     * @return void
51     */
52    function init() {
53        parent::init();
54        $this->tpl_mainpage = 'shopping/index.tpl';
55        $this->tpl_column_num = 1;
56        $this->tpl_title = 'ログイン';
57        $masterData = new SC_DB_MasterData();
58        $this->arrPref = $masterData->getMasterData("mtb_pref", array("pref_id", "pref_name", "rank"));
59        $this->arrSex = $masterData->getMasterData("mtb_sex");
60        $this->arrJob = $masterData->getMasterData("mtb_job");
61        $this->tpl_onload = 'fnCheckInputDeliv();';
62        $this->httpCacheControl('nocache');
63    }
64
65    /**
66     * Page のプロセス.
67     *
68     * @return void
69     */
70    function process() {
71        global $objCampaignSess;
72
73        $conn = new SC_DBConn();
74        $objView = new SC_SiteView();
75        $objSiteSess = new SC_SiteSession();
76        $objCartSess = new SC_CartSession();
77        $objCampaignSess = new SC_CampaignSession();
78        $objCustomer = new SC_Customer();
79        $objCookie = new SC_Cookie();
80        $this->objFormParam = new SC_FormParam();            // フォーム用
81        $this->lfInitParam();                                // パラメータ情報の初期化
82        $this->objFormParam->setParam($_POST);            // POST値の取得
83
84        // ユーザユニークIDの取得と購入状態の正当性をチェック
85        $uniqid = SC_Utils_Ex::sfCheckNormalAccess($objSiteSess, $objCartSess);
86        $this->tpl_uniqid = $uniqid;
87
88        // ログインチェック
89        if($objCustomer->isLoginSuccess()) {
90            // すでにログインされている場合は、お届け先設定画面に転送
91            $this->sendRedirect($this->getLocation("./deliv.php"), array());
92            exit;
93        }
94
95        if ($_SERVER["REQUEST_METHOD"] == "POST") {
96            if (!$this->isValidToken()) {
97                SC_Utils_Ex::sfDispSiteError(PAGE_ERROR, "", true);
98            }
99        }
100
101        if (!isset($_POST['mode'])) $_POST['mode'] = "";
102
103        switch($_POST['mode']) {
104        case 'nonmember_confirm':
105            $this->lfSetNonMember($this);
106            // ※breakなし
107        case 'confirm':
108            // 入力値の変換
109            $this->objFormParam->convParam();
110            $this->objFormParam->toLower('order_mail');
111            $this->objFormParam->toLower('order_mail_check');
112
113            $this->arrErr = $this->lfCheckError();
114
115            // 入力エラーなし
116            if(count($this->arrErr) == 0) {
117                // DBへのデータ登録
118                $this->lfRegistData($uniqid);
119
120                // 正常に登録されたことを記録しておく
121                $objSiteSess->setRegistFlag();
122                // お支払い方法選択ページへ移動
123                $this->sendRedirect($this->getLocation(URL_SHOP_PAYMENT));
124                exit;
125            }
126
127            break;
128        // 前のページに戻る
129        case 'return':
130            // 確認ページへ移動
131            $this->sendRedirect($this->getLocation(URL_CART_TOP));
132            exit;
133            break;
134        case 'nonmember':
135            $this->lfSetNonMember($this);
136            // ※breakなし
137        default:
138            if(isset($_GET['from']) && $_GET['from'] == 'nonmember') {
139                $this->lfSetNonMember($this);
140            }
141            // ユーザユニークIDの取得
142            $uniqid = $objSiteSess->getUniqId();
143            $objQuery = new SC_Query();
144            $where = "order_temp_id = ?";
145            $arrRet = $objQuery->select("*", "dtb_order_temp", $where, array($uniqid));
146            if (empty($arrRet)) $arrRet = array(
147                                                array('order_email' => "",
148                                                      'order_birth' => ""));
149
150            // DB値の取得
151            $this->objFormParam->setParam($arrRet[0]);
152            $this->objFormParam->setValue('order_email02', $arrRet[0]['order_email']);
153            $this->objFormParam->setDBDate($arrRet[0]['order_birth']);
154            break;
155        }
156
157        // クッキー判定
158        $this->tpl_login_email = $objCookie->getCookie('login_email');
159        if($this->tpl_login_email != "") {
160            $this->tpl_login_memory = "1";
161        }
162
163        // 生年月日選択肢の取得
164        $objDate = new SC_Date(START_BIRTH_YEAR, date("Y",strtotime("now")));
165        $this->arrYear = $objDate->getYear('', 1950, '');
166        $this->arrMonth = $objDate->getMonth(true);
167        $this->arrDay = $objDate->getDay(true);
168
169        // 入力値の取得
170        $this->arrForm = $this->objFormParam->getFormParamList();
171
172        $this->transactionid = $this->getToken();
173        $objView->assignobj($this);
174        // フレームを選択(キャンペーンページから遷移なら変更)
175        $objCampaignSess->pageView($objView);
176    }
177
178    /**
179     * モバイルページを初期化する.
180     *
181     * @return void
182     */
183    function mobileInit() {
184        $this->init();
185        $this->tpl_mainpage = MOBILE_TEMPLATE_DIR . 'shopping/index.tpl';
186    }
187
188    /**
189     * Page のプロセス(モバイル).
190     *
191     * @return void
192     */
193    function mobileProcess() {
194        $conn = new SC_DBConn();
195        $objView = new SC_MobileView();
196        $objSiteSess = new SC_SiteSession();
197        $objCartSess = new SC_CartSession();
198        $objCustomer = new SC_Customer();
199        $objCookie = new SC_Cookie();
200        $this->objFormParam = new SC_FormParam();            // フォーム用
201        $helperMobile = new SC_Helper_Mobile_Ex();
202        $this->lfInitParam();                                // パラメータ情報の初期化
203        $this->objFormParam->setParam($_POST);            // POST値の取得
204
205        // ユーザユニークIDの取得と購入状態の正当性をチェック
206        $uniqid = SC_Utils_Ex::sfCheckNormalAccess($objSiteSess, $objCartSess);
207
208        $this->tpl_uniqid = $uniqid;
209
210        // ログインチェック
211        if($objCustomer->isLoginSuccess(true)) {
212            // すでにログインされている場合は、お届け先設定画面に転送
213            $this->sendRedirect($this->getLocation('./deliv.php'), true);
214            exit;
215        }
216
217        // 携帯端末IDが一致する会員が存在するかどうかをチェックする。
218        $this->tpl_valid_phone_id = $objCustomer->checkMobilePhoneId();
219
220        // クッキー判定
221        $this->tpl_login_email = $objCookie->getCookie('login_email');
222        if($this->tpl_login_email != "") {
223            $this->tpl_login_memory = "1";
224        }
225
226        $objView->assignobj($this);
227        $objView->display(SITE_FRAME);
228    }
229
230    /**
231     * デストラクタ.
232     *
233     * @return void
234     */
235    function destroy() {
236        parent::destroy();
237    }
238
239    /* 非会員入力ページのセット */
240    function lfSetNonMember(&$objPage) {
241        $objPage->tpl_mainpage = 'shopping/nonmember_input.tpl';
242        $this->tpl_title = 'お客様情報入力';
243    }
244
245    /* パラメータ情報の初期化 */
246    function lfInitParam() {
247        $this->objFormParam->addParam("お名前(姓)", "order_name01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
248        $this->objFormParam->addParam("お名前(名)", "order_name02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
249        $this->objFormParam->addParam("フリガナ(セイ)", "order_kana01", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
250        $this->objFormParam->addParam("フリガナ(メイ)", "order_kana02", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
251        $this->objFormParam->addParam("郵便番号1", "order_zip01", ZIP01_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
252        $this->objFormParam->addParam("郵便番号2", "order_zip02", ZIP02_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
253        $this->objFormParam->addParam("都道府県", "order_pref", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
254        $this->objFormParam->addParam("住所1", "order_addr01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
255        $this->objFormParam->addParam("住所2", "order_addr02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
256        $this->objFormParam->addParam("電話番号1", "order_tel01", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
257        $this->objFormParam->addParam("電話番号2", "order_tel02", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
258        $this->objFormParam->addParam("電話番号3", "order_tel03", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
259        $this->objFormParam->addParam("FAX番号1", "order_fax01", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
260        $this->objFormParam->addParam("FAX番号2", "order_fax02", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
261        $this->objFormParam->addParam("FAX番号3", "order_fax03", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
262        $this->objFormParam->addParam("メールアドレス", "order_email", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "NO_SPTAB", "MAX_LENGTH_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK"));
263        $this->objFormParam->addParam("メールアドレス(確認)", "order_email02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "NO_SPTAB", "MAX_LENGTH_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK"), "", false);
264        $this->objFormParam->addParam("年", "year", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
265        $this->objFormParam->addParam("月", "month", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
266        $this->objFormParam->addParam("日", "day", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
267        $this->objFormParam->addParam("性別", "order_sex", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
268        $this->objFormParam->addParam("職業", "order_job", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
269        $this->objFormParam->addParam("別のお届け先", "deliv_check", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
270        $this->objFormParam->addParam("お名前(姓)", "deliv_name01", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
271        $this->objFormParam->addParam("お名前(名)", "deliv_name02", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
272        $this->objFormParam->addParam("フリガナ(セイ)", "deliv_kana01", STEXT_LEN, "KVCa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
273        $this->objFormParam->addParam("フリガナ(メイ)", "deliv_kana02", STEXT_LEN, "KVCa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
274        $this->objFormParam->addParam("郵便番号1", "deliv_zip01", ZIP01_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
275        $this->objFormParam->addParam("郵便番号2", "deliv_zip02", ZIP02_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
276        $this->objFormParam->addParam("都道府県", "deliv_pref", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
277        $this->objFormParam->addParam("住所1", "deliv_addr01", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
278        $this->objFormParam->addParam("住所2", "deliv_addr02", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
279        $this->objFormParam->addParam("電話番号1", "deliv_tel01", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
280        $this->objFormParam->addParam("電話番号2", "deliv_tel02", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
281        $this->objFormParam->addParam("電話番号3", "deliv_tel03", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
282        $this->objFormParam->addParam("メールマガジン", "mail_flag", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), 1);
283    }
284
285    /* DBへデータの登録 */
286    function lfRegistData($uniqid) {
287        $arrRet = $this->objFormParam->getHashArray();
288        $sqlval = $this->objFormParam->getDbArray();
289        // 登録データの作成
290        $sqlval['order_birth'] = SC_Utils_Ex::sfGetTimestamp($arrRet['year'], $arrRet['month'], $arrRet['day']);
291        $sqlval['update_date'] = 'Now()';
292        $sqlval['customer_id'] = '0';
293
294        // お届け先を指定しない場合、
295        if ($sqlval['deliv_check'] != '1') {
296            // 受注一時テーブルに登録する顧客(お客様情報)をお届け先へコピーする
297            $this->lfCopyDeliv($sqlval);
298        }
299
300        // 既存データのチェック
301        $objQuery = new SC_Query();
302        $where = "order_temp_id = ?";
303        $cnt = $objQuery->count("dtb_order_temp", $where, array($uniqid));
304        // 既存データがない場合
305        if ($cnt == 0) {
306            $sqlval['order_temp_id'] = $uniqid;
307            $sqlval['create_date'] = 'Now()';
308            $objQuery->insert("dtb_order_temp", $sqlval);
309        } else {
310            $objQuery->update("dtb_order_temp", $sqlval, $where, array($uniqid));
311        }
312
313    }
314
315    /* 入力内容のチェック */
316    function lfCheckError() {
317        // 入力データを渡す。
318        $arrRet = $this->objFormParam->getHashArray();
319        $objErr = new SC_CheckError($arrRet);
320        $objErr->arrErr = $this->objFormParam->checkError();
321
322        // 別のお届け先チェック
323        if(isset($_POST['deliv_check']) && $_POST['deliv_check'] == "1") {
324            $objErr->doFunc(array("お名前(姓)", "deliv_name01"), array("EXIST_CHECK"));
325            $objErr->doFunc(array("お名前(名)", "deliv_name02"), array("EXIST_CHECK"));
326            $objErr->doFunc(array("フリガナ(セイ)", "deliv_kana01"), array("EXIST_CHECK"));
327            $objErr->doFunc(array("フリガナ(メイ)", "deliv_kana02"), array("EXIST_CHECK"));
328            $objErr->doFunc(array("郵便番号1", "deliv_zip01"), array("EXIST_CHECK"));
329            $objErr->doFunc(array("郵便番号2", "deliv_zip02"), array("EXIST_CHECK"));
330            $objErr->doFunc(array("都道府県", "deliv_pref"), array("EXIST_CHECK"));
331            $objErr->doFunc(array("住所1", "deliv_addr01"), array("EXIST_CHECK"));
332            $objErr->doFunc(array("住所2", "deliv_addr02"), array("EXIST_CHECK"));
333            $objErr->doFunc(array("電話番号1", "deliv_tel01"), array("EXIST_CHECK"));
334            $objErr->doFunc(array("電話番号2", "deliv_tel02"), array("EXIST_CHECK"));
335            $objErr->doFunc(array("電話番号3", "deliv_tel03"), array("EXIST_CHECK"));
336        }
337
338        // 複数項目チェック
339        $objErr->doFunc(array("TEL", "order_tel01", "order_tel02", "order_tel03", TEL_ITEM_LEN), array("TEL_CHECK"));
340        $objErr->doFunc(array("FAX", "order_fax01", "order_fax02", "order_fax03", TEL_ITEM_LEN), array("TEL_CHECK"));
341        $objErr->doFunc(array("郵便番号", "order_zip01", "order_zip02"), array("ALL_EXIST_CHECK"));
342        $objErr->doFunc(array("TEL", "deliv_tel01", "deliv_tel02", "deliv_tel03", TEL_ITEM_LEN), array("TEL_CHECK"));
343        $objErr->doFunc(array("FAX", "deliv_fax01", "deliv_fax02", "deliv_fax03", TEL_ITEM_LEN), array("TEL_CHECK"));
344        $objErr->doFunc(array("郵便番号", "deliv_zip01", "deliv_zip02"), array("ALL_EXIST_CHECK"));
345        $objErr->doFunc(array("生年月日", "year", "month", "day"), array("CHECK_BIRTHDAY"));
346        $objErr->doFunc(array("メールアドレス", "メールアドレス(確認)", "order_email", "order_email02"), array("EQUAL_CHECK"));
347
348        return $objErr->arrErr;
349    }
350
351    /**
352     * 受注一時テーブルに登録する顧客(お客様情報)をお届け先へコピーする
353     *
354     * @param array $sqlval
355     * @return void
356     */
357    function lfCopyDeliv(&$sqlval) {
358        $sqlval['deliv_name01'] = $sqlval['order_name01'];
359        $sqlval['deliv_name02'] = $sqlval['order_name02'];
360        $sqlval['deliv_kana01'] = $sqlval['order_kana01'];
361        $sqlval['deliv_kana02'] = $sqlval['order_kana02'];
362        $sqlval['deliv_pref']   = $sqlval['order_pref'];
363        $sqlval['deliv_zip01']  = $sqlval['order_zip01'];
364        $sqlval['deliv_zip02']  = $sqlval['order_zip02'];
365        $sqlval['deliv_addr01'] = $sqlval['order_addr01'];
366        $sqlval['deliv_addr02'] = $sqlval['order_addr02'];
367        $sqlval['deliv_tel01']  = $sqlval['order_tel01'];
368        $sqlval['deliv_tel02']  = $sqlval['order_tel02'];
369        $sqlval['deliv_tel03']  = $sqlval['order_tel03'];
370    }
371}
372?>
Note: See TracBrowser for help on using the repository browser.