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.fukurou.util.StringUtil;
019    import org.opengion.hayabusa.db.AbstractTableFilter;
020    import org.opengion.hayabusa.db.DBTableModel;
021    
022    import java.util.Map;
023    
024    /**
025     * TableFilter_BIKO2CODE は、TableFilter インターフェースを継承した、DBTableModel 処?の
026     * 実?ラスです?
027     *
028     * ここでは、DB定義書??の備???し?コードリソースとして登録可能な形に再構築します?
029     * 入力カラ?してBIKOが?出力カラ?して、CODE,CODENAME,SEQが?です?
030     * それぞれのカラ?は、keys,valsの引数としても指定可能です?
031     *
032     * ?方法としては、まず備??' '(スペ?ス)区?に?し?<del>取り出したコード情報?
033     * DBTableModelの行として追?ます?</del>
034     * そ?上で、さらに取り出した値?:'で?してコードとコード名称に?します?
035     * ?(SEQ)につ?は、備??記載されて??になります?
036     * 「キー:ラベル キー:ラベル」で、ラベル にスペ?スを含ませる場合?、ダブルクォー??ションで
037     * 囲ってください?
038     *
039     * また?BIKO,CODE,CODENAME,SEQ で?したカラ? DBTableModel に存在しな??合??
040     * 処?のも?を無視します?そ?場合?、警告も出力されませんので、ご注意く???
041     *
042     * パラメータは、tableFilterタグの keys, vals にそれぞれ記述するか?BODY 部にCSS形式で記述します?
043     * 【パラメータ?
044     *  {
045     *       BIKO       : 入力カラ?;    備???を?納して?入力カラ??
046     *       CODE       : 出力カラ?;    コードを格納する?力カラ??
047     *       CODENAME   : 出力カラ?;    コード名称を?納する?力カラ??
048     *       SEQ        : 出力カラ?;    並び?格納する?力カラ?。備??記載されて??になります?
049     *  }
050     *
051     * @og.formSample
052     * ●形式?
053     *      select TABLE_NAME,CLM,NAME_JA,EDITOR,RENDERER,DBTYPE,BIKO,0 SEQ,'' CODE,'' CODENAME,UNIQ,SYSTEM_ID from GF05
054     *      ?&lt;og:tableFilter classId="BIKO2CODE" keys="BIKO,CODE," vals='"TABLE_NAME,CLM"' /&gt;
055     *
056     *      ② &lt;og:tableFilter classId="BIKO2CODE" &gt;
057     *               {
058     *                       BIKO       : 入力カラ?;    備???を?納して?入力カラ??
059     *                       CODE       : 出力カラ?;    コードを格納する?力カラ??
060     *                       CODENAME   : 出力カラ?;    コード名称を?納する?力カラ??
061     *                       SEQ        : 出力カラ?;    並び?格納する?力カラ?。備??記載されて??になります?
062     *               }
063     *         &lt;/og:tableFilter&gt;
064     *
065     * @og.rev 4.1.0.0(2008/01/18) 新規作?
066     * @og.rev 5.6.6.0 (2013/07/05) keys の整合?チェ?を追?
067     *
068     * @version  0.9.0  2000/10/17
069     * @author   Hiroki Nakamura
070     * @since    JDK1.1,
071     */
072    public class TableFilter_BIKO2CODE extends AbstractTableFilter {
073            //* こ?プログラ??VERSION??を設定します?       {@value} */
074            private static final String VERSION = "5.6.6.1 (2013/07/12)" ;
075    
076            /**
077             * keys の整合?チェ?を行うための初期設定を行います?
078             *
079             * @og.rev 5.6.6.1 (2013/07/12) keys の整合?チェ?対?
080             *
081             * @param       keysMap keys の整合?チェ?を行うための Map
082             */
083            @Override
084            protected void init( final Map<String,String> keysMap ) {
085                    keysMap.put( "BIKO"             , "備???を?納して?入力カラ?"         );
086                    keysMap.put( "CODE"     , "コードを格納する?力カラ?"                     );
087                    keysMap.put( "CODENAME" , "コード名称を?納する?力カラ?"          );
088                    keysMap.put( "SEQ"              , "並び?格納する?力カラ?"                     );
089            }
090    
091            /**
092             * DBTableModel処?実行します?
093             *
094             * @og.rev 5.5.2.6 (2012/05/25) protected変数を?private化したため?getterメソ?で取得するよ?変更
095             * @og.rev 5.5.8.5 (2012/11/27) スペ?スで?し?":" が存在する?のみ、コードリソース化します?
096             *
097             * @return 処?果のDBTableModel
098             */
099            public DBTableModel execute() {
100                    DBTableModel table = getDBTableModel();         // 5.5.2.6 (2012/05/25) インターフェースにgetterメソ?追?
101    
102                    int bikoNo = table.getColumnNo( StringUtil.nval( getValue( "BIKO" ), "BIKO" ), false );         // 存在しな??合??1 を返す?
103                    int codeNo = table.getColumnNo( StringUtil.nval( getValue( "CODE" ), "CODE" ), false );
104                    int nameNo = table.getColumnNo( StringUtil.nval( getValue( "CODENAME" ),"CODENAME" ), false );
105                    int seqNo  = table.getColumnNo( StringUtil.nval( getValue( "SEQ" ),  "SEQ" ), false );
106    
107                    char sep = ' ';
108    
109                    if( bikoNo >= 0 && codeNo >= 0 && nameNo >= 0 && seqNo >= 0 ) {
110                            String[] data  = null;
111                            String[] nData = null;
112                            String[] clmValArr = null;
113                            int addRows = 0;
114                            int rowCnt = table.getRowCount();
115                            for( int row=0; row<rowCnt; row++ ) {
116                                    addRows = 0;
117                                    data = table.getValues( row );
118                                    // タグがあった?合?無?
119                                    if( data[bikoNo].indexOf( "/>" ) < 0 && data[bikoNo].indexOf( "</" ) < 0 ) {
120                                            clmValArr = StringUtil.csv2Array( data[bikoNo], sep );
121    //                                      for ( int i = 0; i < clmValArr.length; i++ ) {
122    //                                              addRows++;
123    //                                              nData = new String[data.length];
124    //                                              System.arraycopy( data, 0, nData, 0, data.length );
125    //                                              int clnIdx = clmValArr[i].indexOf( ':' );
126    //                                              if( clnIdx < 0 ) {
127    //                                                      nData[codeNo] = clmValArr[i];
128    //                                                      nData[nameNo] = "";
129    //                                              }
130    //                                              else {
131    //                                                      nData[codeNo] = clmValArr[i].substring( 0, clmValArr[i].indexOf( ':' ) );
132    //                                                      nData[nameNo] = clmValArr[i].substring( clmValArr[i].indexOf( ':' ) + 1 );
133    //                                              }
134    //                                              nData[seqNo] = String.valueOf( i );
135    //                                              table.addValues( nData, row+addRows, false );
136    //                                      }
137                                            // 5.5.8.5 (2012/11/27) スペ?スで?し?":" が存在する?のみ、コードリソース化します?
138                                            int seq = 0;
139                                            for ( int i = 0; i < clmValArr.length; i++ ) {
140                                                    String clmVal = clmValArr[i];
141                                                    int clnIdx = clmVal.indexOf( ':' );
142                                                    if( clnIdx >= 0 ) {
143                                                            nData = new String[data.length];
144                                                            System.arraycopy( data, 0, nData, 0, data.length );
145    
146                                                            nData[codeNo] = clmVal.substring( 0, clnIdx );
147                                                            nData[nameNo] = clmVal.substring( clnIdx + 1 );
148                                                            nData[seqNo]  = String.valueOf( seq++ );
149    
150                                                            addRows++;
151                                                            table.addValues( nData, row+addRows, false );
152                                                    }
153                                            }
154    
155                                            if( addRows > 0 ) {
156                                                    table.removeValue( row );
157                                                    addRows--;
158                                            }
159    
160                                            row += addRows;
161                                            rowCnt += addRows;
162                                    }
163                            }
164                    }
165    
166                    return table;
167            }
168    }