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.hayabusa.common.HybsSystem; 019import org.opengion.hayabusa.common.HybsSystemException; 020 021import org.opengion.hayabusa.db.AbstractEditor; 022import org.opengion.hayabusa.db.CellEditor; 023import org.opengion.hayabusa.db.DBColumn; 024import org.opengion.hayabusa.db.DBColumnConfig; 025import org.opengion.hayabusa.resource.ResourceFactory; 026import org.opengion.hayabusa.resource.ResourceManager; 027 028/** 029 * 動的カラムのデータを編集する場合に使用するエディタークラスです。 030 * 031 * 値の文字列より、DBColumn を作成して、そのエディター文字列を動的に作成します。 032 * 033 * このエディタはeventColumnに対応していません。 034 * 035 * カラムの表示に必要な属性は、DBColumn オブジェクト より取り出します。 036 * このクラスは、DBColumn オブジェクト毎に1つ作成されます。 037 * @og.group データ編集 038 * 039 * @version 4.0 040 * @author Kazuhiko Hasegawa 041 * @since JDK5.0, 042 */ 043public class Editor_COLUMN extends AbstractEditor { 044 /** このプログラムのVERSION文字列を設定します。 {@value} */ 045 private static final String VERSION = "6.4.4.2 (2016/04/01)" ; 046 047 private final String lang ; 048 049 /** 050 * デフォルトコンストラクター。 051 * このコンストラクターで、基本オブジェクトを作成します。 052 * 053 * @og.rev 3.1.1.1 (2003/04/03) 各オブジェクトから自分のインスタンスを返すファクトリメソッドを追加。 054 * 055 */ 056 public Editor_COLUMN() { 057 super(); // 6.4.1.1 (2016/01/16) PMD refactoring. It is a good practice to call super() in a constructor 058 lang = null; 059 } 060 061 /** 062 * DBColumnオブジェクトを指定したprivateコンストラクター。 063 * 064 * @og.rev 3.1.1.1 (2003/04/03) 各オブジェクトから自分のインスタンスを返すファクトリメソッドを追加。 065 * @og.rev 6.4.4.2 (2016/04/01) nameのfinal化 066 * 067 * @param clm DBColumnオブジェクト 068 */ 069 private Editor_COLUMN( final DBColumn clm ) { 070 // super(); // 6.4.1.1 (2016/01/16) PMD refactoring. It is a good practice to call super() in a constructor 071 super( clm ); // 6.4.4.2 (2016/04/01) nameのfinal化 072 // name = clm.getName(); 073 lang = clm.getLang(); 074 } 075 076 /** 077 * 各オブジェクトから自分のインスタンスを返します。 078 * 自分自身をキャッシュするのか、新たに作成するのかは、各サブクラスの実装に 079 * まかされます。 080 * 081 * @og.rev 3.1.1.1 (2003/04/03) 各オブジェクトから自分のインスタンスを返すファクトリメソッドを追加。 082 * @og.rev 3.1.2.1 (2003/04/10) synchronized を、削除します。 083 * 084 * @param clm DBColumnオブジェクト 085 * 086 * @return CellEditorオブジェクト 087 * @og.rtnNotNull 088 */ 089 public CellEditor newInstance( final DBColumn clm ) { 090 return new Editor_COLUMN( clm ); 091 } 092 093 /** 094 * データの編集用文字列を返します。 095 * 096 * @og.rev 3.5.2.0 (2003/10/20) 値で動的カラムが作成できない場合に、エラーメッセージを追加。 097 * 098 * @param value 入力値 099 * 100 * @return データの表示用文字列 101 */ 102 @Override 103 public String getValue( final String value ) { 104 final ResourceManager resource = ResourceFactory.newInstance( lang ) ; 105 final DBColumn dbColumn = resource.getDBColumn( value ); 106 107 if( dbColumn == null ) { 108 final String errMsg = "指定のカラムの値[]で、動的カラムは作成できません。" 109 + CR 110 + " name=[" + name + "]" 111 + " value=[" + value + "]"; 112 throw new HybsSystemException( errMsg ); 113 } 114 115 return dbColumn.getEditorValue( null ); 116 } 117 118 /** 119 * name属性を変えた、データ表示/編集用のHTML文字列を作成します。 120 * テーブル上の name に 行番号を付加して、名前_行番号 で登録するキーを作成し、 121 * リクエスト情報を1つ毎のフィールドで処理できます。 122 * 123 * @param row 行番号 124 * @param value 入力値 125 * 126 * @return データ表示/編集用の文字列 127 */ 128 @Override 129 public String getValue( final int row,final String value ) { 130 final ResourceManager resource = ResourceFactory.newInstance( lang ) ; 131 final DBColumn dbColumn = resource.getDBColumn( value ); 132 133 final String name2 = name + HybsSystem.JOINT_STRING + row ; 134 final DBColumnConfig config ; 135 if( dbColumn == null ) { 136 config = new DBColumnConfig( name2 ) ; 137 } 138 else { 139 config = dbColumn.getConfig() ; 140 config.setName( name2 ); 141 } 142 final DBColumn newColmn = new DBColumn( config ); 143 144 return newColmn.getEditorValue( null ); 145 } 146}