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 java.util.ArrayList;
019import java.util.List;
020import java.util.Locale;
021import java.util.Map;
022import java.util.Set;                                                                                   // 6.4.3.4 (2016/03/11)
023import java.util.concurrent.ConcurrentMap;                                              // 6.4.3.3 (2016/03/04)
024
025import org.opengion.fukurou.util.StringUtil;
026import org.opengion.fukurou.util.XHTMLTag;
027import org.opengion.fukurou.util.ToString;                                              // 6.1.1.0 (2015/01/17)
028import org.opengion.fukurou.util.ArraySet;                                              // 6.4.3.4 (2016/03/11)
029import org.opengion.hayabusa.common.HybsSystem;
030import org.opengion.hayabusa.common.HybsSystemException;
031import org.opengion.hayabusa.db.DBColumn;
032import org.opengion.hayabusa.db.DBColumnConfig;
033import org.opengion.hayabusa.db.DBEditConfig;
034import org.opengion.hayabusa.db.DBLastSql;
035import org.opengion.hayabusa.db.DBTableModel;
036import org.opengion.hayabusa.db.DBTableModelSorter;
037import org.opengion.hayabusa.html.FormatterType;
038import org.opengion.hayabusa.html.TableFormatter;
039import org.opengion.hayabusa.html.ViewCrossTableParam;
040import org.opengion.hayabusa.html.ViewForm;
041import org.opengion.hayabusa.html.ViewFormFactory;
042import org.opengion.hayabusa.html.ViewMarker;
043import org.opengion.hayabusa.resource.RoleMode;
044import org.opengion.hayabusa.resource.UserInfo;
045import org.opengion.hayabusa.resource.GUIInfo;
046
047import static org.opengion.fukurou.util.StringUtil.nval;
048
049/**
050 * データベースの検索結果を表示するタグです。
051 *
052 * 検索結果は、DBTableModel にセットされます。
053 * このタグに、データ(DBTableModel)と、
054 * コントローラ(ViewForm)を与えて、 外部からコントロールすることで、テキストフィールドやテーブルの形で表示したり、
055 * 入力可/不可、表示可/不可の設定を行うことができます。
056 *
057 * @og.formSample
058 * ●形式:<og:view />
059 *     <og:view
060 *         viewFormType = "HTMLTable"
061 *         command      = "{@command}"
062 *         startNo      = "0"
063 *         pageSize     = "20"
064 *         language     = "ja" />
065 *
066 *     viewFormType : ViewFormオブジェクトを作成する時のキー(オプション)     ViewFormFactory参照
067 *     command      : 処理コマンド ( PREV,NEXT,FIRST,LAST,VIEW )(オプション)
068 *     startNo      : データの書き始めの初期値を指定(オプション)
069 *     pageSize     : データのページ数(画面表示件数)を指定(オプション)
070 *     language     : ロケール(オプション)
071 *
072 * ●body:あり(EVAL_BODY_BUFFERED:BODYを評価し、{@XXXX} を解析します)
073 *
074 * ●Tag定義:
075 *   <og:view
076 *       viewFormType        【TAG】ViewForm オブジェクトを作成するクラス({@og.doc03Link viewFormType ViewForm_**** クラス})を指定します
077 *       command             【TAG】コマンド (PREV,NEXT,FIRST,LAST,NEW,RENEW,VIEW,REVIEW,RESET)をセットします
078 *       scope               【TAG】キャッシュする場合のスコープ[request/page/session/application]を指定します(初期値:session)
079 *       startNo             【TAG】表示データを作成する場合の表示の開始行番号をセットします
080 *       pageSize            【TAG】表示データを作成する場合の1ページの行数をセットします
081 *       pagePlus            【TAG】1ページの行数の増加分をセットします(初期値:0)
082 *       writable            【TAG】行が書き込み可能かどうか[true/false]を設定します (初期値:DBTableModel#DEFAULT_WRITABLE[=true])
083 *       checked             【TAG】行のチェックボックスの初期値を設定するかどうか[true/false]を指定します(初期値:null)
084 *       rowspan             【TAG】表示データを作成する場合のフォーマットの行数をセットします(初期値:2)
085 *       skip                【TAG】NEXT等で、選択行以外をスキップするのかどうか[true/false]を指定します (初期値:ViewForm#DEFAULT_SKIP[=false])
086 *       columnWritable      【TAG】書き込み可能カラム名を、CSV形式で与えます
087 *       noWritable          【TAG】書き込み不可カラム名を、CSV形式で与えます
088 *       columnDisplay       【TAG】表示可能カラム名を、CSV形式で与えます
089 *       clmSeqDisplay       【TAG】表示可能カラム名を、カラム順に、CSV形式で与えます
090 *       noDisplay           【TAG】表示不可カラム名を、CSV形式で与えます
091 *       columnGroup         【TAG】同一表示データをまとめる(表示しない)カラム名を、CSV形式で与えます
092 *       noGroup             【TAG】同一表示データをまとめないカラム名を、CSV形式で与えます
093 *       groupClass          【TAG】同一表示データをまとめる場合の、表示方法を指定します
094 *       groupDir            【TAG】同一表示データをまとめる場合に、行(row)か列(column)を指定します(初期値:ROW)
095 *       tableSorterKeys     【TAG】カラム名リンクソートを表示するカラム名を、CSV形式で与えます
096 *       tableId             【TAG】(通常は使いません)sessionから所得する DBTableModelオブジェクトの ID
097 *       viewFormId          【TAG】(通常は使いません)sessionから取得する ViewForm オブジェクトの ID
098 *       viewLinkId          【TAG】(通常つかいません)requestから取得する ViewLink に対応する Attributes オブジェクトの ID
099 *       viewMarkerId        【TAG】(通常は使いません)requestから取得する ViewMarker に対応する Attributes オブジェクトの ID
100 *       editMarkerId        【TAG】(通常は使いません)requestから取得する EditMarker に対応する Attributes オブジェクトの ID
101 *       selectedType        【TAG】表示時の選択用オブジェクトのタイプ[checkbox/radio/hidden/none]を指定します(初期値:checkbox)
102 *       numberType          【TAG】表示時の行番号の表示方法[sequence/none/delete/skip=カラム名/view=カラム名]を指定します(初期値:sequence)
103 *       optionTypeAttributes【TAG】テーブル等のチェックボックスに属性を付加します
104 *       noMessage           【TAG】検索結果メッセージを表示しないかどうか[true/false]を設定します(初期値:false[表示する])
105 *       backLinkCount       【TAG】ページの先頭へのリンクの間隔をセットします (初期値:VIEW_BACK_LINK_COUNT[=0])
106 *       headerSkipCount     【TAG】ヘッダーを出力する間隔をセットします(初期値:システムパラメータ の VIEW_HEADER_SKIP_COUNT)
107 *       useCheckControl     【TAG】チェックボックスの全チェックを選択するJavaScript の機能を使用するかどうかを指定します (初期値:VIEW_USE_CHECK_CONTROL[=true])
108 *       useTableSorter      【TAG】ヘッダーにソート用リンクを作成するかどうか[true/false]を指定します (初期値:VIEW_USE_TABLE_SORTER[=true])
109 *       useParam            【TAG】パラメーターファイルの使用をするかどうか[true/false]を指定します(初期値:false)
110 *       useConsistency      【TAG】Consistency キー による整合性チェックを行うかどうか[true/false]を指定します(初期値:true)
111 *       bgColorCycle        【TAG】テーブルのバックグラウンドカラーの入れ替えのサイクルをセットします(初期値は、1:ゼブラ)
112 *       bgColorClsClm       【TAG】テーブルのバックグラウンドカラーのクラスに指定するカラム名を指定します
113 *       useScrollBar        【TAG】スクロールバー用のDIV要素を出力するかどうか[true/false]を指定します
114                                                                                (初期値:VIEW_USE_SCROLLBAR[={@og.value SystemData#VIEW_USE_SCROLLBAR}])
115 *       maxScrollBarSize    【TAG】ヘッダー固定のスクロールバー使用時の最大行数を指定します
116                                                                                (初期値:VIEW_SCROLLBAR_MAX_ROW_SIZE[={@og.value SystemData#VIEW_SCROLLBAR_MAX_ROW_SIZE}])
117 *       loadMarker          【TAG】viewLink や viewMarker の情報取り込みを制御する(初期値は、NEW,RENEW,REVIEW,RESET)
118 *       useSelectedRow      【TAG】SEL_ROW機能[true:有効/false:無効]を指定します (初期値:VIEW_USE_SELECTED_ROW[=true])
119 *       useSelRowColor      【TAG】SEL_ROW使用時の選択行色変更[true:有効/false:無効]を指定します (初期値:VIEW_USE_SELROW_COLOR[=true])
120 *       useHilightRow       【TAG】HILIGHT_ROW機能[true:有効/false:無効]を指定します (初期値:VIEW_USE_HILIGHT_ROW[=true])
121 *       useAfterHtmlTag     【TAG】処理時間やページサイズなどの情報出力[true:有効/false:無効]を指定します(初期値:true)
122 *       writableControl     【TAG】設定値に "_" が含まれている場合にレンデラーを使用するカラムをCSV形式で指定します
123 *       popupReturnKeys     【TAG】ogPopup で検索結果の値を返すキーを、CSV形式で指定します
124 *       clazz               【TAG】table要素に対して class 属性を設定します(初期値:viewTable)
125 *       language            【TAG】タグ内部で使用する言語コード[ja/en/zh/…]を指定します
126 *       height              【TAG】ビューの高さを指定します
127 *       width               【TAG】ビューの幅を指定します
128 *       fileDwnClms         【TAG】ファイルダウンロード時の抜出カラム名(CSV形式)を指定します
129 *       skipNoEdit          【TAG】編集行のみを表示するかを指定します(初期値:false)
130 *       noTransition        【TAG】(通常は使いません)画面遷移を行わない形式の登録方法を使用するかを指定します
131 *       useHilightCheckOnly 【TAG】選択行ハイライトの制御をチェックボックスのみで有効にするかを指定します (初期値:VIEW_USE_HILIGHT_CHECK_ONLY[=false])
132 *       useHilightRadioClick【TAG】選択行ハイライトの制御でラジオのクリックイベントを発行するかどうかを指定します (初期値:VIEW_USE_HILIGHT_RADIO_CLICK[=true])
133 *       columnBulkSet       【TAG】一括入力カラムのアシスト機能を利用するカラム名を、CSV形式で与えます
134 *       useTimeView         【TAG】処理時間を表示する TimeView を表示するかどうかを指定します
135 *                                                                              (初期値:VIEW_USE_TIMEBAR[={@og.value SystemData#VIEW_USE_TIMEBAR}])。
136 *       caseKey             【TAG】このタグ自体を利用するかどうかの条件キーを指定します(初期値:null)
137 *       caseVal             【TAG】このタグ自体を利用するかどうかの条件値を指定します(初期値:null)
138 *       caseNN              【TAG】指定の値が、null/ゼロ文字列 でない場合(Not Null=NN)は、このタグは使用されます(初期値:判定しない)
139 *       caseNull            【TAG】指定の値が、null/ゼロ文字列 の場合は、このタグは使用されます(初期値:判定しない)
140 *       caseIf              【TAG】指定の値が、true/TRUE文字列の場合は、このタグは使用されます(初期値:判定しない)
141 *       mainView            【TAG】(通常は使いません)セッションに情報を登録するかどうか[true/false]指定します。(初期値:true)
142 *       debug               【TAG】デバッグ情報を出力するかどうか[true/false]を指定します(初期値:false)
143 *   >   ... Body ...
144 *   </og:view>
145 *
146 * ●使用例
147 *       <og:view viewFormId="HTMLTable" command="NEW" startNo="0" pageSize="5" / >
148 *
149 * @og.group 画面表示
150 *
151 * @version  4.0
152 * @author       Kazuhiko Hasegawa
153 * @since    JDK5.0,
154 */
155public class ViewFormTag extends CommonTagSupport {
156        /** このプログラムのVERSION文字列を設定します。   {@value} */
157        private static final String VERSION = "6.7.3.0 (2017/01/27)" ;
158        private static final long serialVersionUID = 673020170127L ;
159
160        /** command 引数に渡す事の出来る コマンド  プレビュー {@value}  */
161        public static final String CMD_PREV  = "PREV" ;
162        /** command 引数に渡す事の出来る コマンド  ネクスト {@value}  */
163        public static final String CMD_NEXT  = "NEXT" ;
164        /** command 引数に渡す事の出来る コマンド  ファースト {@value}  */
165        public static final String CMD_FIRST = "FIRST";
166        /** command 引数に渡す事の出来る コマンド  ラスト {@value}  */
167        public static final String CMD_LAST  = "LAST" ;
168        /** command 引数に渡す事の出来る コマンド  新規 {@value}  */
169        public static final String CMD_NEW       = "NEW" ;
170        /** command 引数に渡す事の出来る コマンド  再検索 {@value}  */
171        public static final String CMD_RENEW = "RENEW" ;
172        /** command 引数に渡す事の出来る コマンド  表示 {@value}  */
173        public static final String CMD_VIEW  = "VIEW" ;
174        /** command 引数に渡す事の出来る コマンド  再表示 {@value}  */
175        public static final String CMD_REVIEW  = "REVIEW" ;
176        /** command 引数に渡す事の出来る コマンド  リセット {@value}  */
177        public static final String CMD_RESET  = "RESET" ;
178
179        // 6.4.3.4 (2016/03/11) String配列 から、Setに置き換えます。
180        private static final Set<String> COMMAND_SET = new ArraySet<>( CMD_PREV , CMD_NEXT , CMD_FIRST , CMD_LAST , CMD_NEW , CMD_RENEW , CMD_VIEW , CMD_REVIEW , CMD_RESET );
181
182        // 3.8.0.8 (2005/10/03)
183        /** コマンドリストに存在しない場合の値 従来の CMD_VIEW と区別させるため。 */
184        private static final String CMD_XXX  = "XXX" ;
185
186        private static final String START_NO_KEY        = "startNo";
187        private static final String PAGE_SIZE_KEY       = "pageSize";
188        private static final String PAGE_PLUS_KEY       = "pagePlus";
189
190        private transient DBTableModel          table ;
191        private transient ViewForm                      form  ;
192        private transient List<TableFormatter>          values;         // 6.3.9.0 (2015/11/06) transient 追加
193
194        private String          tableId                 = HybsSystem.TBL_MDL_KEY;
195        private String          viewFormId              = HybsSystem.VIEWFORM_KEY;
196        private String          viewFormType    ;
197        private String          viewLinkId              = HybsSystem.VIEWLINK_KEY;
198        private String          viewMarkerId    = HybsSystem.VIEW_MARK_KEY;
199        private String          editMarkerId    = HybsSystem.EDIT_MARK_KEY;             // 3.8.6.1 (2006/10/20)
200        private String          command                 ;
201        private int                     startNo                 = -1;           // HTML画面上の表示開始位置(初期値)
202        private int                     tempStartNo             = -1;           // 再検索時の表示開始位置
203        private int                     pageSize                = -1;           // HTML画面上に表示する件数
204        private int                     pagePlus                = -1;           // 3.5.6.4 (2004/07/16)
205        private String          columnWritable  ;
206        private String          noWritable              ;
207        private String          columnDisplay   ;
208        private String          noDisplay               ;
209        private String          clmSeqDisplay   ;               // 5.1.6.0 (2010/05/01) ViewForm_HTMLSeqClmTable 対応
210        private String          columnGroup             ;               // 3.8.5.0 (2006/03/20)
211        private String          noGroup                 ;               // 5.1.8.0 (2010/07/01)
212        private String          groupClass              ;               // 5.1.8.0 (2010/07/01)
213        private boolean         groupDir                ;               // 6.7.3.0 (2017/01/27) false:ROW/true:COLUMN
214        private boolean         noMessage               ;
215        private String          writable                ;
216        private String          checked                 ;
217        private boolean         skip                    = ViewForm.DEFAULT_SKIP;
218        private String          rowspan                 = "2";
219        private String          selectedType    = "checkbox";
220        private String          numberType              = "sequence";           // 3.5.1.0 (2003/10/03) 追加
221        private String          optTypeAttri    ;
222        private int                     backLinkCount   = HybsSystem.sysInt( "VIEW_BACK_LINK_COUNT" );
223        private int                     headerSkipCount = HybsSystem.sysInt( "VIEW_HEADER_SKIP_COUNT" );        // 0:通常ヘッダ、n:n回ごとに現れる
224        private String          bodyString              ;
225        private int                     useCheckControl = -1 ;
226        private String          useTableSorter  ;                               // 3.5.4.7 (2004/02/06)
227
228        private long dyStart                            ;                               // 3.5.4.7 (2004/02/06) 実行時間測定用のDIV要素を出力します。
229        private boolean useTimeView                     = HybsSystem.sysBool( "VIEW_USE_TIMEBAR" );             // 6.3.6.0 (2015/08/16)
230        private boolean useParam                        ;                               // 3.5.4.8 (2004/02/23) パラメータTagの使用を宣言します。
231        /** 6.4.3.1 (2016/02/12) 作成元のMapを、HashMap から ConcurrentHashMap に置き換え。  */
232        private ConcurrentMap<String,String> viewParam;         // 6.4.3.3 (2016/03/04)
233        private List<String[]> viewArrayList;                           // 5.5.9.0 (2012/12/03) viewObjectから変更
234
235        private transient DBLastSql        lastSql      ;                       // 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
236        private transient DBEditConfig editConf ;                       // 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
237
238        // 3.5.5.8 (2004/05/20) 整合性チェックを行う為の、Consistency キー を出力するかどうかを指定します。
239        private boolean useConsistency  = HybsSystem.sysBool( "USE_CONSISTENCY" ) ;
240
241        // 0(ゼブラなし)、-1(ワーニング)、-2以下(エラー)、1(ゼブラ)、2以上(行数まとめ)
242        private int bgColorCycle                = 1 ;           // 3.5.6.2 (2004/07/05) ゼブラ模様の指定を、ViewForm としてサポート
243        private String  bgColorClsClm   ;                       // 5.1.8.0 (2010/07/01) 行に対して、動的にクラス属性を付与するカラム名を指定します。
244        private String  useScrollBar    ;
245        private int             maxScrollBarSize = HybsSystem.sysInt( "VIEW_SCROLLBAR_MAX_ROW_SIZE" ) ;         // 6.2.4.0 (2015/05/15)
246
247        private String  sortKeys                ;                       // 3.6.0.0 (2004/09/17) カラムソートリンクを出すカラム名を指定。
248
249        // 3.6.0.4 (2004/10/14) viewLink や viewMarker の情報取り込みを制御
250        // 前後の , が重要です!
251        private String          loadMarker      = ",NEW,RENEW,REVIEW,RESET,";
252
253        // 3.7.1.1 (2005/05/23) SEL_ROW機能の有効/無効を指定します。
254        private String  useSelectedRow  ;
255
256        // 3.7.1.1 (2005/05/31) SEL_ROW機能使用時に、BG_COLOR_ROWSEL の使用 有/無を指定します。
257        private String  useSelRowColor  ;
258
259        // 3.7.1.1 (2005/05/23) 処理時間やページサイズなどの情報出力の有効/無効を指定します。
260        private boolean useAfterHtmlTag = true ;
261
262        // 3.8.0.9 (2005/10/17) 設定値に "_" が含まれている場合に、レンデラーを使用します。
263        private String  writableControl ;
264
265        // 3.8.6.0 (2006/09/29) HILIGHT_ROW機能の有効/無効を指定します。
266        private String  useHilightRow   ;
267
268        // 3.8.6.1 (2006/10/20) ogPopup で検索結果の値を返すキーを、CSV形式で指定します。
269        private String  popupReturnKeys ;
270
271        // 4.0.0 (2007/04/16) tableタグを出力するときに付与します。
272        private String  clazz                   = "viewTable";
273
274        // 4.2.0.0 (2008/03/18) ビューの幅と高さを指定できるようにします。
275        private String  height                  ;
276        private String  width                   ;
277
278        // 4.3.0.0 (2008/07/04) fileUD ファイルダウンロード時の抜出カラム名(CSV形式)
279        private String  fileDwnClms             ;
280
281        private boolean skipNoEdit              ;       // 4.3.1.0 (2008/09/08)
282        private boolean noTransition    ;       // 4.3.3.0 (2008/10/01)
283
284        // 4.3.7.0 (2009/06/01) HILIGHT_ROW機能有効時に制御を行チェックボックスのみにします。
285        private String  isHiRowCheckOnly;                       // 6.0.2.5 (2014/10/31) refactoring
286        // 6.2.2.0 (2015/03/27) hilightRow で、行選択時にイベント発行可否を指定できるようにする。
287        private String  isHiRadioClick;
288
289        // 5.2.1.0 (2010/10/01) 一括入力カラムのアシスト機能を利用するカラムを指定します。
290        private String  columnBulkSet   ;
291        private boolean useDefBulkset   = HybsSystem.sysBool( "VIEW_USE_DEFAULT_BULKSET" ) ;
292
293        // 5.7.6.1 (2014/05/09) startNoのセッション保存を指定します。
294        private boolean isMainView              = true; 
295
296        // 6.4.6.1 (2016/06/03) tableId 廃止(利用目的を明確にするため、パラメータ名をviewClassに変更)
297        private String  viewClass       ;                               // 今は、外部からの登録は行わない。
298
299        /**
300         * Taglibの開始タグが見つかったときに処理する doStartTag() を オーバーライドします。
301         *
302         * @og.rev 3.5.4.7 (2004/02/06) DBTableModelのソート機能 useTableSorter を追加
303         * @og.rev 3.5.4.7 (2004/02/06) 実行時間測定用に、開始時刻を取得します。
304         * @og.rev 3.5.4.8 (2004/02/23) useParam を、BODY部の処理判定に加えます。
305         * @og.rev 3.5.6.0 (2004/06/18) DBRowHeader のパッケージプライベート化に伴なう変更
306         * @og.rev 3.5.6.1 (2004/06/25) viewFormType変更時のviewForm 再セット
307         * @og.rev 3.5.6.2 (2004/07/05) command="VIEW" などで、ありえないとしていた処理を追加
308         * @og.rev 3.5.6.3 (2004/07/12) markerSet で table の整合性もチェックする。
309         * @og.rev 3.5.6.4 (2004/07/16) DBTableModelのソート時には、viewを初期設定する。
310         * @og.rev 3.6.0.0 (2004/09/17) scope が request の場合(検索)ヘッダーソートリンクは使えない。
311         * @og.rev 3.6.0.0 (2004/09/22) pageSize の form への設定見直し。
312         * @og.rev 3.6.0.0 (2004/09/25) viewLink , viewMarker のリクエストメモリ削除の中止
313         * @og.rev 3.6.0.4 (2004/10/14) viewLink や viewMarker の情報取り込みを制御する loadMarker を追加
314         * @og.rev 3.6.0.5 (2004/10/18) viewLink , viewMarker のリクエストメモリ削除を復活します。
315         * @og.rev 3.8.0.8 (2005/10/03) ヘッダーソート時に、startNo を 0 に戻します。
316         * @og.rev 3.8.8.5 (2007/03/09) markerSet する条件を強化する。
317         * @og.rev 3.8.8.9 (2007/05/29) ソート時のviewLink,viewMarker の取り込み
318         * @og.rev 3.8.9.3 (2007/08/28) soryKeysのみを指定した場合に、ソート用のテーブルモデルが作成されないバグを修正。
319         * @og.rev 4.1.0.0(2008/01/11)システムパラメータ(useCheckControl)の読取は doEndTag 関数から doStartTag 関数に移動します。
320         * @og.rev 5.1.6.0 (2010/05/01) ViewForm_HTMLSeqClmTable クラス によるカラム表示順処理を行います。
321         * @og.rev 5.1.6.0 (2010/05/01) 左右分割スクロール画面でヘッダースクロールが2回処理されるバグを修正
322         * @og.rev 5.1.6.0 (2010/05/01) ユーザー毎の画面項目並び替え対応
323         * @og.rev 5.1.7.0 (2010/06/01) ViewFormに画面IDをセットし、セットされた画面IDと同じ場合のみViewFormを復元する。
324         * @og.rev 5.1.7.0 (2010/06/01) DBColumnの{&#064;XXXX}変数対応
325         * @og.rev 5.1.7.0 (2010/06/01) ヘッダーソート後に画面遷移し、戻ってきた際にstartNoがクリアされるバグを修正
326         * @og.rev 5.1.8.0 (2010/07/01) 全チェックを押した状態で画面遷移した場合にチェック状態を保持する。
327         * @og.rev 5.1.8.0 (2010/07/01) 同時設定不可(columnWritable,noWritable,columnDisplay,noDisplay,columnGroup,noGroup) チェック
328         * @og.rev 5.2.2.0 (2010/11/01) caseKey 、caseVal 属性対応
329         * @og.rev 5.3.0.0 (2010/12/01) 左右分割スクロール(SplitViewTag)対応
330         * @og.rev 5.3.6.0 (2011/06/01) Edit機能見直し
331         * @og.rev 5.4.1.0 (2011/11/01) 5.1.8.0 (2010/07/01)の全チェック保持機能を廃止
332         * @og.rev 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
333         * @og.rev 6.0.3.0 (2014/11/13) Edit機能の超特殊処理
334         * @og.rev 6.2.0.0 (2015/02/27) PopupのBulkSet Off化にも使うので、HTMLSeqClmTable の条件は外す。
335         * @og.rev 6.2.5.0 (2015/06/05) Edit機能改善。viewLink,viewMarker の取り込みは、ソート時と、DBEditConfig 使用時とする。
336         * @og.rev 6.4.0.3 (2015/12/14) ヘッダーソート後のViewLinkが、旧のアドレスを指したままになっている不具合修正。
337         * @og.rev 6.4.6.1 (2016/06/03) tableId 廃止(利用目的を明確にするため、パラメータ名をviewClassに変更)
338         *
339         * @return      後続処理の指示
340         */
341        @Override
342        public int doStartTag() {
343                // 5.2.2.0 (2010/11/01) caseKey 、caseVal 属性対応
344                if( !useTag() ) { return SKIP_BODY ; }  // Body を評価しない
345                dyStart = System.currentTimeMillis();
346
347                // 6.4.6.1 (2016/06/03) tableId 廃止(利用目的を明確にするため、パラメータ名をviewClassに変更)
348                // SplitViewTag を使う場合は、再設定されるので、初期設定をここで行っておく。
349                viewClass = "VIEW_" + tableId ;
350
351                // 5.3.0.0 (2010/12/01) 左右分割スクロール(SplitViewTag)対応
352                splitViewParamSet();
353
354                // 5.1.8.0 (2010/07/01) 同時設定不可(columnWritable,noWritable,columnDisplay,noDisplay,columnGroup,noGroup) チェック
355                if( columnWritable != null && noWritable != null ) {
356                        final String errMsg = "columnWritable と noWritable は同時に指定できません。"
357                                                        + "columnWritable = [" + columnWritable
358                                                        + "] , noWritable = [" + noWritable
359                                                        + "]";
360                        throw new HybsSystemException( errMsg );
361                }
362
363                if( columnDisplay != null && noDisplay != null ) {
364                        final String errMsg = "columnDisplay と noDisplay は同時に指定できません。"
365                                                        + "columnDisplay = [" + columnDisplay
366                                                        + "] , noDisplay = [" + noDisplay
367                                                        + "]";
368                        throw new HybsSystemException( errMsg );
369                }
370
371                if( columnGroup != null && noGroup != null ) {
372                        final String errMsg = "columnGroup と noGroup は同時に指定できません。"
373                                                        + "columnGroup = [" + columnGroup
374                                                        + "] , noGroup = [" + noGroup
375                                                        + "]";
376                        throw new HybsSystemException( errMsg );
377                }
378
379                table = (DBTableModel)getObject( tableId );
380                if( table == null ) { return SKIP_BODY ; }
381
382                // 5.1.6.0 (2010/05/01)ViewForm_HTMLSeqClmTable クラス によるカラム表示順処理を行います。
383                // clmSeqDisplay 属性が設定されていると、クラス指定を変更し、columnDisplay に、clmSeqDisplay を
384                // 設定し、noDisplay を、削除(null をセット)します。
385                if( clmSeqDisplay != null ) {
386                        viewFormType    = "HTMLSeqClmTable" ;
387                }
388
389                // 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
390                final String guikey = getGUIInfoAttri( "KEY" );
391                lastSql = (DBLastSql)getSessionAttribute( HybsSystem.DB_LAST_SQL_KEY );
392                // ここではtableId,scope,項目名などで厳密にチェックを行います。
393                if( lastSql != null && lastSql.isGuiMatch( guikey ) && lastSql.isTableMatch( tableId, getScope() ) ) {
394                        final String editName = getRequestValue( "editName" );
395                        if( editName != null ) {
396                                editConf = getUser().getEditConfig( guikey, editName );
397                                if( editConf != null ) {
398                                        viewFormType = "HTMLSeqClmTable";
399                                }
400                        }
401                }
402
403                // 5.1.7.0 (2010/06/01) DBColumnの{@XXXX}変数対応
404                final int clmSize = table.getColumnCount();
405                for( int clmNo=0; clmNo<clmSize; clmNo++ ) {
406                        final DBColumn dbColumn = table.getDBColumn( clmNo );
407                        if( dbColumn.isNeedsParamParse() ){
408                                final DBColumnConfig config = dbColumn.getConfig();
409                                config.setRendererParam( getRequestParameter( config.getRendererParam() ) );
410                                config.setEditorParam( getRequestParameter( config.getEditorParam() ) );
411                                final DBColumn newColumn = new DBColumn( config );
412                                table.setDBColumn( clmNo, newColumn );
413                        }
414                }
415
416                // 3.8.8.9 (2007/05/29) ソート時の viewLink,viewMarker の取り込み
417                // 実際は、Formオブジェクトが変わった時も取り込む必要があるが、過去のソースとの関係で、今回は見送る。
418                boolean useSorter = false;
419
420                // 3.5.4.7 (2004/02/06) DBTableModelのソート機能 追加
421                // 登録後に同じソート順で再表示させるために、リクエストキャッシュに登録します。
422                // 3.8.9.3 (2007/08/28) soryKeysのみを指定した場合に、ソート用のテーブルモデルが作成されないバグを修正。
423                // 5.1.6.0 (2010/05/01) 左右分割スクロール画面でヘッダースクロールが2回処理されるバグを修正
424                if( "session".equals( getScope() )
425                        && ( nval( useTableSorter,sysBool( "VIEW_USE_TABLE_SORTER" ) ) || sortKeys != null )
426                        && !( table.getConsistencyKey().equals( getRequestAttribute( HybsSystem.VIEW_SORT_KEY ) ) ) ) {
427
428                        final String clm = getRequestValue( HybsSystem.SORT_COLUMNS );
429                        // 若干トリッキー。初めてクリックされるまで、DBTableModelSorter は作成しない。
430                        if( clm != null && clm.length() > 0 ) {
431                                useSorter = true;               // 3.8.8.9 (2007/05/29)
432                                startQueryTransaction( tableId );               // 3.6.0.8 (2004/11/19)
433                                final int clmNo = table.getColumnNo( clm );
434                                boolean sortAscending = nval( getRequestValue( HybsSystem.SORT_ASCENDING ),true );
435                                if( table instanceof DBTableModelSorter ) {
436                                        if( !CMD_RESET.equals( command ) ) {
437                                                ((DBTableModelSorter)table).sortByColumn( clmNo );
438                                        }
439                                        sortAscending = ((DBTableModelSorter)table).isAscending() ;     // ソート方向
440                                }
441                                else {
442                                        final DBTableModelSorter temp = new DBTableModelSorter();
443                                        temp.setModel( table );
444                                        temp.sortByColumn( clmNo,sortAscending );
445                                        table = temp;
446                                }
447                                // 3.6.0.8 (2004/11/19) トランザクションチェックを行います。
448                                if( ! commitTableObject( tableId, table ) ) {
449                                        jspPrint( "ViewFormTag " + getResource().getLabel( "ERR0041" ) ); // 5.8.8.0 (2015/06/05)
450                                        return SKIP_PAGE;
451                                }
452                                if( CMD_VIEW.equals( command ) ) {
453                                        setRequestCacheData( HybsSystem.SORT_COLUMNS,clm );
454                                        setRequestCacheData( HybsSystem.SORT_ASCENDING,String.valueOf( sortAscending ) );
455                                }
456
457                                // 5.1.6.0 (2010/05/01)
458                                setRequestAttribute( HybsSystem.VIEW_SORT_KEY, table.getConsistencyKey() );
459
460                                // 3.8.0.8 (2005/10/03) ヘッダーソート時に、startNo を 0 に戻します。
461                                // 5.1.7.0 (2010/06/01) ヘッダーソート後に画面遷移し、戻ってきた際にstartNoがクリアされるバグを修正
462                                if( !CMD_RENEW.equals( command ) ) {
463                                        startNo = 0;
464                                        tempStartNo = startNo;
465                                }
466                        }
467                }
468
469                if( CMD_NEW.equals( command ) || CMD_RENEW.equals( command ) || CMD_REVIEW.equals( command ) || CMD_RESET.equals( command ) ) {
470                        form = ViewFormFactory.newInstance( viewFormType );             // 3.5.6.1 (2004/06/25)
471                        form.init( table );
472                        table.setDefaultRowWritable( DBTableModel.DEFAULT_WRITABLE );
473                        table.setDefaultRowChecked(  DBTableModel.DEFAULT_CHECKED );
474                }
475                else {
476                        // 3.5.6.1 (2004/06/25) viewFormType変更時のviewForm 再セット
477                        final ViewForm oldForm = (ViewForm)getObject( viewFormId );
478                        // 5.1.7.0 (2010/06/01) ViewFormに画面IDをセットし、セットされた画面IDと同じ場合のみViewFormを復元する。
479                        if( oldForm != null && guikey.equals( oldForm.getGamenId() ) ) {        // 6.0.2.4 (2014/10/17) 
480                                // 6.2.5.0 (2015/06/05) USE_EDIT_WITH_VIEW_CHANGE で、切り替え処理を行う。
481                                final String oldFormType = oldForm.getViewFormType();
482                                if( "HTMLSeqClmTable".equals( oldFormType ) && HybsSystem.sysBool( "USE_EDIT_WITH_VIEW_CHANGE" ) ) {
483                                        viewFormType = "HTMLSeqClmTable" ;
484                                }
485
486                                // 6.4.0.3 (2015/12/14) ヘッダーソート後のViewLinkが、旧のアドレスを指したままになっている不具合修正。
487
488                                if( oldFormType != null && oldFormType.equals( viewFormType ) ) {
489                                        form = oldForm ;
490                                }
491                                else {
492                                        form = ViewFormFactory.newInstance( viewFormType );
493                                }
494
495                                // 6.2.5.0 (2015/06/05) form が切り替わった時のみ、markerSet する。
496                                form.init( table );
497                                // 3.5.6.3 (2004/07/12) markerSet で table の整合性もチェックする。
498                                final DBTableModel oldTable = oldForm.getDBTableModel();
499                                if( table.getConsistencyKey().equals( oldTable.getConsistencyKey() ) ) {
500                                        // 3.8.8.5 (2007/03/09) markerSet する条件を強化する。
501                                        // 3.8.8.9 (2007/05/29) ソート時の viewLink,viewMarker の取り込み
502                                        // 6.2.5.0 (2015/06/05) viewLink,viewMarker の取り込みは、ソート時と、DBEditConfig 使用時とする。
503                                        if( "true".equalsIgnoreCase( loadMarker )                       ||
504                                                loadMarker.indexOf( "," + command + "," ) >= 0  ||
505                                                "HTMLSeqClmTable".equals( viewFormType )                ||                      // 6.2.5.0 (2015/06/05)
506                                                "HTMLSeqClmTable".equals( oldFormType )                 ||                      // 6.2.5.0 (2015/06/05)
507                                                useSorter ) {
508                                                        form.markerSet( oldForm );
509                                        }
510                                }
511                        }
512                        else {
513                                // 3.5.6.2 (2004/07/05) command="VIEW" などで、ありえないとしていた処理を追加
514                                form = ViewFormFactory.newInstance( viewFormType );
515                                form.init( table );
516                        }
517                }
518
519                // 5.1.7.0 (2010/06/01) ViewFormに画面IDをセットし、セットされた画面IDと同じ場合のみViewFormを復元する。
520                form.setGamenId( guikey );                                              // 6.0.2.4 (2014/10/17) 
521
522                // 3.6.0.4 (2004/10/14) ViewMarker 等のセットは、loadMarker で制御します。
523                if( "true".equalsIgnoreCase( loadMarker ) || loadMarker.indexOf( "," + command + "," ) >= 0 ) {
524                        final ViewMarker viewLink = (ViewMarker)getRequestAttribute( viewLinkId );
525                        if( viewLink != null ) {
526                                form.setViewLink( viewLink );
527                                removeRequestAttribute( viewLinkId );   // 3.6.0.5 (2004/10/18) 復活
528                        }
529
530                        final ViewMarker viewMarker = (ViewMarker)getRequestAttribute( viewMarkerId );
531                        if( viewMarker != null ) {
532                                form.setViewMarker( viewMarker );
533                                removeRequestAttribute( viewMarkerId ); // 3.6.0.5 (2004/10/18) 復活
534                        }
535
536                        // 3.8.6.1 (2006/10/24) editMarker を追加する。
537                        // 6.2.0.0 (2015/02/27) Popup(isRenderer=false のviewMarker)のBulkSet Off化対応
538                        final ViewMarker editMarker = (ViewMarker)getRequestAttribute( editMarkerId );
539                        if( editMarker != null ) {
540                                form.setEditMarker( editMarker );
541                                removeRequestAttribute( editMarkerId );
542                                // 6.0.3.0 (2014/11/13) Edit機能の超特殊処理
543                                // editMarkerのカラムは非表示設定する必要がある。
544                                // 6.2.0.0 (2015/02/27) PopupのBulkSet Off化にも使うので、HTMLSeqClmTable の条件は外す。
545                                // 6.2.5.0 (2015/06/05) Edit機能でも、条件によっては、書き込み許可するので、特殊処理廃止
546                        }
547                }
548                // 3.8.0.5 (2005/08/26) false の場合は、無条件に、form のviewLinkとViewMarkerをクリアします。
549                if( "false".equalsIgnoreCase( loadMarker ) ) {
550                        form.setViewLink( null );
551                        form.setViewMarker( null );
552                        form.setEditMarker( null );             // 3.8.6.1 (2006/10/24)
553                }
554                // 4.1.0.0(2008/01/11)システムパラメータ(useCheckControl)の読取は doEndTag 関数から doStartTag 関数に移動します。
555                if( useCheckControl < 0 ) {
556                        useCheckControl = intCase( sys( "VIEW_USE_CHECK_CONTROL" ) ) ;
557                }
558                setTableRowWritable( table );
559
560                setDefaultParameter();
561
562        //      if( pagePlus != 0 ) {   ※ なぜ != だったのか謎。pagePlusがマイナス時は?
563                if( pagePlus > 0 ) {
564                        form.setPageSize( pageSize + pagePlus );
565                }
566                else {
567                        form.setPageSize( pageSize );                           // 3.6.0.0 (2004/09/22) 追加
568                }
569
570                // 3.5.4.8 (2004/02/23)
571                // 6.4.1.1 (2016/01/16) PMD refactoring. A method should have only one exit point, and that should be the last statement in the method
572                return form.canUseFormat() || useParam ? EVAL_BODY_BUFFERED : SKIP_BODY ;
573
574        }
575
576        /**
577         * Taglibのタグ本体を処理する doAfterBody() を オーバーライドします。
578         *
579         * @og.rev 3.1.1.0 (2003/03/28) ボディの内容を取得する処理を、CommonTagSupport で行vう。
580         * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。ボディが存在する場合のみボディが呼ばれる対応。
581         * @og.rev 3.5.4.0 (2003/11/25) 外部からフォーマットが指定されない場合は、内部のフォーマットを登録する。
582         * @og.rev 5.1.7.0 (2010/06/01) フォーマットの{&#064;XXXX}の値に[が含まれる場合は、サイニタイズ("\\]\\"に変換)する。
583         *
584         * @return      後続処理の指示(SKIP_BODY)
585         */
586        @Override
587        public int doAfterBody() {
588                bodyString = getSanitizedBodyString();
589                return SKIP_BODY ;
590        }
591
592        /**
593         * Taglibの終了タグが見つかったときに処理する doEndTag() を オーバーライドします。
594         *
595         * @og.rev 3.0.1.3 (2003/03/11) startNo を隠しフィールドに持つ処理を、追加
596         * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。release2() を doEndTag()で呼ぶ。
597         * @og.rev 3.5.0.0 (2003/03/28) noClass 属性の追加。および、ロジック整理。
598         * @og.rev 3.5.1.0 (2003/10/03) numberType 属性の追加
599         * @og.rev 3.5.2.0 (2003/10/20) headerSkipCount属性を追加
600         * @og.rev 3.5.2.0 (2003/10/20) form が null の場合の条件分岐を追加
601         * @og.rev 3.5.3.1 (2003/10/31) Table系のViewで、skip属性を使用する。
602         * @og.rev 3.5.4.0 (2003/11/25) command="RESET"時に、戻った画面のpageSize がクリアされてしまう対応。
603         * @og.rev 3.5.4.0 (2003/11/25) フォーマット文字列を、TableFormatter オブジェクトを使用するように変更。
604         * @og.rev 3.5.4.1 (2003/12/01) startNo を隠しフィールドに持つ処理を廃止。(キャッシュを使用)
605         * @og.rev 3.5.4.3 (2004/01/05) useCheckControl属性を追加
606         * @og.rev 3.5.4.7 (2004/02/06) DBTableModelのソート機能 useTableSorter を追加
607         * @og.rev 3.5.4.7 (2004/02/06) makeStartNoKeyメソッドの廃止(setRequestCacheDataを利用)
608         * @og.rev 3.5.4.7 (2004/02/06) 実行時間測定用のDIV要素を出力しておきます。
609         * @og.rev 3.5.4.8 (2004/02/23) ViewParamTag のパラメータを追加します。
610         * @og.rev 3.5.5.5 (2004/04/23) DBTableModel の整合性パラメータを hidden で出力します。
611         * @og.rev 3.5.5.8 (2004/05/20) makeConsistencyKey メソッドに処理ロジックを移します。
612         * @og.rev 3.5.6.2 (2004/07/05) bgColorCycle 変数の追加。
613         * @og.rev 3.5.6.4 (2004/07/16) スクロールバー用のDIV要素の出力(開始)
614         * @og.rev 3.6.0.0 (2004/09/17) カラムソートリンクを出すカラム名を指定。
615         * @og.rev 3.6.0.0 (2004/09/22) pageSize の hidden 出力は、初期設定値とします。
616         * @og.rev 3.7.0.3 (2005/03/01) 指定の行番号まで画面をスクロールさせる機能を追加。
617         * @og.rev 3.7.1.1 (2005/05/23) 処理時間やページサイズなどの情報出力の有効/無効を指定します。
618         * @og.rev 3.8.0.3 (2005/07/15) ヘッダー固定のスクロールタイプをセットします。
619         * @og.rev 3.8.0.9 (2005/10/17) writableControl 属性を追加します。
620         * @og.rev 3.8.6.0 (2006/09/29) useHilightRow 属性を追加します。
621         * @og.rev 3.8.6.1 (2006/10/20) ポップアップで値を返すカラム文字列(CSV形式)
622         * @og.rev 4.0.0.0 (2007/11/27) ヘッダーカラムのエディター、レンデラー適用対応
623         * @og.rev 4.1.2.0 (2008/03/12) columnWritable,noWritable に、"null" を指定可能とする。
624         * @og.rev 4.2.0.0 (2008/03/18) ビューの高さ、幅の指定を可能にします。
625         * @og.rev 4.2.1.0 (2008/04/11) null チェック方法変更
626         * @og.rev 4.3.0.0 (2008/07/04) ロールモードによる設定
627         * @og.rev 4.3.0.0 (2008/07/04) fileUD 対応。抜き出すカラムを指定します。
628         * @og.rev 4.3.1.0 (2008/09/08) canUseFormatのエラーハンドリングは各サブクラスで行う。editOnly属性対応。
629         * @og.rev 4.3.3.0 (2008/10/01) noTransition 属性を追加します。
630         * @og.rev 4.3.6.0 (2009/04/01) eventColumn対応
631         * @og.rev 4.3.7.0 (2009/06/01) 行ハイライト機能でチェックボックスでのみON/OFFができるオプションを追加
632         * @og.rev 4.3.8.0 (2009/08/01) noTransition値取得メソッド名変更
633         * @og.rev 5.1.3.0 (2010/02/01) noTransitionのコントロールは、requestで行う。
634         * @og.rev 5.1.6.0 (2010/05/01) fileDwnClmsが指定されない場合は、Viewで表示されたカラムをセット
635         * @og.rev 5.1.7.0 (2010/06/01) 動的プルダウン実装見直し
636         * @og.rev 5.1.7.0 (2010/06/01) HilightRow用のDivは必ず出す(画面遷移なし登録(JavaScript)の正規表現でマッチさせるため))
637         * @og.rev 5.1.8.0 (2010/07/01) form.setNoGroup( noGroup ) , form.setGroupClass( groupClass ) 追加
638         * @og.rev 5.1.8.0 (2010/07/01) form.setBgColorClsClm( bgColorClsClm ) 追加
639         * @og.rev 5.1.8.0 (2010/07/01) Divを必ず出すのは、画面遷移なし登録の場合のみとする(CustomData対応)
640         * @og.rev 5.2.1.0 (2010/10/01) 一括入力カラムのアシスト機能を利用するカラムを指定します。(columnBulkSet)
641         * @og.rev 5.2.2.0 (2010/11/01) useHeaderColumn 属性を、ViewCrossTableParam.USE_HEADER_COLUMN をキーに、取得する
642         * @og.rev 5.2.2.0 (2010/11/01) caseKey 、caseVal 属性対応
643         * @og.rev 5.5.8.3 (2012/11/17) viewObject追加
644         * @og.rev 5.5.9.0 (2012/12/03) viewObjectをviewArrayListに変更
645         * @og.rev 5.7.6.1 (2014/05/09) mainView対応
646         * @og.rev 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
647         * @og.rev 6.0.3.0 (2014/11/13) Edit機能の超特殊処理
648         * @og.rev 6.2.2.0 (2015/03/27) hilightRow で、行選択時にイベント発行可否を指定できるようにする。
649         * @og.rev 6.2.5.0 (2015/06/05) Edit機能改善。条件によっては、書き込み許可するので、特殊処理廃止
650         * @og.rev 5.9.5.3 (2016/02/25) formにtableIdを渡す
651         * @og.rev 6.4.6.1 (2016/06/03) tableId 廃止(利用目的を明確にするため、パラメータ名をviewClassに変更)
652         * @og.rev 6.6.0.0 (2016/12/01) maxScrollBarSize が適用された場合に、メッセージを表示します。
653         * @og.rev 6.7.3.0 (2017/01/27) groupDir追加
654         *
655         * @return      後続処理の指示
656         */
657        @Override
658        public int doEndTag() {
659                debugPrint();           // 4.0.0 (2005/02/28)
660                // 5.2.2.0 (2010/11/01) caseKey 、caseVal 属性対応
661                if( !useTag() ) { return EVAL_PAGE ; }
662
663                // noTransition = isNoTransitionRequest() || noTransition; // 4.3.3.0 (2008/10/01) 追加
664                noTransition = isNoTransitionRequest(); // 5.1.3.0 (2010/02/01)
665                if( form == null ) { return EVAL_PAGE ; }       // 3.5.2.0 (2003/10/20)
666                if( form.canUseFormat() ) {
667                        if( values == null && bodyString != null && !useParam ) {
668                                final TableFormatter format = new TableFormatter();
669                                format.setFormatType( FormatterType.TYPE_HEAD );
670                                format.setFormat( bodyString );
671                                format.setRowspan( rowspan );
672                                values = new ArrayList<>();
673                                values.add( format );
674                                form.setFormatterList( values );
675                        }
676                        else if( values != null ) {
677                                form.setFormatterList( values );
678                        }
679                }
680
681                if( table != null ) {
682                        // 4.2.0.0 (2008/03/18) ビューの高さ、幅を指定する。null回避はAbstractViewFormで行う
683                        form.setHeight( height );
684                        form.setWidth( width );
685
686                        form.setColumnWritable( columnWritable );
687                        form.setNoWritable( noWritable );
688                        form.setColumnDisplay( columnDisplay );
689                        form.setNoDisplay( noDisplay );
690                        form.setColumnGroup( columnGroup );                             // 3.8.5.0 (2006/03/20)
691                        form.setNoGroup( noGroup );                                             // 5.1.8.0 (2010/07/01) 追加
692                        form.setGroupClass( groupClass );                               // 5.1.8.0 (2010/07/01) 追加
693                        form.setGroupDir( groupDir );                                   // 6.7.3.0 (2017/01/27) 追加
694                        form.setTableSorterKeys( sortKeys );                    // 3.6.0.0 (2004/09/17) 追加
695                        form.setNoMessage( noMessage );
696                        form.setSelectedType( selectedType );
697                        form.setUseCheckControl( useCheckControl );             // 3.5.4.3 (2004/01/05) 追加
698                        form.setNumberType( numberType );                               // 3.5.1.0 (2003/10/03) 追加
699                        form.setOptionTypeAttributes( optTypeAttri );
700                        form.setBackLinkCount( backLinkCount );
701                        form.setHeaderSkipCount( headerSkipCount );             // 3.5.2.0 (2003/10/20) 追加
702                        if( useParam ) { 
703                                form.setParam( viewParam );     // 3.5.4.8 (2004/02/23)
704                                form.setViewArrayList( viewArrayList ); // 5.5.9.0 (2012/12/03)
705                        }
706                        form.setBgColorCycle( bgColorCycle );                   // 3.5.6.2 (2004/07/05) 追加
707                        form.setBgColorClsClm( bgColorClsClm );                 // 5.1.8.0 (2010/07/01) 追加
708                        form.setWritableControl( writableControl );             // 3.8.0.9 (2005/10/17) 追加
709
710                        // 5.2.1.0 (2010/10/01) 初期バルクセットが true で、かつ、変数が未設定の場合は、全カラム(*)選択とする。
711                        if( useDefBulkset && columnBulkSet == null ) { columnBulkSet = "*"; }
712                        // selectedType が radio の場合は、カラムの設定を行わない。
713                        if( "radio".equalsIgnoreCase( selectedType ) ) { columnBulkSet = null; }
714                        form.setColumnBulkSet( columnBulkSet );                 // 5.2.1.0 (2010/10/01) 追加
715
716                        // 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
717                        // editConf が null でないという事は、lastSql の条件がクリアされている。
718                        if( editConf != null ) {
719                                // 6.0.3.0 (2014/11/13) Edit機能の超特殊処理
720                                // setColumnDisplay(String) の後でないと、リセットされてしまう。
721                                // 6.2.5.0 (2015/06/05) Edit機能でも、条件によっては、書き込み許可するので、特殊処理廃止
722        //                      if( editMarkerClmNos != null ) {
723        //                              for( int i=0; i<editMarkerClmNos.length; i++ ) {
724        //                                      form.setColumnDisplay( editMarkerClmNos[i] , false );   // 表示しない
725        //                              }
726        //                      }
727
728                                final String orgClms = form.getViewClms();              // form.setColumnDisplay(String) の再セット前に取り出す。
729                                lastSql.setOrgClmNames( orgClms );      
730                                final String userViewClms = editConf.getViewClms( orgClms );
731                                makeEditTable( userViewClms );                                  // ここで、clmSeqDisplay を再セットしている。
732                        }
733
734                        // 6.0.2.4 (2014/10/17) makeEditTable メソッドで、clmSeqDisplay を再セットしている。
735                        if( clmSeqDisplay != null ) {
736                                form.setColumnDisplay( clmSeqDisplay );         // noDisplay は無視されます。
737                        }
738
739                        // 3.6.0.0 (2004/09/22) pageSize の hidden 出力は、初期設定値とします。
740                        final int oldPageSize = pageSize;
741                        pageSize = form.getPageSize();
742                        commandExec( command );
743
744                        form.setStartNo( startNo );
745                        form.setSkip( skip );                                                   // 3.5.3.1 (2003/10/31)
746                        form.setSkipNoEdit( skipNoEdit );                               // 4.3.1.0 (2008/09/08)
747                        final boolean useTblSorter = "session".equals( getScope() ) &&
748                                                nval( useTableSorter,sysBool( "VIEW_USE_TABLE_SORTER" ) );
749                        form.setUseTableSorter( useTblSorter );         // 3.5.4.7 (2004/02/06)
750
751                        // 3.6.0.0 (2004/09/17)
752                        // tableSorter 時のリンクに追加するリクエスト変数のキャッシュMapを追加する。
753                        if( useTblSorter || sortKeys != null ) {
754                                // 4.0.0 (2005/01/31)
755                                final String memKey = HybsSystem.REQ_CACHE_KEY + getGUIInfoAttri( "KEY" );
756                                final Map<?,?> mem = (Map<?,?>)getSessionAttribute( memKey );           // 4.3.3.6 (2008/11/15) Generics警告対応
757                                form.makeTableSorterQuery( mem );
758                        }
759
760                        // 3.5.6.4 (2004/07/16) スクロールバー用のDIV要素の出力(開始)
761                        // 3.8.0.3 (2005/07/15) ヘッダー固定のスクロールタイプをセットします。
762                        // 4.0.0.0 (2007/04/10) ヘッダー固定のスクロールタイプは、一つにする。
763
764                        // 6.2.4.0 (2015/05/15) maxScrollBarSize 追加
765
766                        // 6.6.0.0 (2016/12/01) maxScrollBarSize が適用された場合に、メッセージを表示します。
767                        final boolean useScBar = nval( useScrollBar,sysBool( "VIEW_USE_SCROLLBAR" ) );
768                        final boolean inRange  = Math.min( pageSize,table.getRowCount() ) < maxScrollBarSize ;
769                        form.setUseScrollBar( useScBar && inRange );
770
771                        if( useScBar && !inRange ) {                                    // ヘッダー固定を使用するが、範囲外なので、使用しない。
772                                jspPrint( getResource().getLabel( "MSG0091" ,  String.valueOf( maxScrollBarSize ) ) );
773                        }
774
775                        // 3.8.6.1 (2006/10/20) ポップアップで値を返すカラム文字列(CSV形式)
776                        form.setPopupReturnKeys( popupReturnKeys );
777                        form.setTableClass( clazz );            // 4.0.0 (2007/04/16)
778
779                        // 3.7.0.3 (2005/03/01) 指定の行番号まで画面をスクロールさせる機能を追加。{I} は無視する。
780                        final String rowval = nval( getRequestValue( "SEL_ROW" ),null ) ;
781
782                        final boolean useSelRow = nval( useSelectedRow,sysBool( "VIEW_USE_SELECTED_ROW" ) );
783                        if( useSelRow && rowval != null && !rowval.equalsIgnoreCase( "{I}" ) ) {
784                                final boolean useSelRowClr = nval( useSelRowColor,sysBool( "VIEW_USE_SELROW_COLOR" ) ) ;
785                                form.setScrollRowNo( Integer.parseInt( rowval ),useSelRowClr );
786                        }
787
788                        // 4.0.0 (2005/11/30) カラムロールを判定して、アクセス不可の場合は表示させないようにする。
789                        final int clmSize = table.getColumnCount();
790                        final UserInfo userInfo = getUser();
791                        for( int clmNo=0; clmNo<clmSize; clmNo++ ) {
792                                final DBColumn dbColumn = table.getDBColumn( clmNo );
793
794                                // 4.3.6.0 (2009/04/01) セッションに生SQLを登録
795                                // 5.1.7.0 (2010/06/01) 動的プルダウン実装見直し
796                                final String evCol = dbColumn.getEventColumn();
797                                if( evCol != null && evCol.length() > 0 ){
798                                        addEventColumn( dbColumn );
799                                }
800
801                                // 4.3.0.0 (2008/07/04) ロールモードによる設定
802                                final byte bitMode = userInfo.getAccessBitMode( dbColumn.getRoleMode() );
803                                // アクセス不許可の場合のみ、セットする。
804                                // それ以外は、columnDisplay ,noDisplay 属性が適用されている。
805                                if( !RoleMode.isRead( bitMode ) ) {
806                                        form.setColumnDisplay( clmNo,false );
807                                }
808                                // 書込み不許可の場合のみ、セットする。
809                                // それ以外は、columnWritable ,noWritable 属性が適用されている。
810                                if( !RoleMode.isWrite( bitMode ) ) {
811                                        form.setColumnWritable( clmNo,false );
812                                }
813                        }
814
815                        // 3.8.6.0 (2006/09/29) useHilightRow 属性追加
816                        final boolean useHiRow = nval( useHilightRow,sysBool( "VIEW_USE_HILIGHT_ROW" ) );
817                        // 5.1.7.0 (2010/06/01) HilightRow用のDivは必ず出す(画面遷移なし登録(JavaScript)の正規表現でマッチさせるため))
818                        // 5.1.8.0 (2010/07/01) Divを必ず出すのは、画面遷移なし登録の場合のみとする(CustomData対応)
819                        if( useHiRow || noTransition ) {
820                                jspPrint( "<div id=\"divHlr\"" );
821                                if( useHiRow ) {
822                                        // 4.3.7.0 (2009/06/01) 6.0.2.5 (2014/10/31) refactoring
823                                        final boolean useHiCkOnly = nval( isHiRowCheckOnly ,sysBool( "VIEW_USE_HILIGHT_CHECK_ONLY"  ) );
824                                        // 6.2.2.0 (2015/03/27) hilightRow で、行選択時にイベント発行可否を指定できるようにする。
825                                        final boolean useRdoClick = nval( isHiRadioClick   ,sysBool( "VIEW_USE_HILIGHT_RADIO_CLICK" ) );
826                                        jspPrint( " onclick=\"hilightRow( event, " + useHiCkOnly + ","  + useRdoClick + ");\"" );
827                                }
828                                jspPrint( ">" );
829                        }
830
831                        // 5.2.2.0 (2010/11/01) useHeaderColumn 属性を、ViewCrossTableParam.USE_HEADER_COLUMN をキーに、取得する
832                        if( viewParam != null &&
833                                        "true".equalsIgnoreCase( viewParam.get( ViewCrossTableParam.USE_HEADER_COLUMN ) ) ) {
834                                form.setResourceManager( getResource() );
835                        }
836
837                        form.setNoTransition( noTransition );           // 4.3.3.0 (2008/10/01) 追加
838
839                        // 6.4.6.1 (2016/06/03) tableId 廃止(利用目的を明確にするため、パラメータ名をviewClassに変更)
840                        form.setViewClass( viewClass );                         // 6.4.6.1 (2016/06/03)
841
842                        jspPrint( form.create( startNo,pageSize ) );
843
844                        // 5.1.8.0 (2010/07/01) Divを必ず出すのは、画面遷移なし登録の場合のみとする(CustomData対応)
845                        if( useHiRow || noTransition ) {
846                                jspPrint( "</div>" );
847                        }
848
849                        // 5.7.6.1 (2014/05/09) mainView時のみstartNoを登録する
850                        if( isMainView ){
851                                setRequestCacheData( START_NO_KEY,String.valueOf( tempStartNo ) );      // 3.5.4.7 (2004/02/06)
852                        }
853
854                        // 3.6.0.0 (2004/09/22) pageSize の hidden 出力は、初期設定値とします。
855                        if( useAfterHtmlTag ) { // 3.7.1.1 (2005/05/23)
856                                jspPrint( makePageSize( oldPageSize ) );                // 3.6.0.0 (2004/09/22)
857                        }
858
859                        makeConsistencyKey();           // 3.5.5.8 (2004/05/20)
860
861                        setObject( viewFormId, form );
862
863                        // 3.5.4.8 (2004/02/23) 超特殊処理 DBTableModel を View で置き換えます。
864                        // 5.2.2.0 (2010/11/01) saveTableId 属性を、ViewCrossTableParam.SAVE_SCOPE_KEY をキーに、取得する
865                        if( viewParam != null ) {
866                                final String saveTableId = viewParam.get( ViewCrossTableParam.SAVE_TABLEID_KEY );       // 5.2.2.0 (2010/11/01)
867                                if( saveTableId != null ) {
868                                        final String saveScope = viewParam.get( ViewCrossTableParam.SAVE_SCOPE_KEY );
869                                        setObject( saveTableId, form.getDBTableModel() , saveScope );
870                                }
871                        }
872
873                        // 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
874                        // 5.1.6.0 (2010/05/01) Viewで表示した項目をDBLastSqlにセットします。
875                        if( table.getRowCount() > 0 && lastSql != null ) {
876                                setViewClms( lastSql );
877                        }
878                }
879
880                if( useTimeView && useAfterHtmlTag ) {          // 6.3.6.0 (2015/08/16)
881                        // 3.5.4.7 (2004/02/06)
882                        final long dyTime = System.currentTimeMillis()-dyStart;
883                        jspPrint( "<div id=\"viewTime\" value=\"" + (dyTime) + "\"></div>" );   // 3.5.6.3 (2004/07/12)
884                }
885
886                return EVAL_PAGE ;
887        }
888
889        /**
890         * タグリブオブジェクトをリリースします。
891         * キャッシュされて再利用されるので、フィールドの初期設定を行います。
892         *
893         * @og.rev 2.0.0.4 (2002/09/27) カスタムタグの release() メソッドを、追加
894         * @og.rev 2.0.0.4 (2002/09/27) カスタムタグの release() メソッドを、追加
895         * @og.rev 3.0.1.3 (2003/03/11) startNo を隠しフィールドに持つ処理を、追加
896         * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。release2() を doEndTag()で呼ぶ。
897         * @og.rev 3.5.2.0 (2003/10/20) headerSkipCount属性を追加
898         * @og.rev 3.5.3.0 (2003/10/27) backLinkCount,headerSkipCount属性の初期値をPropertyファイルから設定
899         * @og.rev 3.5.4.0 (2003/11/25) format 関係の文字列を廃止。TableFormatter クラスを使用する。
900         * @og.rev 3.5.4.3 (2004/01/05) useCheckControl属性を追加
901         * @og.rev 3.5.4.7 (2004/02/06) DBTableModelのソート機能 useTableSorter を追加
902         * @og.rev 3.5.4.7 (2004/02/06) 実行時間測定用に、dyStart を追加します。
903         * @og.rev 3.5.4.8 (2004/02/23) ViewParamTag のパラメータを追加します。
904         * @og.rev 3.5.5.8 (2004/05/20) useConsistency 属性を追加します。
905         * @og.rev 3.5.6.2 (2004/07/05) bgColorCycle 変数の追加。
906         * @og.rev 3.5.6.3 (2004/07/12) useScrollBar 変数の追加。
907         * @og.rev 3.6.0.0 (2004/09/17) sortKeys 変数の追加。カラムソートリンクを出すカラム名を指定。
908         * @og.rev 3.6.0.4 (2004/10/14) loadMarker 変数の追加。
909         * @og.rev 3.7.0.1 (2005/01/31) 全件チェックコントロール変更(useCheckControl)
910         * @og.rev 3.7.1.1 (2005/05/23) SEL_ROW機能の有効/無効を指定します。
911         * @og.rev 3.7.1.1 (2005/05/23) 処理時間やページサイズなどの情報出力の有効/無効を指定します。
912         * @og.rev 3.8.0.9 (2005/10/17) writableControl 属性を追加します。
913         * @og.rev 3.8.6.0 (2006/09/29) useHilightRow 属性を追加します。
914         * @og.rev 3.8.6.1 (2006/10/20) editMarkerId , popupReturnKeys属性を追加します。
915         * @og.rev 4.3.0.0 (2008/07/04) fileUD ファイルダウンロード時の抜出カラム名(CSV形式)
916         * @og.rev 4.3.1.0 (2008/09/08) isSkipNoEdit属性対応
917         * @og.rev 4.3.3.0 (2008/10/01) noTransition 属性を追加します。
918         * @og.rev 4.3.7.0 (2009/06/01) useHilightCheckOnly 属性を追加します。
919         * @og.rev 5.1.6.0 (2010/05/01) clmSeqDisplay 属性を追加します。
920         * @og.rev 5.1.8.0 (2010/07/01) noGroup , noGroup 属性を追加します。
921         * @og.rev 5.1.8.0 (2010/07/01) bgColorClsClm 属性を追加します。
922         * @og.rev 5.2.1.0 (2010/10/01) 一括入力カラムのアシスト機能を利用する、columnBulkSet 属性を追加します。
923         * @og.rev 5.5.9.0 (2012/12/03) viewArrayList追加
924         * @og.rev 5.7.6.1 (2014/05/09) mainView追加
925         * @og.rev 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
926         * @og.rev 6.0.3.0 (2014/11/13) Edit機能の超特殊処理。editMarkerClmNos 追加
927         * @og.rev 6.2.2.0 (2015/03/27) hilightRow で、行選択時にイベント発行可否を指定できるようにする。isHiRadioClick 追加
928         * @og.rev 6.2.4.0 (2015/05/15) maxScrollBarSize 追加
929         * @og.rev 6.2.5.0 (2015/06/05) Edit機能改善。条件によっては、書き込み許可するので、特殊処理廃止
930         * @og.rev 6.3.6.0 (2015/08/16) useTimeView の初期値を、VIEW_USE_TIMEBAR にする。
931         * @og.rev 6.4.6.1 (2016/06/03) tableId 廃止(利用目的を明確にするため、パラメータ名をviewClassに変更)
932         * @og.rev 6.7.3.0 (2017/01/27) groupDir追加
933         */
934        @Override
935        protected void release2() {
936                super.release2();
937                tableId                         = HybsSystem.TBL_MDL_KEY;
938                viewFormId                      = HybsSystem.VIEWFORM_KEY;
939                viewFormType            = null;
940                viewLinkId                      = HybsSystem.VIEWLINK_KEY;
941                viewMarkerId            = HybsSystem.VIEW_MARK_KEY;
942                editMarkerId            = HybsSystem.EDIT_MARK_KEY;             // 3.8.6.1 (2006/10/20)
943                command                         = null;
944                startNo                         = -1;                   // HTML画面上の表示開始位置(初期値)
945                tempStartNo                     = -1;                   // 再検索時の表示開始位置
946                pageSize                        = -1;                   // HTML画面上に表示する件数
947                pagePlus                        = -1;                   // 3.5.6.4 (2004/07/16)
948                table                           = null;
949                form                            = null;
950                columnWritable          = null;
951                noWritable                      = null;
952                columnDisplay           = null;
953                noDisplay                       = null;
954                clmSeqDisplay           = null;                 // 5.1.6.0 (2010/05/01) ViewForm_HTMLSeqClmTable 対応
955                columnGroup                     = null;                 // 3.8.5.0 (2006/03/20)
956                noGroup                         = null;                 // 5.1.8.0 (2010/07/01)
957                groupClass                      = null;                 // 5.1.8.0 (2010/07/01)
958                groupDir                        = false;                // 6.7.3.0 (2017/01/27) false:ROW/true:COLUMN
959                noMessage                       = false;
960                writable                        = null;
961                checked                         = null;
962                skip                            = ViewForm.DEFAULT_SKIP;
963                rowspan                         = "2";
964                selectedType            = "checkbox";
965                numberType                      = "sequence";
966                optTypeAttri            = null;
967                values                          = null;
968                backLinkCount           = HybsSystem.sysInt( "VIEW_BACK_LINK_COUNT" );
969                headerSkipCount         = HybsSystem.sysInt( "VIEW_HEADER_SKIP_COUNT" );        // 0:通常ヘッダ、n:n回ごとに現れる
970                bodyString                      = null;
971                useCheckControl         = -1 ;
972                useTableSorter          = null ;                // 3.5.4.7 (2004/02/06)
973                useTimeView                     = HybsSystem.sysBool( "VIEW_USE_TIMEBAR" );     // 6.3.6.0 (2015/08/16)
974                viewParam                       = null;                 // 3.5.4.8 (2004/02/23)
975                useParam                        = false;                // 3.5.4.8 (2004/02/23)
976                useConsistency          = HybsSystem.sysBool( "USE_CONSISTENCY" );              // 3.5.5.8 (2004/05/20)
977                bgColorCycle            = 1 ;                   // 3.5.6.2 (2004/07/05)
978                bgColorClsClm           = null;                 // 5.1.8.0 (2010/07/01)
979                useScrollBar            = null;
980                maxScrollBarSize        = HybsSystem.sysInt( "VIEW_SCROLLBAR_MAX_ROW_SIZE" ) ;          // 6.2.4.0 (2015/05/15)
981                sortKeys                        = null;                 // 3.6.0.0 (2004/09/17)
982                loadMarker                      = ",NEW,RENEW,REVIEW,RESET,";                                   // 4.0.0.0 (2007/11/26)
983                useSelectedRow          = null;
984                useSelRowColor          = null;
985                useAfterHtmlTag         = true;                 // 3.7.1.1 (2005/05/23)
986                writableControl         = null;                 // 3.8.0.9 (2005/10/17)
987                useHilightRow           = null;                 // 3.8.6.0 (2006/09/29)
988                popupReturnKeys         = null;                 // 3.8.6.1 (2006/10/20)
989                clazz                           = "viewTable";  // 4.0.0 (2007/04/16)
990                height                          = null;                 // 4.2.0.0 (2008/03/18)
991                width                           = null;                 // 4.2.0.0 (2008/03/18)
992                fileDwnClms                     = null;                 // 4.3.0.0 (2008/07/04)
993                skipNoEdit                      = false;                // 4.3.1.0 (2008/09/08)
994                noTransition            = false;                // 4.3.3.0 (2008/10/01)
995                isHiRowCheckOnly        = null;                 // 4.3.7.0 (2009/06/01)                 // 6.0.2.5 (2014/10/31) refactoring
996                isHiRadioClick          = null;                 // 6.2.2.0 (2015/03/27)
997                columnBulkSet           = null;                 // 5.2.1.0 (2010/10/01)
998                useDefBulkset           = HybsSystem.sysBool( "VIEW_USE_DEFAULT_BULKSET" ) ;            // 5.2.1.0 (2010/10/01)
999                viewArrayList           = null;                 // 5.5.9.0 (2012/12/03)
1000                isMainView                      = true;                 // 5.7.6.1 (2014/05/09)
1001                lastSql                         = null;                 // 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
1002                editConf                        = null;                 // 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
1003                viewClass                       = null;                 // 6.4.6.1 (2016/06/03)
1004        }
1005
1006        /**
1007         * 左右分割スクロール(SplitViewTag)が存在すれば、パラメータの初期値設定などを行います。
1008         *
1009         * @og.rev 5.3.0.0 (2010/12/01) 左右分割スクロール(SplitViewTag)対応
1010         * @og.rev 5.5.4.0 (2012/07/02) 2回目のnoDisplayを追記型に変更
1011         * @og.rev 6.4.6.1 (2016/06/03) tableId 廃止(利用目的を明確にするため、パラメータ名をviewClassに変更)
1012         */
1013        private void splitViewParamSet() {
1014                final SplitViewTag splitView = (SplitViewTag)findAncestorWithClass( this,SplitViewTag.class );
1015                if( splitView != null ) {
1016                        final String  fixDisplay  = splitView.getFixDisplay();
1017                        final boolean isFirstStep = splitView.isFirstStep();
1018
1019                        if( isFirstStep ) {     // 1回目(左側:固定部)
1020                                // Viewタグの左側には、fixDisplay のカラムを columnDisplay に設定する。
1021                                columnDisplay   = fixDisplay;
1022                                noDisplay               = null;
1023                                viewClass               = "VIEW_X1";                    // 6.4.6.1 (2016/06/03)
1024                        }
1025                        else {                          // 2回目(右側:可変部)
1026                                // Viewタグの右側には、command="VIEW" , noMessage="true" , useSelectedRow="false"
1027                                // numberType="delete" をセットするとともに、fixDisplay のカラムを noDisplay の
1028                                columnDisplay = null;
1029                                if( noDisplay != null && noDisplay.length() > 0 ){
1030                                        noDisplay       += "," + fixDisplay;    // 5.5.4.0 (2012/07/02) CSV形式で追記する
1031                                }
1032                                else{
1033                                        noDisplay     = fixDisplay;
1034                                }
1035
1036                                command                 = "VIEW";
1037                                numberType              = "delete";
1038                                noMessage               = true;
1039                                useSelectedRow  = "false";
1040                                viewClass               = "VIEW_X2";                    // 6.4.6.1 (2016/06/03)
1041                        }
1042                }
1043        }
1044
1045        /**
1046         * 【TAG】(通常は使いません)結果のDBTableModelを、sessionに登録するときのキーを指定します
1047         *              (初期値:HybsSystem#TBL_MDL_KEY[={@og.value HybsSystem#TBL_MDL_KEY}])。
1048         *
1049         * @og.tag
1050         * 検索結果より、DBTableModelオブジェクトを作成します。これを、下流のviewタグ等に
1051         * 渡す場合に、通常は、session を利用します。その場合の登録キーです。
1052         * query タグを同時に実行して、結果を求める場合、同一メモリに配置される為、
1053         * この tableId 属性を利用して、メモリ空間を分けます。
1054         *              (初期値:HybsSystem#TBL_MDL_KEY[={@og.value HybsSystem#TBL_MDL_KEY}])。
1055         *
1056         * @param       id テーブルID (sessionに登録する時のID)
1057         */
1058        public void setTableId( final String id ) {
1059                tableId   = nval( getRequestParameter( id ),tableId );  // 3.8.0.9 (2005/10/17)
1060        }
1061
1062        /**
1063         * 【TAG】(通常は使いません)sessionから取得する ViewForm オブジェクトの ID。
1064         *
1065         * @og.tag
1066         * 表示処理後に,(内部ポインタを書き換えた)ViewForm オブジェクトを
1067         * 同じキーで、sessionに登録します。
1068         * 初期値は、HybsSystem.VIEWFORM_KEY です。
1069         *
1070         * @og.rev 3.3.1.1 (2003/07/03) {&#064;XXXX} 変数が使用できるように修正。
1071         * @og.rev 3.5.6.4 (2004/07/16) VIEW_ID を付加して、他のid と混同しないようにします。
1072         *
1073         * @param       id ViewFormオブジェクトID
1074         */
1075        public void setViewFormId( final String id ) {
1076                final String temp = getRequestParameter( id ) ;
1077                if( temp != null && temp.length() > 0 ) {
1078                        viewFormId = temp + TaglibUtil.VIEW_ID;
1079                }
1080        }
1081
1082        /**
1083         * 【TAG】(通常は使いません)requestから取得する ViewLink に対応する Attributes オブジェクトの ID。
1084         *
1085         * @og.tag
1086         * ViewForm オブジェクトに、ViewLink オブジェクトをこのキーより取得することにより、
1087         * カラムに対して、リンク情報を付加して表示させる。
1088         * 初期値は、HybsSystem.VIEWLINK_KEY です。
1089         *
1090         * @og.rev 3.1.4.0 (2003/04/18) 初期値を考慮して、属性登録を行うように変更。
1091         * @og.rev 3.3.1.1 (2003/07/03) {&#064;XXXX} 変数が使用できるように修正。
1092         * @og.rev 3.5.6.4 (2004/07/16) LINK_ID を付加して、他のid と混同しないようにします。
1093         *
1094         * @param       id ViewLinkオブジェクトID
1095         */
1096        public void setViewLinkId( final String id ) {
1097                final String temp = getRequestParameter( id ) ;
1098                if( temp != null && temp.length() > 0 ) {
1099                        viewLinkId = temp + TaglibUtil.LINK_ID;
1100                }
1101        }
1102
1103        /**
1104         * 【TAG】(通常は使いません)requestから取得する ViewMarker に対応する Attributes オブジェクトの ID。
1105         *
1106         * @og.tag
1107         * ViewForm オブジェクトに、ViewMarker オブジェクトをこのキーより取得することにより、
1108         * カラムに対して、マーカー情報を付加して表示させる。
1109         * 初期値は、HybsSystem.VIEW_MARK_KEY です。
1110         *
1111         * @og.rev 3.1.4.0 (2003/04/18) 新規追加
1112         * @og.rev 3.3.1.1 (2003/07/03) {&#064;XXXX} 変数が使用できるように修正。
1113         * @og.rev 3.5.6.4 (2004/07/16) MARK_ID を付加して、他のid と混同しないようにします。
1114         *
1115         * @param       id ViewMarkerオブジェクトID
1116         */
1117        public void setViewMarkerId( final String id ) {
1118                final String temp = getRequestParameter( id ) ;
1119                if( temp != null && temp.length() > 0 ) {
1120                        viewMarkerId = temp + TaglibUtil.MARK_ID;
1121                }
1122        }
1123
1124        /**
1125         * 【TAG】(通常は使いません)requestから取得する EditMarker に対応する Attributes オブジェクトの ID。
1126         *
1127         * @og.tag
1128         * ViewForm オブジェクトに、EditMarker オブジェクト(実際は、ViewMarker オブジェクト)を
1129         * このキーより取得することにより、カラムに対して、マーカー情報を付加して表示させる。
1130         * 初期値は、HybsSystem.EDIT_MARK_KEY です。
1131         *
1132         * @og.rev 3.8.6.1 (2006/10/20) 新規追加
1133         *
1134         * @param       id EditMarkerオブジェクトID (実際は、ViewMarker オブジェクト)
1135         */
1136        public void setEditMarkerId( final String id ) {
1137                final String temp = getRequestParameter( id ) ;
1138                if( temp != null && temp.length() > 0 ) {
1139                        editMarkerId = temp + TaglibUtil.MARK_ID;
1140                }
1141        }
1142
1143        /**
1144         * 【TAG】ViewForm オブジェクトを作成するクラス({@og.doc03Link viewFormType ViewForm_**** クラスの ****})を指定します。
1145         *
1146         * @og.tag
1147         * これは、org.opengion.hayabusa.html 以下の ViewForm_**** クラスの **** を
1148         * 与えます。これらは、ViewForm インターフェースを継承したサブクラスです。
1149         * 属性クラス定義の {@link org.opengion.hayabusa.html.ViewForm  ViewForm} を参照願います。
1150         * {@og.doc03Link viewFormType ViewForm_**** クラス}
1151         *
1152         * @param       id ViewFormクラス
1153         * @see         org.opengion.hayabusa.html.ViewForm  ViewFormのサブクラス
1154         */
1155        public void setViewFormType( final String id ) {
1156                viewFormType = getRequestParameter( id );
1157
1158                if( viewFormType == null || viewFormType.isEmpty() ) {
1159                        final String errMsg = "viewForm の id が設定されていません。";
1160                        throw new HybsSystemException( errMsg );
1161                }
1162        }
1163
1164        /**
1165         * 【TAG】コマンド (PREV,NEXT,FIRST,LAST,NEW,RENEW,VIEW,REVIEW,RESET)をセットします。
1166         *
1167         * @og.tag
1168         * コマンドは,HTMLから(get/post)指定されますので,CMD_xxx で設定される
1169         * フィールド定数値のいづれかを、指定できます。
1170         *
1171         * @og.rev 3.8.0.8 (2005/10/03) その他のコマンドを CMD_XXX にします。
1172         * @og.rev 6.3.4.0 (2015/08/01) checkメソッド内で、nullチェックも行っている。
1173         * @og.rev 6.4.3.4 (2016/03/11) String配列 から、Setに置き換えます。
1174         *
1175         * @param       cmd コマンド (public static final 宣言されている文字列)
1176         * @see         <a href="../../../../constant-values.html#org.opengion.hayabusa.taglib.ViewFormTag.CMD_PREV">コマンド定数</a>
1177         */
1178        public void setCommand( final String cmd ) {
1179                final String cmd2 = getRequestParameter( cmd );
1180                if( cmd2 != null && cmd2.length() > 0 ) { command = cmd2.toUpperCase(Locale.JAPAN); }
1181
1182                if( ! check( command, COMMAND_SET ) ) {
1183                                // 3.8.0.8 (2005/10/03) その他のコマンドを CMD_XXX にします。
1184                                command = CMD_XXX ;
1185                }
1186        }
1187
1188        /**
1189         * 【TAG】表示データを作成する場合の表示の開始行番号(先頭は0)をセットします。
1190         *
1191         * @og.tag
1192         * セットされていない場合は,変更しません。
1193         *
1194         * @og.rev 3.0.1.3 (2003/03/11) startNo を隠しフィールドに持つ処理を、追加
1195         *
1196         * @param       no 表示開始
1197         */
1198        public void setStartNo( final String no ) {
1199                startNo = nval( getRequestParameter( no ),startNo );
1200                tempStartNo = startNo;
1201        }
1202
1203        /**
1204         * 【TAG】表示データを作成する場合の1ページの行数をセットします。
1205         *
1206         * @og.tag
1207         * セットされていない場合は,変更しません。
1208         *
1209         * @param       sz 表示件数
1210         */
1211        public void   setPageSize( final String sz ) {
1212                pageSize = nval( getRequestParameter( sz ),pageSize );
1213        }
1214
1215        /**
1216         * 【TAG】1ページの行数の増加分をセットします(初期値:0)。
1217         *
1218         * @og.tag
1219         * セットされていない場合は,0(増加なし)です。
1220         *
1221         * @param       pp 1ページの行数
1222         */
1223        public void   setPagePlus( final String pp ) {
1224                pagePlus = nval( getRequestParameter( pp ),pagePlus );
1225        }
1226
1227        /**
1228         * 【TAG】ページの先頭へのリンクの間隔をセットします
1229         *              (初期値:VIEW_BACK_LINK_COUNT[={@og.value SystemData#VIEW_BACK_LINK_COUNT}])。
1230         *
1231         * @og.tag
1232         * 0 にセットすると、リンクは作成されません。
1233         * テーブルのヘッダー固定ができないケースでは、データ件数が多いと、登録ボタンが見えなくなります。
1234         * その場合、スクロールして上に上がるより、行番号に作成されリンクで、一気に上に戻るほうが早く処理できます。
1235         * その場合、段組み等していると、間隔を少なくしておく必要が出てきます。
1236         * ヘッダー固定を利用する場合は、不要です。
1237         * (初期値:システム定数のVIEW_BACK_LINK_COUNT[={@og.value SystemData#VIEW_BACK_LINK_COUNT}])。
1238         *
1239         * @param       blc リンクの間隔
1240         * @see         org.opengion.hayabusa.common.SystemData#VIEW_BACK_LINK_COUNT
1241         */
1242        public void   setBackLinkCount( final String blc ) {
1243                backLinkCount = nval( getRequestParameter( blc ),backLinkCount );
1244        }
1245
1246        /**
1247         * 【TAG】ヘッダーを出力する間隔をセットします
1248         *              (初期値:VIEW_HEADER_SKIP_COUNT[={@og.value SystemData#VIEW_HEADER_SKIP_COUNT}])。
1249         *
1250         * @og.tag
1251         * 0を指定すると、繰り返しません(つまり、ヘッダーを最初に表示するだけです。)
1252         * 数字を指定すると、その回数毎に、ヘッダーをデータの行に挿入します。
1253         * (初期値:システム定数のVIEW_HEADER_SKIP_COUNT[={@og.value SystemData#VIEW_HEADER_SKIP_COUNT}])。
1254         *
1255         * @og.rev 3.5.2.0 (2003/10/20) 新規作成
1256         *
1257         * @param       hsc ヘッダーの表示間隔 (0:通常ヘッダ,n:n回ごとに現れる)
1258         * @see         org.opengion.hayabusa.common.SystemData#VIEW_HEADER_SKIP_COUNT
1259         */
1260        public void   setHeaderSkipCount( final String hsc ) {
1261                headerSkipCount = nval( getRequestParameter( hsc ),headerSkipCount );
1262        }
1263
1264        /**
1265         * 【TAG】書き込み可能カラム名を、CSV形式で与えます。
1266         *
1267         * @og.tag
1268         * これは、書き込み不可カラム名の指定(noWritable)と同時にセットする
1269         * ことは出来ません。
1270         * "*" を指定すると、すべてのカラムを(columnWritable)指定したことになります。
1271         *
1272         * @og.rev 3.3.1.1 (2003/07/03) {&#064;XXXX} 変数が使用できるように修正。
1273         * @og.rev 4.1.2.0 (2008/03/12) 引数に、"null" を指定可能とする。
1274         * @og.rev 4.2.1.0 (2008/04/11) null チェック方法変更
1275         * @og.rev 4.2.1.1 (2008/04/30) 引数にA,B,{&#064;XXXX}等が指定された場合に{&#064;XXXX}の変換が行われないバグを修正
1276         * @og.rev 5.1.8.0 (2010/07/01) noWritable 同時セットチェックを、メソッドではなく、本体で行う。
1277         *
1278         * @param       columnName      書込可能カラム名 (CSV形式) (例:"OYA,KO,HJO,SU,DYSET,DYUPD")
1279         * @see         #setNoWritable( String )
1280         */
1281        public void setColumnWritable( final String columnName ) {
1282                columnWritable = nval( getRequestParameter(columnName),null );
1283                if( "null".equalsIgnoreCase( columnWritable ) ) { columnWritable = ""; }
1284        }
1285
1286        /**
1287         * 【TAG】書き込み不可カラム名を、CSV形式で与えます。
1288         *
1289         * @og.tag
1290         * これは、書き込み可能カラム名の指定(columnWritable)と同時にセットする
1291         * ことは出来ません。
1292         * "*" を指定すると、すべてのカラムを(noWritable)指定したことになります。
1293         *
1294         * @og.rev 3.3.1.1 (2003/07/03) {&#064;XXXX} 変数が使用できるように修正。
1295         * @og.rev 4.1.2.0 (2008/03/12) 引数に、"null" を指定可能とする。
1296         * @og.rev 4.2.1.0 (2008/04/11) null チェック方法変更
1297         * @og.rev 4.2.1.1 (2008/04/30) 引数にA,B,{&#064;XXXX}等が指定された場合に{&#064;XXXX}の変換が行われないバグを修正
1298         * @og.rev 5.1.8.0 (2010/07/01) noWritable 同時セットチェックを、メソッドではなく、本体で行う。
1299         *
1300         * @param       columnName      書込不可カラム名 (CSV形式) (例:"OYA,KO,HJO,SU,DYSET,DYUPD")
1301         * @see         #setColumnWritable( String )
1302         */
1303        public void setNoWritable( final String columnName ) {
1304                noWritable = nval( getRequestParameter(columnName),null );
1305                if( "null".equalsIgnoreCase( noWritable ) ) { noWritable = ""; }
1306        }
1307
1308        /**
1309         * 【TAG】表示可能カラム名を、CSV形式で与えます。
1310         *
1311         * @og.tag
1312         * これは、表示不可カラム名の指定(noDisplay)と同時にセットする
1313         * ことは出来ません。
1314         * "*" を指定すると、すべてのカラムを(columnDisplay)指定したことになります。
1315         *
1316         * @og.rev 3.3.1.1 (2003/07/03) {&#064;XXXX} 変数が使用できるように修正。
1317         * @og.rev 5.1.8.0 (2010/07/01) noWritable 同時セットチェックを、メソッドではなく、本体で行う。
1318         *
1319         * @param       columnName      表示可能カラム名 (CSV形式) (例:"OYA,KO,HJO,SU,DYSET,DYUPD")
1320         * @see         #setNoDisplay( String )
1321         */
1322        public void setColumnDisplay( final String columnName ) {
1323                columnDisplay = nval( getRequestParameter(columnName),null );
1324                if( "null".equalsIgnoreCase( columnDisplay ) ) { columnDisplay = ""; }
1325        }
1326
1327        /**
1328         * 【TAG】表示不可カラム名を、CSV形式で与えます。
1329         *
1330         * @og.tag
1331         * これは、表示可能カラム名の指定(columnDisplay)と同時にセットする
1332         * ことは出来ません。
1333         * "*" を指定すると、すべてのカラムを(noDisplay)指定したことになります。
1334         *
1335         * @og.rev 3.3.1.1 (2003/07/03) {&#064;XXXX} 変数が使用できるように修正。
1336         * @og.rev 5.1.8.0 (2010/07/01) noWritable 同時セットチェックを、メソッドではなく、本体で行う。
1337         *
1338         * @param       columnName      表示不可カラム (CSV形式) (例:"OYA,KO,HJO,SU,DYSET,DYUPD")
1339         * @see         #setColumnDisplay( String )
1340         */
1341        public void setNoDisplay( final String columnName ) {
1342                noDisplay = nval( getRequestParameter(columnName),null );
1343                if( "null".equalsIgnoreCase( noDisplay ) ) { noDisplay = ""; }
1344        }
1345
1346        /**
1347         * 【TAG】表示可能カラム名を、カラム順に、CSV形式で与えます。
1348         *
1349         * @og.tag
1350         * これは、ViewForm_HTMLSeqClmTable 用に特別に用意された属性です。
1351         * 機能的には、columnDisplay 属性で、カラムの表示順まで指定できる機能を
1352         * 用意すべきですが、過去のタグとの互換性の関係で、別に用意しています。
1353         * (この属性を使用すると、通常の表示より、処理速度が低下します。)
1354         *  例:"OYA,KO,HJO,SU,DYSET,DYUPD" この順番で表示され、指定以外のカラムは表示されません。
1355         *
1356         * @og.rev 5.1.6.0 (2010/05/01) clmSeqDisplay 属性を追加します。
1357         *
1358         * @param       columnName      カラム名
1359         */
1360        public void setClmSeqDisplay( final String columnName ) {
1361                clmSeqDisplay = nval( getRequestParameter(columnName),null );
1362        }
1363
1364        /**
1365         * 【TAG】同一表示データをまとめる(表示しない)カラム名を、CSV形式で与えます。
1366         *
1367         * @og.tag
1368         * これは、カラムのグループ化指定を行います。
1369         * 同じカラム番号で一つ上の行番号と同じ内容の場合に、特殊な表示方法で表示します。
1370         * 対応は、表示(Renderer)時のみとします。
1371         * 特殊な表示方法の指定は、groupClass 属性で指定します。
1372         * (例:groupClass にアルファベット以外の文字・・そのまま表示、アルファベットはクラス属性を付与します。)
1373         * カラム単位なので、新しいゼブラによる色分けは行いません。(任意のカラムに適用できる為)
1374         * また、ファイル出力などのデータ自身は変更されていませんので、そのままデータが落ちます。
1375         *
1376         * これは、同一表示データをまとめないカラム名の指定(noGroup)と同時にセットする
1377         * ことは出来ません。
1378         * "*" を指定すると、すべてのカラムを(columnGroup)指定したことになります。
1379         *
1380         * @og.rev 3.8.5.0 (2006/03/20) 新規追加
1381         * @og.rev 5.1.8.0 (2010/07/01) noWritable 同時セットチェックを、メソッドではなく、本体で行う。
1382         *
1383         * @param       group   グループカラム (CSV形式) (例:"OYA,KO,HJO,SU,DYSET,DYUPD")
1384         * @see         #setNoGroup( String )
1385         * @see         #setGroupClass( String )
1386         */
1387        public void setColumnGroup( final String group ) {
1388                columnGroup = nval( getRequestParameter( group ),null );
1389                if( "null".equalsIgnoreCase( columnGroup ) ) { columnGroup = ""; }
1390        }
1391
1392        /**
1393         * 【TAG】同一表示データをまとめないカラム名を、CSV形式で与えます。
1394         *
1395         * @og.tag
1396         * これは、カラムのグループ化指定で、同一でもまとめないカラムを指定するほうが簡単な場合に
1397         * 使用します。例えば、キー情報以外は、グループ化指定したい場合などに便利です。
1398         * 動作は、columnGroup の動きと同じです。(まとめないカラムを指定するだけです。)
1399
1400         * これは、同一表示データをまとめるカラム名の指定(columnGroup)と同時にセットする
1401         * ことは出来ません。
1402         * "*" を指定すると、すべてのカラムを(noGroup)指定したことになります。
1403         *
1404         * @og.rev 5.1.8.0 (2010/07/01) 新規追加
1405         *
1406         * @param       group   グループ除外カラム (CSV形式) (例:"OYA,KO,HJO,SU,DYSET,DYUPD")
1407         * @see         #setColumnGroup( String )
1408         * @see         #setGroupClass( String )
1409         */
1410        public void setNoGroup( final String group ) {
1411                noGroup = nval( getRequestParameter( group ),null );
1412                if( "null".equalsIgnoreCase( noGroup ) ) { noGroup = ""; }
1413        }
1414
1415        /**
1416         * 【TAG】同一表示データをまとめる場合の、表示方法を指定します。
1417         *
1418         * @og.tag
1419         * これは、カラムのグループ化指定(columnGroup)を行う場合の、まとめ表示の方法を指定します。
1420         * なにも指定しない場合は、まとめカラムは、表示しない(ゼロ文字列)になります。
1421         * その場合、先の行と同じ場合も、変更されたカラムが、NULL(ゼロ文字列)であった場合も、
1422         * 同じ用に表示されるため、区別が付きません。
1423         * そこで、前の行と同じデータの場合に、特殊な処理を行うことで、区別できるようにします。
1424         * 指定方法が特殊なので、注意が必要です。
1425         *   記号の場合:
1426         *       記号(-- , → , ↓ , * など)が指定された場合は、そのままの文字に置き換えられます。
1427         *       初期値は、空文字列(ゼロ文字列)です。
1428         *   アルファベットの場合:
1429         *       アルファベット(a-z,A-Z)の場合は、&lt;span class="アルファベット"&gt;元の文字&lt;/span&gt;
1430         * 例えば、バックカラーに色を付ける、文字を薄い灰色にする、などできます。
1431         * ただし、データ量が圧倒的に増えるため、大量のデータ等で使用するのは避けたほうが良いと思います。
1432         *
1433         * @og.rev 3.8.5.0 (2006/03/20) 新規追加
1434         *
1435         * @param       grpCls まとめ表示の方法
1436         * @see         #setColumnGroup( String )
1437         */
1438        public void setGroupClass( final String grpCls ) {
1439                groupClass = nval( getRequestParameter(grpCls),null );
1440        }
1441
1442        /**
1443         * 【TAG】同一表示データをまとめる場合に、行(row)か列(column)を指定します(初期値:ROW)。
1444         *
1445         * @og.tag
1446         * これは、カラムのグループ化指定(columnGroup)を行う場合の、まとめ表示の方向を指定します。
1447         * ROW(初期値)を指定すると、指定のカラムで、行単位に同一データかどうかを判定します。
1448         * COLUMNを指定すると、columnGroup で指定した順番に、列方向に同一データかどうかを判定します。
1449         *
1450         * 指定には、ROW/COLUMN ですが、最初の一文字(R or C)で、かまいません。
1451         * また、初期値は、ROW なので、C が指定されているかどうかで、判定しています。
1452         * DBTableModelの登録順で、ひとつ前のカラムと比較します。
1453         *
1454         * @og.rev 6.7.3.0 (2017/01/27) 新規追加
1455         *
1456         * @param       dir まとめ表示の方向(ROW/COLUMN)
1457         * @see         #setColumnGroup( String )
1458         */
1459        public void setGroupDir( final String dir ) {
1460                final String grpDir = nval( getRequestParameter(dir),null );
1461                groupDir = grpDir != null && grpDir.length() > 0 && ( grpDir.charAt(0) == 'C' || grpDir.charAt(0) == 'c' );
1462        }
1463
1464        /**
1465         * 【TAG】カラム名リンクソートを表示するカラム名を、CSV形式で与えます。
1466         *
1467         * @og.tag
1468         * ヘッダーにソート用リンクを作成する useTableSorter 属性 に対して、
1469         * カラム個別に作成する場合のカラム名をCSV形式で指定します。
1470         * この sortKeys 属性は、useTableSorter 属性 と無関係に、指定した
1471         * カラムのみ、リンクを表示します。
1472         * "*" を指定すると、すべてのカラムを(tableSorterKeys)指定したことになります。
1473         * 例:"OYA,KO,HJO,SU,DYSET,DYUPD"
1474         *
1475         * @og.rev 3.6.0.0 (2004/09/17) 新規作成
1476         *
1477         * @param       columnName      カラム名
1478         */
1479        public void setTableSorterKeys( final String columnName ) {
1480                sortKeys = nval( getRequestParameter(columnName),null );
1481        }
1482
1483        /**
1484         * 【TAG】検索結果メッセージを表示しないかどうか[true/false]を設定します(初期値:false[表示する])。
1485         *
1486         * @og.tag
1487         * 初期値は、表示する(true以外)です。
1488         *
1489         * @param       flag 検索結果非表示 [true:表示しない/それ以外:表示する]
1490         */
1491        public void setNoMessage( final String flag ) {
1492                noMessage = nval( getRequestParameter( flag ),noMessage );
1493        }
1494
1495        /**
1496         * 【TAG】行が書き込み可能かどうか[true/false]を設定します
1497         *              (初期値:DBTableModel#DEFAULT_WRITABLE[={@og.value DBTableModel#DEFAULT_WRITABLE}])。
1498         *
1499         * @og.tag
1500         * 書込み許可する場合は, true、許可しない場合は, true 以外を設定します。
1501         * ここで、false を設定すると全行書込み禁止になります。true を設定した
1502         * 場合、デフォルトで書込み許可が与えられ、先頭カラムが writable であれば、
1503         * その値を取り込んで、行ごとの書込み許可/不許可が決定されます。
1504         * writable,checked,useCheckControl については、writable が最優先で
1505         * 次に、useCheckControl="2"(または、checked)、次に、checked を判定します。
1506         * checked="true"の場合は、useCheckControl が、"1"(true)以上の場合、
1507         * "2"(checked)に設定されます。
1508         * (初期値:DBTableModel#DEFAULT_WRITABLE[={@og.value DBTableModel#DEFAULT_WRITABLE}])。
1509         *
1510         * @param       flag 書き込み許可 [true:許可/false:不可]
1511         * @see         org.opengion.hayabusa.db.DBTableModel#DEFAULT_WRITABLE
1512         */
1513        public void setWritable( final String flag ) {
1514                writable = getRequestParameter( flag );
1515        }
1516
1517        /**
1518         * テーブルデータに書込み許可/チェック状態を設定します。
1519         *
1520         * @og.rev 3.6.0.0 (2004/09/17) writable が false の場合全件チェック用チェックボックスを出さない。
1521         * @og.rev 3.7.0.1 (2005/01/31) 全件チェックコントロールのロジック変更(useCheckControl)
1522         * @og.rev 3.8.8.5 (2007/03/09) 全件チェック(useCheckControl)と、個別チェック(checked)の整合性
1523         * @og.rev 5.5.5.6 (2012/08/31) ユーザーと画面の関係が、リードオンリーの場合は、writable=falseを内部設定する。
1524         * @og.rev 5.5.6.1 (2012/09/03) writable自動セットは指定コマンドのみ
1525         * @og.rev 6.4.3.4 (2016/03/11) String配列 から、Setに置き換えます。
1526         *
1527         * @param       table   DBTableModelオブジェクト
1528         */
1529        private void setTableRowWritable( final DBTableModel table ) {
1530
1531                // 5.5.5.6 (2012/08/31) リードオンリーの場合は、writable=falseを内部設定する。
1532                // このタグで、writable が指定された場合は、そちらを優先する。(つまり、null の場合は、内部設定する。)
1533                // 5.5.6.1 (2012/09/03) この処理を行うのは指定コマンドのみ
1534                if( ( writable == null || writable.isEmpty() ) && check( command, COMMAND_SET ) ) {
1535                        final GUIInfo guiInfo = (GUIInfo)getSessionAttribute( HybsSystem.GUIINFO_KEY );
1536                        if( ! guiInfo.isWrite() ){
1537                                writable = "FALSE" ;
1538                        }
1539                }
1540
1541                if( writable != null && writable.length() > 0 ) {
1542                        final boolean flag = "TRUE".equalsIgnoreCase( writable );
1543                        table.setDefaultRowWritable( flag );
1544                        if( ! flag ) { useCheckControl = 0; }                   // 3.7.0.1 (2005/01/31)
1545                }
1546
1547                // 全チェックONの場合は、個別チェックもONにする。
1548                if( useCheckControl == 2 ) { checked = "true"; }        // 3.8.8.5 (2007/03/09)
1549
1550                if( checked != null && checked.length() > 0 ) {
1551                        final boolean flag = "TRUE".equalsIgnoreCase( checked );
1552                        table.setDefaultRowChecked( flag );
1553                        // 個別チェックONの場合は、全チェックもONにする。
1554                        if( flag && useCheckControl >= 1 ) { useCheckControl = 2; }                     // 3.8.8.5 (2007/03/09)
1555                }
1556        }
1557
1558        /**
1559         * 【TAG】行のチェックボックスの初期値を設定するかどうか[true/false]を指定します(初期値:null)。
1560         *
1561         * @og.tag
1562         * 書き込み可能な行(rowWritable == true)のチェックボックスに対して
1563         * 初期値を 選択済みにするか、非選択済みにするかを指定します。
1564         * writable,checked,useCheckControl については、writable が最優先で
1565         * 次に、useCheckControl="2"(または、checked)、次に、checked を判定します。
1566         * checked="true"の場合は、useCheckControl が、"1"(true)以上の場合、
1567         * "2"(checked)に設定されます。
1568         *
1569         * @param       flag 選択済設定 [true:選択済み/それ以外:非選択状態]
1570         */
1571        public void setChecked( final String flag ) {
1572                checked = getRequestParameter( flag );
1573        }
1574
1575        /**
1576         * 【TAG】NEXT等で、選択行以外をスキップするのかどうか[true/false]を指定します
1577         *              (初期値:ViewForm#DEFAULT_SKIP[={@og.value ViewForm#DEFAULT_SKIP}])。
1578         *
1579         * @og.tag
1580         * 明細情報の登録/編集時に、必要な個所のみを順番に処理する場合に使用します。
1581         * (初期値:ViewForm#DEFAULT_SKIP[={@og.value ViewForm#DEFAULT_SKIP}])。
1582         *
1583         * @param       flag スキップ  [true:する/それ以外:しない]
1584         * @see         org.opengion.hayabusa.html.ViewForm#DEFAULT_SKIP
1585         */
1586        public void setSkip( final String flag ) {
1587                skip = nval( getRequestParameter( flag ),skip );
1588        }
1589
1590        /**
1591         * 【TAG】表示データを作成する場合のフォーマットの行数(rowspan)をセットします(初期値:2)。
1592         *
1593         * @og.tag 表示データを作成する場合のフォーマットの行数をセットします。
1594         *
1595         * @og.rev 3.3.1.1 (2003/07/03) {&#064;XXXX} 変数が使用できるように修正。
1596         *
1597         * @param       rowspan フォーマットの行数
1598         */
1599        public void setRowspan( final String rowspan ) {
1600                this.rowspan = getRequestParameter(rowspan);
1601        }
1602
1603        /**
1604         * 【TAG】表示時の選択用オブジェクトのタイプ[checkbox/radio/hidden/none]を指定します(初期値:checkbox)。
1605         *
1606         * @og.tag
1607         * 複数選択可能時は "checkbox" を指定します。
1608         * 一つだけ選ばせる場合は, "radio" を指定します。
1609         * 隠しフィールドで全件を選ぶ場合は、"hidden" を指定します。
1610         * noneを指定した場合は、行番号に関する情報は出力されません。受け側で、
1611         * selectedAll="true" など指定して処理してください。
1612         * 初期値は、"checkbox" です。
1613         *
1614         * @og.rev 3.3.1.1 (2003/07/03) {&#064;XXXX} 変数が使用できるように修正。
1615         *
1616         * @param       type 選択用タイプ [checkbox:複数選択/radio:一つだけ/hidden:全件選択/none:無出力]
1617         */
1618        public void setSelectedType( final String type ) {
1619                selectedType = nval( getRequestParameter(type),selectedType );
1620        }
1621
1622        /**
1623         * 【TAG】表示時の行番号の表示方法[sequence/none/delete/skip=カラム名/view=カラム名]を指定します(初期値:sequence)。
1624         *
1625         * @og.tag
1626         * ・sequenceは、1から始まる連番です。
1627         * ・none を指定すると、番号は表示されません。
1628         * ・delete を指定すると、行番号表示そのもののタグを取り除きます。(3.5.5.0 追加)
1629         * ・skip=カラム名を指定すると、そのカラムの値が NULL の場合は、番号をスキップします。
1630         * ・view=カラム名を指定すると、そのカラムの値が、使用されます。(ラベルは付きません)
1631         * skip=XX と、view=XX は、=の前後にスペースを入れないで下さい。
1632         * 初期値は、"sequence" です。
1633         *
1634         * @og.rev 3.5.1.0 (2003/10/03) 新規作成
1635         *
1636         * @param       type 行番号表示タイプ [sequence:連番/none:非表示/delete:タグ削除/skip=カラム名/view=カラム名]
1637         */
1638        public void setNumberType( final String type ) {
1639                numberType = nval( getRequestParameter(type),numberType );
1640        }
1641
1642        /**
1643         * 【TAG】テーブル等のチェックボックスに属性を付加します。
1644         *
1645         * @og.tag
1646         * JavaScript などの HTML基本タグ以外の属性を、そのまま
1647         * チェックボックス/ラジオボタン等に使用します。
1648         * そのときに、(')は、(")に置き換えます。
1649         *
1650         * @param       attributes チェックボックス追加属性
1651         */
1652        public void setOptionTypeAttributes( final String attributes ) {
1653                final String optAttri = getRequestParameter( attributes );
1654                if( optAttri != null && optAttri.length() > 0 ) {
1655                        optTypeAttri = optAttri.replace( '\'', '\"' );
1656                }
1657        }
1658
1659        /**
1660         * 【TAG】チェックボックスの全チェックを選択するJavaScript の機能を使用するかどうかを指定します
1661         *              (初期値:VIEW_USE_CHECK_CONTROL[={@og.value SystemData#VIEW_USE_CHECK_CONTROL}])。
1662         *
1663         * @og.tag
1664         * "true" で、コントロール用のチェックボックスが現れて、この機能を使用することができるようになります。
1665         * false は、従来どおりです。
1666         * 使用するにあたり、jsp/commpn/default.js にJavaScriptを設定しておきます。(設定済み)
1667         * false は、0でも代用可能です。true は、1でも代用可能です。
1668         * checked は、2でも代用可能です。checked は、初期値を、チェック済みにします。
1669         * 注意:0,1,2,true,false,checked 以外の文字をセットすると、エラーが発生します。
1670         * writable,checked,useCheckControl については、writable が最優先で
1671         * 次に、useCheckControl="2"(または、checked)、次に、checked を判定します。
1672         * checked="true"の場合は、useCheckControl が、"1"(true)以上の場合、
1673         * "2"(checked)に設定されます。
1674         * (初期値:ユーザー定数のVIEW_USE_CHECK_CONTROL[={@og.value SystemData#VIEW_USE_CHECK_CONTROL}])。
1675         *
1676         * @og.rev 3.5.4.3 (2004/01/05) 新規追加
1677         * @og.rev 3.7.0.1 (2005/01/31) 全件チェックコントロールのロジック変更(useCheckControl)
1678         *
1679         * @param       flag 全チェック選択可否 [true,1:使用する/false,0:使用しない/checked,2:初期値チェック済み]
1680         * @see         org.opengion.hayabusa.common.SystemData#VIEW_USE_CHECK_CONTROL
1681         */
1682        public void setUseCheckControl( final String flag ) {
1683                useCheckControl = intCase( getRequestParameter(flag) );
1684
1685                if( useCheckControl < 0 ) {
1686                        final String errMsg = "useCheckControl は、false(0)/true(1)/2 のいずれかしか登録できません。["
1687                                                 + flag + "]";
1688                        throw new HybsSystemException( errMsg );
1689                }
1690        }
1691
1692        /**
1693         * 【TAG】ヘッダーにソート用リンクを作成するかどうか[true/false]を指定します
1694         *              (初期値:VIEW_USE_TABLE_SORTER[={@og.value SystemData#VIEW_USE_TABLE_SORTER}])。
1695         *
1696         * @og.tag
1697         * "true" で、ヘッダーにソート用リンクを作成します。
1698         * false は、従来どおりです。
1699         * 検索済みのDBTableModelを、メモリ上でソートし、再表示させます。
1700         *              (初期値:ユーザー定数のVIEW_USE_TABLE_SORTER[={@og.value SystemData#VIEW_USE_TABLE_SORTER}])。
1701         *
1702         * @og.rev 3.5.4.7 (2004/02/06) 新規追加
1703         *
1704         * @param       flag ヘッダーソートリンク [true:作成する/false:作成しない]
1705         * @see         org.opengion.hayabusa.common.SystemData#VIEW_USE_TABLE_SORTER
1706         */
1707        public void setUseTableSorter( final String flag ) {
1708                useTableSorter = nval( getRequestParameter(flag),useTableSorter );
1709        }
1710
1711        /**
1712         * 表示データをプレビュー可能かどうかを返します。
1713         *
1714         * 不可能な状態とは,すでに一番先頭から表示されている場合です。
1715         *
1716         * @return      プレビュー可能(true)/不可能(false)
1717         */
1718        private boolean isPrev() {
1719                return startNo > 0;                             // 6.2.6.0 (2015/06/19) refactoring
1720        }
1721
1722        /**
1723         * 表示データをネクスト可能かどうかを返します。
1724         *
1725         * 不可能な状態とは,すでに一番後ろが表示されている場合です。
1726         *
1727         * @return      ネクスト可能(true)/不可能(false)
1728         */
1729        private boolean  isNext() {
1730                return (startNo + pageSize) < table.getRowCount();                              // 6.2.6.0 (2015/06/19) refactoring
1731        }
1732
1733        /**
1734         * コマンドを実行します。
1735         *
1736         * コマンドは,HTMLから(get/post)指定されますので,setCommand()メソッドで
1737         * 登録します。
1738         * コマンドを登録すると同時に,実行も行ないます。
1739         *
1740         * @og.rev 3.8.0.8 (2005/10/03) その他のコマンドを CMD_XXX にします。
1741         *
1742         * @param       command コマンド (public static final 宣言されている文字列)
1743         * @see         <a href="../../../../constant-values.html#org.opengion.hayabusa.taglib.ViewFormTag.CMD_PREV">コマンド定数</a>
1744         */
1745        private void commandExec( final String command ) {
1746                if(      CMD_PREV.equals(       command ) ) { prev() ;  }
1747                else if( CMD_NEXT.equals(       command ) ) { next() ;  }
1748                else if( CMD_FIRST.equals(      command ) ) { first() ; }
1749                else if( CMD_LAST.equals(       command ) ) { last() ;  }
1750        //      else if( CMD_NEW.equals(        command ) ) {}          // 何もしない
1751        //      else if( CMD_REVIEW.equals( command ) ) {}              // 何もしない
1752        //      else if( CMD_RESET.equals(      command ) ) {}          // 何もしない
1753                else if( CMD_VIEW.equals(       command ) ) { view() ;  }
1754                // 3.8.0.8 (2005/10/03) その他のコマンドを CMD_XXX にします。
1755                else if( CMD_XXX.equals(        command ) ) { view() ;  }
1756                this.command = null;
1757        }
1758
1759        /**
1760         * HTMLデータの表示をプレビュー(戻し)します。
1761         *
1762         * @og.rev 3.0.1.3 (2003/03/11) startNo を隠しフィールドに持つ処理を、追加
1763         *
1764         */
1765        private void prev() {
1766                if( ! isPrev() ) { return ; }                   // prev 出来ない。
1767                tempStartNo = tempStartNo - pageSize;
1768                if( tempStartNo < 0 ) { tempStartNo = 0; }
1769                if( skip ) {
1770                        for( int i=startNo-1; i>=0; i-- ) {
1771                                if( form.isMarked( i ) ) {
1772                                        startNo = i;
1773                                        break;
1774                                }
1775                        }
1776                        return ;
1777                }
1778
1779                startNo = startNo - pageSize;
1780                if( startNo < 0 ) {
1781                        startNo = 0;
1782                }
1783        }
1784
1785        /**
1786         * HTMLデータの表示をネクスト(先送り)します。
1787         *
1788         * @og.rev 3.0.1.3 (2003/03/11) startNo を隠しフィールドに持つ処理を、追加
1789         *
1790         */
1791        private void next() {
1792                if( ! isNext() ) { return ; }                   // next 出来ない。
1793                tempStartNo = tempStartNo + pageSize;
1794                if( skip ) {
1795                        final int end  = table.getRowCount();
1796                        for( int i=startNo+1; i<end; i++ ) {
1797                                if( form.isMarked( i ) ) {
1798                                        startNo = i;
1799                                        break;
1800                                }
1801                        }
1802                        return ;
1803                }
1804
1805                startNo = startNo + pageSize;
1806        }
1807
1808        /**
1809         * HTMLデータの表示をファースト(最初)します。
1810         *
1811         * @og.rev 3.0.1.3 (2003/03/11) startNo を隠しフィールドに持つ処理を、追加
1812         *
1813         */
1814        private void first() {
1815                tempStartNo = 0;
1816                if( tempStartNo < 0 ) { tempStartNo = 0; }
1817                if( skip ) {
1818                        final int end  = table.getRowCount();
1819                        for( int i=startNo; i<end; i++ ) {
1820                                if( form.isMarked( i ) ) {
1821                                        startNo = i;
1822                                        break;
1823                                }
1824                        }
1825                        return ;
1826                }
1827
1828                startNo = 0;
1829        }
1830
1831        /**
1832         * HTMLデータの表示をラスト(最後)します。
1833         *
1834         * @og.rev 3.0.1.3 (2003/03/11) startNo を隠しフィールドに持つ処理を、追加
1835         *
1836         */
1837        private void last() {
1838                tempStartNo = table.getRowCount() - pageSize;
1839                if( tempStartNo < 0 ) { tempStartNo = 0; }
1840                if( skip ) {
1841                        for( int i=startNo; i>=0; i-- ) {
1842                                if( form.isMarked( i ) ) {
1843                                        startNo = i;
1844                                        break;
1845                                }
1846                        }
1847                        return ;
1848                }
1849
1850                startNo = table.getRowCount() - pageSize;
1851                if( startNo < 0 ) { startNo = 0; }
1852        }
1853
1854        /**
1855         * HTMLデータの表示をします。
1856         *
1857         */
1858        private void view() {
1859                if( skip ) {
1860                        final int end  = table.getRowCount();
1861                        for( int i=startNo; i<end; i++ ) {
1862                                if( form.isMarked( i ) ) {
1863                                        startNo = i;
1864                                        break;
1865                                }
1866                        }
1867                        return ;
1868                }
1869        }
1870
1871        /**
1872         * startNo,pageSize,pagePlus の初期値を設定する。
1873         *
1874         * @og.rev 3.0.1.3 (2003/03/11) startNo を隠しフィールドに持つ処理を、追加
1875         * @og.rev 3.5.4.1 (2003/12/01) startNo をキャッシュから取り出すように変更。
1876         * @og.rev 3.5.4.7 (2004/02/06) getStartNoKeyメソッドの廃止(getRequestCacheDataを利用)
1877         * @og.rev 3.7.0.2 (2005/02/14) NEXT 時に何も選択しないで追加した場合は、1件目から表示する。
1878         * @og.rev 3.8.0.8 (2005/10/03) その他のコマンドを CMD_XXX にします。
1879         *
1880         */
1881        private void setDefaultParameter() {
1882                // 3.7.0.2 (2005/02/14)
1883                // 3.8.0.8 (2005/10/03) その他のコマンドを CMD_XXX にします。
1884                if( CMD_XXX.equals( command ) ) {
1885                        final String[] selected = getRequestValues( HybsSystem.ROW_SEL_KEY ) ;
1886                        if( selected == null || selected.length == 0 ) {
1887                                startNo = 0;
1888                                tempStartNo = startNo;
1889                        }
1890                }
1891
1892                if( startNo<0 ) {
1893                        startNo = nval( getRequestCacheData( START_NO_KEY ),form.getStartNo() ) ;
1894                        tempStartNo = startNo;
1895                }
1896
1897                if( pageSize<0 ) {
1898                        pageSize = nval( getRequestValue( PAGE_SIZE_KEY ),form.getPageSize() ) ;
1899                }
1900
1901                if( pagePlus<0 ) {
1902                        pagePlus = nval( getRequestValue( PAGE_PLUS_KEY ),0 ) ;
1903                }
1904
1905        }
1906
1907        /**
1908         * 内部タグの TheadTag / TbodyTag / TfootTag より、個々のフォーマットを定義する
1909         * 為のTableFormatter オブジェクトを受け取る。
1910         *
1911         * @og.rev 3.5.4.0 (2003/11/25) 新規登録(setAttributes メソッドより移行)
1912         *
1913         * @param       form TableFormatterオブジェクト
1914         */
1915        protected void addFormatter( final TableFormatter form ) {
1916                if( values == null ) { values = new ArrayList<>(); }
1917                values.add( form );
1918        }
1919
1920        /**
1921         * pageSize をhidden属性で出力するタグを作成します。
1922         *
1923         * @og.rev 3.5.4.0 (2003/11/25) command="RESET"時に、戻った画面のpageSize がクリアされてしまう対応。
1924         * @og.rev 3.5.5.5 (2004/04/23) hidden の出力に、XHTMLTag.hidden を使用します。
1925         *
1926         * @param       pageSize        ページサイズ
1927         *
1928         * @return      hidden属性で出力するタグ
1929         * @og.rtnNotNull
1930         */
1931        private String makePageSize( final int pageSize ) {
1932                final String name   = PAGE_SIZE_KEY;
1933                final String value  = String.valueOf( pageSize );
1934
1935                return XHTMLTag.hidden( name,value );   // 3.5.5.5 (2004/04/23)
1936        }
1937
1938        /**
1939         * consistencyKey をhidden属性で出力するタグを作成します。
1940         * 出力する条件は、useConsistency="true" (初期値)、で
1941         * scope が、 request 以外の場合です。
1942         * tableId が設定された場合は、consistencyKey に、tableId を加えた
1943         * キーにします。
1944         *
1945         * @og.rev 3.5.5.5 (2004/04/23) DBTableModel の整合性パラメータを hidden で出力します。
1946         * @og.rev 3.5.5.5 (2004/04/23) hidden の出力に、XHTMLTag.hidden を使用します。
1947         * @og.rev 3.5.5.8 (2004/05/20) makeConsistencyKey メソッドに処理ロジックを移します。
1948         *
1949         */
1950        private void makeConsistencyKey() {
1951                if( useConsistency && ! "request".equals( getScope() ) ) {
1952                        final String name   = HybsSystem.CONSISTENCY_KEY;
1953                        final String value  = table.getConsistencyKey() ;
1954
1955                        jspPrint( XHTMLTag.hidden( name,value ) );
1956                }
1957        }
1958
1959        /**
1960         * "false","true","checked" の文字列を、それぞれ、0,1,2 に対応した数字に変換します。
1961         * それ以外の文字列は、-1 にします。
1962         *
1963         * @og.rev 3.7.0.1 (2005/01/31) 新規作成
1964         *
1965         * @param    flag 変換対象 [true→1/false→0/checked→2]
1966         *
1967         * @return   設定値(0,1,2の数字、不正な場合は、-1 を返す。
1968         */
1969        private static int intCase( final String flag ) {
1970                int rtn = -1;
1971                if( "FALSE".equalsIgnoreCase( flag ) || "0".equalsIgnoreCase( flag ) ) {
1972                        rtn = 0;
1973                }
1974                else if( "TRUE".equalsIgnoreCase( flag ) || "1".equalsIgnoreCase( flag ) ) {
1975                        rtn = 1;
1976                }
1977                else if( "CHECKED".equalsIgnoreCase( flag ) || "2".equalsIgnoreCase( flag ) ) {
1978                        rtn = 2;
1979                }
1980                return rtn ;
1981        }
1982
1983        /**
1984         * ViewForm のサブクラスに渡すパラメータマップ。
1985         *
1986         * ※ 6.4.3.1 (2016/02/12) で、セットするMapを、ConcurrentHashMap に置き換えているため、
1987         *    key,value ともに、not null制限が入っています。
1988         *
1989         * @og.rev 3.5.4.8 (2004/02/23) ViewParamTag のパラメータを追加します。
1990         * @og.rev 6.4.3.3 (2016/03/04) ConcurrentHashMap を受け取ることを明確にするため、I/FをConcurrentMapに変更します。
1991         *
1992         * @param       map パラメータマップ
1993         */
1994        protected void setParam( final ConcurrentMap<String,String> map ) {
1995                viewParam = map ;
1996        }
1997
1998        /**
1999         * ViewForm のサブクラスに渡すパラメータ(文字列配列のArrayList)を設定します。
2000         *
2001         * @og.rev 5.5.8.3 (2012/11/17) 新規作成(スタックガント対応)
2002         * @og.rev 5.5.9.0 (2012/12/03) objectからArrayListに変更
2003         *
2004         * @param       list 文字列配列のArrayList
2005         */
2006        protected void setViewArrayList( final List<String[]> list ) {
2007                viewArrayList = list;
2008        }
2009
2010        /**
2011         * 【TAG】パラメーターファイルの使用をするかどうか[true/false]を指定します(初期値:false)。
2012         *
2013         * @og.tag
2014         * "true" で、パラメータファイルを読み込むため、BODY部を処理します。
2015         * false は、パラメータファイうを使用しません。
2016         * パラメータファイルは、各ViewFormのサブクラス用に用意します。
2017         * 初期値は、false です。(false)
2018         *
2019         * @og.rev 3.5.4.8 (2004/02/23) 新規追加
2020         *
2021         * @param       flag パラメーター使用可否 [true:使用する/false:使用しない]
2022         */
2023        public void setUseParam( final String flag ) {
2024                useParam = nval( getRequestParameter(flag),useParam );
2025        }
2026
2027        /**
2028         * 【TAG】Consistency キー による整合性チェックを行うかどうか[true/false]を指定します(初期値:true)。
2029         *
2030         * @og.tag
2031         * 検索結果を DBTableModel にセットする時に、整合性キーの Consistency キーを
2032         * 作成します。これを、Viewタグでhidden出力しておき、Entryタグでデータ書き換え時に
2033         * 整合性チェックを行います。これは、IEの戻るボタンで戻った場合に、画面の
2034         * キーと検索結果の DBTableModel の内容が一致しない場合のエラーチェックに
2035         * なります。
2036         * この属性は、何らかのケースで、このエラーチェックを行いたくない場合に、
2037         * false に設定することで、整合性チェックを行いません。
2038         * 初期値は、true(整合性チェックを行う)です。
2039         *
2040         * @og.rev 3.5.5.7 (2004/05/10) 新規登録
2041         *
2042         * @param       ck      整合性チェック [true:行う/false:行わない]
2043         */
2044        public void setUseConsistency( final String ck ) {
2045                useConsistency = nval( getRequestParameter( ck ),useConsistency );
2046        }
2047
2048        /**
2049         * 【TAG】テーブルのバックグラウンドカラーの入れ替えのサイクルをセットします(初期値は、1:ゼブラ)。
2050         *
2051         * @og.tag
2052         * 0(ゼブラなし)、-1(ワーニング)、-2以下(エラー)、1(ゼブラ)、2以上(行数まとめ)
2053         * 初期値は、1(ゼブラ)です。
2054         *
2055         * @og.rev 3.5.6.2 (2004/07/05) 新規追加
2056         *
2057         * @param  sycle  ゼブラ指定 [0:ゼブラなし/-1:警告色/-2:エラー色/1:ゼブラ/2以上:行数まとめ]
2058         */
2059        public void setBgColorCycle( final String sycle ) {
2060                bgColorCycle = nval( getRequestParameter( sycle ),bgColorCycle );
2061        }
2062
2063        /**
2064         * 【TAG】テーブルのバックグラウンドカラーのクラスに指定するカラム名を指定します。
2065         *
2066         * @og.tag
2067         * 通常のゼブラ模様は、tr 属性のクラス指定として、row_0、row_1 が指定されます。
2068         * その代わりに、ここで指定されたカラムの値がクラス属性として設定されます。
2069         * (指定するのはカラム名です。行単位にクラス属性の値を変えることが可能です。)
2070         * 選択行(row_sel)は、優先して使用されます。
2071         * 出力されるクラス名は、"row_" + 属性値 になります。
2072         *
2073         * @og.rev 5.1.8.0 (2010/07/01) 新規追加
2074         *
2075         * @param  clsClm ゼブラ模様指定カラム
2076         */
2077        public void setBgColorClsClm( final String clsClm ) {
2078                bgColorClsClm = nval( getRequestParameter( clsClm ),bgColorClsClm );
2079        }
2080
2081        /**
2082         * 【TAG】スクロールバー用のDIV要素を出力するかどうか[true/false]を指定します
2083         *              (初期値:VIEW_USE_SCROLLBAR[={@og.value SystemData#VIEW_USE_SCROLLBAR}])。
2084         *
2085         * @og.tag
2086         * スクロールバー対応する為、テーブルの先頭に、DIV要素を出力します。
2087         * (初期値:ユーザー定数のVIEW_USE_SCROLLBAR[={@og.value SystemData#VIEW_USE_SCROLLBAR}])。
2088         *
2089         * @og.rev 3.5.6.3 (2004/07/12) 新規追加
2090         *
2091         * @param  useBar  スクロールバー用使用可否 [true:する/false:しない]
2092         * @see         org.opengion.hayabusa.common.SystemData#VIEW_USE_SCROLLBAR
2093         */
2094        public void setUseScrollBar( final String useBar ) {
2095                useScrollBar = nval( getRequestParameter( useBar ),useScrollBar );
2096        }
2097
2098        /**
2099         * 【TAG】ヘッダー固定のスクロールバー使用時の最大行数を指定します
2100         *                      (初期値:VIEW_SCROLLBAR_MAX_ROW_SIZE[={@og.value SystemData#VIEW_SCROLLBAR_MAX_ROW_SIZE}])。
2101         *
2102         * @og.tag
2103         * ヘッダー固定のスクロールバーは、JavaScriptで処理しているため、
2104         * 大量のデータを読み取ると、非常に時間がかかったり、場合によっては
2105         * ブラウザがハングアップします。
2106         * そこで、ある表示件数以上の場合は、強制的にスクロールバーを
2107         * オフにします。
2108         * 指定以上のデータ件数を、表示する場合に、オフにします。
2109         * (初期値:VIEW_SCROLLBAR_MAX_ROW_SIZE[={@og.value SystemData#VIEW_SCROLLBAR_MAX_ROW_SIZE}])
2110         *
2111         * @og.rev 6.2.4.0 (2015/05/15) 新規作成
2112         *
2113         * @param  size  スクロールバー使用時の最大行数
2114         * @see         org.opengion.hayabusa.common.SystemData#VIEW_SCROLLBAR_MAX_ROW_SIZE
2115         */
2116        public void setMaxScrollBarSize( final String size ) {
2117                maxScrollBarSize = nval( getRequestParameter( size ),maxScrollBarSize );
2118        }
2119
2120        /**
2121         * 【TAG】viewLink や viewMarker の情報取り込みを制御する(初期値は、NEW,RENEW,REVIEW,RESET)。
2122         *
2123         * @og.tag
2124         * viewLink や viewMarker の情報取り込みは、command が、NEW,RENEW,REVIEW,RESET
2125         * の場合のみ行われています。
2126         * この属性で、"true" を指定すると、コマンドに無関係に取り込みます。
2127         * "false" の場合は、form にキャッシュしているリンク、マーカーを削除します。
2128         * 取り込み時に、viewLink や viewMarker オブジェクトが存在しない場合は、
2129         * 何もしません。これは、viewMarker オブジェクト自身がすでに設定済みの場合(VIEWなど)
2130         * NEXTやPREVでは、viewMarkerオブジェクトは、リクエスト変数に設定されない為です。
2131         * この場合は、登録しませんが、既存の viewMarkerオブジェクトを持っているはずなので、
2132         * なにも設定しなくても viewMarker は適用されます。
2133         * 初期値は、NEW,RENEW,REVIEW,RESET です。
2134         *
2135         * @og.rev 3.6.0.4 (2004/10/14) 新規追加
2136         *
2137         * @param  load  情報取り込みするキー
2138         */
2139        public void setLoadMarker( final String load ) {
2140                loadMarker = nval( getRequestParameter( load ),loadMarker );
2141        }
2142
2143        /**
2144         * 【TAG】SEL_ROW機能[true:有効/false:無効]を指定します
2145         *              (初期値:VIEW_USE_SELECTED_ROW[={@og.value SystemData#VIEW_USE_SELECTED_ROW}])。
2146         *
2147         * @og.tag
2148         * SEL_ROW機能は、戻るリンクから戻ったときや、登録したときに、選択していた
2149         * 行番号や、先にクリックされた行番号を返す機能で、SEL_ROW リクエストに設定された
2150         * 行がマーカーされます。この機能の有効(true)/無効(false)を指定します。
2151         * この属性で、"true" を指定すると、有効になります。
2152         * "false" の場合は、無効です。
2153         * (初期値:ユーザー定数のVIEW_USE_SELECTED_ROW[={@og.value SystemData#VIEW_USE_SELECTED_ROW}])。
2154         *
2155         * @og.rev 3.7.1.1 (2005/05/23) 新規追加
2156         *
2157         * @param  selRow  SEL_ROW機能有無 [true:有効/false:無効]
2158         * @see         org.opengion.hayabusa.common.SystemData#VIEW_USE_SELECTED_ROW
2159         */
2160        public void setUseSelectedRow( final String selRow ) {
2161                useSelectedRow = nval( getRequestParameter( selRow ),useSelectedRow );
2162        }
2163
2164        /**
2165         * 【TAG】SEL_ROW使用時の選択行色変更[true:有効/false:無効]を指定します
2166         *              (初期値:VIEW_USE_SELROW_COLOR[={@og.value SystemData#VIEW_USE_SELROW_COLOR}])。
2167         *
2168         * @og.tag
2169         * SEL_ROW機能は、現在選択されている行まで、スクロールする機能ですが、そのとき、
2170         * 選択行にマーカーするかどうかを、指定します。
2171         * この属性で、"true" を指定すると、有効になります。
2172         * "false" の場合は、無効です。
2173         * (初期値:ユーザー定数のVIEW_USE_SELROW_COLOR[={@og.value SystemData#VIEW_USE_SELROW_COLOR}])。
2174         *
2175         * @og.rev 3.7.1.1 (2005/05/31) 新規追加
2176         *
2177         * @param  selRowColor  SEL_ROW選択行色変更 [true:有効/false:無効]
2178         * @see         org.opengion.hayabusa.common.SystemData#VIEW_USE_SELROW_COLOR
2179         */
2180        public void setUseSelRowColor( final String selRowColor ) {
2181                useSelRowColor = nval( getRequestParameter( selRowColor ),useSelRowColor );
2182        }
2183
2184        /**
2185         * 【TAG】 処理時間やページサイズなどの情報出力[true:有効/false:無効]を指定します(初期値:true)。
2186         *
2187         * @og.tag
2188         * ViewForm で、CustomData などの 非HTML表示ビューを使用する場合、
2189         * 最後に、処理時間とページサイズ(NEXT時に使用)などの情報を、hidden で
2190         * 出力していますが、これを制御するフラグをセットします。
2191         * true(有効)にすると、これらのHTMLが出力されます。false にすると、出力されません。
2192         * 初期値は、true(有効) です。
2193         *
2194         * @og.rev 3.7.1.1 (2005/05/23) 新規追加
2195         *
2196         * @param  useTag  情報出力の有効/無効 [true:有効/false:無効]
2197         */
2198        public void setUseAfterHtmlTag( final String useTag ) {
2199                useAfterHtmlTag = nval( getRequestParameter( useTag ),useAfterHtmlTag );
2200        }
2201
2202        /**
2203         * 【TAG】設定値に "_" が含まれている場合にレンデラーを使用するカラムをCSV形式で指定します。
2204         *
2205         * @og.tag
2206         * これは、従来の カラム定義の WRITABLE エディターと同等の働きを行うように
2207         * カラム属性を指定します。
2208         * WRITABLE エディターは、設定値にアンダーバー "_" が含まれている場合に、
2209         * その値を書込み禁止にする機能です。これは、エディター自身が値を判断して
2210         * 書き込み許可か禁止かを判断しています。
2211         * この動きを汎用的にするため、指定のカラムをCSV形式(CSV)で指定
2212         * することにより、レンデラーとエディターを設定値によって動的に切り替える
2213         * 機能を実現します。
2214         * その場合、表示/編集ともに、先頭のアンダーバーは削除されます。
2215         * また、全カラムについて、有効にする場合は、writableControl="*" を設定します。
2216         *
2217         * @og.rev 3.8.0.9 (2005/10/17) 新規追加
2218         *
2219         * @param  wrtCtrl 書込制御カラム (CSV形式)
2220         */
2221        public void setWritableControl( final String wrtCtrl ) {
2222                writableControl = nval( getRequestParameter( wrtCtrl ),writableControl );
2223        }
2224
2225        /**
2226         * 【TAG】HILIGHT_ROW機能[true:有効/false:無効]を指定します
2227         *              (初期値:VIEW_USE_HILIGHT_ROW[={@og.value SystemData#VIEW_USE_HILIGHT_ROW}])。
2228         *
2229         * @og.tag
2230         * HILIGHT_ROW機能は、チェックボックスやラジオボタンで行選択した際に、どの行が選択されたか
2231         * 判るように行のハイライト表示を行う機能です。
2232         * さらに、行の任意の箇所をクリックしても、チェックが入り、ハイライト表示されます。
2233         * この属性で、"true" を指定すると、有効になります。
2234         * "false" の場合は、無効です。
2235         * (初期値:ユーザー定数のVIEW_USE_HILIGHT_ROW[={@og.value SystemData#VIEW_USE_HILIGHT_ROW}])。
2236         *
2237         * @og.rev 3.8.6.0 (2006/09/29) HILIGHT_ROW機能の有効/無効を指定します。
2238         *
2239         * @param  hilightRow  HILIGHT_ROW有無 [true:有効/false:無効]
2240         * @see         org.opengion.hayabusa.common.SystemData#VIEW_USE_HILIGHT_ROW
2241         */
2242        public void setUseHilightRow( final String hilightRow ) {
2243                useHilightRow = nval( getRequestParameter( hilightRow ),useHilightRow );
2244        }
2245
2246        /**
2247         * 【TAG】ogPopup で検索結果の値を返すキーを、CSV形式で指定します。
2248         *
2249         * @og.tag
2250         * popup の検索結果を返す画面で、結果のラジオボタンにイベントセットします。
2251         * この場合、オープンもとのwindow に値を返しますが、そのキーをCSV形式で
2252         * 指定します。
2253         * なお、このメソッドは、一覧表示(HTMLTable)関係のビューのみでサポートして
2254         * いますが、チェックメソッドの関係で、それ以外のビューに適用しても素通り
2255         * するようにします。(エラーにしません)
2256         *
2257         * @og.rev 3.8.6.1 (2006/10/20) 新規追加
2258         *
2259         * @param  rtnKeys ポップアップ戻りキー (CSV形式)
2260         */
2261        public void setPopupReturnKeys( final String rtnKeys ) {
2262                popupReturnKeys = nval( getRequestParameter( rtnKeys ),popupReturnKeys );
2263        }
2264
2265        /**
2266         * 【TAG】table要素に対して class 属性を設定します(初期値:viewTable)。
2267         *
2268         * @og.tag
2269         * Javaの言語使用上、class で作成できないため、代用として
2270         * clazz を使用している。
2271         * html で作成される属性は、 class で作成される。
2272         * 初期値は、"viewTable" です。
2273         *
2274         * @og.rev 4.0.0.0 (2007/04/16) 新規追加
2275         *
2276         * @param       cls     class属性
2277         */
2278        public void setClazz( final String cls ) {
2279                clazz = nval( getRequestParameter( cls ),clazz );
2280        }
2281
2282        /**
2283         * 【TAG】ビューの高さを指定します。
2284         *
2285         * @og.tag
2286         * id=posDivのDIV要素に高さを指定します。
2287         * javascriptからこの高さを見てビューの高さを決定します。
2288         * 単位も指定して下さい。
2289         *
2290         * @og.rev 4.2.0.0 (2008/03/18) 新規追加
2291         *
2292         * @param       high    ビューの高さ
2293         */
2294        public void setHeight( final String high ) {
2295                height = nval( getRequestParameter( high ), height );
2296        }
2297
2298        /**
2299         * 【TAG】ビューの幅を指定します。
2300         *
2301         * @og.tag
2302         * id=posDivのDIV要素に幅を指定します。
2303         * javascriptからこの値を見てビューの幅を決定します。
2304         * 単位も指定して下さい。(%指定推奨)
2305         *
2306         * @og.rev 4.2.0.0 (2008/03/18) 新規追加
2307         *
2308         * @param       wide    指定するビューの幅
2309         */
2310        public void setWidth( final String wide ) {
2311                width = nval( getRequestParameter( wide ), width );
2312        }
2313
2314        /**
2315         * 【TAG】ファイルダウンロード時の抜出カラム名(CSV形式)を指定します。
2316         *
2317         * @og.tag
2318         * fileUDのファイル抜出時のカラムをカンマ形式で指定します。
2319         *
2320         * @og.rev 4.3.0.0 (2008/07/04) 新規追加
2321         *
2322         * @param       dwnClms 抜出カラム名 (CSV形式)
2323         */
2324        public void setFileDwnClms( final String dwnClms ) {
2325                fileDwnClms = nval( getRequestParameter( dwnClms ), fileDwnClms );
2326        }
2327
2328        /**
2329         * 【TAG】編集行のみを表示するかを指定します(初期値:false)。
2330         *
2331         * @og.tag
2332         * 編集行のみを表示するかを指定します。trueがセットされた場合、編集行(改廃Cがついている行)
2333         * のみが出力されます。
2334         *
2335         * @og.rev 4.3.1.0 (2008/09/08)
2336         *
2337         * @param       sne     編集行のみ出力 [true:編集行のみ/false:全行]
2338         */
2339        public void setSkipNoEdit( final String sne ) {
2340                skipNoEdit = nval( getRequestParameter( sne ), skipNoEdit );
2341        }
2342
2343        /**
2344         * 【TAG】(通常は使いません)画面遷移を行わない形式の登録方法を使用するかを指定します。
2345         *
2346         * @og.tag
2347         * 画面遷移なしの登録を行うかどうかを指定します。
2348         * trueが指定された場合、HTML出力時に、各行に対して、行番号と改廃Cが属性情報として付加されます。
2349         * ここで出力された情報を元に、JavaScriptの入れ替え処理を行います。
2350         *
2351         * この値は、og:headタグで設定値、または前画面からの値を継承するため、通常、この属性ではセットしません。
2352         *
2353         * @og.rev 4.3.3.0 (2008/10/01) 新規追加
2354         * @og.rev 5.1.3.0 (2010/02/01) noTransition、ajaxSubmitのコントロールは、requestで行う。
2355         *
2356         * @param   noTrnstn 画面遷移なし登録 [true:画面遷移なし登録/false:通常登録]
2357         */
2358        public void setNoTransition( final String noTrnstn ) {
2359                setNoTransitionRequest( nval( getRequestParameter( noTrnstn ), isNoTransitionRequest() ) );
2360        }
2361
2362        /**
2363         * 【TAG】選択行ハイライトの制御をチェックボックスのみで有効にするかを指定します
2364         *              (初期値:VIEW_USE_HILIGHT_CHECK_ONLY[={@og.value SystemData#VIEW_USE_HILIGHT_CHECK_ONLY}])。
2365         *
2366         * @og.tag
2367         * 選択行ハイライトの制御をチェックボックスのみで有効にするかを指定します。
2368         * trueの場合、チェックボックスのみで有効になります。
2369         * falseの場合、行全体の各要素で有効になります。
2370         * trueにした場合、チェックボックスが存在しない行に対しては、ハイライトすることはできません。
2371         * (初期値:ユーザー定数のVIEW_USE_HILIGHT_CHECK_ONLY[={@og.value SystemData#VIEW_USE_HILIGHT_CHECK_ONLY}])。
2372         *
2373         * @og.rev 4.3.7.0 (2009/06/01) 新規追加
2374         *
2375         * @param   hiCkOnly 選択行ハイライト制御 [true:チェックボックスのみ/false:行全体]
2376         * @see         org.opengion.hayabusa.common.SystemData#VIEW_USE_HILIGHT_CHECK_ONLY
2377         */
2378        public void setUseHilightCheckOnly( final String hiCkOnly ) {
2379                isHiRowCheckOnly = nval( getRequestParameter( hiCkOnly ), isHiRowCheckOnly );           // 6.0.2.5 (2014/10/31) refactoring
2380        }
2381
2382        /**
2383         * 【TAG】選択行のハイライト表示を行った場合に、行選択でRadioボタンにclickイベントを発行させるかどうかを指定します
2384         *              (初期値:VIEW_USE_HILIGHT_RADIO_CLICK[={@og.value SystemData#VIEW_USE_HILIGHT_RADIO_CLICK}])。
2385         *
2386         * @og.tag
2387         * trueの場合、clickイベントを発行させます。
2388         * falseの場合、従来通り、ハイライト表示でラジオのチェックは入りますが、イベントは発行されません。
2389         * 互換性を考えれば、false ですが、POPUP系で、行選択してしまうと、選択できなくなるため、
2390         * 行選択で、即POPUPが閉じる true にしておきます。
2391         * (初期値:ユーザー定数のVIEW_USE_HILIGHT_RADIO_CLICK[={@og.value SystemData#VIEW_USE_HILIGHT_RADIO_CLICK}])。
2392         *
2393         * @og.rev 6.2.2.0 (2015/03/27) hilightRow で、行選択時にイベント発行可否を指定できるようにする。
2394         *
2395         * @param   useClick 行選択でRadioボタンのclickイベント [true:発行する/false:発行しない]
2396         * @see         org.opengion.hayabusa.common.SystemData#VIEW_USE_HILIGHT_RADIO_CLICK
2397         */
2398        public void setUseHilightRadioClick( final String useClick ) {
2399                isHiRadioClick = nval( getRequestParameter( useClick ), isHiRadioClick );               // 6.0.2.5 (2014/10/31) refactoring
2400        }
2401
2402        /**
2403         * 【TAG】一括入力カラムのアシスト機能を利用するカラム名を、CSV形式で与えます。
2404         *
2405         * @og.tag
2406         * これは、カラムの書き込み時に、一括入力可能なカラムをヘッダーに表示し、
2407         * 一括登録できる機能を提供します。
2408         * この機能は、jsp/common/bulkSet.js JavaScript とともに提供されます。
2409         * IE については、クリップボードも利用できます。Ctrl-C と Ctrl-V でそれぞれ
2410         * 一連のカラムの値の取り出しと書き込みが可能になります。
2411         * (プルダウンの場合はオプションに上記が追加されます)
2412         * "*" を指定すると、すべてのカラムを(columnBulkSet)指定したことになります。
2413         * "-" を指定すると、すべてのカラムを(columnBulkSet)除外したことになります。
2414         *
2415         * システムリソースで、VIEW_USE_DEFAULT_BULKSET を true に設定すると、初期値が "*"
2416         * になりますので、個別の view に設定しなくてもこの機能が使用できるようになります。
2417         *
2418         * この機能は一括入力の手間削減が目的なので、selectedType が radio の場合は、
2419         * この機能は無効になります。
2420         *
2421         * @og.rev 5.2.1.0 (2010/10/01) 新規作成
2422         * @og.rev 5.4.4.0 (2012/02/01) コメント追加
2423         *
2424         * @param       columnName      一括入力カラム (CST形式) (例:"OYA,KO,HJO,SU,DYSET,DYUPD")
2425         */
2426        public void setColumnBulkSet( final String columnName ) {
2427                columnBulkSet = nval( getRequestParameter(columnName),columnBulkSet );
2428        }
2429
2430        /**
2431         * 【TAG】処理時間を表示する TimeView を表示するかどうか[true:する/false:しない]を指定します
2432         *              (初期値:VIEW_USE_TIMEBAR[={@og.value SystemData#VIEW_USE_TIMEBAR}])。
2433         *
2434         * @og.tag
2435         * true に設定すると、処理時間を表示するバーイメージが表示されます。
2436         * これは、DB検索、APサーバー処理、画面表示の各処理時間をバーイメージで
2437         * 表示させる機能です。処理時間の目安になります。
2438         * (初期値:VIEW_USE_TIMEBAR[={@og.value SystemData#VIEW_USE_TIMEBAR}])。
2439         *
2440         * @og.rev 6.3.6.0 (2015/08/16) useTimeView の初期値を、VIEW_USE_TIMEBAR にする。
2441         *
2442         * @param       flag    処理時間を表示 [true:する/false:しない]
2443         */
2444        public void setUseTimeView( final String flag ) {
2445                useTimeView = nval( getRequestParameter( flag ),useTimeView );
2446        }
2447
2448        /**
2449         * タグの名称を、返します。
2450         * 自分自身のクラス名より、自動的に取り出せないため、このメソッドをオーバーライドします。
2451         *
2452         * @og.rev 4.0.0.0 (2005/01/31) 新規追加
2453         *
2454         * @return  タグの名称
2455         * @og.rtnNotNull
2456         */
2457        @Override
2458        protected String getTagName() {
2459                return "view" ;
2460        }
2461
2462        /**
2463         * seqClmTableを使用するかどうかをチェックします
2464         *
2465         * ここではtableId,scope,項目名などで厳密にチェックを行い、これらが元の情報と合致しない場合は、
2466         * ViewFormTypeの置き換えを行わないようにします。
2467         *
2468         * @og.rev 5.1.6.0 (2010/05/01) 新規追加
2469         * @og.rev 5.3.6.0 (2011/06/01) Edit機能見直しによりメソッド名変更
2470         * @og.rev 5.7.7.3 (2014/06/27) カラムが存在しない場合の挙動変更
2471         * @og.rev 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
2472         * @og.rev 6.2.4.1 (2015/05/22) カラムが DBTableModel に存在しない場合、return から continue に変更
2473         *
2474         * @param       userViewClms    表示カラム
2475         */
2476        private void makeEditTable( final String userViewClms ) {
2477
2478                // 1Queryに対して複数Viewがある場合(左右分割など)、Viewの各項目定義が'|'で分割されてセットされています。
2479                final int vwCnt = nval( (String)getRequestAttribute( "h_vwCnt" ), 0 );
2480                final String[] clmGroup = StringUtil.csv2Array( userViewClms, '|' );
2481                if( clmGroup.length > vwCnt ) {
2482                        // 6.0.2.4 (2014/10/17) カラムの存在チェックと、取り除きを同時に行います。
2483                        // AAA,!BBB,CCC,DDD,!EEE から!がついたカラムのみを取り除く(!がある項目は非表示)
2484                        final String[] clms = StringUtil.csv2Array( clmGroup[vwCnt] );
2485                        final StringBuilder buf = new StringBuilder( BUFFER_MIDDLE );
2486                        for( int i=0; i<clms.length; i++ ) {
2487                                final String clm = clms[i];
2488                                // !がついたカラムは、スルーします。
2489                                if( StringUtil.startsChar( clm , '!' ) ) { continue; }  // 6.2.0.0 (2015/02/27) 1文字 String.startsWith
2490                                if( table.getColumnNo( clm, false ) < 0 ) {
2491                                        continue;       // 6.2.4.1 (2015/05/22) カラムが DBTableModel に存在しない
2492                                }
2493                                else {
2494                                        if( buf.length() > 0 ) { buf.append( ',' ); }   // 最初以外は、カンマを追加する。      // 6.0.2.5 (2014/10/31) char を append する。
2495                                        buf.append( clm );
2496                                }
2497                        }
2498                        // 行カウントカラムを表示する。
2499                        if( table.getColumnNo( "rowCount", false ) >= 0 ) {
2500                                buf.append( ",rowCount" );
2501                        }
2502                        clmSeqDisplay   = buf.toString();       // 6.0.2.4 (2014/10/17)
2503                        setRequestAttribute( "h_vwCnt", String.valueOf( vwCnt+1 ) );
2504                }
2505        }
2506
2507        /**
2508         * Viewで表示した項目をDBLastSqlにセットします。
2509         *
2510         * ここではtableId,scopeなどで厳密にチェックを行い、これらが元の情報と合致しない場合は、
2511         * DBLastSqlへのセットを行わないようにします。
2512         *
2513         * @og.rev 5.1.6.0 (2010/05/01) 新規追加
2514         * @og.rev 5.3.9.0 (2011/09/01) ヘッダーソートを行った場合、編集対象カラムが正しく表示されないバグを修正
2515         * @og.rev 6.0.2.4 (2014/10/17) Edit機能で、JSPソース変更時の対応
2516         *
2517         * @param       lastSql DBLastSqlオブジェクト
2518         */
2519        private void setViewClms( final DBLastSql lastSql ) {
2520                // 4.3.0.0 (2008/07/04) fileUD 対応。抜き出すカラムを指定します。
2521                final String guikey = getGUIInfoAttri( "KEY" );
2522                if( lastSql.isGuiMatch( guikey ) && lastSql.isTableMatch( tableId, getScope() ) && lastSql.isViewEditable() ) {
2523                        // 5.1.6.0 (2010/05/01) fileDwnClmsが指定されない場合は、Viewで表示されたカラムをセット
2524                        if( form.isEditable() ) {
2525                                // 5.3.9.0 (2011/09/01) リクエストに対して初めて処理する場合に対象カラムを一旦クリアする。
2526                                final boolean vwBln = nval( (String)getRequestAttribute( "h_vwBln" ), false );
2527                                if( !vwBln ) {
2528                                        lastSql.setViewClmNames( null );
2529                                        lastSql.setClmNames( null );
2530                                        setRequestAttribute( "h_vwBln", "true" );
2531                                }
2532
2533                                String clmNames = lastSql.getViewClmNames();
2534                                if( clmNames == null || clmNames.isEmpty() ) {
2535                                        clmNames = nval( fileDwnClms, form.getViewClms() );
2536                                }
2537                                else {
2538                                        // 1Queryに対して複数Viewがある場合(左右分割など)、Viewの各項目定義が'|'で分割されてセットします。
2539                                        clmNames += "|" + nval( fileDwnClms, form.getViewClms() );
2540                                }
2541                                lastSql.setViewClmNames( clmNames );
2542                                lastSql.setClmNames( clmNames.replace( "|", "," ) );
2543                        }
2544                        else {
2545                                lastSql.setViewNotEditable();
2546                        }
2547                        setSessionAttribute( HybsSystem.DB_LAST_SQL_KEY,lastSql );
2548                }
2549        }
2550
2551        /**
2552         * 【TAG】(通常は使いません)Viewに関する情報をセッションに情報を登録するかどうかを指定します(初期値:true)。
2553         *
2554         * @og.tag
2555         * 同一画面IDで、複数のViewを表示する場合に利用します。
2556         * View関連の情報をセッションに登録し利用していますが、複数のViewが存在する場合に前の情報が上書きされてしまいます。
2557         * 複数のViewを利用する際に、メイン以外のViewの値をfalseに指定する事でセッションへの保存をしません。
2558         * (QueryTagのmainTransも同時に設定するか検討してください)
2559         *
2560         * 現段階では、セッション保存抑制を行う値はstartNoのみです。
2561         *
2562         * @og.rev 5.7.6.1 (2010/05/09) 新規作成
2563         *
2564         * @param  flag メインView指定 [true:メイン/false:その他]
2565         */
2566        public void setMainView( final String flag ) {
2567                isMainView = nval( getRequestParameter( flag ),isMainView );
2568        }
2569
2570        /**
2571         * このオブジェクトの文字列表現を返します。
2572         * 基本的にデバッグ目的に使用します。
2573         *
2574         * @return このクラスの文字列表現
2575         * @og.rtnNotNull
2576         */
2577        @Override
2578        public String toString() {
2579                return ToString.title( this.getClass().getName() )
2580                                .println( "VERSION"                     ,VERSION                        )
2581                                .println( "tableId"                     ,tableId                        )
2582                                .println( "viewFormId"          ,viewFormId                     )
2583                                .println( "viewFormType"        ,viewFormType           )
2584                                .println( "viewLinkId"          ,viewLinkId                     )
2585                                .println( "viewMarkerId"        ,viewMarkerId           )
2586                                .println( "command"                     ,command                        )
2587                                .println( "startNo"                     ,startNo                        )
2588                                .println( "tempStartNo"         ,tempStartNo            )
2589                                .println( "pageSize"            ,pageSize                       )
2590                                .println( "pagePlus"            ,pagePlus                       )
2591                                .println( "columnWritable"      ,columnWritable         )
2592                                .println( "noWritable"          ,noWritable                     )
2593                                .println( "columnDisplay"       ,columnDisplay          )
2594                                .println( "clmSeqDisplay"       ,clmSeqDisplay          )
2595                                .println( "noDisplay"           ,noDisplay                      )
2596                                .println( "columnGroup"         ,columnGroup            )
2597                                .println( "noMessage"           ,noMessage                      )
2598                                .println( "writable"            ,writable                       )
2599                                .println( "checked"                     ,checked                        )
2600                                .println( "skip"                        ,skip                           )
2601                                .println( "rowspan"                     ,rowspan                        )
2602                                .println( "selectedType"        ,selectedType           )
2603                                .println( "numberType"          ,numberType                     )
2604                                .println( "optTypeAttri"        ,optTypeAttri           )
2605                                .println( "backLinkCount"       ,backLinkCount          )
2606                                .println( "headerSkipCount"     ,headerSkipCount        )
2607                                .println( "bodyString"          ,bodyString                     )
2608                                .println( "useCheckControl"     ,useCheckControl        )
2609                                .println( "useTableSorter"      ,useTableSorter         )
2610                                .println( "useParam"            ,useParam                       )
2611                                .println( "useConsistency"      ,useConsistency         )
2612                                .println( "bgColorCycle"        ,bgColorCycle           )
2613                                .println( "useScrollBar"        ,useScrollBar           )
2614                                .println( "sortKeys"            ,sortKeys                       )
2615                                .println( "loadMarker"          ,loadMarker                     )
2616                                .println( "useSelectedRow"      ,useSelectedRow         )
2617                                .println( "useSelRowColor"      ,useSelRowColor         )
2618                                .println( "useAfterHtmlTag"     ,useAfterHtmlTag        )
2619                                .println( "writableControl"     ,writableControl        )
2620                                .println( "hight"                       ,height                         )
2621                                .println( "width"                       ,width                          )
2622                                .println( "skipNoEdit"          ,skipNoEdit                     )
2623                                .println( "noTransition"        ,noTransition           )
2624                                .println( "useHilightCheckOnly",isHiRowCheckOnly)               // 6.0.2.5 (2014/10/31) refactoring
2625                                .println( "Other..."    ,getAttributes().getAttribute() )
2626                                .fixForm().toString() ;
2627        }
2628}