source: branches/feature-module-update/data/class/pages/inquiry/LC_Page_Inquiry.php @ 15090

Revision 15090, 10.8 KB checked in by nanasess, 17 years ago (diff)

メンバ変数をプルアップし、 init() で初期化するよう変更

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