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 */
016package org.opengion.hayabusa.taglib;
017
018import org.opengion.fukurou.util.ErrMsg;
019import org.opengion.fukurou.util.ErrorMessage;
020import org.opengion.hayabusa.html.ViewForm;
021import org.opengion.hayabusa.html.ViewFormFactory;
022import org.opengion.hayabusa.resource.ResourceManager;
023import org.opengion.hayabusa.db.DBTableModel;
024import org.opengion.hayabusa.db.DBTableModelUtil;
025import org.opengion.hayabusa.db.DBColumn;
026
027import java.util.Arrays;
028import java.util.Comparator;
029
030/**
031 *  Taglib で共通的に使用される ユーティリティクラスです。
032 *
033 * 全てのメソッドは、 パッケージプライベートなstatic 宣言されています。
034 *
035 * @og.rev 3.1.1.0 (2003/03/28) 新規作成
036 * @og.group その他部品
037 *
038 * @version  4.0
039 * @author       Kazuhiko Hasegawa
040 * @since    JDK5.0,
041 */
042final class TaglibUtil  {
043        static final String VIEW_ID = "HYBS_VIEW" ;             // 3.5.6.4 (2004/07/16)
044        static final String LINK_ID = "HYBS_LINK" ;             // 3.5.6.4 (2004/07/16)
045        static final String MARK_ID = "HYBS_MARK" ;             // 3.5.6.4 (2004/07/16)
046
047        private static int tagId = 0;
048
049        /**
050         *      デフォルトコンストラクターをprivateにして、
051         *      オブジェクトの生成をさせないようにする。
052         *
053         */
054        private TaglibUtil() {}
055
056        /**
057         * チェックボックスのラベルを関連つけるための id 値を返します。
058         *
059         * InputTag と OrderByTag 全体で、呼び出される都度に連番をつけて返します。
060         * ユニークな番号になる様にする事が目的なので、99999 で、0 にクリアします。
061         * 別スレッドによる同時アクセスで整合性が破綻(同じ番号が返る)しても、
062         * 問題ありません。(単独のスレッド内でユニークになればよい。)
063         *
064         * @return  ユニークな id 値
065         */
066        static String getTagId() {
067                String id = "ID" + ( tagId++ );
068
069                if( tagId >= 100000 ) { tagId = 0; }
070                return ( id );
071        }
072
073        /**
074         * ErrorMessage オブジェクトと、ResourceManager より、表示用 HTMLテーブルを作成します。
075         * これは、従来,各Taglibパッケージで使用していました、ErrorMessage オブジェクトを、
076         * HTMLテーブル形式で表示する為に、DBUtilクラスや、ViewFormクラスなど、複数のクラスを
077         * 複雑に組み合わせて使用していましたが、一つの static メソッドにまとめたものです。
078         *
079         * @og.rev 3.5.5.2 (2004/04/02) 新規追加
080         * @og.rev 3.5.6.1 (2004/06/25) lang 言語コード 属性を削除します。
081         * @og.rev 3.5.6.2 (2004/07/05) setBgColorCycle の引数定義を変更
082         * @og.rev 3.8.0.4 (2005/08/08) setUseScrollBar の追加(ヘッダー固定のスクロールバーを出さない)
083         * @og.rev 3.8.9.5 (2007/09/12) PG名、ステップ名追加(開発ガイドライン対応)
084         * @og.rev 4.0.0.0 (2005/01/31) ResourceManager getMessage 関数を使用
085         * @og.rev 4.0.0.0 (2007/10/18) メッセージリソース統合( getResource().getMessage ⇒ getResource().getLabel )
086         * @og.rev 4.3.2.0 (2008/09/11) 行番号順ソート、メッセージのラベル(短)化、コメント出力
087         * @og.rev 4.3.4.5 (2009/01/08) 対応方法(概要説明)が存在すれば表示する
088         * @og.rev 4.3.7.6 (2009/07/15) 対応方法のパラメータ対応
089         *
090         * @param   errMsg  ErrorMessageオブジェクト
091         * @param   resource ResourceManager リソースマネージャー
092         *
093         * @return  HTML のテーブルタグに変換後の文字列(無ければ、ゼロストリング)
094         */
095        static String makeHTMLErrorTable( final ErrorMessage errMsg,final ResourceManager resource ) {
096                if( errMsg == null ) { return ""; }
097
098                final String[] names ;
099                if( errMsg.isSetPgStep() ) {
100                        // names = new String[] { "ROW_NO","KEKKA","MSGID","MESSAGE","PG","STEP" }; // 3.8.9.5 (2007/09/12)
101                        names = new String[] { "ROW_NO","KEKKA","MSGID","MESSAGE", "PG","STEP" }; // 3.8.9.5 (2007/09/12)
102                }
103                else {
104                        names = new String[] { "ROW_NO","KEKKA","MSGID","MESSAGE" };
105                }
106
107                int clmSize = names.length;
108
109                DBTableModel errTable = DBTableModelUtil.newDBTable();
110                errTable.init( clmSize );
111
112                for( int i=0; i<clmSize; i++ ) {
113                        DBColumn dbColumn = resource.makeDBColumn( names[i] );
114                        errTable.setDBColumn( i,dbColumn );
115                }
116
117                // 4.3.2.0 (2008/09/11) 行番号順ソート
118                ErrMsg[] errMsgs = errMsg.toArray();
119                Arrays.sort( errMsgs, errComp );
120
121                int tableRow = 0; // 4.3.4.5 (2009/01/08) テーブルモデルの行番号
122
123                for( int i=0; i<errMsg.size(); i++ ) {
124                        ErrMsg err = errMsgs[i];
125                        String[] clmVals = new String[clmSize];
126                        clmVals[0] = String.valueOf( err.getNo() );
127                        clmVals[1] = String.valueOf( err.getKekka() );
128                        clmVals[2] = err.getId();
129                        clmVals[3] = resource.getLabel( err );
130                        if( errMsg.isSetPgStep() ) {
131                                clmVals[4] = err.getPg();
132                                clmVals[5] = err.getStep();
133                        }
134                        errTable.addColumnValues( clmVals );
135                        // errTable.setRowWritable( i,false );  // 書込み禁止
136                        errTable.setRowWritable( tableRow, false );     // 4.3.4.5 (2009/01/08) 書込み禁止
137
138                        // 対応方法(概要説明)が存在すれば直下に一行追加する 4.3.4.5 (2009/01/08)
139                        // String desc = resource.getDescription( clmVals[2] );
140                        String desc = resource.getDescription( err ); // 4.3.7.6 (2009/07/15)
141                        if( desc != null && desc.length() > 0 ){
142                                tableRow++;
143                                String[] descVals = new String[clmSize];
144                                descVals[3] = desc;
145                                errTable.addColumnValues( descVals );
146                                errTable.setRowWritable( tableRow, false );
147                        }
148
149                        tableRow++;
150                }
151
152//              for( int i=0; i<errMsg.size(); i++ ) {
153//                      String[] clmVals = new String[clmSize];
154//                      clmVals[0] = String.valueOf( errMsg.getNo(i) );
155//                      clmVals[1] = String.valueOf( errMsg.getKekka(i) );
156//                      clmVals[2] = errMsg.getId(i);
157//                      ErrMsg err = errMsg.getErrMsg( i );                             // 4.0.0 (2005/01/31)
158////                    clmVals[3] = resource.getMessage( err );                // 4.0.0 (2005/01/31)
159//                      clmVals[3] = resource.getLabel( err );                  // 4.0.0 (2005/01/31)
160//                      if( errMsg.isSetPgStep() ) {
161//                              clmVals[4] = errMsg.getPg(i); // 3.8.9.5 (2007/09/12)
162//                              clmVals[5] = errMsg.getStep(i); // 3.8.9.5 (2007/09/12)
163//                      }
164//                      errTable.addColumnValues( clmVals );
165//                      errTable.setRowWritable( i,false );     // 書込み禁止
166//              }
167
168                // ここまでが、DBTableModel の作成。以下は、View での表示
169
170                ViewForm form = ViewFormFactory.newInstance( "HTMLTable" );
171
172                form.init( errTable );
173                if( ! errMsg.isOK() )  {        // 正常以外
174                        form.setBgColorCycle( -1 * errMsg.getKekka() ); // エラー処理時のゼブラ模様
175                        form.setNumberType( "delete" );                 // 番号欄を出さない。
176                        form.setUseTableSorter( false );                // ソート用リンクは出さない。
177//                      form.setUseScrollBar( false,null );             // 4.0.0 (2005/01/31) スクロールバー用のDIV要素を出力しない。
178                        form.setUseScrollBar( false );                  // 4.0.0 (2005/01/31) スクロールバー用のDIV要素を出力しない。
179                }
180
181                return form.create();
182        }
183
184        /**
185         * ErrorMessage オブジェクトと、ResourceManager より、表示用 HTMLテーブルを作成します。
186         * このメソッドでは、エラーメッセージ及びエラーコードを一覧形式で表示します。
187         *
188         * @param   errMsg  ErrorMessageオブジェクト
189         * @param   resource ResourceManager リソースマネージャー
190         *
191         * @return  HTML のテーブルタグに変換後の文字列(無ければ、ゼロストリング)
192         */
193        static String makeHTMLSimpleErrorList( final ErrorMessage errMsg,final ResourceManager resource ) {
194                if( errMsg == null ) { return ""; }
195
196                String[] names = new String[] { "MESSAGE" };
197
198                int clmSize = names.length;
199
200                DBTableModel errTable = DBTableModelUtil.newDBTable();
201                errTable.init( clmSize );
202
203                for( int i=0; i<clmSize; i++ ) {
204                        DBColumn dbColumn = resource.makeDBColumn( names[i] );
205                        errTable.setDBColumn( i,dbColumn );
206                }
207
208                ErrMsg[] errMsgs = errMsg.toArray();
209                Arrays.sort( errMsgs, errComp );
210
211                for( int i=0; i<errMsg.size(); i++ ) {
212                        ErrMsg err = errMsgs[i];
213                        String[] clmVals = new String[clmSize];
214                        clmVals[0] = resource.getShortLabel( err.getId() ) + "(" + err.getId() + ")";
215                        errTable.addColumnValues( clmVals );
216                        errTable.setRowWritable( i,false );
217                }
218
219                // ここまでが、DBTableModel の作成。以下は、View での表示
220                ViewForm form = ViewFormFactory.newInstance( "HTMLSimpleList" );
221                form.init( errTable );
222
223                if( ! errMsg.isOK() )  {        // 正常以外
224                        form.setBgColorCycle( -1 * errMsg.getKekka() ); // エラー処理時のゼブラ模様
225                }
226
227                return form.create();
228        }
229
230        /**
231         * 指定の文字列から、数字部のみ取り出して、変換して返します。
232         *
233         * 例えば、"200px" を 200 に変換します。
234         *
235         * @og.rev 4.0.0.0 (20065/12/05) 新規作成
236         *
237         * @param       inStr   入力する文字列
238         *
239         * @return  変換後の数字
240         */
241        static int changeInt( final String inStr ) {
242                if( inStr == null || inStr.length() == 0 ) { return 0; }
243
244                int adrs;
245                for( adrs=0; adrs<inStr.length(); adrs++ ) {
246                        char ch = inStr.charAt(adrs);
247                        if( ch < '0' || ch > '9' ) { break; }
248                }
249
250                if( adrs == 0 ) { return 0; }
251
252                return Integer.parseInt( inStr.substring( 0,adrs ) );
253        }
254
255        // 4.3.2.0 (2008/09/11) 行番号順ソートのための、Comparator オブジェクト
256        private static final Comparator<? super ErrMsg> errComp =
257                new Comparator<ErrMsg>() {
258                        public int compare( final ErrMsg err1,final ErrMsg err2 ) {
259                                return err1.getNo() - err2.getNo() ;
260                        }
261                } ;
262
263}