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