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}