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.view;
017
018/**
019 * 検索結果を単純なリスト形式で表示するクラスです。
020 *
021 * このクラスでは、検索結果を単純なリストで表示します。
022 * 表示のみでこの表示フォーマットを利用してデータ編集を行うことはできません。
023 *
024 * 各カラムのデータは、カンマによって連結され、またヘッダー部分も出力されません。
025 * さらに各カラムの属性値に基づくclass属性等も一切出力されません。
026 *
027 * AbstractViewForm により、setter/getterメソッドのデフォルト実装を提供しています。
028 * 各HTMLのタグに必要な setter/getterメソッドのみ、追加定義しています。
029 *
030 * AbstractViewForm を継承している為、ロケールに応じたラベルを出力させる事が出来ます。
031 *
032 * @og.group 画面表示
033 *
034 * @version  4.0
035 * @author       Hiroki Nakamura
036 * @since    JDK5.0,
037 */
038public class ViewForm_HTMLSimpleList extends ViewForm_HTMLTable {
039        /** このプログラムのVERSION文字列を設定します。   {@value} */
040        private static final String VERSION = "7.0.1.0 (2018/10/15)" ;
041
042        /** 警告時の行ごとに色を変更する時の、デフォルトクラス属性 */
043        private static final String BG_WARNING_COLOR = " class=\"row_warning\"";
044
045        /** エラー時の行ごとに色を変更する時の、デフォルトクラス属性 */
046        private static final String BG_ERROR_COLOR = " class=\"row_error\"";
047
048        private String colorRow = "";
049
050        /**
051         * デフォルトコンストラクター
052         *
053         * @og.rev 6.4.2.0 (2016/01/29) PMD refactoring. Each class should declare at least one constructor.
054         */
055        public ViewForm_HTMLSimpleList() { super(); }           // これも、自動的に呼ばれるが、空のメソッドを作成すると警告されるので、明示的にしておきます。
056
057        /**
058         * DBTableModel から HTML文字列を作成して返します。
059         * startNo(表示開始位置)から、pageSize(表示件数)までのView文字列を作成します。
060         * 表示残りデータが pageSize 以下の場合は、残りのデータをすべて出力します。
061         *
062         * @og.rev 6.3.9.1 (2015/11/27) カラムが一つも表示されないケースは、考えないことにする。
063         * @og.rev 7.0.1.0 (2018/10/15) XHTML → HTML5 対応(空要素の、"/>" 止めを、">" に変更します)。
064         *
065         * @param  startNo        表示開始位置
066         * @param  pageSize   表示件数
067         *
068         * @return      DBTableModelから作成された HTML文字列
069         * @og.rtnNotNull
070         */
071        @Override
072        public String create( final int startNo, final int pageSize )  {
073                if( getRowCount() == 0 ) { return ""; }
074
075                final int lastNo = getLastNo( startNo, pageSize );
076
077                final StringBuilder out = new StringBuilder( BUFFER_LARGE );
078
079                final int clmCnt = getColumnCount();
080                for( int row=startNo; row<lastNo; row++ ) {
081                        if( isSkip( row ) || isSkipNoEdit( row ) ) { continue; }
082
083//                      if( row != startNo ) { out.append( "<br />" ); }
084                        if( row != startNo ) { out.append( "<br>" ); }                                                          // 7.0.1.0 (2018/10/15)
085
086                        // 8.5.4.2 (2024/01/12) PMD 7.0.0 ConsecutiveAppendsShouldReuse 対応
087                        out.append( "<span" ).append( getBgColorCycleClass(row) ).append( '>' ) // 6.0.2.5 (2014/10/31) char を append する。
088                        // 6.3.9.1 (2015/11/27) カラムが一つも表示されないケースは、考えないことにする。
089                                .append( row+1 );
090                        for( int column=0; column<clmCnt; column++ ) {
091                                if( isColumnDisplay( column ) ) {
092                                        out.append( ',' ).append( getValueLabel(row,column) );                          // row+1 を append しているので、これでよい。
093                                }
094                        }
095                        out.append( "</span>" );
096                }
097
098                return out.toString();
099        }
100
101        /**
102         * テーブルのバックグラウンドカラーの入れ替えのサイクルをセットします。
103         * 0以上(通常)、-1(ワーニング)、-2以下(エラー)
104         * 初期値は、0以上(通常)です。
105         *
106         * @param  sycle  0以上(通常)、-1(ワーニング)、-2以下(エラー)
107         */
108        @Override
109        public void setBgColorCycle( final int sycle ) {
110                if( sycle == -1 ) {                                     // -1(ワーニング)
111                        colorRow                = BG_WARNING_COLOR ;
112                }
113                else if( sycle < -1 ) {                         // -2以下(エラー)
114                        colorRow                = BG_ERROR_COLOR ;
115                }
116        }
117
118        /**
119         * テーブルのバックグラウンドカラーの値をセットします。
120         *
121         * @param       row 行番号( 0から始める )
122         *
123         * @return      行の色を指定する class 属性( cssファイルで指定 )
124         */
125        @Override
126        protected String getBgColorCycleClass( final int row ) {
127                return colorRow ;
128        }
129
130        /**
131         * 表示項目の編集(並び替え)が可能かどうかを返します。
132         *
133         * @og.rev 5.1.6.0 (2010/05/01) 新規追加
134         *
135         * @return      表示項目の編集(並び替え)が可能かどうか(false:不可能)
136         */
137        @Override
138        public boolean isEditable() {
139                return false;
140        }
141
142}