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.HybsDateUtil; 019import org.opengion.hayabusa.common.HybsSystem; 020import org.opengion.hayabusa.db.AbstractRenderer; 021import org.opengion.hayabusa.db.CellRenderer; 022import org.opengion.hayabusa.db.DBColumn; 023 024// import java.text.SimpleDateFormat; 025import java.util.Calendar; 026// import java.util.Locale; 027 028/** 029 * DATE レンデラーは、カラムのデータを表示パラメータで指定されたフォーマットで 030 * 日付表示する場合に使用するクラスです。 031 * 6桁未満のデータの場合はフォーマットをかけずにそのまま出力します。 032 * 033 * 表示パラメータで指定されたフォーマットを、java.text.SimpleDateFormat で 034 * 解析してフォーマット変換します。 035 * フォーマットルールは、{@link java.text.SimpleDateFormat} を参照願います。 036 * フォーマット初期値はシステムリソースのSYS_TIMEです。 037 * 038 * カラムの表示に必要な属性は, DBColumn オブジェクト より取り出します。 039 * このクラスは、DBColumn オブジェクト毎に1つ作成されます。 040 * 041 * @og.rev 3.5.0.0 (2003/09/17) 新規作成 042 * @og.rev 5.4.3.6 (2012/01/19) コメント修正 043 * @og.group データ表示 044 * 045 * @version 4.0 046 * @author Kazuhiko Hasegawa 047 * @since JDK5.0, 048 */ 049public class Renderer_DATE extends AbstractRenderer { 050 //* このプログラムのVERSION文字列を設定します。 {@value} */ 051 private static final String VERSION = "5.5.7.2 (2012/10/09)" ; 052 053// private final SimpleDateFormat format ; 054 private final String format ; // 5.5.7.2 (2012/10/09) HybsDateUtil を利用 055 private final String defValue ; 056 057 /** 058 * デフォルトコンストラクター。 059 * このコンストラクターで、基本オブジェクトを作成します。 060 * 061 */ 062 public Renderer_DATE() { 063 format = null; 064 defValue = null; 065 } 066 067 /** 068 * 引数つきコンストラクター。 069 * 070 * @og.rev 3.5.1.0 (2003/10/03) 初期値が nullの場合は、""、8桁以下はそのまま返す。 071 * @og.rev 3.8.5.3 (2006/08/01) 日付を6桁以上 とし、それ以下はそのまま返す。 072 * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用するように修正します。 073 * 074 * @param clm DBColumnオブジェクト 075 */ 076 private Renderer_DATE( final DBColumn clm ) { 077 078 String fm = clm.getRendererParam(); 079 if( fm == null || fm.length() == 0 || fm.equals( "_" ) ) { 080 fm = HybsSystem.sys( "SYS_TIME" ); 081 } 082// format = new SimpleDateFormat( fm,Locale.JAPAN ); 083 format = fm; // 5.5.7.2 (2012/10/09) HybsDateUtil を利用 084 085 String defv = clm.getDefault(); 086 if( defv == null || defv.equals( "_" ) ) { 087 defValue = ""; 088 } 089 else if( defv.length() < 6 ) { 090 defValue = defv; 091 } 092 else { 093 Calendar cal = HybsDateUtil.getCalendar( defv ); 094 defValue = HybsDateUtil.getDate( cal.getTimeInMillis() , format ); 095 096// defValue = format.format( getCalendar( defv ).getTime() ); 097 } 098 } 099 100 /** 101 * 各オブジェクトから自分のインスタンスを返します。 102 * 自分自身をキャッシュするのか、新たに作成するのかは、各サブクラスの実装に 103 * まかされます。 104 * 105 * @param clm DBColumnオブジェクト 106 * 107 * @return CellRendererオブジェクト 108 */ 109 public CellRenderer newInstance( final DBColumn clm ) { 110 return new Renderer_DATE( clm ); 111 } 112 113 /** 114 * データの表示用文字列を返します。 115 * 116 * @og.rev 3.5.1.0 (2003/10/03) データが nullの場合は、デフォルト値を、8桁以下はそのまま返す。 117 * @og.rev 3.8.5.3 (2006/08/01) 日付を6桁以上 とし、それ以下はそのまま返す。 118 * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用するように修正します。 119 * 120 * @param value 入力値 121 * 122 * @return データの表示用文字列 123 */ 124 @Override 125 public String getValue( final String value ) { 126 if( value == null ) { return defValue; } 127 if( value.length() < 6 ) { return value; } 128 129 Calendar cal = HybsDateUtil.getCalendar( value ); 130 return HybsDateUtil.getDate( cal.getTimeInMillis() , format ); 131 132// final String rtn ; 133// synchronized( format ) { 134// rtn = format.format( getCalendar( value ).getTime() ); 135// } 136// 137// return rtn; 138 } 139 140 /** 141 * 引数の日付け文字列に応じた、カレンダオブジェクトを返します。 142 * 143 * 引数は、YYYYMMDD形式(8Byte)か、YYYYMMDDHHMMSS形式(14Byte)の 144 * いづれかです。それ以外の場合は、初期化データが返されます。 145 * 146 * @og.rev 3.5.1.0 (2003/10/03) データが null や、""、の場合の処理を削除する。 147 * @og.rev 3.8.5.3 (2006/08/01) 日付を6桁以上 とし、それ以下はそのまま返す。 148 * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用するので廃止する。 149 * 150 * @param value カレンダオブジェクトを作成する、日付け文字列 151 * 152 * @return カレンダオブジェクト 153 */ 154// private Calendar getCalendar( final String value ) { 155// Calendar cal = Calendar.getInstance(); 156// cal.clear(); 157// 158// int hour=0,minute=0,second=0,date=1; 159// 160// int year = Integer.parseInt( value.substring( 0,4 ) ); 161// int month = Integer.parseInt( value.substring( 4,6 ) ) - 1; 162// if( value.length() >= 8 ) { 163// date = Integer.parseInt( value.substring( 6,8 ) ); 164// } 165// 166// if( value.length() == 14 ) { 167// hour = Integer.parseInt( value.substring( 8,10 ) ); 168// minute = Integer.parseInt( value.substring( 10,12 ) ); 169// second = Integer.parseInt( value.substring( 12,14 ) ); 170// } 171// 172// cal.set( year,month,date,hour,minute,second ); 173// 174// return cal; 175// } 176}