source: branches/comu-ver2/data/class/pages/inquiry/LC_Page_Inquiry.php @ 17094

Revision 17094, 12.1 KB checked in by pineray, 16 years ago (diff)

Chgset17049-17053のマージ

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
  • 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_Inquiry.php 15532 2007-08-31 14:39:46Z nanasess $
33 */
34class LC_Page_Inquiry extends LC_Page {
35
36    // }}}
37    // {{{ functions
38
39    /**
40     * Page を初期化する.
41     *
42     * @return void
43     */
44    function init() {
45        parent::init();
46        $this->tpl_mainpage = 'inquiry/index.tpl';
47        $this->tpl_mainno = 'contents';
48    }
49
50    /**
51     * Page のプロセス.
52     *
53     * @return void
54     */
55    function process() {
56        $conn = new SC_DBConn();
57        $objPage = new LC_Page();
58        $objView = new SC_SiteView();
59        $objSess = new SC_Session();
60
61
62        // 都道府県プルダウン用配列
63        $masterData = new SC_DB_MasterData_Ex();
64        $this->arrPref = $masterData->getMasterData("mtb_pref",
65                                  array("pref_id", "pref_name", "rank"));
66
67        // CSV保存項目
68        //---- 登録用カラム配列 オプション以外
69        $arrRegistColumn = array(
70                                     array(  "column" => "name01", "convert" => "aKV" ),
71                                     array(  "column" => "name02", "convert" => "aKV" ),
72                                     array(  "column" => "kana01", "convert" => "CKV" ),
73                                     array(  "column" => "kana02", "convert" => "CKV" ),
74                                     array(  "column" => "zip01", "convert" => "n" ),
75                                     array(  "column" => "zip02", "convert" => "n" ),
76                                     array(  "column" => "pref", "convert" => "n" ),
77                                     array(  "column" => "addr01", "convert" => "aKV" ),
78                                     array(  "column" => "addr02", "convert" => "aKV" ),
79                                     array(  "column" => "email", "convert" => "a" ),
80                                     array(  "column" => "email02", "convert" => "a" ),
81                                     array(  "column" => "tel01", "convert" => "n" ),
82                                     array(  "column" => "tel02", "convert" => "n" ),
83                                     array(  "column" => "tel03", "convert" => "n" ),
84                            );
85
86
87        if (!isset($_POST['mode'])) $_POST['mode'] = "";
88
89        if ( ( ! $_POST['mode'] == 'confirm' ) && ( ! is_numeric($_REQUEST['question_id']) ) ){
90            echo "不正アクセス";
91            exit;
92        }
93
94        // テンプレート登録項目取得
95        $sql = "SELECT question_id, question FROM dtb_question WHERE question_id = ?";
96        $result = $conn->getAll( $sql, array($_REQUEST['question_id']) );
97        $this->QUESTION = $this->lfGetArrInput( unserialize( $result[0]['question'] ) );
98
99        $this->question_id = $_REQUEST['question_id'];
100
101        $this->arrHidden = SC_Utils_Ex::sfMakeHiddenArray($_POST);
102        unset($this->arrHidden['mode']);
103
104        if (isset($this->QUESTION["delete"])
105            && (int)$this->QUESTION["delete"] !== 0 ){
106
107            $objPage->tpl_mainpage = "inquiry/closed.tpl";
108
109        } elseif( $_POST['mode'] == "confirm" ) {
110
111            //-- 入力エラーチェック
112            $this->arrForm = $_POST;
113            $this->arrForm = $this->lfConvertParam($this->arrForm, $arrRegistColumn);
114            $this->arrErr = $this->lfErrorCheck($this->arrForm);
115            $this->arrErr = $this->lfGetArrInput($this->arrErr);
116
117            if( ! $this->arrErr ) {
118                $this->tpl_mainpage = "inquiry/confirm.tpl";
119            }
120
121
122        }elseif( $_POST['mode'] == "return"){
123            $this->arrForm = $_POST;
124
125        }elseif( $_POST['mode'] == "regist" )  {
126
127            //-- 入力文字・変換&エラーチェック
128            $this->arrForm = $_POST;
129            $this->arrForm = $this->lfConvertParam($this->arrForm, $arrRegistColumn);
130            $this->arrErr = $this->lfErrorCheck($this->arrForm);
131            $this->arrErr = $this->lfGetArrInput($this->arrErr);
132
133
134            if( ! $this->arrErr ) {
135
136                //完了画面
137                $this->tpl_mainpage = "inquiry/complete.tpl";
138
139
140                //--------- ▼ SQL ---------//
141
142                    // テーブルに入れるように整形する
143                    $arrOption = $this->arrForm['option'];
144                    unset ($this->arrForm['email02']);
145                    $this->arrForm['mail01'] = $this->arrForm['email'];
146                    unset ($this->arrForm['email']);
147                    unset ($this->arrForm['option']);
148                    $this->arrForm['question_id'] = $this->question_id;
149                    $this->arrForm['question_name'] = $this->QUESTION['title'];
150                    for ( $i=0; $i<(count($arrOption)); $i++ ){
151                        $tmp = "";
152                        if ( is_array($arrOption[$i]) ){
153                            for( $j=0; $j<count($arrOption[$i]); $j++){
154                                if ( $j>0 ) $tmp .= ",";
155                                $tmp .= $arrOption[$i][$j];
156                            }
157                            $this->arrForm['question0'.($i+1)] = $tmp;
158                        } else {
159                            $this->arrForm['question0'.($i+1)] = $arrOption[$i];
160                        }
161                    }
162                    $this->arrForm['create_date'] = "now()";
163                    // DB登録
164                    $objQuery = new SC_Query();
165                    $objQuery->insert("dtb_question_result", $this->arrForm );
166
167                //--------- ▲ SQL ---------//
168
169            }
170        }
171
172        $this->cnt_question = 6;
173        $this->arrActive = isset($arrActive) ? $arrActive : "";
174        $this->arrQuestion = isset($arrQuestion) ? $arrQuestion : "";
175
176
177        //---- ページ表示
178        $objView->_smarty->register_function("lfArray_Search_key_Smarty", array("LC_Page_Inquiry", "lfArray_Search_key_Smarty"));
179        $objView->assignobj($this);
180        $objView->display($this->tpl_mainpage);
181    }
182
183    /**
184     * デストラクタ.
185     *
186     * @return void
187     */
188    function destroy() {
189        parent::destroy();
190    }
191
192    // }}}
193    // {{{ protected functions
194
195    /**
196     * エラーチェック
197     *
198     * @param array FormParam の配列
199     * @return array エラー情報の配列
200     **/
201    function lfErrorCheck($array) {
202
203        $objErr = new SC_CheckError($array);
204
205        $objErr->doFunc(array("お名前(姓)", 'name01', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK","MAX_LENGTH_CHECK"));
206        $objErr->doFunc(array("お名前(名)", 'name02', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
207        $objErr->doFunc(array("フリガナ(セイ)", 'kana01', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK", "KANA_CHECK"));
208        $objErr->doFunc(array("フリガナ(メイ)", 'kana02', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK", "KANA_CHECK"));
209        $objErr->doFunc(array("郵便番号1", "zip01", ZIP01_LEN ) ,array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
210        $objErr->doFunc(array("郵便番号2", "zip02", ZIP02_LEN ) ,array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
211        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
212        $objErr->doFunc(array("都道府県", 'pref'), array("SELECT_CHECK","NUM_CHECK"));
213        $objErr->doFunc(array("ご住所1", "addr01", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
214        $objErr->doFunc(array("ご住所2", "addr02", MTEXT_LEN), array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
215        $objErr->doFunc(array("お電話番号1", 'tel01'), array("EXIST_CHECK", "NUM_CHECK"));
216        $objErr->doFunc(array("お電話番号2", 'tel02'), array("EXIST_CHECK", "NUM_CHECK"));
217        $objErr->doFunc(array("お電話番号3", 'tel03'), array("EXIST_CHECK", "NUM_CHECK"));
218        $objErr->doFunc(array('メールアドレス', "email", MTEXT_LEN) ,array("EXIST_CHECK", "SPTAB_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
219        $objErr->doFunc(array('メールアドレス(確認)', "email02", MTEXT_LEN) ,array("EXIST_CHECK", "SPTAB_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
220        $objErr->doFunc(array('メールアドレス', 'メールアドレス(確認)', "email", "email02") ,array("EQUAL_CHECK"));
221
222        $objErr->arrErr["option"] =  array_map(array($this, "lfCheckNull"), (array)$_POST['option'] );
223
224        return $objErr->arrErr;
225    }
226
227    /**
228     * 取得文字列の変換
229     *
230     * @param array $array 取得文字列の配列
231     * @param array フォームパラメータの配列
232     * @return array 変換後の文字列
233     **/
234    function lfConvertParam($array, $arrRegistColumn) {
235
236        // カラム名とコンバート情報
237        foreach ($arrRegistColumn as $data) {
238            $arrConvList[ $data["column"] ] = $data["convert"];
239        }
240        // 文字変換
241        $new_array = array();
242        foreach ($arrConvList as $key => $val) {
243            $new_array[$key] = $array[$key];
244            if( strlen($val) > 0) {
245                $new_array[$key] = mb_convert_kana($new_array[$key] ,$val);
246            }
247        }
248
249        // オプション配列用
250        for ($i=0; $i<count($array['option']); $i++){
251            if ( is_array($array['option'][$i]) ){
252                $new_array['option'][$i] = $array['option'][$i];
253            } else {
254                $new_array['option'][$i] = mb_convert_kana($array['option'][$i] ,"aKV");
255            }
256        }
257
258        return $new_array;
259    }
260
261    /**
262     * 値が入力された配列のみを返す.
263     *
264     * @param array $arr 入力文字列
265     * @return array 値が入力された配列
266     */
267    function lfGetArrInput( $arr ){
268        // 値が入力された配列のみを返す
269        $return = array();
270
271        if ( is_array($arr) ){
272            foreach ( $arr as $key=>$val ) {
273                if ( is_string($val) && strlen($val) > 0 ){
274                    $return[$key] = $val;
275                } elseif ( is_array( $val ) ) {
276                    $data = $this->lfGetArrInput ( $val );
277                    if ( $data ){
278                        $return[$key] = $data;
279                    }
280                }
281            }
282        }
283        return $return;
284    }
285
286    /**
287     * 配列の Smarty 変数の存在をチェックする.
288     *
289     * @param array $params フォームパラメータの配列
290     * @return Smarty 変数が存在する場合 true
291     */
292    function lfArray_Search_key_Smarty ( $params ){
293
294        $val = $params['val'];
295        $arr = $params['arr'];
296
297        $revers_arr = array_flip($arr);
298        return array_search( $val ,$revers_arr );
299
300
301    }
302
303    /**
304     * 引数が null かチェックする.
305     *
306     * @param mixed $val 入力データ
307     * @return integer|array 引数に null が含まれる場合 1, それ以外は空の配列
308     */
309    function lfCheckNull ( $val ){
310        $return = array();
311
312        if ( ( ! is_array( $val ) ) && ( strlen( $val ) < 1 ) ){
313            $return = "1";
314        } elseif ( is_array( $val ) ) {
315            foreach ($val as $line) {
316                $return = $this->lfCheckNull( $line );
317            }
318        }
319        return $return;
320    }
321}
322?>
Note: See TracBrowser for help on using the repository browser.