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.Map; 019import java.util.Set; // 6.4.3.4 (2016/03/11) 020 021import org.opengion.fukurou.util.StringUtil; 022import org.opengion.fukurou.util.ToString; // 6.1.1.0 (2015/01/17) 023import org.opengion.fukurou.util.ArraySet; // 6.4.3.4 (2016/03/11) 024import org.opengion.hayabusa.common.HybsSystem; 025import org.opengion.hayabusa.common.HybsSystemException; 026import org.opengion.hayabusa.db.DBColumn; 027import org.opengion.hayabusa.db.DBColumnConfig; 028import org.opengion.hayabusa.db.DBTableModel; 029import org.opengion.hayabusa.resource.CodeData; 030import org.opengion.hayabusa.resource.LabelData; 031import static org.opengion.fukurou.util.StringUtil.nval; 032 033/** 034 * 検索結果のカラムに対して様々な属性を付加するタグです。 035 * 036 * このタグでは、カラムリソースの属性を再設定できます。検索結果(DBTableModel) 037 * には、カラムオブジェクト(DBColumn)を持っています。このオブジェクトは、 038 * カラムリソースで設定した値を持っています。その個々の値を再設定することで、 039 * カラムオブジェクトの属性をその都度設定しなおすことができます。 040 * 最もよく使用するのは、must 属性の設定と、DBMENU エディターの設定です。 041 * must属性は、予め必須項目として指定することが出来ない為、画面毎に再設定が 042 * 必要です。ただし、ここでのmust属性は、カラムの表示色を変更するだけで、 043 * 実際のnullチェックは、columnCheck タグのnullCheck属性で指定します。 044 * DBMENU エディターは、データベースの属性から選択リストを作成する機能ですが、 045 * これも、マスタ登録時は、テキストフィールドで入力し、使用時は、選択するケース 046 * の様に、画面毎に異なる形式で使用したい場合があるためです。 047 * このタグでは、カラムオブジェクトの属性以外に、HTMLの属性を付加する事も 048 * できます。 049 * 050 * 6.7.6.0 (2017/03/17) [strictCheck属性]は、カラムIDの存在チェックを行うかどうかを指定します(初期値:true) 051 * true カラムIDがDBTableModel に存在しない場合は、エラーになる。 052 * false カラムIDがDBTableModel に存在しない場合は、無視する。 053 * 054 * @og.formSample 055 * ●形式:<og:ColumnEditor column="・・・" ・・・ > ・・・ </og:ColumnEditor > 056 * ●body:あり(EVAL_BODY_BUFFERED:BODYを評価し、{@XXXX} を解析します) 057 * 058 * ●Tag定義: 059 * <og:columnEditor 060 * column 【TAG】カラム名をセットします 061 * columns 【TAG】カラム名をCSV形式で複数セットします 062 * label 【TAG】ラベルリソースに定義されたラベルIDをセットします 063 * className 【TAG】カラムのクラス名(VARCHAR2,NUMBER など)をセットします。既存値:設定値対応 064 * size 【HTML】カラムの入力枠サイズをセットします(大きさだけで入力文字制限ではありません) 065 * viewSize 【TAG】カラムの表示サイズ(横幅)を文字数でセットします。 066 * maxlength 【HTML】カラムの入力文字制限数をセットします 067 * writable 【TAG】カラムが書き込み可能かどうか[true/false]をセットします(初期値:null) 068 * renderer 【TAG】カラムの表示用レンデラー({@og.doc03Link renderer Renderer_****})をセットします。既存値:設定値対応 069 * editor 【TAG】カラムの編集用エディター({@og.doc03Link editor Editor_****})をセットします。既存値:設定値対応 070 * dbType 【TAG】DBタイプ({@og.doc03Link dbType DBType_****})をセットします。既存値:設定値対応 071 * codeName 【TAG】コードセレクトのユニークキー(コード名称)をセットします 072 * codeList 【TAG】コードセレクトのサブセットとなるコードをCSV形式で指定します 073 * codeGroup 【TAG】コードセレクトのサブセットとなるグループを指定します 074 * codeKeyVal 【TAG】新しいコードセレクトを作成する為の「キー:ラベル キー:ラベル」の文字列を指定します 075 * defaultVal 【TAG】初期値をセットします 076 * param 【TAG】パラメータをセットします 077 * roles 【TAG】ロールをセットします 078 * must 【TAG】必須入力を表す色に変えるかどうか[true/false]を指定します(初期値:false) 079 * mustAny 【TAG】選択必須入力(どれかひとつ必須)を表す色[true/mustAny/その他]を指定します(初期値:無指定) 080 * optionAttributes 【TAG】JavaScript などの HTML基本タグ以外の属性を、そのままタグとして使用します 081 * addNoValue 【TAG】セレクトメニューの値なしのOptionの有無[true/false]を指定します(初期値:falseと同等) 082 * addKeyLabel 【TAG】セレクトメニューの場合、キー:ラベル形式で表示するかどうか[true/false/null]を指定します(初期値:null) 083 * writeKeyLabel 【TAG】セレクトメニューの場合、キーとラベルを分けて出力するかどうか[true/false]を指定します(初期値:false) 084 * useLabelMap 【TAG】SQL文を指定してラベル情報を動的に読み込むかどうか[true/false]指定します(初期値:false) 085 * useSLabel 【TAG】MENU,DBMENUでSLABELを利用するかどうか[auto/true/false]を指定します(初期値:null) 086 * noDisplayVal 【TAG】指定の値を非表示にします(レンデラーのみ有効)(初期値:null) 087 * scope 【TAG】キャッシュする場合のスコープ[request/page/session/application]を指定します(初期値:session) 088 * tableId 【TAG】(通常は使いません)sessionから所得する DBTableModelオブジェクトの ID(初期値:HybsSystem#TBL_MDL_KEY[={@og.value HybsSystem#TBL_MDL_KEY}]) 089 * dbid 【TAG】(通常は使いません)データベースへ接続する場合のID(初期値:null) 090 * caseKey 【TAG】このタグ自体を利用するかどうかの条件キーを指定します(初期値:null) 091 * caseVal 【TAG】このタグ自体を利用するかどうかの条件値を指定します(初期値:null) 092 * caseNN 【TAG】指定の値が、null/ゼロ文字列 でない場合(Not Null=NN)は、このタグは使用されます(初期値:判定しない) 093 * caseNull 【TAG】指定の値が、null/ゼロ文字列 の場合は、このタグは使用されます(初期値:判定しない) 094 * caseIf 【TAG】指定の値が、true/TRUE文字列の場合は、このタグは使用されます(初期値:判定しない) 095 * lang 【HTML】要素の内容と他の属性値の言語(lang,xml:lang)を指定します 096 * style 【HTML】この要素に対して適用させるスタイルシート(style)を設定します 097 * clazz 【HTML】要素に対して class 属性を設定します 098 * readonly 【HTML】その部品に対して変更が出来ないように(readonly)指定します(サーバーに送信される) 8.4.3.0 (2023/03/31) 099 * disabled 【HTML】その部品に対して、選択や変更が出来ないように(disabled)指定します(サーバーに送信されない) 8.4.3.0 (2023/03/31) 100 * onClick 【HTML】JavaScriptのイベント onClick を設定します(例:onClick="renew('query.jsp','QUERY');") 101 * onChange 【HTML】JavaScriptのイベント onChange を設定します(例:onChange="renew('query.jsp','QUERY');") 102 * onBlur 【HTML】JavaScriptのイベント onBlur を設定します(例:onBlur="this.value=value.toUpperCase();") 103 * onFocus 【HTML】JavaScriptのイベント onFocus を設定します 104 * ondblClick 【HTML】JavaScriptのイベント ondblClick を設定します 105 * onMouseDown 【HTML】JavaScriptのイベント onMouseDown を設定します 106 * onMouseUp 【HTML】JavaScriptのイベント onMouseUp を設定します 107 * onMouseMove 【HTML】JavaScriptのイベント onMouseMove を設定します 108 * onMouseOut 【HTML】JavaScriptのイベント onMouseOut を設定します 109 * onMouseOver 【HTML】JavaScriptのイベント onMouseOver を設定します 110 * onSelect 【HTML】JavaScriptのイベント onSelect を設定します 111 * onKeydown 【HTML】JavaScriptのイベント onKeydown を設定します 112 * onKeypress 【HTML】JavaScriptのイベント onKeypress を設定します 113 * onKeyup 【HTML】JavaScriptのイベント onKeyup を設定します 114 * autocomplete 【HTML5】入力候補を提示して入力内容を自動補完する[on/off](初期値はon) 115 * autofocus 【HTML5】指定した入力欄にカーソルが当たって自動的にフォーカスされます 116 * pattern 【HTML5】正規表現で入力値のパターンを指定します 117 * placeholder 【HTML5】入力欄に初期表示する内容を指定します 118 * required 【HTML5】入力必須を指定します 119 * list 【HTML5】ユーザーに入力候補として提案するデータリストの要素のid属性の値を指定します 120 * min 【HTML5】入力欄で入力できる最小値を指定します 121 * max 【HTML5】入力欄で入力できる最大値を指定します 122 * step 【HTML5】入力欄で刻むステップ値を指定する 123 * type 【HTML5】HTML5追加分[text/search/tel/url/email/datetime/date/month/week/time/datetime-local/number/range/color] 124 * eventColumn 【TAG】イベントカラム(親カラム)のセット 125 * eventValue 【TAG】イベントValueのSQL分 126 * eventURL 【TAG】eventColumn利用時に呼ばれるJSPのURL 127 * eventCallback 【TAG】eventColumn実行後のcallbak関数指定を指定します 128 * noResource 【TAG】ResourceManager を使用しないかどうか[true/false]を指定します(初期値:false) 129 * strictCheck 【TAG】(通常は使いません)カラムIDの存在チェックを行うかどうか[true/false]を指定します(初期値:true) 130 * stringOutput 【TAG】レンデラ利用のExcel出力時にセルタイプを文字列にするかどうか(初期値:true) 131 * useRealTimeCheck 【TAG】(通常は使いません)リアルタイムチェックを行うかどうか(初期値:true:行う) 5.9.32.2 (2018/05/18) 132 * useDateFeed 【TAG】日付送り戻し機能を有効にするかどうか[true:有効/false:無効]指定します (初期値:true) 8.1.2.3 (2022/05/20) 133 * debug 【TAG】デバッグ情報を出力するかどうか[true/false]を指定します(初期値:false) 134 * > ... Body ... 135 * </og:columnEditor> 136 * 137 * ●使用例: 138 * ・必須表示の場合 139 * <og:columnEditor column="NOSYN" must="true" /> 140 * 141 * ・DBからのセレクトメニューの場合 142 * <og:columnEditor column="CDBK" editor="DBMENU"> 143 * select CDBK,CDBK||':'||NMBK from DB02 order by 1 144 * </og:columnEditor> 145 * 146 * ・親子関係のプルダウンを作る場合 147 * ({@xxx.value}で同じ行のxxxカラムで選択した値を取得します) 148 * <og:columnEditor column="CDBK" editor="DBMENU" 149 * eventColumn="OYA"> 150 * select CDBK,CDBK||':'||NMBK from DB02 151 * where CLM = {@OYA.value} order by 1 152 * </og:columnEditor> 153 * 154 * 155 * @og.rev 3.5.1.0 (2003/10/03) 親クラスをCommonTagSupportからHTMLTagSupportに変更。 156 * @og.group 画面表示 157 * 158 * @version 4.0 159 * @author Kazuhiko Hasegawa 160 * @since JDK5.0, 161 */ 162public class ColumnEditorTag extends HTMLTagSupport { 163 /** このプログラムのVERSION文字列を設定します。 {@value} */ 164 private static final String VERSION = "8.1.2.3 (2022/05/20)" ; 165 private static final long serialVersionUID = 812320220520L ; 166 167 // 5.7.1.0 (2013/12/06) HTML5 で新たに追加された、type を追加 168 // 6.3.4.0 (2015/08/01) String から String配列 に置き換え 169 170 // 6.4.3.4 (2016/03/11) String配列 から、Setに置き換えます。 171 private static final Set<String> TYPE_SET = new ArraySet<>( "text","search","tel","url","email","datetime","date","month","week","time","datetime-local","number","range","color" ); 172 173 private static final String DEFAULT_ADD_NO_VALUE= "true"; // 3.7.0.5 (2005/04/11) 174 175 private transient LabelData labelData ; 176 177 /** 6.4.3.1 (2016/02/12) 取得元が ConcurrentHashMap で返す。 */ 178 private transient Map<String,LabelData> labelMap ; // 6.3.9.0 (2015/11/06) transient 追加 179 180 private String tableId = HybsSystem.TBL_MDL_KEY; 181 private String[] columns ; // 3.7.0.5 (2005/04/11) 182 private boolean allColumns ; // 3.8.8.5 (2007/03/09) 183 private String className ; 184 private String fieldSize ; // 6.2.0.0 (2015/02/27) 185 private String viewSize ; // 6.2.0.0 (2015/02/27) 186 private String maxlength ; // 3.5.5.5 (2004/04/23) 187 private String writable ; 188 private String renderer ; 189 private String editor ; 190 private String dbType ; 191 private String codeName ; // 3.5.5.7 (2004/05/10) 192 /** Codeリソースのサブセット */ 193 private String codeList ; // 5.1.9.0 (2010/08/01) 194 /** Codeリソースのサブセットとなるグループ */ 195 private String codeGroup ; // 5.1.9.0 (2010/08/01) 196 /** 新しいコードセレクトを作成する為の KEY:VAL 文字列 */ 197 private String codeKeyVal ; // 6.3.1.1 (2015/07/10) 198 private String defaultVal ; 199 private String parameter ; 200 private String dbid ; 201 private String addNoValue ; // 3.5.5.9 (2004/06/07) 202 /** キー:ラベル形式で表示するかどうか */ 203 private String addKeyLabel ; // 6.0.4.0 (2014/11/28) 204 private boolean writeKeyLabel ; // 6.2.3.0 (2015/05/01) 205 206 /** 親カラムの指定 */ 207 private String eventColumn ; // 4.3.6.0 (2009/04/01) 208 /** イベントカラムの初期値 */ 209 private String eventValue ; // 6.3.4.0 (2015/08/01) 210 /** 生パラメータ */ 211 private String rawParameter ; // 4.3.6.0 (2009/04/01) 212 /** eventColumnで飛ばすURL */ 213 private String eventURL ; // 4.3.6.0 (2009/04/01) 214 215 /** ラベルデータの動的取得に対応 */ 216 private boolean useLabelMap ; // 4.3.4.0 (2008/12/01) 217 /** MENU,DBMENUでSLABELを利用するかどうか */ 218 private String useSLabel ; // 5.6.2.3 (2013/03/22) 219 /** 非表示文字の設定 */ 220 private String noDisplayVal ; // 5.6.2.3 (2013/03/22) 221 222 // 5.7.3.0 (2014/02/07) ResourceManager を使用しないかどうか[true/false]を指定 223 private boolean noResource ; 224 /** カラムIDの存在チェックを行うかどうか */ 225 private boolean strictCheck = true; // 6.7.6.0 (2017/03/17) 226 227 private boolean stringOutput = HybsSystem.sysBool( "USE_STRING_EXCEL_OUTPUT" ); // 5.7.6.3 (2014/05/23) 228 /** 日付送り戻し機能の有効/無効 */ 229 private boolean useDateFeed = true; // 8.1.2.3 (2022/05/20) 230 231 /** 232 * デフォルトコンストラクター 233 * 234 * @og.rev 6.4.2.0 (2016/01/29) PMD refactoring. Each class should declare at least one constructor. 235 */ 236 public ColumnEditorTag() { super(); } // これも、自動的に呼ばれるが、空のメソッドを作成すると警告されるので、明示的にしておきます。 237 238 /** 239 * Taglibの開始タグが見つかったときに処理する doStartTag() を オーバーライドします。 240 * 241 * @og.rev 3.1.0.0 (2003/03/20) DBColumnConfig#getColumnConfig() メソッド廃止 242 * @og.rev 3.1.1.0 (2003/03/28) ボディの内容を取得する処理を、CommonTagSupport で行う。 243 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。ボディが存在する場合のみボディが呼ばれる対応。 244 * @og.rev 3.5.1.0 (2003/10/03) 親クラスをCommonTagSupportからHTMLTagSupportに変更。 245 * @og.rev 3.5.5.5 (2004/04/23) 入力欄の大きさを指定する viewSize 属性を追加。 246 * @og.rev 3.5.5.7 (2004/05/10) CodeSelection を、codeName を元に構築できるように設定します。 247 * @og.rev 3.5.5.9 (2004/06/07) addNoValue が、設定された場合のみ、config に設定します 248 * @og.rev 3.7.0.5 (2005/04/11) 複数カラムを同時設定できる columns 属性を追加 249 * @og.rev 5.2.2.0 (2010/11/01) caseKey 、caseVal 属性対応 250 * 251 * @return 後続処理の指示( EVAL_BODY_BUFFERED ) 252 */ 253 @Override 254 public int doStartTag() { 255 // 5.2.2.0 (2010/11/01) caseKey 、caseVal 属性対応 256 if( useTag() ) { 257 if( "DBMENU".equalsIgnoreCase(editor) ) { 258 className = "VARCHAR2"; 259 renderer = "DBMENU"; 260 editor = "DBMENU"; 261 262 if( addNoValue == null ) { 263 addNoValue = DEFAULT_ADD_NO_VALUE ; 264 } 265 } 266 267 return EVAL_BODY_BUFFERED ; 268 } 269 return SKIP_BODY ; // Body を評価しない 270 } 271 272 /** 273 * Taglibのタグ本体を処理する doAfterBody() を オーバーライドします。 274 * 275 * @og.rev 2.3.1.3 (2003/02/08) ラベル、サイズのみでも変更できるように修正 276 * @og.rev 3.0.0.1 (2003/02/14) DBMENU作成時に、ラベルの最後のスペースを除去する。 277 * @og.rev 3.1.0.0 (2003/03/20) DBColumnConfig#getColumnConfig() メソッド廃止 278 * @og.rev 3.1.1.0 (2003/03/28) ボディの内容を取得する処理を、CommonTagSupport で行う。 279 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。ボディが存在する場合のみボディが呼ばれる対応。 280 * @og.rev 3.5.0.0 (2003/09/17) キー、ラベルともに、""(ダブルコーテーション)で囲うように変更。 281 * @og.rev 3.5.5.7 (2004/05/10) このタグでSQLを発行するのではなく、DBMENU の DBColumnを作成する。 282 * @og.rev 3.5.5.9 (2004/06/07) addNoValue が null の場合は、初期値を設定します。 283 * @og.rev 3.7.0.5 (2005/04/11) 複数カラムを同時設定できる columns 属性を追加 284 * @og.rev 3.8.6.3 (2006/11/30) SQL 文の前後のスペースを取り除きます。 285 * @og.rev 4.3.4.0 (2008/12/01) ラベルデータの動的取得に対応します。 286 * @og.rev 4.3.6.0 (2009/04/01) イベントカラム対応 287 * @og.rev 5.1.7.0 (2010/06/01) 動的プルダウン実装見直し 288 * @og.rev 5.5.4.0 (2012/07/02) 予約語対応 289 * @og.rev 6.3.1.1 (2015/07/10) BodyString,BodyRawStringは、CommonTagSupport で、trim() します。 290 * @og.rev 6.4.0.5 (2016/01/09) useLabelMap="true" 時のSQL文の実行は、dbid を使用して行う。 291 * 292 * @return 後続処理の指示(SKIP_BODY) 293 */ 294 @Override 295 public int doAfterBody() { 296 final String sql = getBodyString(); 297 if( sql != null && sql.length() > 0 ) { 298 if( useLabelMap ) { 299 // 6.4.0.5 (2016/01/09) useLabelMap="true" 時のSQL文の実行は、dbid を使用して行う。 300 labelMap = getResource().getLabelMap( sql.trim() , dbid ); // 4.3.4.0 (2008/12/01) 301 } 302 else { 303 if( eventColumn != null && eventColumn.length() >0 ){ // 4.3.6.0 (2009/04/01) 304 rawParameter = getReservedParameter( getBodyRawString() ); // 6.3.1.1 (2015/07/10) 305 } 306 parameter = sql.trim() ; 307 } 308 } 309 310 return SKIP_BODY ; 311 } 312 313 /** 314 * Taglibの終了タグが見つかったときに処理する doEndTag() を オーバーライドします。 315 * 316 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。release2() を doEndTag()で呼ぶ。 317 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。ボディが存在する場合のみボディが呼ばれる対応。 318 * @og.rev 3.7.0.5 (2005/04/11) 複数カラムを同時設定できる columns 属性を追加 319 * @og.rev 3.8.8.5 (2007/03/09) 全カラム が指定されたことにする allColumns 属性を追加 320 * @og.rev 4.1.2.1 (2008/03/13) must , mustAny 属性を自動化します。 321 * @og.rev 4.3.4.0 (2008/12/01) カラム指定のワイルドカード対応 322 * @og.rev 5.2.1.0 (2010/10/01) must , mustAny 属性の処理を、HTMLTagSupport に移します。 323 * @og.rev 5.2.2.0 (2010/11/01) caseKey 、caseVal 属性対応 324 * @og.rev 6.7.6.0 (2017/03/17) strictCheck 追加。 325 * @og.rev 6.8.1.4 (2017/08/25) must="false"で、config.setEditorAttributes で、属性を追加するようになった為の取り消しの対応。 326 * 327 * @return 後続処理の指示 328 */ 329 @Override 330 public int doEndTag() { 331 debugPrint(); // 4.0.0 (2005/02/28) 332 // 5.2.2.0 (2010/11/01) caseKey 、caseVal 属性対応 333 if( !useTag() ) { return EVAL_PAGE; } 334 335 final DBTableModel table = (DBTableModel)getObject( tableId ); 336 if( table == null ) { return EVAL_PAGE; } 337 338 if( columns != null ) { 339 // 3.8.8.5 (2007/03/09) 全カラム が指定 340 final String mustType = getMustType(); // 5.2.1.0 (2010/10/01) 341 if( allColumns ) { 342 final int len = table.getColumnCount(); 343 for( int i=0; i<len; i++ ) { 344 345 // 4.3.4.0 (2008/12/01) 346 final DBColumn dbColumn = table.getDBColumn( i ); 347 for( int j=0; j<columns.length; j++ ) { 348 final String prefix = columns[j].replace( "*", "" ); 349 if( dbColumn.getName().indexOf( prefix ) == 0 ) { // 前方一致のみ対応 350 // 6.8.1.4 (2017/08/25) must="false"で、config.setEditorAttributes で、属性を追加するようになった為の取り消しの対応。 351 final DBColumnConfig config = getModifyConfig( dbColumn ); 352 353 // 4.1.2.1 (2008/03/13) 354 if( mustType != null ) { 355 table.addMustType( i,mustType ); 356 // 6.8.1.4 (2017/08/25) must="false" で、must の取り消し 357 if( "false".equalsIgnoreCase( mustType ) ) { 358 config.removeEditorAttributes( "class" , "must" ); 359 } 360 } 361 362 table.setDBColumn( i,new DBColumn( config ) ); 363 364 break; 365 } 366 } 367 } 368 } 369 else { 370 for( int i=0; i<columns.length; i++ ) { 371 final int clmNo = table.getColumnNo( columns[i],strictCheck ); // 6.7.6.0 (2017/03/17) 372 if( clmNo < 0 ) { continue; } // 6.7.6.0 (2017/03/17) 373 374 final DBColumn dbColumn = table.getDBColumn( clmNo ); 375 376 final DBColumnConfig config = getModifyConfig( dbColumn ); 377 // 6.8.1.4 (2017/08/25) must="false"で、config.setEditorAttributes で、属性を追加するようになった為の取り消しの対応。 378 379 // 4.1.2.1 (2008/03/13) 380 if( mustType != null ) { 381 table.addMustType( clmNo,mustType ); 382 // 6.8.1.4 (2017/08/25) must="false" で、must の取り消し 383 if( "false".equalsIgnoreCase( mustType ) ) { 384 config.removeEditorAttributes( "class" , "must" ); 385 } 386 } 387 388 table.setDBColumn( clmNo,new DBColumn( config ) ); 389 } 390 } 391 } 392 393 return EVAL_PAGE ; 394 } 395 396 /** 397 * タグ文字列を作成します。 398 * 399 * ColumnEditor としては、HTMLTagSupport を継承しているため、 400 * このメソッドを定義する必要がありますが、内部的には使用していません。 401 * 各種属性は、入力する必要がある為、継承しているだけです。 402 * このクラスでは、このメソッドは、使われておりません。 403 * 404 * @og.rev 3.5.1.0 (2003/10/03) 新規追加 405 * 406 * @return タグ文字列(常に null を返す) 407 */ 408 @Override 409 protected String makeTag() { 410 return null; 411 } 412 413 /** 414 * タグリブオブジェクトをリリースします。 415 * 416 * キャッシュされて再利用されるので、フィールドの初期設定を行います。 417 * 418 * @og.rev 2.0.0.4 (2002/09/27) カスタムタグの release() メソッドを、追加 419 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。release2() を doEndTag()で呼ぶ。 420 * @og.rev 3.5.1.0 (2003/10/03) 親クラスをCommonTagSupportからHTMLTagSupportに変更。 421 * @og.rev 3.5.5.5 (2004/04/23) 入力欄の大きさを指定する viewSize 属性を追加。 422 * @og.rev 3.5.5.7 (2004/05/10) codeName 属性を追加。 423 * @og.rev 3.5.5.9 (2004/06/07) addNoValue 属性を修正。 424 * @og.rev 3.7.0.5 (2005/04/11) 複数カラムを同時設定できる columns 属性を追加 425 * @og.rev 3.8.8.5 (2007/03/09) 全カラム が指定されたことにする allColumns 属性を追加 426 * @og.rev 4.1.2.1 (2008/03/13) must , mustAny 属性を自動化します。 427 * @og.rev 4.3.4.0 (2008/12/01) ラベルデータの動的取得に対応します。 428 * @og.rev 5.1.9.0 (2010/08/01) codeList , codeGroup 属性を追加。(Codeリソースのサブセット) 429 * @og.rev 5.2.1.0 (2010/10/01) must , mustAny 属性の処理を、HTMLTagSupport に移します。 430 * @og.rev 5.6.2.3 (2013/03/22) useSLabel 属性を追加。(MENU,DBMENUでSLABELを利用するかどうか) 431 * @og.rev 5.6.2.3 (2013/03/22) 非表示文字の設定。noDisplayVal 属性を追加。 432 * @og.rev 5.7.3.0 (2014/02/07) noResource 属性を追加。ResourceManager を使用しないかどうか 433 * @og.rev 5.7.6.3 (2014/05/23) stringOutput追加 434 * @og.rev 6.0.4.0 (2014/11/28) addKeyLabel 属性を追加 435 * @og.rev 6.2.0.0 (2015/02/27) viewSize 属性の追加 436 * @og.rev 6.2.3.0 (2015/05/01) キー,ラベルで分離して出力するかどうか。writeKeyLabel 属性を追加 437 * @og.rev 6.3.1.1 (2015/07/10) codeKeyVal 属性を追加 438 * @og.rev 6.3.4.0 (2015/08/01) eventValue 追加 439 * @og.rev 6.7.6.0 (2017/03/17) strictCheck 追加 440 * @og.rev 8.1.2.3 (2022/05/20) 日付送り戻し不具合対応(useDateFeed 属性追加) 441 */ 442 @Override 443 protected void release2() { 444 super.release2(); 445 tableId = HybsSystem.TBL_MDL_KEY; 446 columns = null; // 3.7.0.5 (2005/04/11) 447 allColumns = false; // 3.8.8.5 (2007/03/09) 448 labelData = null; // 4.0.0 (2005/01/31) 449 className = null; 450 fieldSize = null; // 6.2.0.0 (2015/02/27) 451 viewSize = null; // 6.2.0.0 (2015/02/27) 452 maxlength = null; // 3.5.5.5 (2004/04/23) 453 writable = null; 454 renderer = null; 455 editor = null; 456 dbType = null; 457 codeName = null; // 3.5.5.7 (2004/05/10) 458 codeList = null; // 5.1.9.0 (2010/08/01) 新規追加(Codeリソースのサブセット) 459 codeGroup = null; // 5.1.9.0 (2010/08/01) 新規追加(Codeリソースのサブセット) 460 codeKeyVal = null; // 6.3.1.1 (2015/07/10) 新規追加(新しいコードセレクトを作成する為の KEY:VAL 文字列) 461 defaultVal = null; 462 parameter = null; 463 dbid = null; 464 addNoValue = null; // 3.5.5.9 (2004/06/07) 465 addKeyLabel = null; // 6.0.4.0 (2014/11/28) キー:ラベル形式で表示するかどうか 466 writeKeyLabel = false; // 6.2.3.0 (2015/05/01) キー,ラベルで分離して出力するかどうか 467 useLabelMap = false; // 4.3.4.0 (2008/12/01) 468 useSLabel = null; // 5.6.2.3 (2013/03/22) MENU,DBMENUでSLABELを利用するかどうか 469 noDisplayVal = null; // 5.6.2.3 (2013/03/22) 非表示文字の設定 470 labelMap = null; // 4.3.4.0 (2008/12/01) 471 eventColumn = null; // 4.3.6.0 (2009/04/01) 472 eventValue = null; // 6.3.4.0 (2015/08/01) 473 rawParameter = null; // 4.3.6.0 (2009/04/01) 474 eventURL = null; // 4.3.6.0 (2009/04/01) 475 noResource = false; // 5.7.3.0 (2014/02/07) noResource 属性を追加。 476 strictCheck = true; // 6.7.6.0 (2017/03/17) 477 stringOutput = HybsSystem.sysBool( "USE_STRING_EXCEL_OUTPUT" ); // 5.7.6.3 (2014/05/23) 478 useDateFeed = true; // 8.1.2.3 (2022/05/20) 479 } 480 481 /** 482 * カスタマイズされた DBColumnConfig を作成します。 483 * 484 * DBColumnConfig は、DBColumn より取得します。この DBColumnConfig に、 485 * 属性で指定された値をセットすることで、カスタマイズを行います。 486 * 487 * @og.rev 3.7.0.5 (2005/04/11) 新規追加 488 * @og.rev 4.1.2.1 (2008/03/13) must , mustAny 属性を自動化します。 489 * @og.rev 4.3.4.0 (2008/12/01) ラベルデータの動的取得に対応します。 490 * @og.rev 4.3.6.0 (2009/04/01) evnetColumn対応 491 * @og.rev 5.1.8.0 (2010/07/01) メソッド名変更(setDefValue ⇒ setDefault) 492 * @og.rev 5.1.9.0 (2010/08/01) codeList ,codeGroup 属性を追加(Codeリソースのサブセット) 493 * @og.rev 5.6.2.3 (2013/03/22) useSLabel 属性を追加。(MENU,DBMENUでSLABELを利用するかどうか) 494 * @og.rev 5.6.2.3 (2013/03/22) 非表示文字の設定。noDisplayVal 属性を追加。 495 * @og.rev 5.7.3.0 (2014/02/07) noResource 属性を追加。ResourceManager を使用しないかどうか 496 * @og.rev 5.7.6.2 (2014/05/16) IEのHTML5機能が無効の場合の処理 497 * @og.rev 5.7.6.3 (2014/05/23) stringOutput追加 498 * @og.rev 6.0.4.0 (2014/11/28) addKeyLabel 属性を追加 499 * @og.rev 6.2.0.0 (2015/02/27) viewSize 属性の追加 500 * @og.rev 6.2.3.0 (2015/05/01) maxlength 変数は、0 の場合は、無制限になります。 501 * @og.rev 6.3.1.0 (2015/06/28) 個人リソースのUSE_ADD_KEY_LABELで初期値設定 502 * @og.rev 6.3.1.1 (2015/07/10) codeKeyVal 属性を追加 503 * @og.rev 6.3.4.0 (2015/08/01) eventValue 追加 504 * @og.rev 5.9.18.1 (2017/03/24) DATALIST_R用のIEのHTML5機能が無効の場合の処理を追加 505 * 506 * @param dbColumn カラムオブジェクト 507 * 508 * @return カスタマイズされた DBColumnConfig 509 */ 510 private DBColumnConfig getModifyConfig( final DBColumn dbColumn ) { 511 // 5.7.3.0 (2014/02/07) noResource 属性を追加 512 if( noResource ) { 513 labelData = new LabelData( dbColumn.getName() ); 514 renderer = "LABEL"; 515 } 516 517 final DBColumnConfig config = dbColumn.getConfig(); 518 519 // 5.7.6.2 (2014/05/16) IEのHTML5機能が無効の場合の処理 520 final String ieHTML5 = (String)getSessionAttribute( HybsSystem.IE_HTML5_KEY ); 521 if( "FALSE".equalsIgnoreCase( ieHTML5 ) ) { 522 if( "DATALIST".equalsIgnoreCase( editor ) || 523 "DATALIST".equalsIgnoreCase( config.getEditor() ) ) { 524 editor = "INDBMENU"; 525 } 526 // 5.9.18.1 (2017/03/24) IEのHTML5機能が無効の場合の処理(DATALIST_R用) 527 if( "DATALIST_R".equalsIgnoreCase( editor ) || 528 "DATALIST_R".equalsIgnoreCase( config.getEditor() )){ 529 editor = "INMENU"; 530 } 531 } 532 533 // 6.3.1.0 (2015/06/28) 個人リソースのUSE_ADD_KEY_LABELで初期値設定 534 if( addKeyLabel == null ) { addKeyLabel = nval( sys( "USE_ADD_KEY_LABEL" ) , null ); } // 4:個人設定可 535 536 final String lang = get( "lang" ); // 4.0.0 (2005/01/31) super クラスで受けます。 537 538 if( lang != null ) { config.setLang( lang ); } 539 if( labelData != null ) { config.setLabelData( labelData ); } // 4.0.0 (2005/01/31) 540 if( className != null ) { config.setClassName( className ); } 541 if( fieldSize != null ) { config.setFieldSize( fieldSize ); } // 6.2.0.0 (2015/02/27) メソッド名変更 542 if( viewSize != null ) { config.setViewLength( viewSize ); } // 6.2.0.0 (2015/02/27) 新規追加 543 if( maxlength != null ) { config.setMaxlength( maxlength ); } // 3.5.5.5 (2004/04/23) 544 if( writable != null ) { config.setWritable( writable ); } 545 if( renderer != null ) { config.setRenderer( renderer ); } 546 if( editor != null ) { config.setEditor( editor ); } 547 if( dbType != null ) { config.setDbType( dbType ); } 548 if( defaultVal != null ) { config.setDefault( defaultVal ); } // 5.1.8.0 (2010/07/01) 549 if( parameter != null ) { config.setParameter( parameter ); } 550 if( dbid != null ) { config.setDbid( dbid ); } 551 if( eventColumn != null ) { config.setEventColumn( eventColumn ); } // 4.3.6.0 (2009/04/01) 552 if( eventValue != null ) { config.setEventValue( eventValue ); } // 6.3.4.0 (2015/08/01) 553 if( eventURL != null ) { config.setEventURL( eventURL ); } // 4.3.6.0 (2009/04/01) 554 if( rawParameter != null ){ config.setRawParameter( rawParameter ); } // 4.3.6.0 (2009/04/01) 555 if( useSLabel != null ) { config.setUseSLabel( useSLabel ); } // 5.6.2.3 (2013/03/22) 556 if( noDisplayVal != null ) { config.setNoDisplayVal( noDisplayVal ); } // 5.6.2.3 (2013/03/22) 557 if( addKeyLabel != null ) { config.setAddKeyLabel( addKeyLabel ); } // 6.0.4.0 (2014/11/28) 558 559 if( writeKeyLabel ) { config.setWriteKeyLabel( writeKeyLabel ); } // 6.2.3.0 (2015/05/01) 560 if( !useDateFeed ) { config.setUseDateFeed( useDateFeed ); } // 8.1.2.3 (2022/05/20) 561 562 // 4.0.0 (2005/11/30) ロールを指定 563 final String roles = get( "roles" ); 564 if( roles != null ) { config.setRoles( roles ); } 565 566 // 4.0.0 (2005/01/31) 567 if( codeName != null ) { 568 final CodeData codeData = getResource().getCodeData( codeName ) ; 569 config.setCodeData( codeData ); 570 } 571 572 // codeName で指定のリソースでも、サブセットが作成できます。 573 // 5.1.9.0 (2010/08/01) codeList 属性を追加(Codeリソースのサブセット) 574 if( codeList != null ) { 575 final CodeData codeData = config.getCodeData() ; 576 if( codeData != null ) { 577 config.setCodeData( codeData.subsetList( codeList ) ); 578 } 579 } 580 581 // 5.1.9.0 (2010/08/01) codeGroup 属性を追加(Codeリソースのサブセット) 582 if( codeGroup != null ) { 583 final CodeData codeData = config.getCodeData() ; 584 if( codeData != null && codeData.useGroup() ) { 585 config.setCodeData( codeData.subsetGroup( codeGroup ) ); 586 } 587 } 588 589 // 6.3.1.1 (2015/07/10) 新規追加(新しいコードセレクトを作成する為の KEY:VAL 文字列) 590 if( codeKeyVal != null ) { 591 config.setParameter( codeKeyVal ); 592 config.setRenderer( "KVMENU" ); 593 config.setEditor( "KVMENU" ); 594 } 595 596 // 3.5.5.9 (2004/06/07) 597 // 注意:addNoValue は、互換性の関係で、値が指定された場合のみ、 598 // config に設定します。 599 // editor="DBMENU" が、指定された場合は、addNoValue が指定されていない場合のみ、 600 // 従来との互換性の関係より、このクラスのデフォルト(true)を、config に設定します。 601 if( addNoValue != null ) { 602 // Boolean.parseBoolean は、引数がnullの場合は、falseを返すが、値が設定されている時のみセットするので、nullチェックしている。 603 config.setAddNoValue( Boolean.parseBoolean( addNoValue ) ); // 6.1.0.0 (2014/12/26) refactoring 604 } 605 606 // 3.5.1.0 (2003/10/03) 親クラスをCommonTagSupportからHTMLTagSupportに変更。 607 config.setEditorAttributes( getAttributes() ); 608 609 // 4.3.4.0 (2008/12/01) ラベルデータの動的取得に対応します。 610 if( useLabelMap && labelMap != null ) { 611 final LabelData ldata = labelMap.get( dbColumn.getName() ); 612 if( ldata != null ) { 613 config.setLabelData( ldata ); 614 } 615 } 616 617 // 5.7.6.3 (2014/05/23) 618 config.setStringOutput( stringOutput ); 619 620 return config ; 621 } 622 623 /** 624 * 【TAG】カラム名をセットします。 625 * 626 * @og.tag 627 * カラム名をセットします。 628 * columns と同時にはセットできません。 629 * 値に"*"を指定することで、全カラムを対象とすることができます。 630 * また、"PN*,CDK*"等のように前方一致でのワイルドカード指定も可能です。 631 * 632 * @og.rev 3.7.0.5 (2005/04/11) 複数カラムを同時設定できる columns 属性を追加 633 * @og.rev 3.8.8.5 (2007/03/09) 全カラム が指定されたことにする allColumns 属性を追加 634 * 635 * @param clm カラム名 636 */ 637 public void setColumn( final String clm ) { 638 if( columns != null ) { 639 final String errMsg = "columns との同時セットは出来ません。: " + CR 640 + "column=[" + clm + "] , " 641 + "columns=[" + StringUtil.array2csv( columns ) + "]"; 642 throw new HybsSystemException( errMsg ); 643 } 644 final String column = getRequestParameter( clm ); 645 if( column != null && column.length() > 0 ) { 646 columns = new String[] { column }; 647 allColumns = column.indexOf( '*' ) >= 0 ; // 3.8.8.5 (2007/03/09) 648 } 649 } 650 651 /** 652 * 【TAG】カラム名をCSV形式で複数セットします。 653 * 654 * @og.tag 655 * カラム名をセットします。 656 * column と同時にはセットできません。 657 * 分解方法は、通常のパラメータ取得後に、CSV分解します。 658 * 値に"*"を指定することで、全カラムを対象とすることができます。 659 * また、"PN*,CDK*"等のように前方一致でのワイルドカード指定も可能です。 660 * 661 * @og.rev 3.7.0.5 (2005/04/11) 複数カラムを同時設定できる columns 属性を追加 662 * @og.rev 3.8.8.5 (2007/03/09) 通常のパラメータ取得後に、CSV分解に戻します。 663 * @og.rev 3.8.8.5 (2007/03/09) 全カラム が指定されたことにする allColumns 属性を追加 664 * 665 * @param clms カラム名(CSV形式) 666 */ 667 public void setColumns( final String clms ) { 668 if( columns != null ) { 669 final String errMsg = "column との同時セットは出来ません。: " + CR 670 + "column=[" + StringUtil.array2csv( columns ) + "] , " 671 + "columns=[" + clms + "]" ; 672 throw new HybsSystemException( errMsg ); 673 } 674 final String column = nval( getRequestParameter( clms ),null ); 675 if( column != null ) { 676 allColumns = column.indexOf( '*' ) >= 0 ; // 3.8.8.5 (2007/03/09) 677 columns = StringUtil.csv2Array( column ); 678 if( columns.length == 0 ) { columns = null; } 679 } 680 } 681 682 /** 683 * 【TAG】ラベルリソースに定義されたラベルIDをセットします。 684 * 685 * @og.tag 686 * ラベルをセットします。 687 * 688 * @og.rev 2.3.1.2 (2003/01/28) ラベルリソースからラベル名を取得するように修正 689 * @og.rev 4.0.0.0 (2005/01/31) キーより、ラベルデータオブジェクトを取得します。 690 * 691 * @param lbl ラベル 692 */ 693 public void setLabel( final String lbl ) { 694 labelData = getResource().getLabelData( getRequestParameter( lbl ) ) ; // 4.0.0 (2005/01/31) 695 } 696 697 /** 698 * 【TAG】カラムのクラス名(VARCHAR2,NUMBER など)をセットします。 699 * 700 * @og.tag 701 * カラムのクラス名をセットします。 702 * "既存値:設定値" という指定を行えば、既存値を持っている場合のみ、設定値に置き換えます。 703 * 704 * @og.rev 6.4.1.1 (2016/01/16) "既存値:設定値" という指定を行えば、既存値を持っている場合のみ、設定値に置き換えます。 705 * 706 * @param cls クラス 707 */ 708 public void setClassName ( final String cls ) { 709 className = nval( getRequestParameter( cls ),className ); 710 } 711 712 /** 713 * 【HTML】最大入力文字数を指定します(入力可能文字数で、バイト数ではありません)。 714 * 715 * @og.tag 716 * カラムの入力文字制限数をセットします。 717 * 718 * @og.rev 6.2.3.0 (2015/05/01) maxlength 変数は、0 の場合は、無制限になります。 719 * 720 * @param len 入力文字制限数 721 */ 722 public void setMaxlength( final String len ) { 723 maxlength = nval( getRequestParameter( len ),maxlength ); 724 725 // 6.2.3.0 (2015/05/01) maxlength 変数は、0 の場合は、無制限になります。 726 if( "0".equals( maxlength ) ) { set( "NO_MAXLEN", "true" ); } 727 } 728 729 /** 730 * 【TAG】カラムの入力枠サイズ(横幅)を文字数でセットします(入力文字制限ではありません)。 731 * 732 * @og.tag 733 * カラムのサイズをセットします。 734 * 735 * @og.rev 3.5.5.5 (2004/04/23) 入力欄の大きさを指定する viewSize 属性を追加。 736 * 737 * @param siz サイズ 738 */ 739 public void setSize( final String siz ) { 740 fieldSize = nval( getRequestParameter( siz ),null ); // 6.2.0.0 (2015/02/27) 741 } 742 743 /** 744 * 【TAG】カラムの表示サイズ(横幅)を文字数でセットします。 745 * 746 * @og.tag 747 * 入力枠ではなく、表示する時の文字数制限に使われます。 748 * maxLength は、DB上の桁数(バイト数)ですが、viewSize は、文字数です。 749 * SLABEL の簡易バイト数計算(全角2Byte)でもなく、文字数計算になります。 750 * 751 * @og.rev 6.2.0.0 (2015/02/27) viewSize 属性の追加 752 * 753 * @param len 表示サイズ(横幅) 754 */ 755 public void setViewSize( final String len ) { 756 viewSize = nval( getRequestParameter( len ),null ); 757 } 758 759 /** 760 * 【TAG】カラムが書き込み可能かどうか[true:可能/false:不可]を設定します(初期値:null)。 761 * 762 * @og.tag 763 * カラムの書き込み可能を設定します。 764 * 初期値は、null:無指定 です。 765 * 766 * @param flag 書き込み許可 [true:許可/false:不可] 767 */ 768 public void setWritable ( final String flag ) { 769 writable = nval( getRequestParameter( flag ),writable ); 770 } 771 772 /** 773 * 【TAG】カラムの表示用レンデラー({@og.doc03Link renderer Renderer_****})をセットします。 774 * 775 * @og.tag 776 * これは、plugin.column 以下の Renderer_**** クラスの **** を与えます。 777 * これらは、CellRenderer インターフェースを継承したサブクラスです。 778 * 属性クラス定義の {@link org.opengion.hayabusa.db.CellRenderer Renderer} を参照願います。 779 * {@og.doc03Link renderer Renderer_**** クラス} 780 * "既存値:設定値" という指定を行えば、既存値を持っている場合のみ、設定値に置き換えます。 781 * 782 * @og.rev 6.4.1.1 (2016/01/16) "既存値:設定値" という指定を行えば、既存値を持っている場合のみ、設定値に置き換えます。 783 * 784 * @param rdr 表示用レンデラー (Renderer_**** の ****) 785 * @see org.opengion.hayabusa.db.CellRenderer 786 */ 787 public void setRenderer ( final String rdr ) { 788 renderer = nval( getRequestParameter( rdr ),renderer ); 789 } 790 791 /** 792 * 【TAG】カラムの編集用エディター({@og.doc03Link editor Editor_****})をセットします。 793 * 794 * @og.tag 795 * これは、plugin.column 以下の Editor_**** クラスの **** を 796 * 与えます。これらは、CellEditor インターフェースを継承したサブクラスです。 797 * 属性クラス定義の {@link org.opengion.hayabusa.db.CellEditor Editor} を参照願います。 798 * {@og.doc03Link editor Editor_**** クラス} 799 * "既存値:設定値" という指定を行えば、既存値を持っている場合のみ、設定値に置き換えます。 800 * 801 * @og.rev 6.4.1.1 (2016/01/16) "既存値:設定値" という指定を行えば、既存値を持っている場合のみ、設定値に置き換えます。 802 * 803 * @param ed 編集用エディター (Editor_**** の ****) 804 * @see org.opengion.hayabusa.db.CellEditor 805 */ 806 public void setEditor ( final String ed ) { 807 editor = nval( getRequestParameter( ed ),editor ); 808 } 809 810 /** 811 * 【TAG】DBタイプ({@og.doc03Link dbType DBType_****})をセットします。 812 * 813 * @og.tag 814 * これは、org.opengion.hayabusa.db.column 以下の DBType_**** クラスの **** を 815 * 与えます。これらは、DBType インターフェースを継承したサブクラスです。 816 * 属性クラス定義の {@link org.opengion.hayabusa.db.DBType DBType} を参照願います。 817 * {@og.doc03Link dbType DBType_**** クラス} 818 * "既存値:設定値" という指定を行えば、既存値を持っている場合のみ、設定値に置き換えます。 819 * 820 * @og.rev 6.4.1.1 (2016/01/16) "既存値:設定値" という指定を行えば、既存値を持っている場合のみ、設定値に置き換えます。 821 * 822 * @param dt パラメータ 823 * @see org.opengion.hayabusa.db.DBType DBType_**** の **** 824 */ 825 public void setDbType( final String dt ) { 826 dbType = nval( getRequestParameter( dt ),dbType ); 827 } 828 829 /** 830 * 【TAG】コードセレクトのユニークキー(コード名称)をセットします。 831 * 832 * @og.tag 833 * このキーを元に、CodeSelectionオブジェクトを構築します。 834 * 835 * @og.rev 3.5.5.7 (2004/05/10) 新規作成 836 * 837 * @param name メニューのユニークキー(コード名称) 838 */ 839 public void setCodeName( final String name ) { 840 codeName = nval( getRequestParameter( name ),codeName ); 841 } 842 843 /** 844 * 【TAG】コードセレクトのサブセットとなるコード(キー)をCSV形式で指定します。 845 * 846 * @og.tag 847 * この値に限定された、コードリソースを、既存の、CodeData の 848 * サブセットとして作成します。 849 * codeName で指定されたリソースでも、サブセットを作成する事ができます。 850 * ここで指定するのは、コード(キー)だけです。 851 * 852 * @og.rev 5.1.9.0 (2010/08/01) 新規作成 853 * 854 * @param list コードセレクトのサブセットとなるコード(キー) 855 */ 856 public void setCodeList( final String list ) { 857 codeList = nval( getRequestParameter( list ),codeList ); 858 } 859 860 /** 861 * 【TAG】コードセレクトのサブセットとなるグループを指定します。 862 * 863 * @og.tag 864 * この値に限定された、コードリソースを、既存の、CodeData の 865 * サブセットとして作成します。 866 * codeName で指定されたリソースでも、サブセットを作成する事ができます。 867 * 868 * @og.rev 5.1.9.0 (2010/08/01) 新規作成 869 * 870 * @param group コードセレクトのサブセットとなるグループ 871 */ 872 public void setCodeGroup( final String group ) { 873 codeGroup = nval( getRequestParameter( group ),codeGroup ); 874 } 875 876 /** 877 * 【TAG】新しいコードセレクトを作成する為の「キー:ラベル キー:ラベル」の文字列を指定します。 878 * 879 * @og.tag 880 * 既存の、CodeData には存在しない、新しいコードリソースを作成する為の、文字列を指定します。 881 * 文字列は、「キー:ラベル キー:ラベル」形式で、スペースで分解後、":" でキーとラベルに分離します。 882 * スペース分解後の文字列に、":" が含まれていない場合は、キーをラベルとして扱います。 883 * また、ラベル部分は、ラベルリソースを使用して、変換を行います。 884 * 内部的には、CodeData を作成しません。DBColumnオブジェクト内で、直接、Selection_KEYVAL を生成します。 885 * codeName 、codeList、codeGroup などが指定された場合は、そちらが優先されます。 886 * 「キー:ラベル キー:ラベル」で、ラベル にスペースを含ませる場合は、ダブルクォーテーションで囲ってください。 887 * 「"キー:ラベル" "キー:ラベル"」という感じです。 888 * 889 * ※ editor,renderer を、"KVMENU" にして、param に、「キー:ラベル キー:ラベル」 890 * の文字列を指定する方法の、簡易版です。 891 * 892 * @og.rev 6.3.1.1 (2015/07/10) codeKeyVal 属性を追加 893 * 894 * @param keyval KEY:VAL文字列 895 */ 896 public void setCodeKeyVal( final String keyval ) { 897 codeKeyVal = nval( getRequestParameter( keyval ),codeKeyVal ); 898 } 899 900 /** 901 * 【TAG】パラメータをセットします。 902 * 903 * @og.tag 904 * ここで指定したパラメータは、renderer、editor、dbType すべてのパラメータに 905 * セットされます。 906 * パラメータをセットします。 907 * 908 * @og.rev 5.6.4.3 (2013/05/24) 新規追加 909 * 910 * @param prm パラメータ 911 */ 912 public void setParam( final String prm ) { 913 parameter = nval( getRequestParameter( prm ),parameter ); 914 rawParameter = nval( prm, parameter ); 915 } 916 917 /** 918 * 【TAG】value属性に値がセットされていないとき使用する、初期値を指定します。 919 * 920 * @og.tag 921 * value属性に値がセットされていないときに、この初期値を使用します。 922 * 923 * 8.4.3.0 (2023/03/31) defaultVal の設定値の取り扱い(変更なし) 924 * {@XXXX} は、リクエスト変数 ⇒ valueタグセット値 を確認 925 * 値がなければ、null となる。DBColumnの初期値は、""(空文字列)にセットされる。 926 * 通常の固定値は、そのまま使用されるが、""(空文字列)の場合は、 927 * null となる。DBColumnの初期値は、""(空文字列)にセットされる。 928 * defaultVal属性を使用しない場合は、 929 * null のままで、DBColumnの初期値は、""(空文字列)にセットされる。 930 * 931 * @param dv 初期値 932 */ 933 public void setDefaultVal( final String dv ) { 934 defaultVal = nval( getRequestParameter( dv ),defaultVal ); 935 } 936 937 /** 938 * 【TAG】セレクトメニューの値なしのOptionの有無[true/false]を指定します(初期値:falseと同等)。 939 * 940 * @og.tag 941 * セレクトメニューの場合、値なしのOptionをSelectに含めるかどうかを指定します。 942 * ここでは、検索結果の登録画面に使用されるケースが多いため、なにも指定されない 943 * 場合は、なにもセットしません。(Coderesourceの指定どおり) 944 * 動作としては、初期値は、含めない("false") と同等です。 945 * 946 * <og:columnEditor column="CDBK" addNoValue="false" /> 947 * 948 * @param flag 値なしのOptionの有無 [true:含める/それ以外:含めない] 949 */ 950 public void setAddNoValue( final String flag ) { 951 addNoValue = nval( getRequestParameter( flag ),addNoValue ); 952 } 953 954 /** 955 * 【TAG】セレクトメニューの場合、キー:ラベル形式で表示するかどうか[true/false/null]を指定します(初期値:null)。 956 * 957 * @og.tag 958 * カラムがプルダウンメニュー形式の場合、キー:ラベル形式で表示するか、ラベルだけで表示するかを 959 * 選択できます。 960 * true を指定すると、「強制的に」キー:ラベル形式で表示します。 961 * false の場合は、「強制的に」ラベルのみで表示されます。 962 * 初期値の null の場合、コードリソースや、SQL文に準拠した指定通りの形式で表示します。 963 * 964 * <og:column name="CDC" addKeyLabel="true" /> 965 * 966 * @og.rev 6.0.4.0 (2014/11/28) キー:ラベル形式で表示するかどうか。新規追加 967 * 968 * @param flag キー:ラベル形式表示 [true:キー:ラベル形式/false:ラベルのみ/null:指定通り] 969 */ 970 public void setAddKeyLabel( final String flag ) { 971 addKeyLabel = nval( getRequestParameter( flag ),addKeyLabel ); 972 } 973 974 /** 975 * 【TAG】セレクトメニューの場合、キーとラベルを分けて出力するかどうか[true/false]を指定します(初期値:false)。 976 * 977 * @og.tag 978 * カラムがプルダウンメニュー形式の場合、ファイル出力時に、キーとラベルを分離して出力する事ができます。 979 * この属性と、addKeyLabel とは、微妙に関連していて、addKeyLabel="true" のみの場合は、 980 * キー:ラベル形式で、出力されますが、writeKeyLabel="true" も指定されている場合は、こちらが優先されます。 981 * なお、この指定が有効なのは、セレクトメニューのカラムのみです。 982 * 初期値は、false です。 983 * 984 * @og.rev 6.2.3.0 (2015/05/01) キー/ラベルで分離して出力するかどうか。 985 * 986 * @param flag キー/ラベル分離出力するかどうか [true:分離出力/false:通常] 987 */ 988 public void setWriteKeyLabel( final String flag ) { 989 writeKeyLabel = nval( getRequestParameter( flag ),writeKeyLabel ); 990 } 991 992 /** 993 * 【TAG】SQL文を指定してラベル情報を動的に読み込むかどうか[true/false]指定します(初期値:false)。 994 * 995 * @og.tag 996 * trueを指定すると、body部分に記述されたSQL文よりラベル情報を生成して、 997 * 動的にラベル表示を切り替えます。 998 * 999 * ワイルドカードを使用した、カラムの複数指定と組み合わせることで、外部から設定 1000 * されたラベル情報で一括で変更することができます。 1001 * 1002 * 発行するクエリでは、第1カラムにラベルキーを、第2カラムにラベル名称を設定します。 1003 * 第3カラムが存在する場合は、名称(短)として使用されます。(必須ではありません) 1004 * 1005 * ここで作成されたラベル情報は、カラムエディターを適用したDBTableModelのみで 1006 * 有効であり、内部的にもキャッシュされません。 1007 * 1008 * 初期値は、false(動的読込しない)です。 1009 * 1010 * @og.rev 4.3.4.0 (2008/12/01) 新規作成 1011 * 1012 * @param flag 動的読込 [true:する/false:しない] 1013 */ 1014 public void setUseLabelMap( final String flag ) { 1015 useLabelMap = nval( getRequestParameter( flag ),useLabelMap ); 1016 } 1017 1018 /** 1019 * 【TAG】MENU,DBMENUでSLABELを利用するかどうか[auto/true/false]を指定します(初期値:null)。 1020 * 1021 * @og.tag 1022 * 通常はセレクトメニューは一覧とそれ以外で短縮ラベルの利用が自動で切り替わります。 1023 * 強制的にSLABELを利用させたい場合にこの属性をtrueにセットして下さい。 1024 * auto/true/false以外を指定した場合はfalse扱いとします。 1025 * ここでの初期値は、値の変更を行わないということで、null です。 1026 * 1027 * @og.rev 5.6.2.3 (2013/03/22) columnタグに実装されているので移植 1028 * 1029 * @param prm SLABEL利用 [auto:自動/true:利用する/false:利用しない] 1030 */ 1031 public void setUseSLabel( final String prm ) { 1032 useSLabel = nval( getRequestParameter( prm ),useSLabel ); 1033 if( useSLabel != null && 1034 !"auto".equalsIgnoreCase( useSLabel ) && 1035 !"true".equalsIgnoreCase( useSLabel ) && 1036 !"false".equalsIgnoreCase( useSLabel ) ) { 1037 final String errMsg = "useSLabel は、[auto:自動/true:利用する/false:利用しない] から選んでください。" 1038 + "useSLabel=[" + prm + "]" + CR ; 1039 throw new HybsSystemException( errMsg ); 1040 } 1041 } 1042 1043 /** 1044 * 【TAG】非表示文字列を指定します(初期値:null)。 1045 * 1046 * @og.tag 1047 * これは、例えば、数字型の場合は、0 がデフォルトなどの場合、 1048 * あえて表示したくないなどのケースに使います。 1049 * そのような状況が設定されていない場合は、null が返されます。 1050 * 初期値は、null です。 1051 * 1052 * @og.rev 5.6.2.3 (2013/03/22) 新規追加 1053 * 1054 * @param prm 非表示文字列 [auto:自動/true:利用する/false:利用しない] 1055 */ 1056 public void setNoDisplayVal( final String prm ) { 1057 noDisplayVal = nval( getRequestParameter( prm ),noDisplayVal ); 1058 } 1059 1060 /** 1061 * 【TAG】(通常は使いません)結果のDBTableModelを、sessionに登録するときのキーを指定します 1062 * (初期値:HybsSystem#TBL_MDL_KEY[={@og.value HybsSystem#TBL_MDL_KEY}])。 1063 * 1064 * @og.tag 1065 * 検索結果より、DBTableModelオブジェクトを作成します。これを、下流のviewタグ等に 1066 * 渡す場合に、通常は、session を利用します。その場合の登録キーです。 1067 * query タグを同時に実行して、結果を求める場合、同一メモリに配置される為、 1068 * この tableId 属性を利用して、メモリ空間を分けます。 1069 * (初期値:HybsSystem#TBL_MDL_KEY[={@og.value HybsSystem#TBL_MDL_KEY}])。 1070 * 1071 * @param id テーブルID (sessionに登録する時のID) 1072 */ 1073 public void setTableId( final String id ) { 1074 tableId = nval( getRequestParameter( id ),tableId ); 1075 } 1076 1077 /** 1078 * 【TAG】データベースへ接続する場合のID(初期値:null)。 1079 * 1080 * @og.tag 1081 * データベース接続を使用するエディター、レンデラーを使用する場合に使用する接続先IDを指定します。 1082 * カラムオブジェクトは、query処理ではなく、view処理時に適用されるため、データベース 1083 * 接続先を指定する必要があります。 1084 * 初期値は、null(DEFAULT 接続) です。 1085 * 1086 * @og.rev 4.0.0.0 (2006/04/02) 新規追加 1087 * 1088 * @param id 接続先ID 1089 */ 1090 public void setDbid( final String id ) { 1091 dbid = nval( getRequestParameter( id ),dbid ); 1092 } 1093 1094 /** 1095 * 【TAG】イベントカラム(親カラム)を設定します。 1096 * 1097 * @og.tag 1098 * 親子関係を持った項目の動的な入れ替えを行う場合に利用します。 1099 * このカラムを変化させるトリガとなるカラムの名前をセットします。 1100 * 1101 * ※詳細はcolumnTagのeventURL属性の説明をご覧下さい。 1102 * 1103 * なお、columnEditorで、Viewに対して、SQL文の定義(置き換え定義)をする場合でも、 1104 * 他カラムの値の参照は、columnタグの場合と同様に、{@XXXX}または$nの変数により行います。 1105 * この場合、これらの変数は、"自身と同一行のカラム"を意味します。 1106 * 1107 * @og.rev 4.3.6.0 (2009/04/01) 1108 * @og.rev 5.1.7.0 (2010/06/01) コメント大幅修正 1109 * 1110 * @param col 親カラム 1111 */ 1112 public void setEventColumn( final String col ) { 1113 eventColumn = nval( getRequestParameter( col ), eventColumn ); 1114 } 1115 1116 /** 1117 * 【TAG】eventColumn使用時の値を、SQL文から求めるためのqueryをセットします。 1118 * 1119 * @og.tag 1120 * eventColumn利用時は{@XXXX}はリクエストパラメータではなく 1121 * xxxカラムの実際の値が利用されます。 1122 * 1123 * @og.rev 6.3.4.0 (2015/08/01) eventValue 追加 1124 * @param val パラメータ 1125 */ 1126 public void setEventValue( final String val ) { 1127 eventValue = nval( getReservedParameter( val ), eventValue ); // ここでは{@XXXX}変換をしない 1128 } 1129 1130 /** 1131 * 【TAG】イベントカラム指定時に呼び出すURLを指定します。 1132 * 1133 * @og.tag 1134 * イベントカラム指定時に部品を作成するJSPを指定します。 1135 * 初期値はシステムリソースのEVENT_COLUMN_URLです。 1136 * (例:eventURL="makeColumn_custom.jsp") 1137 * 1138 * ※詳細はcolumnTagのeventURL属性の説明をご覧下さい。 1139 * 1140 * @og.rev 4.3.6.0 (2009/04/01) 1141 * 1142 * @param url JSPのURL 1143 */ 1144 public void setEventURL( final String url ) { 1145 eventURL = nval( getRequestParameter( url ), eventURL ); 1146 } 1147 1148 /** 1149 * 【TAG】eventColumn実行後のcallbak関数を指定します。 1150 * 1151 * @og.tag 1152 * eventColumnの動作終了後に実行するCallback関数の指定を行います。 1153 * 関数名のみを指定して下さい。 1154 * ex) sampleCallback()を実行する場合はeventCallback="sampleCallback" 1155 * 実行する関数の第一引数には自動的に次の要素が入った配列が渡されます 1156 * [0] 変更された子カラムのID属性値 1157 * [1] evnetColumn実行後の子カラムの値 1158 * [2] eventColumn実行前の子カラムの値 1159 * 1160 * この属性は、optionAttributesへの設定と同様の動作を行います。 1161 * 1162 * @og.rev 5.5.4.0 (2012/07/02) 新規追加 1163 * @og.rev 6.9.8.0 (2018/05/28) パラメータ引数が、未設定の場合の考慮不足 1164 * 1165 * @param callback Callback関数 1166 */ 1167 public void setEventCallback( final String callback ) { 1168 // optionAttributes扱いで登録します。 1169 final String clbk = getRequestParameter( callback ); 1170 if( StringUtil.isNotNull( clbk ) ){ 1171 add( "optionAttributes", "eventCallback='" + clbk + "'" ); 1172 } 1173 1174// // optionAttributes扱いで登録します。 1175// if( callback != null && callback.length() > 0 ){ 1176// add( "optionAttributes", "eventCallback='"+getRequestParameter( callback )+"'" ); 1177// } 1178 } 1179 1180 /** 1181 * 【HTML5】表示形式を指定します(初期値:text)。 1182 * 1183 * @og.tag 1184 * ColumnTagは、カラムリソースで作成される為、タイプは固定です。 1185 * しかし、HTML5 で追加された形式には、有用なタイプも存在する為、 1186 * それらへの書き換えをできるようにします。 1187 * よって、ここでは、従来型のタイプへの書き換えはできません。 1188 * (textだけは例外で戻せるようにします)。 1189 * 1190 * [search/tel/url/email/datetime/date/month/week/time/datetime-local/number/range/color] 1191 * が、設定できます。 1192 * 1193 * HTML5 の機能を有効にするには、ネイティブモードで動作させる必要があります。 1194 * ① USE_IE7_HEADER = "false" に設定する。 1195 * ② USE_HTML5_HEADER = "true" に設定する。 1196 * ③ IEのツール⇒互換表示設定で、互換表示に追加したWebサイトから削除する。 1197 * ④ 同上の設定で、イントラサイトを互換表示で表示するのチェックを外す。 1198 * 必要があります。 1199 * 1200 * <og:input type="text" /> テキストボックスを表示 1201 * 1202 * HTML5 で追加されたタイプ 1203 * <og:input type="search" /> 検索テキストの入力欄を作成する 1204 * <og:input type="tel" /> 電話番号の入力欄を作成する 1205 * <og:input type="url" /> URLの入力欄を作成する 1206 * <og:input type="email" /> メールアドレスの入力欄を作成する 1207 * <og:input type="datetime" /> UTC(協定世界時)による日時の入力欄を作成する 1208 * <og:input type="date" /> 日付の入力欄を作成する 1209 * <og:input type="month" /> 月の入力欄を作成する 1210 * <og:input type="week" /> 週の入力欄を作成する 1211 * <og:input type="time" /> 時間の入力欄を作成する 1212 * <og:input type="datetime-local" /> UTC(協定世界時)によらないローカル日時の入力欄を作成する 1213 * <og:input type="number" /> 数値の入力欄を作成する 1214 * <og:input type="range" /> レンジの入力欄を作成する 1215 * <og:input type="color" /> 色の入力欄を作成する 1216 * 1217 * @og.rev 5.7.1.0 (2013/12/06) HTML5 対応(新規追加) 1218 * @og.rev 6.3.4.0 (2015/08/01) Arrays.toString から String.join に置き換え。 1219 * @og.rev 6.4.3.4 (2016/03/11) String配列 から、Setに置き換えます。 1220 * 1221 * @param type HTML5用 [text/search/tel/url/email/datetime/date/month/week/time/datetime-local/number/range/color] 1222 */ 1223 public void setType( final String type ) { 1224 final String tp = getRequestParameter( type ); 1225 1226 if( check( tp , TYPE_SET ) ) { 1227 set( "type",tp ); 1228 } 1229 else { 1230 final String errMsg = "type 属性は、下記の中から選択してください。type=[" 1231 + tp + "] in [" + String.join( ", " , TYPE_SET ) + "]"; 1232 throw new HybsSystemException( errMsg ); 1233 } 1234 } 1235 1236 /** 1237 * 【TAG】ResourceManager を使用しないかどうか[true/false]を指定します(初期値:false)。 1238 * 1239 * @og.tag 1240 * trueを指定すると、使用しない設定になります。 1241 * これは、データベースから検索した値そのものが返される カラムオブジェクトを使用することになります。 1242 * 「noResource」なので、意味が反転しているのをご注意ください。 1243 * 1244 * false(初期値)は、ResourceManager を使用します。 1245 * 1246 * @og.rev 5.7.3.0 (2014/02/07) 新規作成 1247 * 1248 * @param flag ResourceManagerの不使用 [true:不使用/false:使用] 1249 */ 1250 public void setNoResource( final String flag ) { 1251 noResource = nval( getRequestParameter( flag ),noResource ); 1252 } 1253 1254 /** 1255 * 【TAG】(通常は使いません)カラムIDの存在チェックを行うかどうか[true/false]を指定します(初期値:true)。 1256 * 1257 * @og.tag 1258 * true の場合、カラムIDがDBTableModel に存在しない場合は、エラーになります。 1259 * false の場合、カラムIDがDBTableModel に存在しない場合は、無視します。 1260 * これは、検索条件によって、設定されるカラムが異なる場合でも、後続処理を 1261 * 正常に動作させたい場合に、使用します。 1262 * 初期値は true (チェックを行う) です。 1263 * 1264 * @og.rev 6.7.6.0 (2017/03/17) strictCheck 追加。 1265 * 1266 * @param check 存在チェック [true:行う/false:行わない] 1267 */ 1268 public void setStrictCheck( final String check ) { 1269 strictCheck = nval( getRequestParameter( check ),strictCheck ); 1270 } 1271 1272 /** 1273 * 【TAG】レンデラ利用時のExcel出力でセルタイプを文字固定にするか[true/false]を指定します(初期値:システム定数のUSE_STRING_EXCEL_OUTPUT)。 1274 * 1275 * @og.tag 1276 * falseを指定すると、dbTypeに従ったセルタイプとなります。 1277 * TableWriter内部でdouble変換をするためエラーに注意してください。 1278 * (初期値:システム定数のUSE_STRING_EXCEL_OUTPUT[={@og.value SystemData#USE_STRING_EXCEL_OUTPUT}])。 1279 * 1280 * @og.rev 5.7.6.3 (2014/05/23) 新規作成 1281 * 1282 * @param flag セルタイプの文字固定にするか [true:固定する/false:固定しない] 1283 */ 1284 public void setStringOutput( final String flag ) { 1285 stringOutput = nval( getRequestParameter( flag ),stringOutput ); 1286 } 1287 1288 /** 1289 * 【TAG】リアルタイムチェックを行うかどうかを指定します(初期値:true)。 1290 * 1291 * @og.tag 1292 * カラム単位でリアルタイムチェックを行うかどうかを設定をします。 1293 * タグに独自属性としてrealTimeCheck="true/false"を追記します。 1294 * falseを設定した場合にチェックが行われなくなります。 1295 * 初期値はリアルタイムチェックを行う(true)です。 1296 * 1297 * この属性は、optionAttributesへの設定と同様の動作を行います。 1298 * 引数の文字列の、true/false 判定を行っていません。そのままの文字列が設定されます。 1299 * JavaScript 側では、false 判定のみ行っているので、不正な文字列の場合は、 1300 * 初期値(true:リアルタイムチェックを行う)が適用されます。 1301 * これは、Ver5 とロジックを合わせておくための処置です。 1302 * 1303 * @og.rev 5.9.32.2 (2018/05/18) 新規追加 1304 * @og.rev 6.9.8.0 (2018/05/28) Ver5 とロジックを合わせます。 1305 * 1306 * @param flag リアルタイムチェックを行うかどうか [true:行う/false:行わない] 1307 */ 1308 public void setUseRealTimeCheck( final String flag ) { 1309 // optionAttributes扱いで登録します。 1310 final String rtcf = getRequestParameter( flag ); 1311 1312 if( StringUtil.isNotNull( rtcf ) ){ 1313 add( "optionAttributes", "realTimeChk=\"" + rtcf + "\"" ); // 連結時のスペースは、Attributes クラスで処理 1314 } 1315 1316// final boolean useRtc = nval( getRequestParameter( flag ) , true ); 1317// 1318// if( !useRtc ) { // true 以外の場合のみ、optionAttributes に属性を追加します。 1319// add( "optionAttributes", "realTimeChk=\"false\"" ); // 連結時のスペースは、Attributes クラスで処理 1320// } 1321 } 1322 1323 /** 1324 * 【TAG】日付送り戻し機能を有効にするかどうか[true:有効/false:無効]指定します(初期値:true)。 1325 * 1326 * @og.tag 1327 * 編集種別が年月(YM)、年月日(YMD)、年月日(YMD2)のとき、日付送り戻し機能の 1328 * 有効(true)/無効(false)を指定します。 1329 * イベントカラム(親カラム)を設定し、param属性に定義したSQL文を実行させたい場合には、 1330 * false を指定します。 1331 * 1332 * @og.rev 8.1.2.3 (2022/05/20) 日付送り戻し不具合対応(useDateFeed 属性追加) 1333 * 1334 * @param flag 日付送り戻し機能有無 [true:有効/false:無効] 1335 */ 1336 public void setUseDateFeed( final String flag ) { 1337 useDateFeed = nval( getRequestParameter( flag ),useDateFeed ); 1338 } 1339 1340 /** 1341 * このオブジェクトの文字列表現を返します。 1342 * 基本的にデバッグ目的に使用します。 1343 * 1344 * @return このクラスの文字列表現 1345 * @og.rtnNotNull 1346 */ 1347 @Override 1348 public String toString() { 1349 return ToString.title( this.getClass().getName() ) 1350 .println( "VERSION" ,VERSION ) 1351 .println( "tableId" ,tableId ) 1352 .println( "columns" ,columns ) 1353 .println( "allColumns" ,allColumns ) 1354 .println( "className" ,className ) 1355 .println( "size" ,fieldSize ) // 6.2.0.0 (2015/02/27) 1356 .println( "viewSize" ,viewSize ) // 6.2.0.0 (2015/02/27) 1357 .println( "maxlength" ,maxlength ) 1358 .println( "writable" ,writable ) 1359 .println( "renderer" ,renderer ) 1360 .println( "editor" ,editor ) 1361 .println( "codeName" ,codeName ) 1362 .println( "dbType" ,dbType ) 1363 .println( "defaultVal" ,defaultVal ) 1364 .println( "parameter" ,parameter ) 1365 .println( "dbid" ,dbid ) 1366 .println( "addNoValue" ,addNoValue ) 1367 .println( "Other..." ,getAttributes().getAttribute() ) 1368 .fixForm().toString() ; 1369 } 1370}