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 }