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 }