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.Cleanable;
019// import org.opengion.fukurou.util.StringUtil;
020import org.opengion.hayabusa.common.HybsSystem ;
021import org.opengion.hayabusa.common.SystemManager ;
022import org.opengion.hayabusa.common.HybsSystemException ;
023import org.opengion.hayabusa.common.BuildNumber ;
024import org.opengion.hayabusa.resource.ResourceFactory;
025import org.opengion.hayabusa.resource.ResourceManager ;
026import org.opengion.hayabusa.resource.UserInfoFactory ;
027import org.opengion.hayabusa.resource.UserInfo ;
028import org.opengion.hayabusa.resource.GUIInfo ;
029
030import static org.opengion.fukurou.util.StringUtil.nval ;
031
032import javax.servlet.http.HttpSession ;
033import javax.servlet.http.HttpServletRequest ;
034import javax.servlet.http.HttpServletResponse ;
035import javax.servlet.ServletException;
036import javax.servlet.jsp.tagext.Tag ;
037
038import java.io.UnsupportedEncodingException;
039import java.io.IOException;
040import java.io.File;
041import java.util.Map;
042import java.util.HashMap;
043
044/**
045 * HTMLファイルの head タグに相当する機能を付加します。
046 * レイアウトを構築する場合に、HTMLファイルの構造に準拠した形式で記述できるように
047 * なります。JavaScript や body タグを 各JSPファイル内で独自に設定できるように
048 * なる為、カスタマイズが容易になります。
049 *
050 * 機能的には、旧バージョンの
051 *    common/session_init.jsp
052 *    common/HTML.jsp
053 *    <og:responseHeader cacheControl = "max-age=0" />
054 * を組み込んだ、common/jsp_init.jsp の代わりに使用できるタグになります。
055 *
056 * 属性に、下記の値を設定できます。それ以外は、BODY部に直接記述することで追加できます。
057 * BODY部、および、属性の引数には、{@XXXX}が使用できます。
058 * 例えば、{@SYS.CONTEXT_NAME}を使用すれば、相対アドレスでの指定ではなく、
059 * 絶対アドレスで指定可能になるため、ブラウザのキャッシュが利用できます。
060 *
061 * システム変数による、初期値制御されているのは、下記のフラグです。
062 * これらは、headerタグで個別に指定する事はできません。
063 *
064 *     MAX_INACTIVE_INTERVAL = "1800"
065 *     USE_HTML5_HEADER = "(Ver5=false Ver6=true)"
066 *     SCROLL_BAR_TYPE  = "common/scrollBar2"
067 *     GUI_TOP_TITLE    = "Web アプリケーションシステム" ;
068 *     VIEW_USE_BLOCKUI = "true"
069 *
070 * @og.formSample
071 * ●形式:<og:head />
072 * ●body:あり(EVAL_BODY_BUFFERED:BODYを評価し、{@XXXX} を解析します)
073 *
074 * ●Tag定義:
075 *   <og:head
076 *       title              【TAG】HTML の タイトルを設定します(初期値:session に"GUI_TITLE" キーで登録されている値)
077 *       headType           【TAG】ヘッダータイプ[xml|init|query|result|menu|simple|handy|frame|popup]を設定します(初期値:null)
078 *       useScrollBar       【TAG】ScrollBar.js JavaScript を使用するかどうか[true/false]を指定します(初期値:true)
079 *       useGantt           【TAG】option/gantt.js JavaScript を使用するかどうか[true/false]を指定します(初期値:false)
080 *       useTreeBOM         【TAG】option/treeBOM.js JavaScript を使用するかどうか[true/false]を指定します(初期値:false)
081 *       useGuest           【TAG】ゲストユーザを利用するかどうか[true/false]を指定します(初期値false)
082 *       useAjaxTreeTable   【TAG】Ajaxを利用したツリー形式のテーブル表示を使用するかを指定します
083 *       noTransition       【TAG】画面遷移を行わない形式の登録方法を使用するかを指定します(NO_TRANSITION_MODE=false)
084 *       useTabLink         【TAG】og:tabLinkタグで使用される common/tagLink.js をインクルードするかどうか[true/false]を指定します(初期値:false)
085 *       useTabstrip        【TAG】【廃止】useJQUIと同じ動作をします(初期値:false)
086 *       useRealTimeCheck   【TAG】カラムチェックをリアルタイムで行うかどうか[true/false]を指定します(初期値:true)
087 *       useIE7Header       【TAG】IE8でIE7エミュレートモードで動作させるタグを出力するかどうか[true/false]を指定します(初期値:USE_IE7_HEADER[=true])
088 *       useViewPort        【TAG】タブレット等の画面サイズ調整METAタグ(viewport)出力するかどうか[true/false]を指定します(初期値:USE_VIEWPORT_HEADER[=false])
089 *       useAjaxSubmit      【TAG】フォームのSubmit処理をJavaScriptを利用して行うか(ポップアップエラー表示)(初期値:USE_AJAX_SUBMIT=false)
090 *       useFocusHilight    【TAG】フォーカスが当っている入力ボックスの色を変更するかどうか[true/false]を指定します(初期値:true)
091 *       useHrefIcon        【TAG】href(リンク)の拡張子に応じたアイコンを表示するかどうか[true/false]を指定します(初期値:false)
092 *       useBlockUI         【TAG】検索中表示を行うかどうかを[true/false]を指定します(初期値:VIEW_USE_BLOCKUI[=true])
093 *       addEvent           【TAG】javaScript を初期ロードし、起動するメソッドを指定します(初期値:null)
094 *       adjustEvent        【TAG】特定の javaScript を初期ロードし、起動するメソッドを指定します(初期値:null)
095 *       useTbodyMovable    【TAG】option/ogTbodyMovable.js JavaScript を使用するかどうか[true/false]を指定します(初期値:false)
096 *       useJQUI            【TAG】jquery/jquery-uiをロードするかどうかを指定します(初期値:false)
097 *       debug              【TAG】デバッグ情報を出力するかどうか[true/false]を指定します(初期値:false)
098 *   >   ... Body ...
099 *   </og:head>
100 * ●使用例
101 *       <og:head
102 *          headType        = "[xml|init|query|result|menu|simple|handy|frame|popup]"
103 *          title           = "HEAD タグの TITLE属性"
104 *          useScrollBar    = "[true/false]"    scrollBar2.js
105 *          useGantt        = "[false/true]"    option/gantt.js
106 *          useTreeBOM      = "[false/true]"    option/treeBOM.js
107 *          useAjaxTreeTable= "[false/true]"    option/ajaxTreeTable.js
108 *          noTransition    = "[false/true]"    option/noTransition.js
109 *          useTabLink      = "[false/true]"    option/tabLink.js
110 *          useRealTimeCheck= "[true/false]"    realTimeCheck.js        5.4.5.0 (2012/03/01) 追加(復活)
111 *          useFocusHilight = "[true/false]"    focusHilight.js         5.4.5.0 (2012/03/01) 追加(復活)
112 *          useHrefIcon     = "[false/true]"    hrefIcon.css            5.6.5.2 (2013/06/21) 追加
113 *          useBlockUI      = "[true/false]"    jquery/blockUI.js       5.7.9.0 (2014/08/08) 追加
114 *          adjustEvent     = "[Bar|Matrix|Table|Gantt|Task]"       5.6.3.2 (2013/04/12) 追加
115 *          useTbodyMovable = "[false/true]"    option/ogTbodyMovable.js   5.6.3.3 (2013/04/19) 追加
116 *       > ... Body ...
117 *       </og:head>
118 *
119 * ●廃止属性(5.2.1.0 (2010/10/01))
120 *      //  useTimeSet      = "[true/false]"    timeSet.js , timeCheck.js
121 *      //  useToggleFrame  = "[true/false]"    toggleFrame.js      5.2.1.0 (2010/10/01) 廃止
122 *      //  useInputFocus   = "[true/false]"    inputFocus.js       4.3.5.0 (2009/02/01) 廃止
123 *      //  useHilightRow   = "[true/false]"    hilightRow.js       5.2.1.0 (2010/10/01) 廃止
124 *      //  usePrintLine    = "[true/false]"    printLine.js        5.2.1.0 (2010/10/01) 廃止
125 *      //  useAutoConvert  = "[true/false]"    autoConvert.js      5.2.1.0 (2010/10/01) 廃止
126 *      //  useFocusFirstElm= "[true/false]"    focusFirstElm.js    5.2.1.0 (2010/10/01) 廃止
127 *      //  useAdjustFrameHeight = "[true/false]" adjustFrameHeight 5.2.1.0 (2010/10/01) 廃止
128 *      //  useTabstrip     = "[false/true]"    option/tabstrip.js  5.9.1.3 (2015/10/30) 廃止
129 *
130 * @og.rev 4.0.0.0 (2007/04/16) 新規作成
131 * @og.rev 5.7.4.3 (2014/03/28) ソースコード大幅見直し
132 * @og.group その他
133 *
134 * @version  4.0
135 * @author   Kazuhiko Hasegawa
136 * @since    JDK5.0,
137 */
138public class HeadTag extends CommonTagSupport {
139        //* このプログラムのVERSION文字列を設定します。   {@value} */
140        private static final String VERSION = "5.7.9.0 (2014/08/08)" ;
141
142        private static final long serialVersionUID = 579020140808L ;
143
144        private static final String CR           = HybsSystem.CR;
145        private static final String JSP_ADRS = "/" + HybsSystem.getContextName() + "/jsp/" ;
146        private static final String JSP_DIR  = HybsSystem.sys( "REAL_PATH" ) + "jsp/" ;                 // 5.2.1.0 (2010/10/01)
147
148        /** adjustEvent 引数に渡す事の出来る 文字列リスト  */
149        private static final String ADJUST_EVENT_LIST = "|Bar|Matrix|Table|Gantt|Task|" ;               // 5.6.3.2 (2013/04/12)
150
151        // headType が null の場合、使用されるJavaScript,stylesheet (XMLタイプ以外すべて)
152        private static final String DEFAULT_CSS         = "common/default.css";
153        private static final String CALENDAR_CSS        = "common/calendar.css";
154        private static final String CUSTOM_CSS          = "custom/custom.css";
155
156        // init,query,result,menu 両タイプで使用されるJavaScript,stylesheet (null でなく、XML でないすべて)
157        private static final String JQUERY_JS           = "common/jquery/jquery.js";
158        private static final String JQUERY_OG_JS        = "common/jqog.js";
159        private static final String DEFAULT_JS          = "common/default.js";                                  // 5.2.1.0 (2010/10/01)
160        private static final String TABLINK_JS          = "common/option/tabLink.js";                   // useTabLink
161
162        // query,result 両タイプで使用されるJavaScript
163        private static final String EVENT_SCRIPT_JS             = "common/eventScript.js";                      // 5.2.1.0 (2010/10/01)
164        private static final String REAL_TIME_CHECK_FLG = "USE_REAL_TIME_CHECK";                        // 5.4.5.0 (2012/03/01)
165        private static final String FOCUS_HILIGHT_FLG   = "USE_FOCUS_HILIGHT";                          // 5.4.5.0 (2012/03/01)
166        private static final String HYBS_CAL_START_MON = "HYBS_CAL_START_MON";                          // 5.8.9.0 (2015/08/07)
167        
168        private boolean CALENDAR_START_MONDAY   = HybsSystem.sysBool( "CALENDAR_START_MONDAY" );        // 5.8.9.0 (2015/08/07)
169
170        private static final String JQUERY_FORM_JS              = "common/jquery/jquery.form.js";       // noTransition || useAjaxSubmit
171        private static final String JQUERY_DRAG_JS              = "common/jquery/jqDnR.js";                     // noTransition || useAjaxSubmit
172        private static final String JQUERY_MODAL_JS             = "common/option/jqModal.js";           // noTransition || useAjaxSubmit
173        private static final String JQUERY_MODAL_CSS    = "common/option/jqModal.css";          // noTransition || useAjaxSubmit
174
175        // query タイプで使用されるJavaScript
176        private static final String QUERY_SCRIPT_JS                     = "common/queryScript.js";              // 5.2.1.0 (2010/10/01)
177        private static final String QUERYCONV_SCRIPT_JS         = "common/queryConvert.js";             // 5.6.2.3 (2013/03/22) QUERYPRE_SCRIPT_JS   → QUERYCONV_SCRIPT_JS に変更
178        // 5.7.7.1 (2014/06/13) jquery.blockUI.js による検索中表示
179        private static final String JQUERY_BLOCKUI_JS           = "common/jquery/jquery.blockUI.js";    // useBlockUI
180        private static final String CUSTOM_BLOCKUI_JS           = "common/jquery/blockUI.js";                   // useBlockUI
181
182        // result タイプで使用されるJavaScript,stylesheet
183        private static final String SCROLL_BAR_JS               = HybsSystem.sys( "SCROLL_BAR_TYPE" ) + ".js";  // 4.3.5.0 (2009/02/01)
184        private static final String SCROLL_BAR_CSS              = HybsSystem.sys( "SCROLL_BAR_TYPE" ) + ".css"; // 4.3.5.0 (2009/02/01)
185
186        private static final String RESULT_SCRIPT_JS    = "common/resultScript.js";                     // 5.2.1.0 (2010/10/01)
187
188        private static final String GANTT_JS                    = "common/option/gantt.js";                             // useGantt
189        private static final String TREEBOM_JS                  = "common/option/treeBOM.js";                   // useTreeBOM
190        private static final String AJAX_TREETABLE_JS   = "common/option/ajaxTreeTable.js";             // useAjaxTreeTable
191        private static final String AJAX_HYBS_FORM              = "common/option/ajaxHybsForm.js";              // noTransition || useAjaxSubmit
192        private static final String NO_TRANSITION_JS    = "common/option/noTransition.js";              // noTransition
193        private static final String AJAX_SUBMIT_JS              = "common/option/ajaxSubmit.js";                // useAjaxSubmit
194
195        private static final String TBODY_MOVABLE_JS    = "common/option/ogTbodyMovable.js";    // 5.6.3.3 (2013/04/19) useTbodyMovable 
196
197        // 5.6.3.2 (2013/04/12) adjustEvent の引数に応じて、初期に組み込む script,css 群を定義します。
198        private static final String AJST_GANTT_JS               = "common/option/adjustGanttTable.js";                  // 5.6.3.2 (2013/04/12) adjustTable,adjustGant,adjustTask
199        private static final String AJST_GANTT_CSS              = "common/option/adjustGanttTable.css";                 // 5.6.3.2 (2013/04/12) adjustTable,adjustGant,adjustTask
200        private static final String AJST_BAR_JS                 = "common/option/adjustBar.js";                                 // 5.6.3.2 (2013/04/12) adjustBar
201        private static final String AJST_MATRIX_JS              = "common/option/adjustMatrix.js";                              // 5.6.3.2 (2013/04/12) adjustMatrix
202
203        private static final String HREF_ICON_CSS               = "common/hrefIcon.css";                                                // 5.6.5.2 (2013/06/21) useHrefIcon
204        
205        // 5.9.1.3 (2015/10/30) UIの制御追加
206        private static final String JQUERYUI_JS         = "common/jquery/jquery-ui.js";
207        private static final String JQUERYUI_CSS                = "common/jquery/jquery-ui.css";
208
209
210        // 4.2.1.0 (2008/04/16) htmlタグにクラスを付けるため、HEAD1と2に分離
211        // class名は"headtype"+headtype (IDの先頭は数字では駄目なのでheadtypeを付ける)
212        private static final String HEAD1 =
213                "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Frameset//EN\""       + CR
214                + "  \"http://www.w3.org/TR/html4/frameset.dtd\">"                           + CR
215                + "<html class=\"headtype-";
216
217        private static final String HEAD2 =
218                "\">"                                + CR
219                + "<head>"                        + CR
220                + "  <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />" + CR
221                + "  <meta http-equiv=\"Content-Style-Type\" content=\"text/css\" />"                     + CR
222                + "  <meta http-equiv=\"Content-Script-Type\" content=\"text/javascript\" />"     + CR;
223
224        // 5.7.1.0 (2013/12/06) HTML5 用のヘッダー1
225        // HTML5では、DOCTYPE宣言がなくなったのですが、無いとブラウザが、互換モードになる為入れておきます。
226        private static final String HTML5_HEAD1 =
227                "<!DOCTYPE html>" + CR
228                + "<html class=\"headtype-";
229
230        // 5.7.1.0 (2013/12/06) HTML5 用のヘッダー2
231        // HTML5では、content-style-type と Content-Script-Type も設定不要です。
232        private static final String HTML5_HEAD2 =
233                "\">"                                + CR
234                + "<head>"                        + CR
235                + "  <meta charset=\"UTF-8\" />" + CR ;
236
237        private static final String XML_HEAD =
238                "<?xml version=\"1.0\" encoding=\"UTF-8\" ?>"     + CR;
239
240        // 5.9.1.3 (2015/10/30) htsファイル利用をやめるので廃止
241//      private static final String TAB_HEAD =
242//              "<?xml version=\"1.0\" encoding=\"UTF-8\" ?>"     + CR
243//              + "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\"" + CR
244//              + "    \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">" + CR
245//              + "<html xmlns=\"http://www.w3.org/1999/xhtml\" xmlns:mp xmlns:ts >"      + CR
246//              + "<head>"                                                                                                                                + CR
247//              + "  <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />" + CR
248//              + "  <meta http-equiv=\"Content-Style-Type\" content=\"text/css\" />"                     + CR
249//              + "  <meta http-equiv=\"Content-Script-Type\" content=\"text/javascript\" />"     + CR
250//              + "  <?IMPORT NAMESPACE=\"mp\" IMPLEMENTATION=\""
251//              + JSP_ADRS + "common/option/multipage.htc\" />"                              + CR
252//              + "  <?IMPORT NAMESPACE=\"ts\" IMPLEMENTATION=\""
253//              + JSP_ADRS + "common/option/tabstrip.htc\" />"                               + CR;
254
255        // 4.3.7.0 (2009/06/01) IE8対応。IE7用Metaタグ追加
256        private static final String IE7_HEAD =
257                "  <meta http-equiv=\"X-UA-Compatible\" content=\"IE=EmulateIE7\" />" + CR;
258
259        // 5.5.8.0 (2012/11/01) タブレット対応
260        private static final String MOBILE_HEAD =
261                "  <meta content=\"width=device-width, initial-scale=1\" name=\"viewport\"/>" + CR;
262
263        // 5.2.1.0 (2010/10/01) キャッシュは、各ファイルのタイムスタンプベースで行う。
264        private static final Map<String,String> srcAdrs = new HashMap<String,String>();
265
266        // 5.7.4.3 (2014/03/28) headType="popup" 時に、BODY にINSERTする文字列。
267        // POPUPでは、自分自身にsubmiするため、base タグで target の記述が必要です。
268        private static final String POPUP_BODY = "<base target=\"_self\" />" ;
269
270        // 5.7.7.1 (2014/06/13) headType="result" 時に、BODY にINSERTする文字列。
271        // 5.7.8.1 (2014/07/18) 3ペイン等で、frame が多段階になっている場合の対応
272        // 5.8.7.1 (2015/05/22) fnUnblockUI 未定義エラーに対応(6.2.4.0対応の適用)
273        // 
274        private static final String UNBLOCKUI_READY
275//                                      =       "       $(function(){" + CR
276//                                      +       "               var qfrm=window.parent.frames['QUERY'];" + CR
277//                                      +       "               if(qfrm){ $(document).ready(function(){ qfrm.$.fnUnblockUI(); }); }" + CR
278//                                      +       "               else {" + CR
279//                                      +       "                       qfrm=window.parent.parent.frames['QUERY'];" + CR
280//                                      +       "                       if(qfrm){ $(document).ready(function(){ qfrm.$.fnUnblockUI(); }); }" + CR
281//                                      +       "               }" + CR
282//                                      +       "       });" ;
283                                        =       "       $(function(){" + CR
284                                        +       "               var qfrm=window.parent.frames['QUERY'];" + CR
285                                        +       "               if(qfrm == null) {" + CR
286                                        +       "                       qfrm=window.parent.parent.frames['QUERY'];" + CR
287                                        +       "               }" + CR
288                                        +       "               if( qfrm && qfrm.$.fnUnblockUI ) {" + CR
289                                        +       "                       $(document).ready(function(){ qfrm.$.fnUnblockUI(); });" + CR
290                                        +       "               }" + CR
291                                        +       "       });" ;
292
293        //enum化
294        // 5.7.4.3 (2014/03/28) frame,popup追加
295//      private enum HEAD_TYPE_ENUM { xml , init , query , result , menu , simple , handy };
296//      private enum HEAD_TYPE_ENUM { xml , init , query , result , menu , simple , handy , frame , popup };
297        // 5.7.8.1 (2014/07/18) 後処理を簡素化する為に、enum関数を作成
298        private enum HEAD_TYPE_ENUM {
299                        xml , init , query , result , menu , simple , handy , frame , popup ;
300
301                        public boolean into( final String str ) {
302                                return str != null && str.contains( this.name() );
303                        }
304        };
305
306        private String  body            = null;
307        private String  title           = null;
308        private HEAD_TYPE_ENUM headType = null;
309
310        private boolean useScrollBar    = true;
311//      private boolean useTabstrip             = false;        // 5.9.1.3 (2015/10/30) 廃止 jQUIで置換
312        private boolean useGantt                = false;
313        private boolean useTreeBOM              = false;
314        private boolean useGuest                = false;                                                                                        // 4.2.2.0 (2008/05/28)
315        private boolean useAjaxTreeTable= false;                                                                                        // 4.3.1.0 (2008/09/02)
316        private boolean noTransition    = HybsSystem.sysBool( "NO_TRANSITION_MODE" );           // 4.3.1.0 (2008/09/02)
317        private boolean useAjaxSubmit   = HybsSystem.sysBool( "USE_AJAX_SUBMIT" );
318        private boolean useRealTimeCheck= true;                                                                                         // 5.4.5.0 (2012/03/01)
319        private boolean useTabLink              = false;                                                                                        // 4.3.3.0 (2008/10/01)
320        private boolean useFocusHilight = true;                                                                                         // 5.4.5.0 (2012/03/01)
321        private boolean useHrefIcon             = false;                                                                                        // 5.6.5.2 (2013/06/21) 追加
322        private boolean useIE7Header    = HybsSystem.sysBool( "USE_IE7_HEADER" );                       // 4.3.7.0 (2009/06/01) IE8対応
323        private boolean useViewPort             = HybsSystem.sysBool( "USE_VIEWPORT_HEADER" );          // 5.5.8.0 (2012/11/01)
324        private boolean useBlockUI              = HybsSystem.sysBool( "VIEW_USE_BLOCKUI" );                     // 5.7.9.0 (2014/08/08)
325        private String  addEvent                = null;                                                                                         // 5.6.3.0 (2013/04/01) addEvent 追加
326        private String  adjustEvent             = null;                                                                                         // 5.6.3.2 (2013/04/12) adjustEvent 追加
327        private boolean useTbodyMovable = false;                                                                                        // 5.6.3.3 (2013/04/19) 新規追加
328
329        private boolean useHTML5                = HybsSystem.sysBool( "USE_HTML5_HEADER" );                     // 5.7.1.0 (2013/12/06) HTML5対応
330        
331        private boolean useJQUI                 = false;                                                                                        // 5.9.1.3 (2015/10/30) jQuery-UIの読み込み制御を追加する
332
333        // 5.2.1.0 (2010/10/01) キャッシュのクリアは、adminメニューの[プール削除]で可能
334        static {
335                final Cleanable clr = new Cleanable() {
336                        public void clear() {
337                                srcAdrs.clear();
338                        }
339                };
340                SystemManager.addCleanable( clr );
341        }
342
343        /**
344         * このタグハンドラの親(最も近くを囲んでいるタグハンドラ)を設定する
345         * setParent( Tag ) を オーバーライドします。
346         * この、オーバーライドは、カスタムタグのライフサイクルに基づき、
347         * 各種セッターメソッドの前に呼ばれる メソッドとして、利用しています。
348         *
349         * 目的は、sessionInit() メソッドの実行により、{&#064;SYS.XXXX} 変数を利用可能にすることです。
350         *
351         * @og.rev 4.3.4.1 (2008/12/08) 新規作成
352         *
353         * @param  tag タグハンドラの親
354         */
355        @Override
356        public void setParent( final Tag tag ) {
357                super.setParent( tag );
358                sessionInit() ;
359        }
360
361        /**
362         * Taglibの開始タグが見つかったときに処理する doStartTag() を オーバーライドします。
363         *
364         * @og.rev 4.2.1.0 (2008/04/16) headTypeのenum化
365         * @og.rev 4.3.4.1 (2008/12/08) sessionInit() を、setParent( Tag ) メソッドへ移動、title 属性の設定
366         * @og.rev 5.2.3.0 (2010/12/01) 画面アクセス履歴管理対応
367         *
368         * @return      後続処理の指示( EVAL_BODY_BUFFERED )
369         */
370        @Override
371        public int doStartTag() {
372                // 4.3.5.7 (2009/03/22) アクセスカウントの不具合対応。sessionInitから移動
373                if( headType == HEAD_TYPE_ENUM.result ) {
374                        GUIInfo guiInfo = (GUIInfo)getSessionAttribute( HybsSystem.GUIINFO_KEY );
375                        guiInfo.addAccessCount();
376                        // 5.2.3.0 (2010/12/01) 画面アクセス履歴管理対応
377                        UserInfo userInfo = (UserInfo)getSessionAttribute( HybsSystem.USERINFO_KEY );
378                        userInfo.setAccessGui( guiInfo );
379                }
380
381                HttpServletResponse response = (HttpServletResponse)pageContext.getResponse();
382                if( headType == HEAD_TYPE_ENUM.xml ) {
383                        response.setHeader( "contentType","text/xml; charset=UTF-8" );
384                }
385                response.setHeader( "Cache-Control","max-age=0" );
386
387                if( headType == HEAD_TYPE_ENUM.query ){
388                        removeSessionAttribute( HybsSystem.TBL_MDL_CONKEY );
389                }
390
391                // 4.3.4.1 (2008/12/08) title 属性を sessionInit() でなく、doStartTag() メソッドで処理
392                // title 属性を最優先で設定する。
393                if( title != null ) {
394                        setSessionAttribute( "GUI_TITLE", title );
395                }
396                else {
397                        title = String.valueOf( getSessionAttribute( "GUI_TITLE" ) );
398                }
399
400                return EVAL_BODY_BUFFERED ;     // Body を評価する。( extends BodyTagSupport 時)
401        }
402
403        /**
404         * Taglibのタグ本体を処理する doAfterBody() を オーバーライドします。
405         *
406         * @og.rev 5.7.4.3 (2014/03/28) headType="popup" 時は、BODY に、POPUP_BODY を出力します。
407         *
408         * @return      後続処理の指示(SKIP_BODY)
409         */
410        @Override
411        public int doAfterBody() {
412                // 5.7.4.3 (2014/03/28) headType="popup" 時は、BODY に、POPUP_BODY を出力します。
413                // そのため、すでに、body が書かれている場合の対応が必要です。
414//              body = nval( getBodyString(),null );
415
416                String tmpBody = nval( getBodyString(),null );
417
418                // tmpBody == null なら、body のままなので、処理無し。
419                if( tmpBody != null ) {
420                        body = (body == null) ? tmpBody : body + CR + tmpBody ;
421                }
422
423                return SKIP_BODY ;
424        }
425
426        /**
427         * Taglibの終了タグが見つかったときに処理する doEndTag() を オーバーライドします。
428         *
429         * @og.rev 4.2.1.0 (2008/04/16) headTypeのenum化、HTMLタグにclass属性を出力
430         * @og.rev 4.3.1.0 (2008/09/02) AJaxツリーテーブル、画面遷移なしモードの対応
431         * @og.rev 4.3.3.0 (2008/10/01) リアルタイムチェック時にjQueryをインクルード・tabLinkのJS追加
432         * @og.rev 4.3.5.0 (2009/02/01) JavaScript整理に伴う変更
433         * @og.rev 4.3.6.0 (2009/04/01) eventColumn追加
434         * @og.rev 4.3.8.0 (2009/08/01) useAjaxSubmit追加
435         * @og.rev 5.1.3.0 (2010/02/01) CSSは、headTypeがnullでもinclude(forward.jspでエラーが発生した場合への対応)
436         * @og.rev 5.1.3.0 (2010/02/01) noTransition,ajaxSubmitのコントロールは、requestで行う。
437         * @og.rev 5.2.0.0 (2010/09/01) Javaスクリプトで登録したイベントをイベントハンドラにバインドする
438         * @og.rev 5.2.1.0 (2010/10/01) bulkSet.js追加 、JavaScript の統合、廃止
439         * @og.rev 5.3.6.0 (2011/06/01) QUERYのFocusの制御を追加
440         * @og.rev 5.4.4.2 (2012/02/03) type simple追加
441         * @og.rev 5.4.5.0 (2012/03/01) realTimeCheck,focusHilight制御追加
442         * @og.rev 5.5.8.0 (2012/11/01) viewport
443         * @og.rev 5.6.0.3 (2013/01/24) EventScriptの前に呼ぶqueryScriptPre追加
444         * @og.rev 5.6.2.1 (2013/03/08) useGantt2="true" の条件追加
445         * @og.rev 5.6.2.3 (2013/03/22) QUERYPRE_SCRIPT_JS   → QUERYCONV_SCRIPT_JS に変更
446         * @og.rev 5.6.3.0 (2013/04/01) addEvent 追加。useGantt2="true" 時の処理内容と分離
447         * @og.rev 5.6.3.2 (2013/04/12) useGantt2 廃止。adjustEvent の引数で使い分ける。
448         * @og.rev 5.6.3.3 (2013/04/19) useTbodyMovable 追加
449         * @og.rev 5.7.1.0 (2013/12/06) HTML5対応 , handyタイプ追加 , 処理方法を変更。
450         * @og.rev 5.7.4.3 (2014/03/28) ソースコードのメンテナンス
451         * @og.rev 5.7.6.2 (2014/05/16) IEのHTML5機能が有効か無効かの判定値をsessionに設定します。
452         * @og.rev 5.7.7.1 (2014/06/13) blockUI 対応
453         * @og.rev 5.7.8.1 (2014/07/18) headType が、query でも、登録系もあるため、query.jsp のみ ON する。
454         * @og.rev 5.7.9.0 (2014/08/08) headType="query"の時は、RequestURI に含まれる場合のみ ON する。
455         * @og.rev 5.8.9.0 (2015/08/07) カレンダー用のJavaScript変数の出力
456         * @og.rev 5.9.1.3 (2015/10/30) jQueryUIの出力フラグ追加とuseTabstrip廃止
457         *
458         * @return      後続処理の指示
459         */
460        @Override
461        public int doEndTag() {
462                debugPrint();           // 4.0.0 (2005/02/28)
463
464                // 4.3.3.0 (2008/10/01) デフォルト値として、リクエストパラメーターを使用
465                noTransition  = nval( getRequest().getParameter( HybsSystem.NO_TRANSITION_MODE_KEY ), noTransition ) ;
466                useAjaxSubmit = nval( getRequest().getParameter( HybsSystem.USE_AJAX_SUBMIT_KEY ), useAjaxSubmit ) ;
467                // 4.3.8.0 (2009/08/01) useAjaxSubmit追加 noTransitionがtrueの場合はajaxSubmitはfalse
468                if( noTransition ) { useAjaxSubmit = false; }
469
470                setNoTransitionRequest( noTransition );
471                setAjaxSubmitRequest( useAjaxSubmit );
472
473                // if( headType == XML_TYPE ) { // 4.2.1.0 (2008/04/16)
474                if( headType == HEAD_TYPE_ENUM.xml ){
475                        jspPrint( XML_HEAD );
476                        return EVAL_PAGE ;              // ページの残りを評価する。
477                }
478                // 5.7.1.0 (2013/12/06) ======= ※ ここより下流には、HEAD_TYPE_ENUM.xml の headType は来ない。 =======
479
480                StringBuilder buf = new StringBuilder( HybsSystem.BUFFER_MIDDLE );
481
482                // 5.9.1.3 (2015/10/30) useTabstrip廃止
483//              if( useTabstrip ) { buf.append( TAB_HEAD ); }   // tabstrip 機能を使用する場合
484//              else {
485                // 5.7.1.0 (2013/12/06) HTML5対応
486                if( useHTML5 ) { buf.append( HTML5_HEAD1 ).append( headType ).append( HTML5_HEAD2 ); }
487                else           { buf.append( HEAD1       ).append( headType ).append( HEAD2       ); }
488//              }
489
490                // 4.3.7.0 (2009/06/01) IE8対応(IE7互換モード)
491                if( useIE7Header ){ buf.append ( IE7_HEAD ); }
492
493                // 5.5.8.0 (2012/11/01) タブレット等の画面サイズ調整METAタグ
494                if( useViewPort ){ buf.append( MOBILE_HEAD ); }
495
496                // titleの設定。もし、spanタグでマークアップされていれば、そのBODY部にtitleタグを追加します。
497                if( title.startsWith( "<span" ) ) {
498                        int adrs1 = title.indexOf( '>' );
499                        int adrs2 = title.length() - 7;         // </span> で終了しているはず。
500                        buf.append( title.substring( 0,adrs1+1 ) ).append( "<title>" );
501                        buf.append( title.substring( adrs1+1,adrs2 ) ).append( "</title>" );
502                        buf.append( title.substring( adrs2 ) );
503                }
504                else {
505                        buf.append( "  <title>" ).append( title ).append( "</title>" ).append( CR );
506                }
507
508                // 5.7.1.0 (2013/12/06) HEAD_TYPE_ENUM.handy の設定を終わらせてしまう。
509                if( headType == HEAD_TYPE_ENUM.handy ){
510                        // CALENDAR_CSS を組み込まない。
511                        addStyleTag(  DEFAULT_CSS       ,buf );
512                        addStyleTag(  CUSTOM_CSS        ,buf );
513                }
514
515                // 5.7.1.0 (2013/12/06) HEAD_TYPE_ENUM.simple と handy の設定を終わらせてしまう。
516                if( headType == HEAD_TYPE_ENUM.simple || headType == HEAD_TYPE_ENUM.handy ){
517                        // 以前は、useHrefIcon == true で、HREF_ICON_CSS を組み込んでいたが、組み込まない。
518
519                        // 注意:body の直前には、改行は入れないほうが良い。(Tomcat4.1.30 では)
520                        if( body != null ) { buf.append( body ); }
521                        buf.append( "</head>" );
522
523                        jspPrint( buf.toString() );
524                        return EVAL_PAGE ;              // ページの残りを評価する。
525                }
526                // 5.7.1.0 (2013/12/06) ======= ※ ここより下流には、HEAD_TYPE_ENUM.simple と handy headType は来ない。 =======
527
528                // 5.7.4.3 (2014/03/28) 処理の順番の関係で、イベント制御用JSフラグ出力 と入れ替えます。
529                addStyleTag( DEFAULT_CSS        ,buf );
530                addStyleTag( CALENDAR_CSS       ,buf );
531                addStyleTag( CUSTOM_CSS         ,buf );
532
533                // 5.4.5.0 (2012/03/01) イベント制御用JSフラグ出力
534                if( headType == HEAD_TYPE_ENUM.query || headType == HEAD_TYPE_ENUM.result ){
535                        buf.append( "  <script type=\"text/javascript\">" ).append( CR );
536                        addScriptFlg( REAL_TIME_CHECK_FLG ,useRealTimeCheck ,buf );
537                        addScriptFlg( FOCUS_HILIGHT_FLG   ,useFocusHilight  ,buf );
538                        addScriptFlg( HYBS_CAL_START_MON   ,CALENDAR_START_MONDAY  ,buf ); // 5.8.9.0 (2015/08/07)
539                        buf.append( "  </script>" ).append( CR );
540                }
541
542                // init,query,result,menu タイプで使用されるJavaScript
543                if ( headType != null ){
544                        addScriptTag( JQUERY_JS         ,buf ); // 4.3.5.0 (2009/02/01)
545                        addScriptTag( JQUERY_OG_JS      ,buf ); // 4.3.5.0 (2009/02/01)
546                        addScriptTag( DEFAULT_JS        ,buf );
547                        if( useTabLink ) { addScriptTag( TABLINK_JS     ,buf ); } // 4.3.3.0 (2008/10/01)
548                }
549
550                // 5.6.0.3 (2013/01/24) EventScrpt前に呼び出すquery専用スクリプト
551                if( headType == HEAD_TYPE_ENUM.query ){
552                        addScriptTag( QUERYCONV_SCRIPT_JS ,buf );
553                }
554
555                // query,result タイプで使用されるJavaScript
556                if( headType == HEAD_TYPE_ENUM.query || headType == HEAD_TYPE_ENUM.result ){
557                        addScriptTag( EVENT_SCRIPT_JS, buf );   // 5.2.1.0 (2010/10/01) JavaScript新規統合
558                        // 4.3.3.0 (2008/10/01)
559                        if( noTransition || useAjaxSubmit ){ // 4.3.8.0 (2009/08/01)
560                                addScriptTag( JQUERY_FORM_JS, buf );
561                                addScriptTag( JQUERY_DRAG_JS, buf );
562                                addScriptTag( JQUERY_MODAL_JS, buf );
563                                addStyleTag( JQUERY_MODAL_CSS, buf );
564                        }
565
566                        // 5.6.4.3 (2013/05/24) useTbodyMovable 付け忘れ
567                        if( useTbodyMovable ) {
568                                addScriptTag( TBODY_MOVABLE_JS, buf );          // 5.6.3.3 (2013/04/19) useTbodyMovable 追加
569                        }
570                }
571
572                // 5.7.7.1 (2014/06/13) blockUI は、HybsSystem.VIEW_USE_BLOCKUI が、true の場合のみ有効とする。
573//              boolean isBlockUi = HybsSystem.sysBool( "VIEW_USE_BLOCKUI" );
574//              boolean isBlockUi = HybsSystem.sysBool( "VIEW_USE_BLOCKUI" )
575//                                                              && headType != null
576//                                                              && headType.into( ((HttpServletRequest)getRequest()).getRequestURI() );
577
578                // 4.3.5.0 (2008/02/01) 位置を両タイプで利用される前のインクルードから後に変更
579                // query タイプで使用されるJavaScript
580                if( headType == HEAD_TYPE_ENUM.query ){
581                        addScriptTag( QUERY_SCRIPT_JS ,buf );   // 5.2.1.0 (2010/10/01) JavaScript新規統合
582
583                        // 5.3.6.0 (2011/06/01) QUERYのFocusの制御を追加
584                        boolean isFocus = nval( getRequestValue( HybsSystem.QUERY_FOCUS_KEY ), true );
585                        // 機能を利用しない場合のみ変数を出力
586                        if( !isFocus ) { addScriptValue( HybsSystem.QUERY_FOCUS_KEY, "false", buf ); }
587
588                        // 5.7.7.1 (2014/06/13) blockUI 対応
589                        // 5.7.9.0 (2014/08/08) headType="query"の時は、RequestURI に含まれる場合のみ ON する。
590//                      if( isBlockUi ) {
591                        if( useBlockUI && headType.into( ((HttpServletRequest)getRequest()).getRequestURI() ) ) {
592                                addScriptTag( JQUERY_BLOCKUI_JS ,buf );
593                                addScriptTag( CUSTOM_BLOCKUI_JS ,buf );
594                        }
595                }
596
597                // result タイプで使用されるJavaScript
598                if( headType == HEAD_TYPE_ENUM.result ) {
599                        addScriptTag( RESULT_SCRIPT_JS ,buf );  // 5.2.1.0 (2010/10/01) JavaScript新規統合
600
601                        if( useScrollBar        ) {
602                                                                        //  4.3.5.0 (2009/02/01) CSSも読み込む
603                                                                        addScriptTag( SCROLL_BAR_JS, buf );
604                                                                        addStyleTag ( SCROLL_BAR_CSS, buf );
605                        }
606                        if( useGantt            ) { addScriptTag( GANTT_JS                      ,buf ); }
607                        if( useTreeBOM          ) { addScriptTag( TREEBOM_JS            ,buf ); }
608                        if( useAjaxTreeTable) { addScriptTag( AJAX_TREETABLE_JS ,buf ); }               // 4.3.1.0 (2008/09/02)
609                        if( noTransition        ) {
610                                                                        addScriptTag( AJAX_HYBS_FORM    ,buf );                 // 4.3.8.0 (2009/08/01)
611                                                                        addScriptTag( NO_TRANSITION_JS  ,buf );
612                                                                  } // 4.3.1.0 (2008/09/02)
613                        if( useAjaxSubmit       ) {
614                                                                        addScriptTag( AJAX_HYBS_FORM    ,buf );
615                                                                        addScriptTag( AJAX_SUBMIT_JS    ,buf );
616                                                                  } // 4.3.8.0 (2009/08/01)
617
618                        // 5.6.3.2 (2013/04/12) useGantt2 廃止。adjustEvent の引数で使い分ける。
619                        if( adjustEvent != null ) {
620                                if( "Bar".equals( adjustEvent ) ) {
621                                        addScriptTag(   AJST_BAR_JS             ,buf );
622                                }
623                                else if( "Matrix".equals( adjustEvent ) ) {
624                                        addScriptTag(   AJST_MATRIX_JS  ,buf );
625                                }
626                                else if( "Table".equals( adjustEvent ) || "Gantt".equals( adjustEvent ) || "Task".equals( adjustEvent ) ) {
627                                        addStyleTag (   AJST_GANTT_CSS  ,buf );
628                                        addScriptTag(   AJST_GANTT_JS   ,buf );
629                                }
630                                addEventScript( "adjust" + adjustEvent  ,buf );
631                        }
632
633                        // 5.6.3.2 (2013/04/12) addEvent 追加 を、メソッド化
634                        addEventScript( addEvent,buf );
635
636                        // 5.7.6.2 (2014/05/16) IEのHTML5機能が有効か無効かの判定値をsessionに設定します。
637                        // result タイプ のみで有効にしておきます。
638                        String h_HTML5 = getRequest().getParameter( HybsSystem.IE_HTML5_KEY );
639                        if( h_HTML5 != null ) {
640                                setSessionAttribute( HybsSystem.IE_HTML5_KEY,h_HTML5 );
641                                // buf.append( "<div>IE_HTML5=" ).append( h_HTML5 ).append( "</div>" ).append( CR );
642                        }
643
644                        // 5.7.7.1 (2014/06/13) blockUI 対応
645                        if( useBlockUI ) {
646                                buf.append( "  <script type=\"text/javascript\">" ).append( CR );
647                                buf.append( UNBLOCKUI_READY ).append( CR );
648                                buf.append( "  </script>" ).append( CR );
649                        }
650                }
651
652                // 5.6.5.2 (2013/06/21) useHrefIcon
653                if( useHrefIcon ) {
654                        addStyleTag(  HREF_ICON_CSS     ,buf );
655                }
656                
657                // 5.9.1.3 (2015/10/30) useJQUI
658                if( useJQUI ){
659                        addScriptTag(   JQUERYUI_JS     ,buf );
660                        addStyleTag (   JQUERYUI_CSS    ,buf );
661                }
662
663                // 注意:body の直前には、改行は入れないほうが良い。(Tomcat4.1.30 では)
664                if( body != null ) {    buf.append( body ); }
665                buf.append( "</head>" );
666
667                jspPrint( buf.toString() );
668                return EVAL_PAGE ;              // ページの残りを評価する。
669        }
670
671        /**
672         * タグリブオブジェクトをリリースします。
673         * キャッシュされて再利用されるので、フィールドの初期設定を行います。
674         *
675         * @og.rev 5.2.1.0 (2010/10/01) JavaScript の統合、廃止
676         * @og.rev 5.4.5.0 (2012/03/01) realTimeCheck,focusHilight
677         * @og.rev 5.5.8.0 (2012/11/01) useViewPort  追加
678         * @og.rev 5.6.2.1 (2013/03/08) useGantt2  追加
679         * @og.rev 5.6.3.0 (2013/04/01) addEvent 追加
680         * @og.rev 5.6.3.2 (2013/04/12) useGantt2 廃止。adjustEvent の引数で使い分ける。
681         * @og.rev 5.6.3.3 (2013/04/19) useTbodyMovable 追加
682         * @og.rev 5.6.5.2 (2013/06/21) useHrefIcon 追加
683         * @og.rev 5.7.1.0 (2013/12/06) HTML5対応
684         * @og.rev 5.7.9.0 (2014/08/08) useBlockUI 追加
685         * @og.rev 5.9.1.3 (2015/10/30) useJQUI追加, useTabstrip廃止
686         */
687        @Override
688        protected void release2() {
689                super.release2();
690                body                    = null;
691                title                   = null ;
692                headType                = null;
693                useScrollBar    = true;
694//              useTabstrip             = false;                        // 5.9.1.3 (2015/10/30) 廃止
695                useGantt                = false;
696                useTreeBOM              = false;
697                useGuest                = false;                                                                                // 4.2.2.0 (2008/05/28)
698                useAjaxTreeTable= false;                                                                                // 4.3.1.0 (2008/09/02)
699                noTransition    = HybsSystem.sysBool( "NO_TRANSITION_MODE" );   // 4.3.1.0 (2008/09/02)
700                useAjaxSubmit   = HybsSystem.sysBool( "USE_AJAX_SUBMIT" );
701                useRealTimeCheck= true;                                                                                 // 5.4.5.0 (2012/03/01) 復活
702                useTabLink              = false;                                                                                // 4.3.3.0 (2008/10/01)
703                useFocusHilight = true;                                                                                 // 5.4.5.0 (2012/03/01) 復活
704                useHrefIcon             = false;                                                                                // 5.6.5.2 (2013/06/21) 追加
705                useIE7Header    = HybsSystem.sysBool( "USE_IE7_HEADER" );               // 4.3.7.0 (2009/06/01) IE8対応
706                useViewPort             = HybsSystem.sysBool( "USE_VIEWPORT_HEADER" );  // 5.5.8.0 (2012/11/01)
707                useBlockUI              = HybsSystem.sysBool( "VIEW_USE_BLOCKUI" );             // 5.7.9.0 (2014/08/08)
708                addEvent                = null;                                                                                 // 5.6.3.0 (2013/04/01) addEvent 追加
709                adjustEvent             = null;                                                                                 // 5.6.3.2 (2013/04/12) adjustEvent 追加
710                useTbodyMovable = false;                                                                                // 5.6.3.3 (2013/04/19) 新規追加
711                useHTML5                = HybsSystem.sysBool( "USE_HTML5_HEADER" );             // 5.7.1.0 (2013/12/06) HTML5対応
712                useJQUI                 = false;                                                                                // 5.9.1.3 (2015/10/30) 追加
713        }
714
715        /**
716         * スクリプトを制御するための変数文字列を作成します。
717         * JavaScriptのファイル統合によりファイルを行うか否かでは、機能のON/OFFを
718         * 行うことができません。
719         * このため、機能のON/OFFを制御するための変数を書き出して、JavaScript内で
720         * これをコントロールします。
721         * &lt;script type="text/javascript" &lt;!-- var (key)="(value)"; --&gt;&lt;/script&gt;
722         *
723         * @og.rev 5.3.6.0 (2011/06/01) 新規作成
724         *
725         * @param       key             JavaScript変数名
726         * @param       value   JavaScriptに渡す値
727         * @param       buf     指定文字列を追加する StringBuilder
728         *
729         * @return      追加されたStringBuilder
730         */
731        private StringBuilder addScriptValue( final String key, final String value, final StringBuilder buf ) {
732                if( value != null && value.length() > 0 ) {
733                        String tag = "  <script type=\"text/javascript\">"
734                                + " var " + key + "=\"" + value + "\"; </script>"
735                                + CR ;
736                        buf.append( tag );
737                }
738                return buf ;
739        }
740
741        /**
742         * スクリプトを制御するためのファイルをインクルードする文字列を作成します。
743         * ファイル名を指定して、JavaScriptの src 属性に設定した 文字列を作成します。
744         * ここで、作成するファイル名には、v=識別番号 のパラメータをセットします。
745         * 識別番号は、ファイルの最終更新時刻をセットします。これが取得できない場合は、
746         * BuildNumber.BUILD_ID を使用します。
747         * このキーで、ファイルが更新されるか、エンジンのバージョンが更新されると
748         * ブラウザキャッシュが更新されることになります。
749         *
750         * @og.rev 5.3.6.0 (2011/06/01) 新規作成
751         *
752         * @param       filename        JavaScriptファイル名
753         * @param       buf     指定文字列を追加する StringBuilder
754         *
755         * @return      追加されたStringBuilder
756         */
757        private StringBuilder addScriptTag( final String filename, final StringBuilder buf ) {
758                String tag = srcAdrs.get( filename );
759                if( tag == null ) {
760                        File file = new File( JSP_DIR + filename );
761                        // 5.6.2.1 (2013/03/08) ファイルの最終更新時刻が取得できない場合は、BuildNumber.BUILD_ID を使用
762                        long ts = file.lastModified();
763                        String tsv = (ts != 0L) ? String.valueOf( ts ) : BuildNumber.BUILD_ID ;
764
765                        tag = "  <script type=\"text/javascript\" src=\""
766                                        + JSP_ADRS
767                                        + filename
768                                        + "?v="
769                                        + tsv                                                                           // 5.6.2.1 (2013/03/08) 
770                                        + "\" ><!-- --></script>"
771                                        + CR ;
772                        srcAdrs.put( filename,tag );
773                }
774                buf.append( tag );
775                return buf ;
776        }
777
778        /**
779         * var xxx = true;のような文字列を作成します。
780         * xxxとtrue/falseを外部から与えます。
781         *
782         * @og.rev 5.4.5.0 (2012/03/01) 新規作成
783         *
784         * @param       var     変数名
785         * @param       flg     true/false
786         * @param       buf     指定文字列を追加する StringBuilder
787         *
788         * @return      追加されたStringBuilder
789         */
790        private StringBuilder addScriptFlg( final String var, final boolean flg, final StringBuilder buf ) {
791                buf.append( "    var ")
792                        .append( var )
793                        .append( " = ")
794                        .append( flg )
795                        .append( ";" )
796                        .append( CR );
797                return buf ;
798        }
799
800        /**
801         * stylesheetを制御するためのファイルをインクルードする文字列を作成します。
802         * ファイル名を指定して、stylesheetの href 属性に設定した 文字列を作成します。
803         * ここで、作成するファイル名には、v=識別番号 のパラメータをセットします。
804         * 識別番号は、ファイルの最終更新時刻をセットします。これが取得できない場合は、
805         * BuildNumber.BUILD_ID を使用します。
806         * このキーで、ファイルが更新されるか、エンジンのバージョンが更新されると
807         * ブラウザキャッシュが更新されることになります。
808         *
809         * @og.rev 5.3.6.0 (2011/06/01) 新規作成
810         *
811         * @param       filename        stylesheetファイル名
812         * @param       buf     指定文字列を追加する StringBuilder
813         *
814         * @return      追加されたStringBuilder
815         */
816        private StringBuilder addStyleTag( final String filename, final StringBuilder buf ) {
817                String tag = srcAdrs.get( filename );
818                if( tag == null ) {
819                        File file = new File( JSP_DIR + filename );
820                        // 5.6.2.1 (2013/03/08) ファイルの最終更新日が取得できない場合は、BuildNumber.BUILD_ID を使用
821                        long ts = file.lastModified();
822                        String tsv = (ts != 0L) ? String.valueOf( ts ) : BuildNumber.BUILD_ID ;
823
824                        tag = "  <link rel=\"stylesheet\" type=\"text/css\" href=\""
825                                        + JSP_ADRS
826                                        + filename
827                                        + "?v="
828                                        + tsv                                                                           // 5.6.2.1 (2013/03/08) 
829                                        + "\" />"
830                                        + CR ;
831                        srcAdrs.put( filename,tag );
832                }
833                buf.append( tag );
834                return buf ;
835        }
836
837        /**
838         * addEvent でJavaScript をロードする処理を行う文字列を作成します。
839         * イベント名を外部から与えます。
840         *
841         * @og.rev 5.6.3.2 (2013/04/12) 新規作成
842         *
843         * @param       event   イベント名
844         * @param       buf     指定文字列を追加する StringBuilder
845         *
846         * @return      追加されたStringBuilder
847         */
848        private StringBuilder addEventScript( final String event, final StringBuilder buf ) {
849                if( event != null && event.length() > 0 ) {
850                        buf.append( "  <script type=\"text/javascript\"> addEvent( this, \"load\", " )
851                                .append( event )
852                                .append( " ); </script>" )
853                                .append( CR );
854                }
855                return buf ;
856        }
857
858        /**
859         * セッションの初期処理を行います。
860         * common/session_init.jsp をタグに組み込みました。
861         *
862         * @og.rev 3.8.0.0 (2005/06/07) 同一セッションでのマルチ起動対策を行います。
863         * @og.rev 3.8.0.4 (2005/08/08) custom を呼び出せるように追加
864         * @og.rev 3.8.1.2 (2005/12/19) 認証無しの場合のユーザー制御修正
865         * @og.rev 4.0.0.0 (2007/10/18) メッセージリソース統合( getResource().getMessage ⇒ getResource().getLabel )
866         * @og.rev 4.0.0.0 (2007/10/31) ロール指定でのログイン機能追加
867         * @og.rev 4.2.1.0 (2008/04/16) headTypeのenum化
868         * @og.rev 4.2.2.0 (2008/05/28) GUESTユーザの復活
869         * @og.rev 4.2.4.1 (2008/07/08) pageContext.include時にflushしないように修正
870         * @og.rev 4.3.3.1 (2008/10/08) システムパラメータの初期値設定は userInfo 作成ブロックの外で行うように変更します。
871         * @og.rev 4.3.4.1 (2008/12/08) title 属性を使用しなくします。(doStartTag() メソッドで処理)
872         * @og.rev 5.1.4.0 (2010/03/01) lang を書き換え可能とする。
873         * @og.rev 5.1.8.0 (2010/07/01) useGuest属性が有効にならないバグを修正。
874         * @og.rev 5.1.8.0 (2010/07/01) ユーザーIDの大文字・小文字を区別する(大文字化を廃止)
875         * @og.rev 5.2.0.0 (2010/09/01) アクセス禁止アドレスによる不正アクセス防止機能追加
876         */
877        private void sessionInit() {
878                HttpSession session = pageContext.getSession();
879                HttpServletRequest request = (HttpServletRequest)pageContext.getRequest();
880
881                // 3.5.3.0 (2003/10/27) encode.jsp 廃止
882                try {
883                        request.setCharacterEncoding( "UTF-8" );
884                }
885                catch (UnsupportedEncodingException ex) {
886                        throw new HybsSystemException( ex );
887                }
888
889                // 3.8.0.0 (2005/06/07) 同一セッションでのマルチ起動対策を行います。
890                String cntR = request.getParameter( HybsSystem.MULTI_SESSION_CHECK );
891                if( cntR != null ) {
892                        String cntS = (String)session.getAttribute( HybsSystem.MULTI_SESSION_CHECK );
893                        if( cntS != null && !cntR.equals( cntS ) ) {
894                                ResourceManager resource = ResourceFactory.newInstance( request.getLocale().getLanguage() );
895
896                                StringBuilder buf = new StringBuilder( HybsSystem.BUFFER_MIDDLE );
897                                buf.append( resource.getLabel( "ERR0035.T" ) ).append( HybsSystem.CR );
898                                buf.append( resource.getLabel( "ERR0035.1" ) ).append( HybsSystem.CR );
899                                buf.append( resource.getLabel( "ERR0035.2" ) ).append( HybsSystem.CR );
900                                buf.append( resource.getLabel( "ERR0035.3" ) ).append( HybsSystem.CR );
901
902                                throw new HybsSystemException( buf.toString() );
903                        }
904                }
905
906                // システムパラメータの初期値設定
907                // 4.3.3.1 (2008/10/08) 戻るリンクの不具合対応で、後方の userInfo 作成ブロックの外に出してくる。
908                if( ! HybsSystem.isParamSet() ) {
909                        String  serverName      = request.getServerName();
910                        String  scheme          = request.getScheme();
911                        int             port            = request.getServerPort();
912                        String  contextPath = request.getContextPath();
913
914                        HybsSystem.setRequestParam( serverName,scheme,port,contextPath );
915                }
916
917                // 3.3.0.0 (2003/06/23) 操作途中以外でのセッション切断に対応。
918                // ログイン時の初期化を行います。
919                UserInfo userInfo = (UserInfo)getSessionAttribute( HybsSystem.USERINFO_KEY );
920                String userID = request.getRemoteUser() ;
921
922                // 3.8.1.2 (2005/12/19)
923                if( userInfo == null || ( userID != null && ! userID.equalsIgnoreCase( userInfo.getUserID() ))) {
924                // セッションタイムアウトの確認 command が、null,"NEW","INIT" 以外は、エラー
925                        String command = request.getParameter( "command" );
926                        if( command == null || "NEW".equals( command ) || "INIT".equals( command ) ) {
927                                if( userID == null ) {
928                                        // 4.2.2.0 (2008/05/28) GUESTユーザ復活(useGuestで制御)
929                                        // 5.1.8.0 (2010/07/01) useGuest属性が有効にならないバグを修正。
930                                        userID = "GUEST" ;              // 認証されていない場合は、強制的に GUESTユーザー
931                                }
932                                userInfo = UserInfoFactory.newInstance( userID,request.getRemoteAddr(),request.getParameter( "ROLES" ) );
933
934                                // 5.1.4.0 (2010/03/01) lang を書き換え可能とする。
935                                String newLang = request.getParameter( "NEWLANG" ) ;
936                                if( newLang != null ) { userInfo.setLang( newLang ); }
937
938                                session.setAttribute( HybsSystem.USERINFO_KEY, userInfo );
939
940                                // セッションタイムアウトを変更
941                                session.setMaxInactiveInterval( HybsSystem.sysInt( "MAX_INACTIVE_INTERVAL" ) );
942                                SystemManager.addSession( session );
943
944                                try {
945                                        // 4.2.4.1 (2008/07/08)
946                                        pageContext.include( "/jsp/custom/init.jsp", false );
947                                } catch ( IOException ex ) {
948                                        String errMsg = "/jsp/custom/init.jsp の include に失敗しました。 " + toString();
949                                        throw new HybsSystemException( errMsg,ex );             // 3.5.5.4 (2004/04/15) 引数の並び順変更
950                                } catch ( ServletException ex ) {
951                                        String errMsg = "/jsp/custom/init.jsp の include に失敗しました。 " + toString();
952                                        throw new HybsSystemException( errMsg,ex );             // 3.5.5.4 (2004/04/15) 引数の並び順変更
953                                }
954                        }
955                        else {
956                                ResourceManager resource = ResourceFactory.newInstance( request.getLocale().getLanguage() );
957
958                                // エラー表示ページを表示する。4.0.0 (2005/01/31)
959                                String msg = String.valueOf( HybsSystem.sysInt( "MAX_INACTIVE_INTERVAL" ) ) ;
960
961                                // ERR0002.T=ユーザーログインエラー
962                                // ERR0002.1=セッションのタイムアウトか,またはユーザーログインエラーが発生しました。
963                                // ERR0002.2=現在のタイムアウトは {0} 秒にセットされています。
964                                // ERR0002.3=長時間使用しない場合は,画面を閉じる事により,サーバー側の負荷を軽減する事ができます。
965                                // ERR0002.4=<h2>もう一度,ログインし直して下さい。</h2>
966
967                                StringBuilder buf = new StringBuilder( HybsSystem.BUFFER_MIDDLE );
968                                buf.append( resource.getLabel( "ERR0002.T" ) ).append( HybsSystem.CR );
969                                buf.append( resource.getLabel( "ERR0002.1" ) ).append( HybsSystem.CR );
970                                buf.append( resource.getLabel( "ERR0002.2",new String[] { msg } ) ).append( HybsSystem.CR );
971                                buf.append( resource.getLabel( "ERR0002.3" ) ).append( HybsSystem.CR );
972                                buf.append( resource.getLabel( "ERR0002.4" ) ).append( HybsSystem.CR );
973
974                                throw new HybsSystemException( buf.toString() );                // 4.0.0 (2005/01/31)
975                        }
976                }
977
978                boolean useGamenId = false;
979                String gamenId = request.getParameter( "GAMENID" );
980                String requestURI = request.getRequestURI();
981
982                int index2 = requestURI.lastIndexOf( '/' );
983                String jspID   = requestURI.substring( index2+1 );
984                if( gamenId == null ) {
985                        int index1 = requestURI.lastIndexOf( '/',index2-1 );
986                        gamenId = requestURI.substring( index1+1,index2 );
987                }
988                else {
989                        useGamenId = true;
990                }
991
992                ResourceManager resource = ResourceFactory.newInstance( userInfo.getLang() );
993                // 4.0.0 (2004/12/31)
994                if( ! userInfo.isGUIInfoSet() ) {
995                        resource.makeGUIInfos( userInfo );
996                }
997
998                GUIInfo guiInfo = null;
999                String gui_title ;
1000                // 3.8.0.4 (2005/08/08) custom を呼び出せるように追加
1001                if( "menu".equals( gamenId ) || "jsp".equals( gamenId ) || "custom".equals( gamenId ) || "common".equals( gamenId ) ) {
1002                        // 3.5.4.5 (2004/01/23) トップメニューの設定
1003                        // 4.3.4.1 (2008/12/08) title 属性を使用しなくします。(doStartTag() メソッドで処理)
1004                        gui_title = HybsSystem.sys( "GUI_TOP_TITLE" );
1005                        if( gui_title == null ) { gui_title = "Hayabusa " + gamenId ; }
1006                }
1007                else {
1008                        guiInfo = userInfo.getGUIInfo( gamenId );               // 4.0.0 (2004/12/31)
1009
1010                        if( guiInfo != null ) {
1011                                session.setAttribute( HybsSystem.GUIINFO_KEY, guiInfo );
1012                                session.setAttribute( "JSPID", jspID );
1013                        }
1014                        else {
1015                                // エラー表示ページを表示する。4.0.0 (2005/01/31)
1016                                String msg = userInfo.getJname();
1017
1018                                StringBuilder buf = new StringBuilder( HybsSystem.BUFFER_MIDDLE );
1019                                buf.append( resource.getLabel( "ERR0003.T" ) ).append( HybsSystem.CR );
1020                                buf.append( resource.getLabel( "ERR0002.1",new String[] { msg } ) ).append( HybsSystem.CR );
1021                                buf.append( resource.getLabel( "ERR0002.2" ) ).append( HybsSystem.CR );
1022
1023                                throw new HybsSystemException( buf.toString() );                // 4.0.0 (2005/01/31)
1024                        }
1025
1026                        // 画面のタイトルをリクエスト変数でも指定できるようにします。
1027                        // 相当、やっつけ仕事が入っていますが、必ず見直します。
1028                        // 4.3.4.1 (2008/12/08) title 属性を使用しなくします。(doStartTag() メソッドで処理)
1029                        gui_title = request.getParameter( "GUI_TITLE" );
1030                        if( gui_title == null || gui_title.length() == 0 ) {
1031                                String cmd = request.getParameter( "command" );
1032                                if( cmd == null || cmd.equals( "NEW" ) ||
1033                                         cmd.equals( "RENEW" ) || cmd.equals( "INIT" ) ||
1034                                         cmd.equals( "RESET" ) || cmd.length() == 0  ) {
1035                                        gui_title = guiInfo.getLongName();
1036                                }
1037                        }
1038                }
1039
1040                // 5.2.0.0 (2010/09/01) アクセス禁止アドレスによる不正アクセス防止機能追加
1041                if( useGamenId ) {
1042                        int idx1 = requestURI.lastIndexOf( "/jsp/" ) + 5;
1043                        int idx2 = requestURI.lastIndexOf( '/' );
1044                        if( idx1 >= 0 && idx2 >= 0 && idx1 < idx2 ) {
1045                                String reqAddr = requestURI.substring( idx1, idx2 );
1046                                if( reqAddr.indexOf( '/' ) < 0 && !userInfo.isValidAddr( reqAddr ) ) {
1047                                        String msg = userInfo.getJname();
1048                                        StringBuilder buf = new StringBuilder( HybsSystem.BUFFER_MIDDLE );
1049                                        buf.append( resource.getLabel( "ERR0003.T" ) ).append( HybsSystem.CR );
1050                                        buf.append( resource.getLabel( "ERR0002.1",new String[] { msg } ) ).append( HybsSystem.CR );
1051                                        throw new HybsSystemException( buf.toString() );
1052                                }
1053                        }
1054                }
1055
1056                // 4.3.4.1 (2008/12/08) title 属性を使用しなくします。(doStartTag() メソッドで処理)
1057                if( gui_title != null ) {
1058                        session.setAttribute( "GUI_TITLE", gui_title );
1059                }
1060        }
1061
1062        /**
1063         * 【TAG】HTML の タイトルを設定します(初期値:session に"GUI_TITLE" キーで登録されている値)。
1064         *
1065         * @og.tag
1066         *  head タグのBody部に、title タグを設定します。
1067         * &lt;title&gt;タイトル &lt;/title&gt; を追加します。
1068         * 設定は、このタグでの指定が最優先されます。次に、リクエスト情報の
1069         * GUI_TITLE があれば、使用されます。最後に、初期値である、session の
1070         * "GUI_TITLE" キーで登録されている値を使用します。
1071         * session に登録されている値とは、GUIリソースで定義された、名前(長)です。
1072         *
1073         * 初期値は、session に"GUI_TITLE" キーで登録されている値です。
1074         * トップメニューのタイトルは、システムパラメータ の、GUI_TOP_TITLE キー
1075         * で登録されている値です。
1076         *
1077         * @param       titl    タイトル
1078         */
1079        public void setTitle( final String titl ) {
1080                title = nval( getRequestParameter( titl ),title );
1081        }
1082
1083        /**
1084         * 【TAG】ヘッダータイプを設定します(初期値:null)。
1085         *
1086         * @og.tag
1087         * ヘッダータイプ とは、個別の設定をしなくても、基本的なバリエーションを
1088         * 簡易的に設定する場合に使用するキーワードです。
1089         * ここでは、null,xml,init,query,result,menu,simple,handy,frame,popup の指定できます。
1090         * query を指定すると、query.jsp で使用する基本的な設定を再現できます。
1091         * timeSet.js , toggleFrame.js , inputFocus.js が標準で設定されます。
1092         * result も同様で、result.jsp で使用する基本的な設定を再現できます。
1093         * hilightRow.js , ScrollBar.js , printLine.js ,
1094         * timeCheck.js , inputFocus.js が標準で設定されます。
1095         * inputFocus.js に関しては、query,result 両タイプとも設定されます。
1096         * init の場合は、通常はユーザーに見えない画面ですが、登録時エラーで
1097         * 処理が停止する場合があり、CSSファイルのみ組み込む必要があります。
1098         * menu はmultiMenu.jsp等のメニュー画面用の設定です。
1099         * なにも指定しない場合(null)では、index.jsp , forward.jsp などの、
1100         * 直接画面に表示されないタイプのヘッダーになります。
1101         * simple は何もインクルードしないタイプです。携帯電話用画面等でdefault.css
1102         * すらインクルードしたくないが、JSPの作りは同じにしておきたい場合に利用します。
1103         * xml は、Webサービスや、Ajax などで使用する XML レスポンス用の
1104         * 特別なヘッダーを作成します。
1105         * handy は、ハンディーターミナル等の必要最小限のインクルードを行います。
1106         * frame は、index.jsp を想定した、HTML5適用時に、frameset を使う箇所のみHTML4 のタグを出力します。
1107         * popup は、popup.jsp を想定した、キーワードですが、現時点では、result + baseタグ出力です。
1108         * 初期値は、null です。
1109         *
1110         * @og.rev 4.2.1.0 (2008/04/16) headTypeのenum化に伴う変更
1111         * @og.rev 5.4.4.2 (2012/02/03) simpleタイプ追加
1112         * @og.rev 5.7.1.0 (2013/12/06) handyタイプ追加(JavaDoc修正)
1113         * @og.rev 5.7.4.3 (2014/03/28) frame,popup追加
1114         *
1115         * @param       type    ヘッダータイプ(null,xml,init,query,result,handy)
1116         */
1117        public void setHeadType( final String type ) {
1118                String hType = nval( getRequestParameter( type ),null );
1119                if( "null".equals( hType )){ // nullを入れた時
1120                        hType = null;
1121                }
1122                if( hType != null ) {
1123                        try {
1124                                headType = HEAD_TYPE_ENUM.valueOf( hType );
1125                        }
1126                        catch (IllegalArgumentException  iaex) {
1127                                StringBuilder errBuf = new StringBuilder(100);
1128                                errBuf.append( "headType は" );
1129                                for( HEAD_TYPE_ENUM obj : HEAD_TYPE_ENUM.values() ) {
1130                                        errBuf.append( ',' );
1131                                        errBuf.append( obj.name() );
1132                                }
1133                                errBuf.append("から選んでください。");
1134                                throw new HybsSystemException( errBuf.toString(),iaex );        // 4.3.1.1 (2008/08/23)
1135                        }
1136                }
1137
1138                // 5.7.4.3 (2014/03/28) headType="frame" 時は、従来のHTML4 を出力します。
1139                if( headType == HEAD_TYPE_ENUM.frame ) {
1140                        useHTML5 = false;
1141                        // index.jsp を想定しているため、従来の headType=null と同じ動きをさせます。
1142                        headType = null;
1143                }
1144
1145                // 5.7.4.3 (2014/03/28) headType="popup" 時は、BODY に、POPUP_BODY を出力します。
1146                if( headType == HEAD_TYPE_ENUM.popup ) {
1147                        body = POPUP_BODY ;
1148                        // popup は、query.jsp と result.jsp を合成するが、result と同じでよい。
1149                        headType = HEAD_TYPE_ENUM.result;
1150                }
1151        }
1152
1153        /**
1154         * 【TAG】ScrollBar.js JavaScript を使用するかどうか[true/false]を指定します(初期値:true)。
1155         *
1156         * @og.tag
1157         * 標準組み込みJavaScriptである、ScrollBar.js を使用するかどうかを指定します。
1158         * (従来のTYPE2です。)
1159         * result タイプで有効です。
1160         * 初期値は、使用する(true)です。
1161         *
1162         * @param       flag    使用するかどうか [true:使用する/false:使用しない]
1163         */
1164        public void setUseScrollBar( final String flag ) {
1165                useScrollBar = nval( getRequestParameter( flag ),useScrollBar );
1166        }
1167
1168        /**
1169         * 【TAG】tabstrip.js JavaScript を使用するかどうか[true/false]を指定します(初期値:false)。
1170         *
1171         * @og.tag
1172         * 標準組み込みJavaScriptである、tabstrip.js を使用するかどうかを指定します。
1173         * init,query,result タイプで有効です。
1174         * この機能は特別な為、初期値は、使用しない(false)です。
1175         *
1176         * @param       flag    使用するかどうか [true:使用する/false:使用しない]
1177         * @deprecated 廃止します。互換性のためuseJQUIと同じ意味を持たせています。
1178         */
1179        @Deprecated public void setUseTabstrip( final String flag ) {
1180//              useTabstrip = nval( getRequestParameter( flag ),useTabstrip );
1181                useJQUI = nval( getRequestParameter( flag ),useJQUI );
1182        }
1183
1184        /**
1185         * 【TAG】option/gantt.js JavaScript を使用するかどうか[true/false]を指定します(初期値:false)。
1186         *
1187         * @og.tag
1188         * 標準組み込みJavaScriptである、option/gantt.js を使用するかどうかを指定します。
1189         * result タイプで有効です。
1190         * この機能は特別な為、初期値は、使用しない(false)です。
1191         *
1192         * @param       flag    使用するかどうか [true:使用する/false:使用しない]
1193         */
1194        public void setUseGantt( final String flag ) {
1195                useGantt = nval( getRequestParameter( flag ),useGantt );
1196        }
1197
1198        /**
1199         * 【TAG】option/treeBOM.js JavaScript を使用するかどうか[true/false]を指定します(初期値:false)。
1200         *
1201         * @og.tag
1202         * 標準組み込みJavaScriptである、option/treeBOM.js を使用するかどうかを指定します。
1203         * result タイプで有効です。
1204         * この機能は特別な為、初期値は、使用しない(false)です。
1205         *
1206         * @param       flag    使用するかどうか [true:使用する/false:使用しない]
1207         */
1208        public void setUseTreeBOM( final String flag ) {
1209                useTreeBOM = nval( getRequestParameter( flag ),useTreeBOM );
1210        }
1211
1212        /**
1213         * 【TAG】ゲストユーザを利用するかどうか[true/false]を指定します(初期値false)。
1214         *
1215         * @og.tag
1216         *
1217         * ユーザIDが指定されていなかった場合にユーザのIDをGUESTとしてログインさせるかを指定します。
1218         * TOMCATの認証機能を外した領域でユーザを限定せずにログインさせたい場合等に利用します。
1219         * なお、システム定数RESOURCE_USER_SQLで帰ってくる結果に「GUEST」IDのユーザが必要です。
1220         * 初期値はfalse(利用しない)となります。
1221         *
1222         * @param       flag    ゲストユーザを使用するかどうか [true:使用する/false:使用しない]
1223         *
1224         * @og.rev 4.2.2.0 (2008/05/28) 新規作成
1225         */
1226        public void setUseGuest( final String flag ) {
1227                useGuest = nval( getRequestParameter( flag ),useGuest );
1228        }
1229
1230        /**
1231         * 【TAG】Ajaxを利用したツリー形式のテーブル表示を使用するかを指定します。
1232         *
1233         * @og.tag
1234         * Ajaxを利用したツリー形式のテーブル表示を使用するかを指定します。
1235         * viewタグのviewFormType="HTMLAjaxTreeTable"を使用する場合は、必ずtrueを指定して下さい。
1236         *
1237         * また、ツリー形式のテーブルに対して登録を行う場合は、noTransition属性も
1238         * 同時にtrueにしておく必要があります。
1239         *
1240         * 初期値は、false(使用しない)です。
1241         *
1242         * @og.rev 4.3.1.0 (2008/09/02) 新規追加
1243         *
1244         * @param   flag Ajaxを利用したツリー形式のテーブル表示を使用するか
1245         */
1246        public void setUseAjaxTreeTable( final String flag ) {
1247                useAjaxTreeTable = nval( getRequestParameter( flag ), useAjaxTreeTable );
1248        }
1249
1250        /**
1251         * 【TAG】画面遷移を行わない形式の登録方法を使用するかを指定します
1252         *              (初期値:NO_TRANSITION_MODE[={@og.value org.opengion.hayabusa.common.SystemData#NO_TRANSITION_MODE}])。
1253         *
1254         * @og.tag
1255         * 画面遷移なしの登録を行うかどうかを指定します。
1256         * trueが指定された場合、画面遷移を行わず選択行のみを動的に切り替えることで、
1257         * 編集、登録を行います。サーバーへのデータ送信には、jQueryのFormPluginを
1258         * 利用しています。
1259         * また、データを送信する対象のフォームには、id="noTransition"を指定して下さい。
1260         * (該当のIDのフォームが存在しない場合は、JSPの1番目のフォームが送信されます。)
1261         * (初期値:システム定数のNO_TRANSITION_MODE[={@og.value org.opengion.hayabusa.common.SystemData#NO_TRANSITION_MODE}])。
1262         *
1263         * システムパラメーターまたは、このタグの属性でtrueに指定された場合でも、submitされた
1264         * commandがINSERT,COPY,MODIFY,DELETE,ENTRY,UNDOの場合のみ、バックグラウンドで
1265         * 実行されます。
1266         * それ以外のコマンドでは通常通り、画面遷移を伴うsubmitとなります。
1267         *
1268         * また、システムパラメーターまたは、このタグの属性でtrueに指定された場合、バックグラウンド
1269         * で実行されるJSPには、その値が引き継がれるため、これらのJSPの各タグでtrueを指定する
1270         * 必要はありません。
1271         *
1272         * @og.rev 4.3.1.0 (2008/09/02) 新規追加
1273         * @og.rev 4.3.8.0 (2009/08/01) noTransitionにnullを許容する
1274         * @og.rev 5.1.3.0 (2010/02/01) リクエストに戻す
1275         *
1276         * @param   noTrnstn 画面遷移を行わない形式の登録方法を使用するか
1277         */
1278        public void setNoTransition( final String noTrnstn ) {
1279                noTransition = nval( getRequestParameter( noTrnstn ), noTransition );
1280        }
1281
1282        /**
1283         * 【TAG】og:tabLinkタグで使用される common/tagLink.js をインクルードするかどうか[true/false]を指定します(初期値:false)。
1284         *
1285         * @og.tag
1286         * og:tabLinkタグで使用される common/tagLink.js をインクルードするかを指定します。
1287         * trueが指定された場合、該当のJavaScriptをインクルードします。
1288         * og:tabLinkを使用する場合は、必ずtrueを指定して下さい。
1289         * 初期値は、false(インクルードしない)です。
1290         *
1291         * @og.rev 4.3.3.0 (2008/10/01) 新規追加
1292         *
1293         * @param   flag common/tagLink.js をインクルード [true:する/false:しない]
1294         */
1295        public void setUseTabLink( final String flag ) {
1296                useTabLink = nval( getRequestParameter( flag ), useTabLink );
1297        }
1298
1299        /**
1300         * 【TAG】カラムチェックをリアルタイムで行うかどうか[true/false]を指定します(初期値:true)。
1301         *
1302         * @og.tag
1303         * &lt;del&gt;common/realTimeCheck.jsをインクルードするかの指定です。
1304         * インクルードするとカラムチェックがリアルタイムで行われます。
1305         * (フォーカスが離れた時に動作)
1306         * &lt;del&gt;
1307         * リアルタイムチェックイベントを無効にするかどうかを決めます。
1308         * falseを指定すると、リアルタイムチェックを行いません。
1309         * query,result 両タイプで有効です。
1310         * このチェックはDBTypeを用いた簡易的なチェックです。
1311         * チェックにかかった場合はバルーンで警告が表示されます。
1312         * &lt;del&gt;初期値は、システムリソースのUSE_REAL_TIME_CHECKで設定することが可能です。&lt;del&gt;
1313         * 初期値はtrue(利用する)です。
1314         *
1315         * @og.rev 4.3.5.0 (2009/02/01) 新規追加
1316         * @og.rev 5.2.1.0 (2010/10/01) JavaScript の統合、廃止
1317         * @og.rev 5.4.5.0 (2012/03/01) 復活 ローカルリソース時等で使いたくない場合がある
1318         *
1319         * @param   flag common/realTimeCheck.jsをインクルード [true:する/false:しない]
1320         */
1321        public void setUseRealTimeCheck( final String flag ) {
1322                useRealTimeCheck = nval( getRequestParameter( flag ), useRealTimeCheck );
1323        }
1324
1325        /**
1326         * 【TAG】フォーカスが当っている入力ボックスの色を変更するかどうか[true/false]を指定します(初期値:true)。
1327         *
1328         * @og.tag
1329         * &lt;del&gt;標準組み込みJavaScriptである、focusHilight.jsをインクルードするかの指定です。
1330         * フォーカスが当っている入力ボックスの背景色を変更します。
1331         * インクルードすると自動的に有効になります。
1332         * &lt;del&gt;
1333         * 入力ボックス色変更JavaScriptのイベントを無効にするフラグの制御を行います。
1334         * falseを指定するとイベントを無効にします。
1335         * ポップアップ時にプルダウンが正常動作しない場合はこれをfalseとしてください。
1336         * query,result 両タイプで有効です。
1337         * 初期値は使用する(true)です。
1338         *
1339         * @og.rev 4.3.5.0 (2009/02/01) 新規追加
1340         * @og.rev 5.2.1.0 (2010/10/01) JavaScript の統合、廃止
1341         * @og.rev 5.4.5.0 (2012/03/01) モーダルダイアログのプルダウン挙動対応で復活
1342         *
1343         * @param   flag common/focusHilight.jsをインクルード [true:する/false:しない]
1344         */
1345        public void setUseFocusHilight( final String flag ) {
1346                useFocusHilight = nval( getRequestParameter( flag ), useFocusHilight );
1347        }
1348
1349        /**
1350         * 【TAG】href(リンク)の拡張子に応じたアイコンを表示するかどうか[true/false]を指定します(初期値:false)。
1351         *
1352         * @og.tag
1353         * 標準組み込みCSSである、hrefIcon.cssをインクルードするかの指定です。
1354         * これは、href(リンク)の拡張子に応じたアイコンを、jsp/image/ext フォルダ以下の画像ファイルと
1355         * 拡張子と関連付けて、アイコン画像をリンクの頭に表示します。
1356         * 初期値は使用しない(false)です。
1357         *
1358         * @og.rev 5.6.5.2 (2013/06/21) 新規追加
1359         *
1360         * @param   flag common/hrefIcon.cssをインクルード [true:する/false:しない]
1361         */
1362        public void setUseHrefIcon( final String flag ) {
1363                useHrefIcon = nval( getRequestParameter( flag ), useHrefIcon );
1364        }
1365
1366        /**
1367         * 【TAG】検索中表示を行うかどうかを[true/false]を指定します
1368         *              (初期値:VIEW_USE_BLOCKUI[={@og.value org.opengion.hayabusa.common.SystemData#VIEW_USE_BLOCKUI}])。
1369         *
1370         * @og.tag
1371         * 検索中表示は、headType="query" で、jquery/blockUI.js を呼出し、queryButtonSubmit の click で、
1372         * 起動されます。ただし、result風画面(例えば、エントリー系)では、想定通りの動きをしない場合が
1373         * ありますので、特別に、headType="query" の場合は、getRequestURI() から、JSP画面が、query.jsp の
1374         * 場合のみに限定しています。
1375         * 解除は、headType="request" 時に、window.parent.frames['QUERY']; を見つけて、fnUnblockUI() を呼び出します。
1376         * 一応、3ペインを想定して、上記オブジェクトが見つからない場合、window.parent.parent.frames['QUERY']; も
1377         * 実行します。(親フレームのさらに親フレーム。ただし、名称は、QUERY でなければなりません。)
1378         * この属性は、上記の条件をプラスしたうえで適用されます。つまり、true に設定しても強制的に
1379         * 検索中表示を出すことはできません。逆に、false にすると、強制的に、検索中表示を出さなくします。
1380         * (初期値:システム定数のVIEW_USE_BLOCKUI[={@og.value org.opengion.hayabusa.common.SystemData#VIEW_USE_BLOCKUI}])。
1381         *
1382         * @og.rev 5.7.9.0 (2014/08/08) 新規追加
1383         *
1384         * @param   flag common/jquery/blockUI.js をインクルード [true:する/false:しない]
1385         */
1386        public void setUseBlockUI( final String flag ) {
1387                useBlockUI = nval( getRequestParameter( flag ), useBlockUI );
1388        }
1389
1390        /**
1391         * 【TAG】IE8でIE7エミュレートモードで動作させるタグを出力するかどうか[true/false]を指定します
1392         *              (初期値:USE_IE7_HEADER[={@og.value org.opengion.hayabusa.common.SystemData#USE_IE7_HEADER}])。
1393         *
1394         * @og.tag
1395         * IE8でIE7エミュレートモード動作をさせるためのMETAタグを出力するか指定します。
1396         * (初期値:システム定数のUSE_IE7_HEADER[={@og.value org.opengion.hayabusa.common.SystemData#USE_IE7_HEADER}])。
1397         *
1398         * @og.rev 4.3.7.0 (2009/06/01)
1399         *
1400         * @param   flag IE7エミュレートモード用METAタグを出力するか [true:出力する/false:出力しない]
1401         * @see         org.opengion.hayabusa.common.SystemData#USE_IE7_HEADER
1402         */
1403        public void setUseIE7Header( final String flag ) {
1404                useIE7Header = nval( getRequestParameter( flag ), useIE7Header );
1405        }
1406        
1407        /**
1408         * 【TAG】タブレット等の画面サイズ調整METAタグ(viewport)を出力するかどうか[true/false]を指定します
1409         *              (初期値:USE_VIEWPORT_HEADER[={@og.value org.opengion.hayabusa.common.SystemData#USE_VIEWPORT_HEADER}])。
1410         *
1411         * @og.tag
1412         * タブレット等の画面サイズ調整METAタグ(viewport)を出力するかどうか[true/false]を指定します。
1413         * trueを指定すると、METAタグで
1414         * content="width=device-width, initial-scale=1" name="viewport"
1415         * の値が出力されます。
1416         * (初期値:システム定数のUSE_VIEWPORT_HEADER[={@og.value org.opengion.hayabusa.common.SystemData#USE_VIEWPORT_HEADER}])。
1417         *
1418         * @og.rev 5.5.8.0 (2012/11/01) 新規作成
1419         *
1420         * @param   flag タブレット画面サイズ調整METAタグを出力するか [true:出力する/false:出力しない]
1421         * @see         org.opengion.hayabusa.common.SystemData#USE_VIEWPORT_HEADER
1422         */
1423        public void setUseViewPort( final String flag ) {
1424                useViewPort = nval( getRequestParameter( flag ), useViewPort );
1425        }
1426
1427        /**
1428         * 【TAG】フォームのSubmit処理をJavaScriptを利用して行うか(ポップアップエラー表示)
1429         *              (初期値:USE_AJAX_SUBMIT[={@og.value org.opengion.hayabusa.common.SystemData#USE_AJAX_SUBMIT}])。
1430         *
1431         * @og.tag
1432         * この属性をtrueにセットする事で、ajaxを利用したsubmitを行います。
1433         * submit後のページでエラーが発生した場合は画面が切り替わらずに
1434         * ポップアップ形式でエラー表示されます(command=ENTRYの場合のみ)。
1435         * 動的カラム(eventColumn属性)をRESULT部分で利用する場合は、戻るボタンが
1436         * 正常に動作しないため、この属性をtrueにする方が望ましいです。
1437         *
1438         * データを送信する対象のフォームには、id="ajaxSubmit"を指定して下さい。
1439         * (該当のIDのフォームが存在しない場合は、JSPの1番目のフォームが送信されます。)
1440         *
1441         * システムパラメーターまたは、このタグの属性でtrueに指定された場合でも、submitされた
1442         * commandがENTRYの場合のみ、バックグラウンドで実行されます。
1443         * それ以外のコマンドでは通常通り、画面遷移を伴うsubmitとなります。
1444         *
1445         * また、システムパラメーターまたは、このタグの属性でtrueに指定された場合、バックグラウンド
1446         * で実行されるJSPには、その値が引き継がれるため、これらのJSPの各タグでtrueを指定する
1447         * 必要はありません。
1448         *
1449         * (初期値:システム定数のUSE_AJAX_SUBMIT[={@og.value org.opengion.hayabusa.common.SystemData#USE_AJAX_SUBMIT}])。
1450         *
1451         * @og.rev 4.3.8.0 (2009/08/01) 新規追加
1452         * @og.rev 5.1.3.0 (2010/02/01) リクエストに戻す
1453         *
1454         * @param   flag ajaxSubmitを行うかどうか
1455         */
1456        public void setUseAjaxSubmit( final String flag ) {
1457                useAjaxSubmit = nval( getRequestParameter( flag ), useAjaxSubmit );
1458        }
1459
1460        /**
1461         * 【TAG】javaScript を初期ロードし、起動するメソッド名を指定します(初期値:null)。
1462         *
1463         * @og.tag
1464         * これは、addEvent( this, "load", method ); をJavaScript として組み込みます。
1465         *
1466         * @og.rev 5.6.3.0 (2013/04/01) 新規作成
1467         *
1468         * @param   method javaScriptを初期ロードし、起動するメソッド名
1469         */
1470        public void setAddEvent( final String method ) {
1471                addEvent = nval( getRequestParameter( method ), addEvent );
1472        }
1473
1474        /**
1475         * 【TAG】javaScript を初期ロードし、起動する定義名を指定します(初期値:null)。
1476         *
1477         * @og.tag
1478         * これは、指定の定義に対応する、javaScript を組み込みます。
1479         * Bar、 Matrix、 Table、 Gantt、 Task が指定できます。
1480         * これらを組み込む際には、useGantt = "false" , useScrollBar = "false" も自動セットされます。
1481         * 組み込まれるJavaScript,CSSファイルは、jsp/common/option/ 以下にあります。
1482         * <table border="1" frame="box" rules="all" >
1483         *   <caption>組み込みJavaScriptの説明</caption>
1484         *   <tr><th>利用タグ    </th><th>タグ機能          </th><th>adjustEvent</th><th>組み込まれるJavaScript</th><th>組み込まれるCSS     </th><th>初期ロードされるメソッド名</th></tr>
1485         *   <tr><th>og:iHead    </th><th>ヘッダー補足      </th><th>Bar        </th><th>adjustBar.js          </th><th>                    </th><th>adjustBar   </th></tr>
1486         *   <tr><th>og:iBar     </th><th>縦棒(明細)      </th><th>Bar        </th><th>adjustBar.js          </th><th>                    </th><th>adjustBar   </th></tr>
1487         *   <tr><th>og:iMatrix  </th><th>配置図/座席表    </th><th>Matrix     </th><th>adjustMatrix.js       </th><th>                    </th><th>adjustMatrix</th></tr>
1488         *   <tr><th>og:iTable   </th><th>左右分割          </th><th>Table      </th><th>adjustGanttTable.js   </th><th>adjustGanttTable.css</th><th>adjustTable </th></tr>
1489         *   <tr><th>og:iGantt   </th><th>ガント処理        </th><th>Gantt      </th><th>adjustGanttTable.js   </th><th>adjustGanttTable.css</th><th>adjustGantt </th></tr>
1490         *   <tr><th>og:iGanttBar</th><th>ガント積上        </th><th>Gantt      </th><th>adjustGanttTable.js   </th><th>adjustGanttTable.css</th><th>adjustGantt </th></tr>
1491         *   <tr><th>og:iTask    </th><th>ガント積上(内部)  </th><th>Task       </th><th>adjustGanttTable.js   </th><th>adjustGanttTable.css</th><th>adjustTask  </th></tr>
1492         * </table>
1493         *
1494         * @og.rev 5.6.3.2 (2013/04/12) 新規作成
1495         *
1496         * @param   ajEvent javaScriptを初期ロードし、起動する定義名
1497         */
1498        public void setAdjustEvent( final String ajEvent ) {
1499                adjustEvent = nval( getRequestParameter( ajEvent ), ajEvent );
1500
1501                if( adjustEvent != null ) {
1502                        if( check( adjustEvent , ADJUST_EVENT_LIST ) ) {
1503                                useGantt     = false;
1504                                useScrollBar = false;
1505                        }
1506                        else {
1507                                String errMsg = "adjustEvent に指定する値は、[" + ADJUST_EVENT_LIST + "] から選んでください。"
1508                                                                        + HybsSystem.CR
1509                                                                        + " adjustEvent = " + adjustEvent ;
1510                                throw new HybsSystemException( errMsg );
1511                        }
1512                }
1513        }
1514
1515        /**
1516         * 【TAG】option/ogTbodyMovable.js JavaScript を使用するかどうか[true/false]を指定します(初期値:false)。
1517         *
1518         * @og.tag
1519         * option組み込みJavaScriptである、ogTbodyMovable.js を使用するかどうかを指定します。
1520         * これは、id="viewTable" の tbody をマウス、またはカーソルキーで上下に動かす動作を行います。
1521         * この動作と、TbodyMovableTag を組み合わせれば、左右分割等で同期をとりながら上下に動かしたり、
1522         * 値を入れ替える(つまり、元の位置から動かない)や+1、−1するなどの機能を使う事で、
1523         * 視覚的に上下を入れ替えたのその値を登録することが可能になります。
1524         * ガントテーブルでのマウスでの入れ替えなどに効果的です。
1525         * 初期値は、使用しない(false)です。
1526         *
1527         * @og.rev 5.6.3.3 (2013/04/19) 新規作成
1528         *
1529         * @param   flag option/ogTbodyMovable.jsをインクルード [true:する/false:しない]
1530         * @see         org.opengion.hayabusa.taglib.TbodyMovableTag
1531         */
1532        public void setUseTbodyMovable( final String flag ) {
1533                useTbodyMovable = nval( getRequestParameter( flag ),useTbodyMovable );
1534        }
1535        
1536        /**
1537         * 【TAG】jquery/jquery-ui.js JavaScript を使用するかどうか[true/false]を指定します(初期値:false)。
1538         *
1539         * @og.tag
1540         * common/jquery内のjquery-ui.js及び.cssを利用するかどうかを指定します。
1541         * これによりdraggableやtabの機能が利用できますが、使わない画面も多いので初期値はfalseとします。
1542         *
1543         * @param       flag    使用するかどうか [true:使用する/false:使用しない]
1544         */
1545        public void setUseJQUI( final String flag ) {
1546                useJQUI = nval( getRequestParameter( flag ),useJQUI );
1547        }
1548
1549        /**
1550         * このオブジェクトの文字列表現を返します。
1551         * 基本的にデバッグ目的に使用します。
1552         *
1553         * @return このクラスの文字列表現
1554         */
1555        @Override
1556        public String toString() {
1557                return org.opengion.fukurou.util.ToString.title( this.getClass().getName() )
1558                                .println( "VERSION"             ,VERSION        )
1559                                .println( "body"                ,body           )
1560                                .println( "title"               ,title          )
1561                                .println( "Other..."    ,getAttributes().getAttribute() )
1562                                .fixForm().toString() ;
1563        }
1564}