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.hayabusa.db.AbstractRenderer; 020import org.opengion.hayabusa.db.CellRenderer; 021import org.opengion.hayabusa.db.DBColumn; 022 023/** 024 * RICHLABEL レンデラは、特殊文字のエスケープを元に戻して表示する場合に 025 * 使用するクラスです。 026 * readonlyのテキストエリアでname属性は付けません。(データは送信されません) 027 * 028 * カラムの表示に必要な属性は, DBColumn オブジェクト より取り出します。 029 * このクラスは、DBColumn オブジェクト毎に1つ作成されます。 030 * 031 * @og.rev 5.9.33.0 (2018/06/01) 新規作成 032 * @og.rev 5.10.1.0 (2018/06/29) ignoreStrに値を追加。 033 * @og.group データ編集 034 * 035 * @version 5.9.33.0 036 * @author T.OTA 037 * @since JDK7.0, 038 */ 039public class Renderer_RICHLABEL extends AbstractRenderer { 040 //* このプログラムのVERSION文字列を設定します。 {@value} */ 041 private static final String VERSION = "5.9.33.0 (2018/06/01)" ; 042 043 private static final CellRenderer dbCell = new Renderer_RICHLABEL(); 044 045 // 2018/06/28 MODIFY pre,img,table,thead,tbody,tr,th,td,ul,li,h[数値]を追加 046// private static final String ignoreStr = "strong|font|a|br|p|span|div"; 047 private static final String ignoreStr = "strong|font|a|br|p|span|div|pre|img|table|thead|tbody|tr|th|td|ul|li|h\\d"; 048 049 /** 050 * デフォルトコンストラクター。 051 * このコンストラクターで、基本オブジェクトを作成します。 052 * 053 */ 054 public Renderer_RICHLABEL() { super(); } // これも、自動的に呼ばれるが、空のメソッドを作成すると警告されるので、明示的にしておきます。 055 056 /** 057 * 各オブジェクトから自分のインスタンスを返します。 058 * 自分自身をキャッシュするのか、新たに作成するのかは、各サブクラスの実装に 059 * まかされます。 060 * 061 * @param clm DBColumnオブジェクト 062 * 063 * @return CellEditorオブジェクト 064 */ 065 public CellRenderer newInstance( final DBColumn clm ) { 066 return dbCell; 067 } 068 069 /** 070 * データの表示用文字列を返します。 071 * 072 * @param value 入力値 073 * 074 * @return データの表示用文字列 075 */ 076 @Override 077 public String getValue( final String value ) { 078 return StringUtil.escapeFilter( value,ignoreStr ); 079 } 080}