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 org.opengion.fukurou.util.TagBuffer;                                             // 6.1.1.0 (2015/01/17)
019import org.opengion.fukurou.util.XHTMLTag;
020import org.opengion.fukurou.util.ToString;                                              // 6.1.1.0 (2015/01/17)
021import org.opengion.hayabusa.common.HybsSystem;
022import org.opengion.hayabusa.common.HybsSystemException;                // 6.4.0.5 (2016/01/09)
023import org.opengion.hayabusa.db.DBColumn;
024import org.opengion.hayabusa.db.DBEditConfig;
025// import org.opengion.hayabusa.db.DBEditConfigManager;                 // 6.4.5.0 (2016/04/08) , 6.9.2.1 (2018/03/12) 廃止
026
027import static org.opengion.fukurou.util.StringUtil.nval;
028
029/**
030 * query.jsp での検索ボタンを表示します。
031 * 検索ボタン以外に、pageSize、maxRowCount、prevNext、timeView などの
032 * 項目も表示可能です。
033 * また、BODY部に登録した値は、table 要素として、td 部に追記されます。
034 *
035 * @og.formSample
036 * ●形式:<og:queryButton />
037 * ●body:あり(EVAL_BODY_BUFFERED:BODYを評価し、{@XXXX} を解析します)
038 *
039 * ●Tag定義:
040 *   <og:queryButton
041 *       command            【TAG】リクエストとして送信するコマンドを指定します(初期値:NEW)
042 *       pageSize           【TAG】pageSize プルダウンメニューの初期値を指定します (初期値:HTML_PAGESIZE[=100])
043 *       maxRowCount        【TAG】maxRowCount プルダウンメニューの初期値を指定します (初期値:DB_MAX_ROW_COUNT[=1000])
044 *       type               【TAG】典型的なボタンの形状に設定します(初期値:null)
045 *       scope              【TAG】リクエストとして送信するスコープを指定します(初期値:null)
046 *       lbl                【TAG】ラベルリソースのラベルIDを指定します
047 *       accesskey          【TAG】検索ボタンに使用するショートカットキー文字を指定します(初期値:F)
048 *       usePrevNext        【TAG】進む/戻るのprev_next リンクを表示するかどうかを指定します(初期値:true)
049 *       usePageSize        【TAG】pageSize 引数を使用するかどうかを指定します(初期値:true)
050 *       useRowCount        【TAG】maxRowCount 引数を使用するかどうかを指定します(初期値:true)
051 *       useTimeView        【TAG】処理時間を表示する TimeView を表示するかどうかを指定します
052 *                                                                              (初期値:VIEW_USE_TIMEBAR[={@og.value SystemData#VIEW_USE_TIMEBAR}])。
053 *       clearAccesskey     【TAG】クリアボタンに使用するショートカットキー文字を指定します(初期値:C)
054 *       useDummy           【TAG】IE用ダミーinputを出力するかどうか
055 *       useEditMenu        【TAG】編集プルダウンを出すかどうか(初期値:true)
056 *       blockUIMsg         【TAG】検索中表示を画面上に表示するメッセージリソースIDを指定します (初期値:MSG0090(検索中です・・・)) 6.4.8.0 (2016/06/24) 
057 *       useClear           【TAG】JavaScriptによる初期化(クリア)ボタンを使用するかどうか[true/false/none]を指定します(初期値:true) 6.4.3.4 (2016/03/11) 
058 *       clearTarget        【TAG】useCrear=true時のターゲット名(フレーム名)を指定します(初期値:QUERY) 5.9.21.1 (2017/06/16)  。
059 *       clearHref          【TAG】useCrear=true時の遷移先JSPを指定します(初期値:query.jsp) 5.9.21.1 (2017/06/16)。
060 *       clearCommand       【TAG】useCrear=true時のcommandを指定します(初期値:NEW) 5.9.21.1 (2017/06/16) 。
061 *       title              【HTML】要素に対する補足的情報(title)を設定します
062 *       style              【HTML】この要素に対して適用させるスタイルシート(style)を設定します
063 *       disabled           【HTML】その部品に対して、選択や変更が出来ないように(disabled)指定します(サーバーに送信されない)
064 *       tabindex           【HTML】タブの移動順(tabindex)を指定します(0 ~ 32767)
065 *       clazz              【HTML】要素に対して class 属性を設定します
066 *       onClick            【HTML】JavaScriptのイベント onClick を設定します(例:onClick="renew('query.jsp','QUERY');")
067 *       onBlur             【HTML】JavaScriptのイベント onBlur を設定します(例:onBlur="this.value=value.toUpperCase();")
068 *       onFocus            【HTML】JavaScriptのイベント onFocus を設定します
069 *       ondblClick         【HTML】JavaScriptのイベント ondblClick を設定します
070 *       onMouseDown        【HTML】JavaScriptのイベント onMouseDown を設定します
071 *       onMouseUp          【HTML】JavaScriptのイベント onMouseUp を設定します
072 *       onMouseMove        【HTML】JavaScriptのイベント onMouseMove を設定します
073 *       onMouseOut         【HTML】JavaScriptのイベント onMouseOut を設定します
074 *       onMouseOver        【HTML】JavaScriptのイベント onMouseOver を設定します
075 *       autofocus          【HTML5】指定した入力欄にカーソルが当たって自動的にフォーカスされます。
076 *       caseKey            【TAG】このタグ自体を利用するかどうかの条件キーを指定します(初期値:null)
077 *       caseVal            【TAG】このタグ自体を利用するかどうかの条件値を指定します(初期値:null)
078 *       caseNN             【TAG】指定の値が、null/ゼロ文字列 でない場合(Not Null=NN)は、このタグは使用されます(初期値:判定しない)
079 *       caseNull           【TAG】指定の値が、null/ゼロ文字列 の場合は、このタグは使用されます(初期値:判定しない)
080 *       caseIf             【TAG】指定の値が、true/TRUE文字列の場合は、このタグは使用されます(初期値:判定しない)
081 *       debug              【TAG】デバッグ情報を出力するかどうか[true/false]を指定します(初期値:false)
082 *   >   ... Body ...
083 *   </og:queryButton>
084 *
085 * ●使用例
086 *    <og:queryButton
087 *        command     = "NEW"      NEW:通常の検索(初期値)/ENTRY:エントリ登録時
088 *        type        = "ENTRY"    null:標準 , SELECT:検索ボタンのみ , ENTRY:登録ボタンのみ
089 *        pageSize    = "100"      pageSize の初期値設定(初期値:HTML_PAGESIZE)
090 *        maxRowCount = "100"      maxRowCount の初期値設定(初期値:DB_MAX_ROW_COUNT)
091 *        useClear    = "true"     true:JavaScriptによる初期化(クリア)/false:通常のresetボタン/none:表示しない
092 *        scope       = "request"  null(初期値)/session:セッション登録/request:リクエスト登録
093 *        lbl         = "MSG0010"  検索ボタンに表示するメッセージID(初期値:MSG0010)
094 *        accesskey   = "F"        ショートカットキー文字(初期値:F)
095 *        usePrevNext = "true"     Prev-Nextリンクを使用するかどうか(初期値:true)
096 *        usePageSize = "true"     pageSize 引数を使用するかどうか(初期値:true)
097 *        useRowCount = "true"     maxRowCount 引数を使用するかどうか(初期値:true)
098 *        useTimeView = "true"     timeView表示(実行時間表示)を使用するかどうか(初期値:VIEW_USE_TIMEBAR)
099 *        useEditMenu = "true"     編集プルダウンを出すかどうか(初期値:true)
100 *    />
101 *
102 *  標準的な検索ボタン
103 *    <og:queryButton />
104 *
105 *  標準的な登録ボタン(command="NEW" で、query.jsp で使用するボタン)
106 *    <og:queryButton type="ENTRY" />
107 *
108 *  BODY 部に追加要素を表示
109 *    <og:queryButton >
110 *        <td><jsp:directive.include file="/jsp/common/timeViewImage.jsp" /></td>
111 *    </og:queryButton >
112 *
113 * @og.rev 4.0.0.0 (2005/01/31) 新規作成
114 * @og.rev 5.7.1.0 (2013/12/06) HTMLTagSupport を継承し、ボタンに付ける属性を増やします。
115 * @og.group 画面制御
116 *
117 * @version  4.0
118 * @author   Kazuhiko Hasegawa
119 * @since    JDK5.0,
120 */
121public class QueryButtonTag extends HTMLTagSupport {
122        /** このプログラムのVERSION文字列を設定します。   {@value} */
123        private static final String VERSION = "6.9.2.1 (2018/03/12)" ;
124        private static final long serialVersionUID = 692120180312L ;
125
126        private static final String COMMAND     =
127                "<input type=\"hidden\" name=\"command\" value=\"NEW\" id=\"h_cmd\" />";
128
129        private static final String JSP = HybsSystem.sys( "JSP" );
130
131        // 4.2.1.0 (2008/04/07) TDにIDを追加
132        // 4.3.1.0 (2008/09/03) 戻る・進むボタンをsubmitにより実行する。
133        // 6.0.2.4 (2014/10/17) img タグに、title 属性追記
134        private static final String PREV_NEXT =
135                "<td id=\"prev-next\"><a href=\"forward.jsp?command=FIRST\" target=\"RESULT\" >"                + CR +
136                "  <img src=\"" + JSP + "/image/FIRST.gif\" alt=\"FIRST\" title=\"FIRST\" border=\"0px\" " + CR +
137                "    onclick=\"return submitPrevNextForm('FIRST');\"/>" + CR +
138                "</a>"                                                                                                                          + CR +
139                "<a href=\"forward.jsp?command=PREV\" target=\"RESULT\" >"                      + CR +
140                "  <img src=\"" + JSP + "/image/PREV.gif\" alt=\"PREV\" title=\"PREV\" border=\"0px\" " + CR +
141                "    onclick=\"return submitPrevNextForm('PREV');\"/>"  + CR +
142                "</a>"                                                                                                                          + CR +
143                "<a href=\"forward.jsp?command=NEXT\" target=\"RESULT\" >"                      + CR +
144                "  <img src=\"" + JSP + "/image/NEXT.gif\" alt=\"NEXT\" title=\"NEXT\" border=\"0px\" " + CR +
145                "    onclick=\"return submitPrevNextForm('NEXT');\"/>"  + CR +
146                "</a>"                                                                                                                          + CR +
147                "<a href=\"forward.jsp?command=LAST\" target=\"RESULT\" >"                      + CR +
148                "  <img src=\"" + JSP + "/image/LAST.gif\" alt=\"LAST\" title=\"LAST\" border=\"0px\" " + CR +
149                "    onclick=\"return submitPrevNextForm('LAST');\"/>"  + CR +
150                "</a></td>" + CR ;
151
152        private static final String TIME_VIEW =         // 4.2.1.0 (2008/04/07) 直接色指定をやめる。
153                "<td><table cellspacing=\"0\" cellpadding=\"0\">"       + CR +
154                "<tr>"                                                                                          + CR +
155                "<td width=\"20px\"> </td>"                                                     + CR +
156                "<td width=\"0px\" id=\"queryTbl\" title=\"\" ></td>" + CR +    // #ff0000
157                "<td width=\"0px\" id=\"viewTbl\"  title=\"\" ></td>" + CR +    // #0000ff
158                "<td width=\"0px\" id=\"pageTbl\"  title=\"\" ></td>" + CR +    // #00ff00
159                "<td width=\"10px\"></td>"                                              + CR +
160                "<td style=\"background-color:transparent;\" id=\"totalTbl\"></td>" + CR +
161                "</tr>"                                                                                 + CR +
162                "</table></td>" + CR ;
163
164        // 4.3.6.0 (2009/04/01) 件数をボタンで開閉させる
165        // 6.0.2.4 (2014/10/17) img タグに、title 属性追記
166        private static final String COUNT_SWITCH=
167                "<td>" +
168                "  <img id=\"queryHide\" src=\"" + JSP + "/image/expand_r.png\" alt=\"pageSize\" title=\"pageSize\" border=\"0px\" "+   // 5.5.3.2 (2012/06/08)
169                                " onClick=\"hideClass( event, this, 'hide', 'expand_r', 'shrink_r' )\"> "       + CR +
170                "</td>";
171
172        // 6.1.1.0 (2015/01/17) DUMMY_INPUT_TAG は、システム共通で固定値でよい。
173        // 5.6.1.0 (2013/02/01) display:noneのダミー出力(IEのEnterボタンのための、隠しinput出力)
174        private static final String DUMMY_INPUT_TAG =
175                new TagBuffer( "input" )
176                        .add( "name"    , "HYBS_DUMMY_NPUT" )
177                        .add( "style"   , "display:none;" )
178                        .makeTag() ;
179
180        // 5.7.6.2 (2014/05/16) IEのHTML5機能が有効か無効かの判定値を飛ばす、hidden タグを作成します。
181        // 判定方法は、HTML5で新規追加された canvas タグが、有効かどうか(内部メソッドの戻り値があるかどうか)で判定します。
182        private static final String IE_HTML5_CHECK = 
183                        "<script type=\"text/javascript\">" + CR
184                +       "  (function($){" + CR
185                +       "    var test = document.createElement('canvas');" + CR
186                +       "    $.support.canvas = !(!test || !test.getContext);" + CR
187                +       "  })(jQuery);" + CR
188                +       "  $('<input/>').attr('type','hidden').attr('name','"
189                +                       HybsSystem.IE_HTML5_KEY
190                +               "').val( $.support.canvas ).appendTo('form');" + CR
191                +       "</script>" + CR ;
192
193        private String  command         = "NEW";
194        private String  pageSize        ;
195        private String  maxRowCount     ;
196        private String  accesskey       = "F";
197        private String  useClear        = "true";       // 6.4.3.4 (2016/03/11) つづり間違いを訂正。useCrear → useClear
198
199        private String  type            ;                       // null:標準 , SELECT:検索ボタンのみ , ENTRY:登録ボタンのみ
200        private String  scope           ;
201        private boolean usePrevNext     = true;
202        private boolean usePageSize     = true;
203        private boolean useRowCount     = true;
204        private boolean useTimeView     = HybsSystem.sysBool( "VIEW_USE_TIMEBAR" );             // 6.3.6.0 (2015/08/16)
205        private String  body            ;
206        private String  clearAcskey     = "C";
207        private boolean useDummy        = HybsSystem.sysBool( "USE_DUMMY_INPUT" );              // 5.6.1.0 (2013/02/01)
208        private boolean useEditMenu     = true;                 // 5.7.5.0 (2014/04/04) 編集プルダウンを出すかどうか(初期値:true)。
209        private String  blockUIMsg      = "MSG0090";    // 6.4.8.0 (2016/06/24) 検索中です・・・
210
211        private String  clearTarget             = "QUERY";              // 5.9.21.1 (2017/06/16) クリアボタンのターゲット
212        private String  clearHref               = "query.jsp";  // 5.9.21.1 (2017/06/16) クリアボタンの遷移アドレス
213        private String  clearCommand    = "NEW";                // 5.9.21.1 (2017/06/16) クリア時のコマンド
214
215        /**
216         * デフォルトコンストラクター
217         *
218         * @og.rev 6.4.2.0 (2016/01/29) PMD refactoring. Each class should declare at least one constructor.
219         */
220        public QueryButtonTag() { super(); }            // これも、自動的に呼ばれるが、空のメソッドを作成すると警告されるので、明示的にしておきます。
221
222        /**
223         * Taglibの開始タグが見つかったときに処理する doStartTag() を オーバーライドします。
224         *
225         * @og.rev 6.3.4.0 (2015/08/01) caseKey,caseVal,caseNN,caseNull,caseIf 属性対応
226         *
227         * @return      後続処理の指示( EVAL_BODY_BUFFERED )
228         */
229        @Override
230        public int doStartTag() {
231                // 6.4.1.1 (2016/01/16) PMD refactoring. A method should have only one exit point, and that should be the last statement in the method
232                // 反転注意
233                return useTag() ? EVAL_BODY_BUFFERED : SKIP_BODY ;
234
235        }
236
237        /**
238         * Taglibのタグ本体を処理する doAfterBody() を オーバーライドします。
239         *
240         * @og.rev 2.2.0.0 (2002/12/17) 中国語(国際化)対応 エンコードの取得方法変更
241         * @og.rev 3.0.0.0 (2002/12/25) StringUtil#changeString 廃止
242         * @og.rev 3.1.1.0 (2003/03/28) ボディの内容を取得する処理を、CommonTagSupport で行う。
243         *
244         * @return      後続処理の指示(SKIP_BODY)
245         */
246        @Override
247        public int doAfterBody() {
248                body = nval( getBodyString(),body );
249
250                return SKIP_BODY ;
251        }
252
253        /**
254         * Taglibの終了タグが見つかったときに処理する doEndTag() を オーバーライドします。
255         *
256         * @og.rev 5.3.6.0 (2011/06/01) 集計、合計などのEdit機能に対応します。
257         * @og.rev 5.6.5.1 (2013/06/14) debugプルダウンの追加。ついでに、PageSize と MaxRowCount の 表示条件を、整備します。
258         * @og.rev 5.6.9.4 (2013/10/31) editNameの初期値を外部から与えられるようにする
259         * @og.rev 5.7.1.0 (2013/12/06) HTMLTagSupportを継承する為、メソッドを、getSubmit() ⇒ makeTag() に変更
260         * @og.rev 5.7.1.2 (2013/12/20) USE_DEFAULT_EDITNAMEでeditNameの初期値変更
261         * @og.rev 5.7.5.0 (2014/04/04) useEditMenu 追加
262         * @og.rev 5.7.6.2 (2014/05/16) IEのHTML5機能が有効か無効かの判定値を飛ばす、hidden タグを作成します。
263         * @og.rev 6.3.4.0 (2015/08/01) caseKey,caseVal,caseNN,caseNull,caseIf 属性対応
264         * @og.rev 6.4.5.0 (2016/04/08) UserInfo のEditConfig関連機能を、DBEditConfigManagerに移植します。
265         * @og.rev 5.9.12.0 (2016/09/02) tableのframe属性を削除する
266         * @og.rev 6.9.2.1 (2018/03/12) DBEditConfigManagerを直接取り出す処理を、廃止します。
267         *
268         * @return      後続処理の指示
269         */
270        @Override
271        public int doEndTag() {
272                debugPrint();           // 4.0.0 (2005/02/28)
273                if( !useTag() ) { return EVAL_PAGE ; }  // 6.3.4.0 (2015/08/01)
274
275                final StringBuilder buf = new StringBuilder( BUFFER_MIDDLE )
276                        .append( getHiddenScope() ).append( CR )
277                        .append( "<table border=\"0\" summary=\"submit\" ><tr>" )                                               // 5.9.12.0 (2016/090/02)
278                        .append( CR )
279                        .append( "<td>" ).append( makeTag()             ).append( "</td>" ).append( CR )                // 5.7.1.0 (2013/12/06)
280                        .append( "<td>" ).append( getReset()    ).append( "</td>" ).append( CR )
281                        .append( "<td>" ).append( getCommand()  ).append( "</td>" ).append( CR )
282                        .append( "<td>" ).append( getGamenId()  ).append( "</td>" ).append( CR );
283                if( usePrevNext ) { buf.append( PREV_NEXT       ).append( CR ); }
284                buf.append( "<td><span id=\"query-button-append\"></span></td>").append( CR );          //4 3.6.0 (2009/04/01)
285                // if( usePageSize ) { buf.append( getPageSize()        ).append( CR ); }
286                // if( useRowCount ) { buf.append( getMaxRowCount()).append( CR ); }
287                if( body != null ) {
288                        buf.append( "<td>" ).append( body ).append( "</td>" ).append( CR );
289                }
290
291                // 5.7.5.0 (2014/04/04) useEditMenu 追加。trueで、編集プルダウンを出力します。
292                if( useEditMenu ) {
293                        // 6.9.2.1 (2018/03/12) DBEditConfigManagerを直接取り出す処理を、廃止します。
294//                      final DBEditConfigManager dbConfMgr = getUser().getEditConfigManager();         // 6.4.5.0 (2016/04/08)
295
296                        // 5.3.6.0 (2011/06/01) 集計、合計などのEdit機能に対応します。
297                        final String guikey = getGUIInfoAttri( "KEY" );
298                        // 6.1.0.0 (2014/12/26) findBugs: null ではなく長さが0の配列を返す。
299                        // 6.9.2.1 (2018/03/12) DBEditConfigManagerを直接取り出す処理を、廃止します。
300//                      final DBEditConfig[] configs = dbConfMgr.getEditConfigs( guikey );
301                        final DBEditConfig[] configs = getUser().getEditConfigs( guikey );
302                        if( configs.length > 0 ) {
303        //                      String selEditName = getUser().getSelectedEdit( getGUIInfoAttri( "KEY" ) );
304        //                      String selEditName = nval( getRequestValue( "editName" ) , getUser().getSelectedEdit( getGUIInfoAttri( "KEY" ) ));      // 5.6.9.4 (2013/10/31)
305                                String selEditName ; // 5.7.1.2 (2013/12/20)
306                                if( "FALSE".equalsIgnoreCase( sys( "USE_DEFAULT_EDITNAME" ) ) ){
307                                        selEditName = getRequestValue( "editName" );
308                                }
309                                else{
310                                        selEditName = nval( getRequestValue( "editName" ) , getUser().getSelectedEdit( guikey ));                                               // 5.6.9.4 (2013/10/31)
311        //                              selEditName = nval( getRequestValue( "editName" ) , dbConfMgr.getSelectedEdit( guikey ) );                                              // 6.4.5.0 (2016/04/08)
312                                }
313                                buf.append( getEditSelect( configs, selEditName ) ).append( CR );
314                        }
315                }
316
317                // 5.6.5.1 (2013/06/14) debugプルダウンの追加。ついでに、PageSize と MaxRowCount の 表示条件を、整備します。
318                if( usePageSize || useRowCount) {
319                        buf.append( COUNT_SWITCH ).append( CR );
320                        if( usePageSize ) { buf.append( getPageSize()   ).append( CR ); }
321                        if( useRowCount ) { buf.append( getMaxRowCount()).append( CR ); }
322                        // デバッグは、ユーザーのロールが、root の場合のみ表示するようにします。
323                        if( "root".equalsIgnoreCase( getUser().getRoles() ) ) {
324                                buf.append( getDebugClm() ).append( CR );                                               // 5.6.5.1 (2013/06/14) debugプルダウンの追加
325                        }
326                }
327
328                if( useTimeView ) { buf.append( TIME_VIEW ).append( CR ); }
329
330                buf.append( "</tr></table>" ).append( CR );
331
332                // 5.7.6.2 (2014/05/16) IEのHTML5機能が有効か無効かの判定値を飛ばす、hidden タグを作成します。
333                // IE_HTML5_KEY をキーとする設定値がなければ、まだ未設定なので、hidden タグを作成します。
334                if( getSessionAttribute( HybsSystem.IE_HTML5_KEY ) == null ) {
335                        buf.append( IE_HTML5_CHECK );
336                }
337
338                jspPrint( buf.toString() );
339                if( useDummy ){ jspPrint( DUMMY_INPUT_TAG ); }  // 6.1.1.0 (2015/01/17) 固定値でよい
340
341                return EVAL_PAGE ;              // ページの残りを評価する。
342        }
343
344        /**
345         * タグリブオブジェクトをリリースします。
346         * キャッシュされて再利用されるので、フィールドの初期設定を行います。
347         *
348         * @og.rev 5.6.1.0 (2013/02/01) useDummy 追加
349         * @og.rev 5.7.5.0 (2014/04/04) useEditMenu 追加
350         * @og.rev 6.3.6.0 (2015/08/16) useTimeView の初期値を、VIEW_USE_TIMEBAR にする。
351         * @og.rev 6.4.0.5 (2016/01/09) true/false に加えて、none:表示しない を追加。
352         * @og.rev 6.4.8.0 (2016/06/24) blockUIMsg を追加。 検索中です・・・
353         * @og.rev 5.9.21.1 (2017/06/16) clearTarget , clearHref , clearCommand追加
354         */
355        @Override
356        protected void release2() {
357                super.release2();
358                command                 = "NEW";
359                pageSize                = null;
360                maxRowCount             = null;
361                accesskey               = "F";
362                useClear                = "true";       // 6.4.0.5 (2016/01/09) true/false に加えて、none:表示しない を追加。
363                scope                   = null;
364                usePrevNext             = true;
365                usePageSize             = true;
366                useRowCount             = true;
367                useTimeView             = HybsSystem.sysBool( "VIEW_USE_TIMEBAR" );     // 6.3.6.0 (2015/08/16)
368                clearAcskey             = "C";                                                                          // 5.3.5.0 (2011/05/01) クリアボタンアクセスキー対応
369                useDummy                = HybsSystem.sysBool( "USE_DUMMY_INPUT" );      // 5.6.1.0 (2013/02/01)
370                useEditMenu             = true;                                                                         // 5.7.5.0 (2014/04/04) 編集プルダウンを出すかどうか(初期値:true)。
371                blockUIMsg              = "MSG0090";    // 6.4.8.0 (2016/06/24) 検索中です・・・
372                clearTarget             = "QUERY";              // 5.9.21.1 (2017/06/16) クリアボタンのターゲット
373                clearHref               = "query.jsp";  // 5.9.21.1 (2017/06/16)
374                clearCommand    = "NEW";                // 5.9.21.1 (2017/06/16)
375        }
376
377        /**
378         * サブミットボタンを作成します。
379         *
380         * @og.rev 5.3.6.0 (2011/06/01) accessKeyを削除できるように対応
381         * @og.rev 5.5.7.1 (2012/10/05) 不要な括弧出力を削除
382         * @og.rev 5.6.9.3 (2013/10/25) IDを出力する
383         * @og.rev 5.7.1.0 (2013/12/06) HTMLTagSupportを継承する為、メソッドを、getSubmit() ⇒ makeTag() に変更
384         * @og.rev 6.2.2.0 (2015/03/27) 互換モード/ネイティブモード対応。検索ボタンをbutton→input に変更
385         * @og.rev 6.4.8.0 (2016/06/24) blockUIMsg を追加。 検索中です・・・
386         *
387         * @return      サブミットボタン
388         * @og.rtnNotNull
389         */
390        @Override
391        protected String makeTag() {
392                String msglbl = getLongLabel();         // 4.0.0 (2005/01/31)
393                if( msglbl == null ) {
394                        if( "ENTRY".equalsIgnoreCase( type ) ) {
395                                msglbl = getLabel( "ENTRY" );
396                        }
397                        else {
398                                msglbl = getLabel( "QUERY" );
399                        }
400                }
401
402                // 5.7.1.0 (2013/12/06) XHTMLTag を使用することで、各種属性を追加できるようにします。
403                if( accesskey != null ) {
404                        set( "accesskey" , accesskey );
405                        msglbl = msglbl + "(" + accesskey + ")" ;
406                }
407
408                // 6.4.8.0 (2016/06/24) blockUIMsg を追加。 検索中です・・・
409                if( blockUIMsg != null && !blockUIMsg.isEmpty() ) {
410                        final String uiMsg = getResource().getLabel( blockUIMsg );
411                        set( "alt" , uiMsg );
412                }
413
414                set( "type"     , "submit" );
415                set( "id"       , "queryButtonSubmit" );
416                // 6.2.2.0 (2015/03/27) 互換モード/ネイティブモード対応。検索ボタンをbutton→input に変更
417                set( "value", msglbl );                                                 // 6.2.2.0 (2015/03/27)
418
419                return XHTMLTag.input( getAttributes() );               // 6.2.2.0 (2015/03/27)
420        }
421
422        /**
423         * リセットボタンを作成します。
424         *
425         * @og.rev 4.0.0.0 (2007/10/18) メッセージリソース統合( getResource().getMessage ⇒ getResource().getLabel )
426         * @og.rev 5.0.2.0 (2009/11/01) 戻るボタンが出力されている状態で、クリアボタンを押すと、戻るボタンが消える不具合を修正
427         * @og.rev 5.3.5.0 (2011/05/01) クリアボタンにもアクセスキーが付加できるように対応
428         * @og.rev 5.3.6.0 (2011/06/01) accessKeyを削除できるように対応
429         * @og.rev 6.2.2.0 (2015/03/27) 互換モード/ネイティブモード対応。クリアボタンをbutton→input に変更
430         * @og.rev 6.4.0.5 (2016/01/09) true/false に加えて、none:表示しない を追加。
431         * @og.rev 5.9.21.1 (2017/06/16) クリアボタンのターゲットとページを変更可能にする
432         *
433         * @return      リセットボタン
434         * @og.rtnNotNull
435         */
436        private String getReset() {
437                final String rtn ;
438
439                // 6.4.0.5 (2016/01/09) true/false に加えて、none:表示しない を追加。
440                if( "true".equalsIgnoreCase( useClear ) ) {
441                        final char ch = clearHref.indexOf( '?' ) < 0 ? '?' : '&' ;              // 連結文字列
442
443                        rtn = "<input type=\"button\" onClick=\"window.open('" + JSP + '/' + getGUIInfoAttri( "ADDRESS" ) +
444                                '/' + clearHref + ch + "GAMENID=" + getGUIInfoAttri( "KEY" ) + 
445                                "&command=" + clearCommand + "','" + clearTarget +"')\" " +             // 5.9.21.1 (2017/06/16)
446                                ( clearAcskey == null ? "" : "accesskey=\"" + clearAcskey + '"' ) +
447                                " value=\"" + getResource().getLabel( "MSG0011" ) +
448                                ( clearAcskey == null ? "" : '(' + clearAcskey + ')' ) +
449                                "\" />" ;
450                }
451                else if( "false".equalsIgnoreCase( useClear ) ) {
452                        rtn = "<input type=\"reset\" " +
453                                ( clearAcskey == null ? "" : "accesskey=\"" + clearAcskey + '"' ) +
454                                " value=\"" + getResource().getLabel( "MSG0011" ) +
455                                ( clearAcskey == null ? "" : '(' + clearAcskey + ')' ) +
456                                "\" />" ;
457                }
458                else {          // "none" を想定
459                        rtn = "" ;                              // none:表示しない
460                }
461
462                return rtn;
463        }
464
465        /**
466         * コマンドを出力する hidden を作成します。
467         *
468         * @return      コマンドを出力する hidden
469         * @og.rtnNotNull
470         */
471        private String getCommand() {
472                // 6.1.1.0 (2015/01/17) refactoring. ロジックを見直します。
473
474                return "NEW".equals( command )
475                                        ? COMMAND
476                                        : "<input type=\"hidden\" name=\"command\" value=\"" +
477                                                command + "\" id=\"h_cmd\" />" ;
478        }
479
480        /**
481         * スコープを出力する hidden を作成します。
482         *
483         * @return      スコープを出力する hidden
484         * @og.rtnNotNull
485         */
486        private String getHiddenScope() {
487                // 6.1.1.0 (2015/01/17) refactoring. ロジックを見直します。
488
489                return scope == null
490                                ? ""
491                                : "<input type=\"hidden\" name=\"scope\" value=\"" +
492                                                scope + "\" />" ;
493        }
494
495        /**
496         * 画面IDを出力する hidden を作成します。
497         *
498         * @return      画面IDを出力する hidden
499         * @og.rtnNotNull
500         */
501        private String getGamenId() {
502                // 6.1.1.0 (2015/01/17) refactoring. ロジックを見直します。
503                return "<input type=\"hidden\" name=\"GAMENID\" value=\"" +
504                                                getGUIInfoAttri("KEY") + "\" />";
505        }
506
507        /**
508         * ページサイズプルダウンメニューを作成します。
509         *
510         * @og.rev 4.3.6.0 (2008/04/01) idとclassの変更
511         *
512         * @return      ページサイズプルダウンメニュー
513         * @og.rtnNotNull
514         */
515        private String getPageSize() {
516                if( pageSize == null ) {
517                        final String PAGESIZE  = sys( "HTML_PAGESIZE" );
518                        pageSize = nval( getRequestValue( "pageSize" ),PAGESIZE ) ;
519                }
520
521                final DBColumn column = getDBColumn( "pageSize" );
522                final String tag = column.getEditorValue( pageSize );
523
524                // return ( "<td id=\"label\">" +
525                return "<td class=\"label pageSize hide\">"                                     // 4.3.6.0 (2008/04/01) class出力
526                                +       column.getLongLabel()
527                                +       ":</td><td class=\"pageSize hide\">" + tag + "</td>" ;
528        }
529
530        /**
531         * 検索時の最大検索数のプルダウンメニューを作成します。
532         *
533         * @og.rev 4.3.6.0 (2008/04/01) idとclassの変更
534         *
535         * @return      最大検索数のプルダウンメニュー
536         * @og.rtnNotNull
537         */
538        private String getMaxRowCount() {
539                if( maxRowCount == null ) {
540                        final String ROW_COUNT = sys( "DB_MAX_ROW_COUNT" );
541                        maxRowCount = nval( getRequestValue( "maxRowCount" ), ROW_COUNT ) ;
542                }
543
544                final DBColumn column = getDBColumn( "maxRowCount" );
545                final String tag = column.getEditorValue( maxRowCount );
546
547                // return ( "<td id=\"label\">" +
548                return "<td class=\"label maxRowCount hide\">"                  // 4.3.6.0 (2008/04/01) class出力
549                                +       column.getLongLabel()
550                                +       ":</td><td class=\"maxRowCount hide\">" + tag + "</td>" ;
551        }
552
553        /**
554         *  debugプルダウンメニューを作成します。
555         *
556         * @og.rev 5.6.5.1 (2013/06/14) 新規追加
557         *
558         * @return      debugプルダウンメニュー
559         * @og.rtnNotNull
560         */
561        private String getDebugClm() {
562                final DBColumn column = getDBColumn( "debug" );
563                final String tag = column.getEditorValue( "false" );
564
565                return "<td class=\"label debug hide\">"
566                                +       column.getLongLabel()
567                                +       ":</td><td class=\"debug hide\">" + tag + "</td>" ;
568        }
569
570        /**
571         * 編集名一覧のプルダウンメニューを作成します。
572         *
573         * @og.rev 5.3.6.0 (2011/06/01) 新規追加
574         * @og.rev 5.9.1.2 (2015/10/23) 自己終了タグ修正
575         *
576         * @param configs 編集名一覧(配列)
577         * @param selEditName 選択中の編集名
578         *
579         * @return      編集名一覧のプルダウン
580         * @og.rtnNotNull
581         */
582        private String getEditSelect( final DBEditConfig[] configs, final String selEditName ) {
583                final DBColumn column = getDBColumn( "editName" );
584
585                final StringBuilder buf = new StringBuilder( BUFFER_MIDDLE )
586                        .append( "<td class=\"label editName\">" )
587                        .append( column.getLongLabel() )
588                        .append( ":</td><td class=\"editName\">" )
589                        .append( "<select name=\"editName\">" )
590                        .append( "<option><!-- --></option>" ); // 5.9.1.2 (2015/10/23)
591
592                for( final DBEditConfig config : configs ) {
593                        final String name = config.getEditName();
594                        if( name != null && name.length() > 0 ) {
595                                buf.append( "<option value=\"" ).append( name ).append( '"' );          // 6.0.2.5 (2014/10/31) char を append する。
596                                if( config.isCommon() ) {
597                                        buf.append( " class=\"commonEdit\"" );
598                                }
599                                if( name.equals( selEditName ) ) {
600                                        buf.append( " selected" );
601                                }
602                                buf.append( '>' ).append( name ).append( "</option>" );                         // 6.0.2.5 (2014/10/31) char を append する。
603                        }
604                }
605                buf.append( "</select></td>" );
606                return buf.toString();
607        }
608
609        /**
610         * 【TAG】リクエストとして送信するコマンドを指定します(初期値:NEW)。
611         *
612         * @og.tag
613         *  NEW:通常の検索(初期値)/ENTRY:エントリ登録時
614         *
615         * @param       cmd     送信するコマンド
616         */
617        public void setCommand( final String cmd ) {
618                command = nval( getRequestParameter( cmd ),command );
619        }
620
621        /**
622         * 【TAG】JavaScriptによる初期化(クリア)ボタンを使用するかどうか[true/false/none]を指定します(初期値:true)。
623         *
624         * @og.tag
625         * 通常の初期化(クリア)ボタンでは、HTMLが作成された状態に戻すだけです。
626         * 例えば、引数付きで設定された場合、その引数が設定されている状態へ戻します。
627         * このJavaScriptによる初期化ボタンの場合(trueの場合)は、JavaScriptにより
628         * INIT状態でもう一度QUERYフレームを呼び出しますので、指定された引数もクリアされます。
629         * none を指定すると、クリアボタンを表示しません。
630         * 
631         * true:  JavaScriptによる初期化ボタン(すべての引数がクリアされます)
632         * false: HTMLによる RESET処理(type="reset" のinputタグが出力されます。)
633         * none:  クリアボタンを表示しません。 (※ 6.4.0.5 (2016/01/09) 以降 )
634         * 
635         * 初期値は、true:JavaScriptによる初期化です。
636         *
637         * @og.rev 6.4.0.5 (2016/01/09) true/false に加えて、none:表示しない を追加。
638         * @og.rev 6.4.3.4 (2016/03/11) つづり間違いを訂正。useCrear → useClear。
639         *
640         * @param   flag JavaScriptによる初期化ボタン使用可否 [true:JavaScript初期化ボタン/false:通常のresetボタン]
641         */
642        public void setUseClear( final String flag ) {
643                useClear = nval( getRequestParameter( flag ),useClear );
644
645                // 6.4.0.5 (2016/01/09) true/false に加えて、none:表示しない を追加。
646                if( useClear != null &&
647                        !"true".equalsIgnoreCase( useClear ) &&
648                        !"false".equalsIgnoreCase( useClear ) &&
649                        !"none".equalsIgnoreCase( useClear ) ) {
650                                final String errMsg = "useClear は、[true:全クリア/false:リセット/none:表示しない] から選んでください。"
651                                                                + "useClear=[" + flag + "]" + CR ;
652                                throw new HybsSystemException( errMsg );
653                }
654        }
655
656        /**
657         * 【廃止】JavaScriptによる初期化(クリア)ボタンを使用するかどうか[true/false/none]を指定します(初期値:true)。
658         *
659         * @og.tag
660         * 通常の初期化(クリア)ボタンでは、HTMLが作成された状態に戻すだけです。
661         * 例えば、引数付きで設定された場合、その引数が設定されている状態へ戻します。
662         * このJavaScriptによる初期化ボタンの場合(trueの場合)は、JavaScriptにより
663         * INIT状態でもう一度QUERYフレームを呼び出しますので、指定された引数もクリアされます。
664         * none を指定すると、クリアボタンを表示しません。
665         * 
666         * true:  JavaScriptによる初期化ボタン(すべての引数がクリアされます)
667         * false: HTMLによる RESET処理(type="reset" のinputタグが出力されます。)
668         * none:  クリアボタンを表示しません。 (※ 6.4.0.5 (2016/01/09) 以降 )
669         * 
670         * 初期値は、true:JavaScriptによる初期化です。
671         *
672         * @og.rev 6.4.0.5 (2016/01/09) true/false に加えて、none:表示しない を追加。
673         * @og.rev 6.4.3.4 (2016/03/11) つづり間違いを訂正。useCrear → useClear。
674         *
675         * @param   flag JavaScriptによる初期化ボタン使用可否 [true:JavaScript初期化ボタン/false:通常のresetボタン]
676         */
677        public void setUseCrear( final String flag ) {
678                setUseClear( flag );
679        }
680
681        /**
682         * 【TAG】useClear時のターゲットを指定します(初期値=QUERY)。
683         *
684         * @og.tag
685         * useClearをtrueにしている場合、window.openを利用した初期化を行います。
686         * この際に検索部分の名称がQUERY以外の場合にこの属性で指定します。
687         * 初期値はQUERYです。
688         *
689         * @og.rev 5.9.21.1 (2017/06/16) 新規追加
690         *
691         * @param   tgt ターゲット名
692         */
693        public void setClearTarget( final String tgt ) {
694                clearTarget = nval( getRequestParameter( tgt ), clearTarget );
695        }
696
697        /**
698         * 【TAG】useClear時の遷移先を指定します(初期値=query.jsp)。
699         *
700         * @og.tag
701         * useClearをtrueにしている場合、window.openを利用した初期化を行います。
702         * この際に検索画面のURLがquery.jspでない場合にこの属性で指定します。
703         * また、query.jsp でも、特定の値を再設定したい場合、query.jsp?KEY=VALUE という
704         * 記述が可能です。指定のキーだけ、クリアしないということが出来るようになります。
705         * 初期値はquery.jspです。
706         *
707         * @og.rev 5.9.21.1 (2017/06/16) 新規追加
708         *
709         * @param   page 遷移先
710         */
711        public void setClearHref( final String page ) {
712                clearHref = nval( getRequestParameter( page ), clearHref );
713        }
714
715        /**
716         * 【TAG】useClear時のcommandを指定します(初期値=NEW)。
717         *
718         * @og.tag
719         * useClearをtrueにしている場合、window.openを利用した初期化を行います。
720         * この際に読み込む画面に対してcommand=NEW以外を送信したい場合にこの属性で指定します。
721         * 初期値はNEWです。
722         *
723         * @og.rev 5.9.21.1 (2017/06/16) 新規追加
724         *
725         * @param   cmd コマンド
726         */
727        public void setClearCommand( final String cmd ) {
728                clearCommand = nval( getRequestParameter( cmd ), clearCommand );
729        }
730
731        /**
732         * 【TAG】典型的なボタンの形状に設定します(初期値:null)。
733         *
734         * @og.tag
735         * クエリーボタンでは、検索ボタン以外に、pageSize、maxRowCount、
736         * prevNext、timeView などの項目も表示可能です。
737         * これらを、個別に設定可能ですが、通常使用するタイプとして、3タイプを
738         * 用意します。これは、設定状態の初期値といえます。
739         * null  :通常の検索ボタンで、フル装備の指定です。
740         * SELECT:1件のみ検索するようなケースで使用します。
741         *        検索ボタンとクリアボタンのみを表示します。
742         * ENTRY :いきなり登録するようなケースで使用します。
743         *        登録ボタンとクリアボタンのみを表示します。(command="NEW" です。)
744         *
745         * @og.rev 6.4.0.5 (2016/01/09) accesskey="" が効かなかったので、対応。
746         *
747         * @param       tp      タイプ指定 [null/SELECT/ENTRY]
748         */
749        public void setType( final String tp ) {
750                type = nval( getRequestParameter( tp ),type );
751
752                // 6.4.0.5 (2016/01/09) accesskey="" が効かなかったので、対応。
753                // accesskey の初期値が "F" なので、ENTRYの場合のみ、"F" のときは "W" に変更します。
754
755                if( "SELECT".equalsIgnoreCase( type ) ) {
756                        usePrevNext     = false;
757                        usePageSize     = false;
758                        useRowCount     = false;
759                        useTimeView     = false;
760                }
761                else if( "ENTRY".equalsIgnoreCase( type ) ) {
762                        if( "F".equals( accesskey ) ) { accesskey = "W"; }              // ENTRYの場合は、"F" の場合のみ、"W" に置き換えます。
763                        usePrevNext     = false;
764                        usePageSize     = false;
765                        useRowCount     = false;
766                        useTimeView     = false;
767                }
768        }
769
770        /**
771         * 【TAG】リクエストとして送信するスコープを指定します(初期値:null)。
772         *
773         * @og.tag
774         * リクエスト時に、付与する引数情報のうちの、スコープを指定します。
775         * これは、検索専用画面の場合は、scope="request" にする事で、メモリの
776         * 無駄な確保を行わずに、検索結果を表示できます。
777         * ただし、その結果に対して、NEXT-PREV や、ヘッダーソートリンクなどの
778         * 機能が使えなくなります。
779         * 通常は、何も指定しない状態(null)で、RESULT画面の設定に任せるのが良いでしょう。
780         * 初期値は、null = session(セッション登録) です。
781         *
782         * @param   scp スコープ [session:セッション登録/request:リクエスト登録]
783         */
784        @Override
785        public void setScope( final String scp ) {
786                scope = nval( getRequestParameter( scp ),scope );
787        }
788
789        /**
790         * 【TAG】検索ボタンに使用するショートカットキー文字を指定します(初期値:F)。
791         *
792         * @og.tag
793         * ボタンを、Alt-XX で実行できるようにするショートカットキーを設定します。
794         * 標準では、検索ボタンは、"F" に設定していますので、Alt-F となります。
795         * ゼロ文字列を指定すると、ショートカットキーなしに設定できます。
796         * 初期値は、Find の "F" です。
797         *
798         * @og.rev 5.3.6.0 (2011/06/01) accessKeyを削除できるように対応
799         * @og.rev 5.6.0.3 (2012/01/24) getRequestParameter を何度も呼んでいるので修正。
800         *
801         * @param       accsKey ショートカットキー文字(初期値:F)
802         */
803        @Override
804        public void setAccesskey( final String accsKey ) {
805                final String val = getRequestParameter( accsKey );
806                if( val == null || val.isEmpty() ) {
807                        accesskey = null;
808                }
809                else {
810                        accesskey = val;                                                                // 5.6.0.3 (2012/01/24)
811                }
812        }
813
814        /**
815         * 【TAG】クリアボタンに使用するショートカットキー文字を指定します(初期値:C)。
816         *
817         * @og.tag
818         * ボタンを、Alt-XX で実行できるようにするショートカットキーを設定します。
819         * 標準では、検索ボタンは、"C" に設定していますので、Alt-C となります。
820         * ゼロ文字列を指定すると、ショートカットキーなしに設定できます。
821         * 初期値は、Clear の "C" です。
822         *
823         * @og.rev 5.3.6.0 (2011/06/01) accessKeyを削除できるように対応
824         * @og.rev 5.6.0.3 (2012/01/24) getRequestParameter を何度も呼んでいるので修正。
825         *
826         * @param       accsKey クリアボタンのショートカットキー文字(初期値:C)
827         */
828        public void setClearAccesskey( final String accsKey ) {
829                final String val = getRequestParameter( accsKey );
830                if( val == null || val.isEmpty() ) {
831                        clearAcskey = null;
832                }
833                else {
834                        clearAcskey = val;                                                              // 5.6.0.3 (2012/01/24)
835                }
836        }
837
838        /**
839         * 【TAG】進む/戻るのprev_next リンクを表示するかどうかを指定します(初期値:true)。
840         *
841         * @og.tag
842         * 進む/戻るリンクは、RESULT画面にコマンド (FIRST,PREV,NEXT,LAST) という
843         * コマンドを送る事で実現している画像リンクです。
844         * PREV_NEXT が存在しない画面では、消去しておく必要があります。
845         * 初期値は、true(表示する)です。
846         *
847         * @param       flag    prev_nextリンク表示 [true:する/false:しない]
848         */
849        public void setUsePrevNext( final String flag ) {
850                usePrevNext = nval( getRequestParameter( flag ),usePrevNext );
851        }
852
853        /**
854         * 【TAG】pageSize 引数を使用するかどうかを指定します(初期値:true)。
855         *
856         * @og.tag
857         * pageSize 引数は、RESULT画面のviewタグで使用する 一回の表示に
858         * 何件のデータを表示させるかを指定する引数です。
859         * この件数が多いと、多くのデータを見ることが出来ますが、その分表示が
860         * 遅くなります。逆に、少ないと、PREV_NEXT を多用することになり、
861         * 目的の行を探し出しにくくなります。
862         * pageSize の値は、pageSizeパラメータで画面単位に指定するか、システム
863         * パラメータの HTML_PAGESIZE でシステム単位に指定できます。
864         * 初期値は、true(使用する)です。
865         *
866         * @param       flag    pageSize引数使用 [true:する/false:しない]
867         * @see     #setPageSize( String )
868         */
869        public void setUsePageSize( final String flag ) {
870                usePageSize = nval( getRequestParameter( flag ),usePageSize );
871        }
872
873        /**
874         * 【TAG】maxRowCount 引数を使用するかどうかを指定します(初期値:true)。
875         *
876         * @og.tag
877         * maxRowCount 引数は、RESULT画面のqueryタグで使用する 一回の検索時に
878         * 何件のデータを取得させるかを指定する引数です。
879         * この件数が多いと、多くのデータを検索することが出来ますが、その分表示が
880         * 遅くなります。逆に、少ないと、目的の行まで探し出せないかもしれません。
881         * maxRowCount の値は、rowCountパラメータで画面単位に指定するか、システム
882         * パラメータの DB_MAX_ROW_COUNT でシステム単位に指定できます。
883         *
884         * 初期値は、true(使用する)です。
885         *
886         * @param       flag    maxRowCount引数使用 [true:する/false:しない]
887         * @see     #setMaxRowCount( String )
888         */
889        public void setUseRowCount( final String flag ) {
890                useRowCount = nval( getRequestParameter( flag ),useRowCount );
891        }
892
893        /**
894         * 【TAG】処理時間を表示する TimeView を表示するかどうか[true:する/false:しない]を指定します
895         *              (初期値:VIEW_USE_TIMEBAR[={@og.value SystemData#VIEW_USE_TIMEBAR}])。
896         *
897         * @og.tag
898         * true に設定すると、処理時間を表示するバーイメージが表示されます。
899         * これは、DB検索、APサーバー処理、画面表示の各処理時間をバーイメージで
900         * 表示させる機能です。処理時間の目安になります。
901         * (初期値:VIEW_USE_TIMEBAR[={@og.value SystemData#VIEW_USE_TIMEBAR}])。
902         *
903         * @og.rev 6.3.6.0 (2015/08/16) useTimeView の初期値を、VIEW_USE_TIMEBAR にする。
904         *
905         * @param       flag    処理時間を表示 [true:する/false:しない]
906         */
907        public void setUseTimeView( final String flag ) {
908                useTimeView = nval( getRequestParameter( flag ),useTimeView );
909        }
910
911        /**
912         * 【TAG】pageSize プルダウンメニューの初期表示件数を指定します
913         *              (初期値:HTML_PAGESIZE[={@og.value SystemData#HTML_PAGESIZE}])。
914         *
915         * @og.tag
916         * プルダウンメニューを表示する場合の初期値を指定します。
917         * (初期値:ユーザー定数のHTML_PAGESIZE[={@og.value SystemData#HTML_PAGESIZE}])。
918         *
919         * @param       pSize   表示件数
920         * @see     #setUsePageSize( String )
921         * @see         org.opengion.hayabusa.common.SystemData#HTML_PAGESIZE
922         */
923        public void setPageSize( final String pSize ) {
924                pageSize = nval( getRequestParameter( pSize ),pageSize );
925        }
926
927        /**
928         * 【TAG】maxRowCount プルダウンメニューの初期値を指定します
929         *              (初期値:DB_MAX_ROW_COUNT[={@og.value SystemData#DB_MAX_ROW_COUNT}])。
930         *
931         * @og.tag
932         * プルダウンメニューを表示する場合のmaxRowCountの初期値を指定します。
933         * (初期値:ユーザー定数のDB_MAX_ROW_COUNT[={@og.value SystemData#DB_MAX_ROW_COUNT}])。
934         *
935         * @param       maxSize 最大件数
936         * @see     #setUseRowCount( String )
937         * @see         org.opengion.hayabusa.common.SystemData#DB_MAX_ROW_COUNT
938         */
939        public void setMaxRowCount( final String maxSize ) {
940                maxRowCount = nval( getRequestParameter( maxSize ),maxRowCount );
941        }
942
943        /**
944         * 【TAG】ダミーのinputタグ(display:none)を出力するか設定します
945         *              (初期値:USE_DUMMY_INPUT[={@og.value SystemData#USE_DUMMY_INPUT}])。
946         *
947         * @og.tag
948         * ダミーのinputタグ(display:none)を出力するか設定します。
949         * IEではinputが1つだけの場合にエンターでのsubmitが上手くいかないため、ダミーを配置する必要があります。
950         * trueに設定するとWriteCheckタグがダミーを(常に)出力します。
951         * (初期値:USE_DUMMY_INPUT[={@og.value SystemData#USE_DUMMY_INPUT}])。
952         *
953         * @og.rev 5.6.1.0 (2013/02/01) 新規追加
954         *
955         * @param   flag 出力可否 [true:する/false:しない]
956         * @see         org.opengion.hayabusa.common.SystemData#USE_DUMMY_INPUT
957         */
958        public void setUseDummy( final String flag ) {
959                useDummy = nval( getRequestParameter( flag ), useDummy );
960        }
961
962        /**
963         * 【TAG】query画面等で編集プルダウンを出力するかどうか[true:する/false:しない]を指定します(初期値:true)。
964         *
965         * @og.tag
966         * falseを指定すると編集プルダウンを出さない。
967         * popup画面等、画面ID単位では編集機能は使うが、部分的に使いたくない場合に
968         * タグのパラメータとして個別に指定できるようにします。
969         * 初期値は、互換性の関係から、編集プルダウンを出力する(=true)です。
970         *
971         * @og.rev 5.7.5.0 (2014/04/04) 新規追加
972         *
973         * @param       flag    編集メニュー出力 [true:する/false:しない]
974         * @see         org.opengion.hayabusa.taglib.FileUDTag#setUseEditLink(String)
975         */
976        public void setUseEditMenu( final String flag ) {
977                useEditMenu = nval( getRequestParameter( flag ),useEditMenu );
978        }
979
980        /**
981         * 【TAG】検索ボタンを押下した際に表示されるメッセージリソースIDを指定します
982         *              (初期値:MSG0090[検索中です・・・])。
983         *
984         * @og.tag
985         * headタグのuseBlockUI=true のときに、検索ボタンを押下すると、「検索中です・・・」と表示されます。
986         * このメッセージのリソースIDを指定します。
987         * 表示させたくない場合は, blockUIMsg = "" をセットするか、headタグのuseBlockUI=false をセットしてください。
988         *
989         * @og.rev 6.4.8.0 (2016/06/24) blockUIMsg を追加。 検索中です・・・
990         *
991         * @param       id 検索中ですメッセージID
992         */
993        public void setBlockUIMsg( final String id ) {
994                final String ids = getRequestParameter( id );
995                if( ids != null ) { blockUIMsg = ids; }
996        }
997
998        /**
999         * このオブジェクトの文字列表現を返します。
1000         * 基本的にデバッグ目的に使用します。
1001         *
1002         * @return このクラスの文字列表現
1003         * @og.rtnNotNull
1004         */
1005        @Override
1006        public String toString() {
1007                return ToString.title( this.getClass().getName() )
1008                                .println( "VERSION"                     , VERSION               )
1009                                .println( "command"                     , command               )
1010                                .println( "pageSize"            , pageSize              )
1011                                .println( "maxRowCount"         , maxRowCount   )
1012                                .println( "accesskey"           , accesskey             )
1013                                .println( "scope"                       , scope                 )
1014                                .println( "useClear"            , useClear              )
1015                                .println( "usePrevNext"         , usePrevNext   )
1016                                .println( "usePageSize"         , usePageSize   )
1017                                .println( "useRowCount"         , useRowCount   )
1018                                .println( "useTimeView"         , useTimeView   )
1019                                .println( "clearTarget"         , clearTarget   )
1020                                .println( "clearHref"           , clearHref             )
1021                                .println( "clearCommand"        , clearCommand  )
1022                                .println( "body"                        , body                  )
1023                                .println( "Other..."            , getAttributes().getAttribute() )
1024                                .fixForm().toString() ;
1025        }
1026}