source: branches/feature-module-update/data/class/pages/shopping/LC_Page_Shopping_Deliv.php @ 16034

Revision 16034, 13.8 KB checked in by nanasess, 15 years ago (diff)

$this->tpl_column_num = 1 追加

  • 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_Deliv.php 15532 2007-08-31 14:39:46Z nanasess $
17 */
18class LC_Page_Shopping_Deliv extends LC_Page {
19
20    // {{{ properties
21
22    /** フォームパラメータの配列 */
23    var $objFormParam;
24
25    /** ログインフォームパラメータ配列 */
26    var $objLoginFormParam;
27
28    // }}}
29    // {{{ functions
30
31    /**
32     * Page を初期化する.
33     *
34     * @return void
35     */
36    function init() {
37        parent::init();
38        $this->tpl_mainpage = 'shopping/deliv.tpl';
39        $this->tpl_column_num = 1;
40        $this->tpl_css = URL_DIR.'css/layout/shopping/index.css';
41        $masterData = new SC_DB_MasterData();
42        $this->arrPref = $masterData->getMasterData("mtb_pref", array("pref_id", "pref_name", "rank"));
43        $this->tpl_title = "お届け先指定";
44
45        $this->allowClientCache();
46    }
47
48    /**
49     * Page のプロセス.
50     *
51     * @return void
52     */
53    function process() {
54        $objView = new SC_SiteView();
55        $objSiteSess = new SC_SiteSession();
56        $objCartSess = new SC_CartSession();
57        $objCampaignSess = new SC_CampaignSession();
58        $objCustomer = new SC_Customer();
59        // クッキー管理クラス
60        $objCookie = new SC_Cookie(COOKIE_EXPIRE);
61        // パラメータ管理クラス
62        $this->objFormParam = new SC_FormParam();
63        // パラメータ情報の初期化
64        $this->lfInitParam();
65        // POST値の取得
66        $this->objFormParam->setParam($_POST);
67
68        $this->objLoginFormParam = new SC_FormParam();  // ログインフォーム用
69        $this->lfInitLoginFormParam();                      // 初期設定
70        $this->objLoginFormParam->setParam($_POST);     // POST値の取得
71
72        // ユーザユニークIDの取得と購入状態の正当性をチェック
73        $uniqid = SC_Utils_Ex::sfCheckNormalAccess($objSiteSess, $objCartSess);
74        $this->tpl_uniqid = $uniqid;
75
76        if (!isset($_POST['mode'])) $_POST['mode'] = "";
77
78        // ログインチェック
79        if($_POST['mode'] != 'login' && !$objCustomer->isLoginSuccess()) {
80            // 不正アクセスとみなす
81            SC_Utils_Ex::sfDispSiteError(CUSTOMER_ERROR);
82        }
83
84        switch($_POST['mode']) {
85        case 'login':
86            $this->objLoginFormParam->toLower('login_email');
87            $this->arrErr = $this->objLoginFormParam->checkError();
88            $arrForm =  $this->objLoginFormParam->getHashArray();
89            // クッキー保存判定
90            if($arrForm['login_memory'] == "1" && $arrForm['login_email'] != "") {
91                $objCookie->setCookie('login_email', $_POST['login_email']);
92            } else {
93                $objCookie->setCookie('login_email', '');
94            }
95
96            if(count($this->arrErr) == 0) {
97                // ログイン判定
98                if(!$objCustomer->getCustomerDataFromEmailPass($arrForm['login_pass'], $arrForm['login_email'])) {
99                    // 仮登録の判定
100                    $objQuery = new SC_Query;
101                    $where = "email = ? AND status = 1 AND del_flg = 0";
102                    $ret = $objQuery->count("dtb_customer", $where, array($arrForm['login_email']));
103
104                    if($ret > 0) {
105                        SC_Utils_Ex::sfDispSiteError(TEMP_LOGIN_ERROR);
106                    } else {
107                        SC_Utils_Ex::sfDispSiteError(SITE_LOGIN_ERROR);
108                    }
109                }
110            } else {
111                // ログインページに戻る
112                $this->sendRedirect(URL_SHOP_TOP);
113                exit;
114            }
115            break;
116        // 削除
117        case 'delete':
118            if (sfIsInt($_POST['other_deliv_id'])) {
119                $objQuery = new SC_Query();
120                $where = "other_deliv_id = ?";
121                $arrRet = $objQuery->delete("dtb_other_deliv", $where, array($_POST['other_deliv_id']));
122                $this->objFormParam->setValue('select_addr_id', '');
123            }
124            break;
125        // 会員登録住所に送る
126        case 'customer_addr':
127            // 会員登録住所がチェックされている場合
128            if ($_POST['deliv_check'] == '-1') {
129                // 会員情報の住所を受注一時テーブルに書き込む
130                $this->lfRegistDelivData($uniqid, $objCustomer);
131                // 正常に登録されたことを記録しておく
132                $objSiteSess->setRegistFlag();
133                // お支払い方法選択ページへ移動
134                $this->sendRedirect($this->getLocation(URL_SHOP_PAYMENT, array(), true));
135                exit;
136            // 別のお届け先がチェックされている場合
137            } elseif($_POST['deliv_check'] >= 1) {
138                if (sfIsInt($_POST['deliv_check'])) {
139                    // 登録済みの別のお届け先を受注一時テーブルに書き込む
140                    lfRegistOtherDelivData($uniqid, $objCustomer, $_POST['deliv_check']);
141                    // 正常に登録されたことを記録しておく
142                    $objSiteSess->setRegistFlag();
143                    // お支払い方法選択ページへ移動
144                    $this->sendRedirect($this->getLocation(URL_SHOP_PAYMENT, array(), true));
145                    exit;
146                }
147            }else{
148                // エラーを返す
149                $arrErr['deli'] = '※ お届け先を選択してください。';
150            }
151            break;
152        // 前のページに戻る
153        case 'return':
154            // 確認ページへ移動
155            $this->sendRedirect($this->getLocation(URL_CART_TOP, array(), true));
156            exit;
157            break;
158        default:
159            $objQuery = new SC_Query();
160            $where = "order_temp_id = ?";
161            $arrRet = $objQuery->select("*", "dtb_order_temp", $where, array($uniqid));
162            if (empty($arrRet)) $arrRet = array("");
163            $this->objFormParam->setParam($arrRet[0]);
164            break;
165        }
166
167        /** 表示処理 **/
168
169        // 会員登録住所の取得
170        $col = "name01, name02, pref, addr01, addr02";
171        $where = "customer_id = ?";
172        $objQuery = new SC_Query();
173        $arrCustomerAddr = $objQuery->select($col, "dtb_customer", $where, array($_SESSION['customer']['customer_id']));
174        // 別のお届け先住所の取得
175        $col = "other_deliv_id, name01, name02, pref, addr01, addr02";
176        $objQuery->setorder("other_deliv_id DESC");
177        $objOtherAddr = $objQuery->select($col, "dtb_other_deliv", $where, array($_SESSION['customer']['customer_id']));
178        $this->arrAddr = $arrCustomerAddr;
179        $this->tpl_addrmax = count($objOtherAddr);
180        $cnt = 1;
181        foreach($objOtherAddr as $val) {
182            $this->arrAddr[$cnt] = $val;
183            $cnt++;
184        }
185
186        // 入力値の取得
187        if (!isset($arrErr)) $arrErr = array();
188        $this->arrForm = $this->objFormParam->getFormParamList();
189        $this->arrErr = $arrErr;
190
191        $objView->assignobj($this);
192        // フレームを選択(キャンペーンページから遷移なら変更)
193        $objCampaignSess->pageView($objView);
194    }
195
196    /**
197     * デストラクタ.
198     *
199     * @return void
200     */
201    function destroy() {
202        parent::destroy();
203    }
204
205    /* パラメータ情報の初期化 */
206    function lfInitParam() {
207        $this->objFormParam->addParam("お名前1", "deliv_name01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
208        $this->objFormParam->addParam("お名前2", "deliv_name02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
209        $this->objFormParam->addParam("フリガナ1", "deliv_kana01", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
210        $this->objFormParam->addParam("フリガナ2", "deliv_kana02", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
211        $this->objFormParam->addParam("郵便番号1", "deliv_zip01", ZIP01_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
212        $this->objFormParam->addParam("郵便番号2", "deliv_zip02", ZIP02_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
213        $this->objFormParam->addParam("都道府県", "deliv_pref", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
214        $this->objFormParam->addParam("住所1", "deliv_addr01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
215        $this->objFormParam->addParam("住所2", "deliv_addr02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
216        $this->objFormParam->addParam("電話番号1", "deliv_tel01", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
217        $this->objFormParam->addParam("電話番号2", "deliv_tel02", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
218        $this->objFormParam->addParam("電話番号3", "deliv_tel03", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
219        $this->objFormParam->addParam("", "deliv_check");
220    }
221
222    function lfInitLoginFormParam() {
223        $this->objLoginFormParam->addParam("記憶する", "login_memory", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
224        $this->objLoginFormParam->addParam("メールアドレス", "login_email", STEXT_LEN, "KVa", array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
225        $this->objLoginFormParam->addParam("パスワード", "login_pass", STEXT_LEN, "KVa", array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
226    }
227
228    /* DBへデータの登録 */
229    function lfRegistNewAddrData($uniqid, $objCustomer) {
230        $arrRet = $this->objFormParam->getHashArray();
231        $sqlval = $this->objFormParam->getDbArray();
232        // 登録データの作成
233        $sqlval['deliv_check'] = '1';
234        $sqlval['order_temp_id'] = $uniqid;
235        $sqlval['update_date'] = 'Now()';
236        $sqlval['customer_id'] = $objCustomer->getValue('customer_id');
237        $sqlval['order_birth'] = $objCustomer->getValue('birth');
238
239        $objDb = new SC_Helper_DB_Ex();
240        $objDb->sfRegistTempOrder($uniqid, $sqlval);
241    }
242
243    /* 会員情報の住所を一時受注テーブルへ */
244    function lfRegistDelivData($uniqid, $objCustomer) {
245        // 登録データの作成
246        $sqlval['order_temp_id'] = $uniqid;
247        $sqlval['update_date'] = 'Now()';
248        $sqlval['customer_id'] = $objCustomer->getValue('customer_id');
249        $sqlval['deliv_check'] = '-1';
250        $sqlval['deliv_name01'] = $objCustomer->getValue('name01');
251        $sqlval['deliv_name02'] = $objCustomer->getValue('name02');
252        $sqlval['deliv_kana01'] = $objCustomer->getValue('kana01');
253        $sqlval['deliv_kana02'] = $objCustomer->getValue('kana02');
254        $sqlval['deliv_zip01'] = $objCustomer->getValue('zip01');
255        $sqlval['deliv_zip02'] = $objCustomer->getValue('zip02');
256        $sqlval['deliv_pref'] = $objCustomer->getValue('pref');
257        $sqlval['deliv_addr01'] = $objCustomer->getValue('addr01');
258        $sqlval['deliv_addr02'] = $objCustomer->getValue('addr02');
259        $sqlval['deliv_tel01'] = $objCustomer->getValue('tel01');
260        $sqlval['deliv_tel02'] = $objCustomer->getValue('tel02');
261        $sqlval['deliv_tel03'] = $objCustomer->getValue('tel03');
262
263        $sqlval['deliv_fax01'] = $objCustomer->getValue('fax01');
264        $sqlval['deliv_fax02'] = $objCustomer->getValue('fax02');
265        $sqlval['deliv_fax03'] = $objCustomer->getValue('fax03');
266
267        $objDb = new SC_Helper_DB_Ex();
268        $objDb->sfRegistTempOrder($uniqid, $sqlval);
269    }
270
271    /* 別のお届け先住所を一時受注テーブルへ */
272    function lfRegistOtherDelivData($uniqid, $objCustomer, $other_deliv_id) {
273        // 登録データの作成
274        $sqlval['order_temp_id'] = $uniqid;
275        $sqlval['update_date'] = 'Now()';
276        $sqlval['customer_id'] = $objCustomer->getValue('customer_id');
277        $sqlval['order_birth'] = $objCustomer->getValue('birth');
278
279        $objQuery = new SC_Query();
280        $where = "other_deliv_id = ?";
281        $arrRet = $objQuery->select("*", "dtb_other_deliv", $where, array($other_deliv_id));
282
283        $sqlval['deliv_check'] = $other_deliv_id;
284        $sqlval['deliv_name01'] = $arrRet[0]['name01'];
285        $sqlval['deliv_name02'] = $arrRet[0]['name02'];
286        $sqlval['deliv_kana01'] = $arrRet[0]['kana01'];
287        $sqlval['deliv_kana02'] = $arrRet[0]['kana02'];
288        $sqlval['deliv_zip01'] = $arrRet[0]['zip01'];
289        $sqlval['deliv_zip02'] = $arrRet[0]['zip02'];
290        $sqlval['deliv_pref'] = $arrRet[0]['pref'];
291        $sqlval['deliv_addr01'] = $arrRet[0]['addr01'];
292        $sqlval['deliv_addr02'] = $arrRet[0]['addr02'];
293        $sqlval['deliv_tel01'] = $arrRet[0]['tel01'];
294        $sqlval['deliv_tel02'] = $arrRet[0]['tel02'];
295        $sqlval['deliv_tel03'] = $arrRet[0]['tel03'];
296        $objDb = new SC_Helper_DB_Ex();
297        $objDb->sfRegistTempOrder($uniqid, $sqlval);
298    }
299
300    /* 入力内容のチェック */
301    function lfCheckError() {
302        // 入力データを渡す。
303        $arrRet =  $this->objFormParam->getHashArray();
304        $objErr = new SC_CheckError($arrRet);
305        $objErr->arrErr = $this->objFormParam->checkError();
306        // 複数項目チェック
307        if ($_POST['mode'] == 'login'){
308            $objErr->doFunc(array("メールアドレス", "login_email", STEXT_LEN), array("EXIST_CHECK"));
309            $objErr->doFunc(array("パスワード", "login_pass", STEXT_LEN), array("EXIST_CHECK"));
310        }
311        $objErr->doFunc(array("TEL", "deliv_tel01", "deliv_tel02", "deliv_tel03", TEL_ITEM_LEN), array("TEL_CHECK"));
312        return $objErr->arrErr;
313    }
314}
315?>
Note: See TracBrowser for help on using the repository browser.