source: branches/feature-module-update/data/class/pages/shopping/LC_Page_Shopping.php @ 16386

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