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