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 }