source: branches/dev/html/mobile/shopping/deliv.php @ 11460

Revision 11460, 11.2 KB checked in by inoue, 17 years ago (diff)

モバイル版EC-CUBE

  • Property svn:eol-style set to native
Line 
1<?php
2/*
3 * Copyright(c) 2000-2006 LOCKON CO.,LTD. All Rights Reserved.
4 *
5 * http://www.lockon.co.jp/
6 */
7
8require_once("../require.php");
9
10class LC_Page {
11    var $arrSession;
12    var $tpl_mode;
13    var $arrAddr;
14    function LC_Page() {
15        $this->tpl_mainpage = 'shopping/deliv.tpl';
16        $this->tpl_css = '/css/layout/shopping/index.css';
17        global $arrPref;
18        $this->arrPref = $arrPref;
19        $this->tpl_title = "¤ªÆϤ±Àè»ØÄê";      // ¥¿¥¤¥È¥ë
20
21        /*
22         session_start»þ¤Îno-cache¥Ø¥Ã¥À¡¼¤òÍÞÀ©¤¹¤ë¤³¤È¤Ç
23         ¡ÖÌá¤ë¡×¥Ü¥¿¥ó»ÈÍÑ»þ¤ÎÍ­¸ú´ü¸ÂÀÚ¤ìɽ¼¨¤òÍÞÀ©¤¹¤ë¡£
24         private-no-expire:¥¯¥é¥¤¥¢¥ó¥È¤Î¥­¥ã¥Ã¥·¥å¤òµö²Ä¤¹¤ë¡£
25        */
26        session_cache_limiter('private-no-expire');     
27
28    }
29}
30
31$objPage = new LC_Page();
32$objView = new SC_SiteView();
33$objSiteSess = new SC_SiteSession();
34$objCartSess = new SC_CartSession();
35$objCustomer = new SC_Customer();
36// ¥¯¥Ã¥­¡¼´ÉÍý¥¯¥é¥¹
37$objCookie = new SC_Cookie(COOKIE_EXPIRE);
38// ¥Ñ¥é¥á¡¼¥¿´ÉÍý¥¯¥é¥¹
39$objFormParam = new SC_FormParam();
40// ¥Ñ¥é¥á¡¼¥¿¾ðÊó¤Î½é´ü²½
41lfInitParam();
42// POSTÃͤμèÆÀ
43$objFormParam->setParam($_POST);
44
45$objLoginFormParam = new SC_FormParam();    // ¥í¥°¥¤¥ó¥Õ¥©¡¼¥àÍÑ
46lfInitLoginFormParam();                     // ½é´üÀßÄê
47$objLoginFormParam->setParam($_POST);       // POSTÃͤμèÆÀ
48
49// ¥æ¡¼¥¶¥æ¥Ë¡¼¥¯ID¤Î¼èÆÀ¤È¹ØÆþ¾õÂÖ¤ÎÀµÅöÀ­¤ò¥Á¥§¥Ã¥¯
50$uniqid = sfCheckNormalAccess($objSiteSess, $objCartSess);
51$objPage->tpl_uniqid = $uniqid;
52
53// ¥í¥°¥¤¥ó¥Á¥§¥Ã¥¯
54if($_POST['mode'] != 'login' && !$objCustomer->isLoginSuccess()) {
55    // ÉÔÀµ¥¢¥¯¥»¥¹¤È¤ß¤Ê¤¹
56    sfDispSiteError(CUSTOMER_ERROR);
57}
58
59switch($_POST['mode']) {
60case 'login':
61    $objLoginFormParam->toLower('login_email');
62    $objPage->arrErr = $objLoginFormParam->checkError();
63    $arrForm =  $objLoginFormParam->getHashArray();
64    // ¥¯¥Ã¥­¡¼ÊݸȽÄê
65    if($arrForm['login_memory'] == "1" && $arrForm['login_email'] != "") {
66        $objCookie->setCookie('login_email', $_POST['login_email']);
67    } else {
68        $objCookie->setCookie('login_email', '');
69    }
70
71    if(count($objPage->arrErr) == 0) {
72        // ¥í¥°¥¤¥óȽÄê
73        if(!$objCustomer->getCustomerDataFromMobilePhoneIdPass($arrForm['login_pass']) &&
74           !$objCustomer->getCustomerDataFromEmailPass($arrForm['login_pass'], $arrForm['login_email'], true)) {
75            // ²¾ÅÐÏ¿¤ÎȽÄê
76            $objQuery = new SC_Query;
77            $where = "email = ? AND status = 1 AND del_flg = 0";
78            $ret = $objQuery->count("dtb_customer", $where, array($arrForm['login_email']));
79           
80            if($ret > 0) {
81                sfDispSiteError(TEMP_LOGIN_ERROR);
82            } else {
83                sfDispSiteError(SITE_LOGIN_ERROR);
84            }
85        }
86    } else {
87        // ¥í¥°¥¤¥ó¥Ú¡¼¥¸¤ËÌá¤ë
88        header("Location: " . gfAddSessionId(URL_SHOP_TOP));
89        exit;
90    }
91
92    // ¥í¥°¥¤¥ó¤¬À®¸ù¤·¤¿¾ì¹ç¤Ï·ÈÂÓüËöID¤òÊݸ¤¹¤ë¡£
93    $objCustomer->updateMobilePhoneId();
94
95    // ·ÈÂӤΥ᡼¥ë¥¢¥É¥ì¥¹¤ò¥³¥Ô¡¼¤¹¤ë¡£
96    $objCustomer->updateEmailMobile();
97
98    // ·ÈÂӤΥ᡼¥ë¥¢¥É¥ì¥¹¤¬ÅÐÏ¿¤µ¤ì¤Æ¤¤¤Ê¤¤¾ì¹ç
99    if (!$objCustomer->hasValue('email_mobile')) {
100        header('Location: ' . gfAddSessionId('../entry/email_mobile.php'));
101        exit;
102    }
103    break;
104// ºï½ü
105case 'delete':
106    if (sfIsInt($_POST['other_deliv_id'])) {
107        $objQuery = new SC_Query();
108        $where = "other_deliv_id = ?";
109        $arrRet = $objQuery->delete("dtb_other_deliv", $where, array($_POST['other_deliv_id']));
110        $objFormParam->setValue('select_addr_id', '');
111    }
112    break;
113// ²ñ°÷ÅÐÏ¿½»½ê¤ËÁ÷¤ë
114case 'customer_addr':
115    // ¤ªÆϤ±À褬¥Á¥§¥Ã¥¯¤µ¤ì¤Æ¤¤¤ë¾ì¹ç¤Ë¤Ï¹¹¿·½èÍý¤ò¹Ô¤¦
116    if ($_POST['deli'] != "") {
117        // ²ñ°÷¾ðÊó¤Î½»½ê¤ò¼õÃí°ì»þ¥Æ¡¼¥Ö¥ë¤Ë½ñ¤­¹þ¤à
118        lfRegistDelivData($uniqid, $objCustomer);
119        // Àµ¾ï¤ËÅÐÏ¿¤µ¤ì¤¿¤³¤È¤òµ­Ï¿¤·¤Æ¤ª¤¯
120        $objSiteSess->setRegistFlag();
121        // ¤ª»Ùʧ¤¤ÊýË¡ÁªÂò¥Ú¡¼¥¸¤Ø°ÜÆ°
122        header("Location: " . gfAddSessionId(URL_SHOP_PAYMENT));
123        exit;
124    }else{
125        // ¥¨¥é¡¼¤òÊÖ¤¹
126        $arrErr['deli'] = '¢¨ ¤ªÆϤ±Àè¤òÁªÂò¤·¤Æ¤¯¤À¤µ¤¤¡£';
127    }
128    break;
129   
130// ÅÐÏ¿ºÑ¤ß¤ÎÊ̤ΤªÆϤ±Àè¤ËÁ÷¤ë
131case 'other_addr':
132    // ¤ªÆϤ±À褬¥Á¥§¥Ã¥¯¤µ¤ì¤Æ¤¤¤ë¾ì¹ç¤Ë¤Ï¹¹¿·½èÍý¤ò¹Ô¤¦
133    if ($_POST['deli'] != "") {
134        if (sfIsInt($_POST['other_deliv_id'])) {
135            // ÅÐÏ¿ºÑ¤ß¤ÎÊ̤ΤªÆϤ±Àè¤ò¼õÃí°ì»þ¥Æ¡¼¥Ö¥ë¤Ë½ñ¤­¹þ¤à
136            lfRegistOtherDelivData($uniqid, $objCustomer, $_POST['other_deliv_id']);
137            // Àµ¾ï¤ËÅÐÏ¿¤µ¤ì¤¿¤³¤È¤òµ­Ï¿¤·¤Æ¤ª¤¯
138            $objSiteSess->setRegistFlag();
139            // ¤ª»Ùʧ¤¤ÊýË¡ÁªÂò¥Ú¡¼¥¸¤Ø°ÜÆ°
140            header("Location: " . gfAddSessionId(URL_SHOP_PAYMENT));
141            exit;
142        }
143    }else{
144        // ¥¨¥é¡¼¤òÊÖ¤¹
145        $arrErr['deli'] = '¢¨ ¤ªÆϤ±Àè¤òÁªÂò¤·¤Æ¤¯¤À¤µ¤¤¡£';
146    }
147    break;
148
149/*
150// Ê̤ΤªÆϤ±Àè¤ò»ØÄê
151case 'new_addr':
152    // ÆþÎÏÃͤÎÊÑ´¹
153    $objFormParam->convParam();
154    $objPage->arrErr = lfCheckError($arrRet);
155    // ÆþÎÏ¥¨¥é¡¼¤Ê¤·
156    if(count($objPage->arrErr) == 0) {
157        // DB¤Ø¤ªÆϤ±Àè¤òÅÐÏ¿
158        lfRegistNewAddrData($uniqid, $objCustomer);
159        // Àµ¾ï¤ËÅÐÏ¿¤µ¤ì¤¿¤³¤È¤òµ­Ï¿¤·¤Æ¤ª¤¯
160        $objSiteSess->setRegistFlag();
161        // ¤ª»Ùʧ¤¤ÊýË¡ÁªÂò¥Ú¡¼¥¸¤Ø°ÜÆ°
162        header("Location: " . URL_SHOP_PAYMENT);
163        exit;
164    }
165    break;
166*/
167
168// Á°¤Î¥Ú¡¼¥¸¤ËÌá¤ë
169case 'return':
170    // ³Îǧ¥Ú¡¼¥¸¤Ø°ÜÆ°
171    header("Location: " . URL_CART_TOP);
172    exit;
173    break;
174default:
175    $objQuery = new SC_Query();
176    $where = "order_temp_id = ?";
177    $arrRet = $objQuery->select("*", "dtb_order_temp", $where, array($uniqid));
178    $objFormParam->setParam($arrRet[0]);
179    break;
180}
181
182/** ɽ¼¨½èÍý **/
183
184// ²ñ°÷ÅÐÏ¿½»½ê¤Î¼èÆÀ
185$col = "name01, name02, pref, addr01, addr02, zip01, zip02";
186$where = "customer_id = ?";
187$objQuery = new SC_Query();
188$arrCustomerAddr = $objQuery->select($col, "dtb_customer", $where, array($_SESSION['customer']['customer_id']));
189// Ê̤ΤªÆϤ±Àè½»½ê¤Î¼èÆÀ
190$col = "other_deliv_id, name01, name02, pref, addr01, addr02, zip01, zip02";
191$objQuery->setorder("other_deliv_id DESC");
192$objOtherAddr = $objQuery->select($col, "dtb_other_deliv", $where, array($_SESSION['customer']['customer_id']));
193$objPage->arrAddr = $arrCustomerAddr;
194$cnt = 1;
195foreach($objOtherAddr as $val) {
196    $objPage->arrAddr[$cnt] = $val;
197    $cnt++;
198}
199
200// ÆþÎÏÃͤμèÆÀ
201$objPage->arrForm = $objFormParam->getFormParamList();
202$objPage->arrErr = $arrErr;
203$objView->assignobj($objPage);
204$objView->display(SITE_FRAME);
205//--------------------------------------------------------------------------------------------------------------------------
206/* ¥Ñ¥é¥á¡¼¥¿¾ðÊó¤Î½é´ü²½ */
207function lfInitParam() {
208    global $objFormParam;
209    $objFormParam->addParam("¤ªÌ¾Á°1", "deliv_name01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
210    $objFormParam->addParam("¤ªÌ¾Á°2", "deliv_name02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
211    $objFormParam->addParam("¥Õ¥ê¥¬¥Ê1", "deliv_kana01", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
212    $objFormParam->addParam("¥Õ¥ê¥¬¥Ê2", "deliv_kana02", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
213    $objFormParam->addParam("͹ÊØÈÖ¹æ1", "deliv_zip01", ZIP01_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
214    $objFormParam->addParam("͹ÊØÈÖ¹æ2", "deliv_zip02", ZIP02_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
215    $objFormParam->addParam("ÅÔÆ»Éܸ©", "deliv_pref", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
216    $objFormParam->addParam("½»½ê1", "deliv_addr01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
217    $objFormParam->addParam("½»½ê2", "deliv_addr02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
218    $objFormParam->addParam("ÅÅÏÃÈÖ¹æ1", "deliv_tel01", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
219    $objFormParam->addParam("ÅÅÏÃÈÖ¹æ2", "deliv_tel02", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
220    $objFormParam->addParam("ÅÅÏÃÈÖ¹æ3", "deliv_tel03", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
221}
222
223function lfInitLoginFormParam() {
224    global $objLoginFormParam;
225    $objLoginFormParam->addParam("µ­²±¤¹¤ë", "login_memory", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
226    $objLoginFormParam->addParam("¥á¡¼¥ë¥¢¥É¥ì¥¹", "login_email", STEXT_LEN, "KVa", array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
227    $objLoginFormParam->addParam("¥Ñ¥¹¥ï¡¼¥É", "login_pass", STEXT_LEN, "KVa", array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
228}
229
230/* DB¤Ø¥Ç¡¼¥¿¤ÎÅÐÏ¿ */
231function lfRegistNewAddrData($uniqid, $objCustomer) {
232    global $objFormParam;
233    $arrRet = $objFormParam->getHashArray();
234    $sqlval = $objFormParam->getDbArray();
235    // ÅÐÏ¿¥Ç¡¼¥¿¤ÎºîÀ®
236    $sqlval['deliv_check'] = '1';
237    $sqlval['order_temp_id'] = $uniqid;
238    $sqlval['update_date'] = 'Now()';
239    $sqlval['customer_id'] = $objCustomer->getValue('customer_id');
240    $sqlval['order_birth'] = $objCustomer->getValue('birth');
241   
242    sfRegistTempOrder($uniqid, $sqlval);
243}
244
245/* ²ñ°÷¾ðÊó¤Î½»½ê¤ò°ì»þ¼õÃí¥Æ¡¼¥Ö¥ë¤Ø */
246function lfRegistDelivData($uniqid, $objCustomer) {
247    // ÅÐÏ¿¥Ç¡¼¥¿¤ÎºîÀ®
248    $sqlval['order_temp_id'] = $uniqid;
249    $sqlval['update_date'] = 'Now()';
250    $sqlval['customer_id'] = $objCustomer->getValue('customer_id');
251    $sqlval['deliv_check'] = '1';
252    $sqlval['deliv_name01'] = $objCustomer->getValue('name01');
253    $sqlval['deliv_name02'] = $objCustomer->getValue('name02');
254    $sqlval['deliv_kana01'] = $objCustomer->getValue('kana01');
255    $sqlval['deliv_kana02'] = $objCustomer->getValue('kana02');
256    $sqlval['deliv_zip01'] = $objCustomer->getValue('zip01');
257    $sqlval['deliv_zip02'] = $objCustomer->getValue('zip02');
258    $sqlval['deliv_pref'] = $objCustomer->getValue('pref');
259    $sqlval['deliv_addr01'] = $objCustomer->getValue('addr01');
260    $sqlval['deliv_addr02'] = $objCustomer->getValue('addr02');
261    $sqlval['deliv_tel01'] = $objCustomer->getValue('tel01');
262    $sqlval['deliv_tel02'] = $objCustomer->getValue('tel02');
263    $sqlval['deliv_tel03'] = $objCustomer->getValue('tel03');
264
265    $sqlval['deliv_fax01'] = $objCustomer->getValue('fax01');
266    $sqlval['deliv_fax02'] = $objCustomer->getValue('fax02');
267    $sqlval['deliv_fax03'] = $objCustomer->getValue('fax03');
268
269    sfRegistTempOrder($uniqid, $sqlval);
270}
271
272/* Ê̤ΤªÆϤ±Àè½»½ê¤ò°ì»þ¼õÃí¥Æ¡¼¥Ö¥ë¤Ø */
273function lfRegistOtherDelivData($uniqid, $objCustomer, $other_deliv_id) {
274    // ÅÐÏ¿¥Ç¡¼¥¿¤ÎºîÀ®
275    $sqlval['order_temp_id'] = $uniqid;
276    $sqlval['update_date'] = 'Now()';
277    $sqlval['customer_id'] = $objCustomer->getValue('customer_id');
278    $sqlval['order_birth'] = $objCustomer->getValue('birth');
279       
280    $objQuery = new SC_Query();
281    $where = "other_deliv_id = ?";
282    $arrRet = $objQuery->select("*", "dtb_other_deliv", $where, array($other_deliv_id));
283   
284    $sqlval['deliv_check'] = '1';
285    $sqlval['deliv_name01'] = $arrRet[0]['name01'];
286    $sqlval['deliv_name02'] = $arrRet[0]['name02'];
287    $sqlval['deliv_kana01'] = $arrRet[0]['kana01'];
288    $sqlval['deliv_kana02'] = $arrRet[0]['kana02'];
289    $sqlval['deliv_zip01'] = $arrRet[0]['zip01'];
290    $sqlval['deliv_zip02'] = $arrRet[0]['zip02'];
291    $sqlval['deliv_pref'] = $arrRet[0]['pref'];
292    $sqlval['deliv_addr01'] = $arrRet[0]['addr01'];
293    $sqlval['deliv_addr02'] = $arrRet[0]['addr02'];
294    $sqlval['deliv_tel01'] = $arrRet[0]['tel01'];
295    $sqlval['deliv_tel02'] = $arrRet[0]['tel02'];
296    $sqlval['deliv_tel03'] = $arrRet[0]['tel03'];
297    sfRegistTempOrder($uniqid, $sqlval);
298}
299
300/* ÆþÎÏÆâÍƤΥÁ¥§¥Ã¥¯ */
301function lfCheckError() {
302    global $objFormParam;
303    // ÆþÎϥǡ¼¥¿¤òÅϤ¹¡£
304    $arrRet =  $objFormParam->getHashArray();
305    $objErr = new SC_CheckError($arrRet);
306    $objErr->arrErr = $objFormParam->checkError();
307    // Ê£¿ô¹àÌÜ¥Á¥§¥Ã¥¯
308    if ($_POST['mode'] == 'login'){
309    $objErr->doFunc(array("¥á¡¼¥ë¥¢¥É¥ì¥¹", "login_email", STEXT_LEN), array("EXIST_CHECK"));
310    $objErr->doFunc(array("¥Ñ¥¹¥ï¡¼¥É", "login_pass", STEXT_LEN), array("EXIST_CHECK"));
311    }
312    $objErr->doFunc(array("TEL", "deliv_tel01", "deliv_tel02", "deliv_tel03", TEL_ITEM_LEN), array("TEL_CHECK"));
313    return $objErr->arrErr;
314}
315?>
Note: See TracBrowser for help on using the repository browser.