source: branches/feature-module-update/data/class/SC_FormParam.php @ 15593

Revision 15593, 11.8 KB checked in by nanasess, 17 years ago (diff)

コメント追加

  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/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/* パラメータ管理クラス */
9class SC_FormParam {
10
11    var $param;
12    var $disp_name;
13    var $keyname;
14    var $length;
15    var $convert;
16    var $arrCheck;
17    var $default;   // 何も入力されていないときに表示する値
18    var $input_db;  // DBにそのまま挿入可能か否か
19    var $html_disp_name;
20
21    // コンストラクタ
22    function SC_FormParam() {
23        $this->check_dir = IMAGE_SAVE_DIR;
24        $this->disp_name = array();
25        $this->keyname = array();
26        $this->length = array();
27        $this->convert = array();
28        $this->arrCheck = array();
29        $this->default = array();
30        $this->input_db = array();
31    }
32
33    // パラメータの追加
34    function addParam($disp_name, $keyname, $length="", $convert="", $arrCheck=array(), $default="", $input_db="true") {
35        $this->disp_name[] = $disp_name;
36        $this->keyname[] = $keyname;
37        $this->length[] = $length;
38        $this->convert[] = $convert;
39        $this->arrCheck[] = $arrCheck;
40        $this->default[] = $default;
41        $this->input_db[] = $input_db;
42    }
43
44    // パラメータの入力
45    // $arrVal  :$arrVal['keyname']・・の配列を一致したキーのインスタンスに格納する
46    // $seq     :trueの場合、$arrVal[0]~の配列を登録順にインスタンスに格納する
47    function setParam($arrVal, $seq = false) {
48        $cnt = 0;
49        if(!$seq){
50            foreach($this->keyname as $val) {
51                if(isset($arrVal[$val])) {
52                    $this->setValue($val, $arrVal[$val]);
53                }
54            }
55        } else {
56            foreach($this->keyname as $val) {
57                $this->param[$cnt] = $arrVal[$cnt];
58                $cnt++;
59            }
60        }
61    }
62
63    // 画面表示用タイトル生成
64    function setHtmlDispNameArray() {
65        $cnt = 0;
66        foreach($this->keyname as $val) {
67            $find = false;
68            foreach($this->arrCheck[$cnt] as $val) {
69                if($val == "EXIST_CHECK") {
70                    $find = true;
71                }
72            }
73
74            if($find) {
75                $this->html_disp_name[$cnt] = $this->disp_name[$cnt] . "<span class='red'>(※ 必須)</span>";
76            } else {
77                $this->html_disp_name[$cnt] = $this->disp_name[$cnt];
78            }
79            $cnt++;
80        }
81    }
82
83    // 画面表示用タイトル取得
84    function getHtmlDispNameArray() {
85        return $this->html_disp_name;
86    }
87
88    // 複数列パラメータの取得
89    function setParamList($arrVal, $keyname) {
90        // DBの件数を取得する。
91        $count = count($arrVal);
92        $no = 1;
93        for($cnt = 0; $cnt < $count; $cnt++) {
94            $key = $keyname.$no;
95            if($arrVal[$cnt][$keyname] != "") {
96                $this->setValue($key, $arrVal[$cnt][$keyname]);
97            }
98            $no++;
99        }
100    }
101
102    function setDBDate($db_date, $year_key = 'year', $month_key = 'month', $day_key = 'day') {
103        list($y, $m, $d) = split("[- ]", $db_date);
104        $this->setValue($year_key, $y);
105        $this->setValue($month_key, $m);
106        $this->setValue($day_key, $d);
107    }
108
109    // キーに対応した値をセットする。
110    function setValue($key, $param) {
111        $cnt = 0;
112        foreach($this->keyname as $val) {
113            if($val == $key) {
114                $this->param[$cnt] = $param;
115                break;
116            }
117            $cnt++;
118        }
119    }
120
121    function toLower($key) {
122        $cnt = 0;
123        foreach($this->keyname as $val) {
124            if($val == $key) {
125                $this->param[$cnt] = strtolower($this->param[$cnt]);
126                break;
127            }
128            $cnt++;
129        }
130    }
131
132    // エラーチェック
133    function checkError($br = true, $keyname = "") {
134        // 連想配列の取得
135        $arrRet = $this->getHashArray($keyname);
136        $objErr = new SC_CheckError($arrRet);
137        $cnt = 0;
138        foreach($this->keyname as $val) {
139            foreach($this->arrCheck[$cnt] as $func) {
140                switch($func) {
141                case 'EXIST_CHECK':
142                case 'NUM_CHECK':
143                case 'EMAIL_CHECK':
144                case 'EMAIL_CHAR_CHECK':
145                case 'ALNUM_CHECK':
146                case 'KANA_CHECK':
147                case 'URL_CHECK':
148                case 'SPTAB_CHECK':
149                case 'ZERO_CHECK':
150                case 'ALPHA_CHECK':
151                case 'ZERO_START':
152                case 'FIND_FILE':
153                case 'NO_SPTAB':
154                case 'DIR_CHECK':
155                case 'DOMAIN_CHECK':
156                case 'FILE_NAME_CHECK':
157                case 'MOBILE_EMAIL_CHECK':
158
159                    if(!is_array($this->param[$cnt])) {
160                        $objErr->doFunc(array($this->disp_name[$cnt], $val), array($func));
161                    } else {
162                        $max = count($this->param[$cnt]);
163                        for($i = 0; $i < $max; $i++) {
164                            $objSubErr = new SC_CheckError($this->param[$cnt]);
165                            $objSubErr->doFunc(array($this->disp_name[$cnt], $i), array($func));
166                            if(count($objSubErr->arrErr) > 0) {
167                                foreach($objSubErr->arrErr as $mess) {
168                                    if($mess != "") {
169                                        $objErr->arrErr[$val] = $mess;
170                                    }
171                                }
172                            }
173                        }
174                    }
175                    break;
176                case 'MAX_LENGTH_CHECK':
177                case 'NUM_COUNT_CHECK':
178                    if(!is_array($this->param[$cnt])) {
179                        $objErr->doFunc(array($this->disp_name[$cnt], $val, $this->length[$cnt]), array($func));
180                    } else {
181                        $max = count($this->param[$cnt]);
182                        for($i = 0; $i < $max; $i++) {
183                            $objSubErr = new SC_CheckError($this->param[$cnt]);
184                            $objSubErr->doFunc(array($this->disp_name[$cnt], $i, $this->length[$cnt]), array($func));
185                            if(count($objSubErr->arrErr) > 0) {
186                                foreach($objSubErr->arrErr as $mess) {
187                                    if($mess != "") {
188                                        $objErr->arrErr[$val] = $mess;
189                                    }
190                                }
191                            }
192                        }
193                    }
194                    break;
195                // 小文字に変換
196                case 'CHANGE_LOWER':
197                    $this->param[$cnt] = strtolower($this->param[$cnt]);
198                    break;
199                // ファイルの存在チェック
200                case 'FILE_EXISTS':
201                    if($this->param[$cnt] != "" && !file_exists($this->check_dir . $this->param[$cnt])) {
202                        $objErr->arrErr[$val] = "※ " . $this->disp_name[$cnt] . "のファイルが存在しません。<br>";
203                    }
204                    break;
205                default:
206                    $objErr->arrErr[$val] = "※※ エラーチェック形式($func)には対応していません ※※ <br>";
207                    break;
208                }
209            }
210
211            if (isset($objErr->arrErr[$val]) && !$br) {
212                $objErr->arrErr[$val] = ereg_replace("<br>$", "", $objErr->arrErr[$val]);
213            }
214            $cnt++;
215        }
216        return $objErr->arrErr;
217    }
218
219    // 入力文字の変換
220    function convParam() {
221        /*
222         *  文字列の変換
223         *  K :  「半角(ハンカク)片仮名」を「全角片仮名」に変換
224         *  C :  「全角ひら仮名」を「全角かた仮名」に変換
225         *  V :  濁点付きの文字を一文字に変換。"K","H"と共に使用します
226         *  n :  「全角」数字を「半角(ハンカク)」に変換
227         *  a :  「全角」英字を「半角」英字に変換
228         */
229        $cnt = 0;
230        foreach ($this->keyname as $val) {
231            if (!isset($this->param[$cnt])) $this->param[$cnt] = "";
232
233            if(!is_array($this->param[$cnt])) {
234                if($this->convert[$cnt] != "") {
235                    $this->param[$cnt] = mb_convert_kana($this->param[$cnt] ,$this->convert[$cnt]);
236                }
237            } else {
238                $max = count($this->param[$cnt]);
239                for($i = 0; $i < $max; $i++) {
240                    if($this->convert[$cnt] != "") {
241                        $this->param[$cnt][$i] = mb_convert_kana($this->param[$cnt][$i] ,$this->convert[$cnt]);
242                    }
243                }
244            }
245            $cnt++;
246        }
247    }
248
249    // 連想配列の作成
250    function getHashArray($keyname = "") {
251        $cnt = 0;
252        foreach($this->keyname as $val) {
253            if($keyname == "" || $keyname == $val) {
254                $arrRet[$val] = $this->param[$cnt];
255                $cnt++;
256            }
257        }
258        return $arrRet;
259    }
260
261    // DB格納用配列の作成
262    function getDbArray() {
263        $cnt = 0;
264        foreach ($this->keyname as $val) {
265            if ($this->input_db[$cnt]) {
266                $arrRet[$val] = $this->param[$cnt];
267            }
268            $cnt++;
269        }
270        return $arrRet;
271    }
272
273    // 配列の縦横を入れ替えて返す
274    function getSwapArray($arrKey) {
275        foreach($arrKey as $keyname) {
276            $arrVal = $this->getValue($keyname);
277            $max = count($arrVal);
278            for($i = 0; $i < $max; $i++) {
279                $arrRet[$i][$keyname] = $arrVal[$i];
280            }
281        }
282        return $arrRet;
283    }
284
285    // 項目名一覧の取得
286    function getTitleArray() {
287        return $this->disp_name;
288    }
289
290    // 項目数を返す
291    function getCount() {
292        $count = count($this->keyname);
293        return $count;
294    }
295
296    // フォームに渡す用のパラメータを返す
297    function getFormParamList() {
298        $cnt = 0;
299        foreach($this->keyname as $val) {
300
301            // キー名
302            $arrRet[$val]['keyname'] = $this->keyname[$cnt];
303            // 文字数制限
304            $arrRet[$val]['length'] = $this->length[$cnt];
305            // 入力値
306            if (isset($this->param[$cnt])) {
307                $arrRet[$val]['value'] = $this->param[$cnt];
308            }
309
310            // TODO 未定義値の対応...
311            if($this->default[$cnt] != "" && $this->param[$cnt] == "") {
312                $arrRet[$val]['value'] = $this->default[$cnt];
313            }
314
315            $cnt++;
316        }
317        return $arrRet;
318    }
319
320    // キー名の一覧を返す
321    function getKeyList() {
322        foreach($this->keyname as $val) {
323            $arrRet[] = $val;
324        }
325        return $arrRet;
326    }
327
328    // キー名と一致した値を返す
329    function getValue($keyname) {
330        $cnt = 0;
331        foreach($this->keyname as $val) {
332            if($val == $keyname) {
333                $ret = $this->param[$cnt];
334                break;
335            }
336            $cnt++;
337        }
338        return $ret;
339    }
340
341    function splitCheckBoxes($keyname) {
342        $cnt = 0;
343        foreach($this->keyname as $val) {
344            if($val == $keyname) {
345                $this->param[$cnt] = sfSplitCheckBoxes($this->param[$cnt]);
346            }
347            $cnt++;
348        }
349    }
350
351    function splitParamCheckBoxes($keyname) {
352        $cnt = 0;
353        foreach($this->keyname as $val) {
354            if($val == $keyname) {
355                if(isset($this->param[$cnt]) && !is_array($this->param[$cnt])) {
356                    $this->param[$cnt] = split("-", $this->param[$cnt]);
357                }
358            }
359            $cnt++;
360        }
361    }
362}
363?>
Note: See TracBrowser for help on using the repository browser.