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.plugin.view;
017
018import org.opengion.hayabusa.common.HybsSystem;
019import org.opengion.hayabusa.html.AbstractViewForm;
020import org.opengion.fukurou.util.XHTMLTag;
021
022import org.opengion.hayabusa.db.DBColumn;
023import org.opengion.hayabusa.db.DBColumnConfig;
024
025/**
026 * 検索結果から、テキストフィールドタグを自動生成する、テキストフィールド作成クラスです。
027 *
028 * AbstractViewForm により、setter/getterメソッドのデフォルト実装を提供しています。
029 * 各HTMLのタグに必要な setter/getterメソッドのみ,追加定義しています。
030 *
031 * AbstractViewForm を継承している為,ロケールに応じたラベルを出力させる事が出来ます。
032 *
033 * @og.group 画面表示
034 *
035 * @version  4.0
036 * @author       Kazuhiko Hasegawa
037 * @since    JDK5.0,
038 */
039public class ViewForm_HTMLTextField extends AbstractViewForm {
040        //* このプログラムのVERSION文字列を設定します。   {@value} */
041        private static final String VERSION = "5.6.2.3 (2013/03/22)" ;
042
043        // 4.0.0 (2005/01/31) HTML_LABEL_SEPARATOR を boolean 変数として取得します。
044        private final String CLM = HybsSystem.sysBool( "HTML_LABEL_SEPARATOR" ) ? ":" : "" ;
045
046        private String columnSpace = HybsSystem.sys( "HTML_COLUMS_SPACE" ) ;            // 項目間のスペース
047        private int maxRowNumber   = HybsSystem.sysInt( "HTML_MAXROW_NUMBER" ) ;        // 縦方向の最大表示件数
048        private static final int PAGE_SIZE = 1;
049
050        /**
051         * DBTableModel から HTML文字列を作成して返します。
052         * startNo(表示開始位置)から、pageSize(表示件数)までのView文字列を作成します。
053         * 表示残りデータが pageSize 以下の場合は,残りのデータをすべて出力します。
054         *
055         * @og.rev 2.0.1.0 (2002/10/10) ラベルとフィールドのセパレーターとして、コロン(:)を使用するかどうかを指定できる
056         * @og.rev 3.6.0.5 (2004/10/18) 印刷時の罫線出力関連機能の追加。id 属性を出力します。
057         * @og.rev 5.6.2.3 (2013/03/22) DBColumn に、useSLabel="false" の値をセットします。
058         *
059         * @param  startNo        表示開始位置
060         * @param  pageSize   表示件数
061         *
062         * @return      DBTableModelから作成された HTML文字列
063         */
064        public String create( final int startNo, final int pageSize )  {
065                if( getRowCount() == 0 ) { return ""; } // 暫定処置
066
067                noSLabelSetting();              // 5.6.2.3 (2013/03/22) DBColumn に、useSLabel="false" の値をセットします。
068
069                int numberOfColumns = getColumnDisplayCount() ;
070                String[] label = new String[numberOfColumns];
071                String[] value = new String[numberOfColumns];
072
073                int realCount = getColumnCount();
074                int clmNo = 0;
075                for( int i=0; i<realCount; i++ ) {
076                        if( isColumnDisplay(i) ) {
077                                label[clmNo] = getColumnLabel(i);
078                                value[clmNo] = getValueLabel(startNo,i);
079                                clmNo++ ;
080                        }
081                }
082
083                int columnNumber = numberOfColumns / maxRowNumber + 1 ;
084
085                StringBuilder out = new StringBuilder( HybsSystem.BUFFER_LARGE );
086
087                out.append( getCountForm( startNo,pageSize ) );
088                out.append( makeSelectNo( startNo ) ).append( HybsSystem.CR );
089
090                out.append("<table id=\"viewTextField\" border=\"0\" summary=\"ViewForm_HTMLTextField\" >");    // 3.6.0.5 (2004/10/18)
091                int rowNumber = (numberOfColumns +1 )/ columnNumber ;
092                for( int row=0; row<rowNumber; row++ ) {
093                        out.append("<tr>").append( HybsSystem.CR );
094                        for( int clm=0; clm<columnNumber; clm++ ) {
095                                int realClm = row + clm * rowNumber ;
096                                out.append("<td id=\"label\">");
097                                if( realClm < numberOfColumns ) {
098                                        out.append( label[realClm] );
099                                        out.append( CLM );
100                                }
101                                out.append("</td>").append( HybsSystem.CR );
102                                out.append("<td>");
103                                if( realClm < numberOfColumns ) { out.append( value[realClm] ); }
104                                out.append("</td>").append( HybsSystem.CR );
105                                out.append("<td width=\"").append( columnSpace ).append("\"> </td>").append( HybsSystem.CR );
106                        }
107                        out.append("</tr>").append( HybsSystem.CR );
108                }
109                out.append("</table>");
110
111                return out.toString();
112        }
113
114        /**
115         * DBColumn に、useSLabel="false" の値をセットします。
116         *
117         * @og.rev 5.6.2.3 (2013/03/22) 新規追加
118         *
119         */
120        protected void noSLabelSetting() {
121                int realCount = getColumnCount();
122
123                for( int clmNo=0; clmNo<realCount; clmNo++ ) {
124                        DBColumnConfig config = getDBColumn( clmNo ).getConfig();
125                        config.setUseSLabel( "false" );
126
127                        setDBColumn( clmNo, new DBColumn( config ) );
128                }
129        }
130
131        /**
132         * 画面に選択された番号を表示します。
133         * また、書き込み許可がある場合は、選択用の隠しフィールドを作成します。
134         *
135         * @og.rev 3.5.5.5 (2004/04/23) hidden の出力に、XHTMLTag.hidden を使用します。
136         *
137         * @param  row   行番号
138         *
139         * @return      隠しフィールドのHTML文字列
140         */
141        protected String makeSelectNo( final int row ) {
142                StringBuilder out = new StringBuilder( HybsSystem.BUFFER_MIDDLE );
143
144                if( isWritable( row ) ) {
145                        // XHTMLTag.hidden( name,value ) を使用。
146                        out.append( XHTMLTag.hidden( HybsSystem.ROW_SEL_KEY,String.valueOf( row ) ) );
147                }
148
149                return out.toString();
150        }
151
152        /**
153         * 内容をクリア(初期化)します。
154         *
155         * @og.rev 3.1.1.0 (2003/03/28) 同期メソッド(synchronized付き)を非同期に変更する。
156         *
157         */
158        @Override
159        public void clear() {
160                super.clear();
161                columnSpace   = HybsSystem.sys( "HTML_COLUMS_SPACE" ) ;                 // 項目間のスペース
162                maxRowNumber  = HybsSystem.sysInt( "HTML_MAXROW_NUMBER" ) ;             // 縦方向の最大表示件数
163        }
164
165        /**
166         * 表示件数を取得します。
167         *
168         * @return      表示件数
169         */
170        @Override
171        public int getPageSize() {
172                return PAGE_SIZE;
173        }
174
175        /**
176         * フォーマットメソッドを使用できるかどうかを問い合わせます。
177         *
178         * @return  使用可能(true)/ 使用不可能(false)
179         */
180        public boolean canUseFormat() {
181                return false;
182        }
183
184        /**
185         * カラムのラベル名(長)を返します。
186         * カラムの項目名に対して,見える形の文字列を返します。
187         * 一般には,リソースバンドルと組合せて,各国ロケール毎にラベルを
188         * 切替えます。
189         *
190         * @og.rev 4.0.0.0 (2005/01/31) 新規追加( longLabel を返します。)
191         *
192         * @param       column カラム番号
193         *
194         * @return      カラムのラベル名(長)
195         */
196        @Override
197        protected String getColumnLabel( final int column ) {
198                return getDBColumn( column ).getLongLabel();
199        }
200
201        /**
202         * 表示項目の編集(並び替え)が可能かどうかを返します
203         *
204         * @og.rev 5.1.6.0 (2010/05/01) 新規追加
205         *
206         * @return      表示項目の編集(並び替え)が可能かどうか(false:不可能)
207         */
208        @Override
209        public boolean isEditable() {
210                return false;
211        }
212}