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;
020import org.opengion.hayabusa.db.CellEditor;
021import org.opengion.hayabusa.db.DBColumn;
022import org.opengion.hayabusa.db.Selection;
023
024// import org.opengion.hayabusa.db.Selection_NUM;               // 5.7.3.0 (2014/02/07) SelectionFactory を使う様に変更
025import org.opengion.hayabusa.db.SelectionFactory;               // 5.7.3.0 (2014/02/07)
026
027/**
028 * カラムの編集パラメーターの開始、終了、ステップの情報より、プルダウンメニューを作成して
029 * 編集する場合に使用するエディタークラスです。
030 *
031 * ここでは、数字(連番)の自動生成を行います。パラメータで、開始、終了、ステップを指定します。
032 * パラメータの初期値は、開始(1)、終了(10)、ステップ(1) です。
033 * 
034 * 例:1,10,1    → 1,2,3,4,5,6,7,8,9,10 のプルダウン
035 * 例:10,100,10 → 10,20,30,40,50,60,70,80,90,100 のプルダウン
036 * 例:-5,5,1    → -5,-4,-3,-2,-1,0,1,2,3,4,5 のプルダウン
037 * 例:5,-5,-2   → 5,3,1,-1,-3,-5 のプルダウン
038 *
039 * カラムの表示に必要な属性は, DBColumn オブジェクト より取り出します。
040 * このクラスは、DBColumn オブジェクト毎に1つ作成されます。
041 *
042 * @og.rev 5.6.1.1 (2013/02/08) 新規作成
043 * @og.group データ編集
044 *
045 * @version  4.0
046 * @author       Kazuhiko Hasegawa
047 * @since    JDK5.0,
048 */
049public class Editor_NUMMENU extends Editor_MENU {
050        //* このプログラムのVERSION文字列を設定します。   {@value} */
051        private static final String VERSION = "5.7.3.0 (2014/02/07)" ;
052
053        /**
054         * デフォルトコンストラクター。
055         * このコンストラクターで、基本オブジェクトを作成します。
056         *
057         */
058        public Editor_NUMMENU() {
059                super();
060        }
061
062        /**
063         * コンストラクター。
064         * ここでは、親クラスの Editor_MENU で初期化を行い、セレクションオブジェクト に、
065         * Selection_NUM を使用するように再設定します。
066         *
067         * @og.rev 5.7.3.0 (2014/02/07) SelectionFactory 対応
068         *
069         * @param       clm     DBColumnオブジェクト
070         */
071        private Editor_NUMMENU( final DBColumn clm ) {
072                super( clm );
073
074                // 5.7.3.0 (2014/02/07) SelectionFactory 対応
075//              selection = new Selection_NUM( clm.getEditorParam() );
076                selection = SelectionFactory.newSelection( "NUM", clm.getEditorParam() );
077        }
078
079        /**
080         * 各オブジェクトから自分のインスタンスを返します。
081         * 自分自身をキャッシュするのか、新たに作成するのかは、各サブクラスの実装に
082         * まかされます。
083         *
084         * @param       clm     DBColumnオブジェクト
085         *
086         * @return      CellEditorオブジェクト
087         */
088        @Override
089        public CellEditor newInstance( final DBColumn clm ) {
090                return new Editor_NUMMENU( clm );
091        }
092}