tpl_mainpage = 'inquiry/index.tpl'; $this->tpl_mainno = 'contents'; } /** * Page のプロセス. * * @return void */ function process() { $conn = new SC_DBConn(); $objPage = new LC_Page(); $objView = new SC_SiteView(); $objSess = new SC_Session(); // 都道府県プルダウン用配列 $masterData = new SC_DB_MasterData_Ex(); $this->arrPref = $masterData->getMasterData("mtb_pref", array("pref_id", "pref_name", "rank")); // CSV保存項目 //---- 登録用カラム配列 オプション以外 $arrRegistColumn = array( array( "column" => "name01", "convert" => "aKV" ), array( "column" => "name02", "convert" => "aKV" ), array( "column" => "kana01", "convert" => "CKV" ), array( "column" => "kana02", "convert" => "CKV" ), array( "column" => "zip01", "convert" => "n" ), array( "column" => "zip02", "convert" => "n" ), array( "column" => "pref", "convert" => "n" ), array( "column" => "addr01", "convert" => "aKV" ), array( "column" => "addr02", "convert" => "aKV" ), array( "column" => "email", "convert" => "a" ), array( "column" => "email02", "convert" => "a" ), array( "column" => "tel01", "convert" => "n" ), array( "column" => "tel02", "convert" => "n" ), array( "column" => "tel03", "convert" => "n" ), ); if (!isset($_POST['mode'])) $_POST['mode'] = ""; if ( ( ! $_POST['mode'] == 'confirm' ) && ( ! is_numeric($_REQUEST['question_id']) ) ){ echo "不正アクセス"; exit; } // テンプレート登録項目取得 $sql = "SELECT question_id, question FROM dtb_question WHERE question_id = ?"; $result = $conn->getAll( $sql, array($_REQUEST['question_id']) ); $this->QUESTION = $this->lfGetArrInput( unserialize( $result[0]['question'] ) ); $this->question_id = $_REQUEST['question_id']; $this->arrHidden = SC_Utils_Ex::sfMakeHiddenArray($_POST); unset($this->arrHidden['mode']); if (isset($this->QUESTION["delete"]) && (int)$this->QUESTION["delete"] !== 0 ){ $objPage->tpl_mainpage = "inquiry/closed.tpl"; } elseif( $_POST['mode'] == "confirm" ) { //-- 入力エラーチェック $this->arrForm = $_POST; $this->arrForm = $this->lfConvertParam($this->arrForm, $arrRegistColumn); $this->arrErr = $this->lfErrorCheck($this->arrForm); $this->arrErr = $this->lfGetArrInput($this->arrErr); if( ! $this->arrErr ) { $this->tpl_mainpage = "inquiry/confirm.tpl"; } }elseif( $_POST['mode'] == "return"){ $this->arrForm = $_POST; }elseif( $_POST['mode'] == "regist" ) { //-- 入力文字・変換&エラーチェック $this->arrForm = $_POST; $this->arrForm = $this->lfConvertParam($this->arrForm, $arrRegistColumn); $this->arrErr = $this->lfErrorCheck($this->arrForm); $this->arrErr = $this->lfGetArrInput($this->arrErr); if( ! $this->arrErr ) { //完了画面 $this->tpl_mainpage = "inquiry/complete.tpl"; //--------- ▼ SQL ---------// // テーブルに入れるように整形する $arrOption = $this->arrForm['option']; unset ($this->arrForm['email02']); $this->arrForm['mail01'] = $this->arrForm['email']; unset ($this->arrForm['email']); unset ($this->arrForm['option']); $this->arrForm['question_id'] = $this->question_id; $this->arrForm['question_name'] = $this->QUESTION['title']; for ( $i=0; $i<(count($arrOption)); $i++ ){ $tmp = ""; if ( is_array($arrOption[$i]) ){ for( $j=0; $j0 ) $tmp .= ","; $tmp .= $arrOption[$i][$j]; } $this->arrForm['question0'.($i+1)] = $tmp; } else { $this->arrForm['question0'.($i+1)] = $arrOption[$i]; } } $this->arrForm['create_date'] = "now()"; // DB登録 $objQuery = new SC_Query(); $objQuery->insert("dtb_question_result", $this->arrForm ); //--------- ▲ SQL ---------// } } $this->cnt_question = 6; $this->arrActive = isset($arrActive) ? $arrActive : ""; $this->arrQuestion = isset($arrQuestion) ? $arrQuestion : ""; //---- ページ表示 $objView->_smarty->register_modifier("lfArray_Search_key_Smarty","lfArray_Search_key_Smarty"); $objView->assignobj($this); $objView->display($this->tpl_mainpage); } /** * デストラクタ. * * @return void */ function destroy() { parent::destroy(); } // }}} // {{{ protected functions /** * エラーチェック * * @param array FormParam の配列 * @return array エラー情報の配列 **/ function lfErrorCheck($array) { $objErr = new SC_CheckError($array); $objErr->doFunc(array("お名前(姓)", 'name01', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK","MAX_LENGTH_CHECK")); $objErr->doFunc(array("お名前(名)", 'name02', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK")); $objErr->doFunc(array("フリガナ(セイ)", 'kana01', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK", "KANA_CHECK")); $objErr->doFunc(array("フリガナ(メイ)", 'kana02', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK", "KANA_CHECK")); $objErr->doFunc(array("郵便番号1", "zip01", ZIP01_LEN ) ,array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK")); $objErr->doFunc(array("郵便番号2", "zip02", ZIP02_LEN ) ,array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK")); $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK")); $objErr->doFunc(array("都道府県", 'pref'), array("SELECT_CHECK","NUM_CHECK")); $objErr->doFunc(array("ご住所1", "addr01", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK")); $objErr->doFunc(array("ご住所2", "addr02", MTEXT_LEN), array("SPTAB_CHECK", "MAX_LENGTH_CHECK")); $objErr->doFunc(array("お電話番号1", 'tel01'), array("EXIST_CHECK", "NUM_CHECK")); $objErr->doFunc(array("お電話番号2", 'tel02'), array("EXIST_CHECK", "NUM_CHECK")); $objErr->doFunc(array("お電話番号3", 'tel03'), array("EXIST_CHECK", "NUM_CHECK")); $objErr->doFunc(array('メールアドレス', "email", MTEXT_LEN) ,array("EXIST_CHECK", "SPTAB_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK")); $objErr->doFunc(array('メールアドレス(確認)', "email02", MTEXT_LEN) ,array("EXIST_CHECK", "SPTAB_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK")); $objErr->doFunc(array('メールアドレス', 'メールアドレス(確認)', "email", "email02") ,array("EQUAL_CHECK")); $objErr->arrErr["option"] = array_map(array($this, "lfCheckNull"), (array)$_POST['option'] ); return $objErr->arrErr; } /** * 取得文字列の変換 * * @param array $array 取得文字列の配列 * @param array フォームパラメータの配列 * @return array 変換後の文字列 **/ function lfConvertParam($array, $arrRegistColumn) { // カラム名とコンバート情報 foreach ($arrRegistColumn as $data) { $arrConvList[ $data["column"] ] = $data["convert"]; } // 文字変換 $new_array = array(); foreach ($arrConvList as $key => $val) { $new_array[$key] = $array[$key]; if( strlen($val) > 0) { $new_array[$key] = mb_convert_kana($new_array[$key] ,$val); } } // オプション配列用 for ($i=0; $i$val ) { if ( is_string($val) && strlen($val) > 0 ){ $return[$key] = $val; } elseif ( is_array( $val ) ) { $data = $this->lfGetArrInput ( $val ); if ( $data ){ $return[$key] = $data; } } } } return $return; } /** * 配列の Smarty 変数の存在をチェックする. * * @param array $params フォームパラメータの配列 * @return Smarty 変数が存在する場合 true */ function lfArray_Search_key_Smarty ( $params ){ $val = $params['val']; $arr = $params['arr']; $revers_arr = array_flip($arr); return array_search( $val ,$revers_arr ); } /** * 引数が null かチェックする. * * @param mixed $val 入力データ * @return integer|array 引数に null が含まれる場合 1, それ以外は空の配列 */ function lfCheckNull ( $val ){ $return = array(); if ( ( ! is_array( $val ) ) && ( strlen( $val ) < 1 ) ){ $return = "1"; } elseif ( is_array( $val ) ) { foreach ($val as $line) { $return = $this->lfCheckNull( $line ); } } return $return; } } ?>