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     */
016    package org.opengion.hayabusa.taglib;
017    
018    import static org.opengion.fukurou.util.StringUtil.nval;
019    
020    import java.io.IOException;
021    import java.io.ObjectInputStream;
022    import java.io.ObjectOutputStream;
023    import java.util.Map;
024    
025    import org.opengion.fukurou.util.StringUtil;
026    import org.opengion.hayabusa.common.HybsSystem;
027    import org.opengion.hayabusa.common.HybsSystemException;
028    import org.opengion.hayabusa.db.DBColumn;
029    import org.opengion.hayabusa.db.DBColumnConfig;
030    import org.opengion.hayabusa.db.DBTableModel;
031    import org.opengion.hayabusa.resource.CodeData;
032    import org.opengion.hayabusa.resource.LabelData;
033    
034    /**
035     * 検索結果のカラ?対して様?な属?を付加するタグです?
036     *
037     * こ?タグでは、カラ?ソースの属?を?設定できます?検索結果(DBTableModel)
038     * には、カラ?ブジェク?DBColumn)を持って?す?こ?オブジェクト??
039     * カラ?ソースで設定した?を持って?す?そ?個?の値を?設定することで?
040     * カラ?ブジェクト?属?をその都度設定しなおすことができます?
041     * ?よく使用するのは、must 属?の設定と、DBMENU エ?ターの設定です?
042     * must属?は、予め???として?することが?来な?、画面毎に再設定が
043     * ?です?ただし?ここでのmust属?は、カラ??表示色を変更する?で?
044     * 実際のnullチェ?は、columnCheck タグのnullCheck属?で?します?
045     * DBMENU エ?ターは、データベ?スの属?から選択リストを作?する機?ですが?
046     * これも?マスタ登録時?、テキストフィールドで入力し、使用時??択するケース
047     * の様に、画面毎に異なる形式で使用した??合があるためです?
048     * こ?タグでは、カラ?ブジェクト?属?以外に、HTMLの属?を付加する事も
049     * できます?
050     *
051     * @og.formSample
052     * ●形式?lt;og:ColumnEditor column="???" ??? > ??? </og:ColumnEditor >
053     * ●body?あ?EVAL_BODY_BUFFERED:BODYを評価し?{@XXXX} を解析しま?
054     *
055     * ●Tag定義??
056     *   <og:columnEditor
057     *       column             【TAG】カラ?をセ?しま?
058     *       columns            【TAG】カラ?をカンマ区?で?セ?しま?
059     *       label              【TAG】ラベルリソースに定義されたラベル??をセ?しま?
060     *       className          【TAG】カラ??クラス?VARCHAR2,NUMBER など)をセ?しま?
061     *       size               【TAG】カラ??表示サイズをセ?しま?大きさ?で入力文字制限ではありません)
062     *       maxlength          【TAG】カラ??入力文字制限数をセ?しま?
063     *       writable           【TAG】カラ?書き込み可能かど?[true/false]をセ?しま?初期値:null)
064     *       renderer           【TAG】カラ??表示用レン?ー({@og.doc03Link renderer Renderer_****})をセ?しま?
065     *       editor             【TAG】カラ??編?エ?ター({@og.doc03Link editor Editor_****})をセ?しま?
066     *       dbType             【TAG】D?タイ?{@og.doc03Link dbType DBType_****})をセ?しま?
067     *       codeName           【TAG】コードセレクト?ユニ?クキー(コード名称)をセ?しま?
068     *       codeList           【TAG】コードセレクト?サブセ?となるコードをCSV形式で?しま?
069     *       codeGroup          【TAG】コードセレクト?サブセ?となるグループを?しま?
070     *       defaultVal         【TAG】?期?をセ?しま?
071     *       param              【TAG】パラメータをセ?しま?
072     *       roles              【TAG】ロールをセ?しま?
073     *       must               【TAG】??入力を表す色に変えるかど?[true/false]を指定しま?初期値:false)
074     *       mustAny            【TAG】選択??入?どれかひとつ??)を表す色[true/mustAny/そ?他]を指定しま?初期値:無??
075     *       optionAttributes   【TAG】JavaScript などの HTML基本タグ以外?属?を?そ?ままタグとして使用しま?
076     *       addNoValue         【TAG】コンボ??スの値なし?Optionの有無[true/false]を指定しま?初期値:falseと同?
077     *       useLabelMap        【TAG】SQL??してラベル??を動?読み込?ど?[true/false]?しま?初期値:false)
078     *       useSLabel          【TAG】MENU,DBMENUでSLABELを利用するかど?[auto/true/false]を指定しま?初期値:null)
079     *       noDisplayVal       【TAG】指定?値を非表示にしま?レン?ーのみ有効)(初期値:null)
080     *       scope              【TAG】キャ?ュする場合?スコープ[request/page/session/applicaton]を指定しま?初期値:session)
081     *       tableId            【TAG?通常使?せん)sessionから?す?DBTableModelオブジェクト? ID
082     *       dbid               【TAG?通常使?せん)??タベ?スへ接続する?合?ID
083     *       caseKey            【TAG】このタグ自体を利用するかど?の条件キーを指定しま?初期値:null)
084     *       caseVal            【TAG】このタグ自体を利用するかど?の条件値を指定しま?初期値:null)
085     *       caseNN             【TAG】指定?値が?null/ゼロ?? でな???Not Null=NN)は、このタグは使用されま?初期値:true)
086     *       caseNull           【TAG】指定?値が?null/ゼロ?? の場合?、このタグは使用されま?初期値:true)
087     *       lang               【HTML】要???と他?属?値の??lang,xml:lang)を指定しま?
088     *       style              【HTML】この要?対して適用させるスタイルシー?style)を設定しま?
089     *       clazz              【HTML】要?対して class 属?を設定しま?
090     *       onClick            【HTML】JavaScriptのイベン?onClick を設定しま??onClick="renew('query.jsp','QUERY');")
091     *       onChange           【HTML】JavaScriptのイベン?onChange を設定しま??onChange="renew('query.jsp','QUERY');")
092     *       onBlur             【HTML】JavaScriptのイベン?onBlur を設定しま??onBlur="this.value=value.toUpperCase();")
093     *       onFocus            【HTML】JavaScriptのイベン?onFocus を設定しま?
094     *       ondblClick         【HTML】JavaScriptのイベン?ondblClick を設定しま?
095     *       onMouseDown        【HTML】JavaScriptのイベン?onMouseDown を設定しま?
096     *       onMouseUp          【HTML】JavaScriptのイベン?onMouseUp を設定しま?
097     *       onMouseMove        【HTML】JavaScriptのイベン?onMouseMove を設定しま?
098     *       onMouseOut         【HTML】JavaScriptのイベン?onMouseOut を設定しま?
099     *       onMouseOver        【HTML】JavaScriptのイベン?onMouseOver を設定しま?
100     *       onSelect           【HTML】JavaScriptのイベン?onSelect を設定しま?
101     *       onKeydown          【HTML】JavaScriptのイベン?onKeydown を設定しま?
102     *       onKeypress         【HTML】JavaScriptのイベン?onKeypress を設定しま?
103     *       onKeyup            【HTML】JavaScriptのイベン?onKeyup を設定しま?
104     *       autocomplete       【HTML5】?力?補を提示して入力?容を?動補完する[on/off]??期?はon??
105     *       autofocus          【HTML5】指定した?力?カーソルが当たって自動的にフォーカスされます?
106     *       pattern            【HTML5】正規表現で入力?のパターンを指定します?
107     *       placeholder        【HTML5】?力?初期表示する?を指定します?
108     *       required           【HTML5】?力??を指定しま?
109     *       list               【HTML5】ユーザーに入力?補として提案するデータリスト?要??id属?の値を指定します?
110     *       min                【HTML5】?力?入力できる??を指定します?
111     *       max                【HTML5】?力?入力できる?値を指定します?
112     *       step               【HTML5】?力?刻??プ?を指定する?
113     *       type               【HTML5】HTML5追??[text/search/tel/url/email/datetime/date/month/week/time/datetime-local/number/range/color]
114     *       eventColumn        【TAG】イベントカラ?親カラ?のセ?
115     *       eventURL           【TAG】eventColumn利用時に呼ばれるJSPのURL
116     *       eventCallback      【TAG】eventColumn実行後?callbak関数??
117     *       noResource         【TAG】ResourceManager を使用しな?ど?[true/false]を指定しま?初期値:false)
118     *       stringOutput       【TAG】レン?利用のExcel出力時にセルタイプを??にするかど?(初期値:true)
119     *       debug              【TAG】デバッグ??を?力するかど?[true/false]を指定しま?初期値:false)
120     *   >   ... Body ...
121     *   </og:columnEditor>
122     *
123     * ●使用例?
124     *     ・??表示の場?
125     *         <og:columnEditor column="NOSYN" must="true" />
126     *
127     *     ・DBからのコンボ??スの場?
128     *         <og:columnEditor column="CDBK" editor="DBMENU">
129     *                 select CDBK,CDBK||':'||NMBK from DB02 order by 1
130     *         </og:columnEditor>
131     *
132     *     ・親子関係?プル?ンを作る場?
133     *       ({@xxx.value}で同じ行?xxxカラ?選択した?を取得しま?
134     *         <og:columnEditor column="CDBK" editor="DBMENU"
135     *              eventColumn="OYA">
136     *                 select CDBK,CDBK||':'||NMBK from DB02
137     *                   where CLM = {@OYA.value} order by 1
138     *         </og:columnEditor>
139     *
140     *
141     * @og.rev 3.5.1.0 (2003/10/03) 親クラスをCommonTagSupportからHTMLTagSupportに変更?
142     * @og.group 画面表示
143     *
144     * @version  4.0
145     * @author       Kazuhiko Hasegawa
146     * @since    JDK5.0,
147     */
148    public class ColumnEditorTag extends HTMLTagSupport {
149            //* こ?プログラ??VERSION??を設定します?       {@value} */
150            private static final String VERSION = "5.7.6.3 (2014/05/23)" ;
151    
152            private static final long serialVersionUID = 576320140523L ;
153    
154            // 5.7.1.0 (2013/12/06) HTML5 で新たに追?れた、type を追?
155            private static final String CHECK_TYPE = "|text|search|tel|url|email|datetime|date|month|week|time|datetime-local|number|range|color|" ;
156    
157            private transient LabelData     labelData               = null;
158            private String          tableId                 = HybsSystem.TBL_MDL_KEY;
159            private String[]        columns                 = null;         // 3.7.0.5 (2005/04/11)
160            private boolean         allColumns              = false;        // 3.8.8.5 (2007/03/09)
161            private String          className               = null;
162            private String          size                    = null;
163            private String          maxlength               = null;         // 3.5.5.5 (2004/04/23)
164            private String          writable                = null;
165            private String          renderer                = null;
166            private String          editor                  = null;
167            private String          dbType                  = null;
168            private String          codeName                = null;         // 3.5.5.7 (2004/05/10)
169            private String          codeList                = null;         // 5.1.9.0 (2010/08/01) 新規追?Codeリソースのサブセ?)
170            private String          codeGroup               = null;         // 5.1.9.0 (2010/08/01) 新規追?Codeリソースのサブセ?)
171            private String          defaultVal              = null;
172            private String          parameter               = null;
173            private String          dbid                    = null;
174            private String          addNoValue              = null;         // 3.5.5.9 (2004/06/07)
175            private static final String DEFAULT_ADD_NO_VALUE        = "true"; // 3.7.0.5 (2005/04/11)
176    
177            private String  eventColumn             = null; // 4.3.6.0 (2009/04/01) イベントカラ?
178            private String  rawParameter    = null; // 4.3.6.0 (2009/04/01) 生パラメータ
179            private String  eventURL                = null; // 4.3.6.0 (2009/04/01) イベン?RL
180    
181            // 4.3.4.0 (2008/12/01) ラベル??タの動的取得に対応します?
182            private boolean         useLabelMap             = false;                // 4.3.4.0 (2008/12/01)
183            private String          useSLabel               = null;                 // 5.6.2.3 (2013/03/22) MENU,DBMENUでSLABELを利用するかど?
184            private String          noDisplayVal    = null;                 // 5.6.2.3 (2013/03/22) 非表示??設?
185            private Map<String,LabelData>             labelMap                = null;
186    
187            // 5.7.3.0 (2014/02/07) ResourceManager を使用しな?ど?[true/false]を指?
188            private boolean         noResource              = false;
189    
190            private boolean         stringOutput    = HybsSystem.sysBool( "USE_STRING_EXCEL_OUTPUT" );              // 5.7.6.3 (2014/05/23)
191    
192            /**
193             * Taglibの開始タグが見つかったときに処??doStartTag() ?オーバ?ライドします?
194             *
195             * @og.rev 3.1.0.0 (2003/03/20) DBColumnConfig#getColumnConfig() メソ??
196             * @og.rev 3.1.1.0 (2003/03/28) ボディの?を取得する??、CommonTagSupport で行う?
197             * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応?ボディが存在する場合?みボディが呼ばれる対応?
198             * @og.rev 3.5.1.0 (2003/10/03) 親クラスをCommonTagSupportからHTMLTagSupportに変更?
199             * @og.rev 3.5.5.5 (2004/04/23) 入力??大きさを指定す?viewSize 属?を追??
200             * @og.rev 3.5.5.7 (2004/05/10) CodeSelection を?codeName を?に構築できるように設定します?
201             * @og.rev 3.5.5.9 (2004/06/07) addNoValue が?設定された場合?み、config に設定しま?
202             * @og.rev 3.7.0.5 (2005/04/11) ?カラ?同時設定できる columns 属?を追?
203             * @og.rev 5.2.2.0 (2010/11/01) caseKey 、caseVal 属?対?
204             *
205             * @return      後続????( EVAL_BODY_BUFFERED )
206             */
207            @Override
208            public int doStartTag() {
209                    // 5.2.2.0 (2010/11/01) caseKey 、caseVal 属?対?
210                    if( useTag() ) {
211                            if( "DBMENU".equalsIgnoreCase(editor) ) {
212                                    className = "VARCHAR2";
213                                    renderer  = "DBMENU";
214                                    editor    = "DBMENU";
215    
216                                    if( addNoValue == null ) {
217                                            addNoValue = DEFAULT_ADD_NO_VALUE ;
218                                    }
219                            }
220    
221                            return EVAL_BODY_BUFFERED ;
222                    }
223                    return SKIP_BODY ;                              // Body を評価しな?
224            }
225    
226            /**
227             * Taglibのタグ本体を処??doAfterBody() ?オーバ?ライドします?
228             *
229             * @og.rev 2.3.1.3 (2003/02/08) ラベル、サイズのみでも変更できるように修正
230             * @og.rev 3.0.0.1 (2003/02/14) DBMENU作?時に、ラベルの??スペ?スを除去する?
231             * @og.rev 3.1.0.0 (2003/03/20) DBColumnConfig#getColumnConfig() メソ??
232             * @og.rev 3.1.1.0 (2003/03/28) ボディの?を取得する??、CommonTagSupport で行う?
233             * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応?ボディが存在する場合?みボディが呼ばれる対応?
234             * @og.rev 3.5.0.0 (2003/09/17) キー、ラベルともに?"(?ルコー??ション)で囲??変更?
235             * @og.rev 3.5.5.7 (2004/05/10) こ?タグでSQLを発行する?ではなく?DBMENU の DBColumnを作?する?
236             * @og.rev 3.5.5.9 (2004/06/07) addNoValue ?null の場合?、?期?を設定します?
237             * @og.rev 3.7.0.5 (2005/04/11) ?カラ?同時設定できる columns 属?を追?
238             * @og.rev 3.8.6.3 (2006/11/30) SQL ??前後?スペ?スを取り除きます?
239             * @og.rev 4.3.4.0 (2008/12/01) ラベル??タの動的取得に対応します?
240             * @og.rev 4.3.6.0 (2009/04/01) イベントカラ??
241             * @og.rev 5.1.7.0 (2010/06/01) 動的プル?ン実?直?
242             * @og.rev 5.5.4.0 (2012/07/02) 予?対?
243             *
244             * @return      後続????(SKIP_BODY)
245             */
246            @Override
247            public int doAfterBody() {
248                    String sql = getBodyString();
249                    if( sql != null && sql.length() > 0 ) {
250                            if( useLabelMap )       { labelMap = getResource().getLabelMap( sql.trim() ); } // 4.3.4.0 (2008/12/01)
251                            else                            {
252                                    if( eventColumn != null && eventColumn.length() >0 ){  // 4.3.6.0 (2009/04/01)
253                                            rawParameter = getReservedParameter(getBodyRawString().trim()); // 5.5.4.0 (2012/07/01)
254                                    }
255                                    parameter = sql.trim() ;
256                            }
257                    }
258    
259                    return SKIP_BODY ;
260            }
261    
262            /**
263             * Taglibの終?グが見つかったときに処??doEndTag() ?オーバ?ライドします?
264             *
265             * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応?release2() ?doEndTag()で呼ぶ?
266             * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応?ボディが存在する場合?みボディが呼ばれる対応?
267             * @og.rev 3.7.0.5 (2005/04/11) ?カラ?同時設定できる columns 属?を追?
268             * @og.rev 3.8.8.5 (2007/03/09) 全カラ?が指定されたことにする allColumns 属?を追?
269             * @og.rev 4.1.2.1 (2008/03/13) must , mustAny 属?を?動化します?
270             * @og.rev 4.3.4.0 (2008/12/01) カラ?定?ワイルドカード対?
271             * @og.rev 5.2.1.0 (2010/10/01) must , mustAny 属?の処?、HTMLTagSupport に移します?
272             * @og.rev 5.2.2.0 (2010/11/01) caseKey 、caseVal 属?対?
273             *
274             * @return      後続????
275             */
276            @Override
277            public int doEndTag() {
278                    debugPrint();           // 4.0.0 (2005/02/28)
279                    // 5.2.2.0 (2010/11/01) caseKey 、caseVal 属?対?
280                    if( !useTag() ) { return EVAL_PAGE; }
281    
282                    DBTableModel table = (DBTableModel)getObject( tableId );
283                    if( table == null ) { return EVAL_PAGE; }
284    
285                    if( columns != null ) {
286                            // 3.8.8.5 (2007/03/09) 全カラ?が指?
287                            String mustType = getMustType();        // 5.2.1.0 (2010/10/01)
288                            if( allColumns ) {
289                                    int len = table.getColumnCount();
290                                    for( int i=0; i<len; i++ ) {
291    
292                                            // 4.3.4.0 (2008/12/01)
293                                            DBColumn dbColumn = table.getDBColumn( i );
294                                            for( int j=0; j<columns.length; j++ ) {
295                                                    String prefix = columns[j].replace( "*", "" );
296                                                    if( dbColumn.getName().indexOf( prefix ) == 0 ) { // 前方??のみ対?
297                                                            DBColumnConfig config = getModifyConfig( dbColumn );
298                                                            table.setDBColumn( i,new DBColumn( config ) );
299    
300                                                            // 4.1.2.1 (2008/03/13)
301                                                            if( mustType != null ) {
302                                                                    table.addMustType( i,mustType );
303                                                            }
304                                                            break;
305                                                    }
306                                            }
307                                    }
308                            }
309                            else {
310                                    for( int i=0; i<columns.length; i++ ) {
311                                            int clmNo = table.getColumnNo( columns[i] );
312                                            DBColumn dbColumn = table.getDBColumn( clmNo );
313                                            DBColumnConfig config = getModifyConfig( dbColumn );
314                                            table.setDBColumn( clmNo,new DBColumn( config ) );
315    
316                                            // 4.1.2.1 (2008/03/13)
317                                            if( mustType != null ) {
318                                                    table.addMustType( clmNo,mustType );
319                                            }
320                                    }
321                            }
322                    }
323    
324                    return EVAL_PAGE ;
325            }
326    
327            /**
328             * 検索条件の入力用の?ストフィールドを作?します?
329             *
330             * ??ブルタグによりフィールド??されます?
331             * 使用時?、テーブルタグを前後に使用して下さ??
332             * こ?クラスでは、このメソ?は、使われておりません?
333             *
334             * @og.rev 3.5.1.0 (2003/10/03) 新規追?
335             *
336             * @return  入力用の?ストフィールドタグ
337             */
338            @Override
339            protected String makeTag() {
340                    return null;
341            }
342    
343            /**
344             * タグリブオブジェクトをリリースします?
345             *
346             * キャ?ュされて再利用される?で、フィールド?初期設定を行います?
347             *
348             * @og.rev 2.0.0.4 (2002/09/27) カスタ?グの release() メソ?を?追?
349             * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応?release2() ?doEndTag()で呼ぶ?
350             * @og.rev 3.5.1.0 (2003/10/03) 親クラスをCommonTagSupportからHTMLTagSupportに変更?
351             * @og.rev 3.5.5.5 (2004/04/23) 入力??大きさを指定す?viewSize 属?を追??
352             * @og.rev 3.5.5.7 (2004/05/10) codeName 属?を追??
353             * @og.rev 3.5.5.9 (2004/06/07) addNoValue 属?を修正?
354             * @og.rev 3.7.0.5 (2005/04/11) ?カラ?同時設定できる columns 属?を追?
355             * @og.rev 3.8.8.5 (2007/03/09) 全カラ?が指定されたことにする allColumns 属?を追?
356             * @og.rev 4.1.2.1 (2008/03/13) must , mustAny 属?を?動化します?
357             * @og.rev 4.3.4.0 (2008/12/01) ラベル??タの動的取得に対応します?
358             * @og.rev 5.1.9.0 (2010/08/01) codeList , codeGroup 属?を追??(Codeリソースのサブセ?)
359             * @og.rev 5.2.1.0 (2010/10/01) must , mustAny 属?の処?、HTMLTagSupport に移します?
360             * @og.rev 5.6.2.3 (2013/03/22) useSLabel 属?を追??(MENU,DBMENUでSLABELを利用するかど?)
361             * @og.rev 5.6.2.3 (2013/03/22) 非表示??設定?noDisplayVal 属?を追??
362             * @og.rev 5.7.3.0 (2014/02/07) noResource 属?を追??ResourceManager を使用しな?ど?
363             * @og.rev 5.7.6.3 (2014/05/23) stringOutput追?
364             */
365            @Override
366            protected void release2() {
367                    super.release2();
368                    tableId                 = HybsSystem.TBL_MDL_KEY;
369                    columns                 = null;         // 3.7.0.5 (2005/04/11)
370                    allColumns              = false;        // 3.8.8.5 (2007/03/09)
371                    labelData               = null;         // 4.0.0 (2005/01/31)
372                    className               = null;
373                    size                    = null;
374                    maxlength               = null;         // 3.5.5.5 (2004/04/23)
375                    writable                = null;
376                    renderer                = null;
377                    editor                  = null;
378                    dbType                  = null;
379                    codeName                = null;         // 3.5.5.7 (2004/05/10)
380                    codeList                = null;         // 5.1.9.0 (2010/08/01) 新規追?Codeリソースのサブセ?)
381                    codeGroup               = null;         // 5.1.9.0 (2010/08/01) 新規追?Codeリソースのサブセ?)
382                    defaultVal              = null;
383                    parameter               = null;
384                    dbid                    = null;
385                    addNoValue              = null;         // 3.5.5.9 (2004/06/07)
386                    useLabelMap             = false;        // 4.3.4.0 (2008/12/01)
387                    useSLabel               = null;         // 5.6.2.3 (2013/03/22) MENU,DBMENUでSLABELを利用するかど?
388                    noDisplayVal    = null;         // 5.6.2.3 (2013/03/22) 非表示??設?
389                    labelMap                = null;         // 4.3.4.0 (2008/12/01)
390                    eventColumn             = null;         // 4.3.6.0 (2009/04/01)
391                    rawParameter    = null;         // 4.3.6.0 (2009/04/01)
392                    eventURL                = null;         // 4.3.6.0 (2009/04/01)
393                    noResource              = false;        // 5.7.3.0 (2014/02/07) noResource 属?を追??
394                    stringOutput    = HybsSystem.sysBool( "USE_STRING_EXCEL_OUTPUT" );              // 5.7.6.3 (2014/05/23)
395            }
396    
397            /**
398             * カスタマイズされ?DBColumnConfig を作?します?
399             *
400             * DBColumnConfig は、DBColumn より取得します?こ? DBColumnConfig に?
401             * 属?で?された値をセ?することで、カスタマイズを行います?
402             *
403             * @og.rev 3.7.0.5 (2005/04/11) 新規追?
404             * @og.rev 4.1.2.1 (2008/03/13) must , mustAny 属?を?動化します?
405             * @og.rev 4.3.4.0 (2008/12/01) ラベル??タの動的取得に対応します?
406             * @og.rev 4.3.6.0 (2009/04/01) evnetColumn対?
407             * @og.rev 5.1.8.0 (2010/07/01) メソ?名変更(setDefValue ?setDefault)
408             * @og.rev 5.1.9.0 (2010/08/01) codeList ,codeGroup 属?を追?Codeリソースのサブセ?)
409             * @og.rev 5.6.2.3 (2013/03/22) useSLabel 属?を追??(MENU,DBMENUでSLABELを利用するかど?)
410             * @og.rev 5.6.2.3 (2013/03/22) 非表示??設定?noDisplayVal 属?を追??
411             * @og.rev 5.7.3.0 (2014/02/07) noResource 属?を追??ResourceManager を使用しな?ど?
412             * @og.rev 5.7.6.2 (2014/05/16) IEのHTML5機?が無効の場合?処?
413             * @og.rev 5.7.6.3 (2014/05/23) stringOutput追?
414             *
415             * @param       dbColumn        カラ?ブジェク?
416             *
417             * @return  カスタマイズされ?DBColumnConfig
418             */
419            private DBColumnConfig getModifyConfig( final DBColumn dbColumn ) {
420                    // 5.7.3.0 (2014/02/07) noResource 属?を追?
421                    if( noResource ) {
422                            labelData = new LabelData( dbColumn.getName() );
423                            renderer  = "LABEL";
424                    }
425    
426                    DBColumnConfig config = dbColumn.getConfig();
427    
428                    // 5.7.6.2 (2014/05/16) IEのHTML5機?が無効の場合?処?
429                    String ieHTML5 = (String)getSessionAttribute( HybsSystem.IE_HTML5_KEY );
430                    if( "FALSE".equalsIgnoreCase( ieHTML5 ) ) {
431                            if( "DATALIST".equalsIgnoreCase( editor ) ||
432                                    "DATALIST".equalsIgnoreCase( config.getEditor() ) ) {
433                                            editor = "INDBMENU";
434                            }
435                    }
436    
437                    String lang = get( "lang" );    // 4.0.0 (2005/01/31) super クラスで受けます?
438    
439                    if( lang                != null ) { config.setLang(              lang           ); }
440                    if( labelData   != null ) { config.setLabelData( labelData      ); }    // 4.0.0 (2005/01/31)
441                    if( className   != null ) { config.setClassName( className      ); }
442                    if( size                != null ) { config.setViewLength(size           ); }
443                    if( maxlength   != null ) { config.setMaxlength( maxlength      ); }    // 3.5.5.5 (2004/04/23)
444                    if( writable    != null ) { config.setWritable(  writable       ); }
445                    if( renderer    != null ) { config.setRenderer(  renderer       ); }
446                    if( editor              != null ) { config.setEditor(    editor         ); }
447                    if( dbType              != null ) { config.setDbType(    dbType         ); }
448                    if( defaultVal  != null ) { config.setDefault(   defaultVal     ); }    // 5.1.8.0 (2010/07/01)
449                    if( parameter   != null ) { config.setParameter( parameter      ); }
450                    if( dbid                != null ) { config.setDbid(              dbid           ); }
451                    if( eventColumn != null ) { config.setEventColumn(eventColumn); }       // 4.3.6.0 (2009/04/01)
452                    if( eventURL    != null ) { config.setEventURL(   eventURL       );     }       // 4.3.6.0 (2009/04/01)
453                    if( rawParameter != null ){ config.setRawParameter( rawParameter ); }   // 4.3.6.0 (2009/04/01)
454                    if( useSLabel   != null ) { config.setUseSLabel(  useSLabel  ); }               // 5.6.2.3 (2013/03/22)
455                    if( noDisplayVal != null ) { config.setNoDisplayVal( noDisplayVal ); }  // 5.6.2.3 (2013/03/22)
456    
457                    // 4.0.0 (2005/11/30) ロールを指?
458                    String roles = get( "roles" );
459                    if( roles               != null ) { config.setRoles(     roles      ); }
460    
461                    // 4.0.0 (2005/01/31)
462                    if( codeName   != null ) {
463                            CodeData codeData = getResource().getCodeData( codeName ) ;
464                            config.setCodeData( codeData );
465                    }
466    
467                    // codeName で??リソースでも?サブセ?が作?できます?
468                    // 5.1.9.0 (2010/08/01) codeList 属?を追?Codeリソースのサブセ?)
469                    if( codeList  != null ) {
470                            CodeData codeData = config.getCodeData() ;
471                            if( codeData != null ) {
472                                    config.setCodeData( codeData.subsetList( codeList ) );
473                            }
474                    }
475    
476                    // 5.1.9.0 (2010/08/01) codeGroup 属?を追?Codeリソースのサブセ?)
477                    if( codeGroup != null ) {
478                            CodeData codeData = config.getCodeData() ;
479                            if( codeData != null && codeData.useGroup() ) {
480                                    config.setCodeData( codeData.subsetGroup( codeGroup ) );
481                            }
482                    }
483    
484                    // 3.5.5.9 (2004/06/07)
485                    // 注意:addNoValue は、互換性の関係で、?が指定された場合?み?
486                    // config に設定します?
487                    // editor="DBMENU" が??された場合?、addNoValue が指定されて???合?み?
488                    // 従来との互換性の関係より?こ?クラスの?ォル?true)を?config に設定します?
489                    if( addNoValue != null ) {
490                            boolean anv = Boolean.valueOf( addNoValue ).booleanValue() ;
491                            config.setAddNoValue( anv );
492                    }
493    
494                    // 3.5.1.0 (2003/10/03) 親クラスをCommonTagSupportからHTMLTagSupportに変更?
495                    config.setEditorAttributes( getAttributes() );
496    
497                    // 4.3.4.0 (2008/12/01) ラベル??タの動的取得に対応します?
498                    if( useLabelMap && labelMap != null ) {
499                            LabelData ldata = labelMap.get( dbColumn.getName() );
500                            if( ldata != null ) {
501                                    config.setLabelData( ldata      );
502                            }
503                    }
504    
505                    // 5.7.6.3 (2014/05/23)
506                    config.setStringOutput( stringOutput );
507    
508                    return config ;
509            }
510    
511            /**
512             * 【TAG】カラ?をセ?します?
513             *
514             * @og.tag
515             * カラ?をセ?します?
516             * columns と同時にはセ?できません?
517             * 値に"*"を指定することで、?カラ?対象とすることができます?
518             * また?"PN*,CDK*"等?ように前方??でのワイルドカード指定も可能です?
519             *
520             * @og.rev 3.7.0.5 (2005/04/11) ?カラ?同時設定できる columns 属?を追?
521             * @og.rev 3.8.8.5 (2007/03/09) 全カラ?が指定されたことにする allColumns 属?を追?
522             *
523             * @param       clm ネ??
524             */
525            public void setColumn( final String clm ) {
526                    if( columns != null ) {
527                            String errMsg = "columns との同時セ?は出来ません? " + HybsSystem.CR
528                                                    + "column=[" + clm + "] , "
529                                                    + "columns=[" + StringUtil.array2csv( columns ) + "]";
530                            throw new HybsSystemException( errMsg );
531                    }
532                    String column = getRequestParameter( clm );
533                    if( column != null && column.length() > 0 ) {
534                            columns = new String[] { column };
535                            allColumns = column.indexOf( '*' ) >= 0 ;    // 3.8.8.5 (2007/03/09)
536                    }
537            }
538    
539            /**
540             * 【TAG】カラ?をカンマ区?で?セ?します?
541             *
542             * @og.tag
543             * カラ?をセ?します?
544             * column と同時にはセ?できません?
545             * ?方法???常のパラメータ取得後に、CSV?します?
546             * 値に"*"を指定することで、?カラ?対象とすることができます?
547             * また?"PN*,CDK*"等?ように前方??でのワイルドカード指定も可能です?
548             *
549             * @og.rev 3.7.0.5 (2005/04/11) ?カラ?同時設定できる columns 属?を追?
550             * @og.rev 3.8.8.5 (2007/03/09) 通常のパラメータ取得後に、CSV?に戻します?
551             * @og.rev 3.8.8.5 (2007/03/09) 全カラ?が指定されたことにする allColumns 属?を追?
552             *
553             * @param       clms CSV形式?カラ?
554             */
555            public void setColumns( final String clms ) {
556                    if( columns != null ) {
557                            String errMsg = "column との同時セ?は出来ません? " + HybsSystem.CR
558                                                    + "column=[" + StringUtil.array2csv( columns ) + "] , "
559                                                    + "columns=[" + clms + "]" ;
560                            throw new HybsSystemException( errMsg );
561                    }
562                    String column = nval( getRequestParameter( clms ),null );
563                    if( column != null ) {
564                            allColumns = column.indexOf( '*' ) >= 0 ;            // 3.8.8.5 (2007/03/09)
565                            columns = StringUtil.csv2Array( column );
566                            if( columns.length == 0 ) { columns = null; }
567                    }
568            }
569    
570            /**
571             * 【TAG】ラベルリソースに定義されたラベル??をセ?します?
572             *
573             * @og.tag
574             * ラベルをセ?します?
575             *
576             * @og.rev 2.3.1.2 (2003/01/28) ラベルリソースからラベル名を取得するよ?修正
577             * @og.rev 4.0.0.0 (2005/01/31) キーより、ラベル??タオブジェクトを取得します?
578             *
579             * @param       lbl ラベル
580             */
581            public void setLabel( final String lbl ) {
582                    labelData = getResource().getLabelData( getRequestParameter( lbl ) ) ;  // 4.0.0 (2005/01/31)
583            }
584    
585            /**
586             * 【TAG】カラ??クラス?VARCHAR2,NUMBER など)をセ?します?
587             *
588             * @og.tag
589             * カラ??クラス名をセ?します?
590             *
591             * @param       cls カラ??クラス
592             */
593            public void setClassName ( final String cls ) {
594                    className = nval( getRequestParameter( cls ),className );
595            }
596    
597            /**
598             * 【TAG】カラ??入力文字制限数をセ?します?
599             *
600             * @og.tag
601             * カラ??入力文字制限数をセ?します?
602             *
603             * @param       len カラ??入力文字制限数
604             */
605            public void setMaxlength( final String len ) {
606                    maxlength = nval( getRequestParameter( len ),maxlength );
607            }
608    
609            /**
610             * 【TAG】カラ??表示サイズをセ?しま?大きさ?で入力文字制限ではありません)?
611             *
612             * @og.tag
613             * カラ??サイズをセ?します?
614             *
615             * @og.rev 3.5.5.5 (2004/04/23) 入力??大きさを指定す?viewSize 属?を追??
616             *
617             * @param       siz カラ??サイズ
618             */
619            public void setSize( final String siz ) {
620                    size = nval( getRequestParameter( siz ),size );
621            }
622    
623            /**
624             * 【TAG】カラ?書き込み可能かど?[true/false]をセ?しま?初期値:null)?
625             *
626             * @og.tag
627             * カラ??書き込み可能をセ?します?
628             *
629             * @param       flag カラ??書き込み可能かど?(true:可能/false:付加)
630             */
631            public void setWritable ( final String flag ) {
632                    writable = nval( getRequestParameter( flag ),writable );
633            }
634    
635            /**
636             * 【TAG】カラ??表示用レン?ー({@og.doc03Link renderer Renderer_****})をセ?します?
637             *
638             * @og.tag
639             * これは、plugin.column 以下? Renderer_**** クラスの **** を与えます?
640             * これら?、CellRenderer インターフェースを継承したサブクラスです?
641             * 属?クラス定義の {@link org.opengion.hayabusa.db.CellRenderer Renderer} を参照願います?
642             * {@og.doc03Link renderer Renderer_**** クラス}
643             *
644             * @param       rdr カラ??表示用レン?ー(Renderer_**** の ****)
645             * @see         org.opengion.hayabusa.db.CellRenderer
646             */
647            public void setRenderer ( final String rdr ) {
648                    renderer = nval( getRequestParameter( rdr ),renderer );
649            }
650    
651            /**
652             * 【TAG】カラ??編?エ?ター({@og.doc03Link editor Editor_****})をセ?します?
653             *
654             * @og.tag
655             * これは、plugin.column 以下? Editor_**** クラスの **** ?
656             * 与えます?これら?、CellEditor インターフェースを継承したサブクラスです?
657             * 属?クラス定義の {@link org.opengion.hayabusa.db.CellEditor Editor} を参照願います?
658             * {@og.doc03Link editor Editor_**** クラス}
659             *
660             * @param       ed カラ??編?エ?ター(Editor_**** の ****)
661             * @see         org.opengion.hayabusa.db.CellEditor
662             */
663            public void setEditor ( final String ed ) {
664                    editor = nval( getRequestParameter( ed ),editor );
665            }
666    
667            /**
668             * 【TAG】D?タイ?{@og.doc03Link dbType DBType_****})をセ?します?
669             *
670             * @og.tag
671             * これは、org.opengion.hayabusa.db.column 以下? DBType_**** クラスの **** ?
672             * 与えます?これら?、DBType インターフェースを継承したサブクラスです?
673             * 属?クラス定義の {@link org.opengion.hayabusa.db.DBType DBType} を参照願います?
674             * {@og.doc03Link dbType DBType_**** クラス}
675             *
676             * @param       dt パラメータ
677             * @see         org.opengion.hayabusa.db.DBType  DBType_**** の ****
678             */
679            public void setDbType( final String dt ) {
680                    dbType = nval( getRequestParameter( dt ),dbType );
681            }
682    
683            /**
684             * 【TAG】コードセレクト?ユニ?クキー(コード名称)をセ?します?
685             *
686             * @og.tag
687             * こ?キーを?に、CodeSelectionオブジェクトを構築します?
688             *
689             * @og.rev 3.5.5.7 (2004/05/10)  新規作?
690             *
691             * @param       name    メニューのユニ?クキー(コード名称)
692             */
693            public void setCodeName( final String name ) {
694                    codeName = nval( getRequestParameter( name ),codeName );
695            }
696    
697            /**
698             * 【TAG】コードセレクト?サブセ?となるコードをCSV形式で?します?
699             *
700             * @og.tag
701             * こ?値に限定された、コードリソースを?既存?、CodeSelection の
702             * サブセ?として作?します?
703             * codeName で?されたリソースでも?サブセ?を作?する事ができます?
704             *
705             * @og.rev 5.1.9.0 (2010/08/01)  新規作?
706             *
707             * @param       list    コードセレクト?サブセ?となるコー?
708             */
709            public void setCodeList( final String list ) {
710                    codeList = nval( getRequestParameter( list ),codeList );
711            }
712    
713            /**
714             * 【TAG】コードセレクト?サブセ?となるグループを?します?
715             *
716             * @og.tag
717             * こ?値に限定された、コードリソースを?既存?、CodeData の
718             * サブセ?として作?します?
719             * codeName で?されたリソースでも?サブセ?を作?する事ができます?
720             *
721             * @og.rev 5.1.9.0 (2010/08/01)  新規作?
722             *
723             * @param       group   コードセレクト?サブセ?となるグルー?
724             */
725            public void setCodeGroup( final String group ) {
726                    codeGroup = nval( getRequestParameter( group ),codeGroup );
727            }
728    
729    //      /**
730    //       * 【?】パラメータをセ?しま?param 属?を使用してください)?
731    //       *
732    //       * @og.tag
733    //       * ここで?したパラメータは、renderer、editor、dbType すべてのパラメータに
734    //       * セ?されます?
735    //       * パラメータをセ?します?
736    //       *
737    //       * @og.rev 5.1.7.0 (2010/06/01) 動的プル?ン実?直?
738    //       * @og.rev 5.6.4.3 (2013/05/24) ?します?param 属?を使用してください?
739    //       *
740    //       * @param       prm パラメータ
741    //       * @see    #setParam( String )
742    //       * @deprecated  lbl 属?を使用してください?
743    //       */
744    //      @Deprecated public void setParameter( final String prm ) {
745    //              setParam( prm );                        // 5.6.4.3 (2013/05/24) ?に伴??新しいメソ?側へ振ります?
746    //      }
747    
748            /**
749             * 【TAG】パラメータをセ?します?
750             *
751             * @og.tag
752             * ここで?したパラメータは、renderer、editor、dbType すべてのパラメータに
753             * セ?されます?
754             * パラメータをセ?します?
755             *
756             * @og.rev 5.6.4.3 (2013/05/24) 新規追?
757             *
758             * @param       prm パラメータ
759             */
760            public void setParam( final String prm ) {
761                    parameter = nval( getRequestParameter( prm ),parameter );
762                    rawParameter = nval( prm, parameter );
763            }
764    
765            /**
766             * 【TAG】?期?をセ?します?
767             *
768             * @og.tag
769             * 初期値をセ?します?
770             *
771             * @param       dv 初期値
772             */
773            public void setDefaultVal( final String dv ) {
774                    defaultVal = nval( getRequestParameter( dv ),defaultVal );
775            }
776    
777            /**
778             * 【TAG】コンボ??スの値なし?Optionの有無[true/false]を指定しま?初期値:falseと同??
779             *
780             * @og.tag
781             * コンボ??スの場合?値なし?OptionをSelectに含めるかど?を指定します?
782             * ここでは、検索結果の登録画面に使用されるケースが多いため、なにも指定されな?
783             * 場合?、なにもセ?しません?Coderesourceの?どおり)
784             * 動作としては、?期?は、含めな?"false") と同等です?
785             *
786             * &lt;og:columnEditor column="CDBK" addNoValue="false" /&gt;
787             *
788             * @param       flag  [true:含める/それ以?含めない]
789             */
790            public void setAddNoValue( final String flag ) {
791                    addNoValue = nval( getRequestParameter( flag ),addNoValue );
792            }
793    
794            /**
795             * 【TAG】SQL??してラベル??を動?読み込?ど?[true/false]?しま?初期値:false)?
796             *
797             * @og.tag
798             * trueを指定すると、body部?記述されたSQL?りラベル??を生成して?
799             * 動的にラベル表示を?り替えます?
800             *
801             * ワイルドカードを使用した、カラ????と?合わせることで、外部から設?
802             * されたラベル??で?で変更することができます?
803             *
804             * 発行するクエリでは、第1カラ?ラベルキーを?第2カラ?ラベル名称を設定します?
805             * 第3カラ?存在する場合?、名称(短)として使用されます?(??ではありません)
806             *
807             * ここで作?されたラベル??は、カラ??ターを適用したDBTableModelのみで
808             * 有効であり、?部?もキャ?ュされません?
809             *
810             * 初期値は、false(動的読込しな?です?
811             *
812             * @og.rev 4.3.4.0 (2008/12/01) 新規作?
813             *
814             * @param       flag 動的読込 [true:する/false:しない]
815             */
816            public void setUseLabelMap( final String flag ) {
817                    useLabelMap = nval( getRequestParameter( flag ),useLabelMap );
818            }
819    
820            /**
821             * 【TAG】MENU,DBMENUでSLABELを利用するかど?[auto/true/false]を指定しま?初期値:null)?
822             *
823             * @og.tag
824             * 通常はセレクトメニューは?とそれ以外で短縮ラベルの利用が?動で?替わります?
825             * 強制?SLABELを利用させたい場合にこ?属?をtrue/falseにセ?して下さ??
826             * auto/true/false以外を?した?合?false扱?します?
827             * ここでの初期値は、?の変更を行わな??ことで、null です?
828             *
829             * @og.rev 5.6.2.3 (2013/03/22) columnタグに実?れて?ので移?
830             *
831             * @param prm [auto:自?true:利用する/false:利用しない]
832             */
833            public void setUseSLabel( final String prm ) {
834                    useSLabel = nval( getRequestParameter( prm ),useSLabel );
835                    if( useSLabel != null &&
836                            !"auto".equalsIgnoreCase( useSLabel ) &&
837                            !"true".equalsIgnoreCase( useSLabel ) &&
838                            !"false".equalsIgnoreCase( useSLabel ) ) {
839                                    String errMsg = "useSLabel は、[auto:自?true:利用する/false:利用しない] から選んでください?
840                                                                    + "useSLabel=[" + prm + "]" + HybsSystem.CR ;
841                                    throw new HybsSystemException( errMsg );
842                    }
843            }
844    
845            /**
846             * 【TAG】非表示??を指定しま?初期値:null)?
847             *
848             * @og.tag
849             * これは、例えば、数字型の場合?? がデフォルトなどの場合?
850             * あえて表示したくな?どのケースに使?す?
851             * そ?ような状況が設定されて???合?、null が返されます?
852             * 初期値は、null です?
853             *
854             * @og.rev 5.6.2.3 (2013/03/22) 新規追?
855             *
856             * @param prm [auto:自?true:利用する/false:利用しない]
857             */
858            public void setNoDisplayVal( final String prm ) {
859                    noDisplayVal = nval( getRequestParameter( prm ),noDisplayVal );
860            }
861    
862            /**
863             * 【TAG?通常は使?せん)結果のDBTableModelを?sessionに登録するとき?キーを指定しま?
864             *              (初期値:HybsSystem#TBL_MDL_KEY[={@og.value org.opengion.hayabusa.common.HybsSystem#TBL_MDL_KEY}])?
865             *
866             * @og.tag
867             * 検索結果より、DBTableModelオブジェクトを作?します?これを?下流?viewタグ等に
868             * 渡す?合に??常は、session を利用します?そ?場合?登録キーです?
869             * query タグを同時に実行して、結果を求める?合?同?モリに配置される為?
870             * こ? tableId 属?を利用して、メモリ空間を?ます?
871             *              (初期値:HybsSystem#TBL_MDL_KEY[={@og.value org.opengion.hayabusa.common.HybsSystem#TBL_MDL_KEY}])?
872             *
873             * @param       id sessionに登録する時? ID
874             */
875            public void setTableId( final String id ) {
876                    tableId   = nval( getRequestParameter( id ),tableId );
877            }
878    
879            /**
880             * 【TAG】データベ?スへ接続する?合?ID?
881             *
882             * @og.tag
883             * ??タベ?ス接続を使用するエ?ター、レン?ーを使用する場合に使用する接続?IDを指定します?
884             * カラ?ブジェクト?、query処?はなく?view処?に適用されるため???タベ?ス
885             * 接続?を指定する?があります?
886             * 初期値は、null(DEFAULT 接? です?
887             *
888             * @og.rev 4.0.0.0 (2006/04/02) 新規追?
889             *
890             * @param       id 接続?ID
891             */
892            public void setDbid( final String id ) {
893                    dbid = nval( getRequestParameter( id ),dbid );
894            }
895    
896            /**
897             * 【TAG】イベントカラ?親カラ?のセ??
898             *
899             * @og.tag
900             * 親子関係を持った?目の動的な入れ替えを行う場合に利用します?
901             * こ?カラ?変化させるトリガとなるカラ??名前をセ?します?
902             *
903             * ※詳細はcolumnTagのeventURL属?の説明をご覧下さ??
904             *
905             * なお?columnEditorで、Viewに対して、SQL??定義(置き換え定義)をする?合でも?
906             * 他カラ??値の参?は、columnタグの場合と同様に、{&#064;XXXX}また?$nの変数により行います?
907             * こ?場合?これら?変数は?自身と同??カラ?を意味します?
908             *
909             * @og.rev 4.3.6.0 (2009/04/01)
910             * @og.rev 5.1.7.0 (2010/06/01) コメント大?正
911             *
912             * @param       col     親カラ?
913             */
914            public void setEventColumn( final String col ) {
915                    eventColumn = nval( getRequestParameter( col ), eventColumn );
916            }
917    
918            /**
919             * 【TAG】eventColumn利用時に呼ばれるJSPのURL?
920             *
921             * @og.tag
922             * イベントカラ?定時に部品を作?するJSPを指定します?
923             * 初期値はシス?リソースのEVENT_COLUMN_URLです?
924             * (例:eventURL="makeColumn_custom.jsp")
925             *
926             * ※詳細はcolumnTagのeventURL属?の説明をご覧下さ??
927             *
928             * @og.rev 4.3.6.0 (2009/04/01)
929             *
930             * @param       url     JSPのURL
931             */
932            public void setEventURL( final String url ) {
933                    eventURL = nval( getRequestParameter( url ), eventURL );
934            }
935    
936            /**
937             * 【TAG】eventColumn実行後?callbak関数??
938             *
939             * @og.tag
940             * eventColumnの動作終?に実行するCallback関数の?を行います?
941             * 関数名?みを指定して下さ??
942             * ?x) sampleCallback()を実行する?合?eventCallback="sampleCallback"
943             * 実行する関数の第?数には自動的に次の要?入った?列が渡されま?
944             * ?0] 変更された子カラ??ID属?値
945             * ?1] evnetColumn実行後?子カラ??値
946             * ?2] eventColumn実行前の子カラ??値
947             *
948             * こ?属?は、optionAttributesへの設定と同様?動作を行います?
949             *
950             * @og.rev 5.5.4.0 (2012/07/02) 新規追?
951             *
952             * @param   callback Callback関数
953             */
954            public void setEventCallback( final String callback ) {
955                    // optionAttributes扱?登録します?
956                    if( callback != null && callback.length() > 0 ){
957                            add( "optionAttributes", "eventCallback='"+getRequestParameter( callback )+"'" );
958                    }
959            }
960    
961            /**
962             * 【HTML5】表示形式を?しま?初期値:text)?
963             *
964             * @og.tag
965             * ColumnTagは、カラ?ソースで作?される為、タイプ?固定です?
966             * しかし?HTML5 で追?れた形式には、有用なタイプも存在する為?
967             * それらへの書き換えをできるようにします?
968             * よって、ここでは、従来型?タイプへの書き換え?できません?
969             * (text?は例外で戻せるようにしま??
970             *
971             * [search/tel/url/email/datetime/date/month/week/time/datetime-local/number/range/color]
972             * が?設定できます?
973             *
974             * HTML5 の機?を有効にするには、ネイ?ブモードで動作させる?があります?
975             *   ?USE_IE7_HEADER = "false" に設定する?
976             *   ② USE_HTML5_HEADER = "true" に設定する?
977             *   ③ IEの??ル⇒互換表示設定で、互換表示に追?たWebサイトから削除する?
978             *   ④ 同上?設定で、イントラサイトを互換表示で表示するのチェ?を外す?
979             * ?があります?
980             *
981             * &lt;og:input type="text"     /&gt; ?スト??スを表示
982             *
983             * HTML5 で追?れたタイ?
984             * &lt;og:input type="search"                       /&gt; 検索?スト?入力?作?する
985             * &lt;og:input type="tel"                          /&gt; 電話番号の入力?作?する
986             * &lt;og:input type="url"                          /&gt; URLの入力?作?する
987             * &lt;og:input type="email"                        /&gt; メールアドレスの入力?作?する
988             * &lt;og:input type="datetime"                     /&gt; UTC?協定世界時)による日時?入力?作?する
989             * &lt;og:input type="date"                         /&gt; 日付?入力?作?する
990             * &lt;og:input type="month"                        /&gt; 月?入力?作?する
991             * &lt;og:input type="week"                         /&gt; 週の入力?作?する
992             * &lt;og:input type="time"                         /&gt; 時間の入力?作?する
993             * &lt;og:input type="datetime-local"       /&gt; UTC?協定世界時)によらな?ーカル日時?入力?作?する
994             * &lt;og:input type="number"                       /&gt; 数値の入力?作?する
995             * &lt;og:input type="range"                        /&gt; レンジの入力?作?する
996             * &lt;og:input type="color"                        /&gt; 色の入力?作?する
997             *
998             * @og.rev 5.7.1.0 (2013/12/06) HTML5 対?新規追?
999             *
1000             * @param   type HTML5用 [text/search/tel/url/email/datetime/date/month/week/time/datetime-local/number/range/color]
1001             */
1002            public void setType( final String type ) {
1003                    String tp = getRequestParameter( type );
1004    
1005                    if( check( "|" + tp + "|" , CHECK_TYPE ) ) {
1006                            set( "type",tp );
1007                    }
1008                    else {
1009                            String errMsg = "type 属?は、下記?中から選択してください。type=["
1010                                                     + tp + "  in [" + CHECK_TYPE + "]";
1011                            throw new HybsSystemException( errMsg );
1012                    }
1013            }
1014    
1015            /**
1016             * 【TAG】ResourceManager を使用しな?ど?[true/false]を指定しま?初期値:false)?
1017             *
1018             * @og.tag
1019             * trueを指定すると、使用しな?定になります?
1020             * これは、データベ?スから検索した値そ?も?が返される カラ?ブジェクトを使用することになります?
1021             * 「noResource」なので、意味が反転して?のをご注意く???
1022             *
1023             * false(初期値)は、ResourceManager を使用します?
1024             *
1025             * @og.rev 5.7.3.0 (2014/02/07) 新規作?
1026             *
1027             * @param       flag ResourceManager を使用しな?ど? [true:使用しな?false:使用する]
1028             */
1029            public void setNoResource( final String flag ) {
1030                    noResource = nval( getRequestParameter( flag ),noResource );
1031            }
1032    
1033            /**
1034             * 【TAG】レン?利用時?Excel出力でセルタイプを?固定にするか[true/false]を指定しま?初期値:シス?定数のUSE_STRING_EXCEL_OUTPUT)?
1035             *
1036             * @og.tag
1037             * falseを指定すると、dbTypeに従ったセルタイプとなります?
1038             * TableWriter?でdouble変換をするためエラーに注意してください?
1039             * (初期値:シス?定数のUSE_STRING_EXCEL_OUTPUT[={@og.value org.opengion.hayabusa.common.SystemData#USE_STRING_EXCEL_OUTPUT}])?
1040             *
1041             * @og.rev 5.7.6.3 (2014/05/23) 新規作?
1042             *
1043             * @param       flag レン?利用時?Excel出力でセルタイプを?固定にする?[true:固定す?false:固定しない]
1044             */
1045            public void setStringOutput( final String flag ) {
1046                    stringOutput = nval( getRequestParameter( flag ),stringOutput );
1047            }
1048    
1049            /**
1050             * シリアライズ用のカスタ?リアライズ書き込みメソ?
1051             *
1052             * @og.rev 4.0.0.0 (2006/09/31) 新規追?
1053             * @serialData ?のオブジェクト?、シリアライズされません?
1054             *
1055             * @param       strm    ObjectOutputStreamオブジェク?
1056             * @throws IOException  シリアライズに関する入出力エラーが発生した??
1057             */
1058            private void writeObject( final ObjectOutputStream strm ) throws IOException {
1059                    strm.defaultWriteObject();
1060            }
1061    
1062            /**
1063             * シリアライズ用のカスタ?リアライズ読み込みメソ?
1064             *
1065             * ここでは、transient 宣?れた?変数の??初期化が?なフィールド?み設定します?
1066             *
1067             * @og.rev 4.0.0.0 (2006/09/31) 新規追?
1068             * @serialData ?のオブジェクト?、シリアライズされません?
1069             *
1070             * @param       strm    ObjectInputStreamオブジェク?
1071             * @see #release2()
1072             * @throws IOException  シリアライズに関する入出力エラーが発生した??
1073             * @throws ClassNotFoundException       クラスを見つけることができなかった??
1074             */
1075            private void readObject( final ObjectInputStream strm ) throws IOException , ClassNotFoundException {
1076                    strm.defaultReadObject();
1077            }
1078    
1079            /**
1080             * こ?オブジェクト???表現を返します?
1081             * 基本???目?使用します?
1082             *
1083             * @return こ?クラスの??表現
1084             */
1085            @Override
1086            public String toString() {
1087                    return org.opengion.fukurou.util.ToString.title( this.getClass().getName() )
1088                                    .println( "VERSION"             ,VERSION        )
1089                                    .println( "tableId"             ,tableId        )
1090                                    .println( "columns"             ,columns        )
1091                                    .println( "allColumns"  ,allColumns     )
1092                                    .println( "className"   ,className      )
1093                                    .println( "size"                ,size           )
1094                                    .println( "maxlength"   ,maxlength      )
1095                                    .println( "writable"    ,writable       )
1096                                    .println( "renderer"    ,renderer       )
1097                                    .println( "editor"              ,editor         )
1098                                    .println( "codeName"    ,codeName       )
1099                                    .println( "dbType"              ,dbType         )
1100                                    .println( "defaultVal"  ,defaultVal     )
1101                                    .println( "parameter"   ,parameter      )
1102                                    .println( "dbid"                ,dbid           )
1103                                    .println( "addNoValue"  ,addNoValue     )
1104                                    .println( "Other..."    ,getAttributes().getAttribute() )
1105                                    .fixForm().toString() ;
1106            }
1107    }