/** * Copyright (C) 2008-2010, Squale Project - http://www.squale.org * * This file is part of Squale. * * Squale is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or any later version. * * Squale is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with Squale. If not, see <http://www.gnu.org/licenses/>. */ /* * Cr�� le 30 mars 04 * * Pour changer le mod�le de ce fichier g�n�r�, allez � : * Fen�tre>Pr�f�rences>Java>G�n�ration de code>Code et commentaires */ package org.squale.welcom.taglib.table; import javax.servlet.jsp.JspException; import javax.servlet.jsp.tagext.BodyTagSupport; import javax.servlet.jsp.tagext.Tag; import org.apache.commons.validator.GenericValidator; /** * @author M327837 Pour changer le mod�le de ce commentaire de type g�n�r�, allez � : * Fen�tre>Pr�f�rences>Java>G�n�ration de code>Code et commentaires */ public class ColTag extends BodyTagSupport { /** * */ private static final long serialVersionUID = -3223443429650477776L; /** parametre du tag */ private String property = ""; /** parametre du tag */ private String key = ""; /** parametre du tag */ private boolean sortable = false; /** parametre du tag */ private boolean editable = true; /** parametre du tag */ private String paramId = ""; /** parametre du tag */ private String paramName = ""; /** parametre du tag */ private String paramProperty = ""; /** parametre du tag */ private String href = ""; /** parametre du tag */ private String width = ""; /** parametre du tag */ private String type = null; /** parametre du tag */ private String dateFormatKey = null; /** parametre du tag */ private String dateFormat = null; /** parametre du tag */ private boolean writeTD = true; /** parametre du tag */ private ColsTag colsTag; /** parametre du tag */ private String emptyKey = ""; /** parametre du tag */ private String contentClass = ""; /** parametre du tag */ private String contentStyle = ""; /** parametre du tag */ private String headerStyle = ""; /** parametre du tag */ private String headerClass = ""; /** parametre du tag */ private String headerTruncate = ""; /** parametre du tag */ private String contentTruncate = ""; /** parametre du tag */ private boolean contentNoWrap = false; /** parametre du tag */ private boolean headerNoWrap = true; /** * @see javax.servlet.jsp.tagext.BodyTagSupport#doStartTag() */ public int doStartTag() throws JspException { // Recherche si un parent est du bon type Tag curParent = null; for ( curParent = getParent(); ( curParent != null ) && !( curParent instanceof ColsTag ); ) { curParent = curParent.getParent(); } if ( curParent == null ) { throw new JspException( "ColTag must be used between Table Tag." ); } colsTag = (ColsTag) curParent; if ( !GenericValidator.isBlankOrNull( colsTag.getEmptyKey() ) && ( pageContext.getAttribute( colsTag.getId() ) == null ) ) { return SKIP_BODY; } else { return EVAL_BODY_BUFFERED; } } /** * @see javax.servlet.jsp.tagext.Tag#doEndTag() */ public int doEndTag() throws JspException { final Col c = new Col(); if ( key == null ) { key = property; } c.setKey( key ); c.setProperty( property ); c.setSortable( sortable ); c.setEditable( editable ); c.setParamId( paramId ); c.setParamName( paramName ); c.setParamProperty( paramProperty ); c.setLink( href ); c.setWidth( width ); c.setPageContext( pageContext ); c.setContentStyle( contentStyle ); c.setContentClass( contentClass ); c.setHeaderStyle( headerStyle ); c.setHeaderClass( headerClass ); c.setHeaderTruncate( headerTruncate ); c.setContentTruncate( contentTruncate ); c.setHeaderNoWrap( headerNoWrap ); c.setContentNoWrap( contentNoWrap ); if ( getBodyContent() != null ) { c.setCurrentValue( getBodyContent().getString().trim() ); } c.setWriteTD( writeTD ); if ( type != null ) { type = type.toUpperCase(); } c.setType( type ); c.setDateFormatKey( dateFormatKey ); c.setDateFormat( dateFormat ); c.setEmptyKey( emptyKey ); colsTag.addCellule( c ); return EVAL_PAGE; } /** * @see javax.servlet.jsp.tagext.BodyTagSupport#release() */ public void release() { colsTag = null; property = ""; key = ""; sortable = false; editable = true; paramId = ""; paramName = ""; paramProperty = ""; href = ""; width = ""; type = null; dateFormatKey = null; dateFormat = null; writeTD = true; emptyKey = ""; contentStyle = ""; contentClass = ""; headerStyle = ""; headerClass = ""; headerTruncate = ""; contentTruncate = ""; headerNoWrap = true; contentNoWrap = false; super.release(); } /** * @return key */ public String getKey() { return key; } /** * @return property */ public String getProperty() { return property; } /** * @return sortable */ public boolean isSortable() { return sortable; } /** * @param string le nouveau key */ public void setKey( final String string ) { key = string; } /** * @param string le nouveau property */ public void setProperty( final String string ) { property = string; } /** * @param b le nouveau sortable */ public void setSortable( final boolean b ) { sortable = b; } /** * @return paramId */ public String getParamId() { return paramId; } /** * @return paramName */ public String getParamName() { return paramName; } /** * @return paramProperty */ public String getParamProperty() { return paramProperty; } /** * @param string le nouveau paramId */ public void setParamId( final String string ) { paramId = string; } /** * @param string le nouveau paramName */ public void setParamName( final String string ) { paramName = string; } /** * @param string le nouveau paramProperty */ public void setParamProperty( final String string ) { paramProperty = string; } /** * @return href */ public String getHref() { return href; } /** * @return width */ public String getWidth() { return width; } /** * @param string le nouveau href */ public void setHref( final String string ) { href = string; } /** * @param string le nouveau width */ public void setWidth( final String string ) { width = string; } /** * @return writeTD */ public boolean isWriteTD() { return writeTD; } /** * @param b le nouveau writeTD */ public void setWriteTD( final boolean b ) { writeTD = b; } /** * @return dateFormat */ public String getDateFormat() { return dateFormat; } /** * @return type */ public String getType() { return type; } /** * @param string le nouveau dateFormat */ public void setDateFormat( final String string ) { dateFormat = string; } /** * @param string le nouveau type */ public void setType( final String string ) { type = string; } /** * @return emptyKey */ public String getEmptyKey() { return emptyKey; } /** * @param string le nouveau emptyKEy */ public void setEmptyKey( final String string ) { emptyKey = string; } /** * @return editable */ public boolean isEditable() { return editable; } /** * @param b editable */ public void setEditable( final boolean b ) { editable = b; } /** * @return headerStyle */ public String getHeaderStyle() { return headerStyle; } /** * @param string headerStyle */ public void setHeaderStyle( final String string ) { headerStyle = string; } /** * @return contentTruncate */ public String getContentTruncate() { return contentTruncate; } /** * @return headerTruncate */ public String getHeaderTruncate() { return headerTruncate; } /** * @param string contentTruncate */ public void setContentTruncate( final String string ) { contentTruncate = string; } /** * @param string headerTruncate */ public void setHeaderTruncate( final String string ) { headerTruncate = string; } /** * @return contentClass */ public String getContentClass() { return contentClass; } /** * @return contentStyle */ public String getContentStyle() { return contentStyle; } /** * @return headerClass */ public String getHeaderClass() { return headerClass; } /** * @param string contentClass */ public void setContentClass( final String string ) { contentClass = string; } /** * @param string contentStyle */ public void setContentStyle( final String string ) { contentStyle = string; } /** * @param string headerClass */ public void setHeaderClass( final String string ) { headerClass = string; } /** * @return dateFormatKey */ public String getDateFormatKey() { return dateFormatKey; } /** * @param string dateFormatKey */ public void setDateFormatKey( final String string ) { dateFormatKey = string; } /** * @return ContentNoWrap */ public boolean isContentNoWrap() { return contentNoWrap; } /** * @return HeaderNoWrap */ public boolean isHeaderNoWrap() { return headerNoWrap; } /** * @param b ContentNoWrap */ public void setContentNoWrap( final boolean b ) { contentNoWrap = b; } /** * @param b HeaderNoWrap */ public void setHeaderNoWrap( final boolean b ) { headerNoWrap = b; } }