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.column; 017 018import org.opengion.fukurou.util.StringUtil; 019import org.opengion.fukurou.util.TagBuffer; 020import org.opengion.hayabusa.common.HybsSystem; 021import org.opengion.hayabusa.db.AbstractRenderer; 022import org.opengion.hayabusa.db.CellRenderer; 023import org.opengion.hayabusa.db.DBColumn; 024 025/** 026 * TEXTAREA レンデラは、カラムのデータをテキストエリアで表示する場合に 027 * 使用するクラスです。 028 * readonlyのテキストエリアでclass=renderer-textareaとして出力し、 029 * name属性は付けません。(データは送信されません) 030 * エリアの縦、横サイズはエディタのテキストエリアと同様にして算出されます。 031 * 032 * カラムの表示に必要な属性は、DBColumn オブジェクト より取り出します。 033 * このクラスは、DBColumn オブジェクト毎に1つ作成されます。 034 * 035 * @og.rev 4.3.5.7 (2009/03/22) 新規作成 036 * @og.group データ編集 037 * 038 * @version 4.0 039 * @author Takahashi Masakazu 040 * @since JDK5.0, 041 */ 042public class Renderer_TEXTAREA extends AbstractRenderer { 043 /** このプログラムのVERSION文字列を設定します。 {@value} */ 044 private static final String VERSION = "8.5.6.1 (2024/03/29)" ; 045 046 /** 表示フィールドの大きさ */ 047 private final int COLUMNS_MAXSIZE = HybsSystem.sysInt( "HTML_COLUMNS_MAXSIZE" ) ; 048 /** viewタグで表示する場合のカラムの大きさ */ 049 private final int VIEW_COLUMNS_MAXSIZE = HybsSystem.sysInt( "HTML_VIEW_COLUMNS_MAXSIZE" ) ; 050 051// private final TagBuffer tagBuffer = new TagBuffer(); // 7.4.2.0 (2021/04/30) 052 053// private String size1; 054// private String size2; 055 /** 検索時の列数1 */ private String cols1; // 8.5.6.1 (2024/03/29) size → cols に統一 056 /** 検索時の行数1 */ private String rows1; 057 /** 登録時の列数2 */ private String cols2; // 8.5.6.1 (2024/03/29) size → cols に統一 058 /** 登録時の行数2 */ private String rows2; 059 060 /** 061 * デフォルトコンストラクター。 062 * このコンストラクターで、基本オブジェクトを作成します。 063 * 064 */ 065 public Renderer_TEXTAREA() { super(); } // これも、自動的に呼ばれるが、空のメソッドを作成すると警告されるので、明示的にしておきます。 066 067 /** 068 * DBColumnオブジェクトを指定したprivateコンストラクター。 069 * 070 * textareaのサイズを決めるため、sizeとrowを決定する 071 * editorの計算を移植。 072 * 073 * @og.rev 6.2.0.0 (2015/02/27) フィールドサイズ 追加(VIEW_LENGTHと分離して、役割を明確にする) 074 * @og.rev 8.5.5.1 (2024/02/29) spotbugs CT_CONSTRUCTOR_THROW(コンストラクタで、Excweptionを出さない) 075 * @og.rev 8.5.6.1 (2024/03/29) クラス名を RowSizeUtil → ColumnUtil に変更します。 076 * 077 * @param clm DBColumnオブジェクト 078 */ 079 private Renderer_TEXTAREA( final DBColumn clm ) { 080 // 6.4.1.1 (2016/01/16) PMD refactoring. It is a good practice to call super() in a constructor 081 super(); 082 083 // 6.2.0.0 (2015/02/27) フィールドサイズ 追加(VIEW_LENGTHと分離して、役割を明確にする) 084// size1 = String.valueOf( clm.getFieldSize( COLUMNS_MAXSIZE ) ); 085// size2 = String.valueOf( clm.getFieldSize( VIEW_COLUMNS_MAXSIZE ) ); 086 cols1 = String.valueOf( clm.getFieldSize( COLUMNS_MAXSIZE ) ); 087 cols2 = String.valueOf( clm.getFieldSize( VIEW_COLUMNS_MAXSIZE ) ); 088 089 // 8.5.5.1 (2024/02/29) spotbugs CT_CONSTRUCTOR_THROW(コンストラクタで、Excweptionを出さない) 090// final int r1 = clm.getTotalSize() / Integer.parseInt( size1 ) + 1; 091// if( r1 > 5 ) { 092// rows1 = "5"; 093// } 094// else { 095// rows1 = String.valueOf( r1 ); 096// } 097// 098// final int r2 = clm.getTotalSize() / Integer.parseInt( size2 ) + 1; 099// if( r2 > 5 ) { 100// rows2 = "5"; 101// } 102// else { 103// rows2 = String.valueOf( r2 ); 104// } 105 final int totalSize = clm.getTotalSize(); // 8.5.5.1 (2024/02/29) 106// rows1 = RowSizeUtil.getRowSize( totalSize,size1 ); // 8.5.5.1 (2024/02/29) 107// rows2 = RowSizeUtil.getRowSize( totalSize,size2 ); // 8.5.5.1 (2024/02/29) 108 rows1 = ColumnUtil.getRowSize( totalSize,cols1 ); // 8.5.6.1 (2024/03/29) 109 rows2 = ColumnUtil.getRowSize( totalSize,cols2 ); // 8.5.6.1 (2024/03/29) 110 111 final String param = StringUtil.nval( clm.getRendererParam(), clm.getViewLength() ); 112 if( param != null && param.length() != 0 ) { 113 final int st = param.indexOf( ',' ); 114 if( st > 0 ) { 115 rows1 = param.substring( 0, st ); 116 rows2 = rows1; 117// size1 = param.substring( st + 1 ); 118// size2 = size1; 119 cols1 = param.substring( st+1 ); 120 cols2 = cols1; 121 } 122 } 123 } 124 125 /** 126 * 各オブジェクトから自分のインスタンスを返します。 127 * 自分自身をキャッシュするのか、新たに作成するのかは、各サブクラスの実装に 128 * まかされます。 129 * 130 * @param clm DBColumnオブジェクト 131 * 132 * @return CellEditorオブジェクト 133 * @og.rtnNotNull 134 */ 135 public CellRenderer newInstance( final DBColumn clm ) { 136 return new Renderer_TEXTAREA( clm ); 137 } 138 139 /** 140 * データの表示用文字列を返します。 141 * 142 * @og.rev 6.0.4.0 (2014/11/28) ロジックの共通化 143 * 144 * @param value 入力値 145 * 146 * @return データの表示用文字列 147 * @og.rtnNotNull 148 */ 149 @Override 150 public String getValue( final String value ) { 151// return getRowsColsValue( value==null ? "" : value, size1, rows1 ); 152 return getRowsColsValue( value==null ? "" : value, cols1, rows1 ); 153 } 154 155 /** 156 * データの表示用文字列を返します。 157 * 158 * @og.rev 6.0.4.0 (2014/11/28) ロジックの共通化 159 * 160 * @param row 行番号 161 * @param value 入力値 162 * 163 * @return データ表示用の文字列 164 * @og.rtnNotNull 165 */ 166 @Override 167 public String getValue( final int row,final String value ) { 168// return getRowsColsValue( value==null ? "" : value, size2, rows2 ); 169 return getRowsColsValue( value==null ? "" : value, cols2, rows2 ); 170 } 171 172 /** 173 * データ出力用の文字列を作成します。 174 * ファイル等に出力する形式を想定しますので、HTMLタグを含まない 175 * データを返します。 176 * 基本は、#getValue( String ) をそのまま返します。 177 * 178 * @og.rev 6.0.4.0 (2014/11/28) データ出力用のレンデラー 179 * 180 * @param value 入力値 181 * 182 * @return データ出力用の文字列 183 * @og.rtnNotNull 184 * @see #getValue( String ) 185 */ 186 @Override 187 public String getWriteValue( final String value ) { 188 return value == null ? "" : value; 189 } 190 191 /** 192 * データの表示用文字列を返します。 193 * 194 * @og.rev 6.0.4.0 (2014/11/28) ロジックの共通化 195 * @og.rev 7.4.2.0 (2021/04/30) tagBuffer は使っていないので削除 196 * 197 * @param value 入力値 表示文字列 198 * @param cols 最小カラム数 199 * @param rows 最小行数 200 * 201 * @return データ表示用の文字列 202 * @og.rtnNotNull 203 */ 204 private String getRowsColsValue( final String value,final String cols, final String rows ) { 205 // 6.1.1.0 (2015/01/17) TagBufferの連結記述 206 return new TagBuffer( "textarea" ) 207 .add( "cols" , cols ) 208 .add( "rows" , rows ) 209 .add( "readonly", "readonly" ) 210 .add( "class" , "renderer-textarea" ) 211// .add( tagBuffer.makeTag() ) 7.4.2.0 (2021/04/30) 212 .addBody( value ) 213 .makeTag(); 214 } 215}