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.fukurou.system.OgBuilder; // 6.4.4.1 (2016/03/18) 019import org.opengion.fukurou.util.XHTMLTag; 020import org.opengion.hayabusa.common.HybsSystem; 021import org.opengion.hayabusa.html.AbstractViewForm; 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 = "8.5.4.0 (2023/12/01)" ; 042 043 /** 4.0.0 (2005/01/31) HTML_LABEL_SEPARATOR を boolean 変数として取得します。 */ 044 private final String CLM = HybsSystem.sysBool( "HTML_LABEL_SEPARATOR" ) ? ":" : "" ; 045 046 /** 項目間のスペース */ 047 private String columnSpace = HybsSystem.sys( "HTML_COLUMS_SPACE" ) ; 048 /** 縦方向の最大表示件数 */ 049 private int maxRowNumber = HybsSystem.sysInt( "HTML_MAXROW_NUMBER" ) ; 050 private static final int PAGE_SIZE = 1; 051 052 /** 053 * デフォルトコンストラクター 054 * 055 * @og.rev 6.4.2.0 (2016/01/29) PMD refactoring. Each class should declare at least one constructor. 056 */ 057 public ViewForm_HTMLTextField() { super(); } // これも、自動的に呼ばれるが、空のメソッドを作成すると警告されるので、明示的にしておきます。 058 059 /** 060 * DBTableModel から HTML文字列を作成して返します。 061 * startNo(表示開始位置)から、pageSize(表示件数)までのView文字列を作成します。 062 * 表示残りデータが pageSize 以下の場合は、残りのデータをすべて出力します。 063 * 064 * @og.rev 2.0.1.0 (2002/10/10) ラベルとフィールドのセパレーターとして、コロン(:)を使用するかどうかを指定できる 065 * @og.rev 3.6.0.5 (2004/10/18) 印刷時の罫線出力関連機能の追加。id 属性を出力します。 066 * @og.rev 5.6.2.3 (2013/03/22) DBColumn に、useSLabel="false" の値をセットします。 067 * @og.rev 8.2.0.2 (2022/06/24) HTML5廃止対応 068 * 069 * @param startNo 表示開始位置 070 * @param pageSize 表示件数 071 * @return DBTableModelから作成された HTML文字列 072 * @og.rtnNotNull 073 */ 074 public String create( final int startNo, final int pageSize ) { 075 if( getRowCount() == 0 ) { return ""; } // 暫定処置 076 077 noSLabelSetting(); // 5.6.2.3 (2013/03/22) DBColumn に、useSLabel="false" の値をセットします。 078 079 final int numberOfColumns = getColumnDisplayCount() ; 080 // 6.3.9.1 (2015/11/27) Found 'DD'-anomaly for variable(PMD) 081 final String[] label = new String[numberOfColumns]; 082 final String[] value = new String[numberOfColumns]; 083 084 final int realCount = getColumnCount(); 085 int clmNo = 0; 086 for( int i=0; i<realCount; i++ ) { 087 if( isColumnDisplay(i) ) { 088 label[clmNo] = getColumnLabel(i); 089 value[clmNo] = getValueLabel(startNo,i); 090 clmNo++ ; 091 } 092 } 093 094 final int columnNumber = numberOfColumns / maxRowNumber + 1 ; 095 096 final StringBuilder out = new StringBuilder( BUFFER_LARGE ) 097 .append( getCountForm( startNo,pageSize ) ) 098 .append( makeSelectNo( startNo ) ).append( CR ) 099// .append("<table id=\"viewTextField\" border=\"0\" summary=\"ViewForm_HTMLTextField\" >"); // 3.6.0.5 (2004/10/18) 100// .append("<table id=\"viewTextField\" border=\"0\" >"); // 8.2.0.2 (2022/06/24) Modify 101 .append("<table id=\"viewTextField\" >"); // 8.5.4.0 (2023/12/01) HTML5廃止対応(border属性削除) 102 103 final int rowNumber = (numberOfColumns +1 )/ columnNumber ; 104 for( int row=0; row<rowNumber; row++ ) { 105 out.append("<tr>").append( CR ); 106 for( int clm=0; clm<columnNumber; clm++ ) { 107 final int realClm = row + clm * rowNumber ; 108 out.append("<td id=\"label\">"); 109 if( realClm < numberOfColumns ) { 110 out.append( label[realClm] ) 111 .append( CLM ); 112 } 113 out.append("</td>").append( CR ) 114 .append("<td>"); 115 if( realClm < numberOfColumns ) { out.append( value[realClm] ); } 116 out.append("</td>").append( CR ) 117// .append("<td width=\"").append( columnSpace ).append("\"> </td>").append( CR ); 118 .append("<td style=\"width:").append( columnSpace ).append(";\"> </td>").append( CR ); // 8.2.0.2 (2022/06/24) Modify 119 } 120 out.append("</tr>").append( CR ); 121 } 122 out.append("</table>"); 123 124 return out.toString(); 125 } 126 127 /** 128 * DBColumn に、useSLabel="false" の値をセットします。 129 * 130 * @og.rev 5.6.2.3 (2013/03/22) 新規追加 131 * 132 */ 133 protected void noSLabelSetting() { 134 final int realCount = getColumnCount(); 135 136 for( int clmNo=0; clmNo<realCount; clmNo++ ) { 137 final DBColumnConfig config = getDBColumn( clmNo ).getConfig(); 138 config.setUseSLabel( "false" ); 139 140 setDBColumn( clmNo, new DBColumn( config ) ); 141 } 142 } 143 144 /** 145 * 画面に選択された番号を表示します。 146 * また、書き込み許可がある場合は、選択用の隠しフィールドを作成します。 147 * 148 * @og.rev 3.5.5.5 (2004/04/23) hidden の出力に、XHTMLTag.hidden を使用します。 149 * @og.rev 6.4.4.1 (2016/03/18) StringBuilderの代わりに、OgBuilderを使用する。 150 * 151 * @param row 行番号 152 * @return 隠しフィールドのHTML文字列 153 * @og.rtnNotNull 154 */ 155 protected String makeSelectNo( final int row ) { 156 return new OgBuilder() 157 .appendIf( isWritable( row ) , String.valueOf( row ) 158 , rowKey -> XHTMLTag.hidden( HybsSystem.ROW_SEL_KEY,rowKey ) ) 159 .toString(); 160 } 161 162 /** 163 * 内容をクリア(初期化)します。 164 * 165 * @og.rev 3.1.1.0 (2003/03/28) 同期メソッド(synchronized付き)を非同期に変更する。 166 * 167 */ 168 @Override 169 public void clear() { 170 super.clear(); 171 columnSpace = HybsSystem.sys( "HTML_COLUMS_SPACE" ) ; // 項目間のスペース 172 maxRowNumber = HybsSystem.sysInt( "HTML_MAXROW_NUMBER" ) ; // 縦方向の最大表示件数 173 } 174 175 /** 176 * 表示件数を取得します。 177 * 178 * @return 表示件数 179 */ 180 @Override 181 public int getPageSize() { 182 return PAGE_SIZE; 183 } 184 185 /** 186 * フォーマットメソッドを使用できるかどうかを問い合わせます。 187 * 188 * @return フォーマットメソッドの使用有無 [true:使用可能/false:使用不可能] 189 */ 190 public boolean canUseFormat() { 191 return false; 192 } 193 194 /** 195 * カラムのラベル名(長)を返します。 196 * カラムの項目名に対して、見える形の文字列を返します。 197 * 一般には、リソースバンドルと組合せて、各国ロケール毎にラベルを切替えます。 198 * 199 * @og.rev 4.0.0.0 (2005/01/31) 新規追加( longLabel を返します。) 200 * 201 * @param column カラム番号 202 * @return カラムのラベル名(長) 203 */ 204 @Override 205 protected String getColumnLabel( final int column ) { 206 return getDBColumn( column ).getLongLabel(); 207 } 208 209 /** 210 * 表示項目の編集(並び替え)が可能かどうかを返します。 211 * 212 * @og.rev 5.1.6.0 (2010/05/01) 新規追加 213 * 214 * @return 表示項目の編集可否 [true:可能/false:不可能] 215 */ 216 @Override 217 public boolean isEditable() { 218 return false; 219 } 220}