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.table; 017 018 import org.opengion.hayabusa.db.AbstractTableFilter; 019 import org.opengion.hayabusa.db.DBTableModel; 020 021 import org.opengion.hayabusa.resource.ResourceFactory; 022 import org.opengion.hayabusa.resource.ResourceManager; 023 024 import org.opengion.fukurou.util.ErrorMessage; 025 import org.opengion.fukurou.util.StringUtil; 026 027 import java.util.Map; 028 029 /** 030 * TableFilter_LABEL は、TableFilter インターフェースを継承した、DBTableModel 処?の 031 * 実?ラスです? 032 * 033 * ここでは、キーのCLM,LBL と、LANG より、ラベルリソースに変換した値を設定します? 034 * 035 * パラメータは、tableFilterタグの keys, vals にそれぞれ記述するか?BODY 部にCSS形式で記述します? 036 * 【パラメータ? 037 * { 038 * SYSTEM_ID : ラベルリソースの作?シス?IDを指定します?無?時は、ログイン時?リソースになります? 039 * LANG : ラベルリソースの?を?します?無?時は、日本語になります? 040 * CLM : ラベルリソースのキーとなる?が設定されて?カラ?を指定します? 041 * LBL : CLMで?されたカラ?から値を取り?し?ラベルリソースに変換した結果をセ?します? 042 * } 043 * 044 * CLM と LBL に同じカラ??すると、このフィルターを?過するたびに、変換後?ラベル? 045 * 再?キーとして変換しよ?試みることになります?不測の事?に陥る可能性があるため? 046 * そ?様な設定?出来なくなって?す? 047 * 048 * また?CLM また? LBL で?したカラ? DBTableModel に存在しな??合?、??のも?? 049 * 無視します?そ?場合?、警告も出力されませんので、ご注意く??? 050 * 051 * @og.formSample 052 * ●形式? 053 * ?<og:tableFilter classId="LABEL" keys="CLM,LBL" vals="COLUMN,LABEL_CLM" /> 054 * 055 * ② <og:tableFilter classId="LABEL" > 056 * { 057 * SYSTEM_ID : GF ; 058 * LANG : ja ; 059 * CLM : COLUMN ; 060 * LBL : LABEL_CLM ; 061 * } 062 * </og:tableFilter> 063 * 064 * @og.rev 5.6.6.0 (2013/07/05) keys の整合?チェ?を追? 065 * 066 * @version 0.9.0 2000/10/17 067 * @author Kazuhiko Hasegawa 068 * @since JDK1.1, 069 */ 070 public class TableFilter_LABEL extends AbstractTableFilter { 071 //* こ?プログラ??VERSION??を設定します? {@value} */ 072 private static final String VERSION = "5.6.6.1 (2013/07/12)" ; 073 074 /** 075 * keys の整合?チェ?を行うための初期設定を行います? 076 * 077 * @og.rev 5.6.6.1 (2013/07/12) keys の整合?チェ?対? 078 * 079 * @param keysMap keys の整合?チェ?を行うための Map 080 */ 081 @Override 082 protected void init( final Map<String,String> keysMap ) { 083 keysMap.put( "SYSTEM_ID" , "シス?IDを指定しま?初期値:ログイン時?リソース)" ); 084 keysMap.put( "LANG" , "?を??初期値:日本?" ); 085 keysMap.put( "CLM" , "キーとなる?が設定されて?カラ?を指? ); 086 keysMap.put( "LBL" , "ラベルリソースに変換した結果をセ?するカラ?を指? ); 087 } 088 089 /** 090 * DBTableModel処?実行します? 091 * 092 * @og.rev 5.5.2.2 (2012/05/09) SYSTEM_ID を受け取るよ?変更 093 * @og.rev 5.5.2.6 (2012/05/25) protected変数を?private化したため?getterメソ?で取得するよ?変更 094 * 095 * @return 処?果のDBTableModel 096 */ 097 public DBTableModel execute() { 098 DBTableModel table = getDBTableModel(); // 5.5.2.6 (2012/05/25) インターフェースにgetterメソ?追? 099 100 String systemId = getValue( "SYSTEM_ID" ); // 5.5.2.2 (2012/05/09) 101 String lang = getValue( "LANG" ); 102 // ResourceManager resource = ResourceFactory.newInstance( lang ); 103 ResourceManager resource = ResourceFactory.newInstance( systemId,lang,false ); // 5.5.2.2 (2012/05/09) 104 105 String clm = getValue( "CLM" ); 106 String lbl = getValue( "LBL" ); 107 108 int clmNo = table.getColumnNo( clm,false ); // 存在しな??合??1 を返す? 109 int lblNo = table.getColumnNo( lbl,false ); 110 111 if( clmNo == lblNo && clmNo >= 0 ) { 112 String errMsg = "CLM と LBL に同じカラ??することは出来ません? ; 113 ErrorMessage errMessage = makeErrorMessage( "TableFilter_LABEL Error",ErrorMessage.NG ); 114 errMessage.addMessage( 0,ErrorMessage.NG,errMsg ); 115 errMessage.addMessage( 0,ErrorMessage.NG,"CLM=[" + clm + "],LBL=[" + lbl + "]" ); 116 } 117 else if( clmNo >= 0 && lblNo >= 0 ) { 118 String[] data = null; 119 int rowCnt = table.getRowCount(); 120 for( int row=0; row<rowCnt; row++ ) { 121 String clmVal = null; 122 try { 123 data = table.getValues( row ); 124 clmVal = data[clmNo]; // 変換する??カラ? 125 data[lblNo] = resource.getLabel( clmVal ) ; // 副作用を及ぼして?す?注? 126 } 127 catch( RuntimeException ex ) { 128 ErrorMessage errMessage = makeErrorMessage( "TableFilter_LABEL Error",ErrorMessage.NG ); 129 errMessage.addMessage( row+1,ErrorMessage.NG,ex.getMessage() ); 130 errMessage.addMessage( row+1,ErrorMessage.NG,StringUtil.array2csv( data ) ); 131 errMessage.addMessage( row+1,ErrorMessage.NG,"CLM=[" + clm + "],VAL=[" + clmVal + "]" ); 132 } 133 } 134 } 135 136 return table; 137 } 138 }