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

Revision 15532, 15.3 KB checked in by nanasess, 17 years ago (diff)

svn:mime-type 修正

  • 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$
17 */
18class LC_Page_Shopping extends LC_Page {
19
20    // {{{ properties
21
22    /** フォームパラメータ */
23    var $objFormParam;
24
25    // TODO
26    var $arrSession;
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        $masterData = new SC_DB_MasterData();
40        $this->arrPref = $masterData->getMasterData("mtb_pref", array("pref_id", "pref_name", "rank"));
41        $this->arrSex = $masterData->getMasterData("mtb_sex");
42        $this->arrJob = $masterData->getMasterData("mtb_job");
43        $this->tpl_onload = 'fnCheckInputDeliv();';
44
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        $this->tpl_uniqid = SC_Utils_Ex::sfCheckNormalAccess($objSiteSess, $objCartSess);
67
68        // ログインチェック
69        if($objCustomer->isLoginSuccess()) {
70            // すでにログインされている場合は、お届け先設定画面に転送
71            $this->sendRedirect($this->getLocation("./deliv.php"), array());
72            exit;
73        }
74
75        if ($_SERVER["REQUEST_METHOD"] == "POST") {
76            if (!$this->isValidToken()) {
77                SC_Utils_Ex::sfDispSiteError(PAGE_ERROR, "", true);
78            }
79        }
80
81        switch($_POST['mode']) {
82        case 'nonmember_confirm':
83            $this = $this->lfSetNonMember($this);
84            // ※breakなし
85        case 'confirm':
86            // 入力値の変換
87            $this->objFormParam->convParam();
88            $this->objFormParam->toLower('order_mail');
89            $this->objFormParam->toLower('order_mail_check');
90
91            $this->arrErr = $this->lfCheckError();
92
93            // 入力エラーなし
94            if(count($this->arrErr) == 0) {
95                // DBへのデータ登録
96                $this->lfRegistData($uniqid);
97
98                // お届け先のコピー
99                $this->lfCopyDeliv($uniqid, $_POST);
100
101                // 正常に登録されたことを記録しておく
102                $objSiteSess->setRegistFlag();
103                // お支払い方法選択ページへ移動
104                $this->sendRedirect($this->getLocation(URL_SHOP_PAYMENT, array()));
105                exit;
106            }
107
108            break;
109        // 前のページに戻る
110        case 'return':
111            // 確認ページへ移動
112            $this->sendRedirect($this->getLocation(URL_CART_TOP, array()));
113            exit;
114            break;
115        case 'nonmember':
116            $this = $this->lfSetNonMember($this);
117            // ※breakなし
118        default:
119            if($_GET['from'] == 'nonmember') {
120                $this = $this->lfSetNonMember($this);
121            }
122            // ユーザユニークIDの取得
123            $uniqid = $objSiteSess->getUniqId();
124            $objQuery = new SC_Query();
125            $where = "order_temp_id = ?";
126            $arrRet = $objQuery->select("*", "dtb_order_temp", $where, array($uniqid));
127            // DB値の取得
128            $this->objFormParam->setParam($arrRet[0]);
129            $this->objFormParam->setValue('order_email_check', $arrRet[0]['order_email']);
130            $this->objFormParam->setDBDate($arrRet[0]['order_birth']);
131            break;
132        }
133
134        // クッキー判定
135        $this->tpl_login_email = $objCookie->getCookie('login_email');
136        if($this->tpl_login_email != "") {
137            $this->tpl_login_memory = "1";
138        }
139
140        // 選択用日付の取得
141        $objDate = new SC_Date(START_BIRTH_YEAR);
142        $this->arrYear = $objDate->getYear('', 1950);   // 日付プルダウン設定
143        $this->arrMonth = $objDate->getMonth();
144        $this->arrDay = $objDate->getDay();
145
146        if($this->year == '') {
147            $this->year = '----';
148        }
149
150        // 入力値の取得
151        $this->arrForm = $this->objFormParam->getFormParamList();
152
153        if($this->arrForm['year']['value'] == ""){
154            $this->arrForm['year']['value'] = '----';
155        }
156
157        $this->transactionid = $this->getToken();
158        $objView->assignobj($this);
159        // フレームを選択(キャンペーンページから遷移なら変更)
160        $objCampaignSess->pageView($objView);
161    }
162
163    /**
164     * デストラクタ.
165     *
166     * @return void
167     */
168    function destroy() {
169        parent::destroy();
170    }
171
172    /* 非会員入力ページのセット */
173    function lfSetNonMember($objPage) {
174        $objPage->tpl_mainpage = 'shopping/nonmember_input.tpl';
175        $objPage->tpl_css = array();
176        $objPage->tpl_css[] = URL_DIR.'css/layout/login/nonmember.css';
177        return $objPage;
178    }
179
180    /* パラメータ情報の初期化 */
181    function lfInitParam() {
182        $this->objFormParam->addParam("お名前(姓)", "order_name01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
183        $this->objFormParam->addParam("お名前(名)", "order_name02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
184        $this->objFormParam->addParam("フリガナ(セイ)", "order_kana01", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
185        $this->objFormParam->addParam("フリガナ(メイ)", "order_kana02", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
186        $this->objFormParam->addParam("郵便番号1", "order_zip01", ZIP01_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
187        $this->objFormParam->addParam("郵便番号2", "order_zip02", ZIP02_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
188        $this->objFormParam->addParam("都道府県", "order_pref", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
189        $this->objFormParam->addParam("住所1", "order_addr01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
190        $this->objFormParam->addParam("住所2", "order_addr02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
191        $this->objFormParam->addParam("電話番号1", "order_tel01", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
192        $this->objFormParam->addParam("電話番号2", "order_tel02", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
193        $this->objFormParam->addParam("電話番号3", "order_tel03", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
194        $this->objFormParam->addParam("FAX番号1", "order_fax01", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
195        $this->objFormParam->addParam("FAX番号2", "order_fax02", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
196        $this->objFormParam->addParam("FAX番号3", "order_fax03", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
197        $this->objFormParam->addParam("メールアドレス", "order_email", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "NO_SPTAB", "MAX_LENGTH_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK"));
198        $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);
199        $this->objFormParam->addParam("年", "year", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
200        $this->objFormParam->addParam("月", "month", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
201        $this->objFormParam->addParam("日", "day", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
202        $this->objFormParam->addParam("性別", "order_sex", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
203        $this->objFormParam->addParam("職業", "order_job", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
204        $this->objFormParam->addParam("別のお届け先", "deliv_check", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
205        $this->objFormParam->addParam("お名前(姓)", "deliv_name01", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
206        $this->objFormParam->addParam("お名前(名)", "deliv_name02", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
207        $this->objFormParam->addParam("フリガナ(セイ)", "deliv_kana01", STEXT_LEN, "KVCa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
208        $this->objFormParam->addParam("フリガナ(メイ)", "deliv_kana02", STEXT_LEN, "KVCa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
209        $this->objFormParam->addParam("郵便番号1", "deliv_zip01", ZIP01_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
210        $this->objFormParam->addParam("郵便番号2", "deliv_zip02", ZIP02_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
211        $this->objFormParam->addParam("都道府県", "deliv_pref", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
212        $this->objFormParam->addParam("住所1", "deliv_addr01", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
213        $this->objFormParam->addParam("住所2", "deliv_addr02", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
214        $this->objFormParam->addParam("電話番号1", "deliv_tel01", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
215        $this->objFormParam->addParam("電話番号2", "deliv_tel02", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
216        $this->objFormParam->addParam("電話番号3", "deliv_tel03", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
217        $this->objFormParam->addParam("メールマガジン", "mail_flag", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), 1);
218    }
219
220    /* DBへデータの登録 */
221    function lfRegistData($uniqid) {
222        $arrRet = $this->objFormParam->getHashArray();
223        $sqlval = $this->objFormParam->getDbArray();
224        // 登録データの作成
225        $sqlval['order_temp_id'] = $uniqid;
226        $sqlval['order_birth'] = SC_Utils_Ex::sfGetTimestamp($arrRet['year'], $arrRet['month'], $arrRet['day']);
227        $sqlval['update_date'] = 'Now()';
228        $sqlval['customer_id'] = '0';
229
230        // 既存データのチェック
231        $objQuery = new SC_Query();
232        $where = "order_temp_id = ?";
233        $cnt = $objQuery->count("dtb_order_temp", $where, array($uniqid));
234        // 既存データがない場合
235        if ($cnt == 0) {
236            $sqlval['create_date'] = 'Now()';
237            $objQuery->insert("dtb_order_temp", $sqlval);
238        } else {
239            $objQuery->update("dtb_order_temp", $sqlval, $where, array($uniqid));
240        }
241
242    }
243
244    /* 入力内容のチェック */
245    function lfCheckError() {
246        // 入力データを渡す。
247        $arrRet = $this->objFormParam->getHashArray();
248        $objErr = new SC_CheckError($arrRet);
249        $objErr->arrErr = $this->objFormParam->checkError();
250
251        // 別のお届け先チェック
252        if($_POST['deliv_check'] == "1") {
253            $objErr->doFunc(array("お名前(姓)", "deliv_name01"), array("EXIST_CHECK"));
254            $objErr->doFunc(array("お名前(名)", "deliv_name02"), array("EXIST_CHECK"));
255            $objErr->doFunc(array("フリガナ(セイ)", "deliv_kana01"), array("EXIST_CHECK"));
256            $objErr->doFunc(array("フリガナ(メイ)", "deliv_kana02"), array("EXIST_CHECK"));
257            $objErr->doFunc(array("郵便番号1", "deliv_zip01"), array("EXIST_CHECK"));
258            $objErr->doFunc(array("郵便番号2", "deliv_zip02"), array("EXIST_CHECK"));
259            $objErr->doFunc(array("都道府県", "deliv_pref"), array("EXIST_CHECK"));
260            $objErr->doFunc(array("住所1", "deliv_addr01"), array("EXIST_CHECK"));
261            $objErr->doFunc(array("住所2", "deliv_addr02"), array("EXIST_CHECK"));
262            $objErr->doFunc(array("電話番号1", "deliv_tel01"), array("EXIST_CHECK"));
263            $objErr->doFunc(array("電話番号2", "deliv_tel02"), array("EXIST_CHECK"));
264            $objErr->doFunc(array("電話番号3", "deliv_tel03"), array("EXIST_CHECK"));
265        }
266
267        // 複数項目チェック
268        $objErr->doFunc(array("TEL", "order_tel01", "order_tel02", "order_tel03", TEL_ITEM_LEN), array("TEL_CHECK"));
269        $objErr->doFunc(array("FAX", "order_fax01", "order_fax02", "order_fax03", TEL_ITEM_LEN), array("TEL_CHECK"));
270        $objErr->doFunc(array("郵便番号", "order_zip01", "order_zip02"), array("ALL_EXIST_CHECK"));
271        $objErr->doFunc(array("TEL", "deliv_tel01", "deliv_tel02", "deliv_tel03", TEL_ITEM_LEN), array("TEL_CHECK"));
272        $objErr->doFunc(array("FAX", "deliv_fax01", "deliv_fax02", "deliv_fax03", TEL_ITEM_LEN), array("TEL_CHECK"));
273        $objErr->doFunc(array("郵便番号", "deliv_zip01", "deliv_zip02"), array("ALL_EXIST_CHECK"));
274        $objErr->doFunc(array("生年月日", "year", "month", "day"), array("CHECK_DATE"));
275        $objErr->doFunc(array("メールアドレス", "メールアドレス(確認)", "order_email", "order_email_check"), array("EQUAL_CHECK"));
276
277        // すでにメルマガテーブルに会員としてメールアドレスが登録されている場合
278        if(SC_Utils_Ex::sfCheckCustomerMailMaga($arrRet['order_email'])) {
279            $objErr->arrErr['order_email'] = "このメールアドレスはすでに登録されています。<br />";
280        }
281
282        return $objErr->arrErr;
283    }
284
285    // 受注一時テーブルのお届け先をコピーする
286    function lfCopyDeliv($uniqid, $arrData) {
287        $objQuery = new SC_Query();
288
289        // 別のお届け先を指定していない場合、配送先に登録住所をコピーする。
290        if($arrData["deliv_check"] != "1") {
291            $sqlval['deliv_name01'] = $arrData['order_name01'];
292            $sqlval['deliv_name02'] = $arrData['order_name02'];
293            $sqlval['deliv_kana01'] = $arrData['order_kana01'];
294            $sqlval['deliv_kana02'] = $arrData['order_kana02'];
295            $sqlval['deliv_pref'] = $arrData['order_pref'];
296            $sqlval['deliv_zip01'] = $arrData['order_zip01'];
297            $sqlval['deliv_zip02'] = $arrData['order_zip02'];
298            $sqlval['deliv_addr01'] = $arrData['order_addr01'];
299            $sqlval['deliv_addr02'] = $arrData['order_addr02'];
300            $sqlval['deliv_tel01'] = $arrData['order_tel01'];
301            $sqlval['deliv_tel02'] = $arrData['order_tel02'];
302            $sqlval['deliv_tel03'] = $arrData['order_tel03'];
303            $where = "order_temp_id = ?";
304            $objQuery->update("dtb_order_temp", $sqlval, $where, array($uniqid));
305        }
306    }
307}
308?>
Note: See TracBrowser for help on using the repository browser.