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.plugin.column;
017    
018    import org.opengion.hayabusa.common.HybsSystem;
019    import org.opengion.hayabusa.common.HybsSystemException;
020    import org.opengion.hayabusa.db.AbstractEditor;
021    import org.opengion.hayabusa.db.CellEditor;
022    import org.opengion.hayabusa.db.DBColumn;
023    import org.opengion.hayabusa.db.Selection;
024    import org.opengion.hayabusa.db.SelectionFactory;
025    import org.opengion.fukurou.util.StringFormat;
026    import org.opengion.fukurou.util.XHTMLTag;
027    import org.opengion.fukurou.util.Attributes;
028    import org.opengion.fukurou.util.TagBuffer;
029    
030    /**
031     * カラãƒ??ç·¨é›?ƒ‘ラメーターã®?³?±?¬æ–??å®Ÿè¡Œçµæžœã‚ˆã‚Šã€datalistを作æ?ã—ã¦
032     * 入力å?補ã¨ãªã‚‹ãƒ‡ãƒ¼ã‚¿ãƒªã‚¹ãƒˆã‚’定義ã™ã‚‹ç·¨é›?”¨ã‚¨ãƒ?‚£ã‚¿ãƒ¼ã‚¯ãƒ©ã‚¹ã§ã™ã?
033     * datalist ã¯ã€HTML5 ã‹ã‚‰æŽ¡ç”¨ã•れãŸã‚¿ã‚°ã§ã™ã?
034     *
035     * ç·¨é›?ƒ‘ラメータã«ã¯ã€datalistを作æ?ã™ã‚‹ãŸã‚ã®ã€SQLæ–?‚’記述ã—ã¾ã™ã?
036     * ã“ã?SQLæ–??ã€select KEY,LABEL from xx ?¥?¥?¥ ã¨ã?†æ§‹æ–‡ã§ã€KEY部åˆ?¨LABEL部åˆ?Œ
037     * é¸æŠžã•れã¾ã™ã?
038     * datalist 自身ãŒã?HTML5ã‹ã‚‰ã®æ–°æ©Ÿè?ãªã®ã§ã€ç¾æ™‚点ã§ã¯ã€ã“れ以上ã?機è?ã¯ã‚りã¾ã›ã‚“ã€?
039     * å°?¥çš?«ã€DBMENU ãªã©ã¨åŒæ§˜ã«ã€ç¬¬ä¸‰ã‚«ãƒ©ãƒ?»¥é™ã‚’利用å¯èƒ½ã«ãªã‚‹ã¨æ€ã„ã¾ã™ã?ã§ã€?
040     * 今ã?使ã‚ãªã?§ãã ã•ã„。(å°?¥ã®æ©Ÿè?追åŠ?™‚ã«äº’æ›æ€§å•題を引ãèµ·ã“ã™ã‹ã‚‚ã—れã¾ã›ã‚“ã®ã§??
041     *
042     * 入力フィールドã¨datalistã‚¿ã‚°ã¨ã®é–¢ä¿‚付ã?ã€ã‚«ãƒ©ãƒ?Dã«ã€?dl_カラãƒ?D" ã§çµã?ã¤ã‘ã¾ã™ã?
043     *
044     * <input name="カラ�D" list="dl_カラ�D" />
045     * <div style="display:none;">
046     *   <datalist id="dl_カラ�D">
047     *     <option value="KEY1">LABEL1</option>
048     *     <option value="KEY2">LABEL2</option>
049     *     <option value="KEY3">LABEL3</option>
050     *   </datalist>
051     * </div>
052     *
053     * divã‚¿ã‚°ã¯ã€HTML5 éžå¯¾å¿œãƒ–ラウザを使用ã—ãŸå ´åˆã?datalist ã® option ãŒãã®ã¾ã¾
054     * ãƒ?‚­ã‚¹ãƒˆã¨ã—ã¦è¦‹ãˆã¦ã—ã¾ã??ã‚’é¿ã‘ã‚‹ãŸã‚ã§ã™ã?
055     *
056     * ä¸?¦§è¡¨å‡ºåŠ›æ™‚ã® getValue( int ,String ) 処ç?§ã¯ã€Selection オブジェクトã?
057     * キャãƒ?‚·ãƒ¥æ©Ÿè?を利用ã—ã¦ã€åŒä¸?election オブジェクトã?é–“ã?ã€datalist ã¯ã€?
058     * ?‘度ã—ã‹ã€å?力ã—ãªã?§˜ã«åˆ¶å¾¡ã—ã¦ã?¾ã™ã?ã“れã«ã‚ˆã‚Šã€å?有ã?datalist を使用ã™ã‚‹ç‚ºã€?
059     * HTMLã®å‡ºåŠ›ãƒ‡ãƒ¼ã‚¿é‡ã‚’抑ãˆã‚‹ã“ã¨ãŒå¯èƒ½ã«ãªã‚Šã¾ã™ã?
060     * (キャãƒ?‚·ãƒ¥ã‚’利用ã—ãªã?¨?‘ï¼ï¼è¡Œå?力ã™ã‚‹ã¨?‘ï¼ï¼å?ã®datalistã‚’å?力ã™ã‚‹äº‹ã«ãªã‚Šã¾ã™ã?)
061     * (åŒæ§˜ã?機è?ã‚’æŒã¤ INDBMENU ã§ã¯ã€è¡Œã”ã¨ã«ãƒ—ルãƒ?‚¦ãƒ³ãƒ??タを作æ?ã—ã¦ã?¾ã™ã?)
062     * ãŸã ã—ã?行å˜ä½ã«SQLã®æ¡ä»¶ã‚’変ãˆã‚‹æ©Ÿè?(AAA:BBB:CCC:DDD引数)ãŒæŒ‡å®šã•れãŸå ´åˆã?ã€?
063     * 行ã”ã¨ã«å‡ºåŠ›ã—ã¾ã™ã?
064     *
065     * å?‚«ãƒ©ãƒ??値(value値)ã«ã€AAA:BBB:CCC:DDD ã¨ã?†å€¤ã‚’設定ã§ãã¾ã™ã?ã“れã¯ã€?
066     * $1,$2,$3,$4 ã«å‰²ã‚Šå½“ã¦ãªãŠã—ã¦ã€QUERYを実行ã—ã¾ã™ã?ã¾ãŸã?$1 ã¯ã€æœ¬æ¥ã®å€¤ã¨ã—ã¦ã€?
067     * メニューã®åˆæœŸå€¤è¨­å®šç­‰ã«ä½¿ç”¨ã—ã¾ã™ã?上記ã?例ã§ã¯ã€AAA ãŒå?ã§ã€ãれ以é™ã?ã€?
068     * 引数ã«ãªã‚Šã¾ã™ã?
069     * åˆã?$Cã«ã¯è‡ªåˆ??身ã®ã‚«ãƒ©ãƒ?を割り当ã¦ã¾ã™ã?
070     * ã“ã?機è?を使用ã™ã‚Œã°ã€å‹•çš?ƒ¡ãƒ‹ãƒ¥ãƒ¼ã‚’行ã”ã¨ã«æ¡ä»¶ã‚’変ãˆã¦ä½œæ?ã™ã‚‹ã“ã¨ã?
071     * å¯èƒ½ã«ãªã‚Šã¾ã™ã?
072     * 例:select KEY,LABEL from xx where KUBUN='$2' and CDK='$3'
073     * ã•らã«ã€å?ã®æ–?­—å?"AAA:BBB:CCC:DDD"ã¯ã€?0 ã«å‰²ã‚Šå½“ã¦ã‚‰ã‚Œã¾ã™ã?割り当ã¦ãŒãªã?
074     * 変数ã¯ã€?"(ゼロæ–?­—å?)ã¨ã—ã¦ã€æ‰±ã‚れã¾ã™ã?
075     *
076     * カラãƒ??表示ã«å¿?¦ãªå±žæ?ã¯, DBColumn オブジェクãƒ?よりå–り出ã—ã¾ã™ã?
077     * ã“ã?クラスã¯ã€DBColumn オブジェクト毎ã«?‘ã¤ä½œæ?ã•れã¾ã™ã?
078     *
079     * @og.rev 5.7.4.3 (2014/03/28) æ–°è¦ä½œæ?
080     * @og.group �?タ編�HTML5)
081     *
082     * @version  4.0
083     * @author       Kazuhiko Hasegawa
084     * @since    JDK5.0,
085     */
086    public class Editor_DATALIST extends AbstractEditor {
087            //* ã“ã?プログラãƒ??VERSIONæ–?­—å?を設定ã—ã¾ã™ã?       {@value} */
088            private static final String VERSION = "5.7.5.0 (2014/04/04)" ;
089    
090            // 5.7.5.0 (2014/04/04) datalist 使用時ã?ã€display:none ã«ã—ã¦ã€HTML5未対応ã?ブラウザã«å‚™ãˆã‚‹ã?
091            private static final String DIV1 = "<div style=\"display:none;\">" ;
092            private static final String DIV2 = "</div>" ;
093    
094            private final String query ;
095            private final String dbid ;
096            private final String lang ;
097    
098            private Selection bkSel= null;  // 5.7.5.0 (2014/04/04) Selection オブジェクトã?キャãƒ?‚·ãƒ¥æ©Ÿè?
099    
100            /**
101             * ãƒ?ƒ•ォルトコンストラクターã€?
102             * ã“ã?コンストラクターã§ã€åŸºæœ¬ã‚ªãƒ–ジェクトを作æ?ã—ã¾ã™ã?
103             *
104             */
105            public Editor_DATALIST() {
106            //      super();
107                    query   = null;
108                    dbid    = null;
109                    lang    = null;
110            }
111    
112            /**
113             * コンストラクター�
114             *
115             * @param       clm     DBColumnオブジェク�
116             */
117            private Editor_DATALIST( final DBColumn clm ) {
118                    super( clm );
119                    tagBuffer.add( XHTMLTag.inputAttri( attributes ) );
120    
121                    query           = clm.getEditorParam();
122                    dbid            = clm.getDbid();
123                    lang            = clm.getLang();                        // 4.0.0 (2006/11/15)
124    
125                    // 3.5.5.9 (2004/06/07)
126                    if( query == null || query.length() == 0 ) {
127                            String errMsg = "DATALIST Editor ã§ã¯ã€ç·¨é›?ƒ‘ラメータã¯å¿??ã§ã™ã?"
128                                            + " name=[" + name + "]" + HybsSystem.CR ;
129                            throw new HybsSystemException( errMsg );
130                    }
131            }
132    
133            /**
134             * å?‚ªãƒ–ジェクトã‹ã‚‰è?åˆ??インスタンスを返ã—ã¾ã™ã?
135             * 自åˆ??身をキャãƒ?‚·ãƒ¥ã™ã‚‹ã®ã‹ã?æ–°ãŸã«ä½œæ?ã™ã‚‹ã®ã‹ã?ã€å„サブクラスã®å®Ÿè£?«
136             * ã¾ã‹ã•れã¾ã™ã?
137             *
138             * @param       clm     DBColumnオブジェク�
139             *
140             * @return      CellEditorオブジェク�
141             */
142            public CellEditor newInstance( final DBColumn clm ) {
143                    return new Editor_DATALIST( clm );
144            }
145    
146            /**
147             * ãƒ??ã‚¿ã®ç·¨é›?”¨æ–?­—å?ã‚’è¿”ã—ã¾ã™ã?
148             *
149             * ã“ã“ã§ã¯ã€AAA:BBB:CCC:DDD ã¨ã?†å€¤ã‚’ã?$1,$2,$3,$4 ã«å‰²ã‚Šå½“ã¦ãªãŠã—ã¦ã€?
150             * QUERYを実行ã—ã¾ã™ã?ã¾ãŸã?$1 ã¯ã€æœ¬æ¥ã®å€¤ã¨ã—ã¦ã€ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã®åˆæœŸå€¤è¨­å®šç­‰ã«
151             * 使用ã—ã¾ã™ã?上記ã?例ã§ã¯ã€AAA ãŒå?ã§ã€ãれ以é™ã?ã€å¼•æ•°ã«ãªã‚Šã¾ã™ã?
152             * ã•らã«ã€å?ã®æ–?­—å?"AAA:BBB:CCC:DDD"ã¯ã€?0 ã«å‰²ã‚Šå½“ã¦ã‚‰ã‚Œã¾ã™ã?割り当ã¦ãŒãªã?
153             * 変数ã¯ã€?"(ゼロæ–?­—å?)ã¨ã—ã¦ã€æ‰±ã‚れã¾ã™ã?
154             * åˆã?$Cã«ã¯è‡ªåˆ??身ã®ã‚«ãƒ©ãƒ?を割り当ã¦ã¾ã™ã?
155             *
156             * @og.rev 5.7.5.0 (2014/04/04) datalist 使用時ã?ã€display:none ã«ã—ã¦ã€HTML5未対応ã?ブラウザã«å‚™ãˆã‚‹ã?
157             *
158             * @param       value 入力å?
159             *
160             * @return      ãƒ??ã‚¿ã®ç·¨é›?”¨æ–?­—å?
161             */
162            @Override
163            public String getValue( final String value ) {
164                    // input ã‚¿ã‚°ã®ä½œæ?
165                    TagBuffer intag = new TagBuffer( "input" );
166                    intag.add( "name"    , name );
167                    if( attributes.get( "id" ) == null || attributes.get( "id" ).length() == 0 ) {
168                            intag.add( "id"      , name );
169                    }
170                    intag.add( "list"    , "dl_" + name );          // datalistã‚¿ã‚°ã¨ã®é–¢ä¿‚付ã‘ã‚‹ãŸã‚ã?キーワーãƒ?
171                    intag.add( "value"   , value );
172                    intag.add( "size"    , size1 );
173                    intag.add( tagBuffer.makeTag() );
174                    intag.add( optAttr );
175    
176                    // datalist ã‚¿ã‚°ã®ä½œæ?
177                    TagBuffer dltag = new TagBuffer( "datalist" );
178                    dltag.add( "id"    , "dl_" + name );                    // inputã‚¿ã‚°ã¨ã®é–¢ä¿‚付ã‘ã‚‹ãŸã‚ã?キーワーãƒ?
179    
180                    dltag = getOption( dltag,value,false );                 // キャãƒ?‚·ãƒ¥ã¯ä½¿ç”¨ã—ãªã??
181    
182                    // display:none ã¯ã€datalist ã® optionã®BODY部ãŒã?HTML5 以外ã§ã¯è¡¨ç¤ºã•れã¦ã—ã¾ã??を防ããŸã‚ã?
183                    return intag.makeTag()  + HybsSystem.CR +
184    //                              dltag.makeTag() + HybsSystem.CR;
185                                    DIV1 + dltag.makeTag() + DIV2 + HybsSystem.CR;
186            }
187    
188            /**
189             * name属æ?を変ãˆãŸã?ãƒ??タ表示/ç·¨é›?”¨ã®HTMLæ–?­—å?を作æ?ã—ã¾ã™ã?
190             * ãƒ??ブル上ã? name 㫠行番å·ã‚’付加ã—ã¦ã€åå‰_è¡Œç•ªå· ã§ç™»éŒ²ã™ã‚‹ã‚­ãƒ¼ã‚’作æ?ã?
191             * ãƒªã‚¯ã‚¨ã‚¹ãƒˆæƒ…å ±ã‚’ï¼‘ã¤æ¯Žã?フィールドã§å‡¦ç?§ãã¾ã™ã?
192             *
193             * ã“ã“ã§ã¯ã€AAA:BBB:CCC:DDD ã¨ã?†å€¤ã‚’ã?$1,$2,$3,$4 ã«å‰²ã‚Šå½“ã¦ãªãŠã—ã¦ã€?
194             * QUERYを実行ã—ã¾ã™ã?ã¾ãŸã?$1 ã¯ã€æœ¬æ¥ã®å€¤ã¨ã—ã¦ã€ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã®åˆæœŸå€¤è¨­å®šç­‰ã«
195             * 使用ã—ã¾ã™ã?上記ã?例ã§ã¯ã€AAA ãŒå?ã§ã€ãれ以é™ã?ã€å¼•æ•°ã«ãªã‚Šã¾ã™ã?
196             * ã•らã«ã€å?ã®æ–?­—å?"AAA:BBB:CCC:DDD"ã¯ã€?0 ã«å‰²ã‚Šå½“ã¦ã‚‰ã‚Œã¾ã™ã?割り当ã¦ãŒãªã?
197             * 変数ã¯ã€?"(ゼロæ–?­—å?)ã¨ã—ã¦ã€æ‰±ã‚れã¾ã™ã?
198             * åˆã?$Cã«ã¯è‡ªåˆ??身ã®ã‚«ãƒ©ãƒ?を割り当ã¦ã¾ã™ã?
199             *
200             * @og.rev 5.7.5.0 (2014/04/04) datalist 使用時ã?ã€display:none ã«ã—ã¦ã€HTML5未対応ã?ブラウザã«å‚™ãˆã‚‹ã?
201             * @og.rev 5.7.5.0 (2014/04/04) Selection オブジェクトã?キャãƒ?‚·ãƒ¥æ©Ÿè?
202             *
203             * @param       row   行番å·
204             * @param       value 入力å?
205             *
206             * @return      ãƒ??タ表示/ç·¨é›?”¨ã®æ–?­—å?
207             */
208            @Override
209            public String getValue( final int row,final String value ) {
210                    String name2 = name + HybsSystem.JOINT_STRING + row ;
211    
212                    // 5.7.5.0 (2014/04/04) Selection オブジェクトã?キャãƒ?‚·ãƒ¥æ©Ÿè? (true:使用å¯èƒ½)
213                    boolean useSelCache = ( value != null && value.indexOf( ':' ) < 0 ) ;
214    
215                    String listId = (useSelCache) ? name : name2;   // キャãƒ?‚·ãƒ¥ã‚’使用ã™ã‚‹å ´åˆã?ã€å?通ã? name を使ã??
216    
217                    // input ã‚¿ã‚°ã®ä½œæ?
218                    TagBuffer intag = new TagBuffer( "input" );
219                    intag.add( "name"    , name2 );
220                    if( attributes.get( "id" ) == null || attributes.get( "id" ).length() == 0 ) {
221                            intag.add( "id"      , name2 );
222                    }
223    //              intag.add( "list"    , "dl_" + name2 );                 // datalistã‚¿ã‚°ã¨ã®é–¢ä¿‚付ã‘ã‚‹ãŸã‚ã?キーワーãƒ?
224                    intag.add( "list"    , "dl_" + listId );                // datalistã‚¿ã‚°ã¨ã®é–¢ä¿‚付ã‘ã‚‹ãŸã‚ã?キーワーãƒ?
225                    intag.add( "value"   , value );
226                    intag.add( "size"    , size2 );
227                    intag.add( tagBuffer.makeTag() );
228                    intag.add( optAttr );
229    
230                    // datalist ã‚¿ã‚°ã®ä½œæ?
231                    TagBuffer dltag = new TagBuffer( "datalist" );
232    //              dltag.add( "id"    , "dl_" + name2 );                   // inputã‚¿ã‚°ã¨ã®é–¢ä¿‚付ã‘ã‚‹ãŸã‚ã?キーワーãƒ?
233                    dltag.add( "id"    , "dl_" + listId );                  // inputã‚¿ã‚°ã¨ã®é–¢ä¿‚付ã‘ã‚‹ãŸã‚ã?キーワーãƒ?
234    
235                    dltag = getOption( dltag,value,useSelCache );
236    
237                    // キャãƒ?‚·ãƒ¥ãŒåйãã¨ã€getOption ã®æˆ»ã‚Šå?ã¯ã€null ã«ãªã‚‹ã?
238                    if( dltag != null ) {
239                            return intag.makeTag( row,value ) + HybsSystem.CR +
240    //                                      dltag.makeTag( row,value ) + HybsSystem.CR ;
241                                            DIV1 + dltag.makeTag( row,value ) + DIV2 + HybsSystem.CR ;
242                    }
243                    else {
244                            return intag.makeTag( row,value ) + HybsSystem.CR ;
245                    }
246            }
247    
248            /**
249             * åˆæœŸå€¤ãŒé¸æŠžæ¸ˆã¿ã® é¸æŠžè‚¢(オプション)ã‚’TagBuffer ã«å映ã—ã¾ã™ã?
250             * ã“ã?オプションã¯ã€å¼•æ•°ã®å€¤ã‚’å?期å?ã¨ã™ã‚‹ã‚ªãƒ—ションタグ作æ?ã—ã?TagBuffer
251             * ã«å€¤ã‚’設定ã—ã¦è¿”ã—ã¾ã™ã?
252             *
253             * 第?“引数ã¯ã€Selection オブジェクトã?キャãƒ?‚·ãƒ¥æ©Ÿè?を使用ã™ã‚‹ã‹ã©ã?‹æŒ?®šã—ã¾ã™ã?
254             * true ã§ã€ä½¿ç”¨ã™ã‚‹äº‹ã‚’剿ã«ã€ãƒã‚§ãƒ?‚¯ã‚’行ã„ã¾ã™ã?
255             * DBMENU ãªã©ã€ä»–ã?メソãƒ?ƒ‰ã§ã¯ã€ãƒ©ãƒ™ãƒ«(短)ã®ä½¿ç”¨æœ‰ç„¡ã¨ã—ã¦ä½¿ç”¨ã—ã¦ã?‚‹ãŸã‚ã€ç•°ãªã‚Šã¾ã™ã?
256             *
257             * ã“ã“ã§ã¯ã€AAA:BBB:CCC:DDD ã¨ã?†å€¤ã‚’ã?$1,$2,$3,$4 ã«å‰²ã‚Šå½“ã¦ãªãŠã—ã¦ã€?
258             * QUERYを実行ã—ã¾ã™ã?ã¾ãŸã?$1 ã¯ã€æœ¬æ¥ã®å€¤ã¨ã—ã¦ã€ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã®åˆæœŸå€¤è¨­å®šç­‰ã«
259             * 使用ã—ã¾ã™ã?上記ã?例ã§ã¯ã€AAA ãŒå?ã§ã€ãれ以é™ã?ã€å¼•æ•°ã«ãªã‚Šã¾ã™ã?
260             * ã•らã«ã€å?ã®æ–?­—å?"AAA:BBB:CCC:DDD"ã¯ã€?0 ã«å‰²ã‚Šå½“ã¦ã‚‰ã‚Œã¾ã™ã?割り当ã¦ãŒãªã?
261             * 変数ã¯ã€?"(ゼロæ–?­—å?)ã¨ã—ã¦ã€æ‰±ã‚れã¾ã™ã?
262             * åˆã?$Cã«ã¯è‡ªåˆ??身ã®ã‚«ãƒ©ãƒ?を割り当ã¦ã¾ã™ã?
263             *
264             * @param       buf    ã‚¿ã‚°æ–?­—å?ã®ãƒãƒƒãƒ•ァー
265             * @param       value  é¸æŠžã•れã¦ã?‚‹å€¤
266             * @param   useSelCache Selection オブジェクトã?キャãƒ?‚·ãƒ¥æ©Ÿè?を使用ã™ã‚‹ã‹ã©ã?‹ã€?
267             *
268             * @return      オプションタグ
269             */
270            private TagBuffer getOption( final TagBuffer buf,final String value,final boolean useSelCache ) {
271    
272                    StringFormat format = new StringFormat( query, value, name );
273                    String newQuery = format.format();
274                    String newValue = format.getValue();
275    
276                    Selection selection = SelectionFactory.newDBSelection( newQuery, dbid, lang );
277    
278                    if( useSelCache ) {
279                            if( selection == bkSel ) { return null; }
280                            bkSel = selection ;
281                    }
282    
283                    buf.setBody( selection.getOption( newValue, false ) );
284    
285                    return buf;
286            }
287    }