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     */
016    package org.opengion.hayabusa.taglib;
017    
018    import org.opengion.hayabusa.common.HybsSystemException;
019    import org.opengion.fukurou.util.StringUtil;
020    import org.opengion.fukurou.util.TagBuffer;
021    
022    /**
023     * ガントチャートを表示するに当たり?ガント?体(?ージ全体?設定)??を行います?
024     *
025     * iGantt タグは、ガントチャート?体に??する事で、最大行数、固定カラ??
026     * 番号列?出力有無を指定する?に使用されます?
027     * 通常は、単独で使用するのではなく?iGanttBar タグと?合わせて使用します?
028     * 通常の view タグの後に記述します?
029     *
030     * ガントには??常のガントと積上ガント??積上ガントがあります?
031     * 通常ガント???常の view をガント化します?
032     * 積上ガント?、ViewにHTMLstackedGanttTableを指定する?があります?
033     * こ?方式?利点は、積上と通常のガントバーを混在できることです?例えば、物件予定をガントバーで、表示し?
034     * 個人の予定工数を積上るなどの表示が可能です?ただし?件数が多いと、??時間がかかります?
035     * ?積上ガント?、エンジン?で積上計算します?で、???早??ですが、ガントバーとの
036     * 混在ができません。これらは、うまく使??けを行う?があります?
037     *
038     * @og.formSample
039     * ●形式?lt;og:iGantt  ... />
040     * ●body?な?
041     * ●前提:headタグで、adjustEvent="Gantt" を指定してください?
042     *
043     * ●Tag定義??
044     *   <og:iGantt
045     *       margeRows          【TAG】前後?行データが??して?場合?マ?ジするかど?[true/false]?しま?初期値:false)
046     *       fixedCols          【TAG】左の固定?の列数?テーブル??割機??を?しま?
047     *       viewNumberType     【TAG】viewタグの出力に番号列が出力されて?かかど???力されて????deleteを指定?
048     *       verticalShift      【TAG】ガント?上下ずらし表示を行うかど?[true/false]?しま?初期値=true:行う)
049     *       paddingLeft        【TAG】ガントバーの間?左区?スペ?スを指定しま?初期値=null)
050     *       paddingRigth       【TAG】ガントバーの間?右区?スペ?スを指定しま?初期値=null)
051     *       useBgColor         【TAG】?の背景色の縞?模様を再作?するか[true/false]?します?argeRows='true'の場合?使用する??
052     *       viewGantt          【TAG】積上ガン?ガント部??表示を行うかど?[true/false]?しま?初期値=true:表示する)
053     *       stackHoliday       【TAG】積上ガン?休日に積上げるかど?[true/false]?します?oom=DAYの場合?み有効。?期?=true:積上げ?
054     *       viewMode           【TAG】積上ガン?1:行??値を基準に積上げ高さの計算を行う/0:能力設定?を基準に積上げ高さの計算を行う?
055     *       stdUpper           【TAG】積上ガン?正常?の上限となる工数です?これを?ると積上げの色が変化しま?初期値:1)
056     *       stdCost            【TAG】積上ガン?こ?工数が行?2/3の高さとなりま?初期値:1)
057     *       stdLower           【TAG】積上ガン?正常?の下限となる工数です?これを下回ると積上げの色が変化しま?初期値:0)
058     *       debug              【TAG】デバッグ??を?力するかど?[true/false]を指定しま?初期値:false)
059     *   />
060     *
061     * ●使用?
062     *   (通常ガン?
063     *  <og:view
064     *      viewFormType = "HTMLCustomTable"
065     *      command      = "{@command}"
066     *      writable     = "false"
067     *      useScrollBar = "false"
068     *  >
069     *    <og:thead rowspan="2">
070     *      <tr>
071     *          <td>[NOORDER]</td>
072     *          <td rowspan="2" class="gantt zoom{@VZOOM}" style="line-height:normal;text-align:left;background-image: url('../image/ganttBG{@VZOOM}.gif');" >
073     *              <div style="position:relative;left:0px;z-index:101; " height="100%" width="100%" >
074     *                  <og:ganttHeader
075     *                      startDate       = "{@startDate}"
076     *                      endDate         = "{@endDate}"
077     *                      zoom            = "{@VZOOM}"
078     *                      daySpan         = "{@daySpan}"
079     *                  />
080     *              </div>
081     *          </td>
082     *      </tr>
083     *    </og:thead>
084     *    <og:tbody rowspan="2">
085     *      <tr>
086     *          <td>[NOORDER]</td>
087     *          <td rowspan="2" class="gantt zoom{@VZOOM}" style="text-align:left;background-image: url('../image/ganttBG{@VZOOM}.gif');" >
088     *              <og:iGanttBar type="1" colorNo="[COLOR]" start="[DYORDER]" end="[DYNOKI]" text="[PN]" />
089     *              <og:iGanttBar type="0" src="../image/dia_blue.gif" start="[DYORDER]"      text="開? />
090     *              <og:iGanttBar type="0" src="../image/dia_red.gif"  end="[DYNOKI]"         text="終? />
091     *          </td>
092     *      </tr>
093     *    </og:tbody>
094     *  </og:view>
095     *    
096     *   <og:iGantt
097     *       margeRows      = "true"
098     *       fixedCols      = "1"
099     *   />
100     *
101     *   (積上ガン?
102     *  積上ガントを利用する場合?、ViewにHTMLstackedGanttTableを利用する?があります?
103     *  <og:view
104     *      viewFormType = "HTMLStackedGanttTable"
105     *      command      = "{@command}"
106     *      writable     = "false"
107     *      useScrollBar = "false"
108     *      useParam     = "true"
109     *      numberType   = "none"
110     *  >
111     *  <og:stackParam
112     *      stackColumns = "NOORDER"
113     *  />
114     * 
115     *    <og:thead rowspan="2">
116     *      <tr>
117     *          <td>[NOORDER]</td>
118     *          <td>[PN]</td>
119     *          <td rowspan="2" class="gantt zoom{@SZOOM}" style="text-align:left;background-image: url('../image/ganttBG{@SZOOM}.gif');" >
120     *              <div style="position:relative;left:0px;z-index:101; " height="100%" width="100%" >
121     *                  <og:ganttHeader
122     *                      startDate   = "{@startDate}"
123     *                      endDate     = "{@endDate}"
124     *                      zoom        = "{@SZOOM}"
125     *                      calDB       = "GE13"
126     *                      arg1        = "A"
127     *                  />
128     *              </div>
129     *          </td>
130     *      </tr>
131     *    </og:thead>
132     *    <og:tbody rowspan="2">
133     *      <tr>
134     *          <td>[NOORDER]</td>
135     *          <td>[PN]</td>
136     *          <td rowspan="2" class="gantt zoom{@VZOOM}" style="text-align:left;background-image: url('../image/ganttBG{@VZOOM}.gif');" >
137     *              <og:iGanttBar type="1" colorNo="[COLOR]" start="[DYORDER]" end="[DYNOKI]"  text="[COSTCLM]"
138     *                    cost="[COSTCLM]" capacity="[CAPACITY]" />
139     *              <og:iGanttBar type="0" src="../image/dia_blue.gif" start="[DYORDER]"      text="開? />
140     *          </td>
141     *      </tr>
142     *    </og:tbody>
143     *  </og:view>
144     *    
145     *   <og:iGantt
146     *       margeRows      = "true"
147     *       fixedCols      = "1"
148     *       verticalShift  = "false"
149     *       viewGantt      = "{@viewGantt}"
150     *       stackHoliday   = "{@stackHoliday}"
151     *       useBgColor     = "true"
152     *       viewMode       = "2"
153     *   />
154     *
155     * @og.rev 5.6.3.2 (2013/04/12) 新規作?
156     * @og.group 画面部?
157     *
158     * @version  5.0
159     * @author       Kazuhiko Hasegawa
160     * @since    JDK6.0,
161     */
162    public class ViewIGanttTag extends CommonTagSupport {
163            //* こ?プログラ??VERSION??を設定します?       {@value} */
164            private static final String VERSION = "5.6.4.2 (2013/05/17)" ;
165    
166            private static final long serialVersionUID = 564220130517L ;
167    
168            private TagBuffer tag = new TagBuffer( "iGantt" ) ;
169    
170            /**
171             * Taglibの終?グが見つかったときに処??doEndTag() ?オーバ?ライドします?
172             *
173             * @og.rev 5.8.1.0 (2014/11/07) HTML5対応?javaScriptで、BODYがな?入れ子になってしま??
174             * @return      後続????
175             */
176            @Override
177            public int doEndTag() {
178                    debugPrint();           // 4.0.0 (2005/02/28)
179    
180                    tag.setBody( "<!-- -->" );                // 5.8.1.0 (2014/11/07) HTML5対応?
181                    jspPrint( tag.makeTag() );
182    
183                    return(EVAL_PAGE);              // ペ?ジの残りを評価する?
184            }
185    
186            /**
187             * タグリブオブジェクトをリリースします?
188             * キャ?ュされて再利用される?で、フィールド?初期設定を行います?
189             *
190             */
191            @Override
192            protected void release2() {
193                    super.release2();
194                    tag = new TagBuffer( "iGantt" );
195            }
196    
197            /**
198             * 【TAG】前後?行データが??して?場合?マ?ジするかど?[true/false]?しま?初期値:false)
199             *
200             * @og.tag
201             * これは、ガントデータが同?ループ?場合に、ガントとして??に表示するようにします?
202             * こ?段階では?段並べのままです?
203             * 前後に付ける?合(??表示??、verticalShift = "true" を指定してください?
204             * (adjustGanttTable.jsの)初期値は、false:行わな?です?
205             *
206             * @param   margeRows ?行?マ?ジを行うかど?[true/false]
207             * @see         #setVerticalShift( String )
208             */
209            public void setMargeRows( final String margeRows ) {
210                    tag.add( "margeRows",StringUtil.nval( getRequestParameter( margeRows ),null ) );
211            }
212    
213            /**
214             * 【TAG】左の固定?の列数?テーブル??割機??を?します?
215             *
216             * @og.tag
217             * ?段?も2段?も?固定したいカラ?を指定します?
218             *
219             * @param   fixedCols 固定したいカラ?
220             */
221            public void setFixedCols( final String fixedCols ) {
222                    tag.add( "fixedCols",StringUtil.nval( getRequestParameter( fixedCols ),null ) );
223            }
224    
225            /**
226             * 【TAG】viewタグの出力に番号列が出力されて?かど???力されて????delete?を?します?
227             *
228             * @og.tag
229             * viewタグで、numberType属?で、行番号を表示しな?定を行った?合?ここでも?viewNumberType="delete" ?
230             * ?する?があります?
231             *
232             * @param   viewNumberType viewタグの番号列が出力されて?かかど?
233             */
234            public void setViewNumberType( final String viewNumberType ) {
235                    tag.add( "viewNumberType",StringUtil.nval( getRequestParameter( viewNumberType ),null ) );
236            }
237    
238            /**
239             * 【TAG】ガント?上下ずらし表示を行うかど?[true/false]?しま?初期値=true:行う)
240             *
241             * @og.tag
242             * 通常のガント表示では、データは階段並べで表示されます?
243             * 同??のガントを横??に表示した??合?、この属?に?true" を指定します?
244             * (adjustGanttTable.jsの)初期値は、true:行う です?
245             *
246             * @param   verticalShift 上下ずらし表示を行うかど?[true/false]
247             */
248            public void setVerticalShift( final String verticalShift ) {
249                    tag.add( "verticalShift",StringUtil.nval( getRequestParameter( verticalShift ), null ) );
250            }
251    
252            /**
253             * 【TAG】ガントバーの間?左区?スペ?スをピクセルで?しま?初期値:null)
254             *
255             * @og.tag
256             * ガント表示で、margeRows="true" (?行?マ?ジを行う)場合?前後?ガントが同?の
257             * 場合?くっつ?表示されます?これを?verticalShift="true" (ガント?上下ずらし表示を行う)
258             * 場合?、???バ?が判別可能ですが、そ?たくな?ースでは、???判別ができません?
259             * そこで、特殊なケースとして、???判別が付く様に、ガントバーの長さを調整した?ース?
260             * あります?
261             *
262             * こ?属?は、バーの左に??空?用意します?
263             * 初期値は、null(属?を?力しな? です?
264             *
265             * @og.rev 5.6.4.2 (2013/05/17) 新規追?
266             *
267             * @param   paddingLeft 左区?スペ?ス
268             * @see         #setPaddingRigth( String )
269             */
270            public void setPaddingLeft( final String paddingLeft ) {
271                    tag.add( "paddingLeft",StringUtil.nval( getRequestParameter( paddingLeft ),null ) );
272            }
273    
274            /**
275             * 【TAG】ガントバーの間?右区?スペ?スをピクセルで?しま?初期値:null)
276             *
277             * @og.tag
278             * ガント表示で、margeRows="true" (?行?マ?ジを行う)場合?前後?ガントが同?の
279             * 場合?くっつ?表示されます?これを?verticalShift="true" (ガント?上下ずらし表示を行う)
280             * 場合?、???バ?が判別可能ですが、そ?たくな?ースでは、???判別ができません?
281             * そこで、特殊なケースとして、???判別が付く様に、ガントバーの長さを調整した?ース?
282             * あります?
283             *
284             * こ?属?は、バーの右に??空?用意します?
285             * 初期値は、null(属?を?力しな? です?
286             *
287             * @og.rev 5.6.4.2 (2013/05/17) 新規追?
288             *
289             * @param   paddingRigth 左区?スペ?ス
290             * @see         #setPaddingLeft( String )
291             */
292            public void setPaddingRigth( final String paddingRigth ) {
293                    tag.add( "paddingRigth",StringUtil.nval( getRequestParameter( paddingRigth ),null ) );
294            }
295    
296            /**
297             * 【TAG】積上ガン?ガント部??表示を行うかど?[true/false]?しま?初期値=true:表示する)
298             *
299             * @og.tag
300             * falseとするとガント部?表示せず、積上げのみ表示します?
301             * (adjustGanttTable.jsの)初期値は、true:表示する?
302             *
303             * @param   viewGantt ガント部??表示を行うかど?[true/false]
304             */
305            public void setViewGantt( final String viewGantt ) {
306                    tag.add( "viewGantt",StringUtil.nval( getRequestParameter( viewGantt ), null ) );
307            }
308    
309            /**
310             * 【TAG】積上ガン?休日に積上げるかど?[true/false]?します(?期?=true:積上げ?
311             *
312             * @og.tag
313             * 休日に積上る場合?平日、休日を合わせた日数で、工数の平準化が行われます?
314             * false:積上な?を指定した?合?平日のみで工数が加算されます?
315             * 積上?、日付関係?場?zoom=DAY)のみ有効で、時間単位?積上機?はありません?
316             * (adjustGanttTable.jsの)初期値は、true:積上げる?
317             *
318             * @param   stackHoliday ガント?表示を行うかど?[true/false]
319             */
320            public void setStackHoliday( final String stackHoliday ) {
321                    tag.add( "stackHoliday",StringUtil.nval( getRequestParameter( stackHoliday ), null ) );
322            }
323    
324            /**
325             * 【TAG】?の背景色の縞?模様を再作?するか[true/false]?しま?初期値:true)
326             *
327             * @og.tag
328             * 背景色の縞?模?ゼブラ模?を作?する場合??true" にセ?します?
329             * margeRows='true'の場合?使用します?
330             * (adjustGanttTable.jsの)初期値は、true:再作?する?
331             *
332             * @param   useBgColor 背景色ゼブラを行うかど?[true/false]
333             * @see         #setMargeRows( String )
334             */
335            public void setUseBgColor( final String useBgColor ) {
336                    tag.add( "useBgColor",StringUtil.nval( getRequestParameter( useBgColor ), null ) );
337            }
338    
339            /**
340             * 【TAG】積上ガン?積上げ高さの計算方法[0:設定?基?1:?値基準]?します(?期?:1:?値基準?
341             *
342             * @og.tag
343             * 積上ガント?大きさを?設定?を基準にするか??値を基準にするか指定します?
344             * 1:?値基準??さ固定と?られます?つまり?積上ガント???.0の場合?
345             * 設定?が?0.1 なら?0.1 ??値としてつみあがります??00??の表示に適して?す?
346             * 0:設定?基準??さ可変です?つまり?積上ガント?設定?の??0.2 の場合?
347             * 0.1 なら?半?の?で積みあがります?値に?値がなく??上結果の相対レベル?
348             * 見た??合に?して?す?
349             * 
350             * 0:能力設定?を基準に積上げ高さの計算を行う?
351             * 1:行??値を基準に積上げ高さの計算を行う?
352             * (adjustGanttTable.jsの)初期値は?:?値基?です?
353             *
354             * @param   viewMode 積上げ高さの計算方法[0:設定?基?1:?値基準]
355             */
356            public void setViewMode( final String viewMode ) {
357                    tag.add( "viewMode",StringUtil.nval( getRequestParameter( viewMode ),null ) );
358            }
359    
360            /**
361             * 【TAG】積上ガン?正常?の上限となる工数を指定しま?初期値:1)?
362             *
363             * @og.tag
364             * 正常?の上限となる工数を?ると積上げの色が変化します?
365             * (adjustGanttTable.jsの)初期値は? です?
366             *
367             * @param   stdUpper 正常?の上限となる工数
368             * @see         #setStdCost( String )
369             */
370            public void setStdUpper( final String stdUpper ) {
371                    tag.add( "stdUpper",StringUtil.nval( getRequestParameter( stdUpper ),null ) );
372            }
373    
374            /**
375             * 【TAG】積上ガン?行?2/3の高さとなる工数を指定しま?初期値:1)?
376             *
377             * @og.tag
378             * 正常?の上限を?期?の "1" に設定し、この値を?期?の "1" を使??
379             * "1" の高さは、行?2/3の高さになるよ?計算されます?つまり?オーバ????
380             * 全体? 1/3 以下?場合に、ち?ど良?じになります?
381             * オーバ?する量との関係で?します?
382             * (adjustGanttTable.jsの)初期値は? です?
383             *
384             * @param   stdCost 行?2/3の高さとなる工数
385             * @see         #setStdUpper( String )
386             */
387            public void setStdCost( final String stdCost ) {
388                    tag.add( "stdCost",StringUtil.nval( getRequestParameter( stdCost ),null ) );
389            }
390    
391            /**
392             * 【TAG】積上ガン?正常?の下限となる工数を指定しま?初期値:0)?
393             *
394             * @og.tag
395             * 正常?の下限となる工数を下回ると積上げの色が変化します?
396             * (adjustGanttTable.jsの)初期値は? です?
397             *
398             * @param   stdLower 背景色ゼブラを行うかど?[true/false]
399             */
400            public void setStdLower( final String stdLower ) {
401                    tag.add( "stdLower",StringUtil.nval( getRequestParameter( stdLower ),null ) );
402            }
403    
404            /**
405             * タグの名称を?返します?
406             * 自??身のクラス名より?自動的に取り出せな?め?こ?メソ?をオーバ?ライドします?
407             *
408             * @return  タグの名称
409             */
410            @Override
411            protected String getTagName() {
412                    return "iGantt" ;
413            }
414    
415            /**
416             * こ?オブジェクト???表現を返します?
417             * 基本???目?使用します?
418             *
419             * @return こ?クラスの??表現
420             */
421            @Override
422            public String toString() {
423                    return org.opengion.fukurou.util.ToString.title( this.getClass().getName() )
424                                    .println( "VERSION"             ,VERSION        )
425                                    .println( "tag"                 ,tag.makeTag()  )
426                                    .println( "Other..."    ,getAttributes().getAttribute() )
427                                    .fixForm().toString() ;
428            }
429    }