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

Revision 15078, 10.9 KB checked in by nanasess, 17 years ago (diff)

r15064 から svn cp
とりあえず暫定コミット.

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