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