001/*
002 * Copyright (c) 2009 The openGion Project.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *     http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
013 * either express or implied. See the License for the specific language
014 * governing permissions and limitations under the License.
015 */
016package org.opengion.hayabusa.taglib;
017
018import static org.opengion.fukurou.util.StringUtil.nval;
019
020import java.io.IOException;
021import java.io.ObjectInputStream;
022import java.io.ObjectOutputStream;
023
024import org.opengion.fukurou.util.Options;
025import org.opengion.fukurou.util.StringUtil;
026import org.opengion.fukurou.util.TagBuffer;
027import org.opengion.fukurou.util.XHTMLTag;
028import org.opengion.hayabusa.common.HybsSystem;
029import org.opengion.hayabusa.common.HybsSystemException;
030
031/**
032 * プルダウンメニューを作成するHTML拡張タグです。
033 *
034 * プルダウンメニュー内の選択肢は、selectタグの内容であるoptionタグ、
035 * またはqueryOptionタグによって指定します。
036 * optionタグがセットされない場合は、name属性の、コードリソース からoption文字列より、
037 * プルダウンメニューの選択肢を作成します。
038 * name 属性に ラベルリソース のキーを与えることで、 ロケールにあわせたリソースを使用して、
039 * 画面に表示します。ロケールは、ユーザー情報の lang 属性を初期値で使用し、
040 * セットされていない場合は、リクエスト情報のロケールから取得します。
041 * language 属性で定義されている場合は、そちらを優先します。
042 *
043 * @og.formSample
044 * ●形式:<og:select name="…" />
045 * ●body:あり(EVAL_BODY_INCLUDE:BODYをインクルードし、{@XXXX} は解析しません)
046 *
047 * ●Tag定義:
048 *   <og:select
049 *       name             ○【TAG】メニューの名称を指定します(必須)。
050 *       value              【TAG】値を指定します
051 *       defaultVal         【TAG】value属性に値がセットされていないとき使用する、初期値を指定します
052 *       lbl                【TAG】ラベルリソースのラベルIDを指定します
053 *       must               【TAG】必須入力を表す色に変えるかどうか[true/false]を指定します(初期値:false)
054 *       mustAny            【TAG】選択必須入力(どれかひとつ必須)を表す色[true/mustAny/その他]を指定します(初期値:無指定)
055 *       addNoValue         【TAG】値なしのOptionを含めるかどうか[true/false]を指定します(初期値:false)
056 *       td                 【TAG】テーブル形式の <td> タグを使用するかどうか[yes/no/false]を指定します(初期値:yes)
057 *       colspan            【TAG】フィールド部分の colspan を指定します
058 *       optionAttributes   【TAG】JavaScript などの HTML基本タグ以外の属性を、そのままタグとして使用します
059 *       size               【TAG】リストボックスとして表示する場合の表示行数を指定します
060 *       multiple           【TAG】複数選択を可能(multiple)にします(初期値:未設定)
061 *       id                 【HTML】要素に対して固有の名前(id)をつける場合に設定します
062 *       caseKey            【TAG】このタグ自体を利用するかどうかの条件キーを指定します(初期値:null)
063 *       caseVal            【TAG】このタグ自体を利用するかどうかの条件値を指定します(初期値:null)
064 *       caseNN             【TAG】指定の値が、null/ゼロ文字列 でない場合(Not Null=NN)は、このタグは使用されます(初期値:true)
065 *       caseNull           【TAG】指定の値が、null/ゼロ文字列 の場合は、このタグは使用されます(初期値:true)
066 *       lang               【HTML】要素の内容と他の属性値の言語(lang,xml:lang)を指定します
067 *       dir                【HTML】文字表記の方向(dir)を指定します
068 *       title              【HTML】要素に対する補足的情報(title)を設定します
069 *       style              【HTML】この要素に対して適用させるスタイルシート(style)を設定します
070 *       disabled           【TAG】その部品に対して、選択や変更が出来ないように(disabled)指定します(サーバーに送信されない)
071 *       tabindex           【HTML】タブの移動順(tabindex)を指定します(0 〜 32767)
072 *       clazz              【HTML】要素に対して class 属性を設定します
073 *       language           【TAG】タグ内部で使用する言語コード[ja/en/zh/…]を指定します
074 *       onClick            【HTML】JavaScriptのイベント onClick を設定します(例:onClick="renew('query.jsp','QUERY');")
075 *       onChange           【HTML】JavaScriptのイベント onChange を設定します(例:onChange="renew('query.jsp','QUERY');")
076 *       onBlur             【HTML】JavaScriptのイベント onBlur を設定します(例:onBlur="this.value=value.toUpperCase();")
077 *       onFocus            【HTML】JavaScriptのイベント onFocus を設定します
078 *       ondblClick         【HTML】JavaScriptのイベント ondblClick を設定します
079 *       onMouseDown        【HTML】JavaScriptのイベント onMouseDown を設定します
080 *       onMouseUp          【HTML】JavaScriptのイベント onMouseUp を設定します
081 *       onMouseMove        【HTML】JavaScriptのイベント onMouseMove を設定します
082 *       onMouseOut         【HTML】JavaScriptのイベント onMouseOut を設定します
083 *       onMouseOver        【HTML】JavaScriptのイベント onMouseOver を設定します
084 *       onSelect           【HTML】JavaScriptのイベント onSelect を設定します
085 *       onKeydown          【HTML】JavaScriptのイベント onKeydown を設定します
086 *       onKeypress         【HTML】JavaScriptのイベント onKeypress を設定します
087 *       onKeyup            【HTML】JavaScriptのイベント onKeyup を設定します
088 *       autofocus          【HTML5】指定した入力欄にカーソルが当たって自動的にフォーカスされます。
089 *       roles              【TAG】ロールをセットします
090 *       eventColumn        【TAG】イベントカラム(親カラム)を指定します
091 *       eventURL           【TAG】イベントカラム指定時に呼び出すURL
092 *       eventCallback      【TAG】eventColumn実行後のcallbak関数指定
093 *       debug              【TAG】デバッグ情報を出力するかどうか[true/false]を指定します(初期値:false)
094 *   >   ... Body ...
095 *   </og:select>
096 *
097 * ●使用例
098 *    <og:select name="CDC">                       CodeResource プロパティの値を使用したいときはcode属性を使います。
099 *        <og:option code="CDC" />
100 *    </og:select>
101 *
102 *    <og:select name="CDC">                       選択項目の一番上に項目を付け足すことも可能です。
103 *        <og:option lbl="MSG0001" />              MessageResource プロパティの値を使用したいとききはlbl属性を使います。
104 *        <og:option code="CDC" />
105 *    </og:select>
106 *
107 *    <og:select name="CDC">                       選択項目の一番上に項目を付け足すことも可能です。
108 *        <og:option lbl="CDC1" />                 LabelResource プロパティの値を使用したいとききはlbl属性を使います。
109 *        <og:option code="CDC" />
110 *    </og:select>
111 *
112 *    <og:select name="CDC" multiple="multiple">   選択肢の中から複数選択できるようにするときはmultiple属性を使います。
113 *        <og:option code="CDC" />
114 *    </og:select>
115 *
116 *    <og:select name="CDC" disabled="disabled">   選択不可にするときはdisabled属性を使います。
117 *        <og:option code="CDC" />
118 *    </og:select>
119 *
120 *    <og:select name="CDC">                       選択肢をSELECT文の結果から作成したいときはqueryOptionタグと組み合わせて使います。
121 *        <og:queryOption>
122 *                    select NOSYN,NOSYN,':',NMSYN from DB01 ORDER BY 1
123 *        </og:queryOption>
124 *    </og:select>
125 *
126 *    <og:select name="CDC" eventColumn="OYA" >    親子関係のプルダウンを作る場合
127 *        <og:queryOption>
128 *                    select NOSYN,NOSYN,':',NMSYN from DB01
129 *                     where CLM = "{@OYA}" ORDER BY 1
130 *        </og:queryOption>
131 *    </og:select>
132 *
133 * @og.group 選択データ制御
134 *
135 * @version  4.0
136 * @author       Kazuhiko Hasegawa
137 * @since    JDK5.0,
138 */
139public class SelectTag extends HTMLTagSupport implements OptionAncestorIF {
140        //* このプログラムのVERSION文字列を設定します。   {@value} */
141        private static final String VERSION = "5.7.1.0 (2013/12/06)" ;
142
143        private static final long serialVersionUID = 571020131206L ;
144
145        // 4.0.0 (2005/01/31) HTML_LABEL_SEPARATOR を boolean 変数として取得します。
146        private final String CLM = ( HybsSystem.sysBool( "HTML_LABEL_SEPARATOR" ) ) ? ":" : "" ;
147
148        // 4.0.0 (2005/01/31) USE_MULTI_KEY_SELECT を定義しておきます。
149        private final boolean USE_MULTI_KEY_SELECT =  HybsSystem.sysBool( "USE_MULTI_KEY_SELECT" ) ;
150
151        // 4.3.6.0 (2009/04/01) JSPの位置を取っておく
152//      private static final String JSP = HybsSystem.sys( "JSP" );
153
154        private transient Options option                = new Options();
155        private String  td_flag         = "yes";        // yes:<td> タグを使用 / false:フィールドのみ / no:ラベルとフィールド
156
157        // 3.0.1.3 (2003/03/11) colspan 属性を追加。
158        private String  colspan     = null;
159
160        // 3.5.4.0 (2003/11/25) value ,defaultVal  属性を追加。
161        private String  value       = null;
162        private String  defaultVal      = null;         // value がセットされていないときの初期値
163        private boolean multipleAll     = false;        // 3.8.0.9 (2005/10/17) 複数選択可能時に全選択を設定する。
164        private String eventColumn      = null;         // 4.3.6.0 (2009/04/01) イベントカラム
165//      private String eventURL         = JSP + "/" + HybsSystem.sys( "EVENT_COLUMN_URL" ); // 4.3.6.0 (2009/04/01) 処理JSPの設定
166        private String eventURL         = null;         // 5.1.9.0 (2010/08/01) 動的プルダウン不具合対応
167
168        // 4.1.2.1 (2008/03/13) must , mustAny 属性を自動化します。
169        // 5.2.1.0 (2010/10/01) must , mustAny 属性の処理を、HTMLTagSupport に移します。
170//      private String  mustType        = null;         // 4.1.2.1 (2008/03/13)
171
172        private String  rawParam        = null;         // 5.1.7.0 (2010/06/01) 動的プルダウン実装見直し
173
174        // 5.1.9.0 (2010/08/01) 値なしのOptionをSelectに含めるかどうか 新規追加
175        private boolean addNoValue  = false;    // 互換性のため、初期値は、false になります。
176
177        /**
178         * Taglibの開始タグが見つかったときに処理する doStartTag() を オーバーライドします。
179         *
180         * @og.rev 5.0.2.0 (2009/11/01) 複数パラメーターの選択に対応
181         * @og.rev 5.1.7.0 (2010/06/01) command=RENEWの場合はdefaultValを無視する。
182         * @og.rev 5.1.9.0 (2010/08/01) addNoValue 対応
183         * @og.rev 5.2.2.0 (2010/11/01) caseKey 、caseVal 属性対応
184         * @og.rev 5.3.7.0 (2011/07/01) 5.1.7.0 (2010/06/01)の対応で判定条件が逆転しているバグを修正
185         *
186         * @return      後続処理の指示( EVAL_BODY_INCLUDE )
187         */
188        @Override
189        public int doStartTag() {
190                // 5.2.2.0 (2010/11/01) caseKey 、caseVal 属性対応
191                if( useTag() ) {
192                        if( value == null ) {
193        //                      value = nval( getRequestValue( get( "name" ) ),defaultVal );
194                                // 5.1.7.0 (2010/06/01) command=RENEWの場合はdefaultValを無視する。
195                                String cmd = pageContext.getRequest().getParameter( "command" );
196                                if( "RENEW".equals( cmd ) ) {
197                                        value = StringUtil.array2line( getRequestValues( get( "name" ) ), "|" );
198                                }
199                                else {
200                                        value = nval( StringUtil.array2line( getRequestValues( get( "name" ) ), "|" ),defaultVal );
201                                }
202                        }
203
204                        // 5.1.9.0 (2010/08/01) addNoValue 対応:option を最初にセットする。
205                        if( addNoValue ) {
206                                option.add( "<option value=\"\" ></option>" );
207                        }
208
209                        return( EVAL_BODY_INCLUDE );    // Body インクルード( extends TagSupport 時)
210                }
211                return ( SKIP_BODY );                           // Body を評価しない
212        }
213
214        /**
215         * タグリブオブジェクトをリリースします。
216         * キャッシュされて再利用されるので、フィールドの初期設定を行います。
217         *
218         * @og.rev 2.0.0.4 (2002/09/27) カスタムタグの release() メソッドを、追加
219         * @og.rev 2.0.0.8 (2002/10/09) yes/no/false で指定するように変更
220         * @og.rev 3.0.1.3 (2003/03/11) colspan 属性を追加。
221         * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。release2() を doEndTag()で呼ぶ。
222         * @og.rev 3.5.4.0 (2003/11/25) value ,defaultVal  属性を追加。
223         * @og.rev 3.8.0.9 (2005/10/17) 複数選択可能時に全選択を設定する。
224         * @og.rev 4.1.2.1 (2008/03/13) must , mustAny 属性を自動化します。
225         * @og.rev 4.3.6.0 (2009/04/01) eventColumn,eventURL追加
226         * @og.rev 5.1.7.0 (2010/06/01) 動的プルダウン実装見直し
227         * @og.rev 5.1.9.0 (2010/08/01) columnタグで動的プルダウンが動作しない不具合に対応
228         * @og.rev 5.1.9.0 (2010/08/01) addNoValue  属性を追加。
229         * @og.rev 5.2.1.0 (2010/10/01) must , mustAny 属性の処理を、HTMLTagSupport に移します。
230         *
231         */
232        @Override
233        protected void release2() {
234                super.release2();
235                option          = new Options();
236                td_flag     = "yes";    // table形式の <td> タグを使用するかどうか
237                colspan     = null;
238                value       = null;
239                defaultVal      = null;         // value がセットされていないときの初期値
240                multipleAll     = false;        // 3.8.0.9 (2005/10/17) 複数選択可能時に全選択を設定する。
241//              mustType        = null;         // 4.1.2.1 (2008/03/13)         // HTMLTagSupport に移します。
242                eventColumn     = null;         // 4.3.6.0 (2009/04/01)
243//              eventURL        = JSP + "/" + HybsSystem.sys( "EVENT_COLUMN_URL" ); // 4.3.6.0 (2009/04/01)
244                eventURL        = null;         // 5.1.9.0 (2010/08/01) columnタグで動的プルダウンが動作しない不具合に対応
245                rawParam        = null;         // 5.1.7.0 (2010/06/01) 動的プルダウン実装見直し
246                addNoValue  = false;    // 5.1.9.0 (2010/08/01) 互換性のため、初期値は、false になります。
247        }
248
249        /**
250         * 入力用のプルダウンメニューを作成します。
251         *
252         * 表示順の項目名タグは、あらかじめ作成済みの値をここでは受け取ります。
253         * hasSelect 属性の値に応じて,タグの作成方法は変わります。
254         *
255         * @og.rev 2.0.0.8 (2002/10/09) yes/no/false で指定するように変更
256         * @og.rev 2.0.1.0 (2002/10/10) ラベルとフィールドのセパレーターとして、コロン(:)を使用するかどうかを指定できる
257         * @og.rev 3.0.1.3 (2003/03/11) colspan 属性を追加。
258         * @og.rev 3.5.4.0 (2003/11/25) value ,defaultVal  属性を追加。
259         * @og.rev 4.0.0.0 (2005/01/31) マルチセレクションのON/OFFをここで指定。
260         * @og.rev 4.1.2.1 (2008/03/13) must , mustAny 属性を自動化します。
261         * @og.rev 4.3.6.0 (2009/04/01) eventColumn対応
262         * @og.rev 4.3.7.1 (2009/06/08) id=labelのclass化
263         * @og.rev 5.1.7.0 (2010/06/01) 動的プルダウン実装見直し
264         * @og.rev 5.2.1.0 (2010/10/01) must , mustAny 属性の処理を、HTMLTagSupport に移します。
265         * @og.rev 5.5.3.0 (2012/06/01) idのセット見直し
266         * @og.rev 5.6.2.2 (2013/03/15) 自動must処理の出力位置を変更
267         *
268         * @return      表示順選択用のプルダウンメニュータグ
269         */
270        @Override
271        protected String makeTag() {
272
273                String name = get( "name" );
274                if( getMsglbl() == null ) { setLbl( name ); }
275
276                if( colspan != null ) {
277                        colspan = " colspan=\"" + colspan + "\" ";
278                }
279                else {
280                        colspan = "";
281                }
282
283                // 4.0.0 (2005/01/31) XHTMLTag.java より移動)
284                if( USE_MULTI_KEY_SELECT ) {
285                        set( "onkeydown", "setKeySelect(this);" );
286                }
287
288                StringBuilder rtn = new StringBuilder( HybsSystem.BUFFER_MIDDLE );
289
290                // 5.5.3.0 既にIDが指定されている場合はnameをセットしない
291                if( get("id")==null || get("id").length() == 0 ){
292                        set( "id", name );
293                }
294
295                // 4.3.6.0 (2009/04/01) eventColumnの対応
296                // 5.1.7.0 (2010/06/01) 動的プルダウン実装見直し
297//              if( eventColumn != null && eventColumn.length() > 0 ) {
298//                      String[] evntCols = StringUtil.csv2Array( eventColumn );
299//                      for( int i = 0; i < evntCols.length; i++ ) {
300//                              // SelectTagは"DBMENU"をmakeColumnに渡す。
301//                              String javaScript =
302//                                      "<script type=\"text/javascript\">" +
303//                                      "$(function(){$('#" + evntCols[i] + "').change(function(){" +
304//                                      "makeColumn('" + name + "','" + name + "',EC_" + name + ",'DBMENU','" + eventURL + "');}).change();});"+
305//                                      "</script>"
306//                                      ;
307//                              rtn.append( javaScript );
308//                      }
309//              }
310
311                String selTag = XHTMLTag.select( getAttributes(), option );
312
313                // 5.1.7.0 (2010/06/01) 動的プルダウン実装見直し
314                if( eventColumn != null && eventColumn.length() > 0 ) {
315                        String editor = null;
316                        if( rawParam != null && rawParam.length() > 0 ) {
317                                editor = "DBMENU";
318                        }
319                        else {
320                                editor = "MENU";
321                        }
322                        addEventColumn( name, eventColumn, eventURL, "", editor, "", rawParam );
323                        TagBuffer span = new TagBuffer( "span" );
324                        span.add( "class", HybsSystem.EVENT_COLUMN_CLASS );
325                        span.add( HybsSystem.EVENT_COLUMN_ID, name );
326                        span.add( HybsSystem.EVENT_COLUMN_INITVAL, value );
327                        span.add( HybsSystem.EVENT_COLUMN_WRITABLE, "true" );
328                        span.setBody( selTag );
329                        selTag = span.makeTag();
330                }
331
332                if( "yes".equals( td_flag ) ) {
333                        // 4.3.7.1 (2009/06/08) id=labelのclass化
334                        // rtn.append( "<td id=\"label\">" );
335                        rtn.append( "<td class=\"label\">" );
336                        rtn.append( getLongLabel() );           // 4.0.0 (2005/01/31)
337                        rtn.append( CLM );
338                        rtn.append( "</td>" );
339                        rtn.append( "<td" );
340                        rtn.append( colspan );
341                        rtn.append( ">" );
342//                      rtn.append( XHTMLTag.select( getAttributes(), option ) );
343                        rtn.append( selTag );
344                        if( getMustType() != null ) { rtn.append( makeMustHidden( name ) ); } // 5.6.2.2 (2013/03/15)
345                        rtn.append( "</td>" );
346                }
347                else if( "no".equals( td_flag ) ) {
348                        // 4.3.7.1 (2009/06/08) id=labelのclass化
349                        // rtn.append( "<span id=\"label\">" );
350                        rtn.append( "<span class=\"label\">" );
351                        rtn.append( getLongLabel() );           // 4.0.0 (2005/01/31)
352                        rtn.append( CLM );
353                        rtn.append( "</span>" );
354//                      rtn.append( XHTMLTag.select( getAttributes(), option ) );
355                        rtn.append( selTag );
356                        if( getMustType() != null ) { rtn.append( makeMustHidden( name ) ); } // 5.6.2.2 (2013/03/15)
357                }
358                else {
359//                      rtn.append( XHTMLTag.select( getAttributes(), option ) );
360                        rtn.append( selTag );
361                        if( getMustType() != null ) { rtn.append( makeMustHidden( name ) ); } // 5.6.2.2 (2013/03/15)
362                }
363
364                // 4.1.2.1 (2008/03/13) must , mustAny 属性を自動化します。
365//              if( mustType != null ) {
366//                      rtn.append( XHTMLTag.hidden( HybsSystem.MUST_KEY + mustType, name ) );
367//              }
368                // 5.2.1.0 (2010/10/01) must , mustAny 属性を自動化します。
369                // 5.6.2.2 (2013/03/15) tdの外に出力される不正形を正します
370//              if( getMustType() != null ) { rtn.append( makeMustHidden( name ) ); }
371
372                return rtn.toString() ;
373        }
374
375        /**
376         * メニュー項目の選択項目を追加します。
377         *
378         * select タグのBODY要素の OptionTag よりアクセスされます。
379         *
380         * @og.rev 3.1.2.0 (2003/04/07) taglib パッケージ内部で使用している箇所を protected 化する。
381         * @param       opt      オプションタグ文字列
382         */
383        public void addOption( final String opt ) {
384                option.add( opt );
385        }
386
387        /**
388         * 【TAG】メニューの名称を指定します。
389         *
390         * @og.tag メニューの名称を指定します。
391         *
392         * @param       name 名称
393         */
394        public void setName( final String name ) {
395                set( "name", getRequestParameter( name ) );
396        }
397
398        /**
399         * 【TAG】リストボックスとして表示する場合の表示行数を指定します。
400         *
401         * @og.tag 表示行数を指定します。
402         *
403         * @param       size 表示行数
404         */
405        public void setSize( final String size ) {
406                set( "size",getRequestParameter( size ) );
407        }
408
409        /**
410         * 【TAG】複数選択を可能(multiple)にします(初期値:未設定)。
411         *
412         * @og.tag
413         * multiple 値が "multiple" または "true" の場合、複数選択状態になります。
414         * また、"ALL" を設定する場合は、OptionTag上で、すべてのOption が選択状態に
415         * 初期設定されます。
416         * 大文字、小文字の種別はなくしますが、指定以外の文字が設定された場合は、エラーになります。
417         *
418         * @og.rev 3.8.0.9 (2005/10/17) 複数選択可能時に全選択を設定する。
419         *
420         * @param       multi 複数選択("multiple" または "true") ,初期値全選択( "ALL" )
421         */
422        public void setMultiple( final String multi ) {
423                String multiple = nval( getRequestParameter( multi ),null );
424                if( "multiple".equalsIgnoreCase( multiple ) || "true".equalsIgnoreCase( multiple ) ) {
425                        set( "multiple","multiple" );
426                }
427                else if( "ALL".equalsIgnoreCase( multiple ) ) {
428                        set( "multiple","multiple" );
429                        multipleAll = true;
430                }
431                else if( ! ( "false".equalsIgnoreCase( multiple ) || multiple == null ) ) {
432                        String errMsg = "multiple 属性には、[multiple,true,ALL] 以外は設定できません。"
433                                                + "multiple=" + multi ;
434                        throw new HybsSystemException( errMsg );
435                }
436        }
437
438        /**
439         * 【TAG】必須入力を表す色に変えるかどうか[true/false]指定します(初期値:false)。
440         *
441         * @og.tag
442         * 初期値は、必須でない("false") です。
443         *
444         * @og.rev 4.0.0.0 (2005/02/28) must属性の登録を、id属性から、class 属性に変更します。
445         * @og.rev 4.1.2.1 (2008/03/13) must属性を自動化します。
446         * @og.rev 5.2.1.0 (2010/10/01) must , mustAny 属性の処理を、HTMLTagSupport に移します。
447         *
448         * @param       flag 必須入力 ("true")/必須でない (それ以外)
449         */
450//      public void setMust( final String flag ) {
451////            boolean must = nval( getRequestParameter( flag ),false );
452//              mustType = nval( getRequestParameter( flag ),null );
453//              if( "true".equalsIgnoreCase( mustType ) ) {
454//                      mustType = "must";
455//                      add( "class","must" );
456//              }
457//      }
458
459        /**
460         * 【TAG】選択必須入力(どれかひとつ必須)を表す色(true|mustAny|その他)を指定します(初期値:無指定)。
461         *
462         * @og.tag
463         * 複数のカラムのうち、どれかひとつを必須とする選択必須入力を示す色を指定します。
464         * true または、mustAny を設定すると、class属性に、mustAny がセットされます。
465         * mustAny は、CSSファイルに初期設定されています。true または、mustAny 以外の値をセット
466         * すると、その値がそのまま、class属性にセットされますので、選択必須のグループ化が
467         * 可能です。
468         * なお、実際の選択必須入力チェックは、ここではなく、columnCheck タグで指定が必要です。
469         * 自動処理は、mustAny="true" 指定の場合のみ有効です。
470         * 初期値は、無指定です。
471         *
472         * @og.rev 3.8.0.9 (2005/10/17) 新規追加
473         * @og.rev 4.1.2.1 (2008/03/13) mustAny属性を自動化します。
474         * @og.rev 5.2.1.0 (2010/10/01) must , mustAny 属性の処理を、HTMLTagSupport に移します。
475         *
476         * @param       flag 選択必須入力(どれかひとつ必須)を表す色を指定(true|mustAny|その他)
477         */
478//      public void setMustAny( final String flag ) {
479//              if( mustType == null ) {        // must 属性と同時設定時には、must 属性を優先します。
480//                      mustType = nval( getRequestParameter( flag ),null );
481//                      if( "true".equalsIgnoreCase( mustType ) ) {
482//                              mustType = "mustAny";
483//                      }
484//                      add( "class",mustType );        // mustType == null の場合は、add されません。
485//              }
486//
487////            String str = nval( getRequestParameter( flag ),null );
488////            if( str != null ) {
489////                    if( str.equalsIgnoreCase( "true" ) ) {
490////                            add( "class","mustAny" );
491////                    }
492////                    else {
493////                            add( "class",str );
494////                    }
495////            }
496//      }
497
498        /**
499         * 【TAG】テーブル形式の &lt;td&gt; タグを使用するかどうか[yes/no/false]を指定します(初期値:yes)。
500         *
501         * @og.tag
502         * 初期値は、使用する("yes") です。
503         *
504         * @og.rev 2.0.0.8 (2002/10/09) yes/no/false で指定するように変更
505         * @og.rev 5.5.1.0 (2012/04/03) エラーメッセージ変更
506         *
507         * @param   flag [yes:tdタグを使用/no:ラベルとフィールド/false:フィールドのみ]
508         */
509        public void setTd( final String flag ) {
510                String td = nval( getRequestParameter( flag ),td_flag );
511
512                if( check( "|" + td + "|" , "|yes|no|false|" ) ) {
513                        td_flag = td;
514                }
515                else {
516                        String errMsg = "Error in SelectTag [td]: " + td;
517                        //errMsg = errMsg + "  in [|true|false|label|] only used";
518                        errMsg = errMsg + "  in [|yes|no|false|] only used"; // 5.5.1.0 (2012/04/03)
519                        throw new HybsSystemException( errMsg );
520                }
521        }
522
523        /**
524         * 【TAG】フィールド部分の colspan を指定します。
525         *
526         * @og.tag
527         * 通常は、3 を指定して、フィールド、ラベル、フィールドの
528         * 組み合わせ部分に、長いフィールドが適用されるように使用します。
529         *
530         *  &lt;og:select name="CDK" colspan="3" /&gt;
531         *
532         * @og.rev 3.0.1.3 (2003/03/11) colspan 属性を追加。
533         *
534         * @param   sp フィールド部分の colspan
535         */
536        public void setColspan( final String sp ) {
537                colspan = nval( getRequestParameter( sp ),colspan );
538        }
539
540        /**
541         * 【TAG】値を指定します。
542         *
543         * @og.tag
544         *   ここで指定された値が、optionタグの値と同じであれば、選択状態になります。
545         *
546         *    &lt;og:select name="CDC" value="{&#064;ABC}" defaultVal="XYZ"  &gt;
547         *         &lt;og:option value="ABC" lbl="CDC1" /&gt;
548         *         &lt;og:option value="XYZ" lbl="CDC2" /&gt;
549         *    &lt;/og:select&gt;
550         *
551         * @og.rev 3.5.4.0 (2003/11/25) 新規作成
552         * @og.rev 5.0.2.0 (2009/11/01) 複数パラメーターの選択に対応
553         *
554         * @param   val 値
555         */
556        public void setValue( final String val ) {
557//              value = nval( getRequestParameter( val ),value );
558                value = nval( StringUtil.array2line( getRequestParameterValues( val ), "|" ),value );
559        }
560
561        /**
562         * 値を外部から取り出します。
563         *
564         * OptionTag で、value を取り出して、内部の値と同じ場合は、選択状態にします。
565         *
566         * @og.rev 3.5.4.0 (2003/11/25) 新規作成
567         * @og.rev 5.7.1.0 (2013/12/06) OptionAncestorIF にする為、protected ⇒ public 化する。
568         *
569         * @return      内部に設定された値
570         */
571//      protected String getValue() {
572        public String getValue() {
573                return value;
574        }
575
576//      /**
577//       * 親のカラムを取得
578//       *
579//       * QueryOptiontagで、eventColumnを取り出して生SQL文の
580//       * セッションへの登録判断をします
581//       *
582//       * @og.rev 4.3.6.0 (2009/04/01)
583//       *
584//       * @return イベントカラム
585//       */
586//      protected String getEventColumn() {
587//              return eventColumn;
588//      }
589
590        /**
591         * 【TAG】イベントカラム(親カラム)を指定します。
592         *
593         * @og.tag
594         *   親子関係のカラムを作成する場合に利用します。
595         *   queryOptionタグとセットで利用して下さい。
596         *
597         *   ※詳細はcolumnTagのeventColumn属性の説明をご覧下さい。
598         *
599         * @og.rev 4.3.6.0 (2009/04/01)
600         *
601         * @param   col 親カラム名
602         */
603        public void setEventColumn( final String col ) {
604                eventColumn = nval( getRequestParameter( col ), eventColumn );
605        }
606
607        /**
608         * 【TAG】イベントカラム指定時に呼び出すURL。
609         *
610         * @og.tag
611         *   イベントカラム指定時に部品を作成するJSPを指定します。
612         *   初期値はシステムリソースのEVENT_COLUMN_URLです。
613         *   (例:eventURL="makeColumn_custom.jsp")
614         *
615         *   ※詳細はcolumnTagのeventURL属性の説明をご覧下さい。
616         *
617         * @og.rev 4.3.6.0 (2009/04/01)
618         *
619         * @param       url     呼び出すURL
620         */
621        public void setEventURL( final String url ) {
622                eventURL = nval( getRequestParameter( url ), eventURL );
623        }
624
625        /**
626         * 複数選択可能時に全選択を設定するかどうかを返します。
627         *
628         * これは、上位入れ子のタグの OptionTag で、multipleAll を取り出して、
629         * true であれば、全選択に設定します。
630         *
631         * @og.rev 3.8.0.9 (2005/10/17) 新規作成
632         * @og.rev 5.7.1.0 (2013/12/06) OptionAncestorIF にする為、protected ⇒ public 化する。
633         *
634         * @return      全選択:true / 通常:false
635         */
636//      protected boolean isMultipleAll() {
637        public boolean isMultipleAll() {
638                return multipleAll;
639        }
640
641        /**
642         * 【TAG】value属性に値がセットされていないとき使用する、初期値を指定します。
643         *
644         * @og.tag
645         * value属性に値がセットされていないときに、初期値をセットします。
646         *
647         * なお、commandがRENEWの場合は、このdefaultValは適用されません。
648         * これは、defaultValの値が埋め込まれた項目が存在する画面に戻った際に、
649         * defaultValの項目の値がnullとなっていた場合に、defaultValの値が復元されると、
650         * 検索結果との不一致が発生するためです。
651         *
652         * @og.rev 3.5.4.0 (2003/11/25) 新規作成
653         * @og.rev 5.0.2.0 (2009/11/01) 複数パラメーターの選択に対応
654         *
655         * @param       dv 初期値
656         */
657        public void setDefaultVal( final String dv ) {
658//              defaultVal = nval( getRequestParameter( dv ),defaultVal );
659                defaultVal = nval( StringUtil.array2line( getRequestParameterValues( dv ), "|" ),defaultVal );
660        }
661
662        /**
663         * 【TAG】値なしのOptionを含めるかどうか[true/false]を指定します(初期値:false)。
664         *
665         * @og.tag
666         * カラムがプルダウンメニュー形式の場合、選択肢には通常データベース登録できる候補が
667         * 並びます。しかし、検索時には、候補を絞りたくない(指定しない)場合があり、
668         * その様な場合には、値なしのOptionを含める(true)ことで、対応可能です。
669         * 初期値:false(値なしのOptionを含めない)は、過去の互換性を重視しているため、column タグと異なります。
670         *
671         * @og.rev 5.1.9.0 (2010/08/01) 新規追加
672         *
673         * @param   flag  [true:含める/それ以外:含めない]
674         */
675        public void setAddNoValue( final String flag ) {
676                addNoValue = nval( getRequestParameter( flag ),addNoValue );
677        }
678
679        /**
680         * パラメーター変換({&#064;XXXX}の置き換えをしない状態のパラメーターをセットします。
681         *
682         * @og.rev 5.1.7.0 (2010/06/01) 新規作成(動的プルダウン実装見直し)
683         * @og.rev 5.5.4.0 (2012/07/02) 予約語対応
684         *
685         * @param   param パラメーター
686         */
687        public void setRawParam( final String param ) {
688//              rawParam = nval( param, rawParam );
689                rawParam = nval( getReservedParameter(param), rawParam ); // 5.5.4.0 (2012/07/02)
690        }
691
692        /**
693         * 【TAG】eventColumn実行後のcallbak関数指定。
694         *
695         * @og.tag
696         * eventColumnの動作終了後に実行するCallback関数の指定を行います。
697         * 関数名のみを指定して下さい。
698         *  ex) sampleCallback()を実行する場合はeventCallback="sampleCallback"
699         * 実行する関数の第一引数には自動的に次の要素が入った配列が渡されます
700         *  [0] 変更された子カラムのID属性値
701         *  [1] evnetColumn実行後の子カラムの値
702         *  [2] eventColumn実行前の子カラムの値
703         *
704         * この属性は、optionAttributesへの設定と同様の動作を行います。
705         *
706         * @og.rev 5.5.4.0 (2012/07/02) 新規追加
707         *
708         * @param   callback callbak関数
709         */
710        public void setEventCallback( final String callback ) {
711                // optionAttributes扱いで登録します。
712                if( callback != null && callback.length() > 0 ){
713                        add( "optionAttributes", "eventCallback='"+getRequestParameter( callback )+"'" );
714                }
715        }
716
717        /**
718         * シリアライズ用のカスタムシリアライズ書き込みメソッド
719         *
720         * @og.rev 4.0.0.0 (2006/09/31) 新規追加
721         * @serialData 一部のオブジェクトは、シリアライズされません。
722         *
723         * @param       strm    ObjectOutputStreamオブジェクト
724         * @throws IOException  入出力エラーが発生した場合
725         */
726        private void writeObject( final ObjectOutputStream strm ) throws IOException {
727                strm.defaultWriteObject();
728        }
729
730        /**
731         * シリアライズ用のカスタムシリアライズ読み込みメソッド
732         *
733         * ここでは、transient 宣言された内部変数の内、初期化が必要なフィールドのみ設定します。
734         *
735         * @og.rev 4.0.0.0 (2006/09/31) 新規追加
736         * @serialData 一部のオブジェクトは、シリアライズされません。
737         *
738         * @param       strm    ObjectInputStreamオブジェクト
739         * @see #release2()
740         * @throws IOException  シリアライズに関する入出力エラーが発生した場合
741         * @throws ClassNotFoundException       クラスを見つけることができなかった場合
742         */
743        private void readObject( final ObjectInputStream strm ) throws IOException , ClassNotFoundException {
744                strm.defaultReadObject();
745                option = new Options();
746        }
747
748        /**
749         * このオブジェクトの文字列表現を返します。
750         * 基本的にデバッグ目的に使用します。
751         *
752         * @return このクラスの文字列表現
753         */
754        @Override
755        public String toString() {
756                return org.opengion.fukurou.util.ToString.title( this.getClass().getName() )
757                                .println( "VERSION"             ,VERSION                )
758                                .println( "td_flag"             ,td_flag                )
759                                .println( "colspan"             ,colspan                )
760                                .println( "value"               ,value                  )
761                                .println( "defaultVal"  ,defaultVal             )
762                                .println( "multipleAll" ,multipleAll    )
763                                .println( "Other..."    ,getAttributes().getAttribute() )
764                                .fixForm().toString() ;
765        }
766}