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

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

暫定 commit

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