src.com.ibm.as400.util.html.HTMLTableCell Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt400 Show documentation
Show all versions of jt400 Show documentation
The Open Source version of the IBM Toolbox for Java
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: HTMLTableCell.java
//
// The source code contained herein is licensed under the IBM Public License
// Version 1.0, which has been approved by the Open Source Initiative.
// Copyright (C) 1997-2001 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.util.html;
import com.ibm.as400.access.ExtendedIllegalArgumentException;
import com.ibm.as400.access.ExtendedIllegalStateException;
import com.ibm.as400.access.Trace;
import java.beans.PropertyChangeSupport;
import java.beans.PropertyChangeListener;
import java.beans.PropertyVetoException;
import java.beans.VetoableChangeSupport;
import java.beans.VetoableChangeListener;
import java.io.Serializable;
/**
* The HTMLTableCell class represents data in an HTML table cell.
*
* This example creates an HTML text HTMLTableCell object.
*
*
* // Create an HTMLText object.
* HTMLText ibmText = new HTMLText("IBM");
* ibmText.setBold(true);
* ibmText.setItalic(true);
* HTMLTableCell textCell = new HTMLTableCell(ibmText);
* textCell.setHorizontalAlignment(HTMLConstants.CENTER);
* System.out.println(textCell.getTag());
*
*
* Here is the output of the tag:
*
*
<td align="center"><b><i>IBM</i></b></td>
*
* Calling getFOTag() produces the following:
*
* <fo:table-cell border-style='solid' border-width='1px' padding='1px' text-align='center'><fo:block-container>
* <fo:block font-weight='bold' font-style='italic'>IBM</fo:block>
* </fo:block-container>
* </fo:table-cell>
*
*
* This example creates an HTMLTableCell object with the element as an HTMLForm
* object containing a submit button.
*
*
* HTMLTableCell formCell = new HTMLTableCell();
* // create an HTMLForm object.
* SubmitFormInput submitButton = new SubmitFormInput("Submit", "Send");
* HTMLForm form = new HTMLForm("http://myCompany.com/myServlet");
* form.addElement(submitButton);
* // add the form to the table cell.
* formCell.setElement(form);
* System.out.println(formCell.getTag());
*
*
* Here is the output of the tag:
*
* <td><form action="http://myCompany.com/myServlet" method="get">
* <input type="submit" value="Send" />
* </form></td>
*
*
* HTMLTableCell objects generate the following events:
*
* - PropertyChangeEvent
*
- VetoableChangeEvent
*
*
* @see com.ibm.as400.util.html.HTMLTable
* @see com.ibm.as400.util.html.HTMLTableRow
**/
public class HTMLTableCell extends HTMLTagAttributes implements HTMLConstants, Serializable
{
private static final String copyright = "Copyright (C) 1997-2001 International Business Machines Corporation and others.";
static final long serialVersionUID = -4848852026390616957L;
private HTMLTagElement element_; // The cell data.
private String align_; // The cell horizontal alignment.
private int colSpan_ = 1; // The number of cell columns in the table the cell should span.
private int height_; // The cell height in percent or pixels.
private int rowSpan_ = 1; // The number of cell rows in the table the cell should span.
private String vAlign_; // The cell vertical alignment.
private int width_; // The cell width in percent or pixels.
private boolean wrap_ = true; // Indicates if normal HTML linebreaking conventions are used.
private String lang_; // The primary language used to display the tags contents. //$B1A
private String dir_; // The direction of the text interpretation. //$B1A
private boolean heightPercent_ = false; // Indicates if the height is in percent.
private boolean widthPercent_ = false; // Indicates if the width is in percent.
private boolean useFO_ = false; // Indicates if XSL-FO tags are used //@D1A
private int borderWidth_ = 1; // The width of the cell border //@D1A
private int cellPadding_ = 1; // The padding for the cell //@D1A
transient private VetoableChangeSupport vetos_; //@CRS
/**
* Constructs a default HTMLTableCell object.
**/
public HTMLTableCell()
{
}
/**
* Constructs an HTMLTableCell.
* @param element The table cell element.
**/
public HTMLTableCell(HTMLTagElement element)
{
if (element == null)
throw new NullPointerException("element");
element_ = element;
}
/**
* Adds the VetoableChangeListener. The specified VetoableChangeListener's vetoableChange
* method is called each time the value of any constrained property is changed.
* @see #removeVetoableChangeListener
* @param listener The VetoableChangeListener.
**/
public void addVetoableChangeListener(VetoableChangeListener listener)
{
if (listener == null)
throw new NullPointerException("listener");
if (vetos_ == null) vetos_ = new VetoableChangeSupport(this); //@CRS
vetos_.addVetoableChangeListener(listener);
}
/**
* Returns the column span. The default value is one.
* @return The column span.
**/
public int getColumnSpan()
{
return colSpan_;
}
/**
* Returns the direction of the text interpretation.
* @return The direction of the text.
**/
public String getDirection() //$B1A
{
return dir_;
}
/**
* Returns the direction attribute tag.
* @return The direction tag.
**/
String getDirectionAttributeTag() //$B1A
{
if(useFO_ ) //@D1A
{ //@D1A
if((dir_ != null) && (dir_.length()>0)) //@D1A
{ //@D1A
if(dir_.equals(HTMLConstants.RTL)) //@D1A
return " writing-mode='rl'"; //@D1A
else //@D1A
return " writing-mode='lr'"; //@D1A
} //@D1A
else //@D1A
return ""; //@D1A
} //@D1A
else //@D1A
{ //@D1A
//@C1D
if ((dir_ != null) && (dir_.length() > 0))
return " dir=\"" + dir_ + "\"";
else
return "";
} //@D1A
}
/**
* Returns the table cell element.
* @return The cell element.
**/
public HTMLTagElement getElement()
{
return element_;
}
/**
* Returns the table cell end tag.
* @return The end tag.
**/
String getEndTag()
{
if(!useFO_) //@D1A
return "\n";
else
return "\n"; // @D1A
}
/**
* Returns the height relative to the table in pixels or percent.
* @return The height.
**/
public int getHeight()
{
return height_;
}
/**
* Returns the horizontal alignment. The default value is LEFT.
* @return The horizontal alignment. One of the following constants
* defined in HTMLConstants: CENTER, LEFT, or RIGHT.
* @see com.ibm.as400.util.html.HTMLConstants
**/
public String getHorizontalAlignment()
{
return align_;
}
/**
* Returns the language of the table cell.
* @return The language of the table cell.
**/
public String getLanguage() //$B1A
{
return lang_;
}
/**
* Returns the language attribute tag.
* @return The language tag.
**/
String getLanguageAttributeTag() //$B1A
{
//@C1D
if ((lang_ != null) && (lang_.length() > 0))
return " lang=\"" + lang_ + "\"";
else
return "";
}
/**
* Returns the row span. The default value is one.
* @return The row span.
**/
public int getRowSpan()
{
return rowSpan_;
}
/**
* Returns the table cell start tag.
* @return The start tag.
**/
String getStartTag()
{
if(!useFO_) //@D1A
return " 1) //@D1A
{
tag.append(" rowspan=\"");
tag.append(rowSpan_);
tag.append("\"");
}
if (colSpan_ > 1) //@D1A
{
tag.append(" colspan=\"");
tag.append(colSpan_);
tag.append("\"");
}
// Add the size attributes.
if (height_ > 0) //@D1A
{
tag.append(" height=\"");
tag.append(height_);
if (heightPercent_)
tag.append("%");
tag.append("\"");
}
if (width_ > 0) //@D1A
{
tag.append(" width=\"");
tag.append(width_);
if (widthPercent_)
tag.append("%");
tag.append("\"");
}
// Add the wrap attribute.
if (!wrap_) //@D1A
tag.append(" nowrap=\"nowrap\"");
tag.append(getLanguageAttributeTag()); //$B1A
tag.append(getDirectionAttributeTag()); //$B1A
tag.append(getAttributeString()); // @Z1A
}
else //@D1A
{
// Add the span attributes.
if (rowSpan_ > 1)
{
tag.append(" number-rows-spanned='");
tag.append(rowSpan_);
tag.append("'");
}
if (colSpan_ > 1)
{
tag.append(" number-columns-spanned='");
tag.append(colSpan_);
tag.append("'");
}
// Add the size attributes.
if (height_ > 0) //@D1A
{
tag.append(" height='");
tag.append(height_);
if (heightPercent_)
tag.append("%");
tag.append("'");
}
if (width_ > 0)
{
tag.append(" width='");
tag.append(width_);
if (widthPercent_)
tag.append("%");
tag.append("'");
}
}
tag.append(">");
return tag.toString(); //@D1C
}
/**
* Returns the table cell tag.
* @return The cell tag.
**/
public String getTag()
{
return getTag(element_);
}
/**
* Returns the XSL-FO table cell tag.
* @return The cell tag.
**/
public String getFOTag() //@D1A
{
return getFOTag(element_);
}
/**
* Returns the XSL-FO table cell tag with the specified element.
* It does not change the cell object's element attribute.
* The valign, wrap and laguage attributes are not supported in XSL-FO.
* @param element The table cell element.
* @return The XSL-FO cell tag.
**/
public String getFOTag(HTMLTagElement element) //@D1A
{
//Save current state of useFO_
boolean useFO = useFO_;
setUseFO(true);
// Verify that the element is set.
if (element == null)
throw new NullPointerException("element");
StringBuffer tag = new StringBuffer(getStartTag());
tag.append(getAttributeTag());
tag.append("\n");
tag.append(element.getFOTag());
tag.append(" \n");
tag.append(getEndTag());
//Set useFO_ to previous state
setUseFO(useFO);
return tag.toString();
}
/**
* Returns the table cell tag with the specified element.
* It does not change the cell object's element attribute.
* @param element The table cell element.
* @return The cell tag.
**/
public String getTag(HTMLTagElement element)
{
//@C1D
if(useFO_) //@D1A
return getFOTag(element); //@D1A
// Verify that the element is set.
if (element == null)
throw new NullPointerException("element");
StringBuffer tag = new StringBuffer(getStartTag());
tag.append(getAttributeTag());
tag.append(element.getTag());
tag.append(getEndTag());
return tag.toString(); //@D1C
}
/**
* Returns the vertical alignment.
* @return The vertical alignment. One of the following constants
* defined in HTMLConstants: BASELINE, BOTTOM, MIDDLE, or TOP.
* @see com.ibm.as400.util.html.HTMLConstants
**/
public String getVerticalAlignment()
{
return vAlign_;
}
/**
* Returns the width relative to the table in pixels or percent.
* @return The width.
**/
public int getWidth()
{
return width_;
}
/**
* Indicates if the height is in percent or pixels.
* The default value is false.
* @return true if percent; pixels otherwise.
**/
public boolean isHeightInPercent()
{
return heightPercent_;
}
/**
* Returns if Formatting Object tags are outputted.
* The default value is false.
* @return true if the output generated is an XSL formatting object, false if the output generated is HTML.
**/
public boolean isUseFO()
{
//@D1A
return useFO_;
}
/**
* Indicates if the width is in percent or pixels.
* The default value is false.
* @return true if percent; pixels otherwise.
**/
public boolean isWidthInPercent()
{
return widthPercent_;
}
/**
* Indicates if the cell data will use normal HTML linebreaking conventions.
* The default value is true.
* @return true if normal HTML linebreaking is used; false otherwise.
**/
public boolean isWrap()
{
return wrap_;
}
/**
* Deserializes and initializes transient data.
**/
private void readObject(java.io.ObjectInputStream in)
throws java.io.IOException, ClassNotFoundException
{
in.defaultReadObject();
//@CRS changes_ = new PropertyChangeSupport(this);
//@CRS vetos_ = new VetoableChangeSupport(this);
}
/**
* Removes the VetoableChangeListener from the internal list.
* If the VetoableChangeListener is not on the list, nothing is done.
* @see #addVetoableChangeListener
* @param listener The VetoableChangeListener.
**/
public void removeVetoableChangeListener(VetoableChangeListener listener)
{
if (listener == null)
throw new NullPointerException("listener");
if (vetos_ != null) vetos_.removeVetoableChangeListener(listener); //@CRS
}
/**
* Sets the column span. The default value is one.
* @param span The column span.
* @exception PropertyVetoException If the change is vetoed.
**/
public void setColumnSpan(int span) throws PropertyVetoException
{
if (span <= 0)
throw new ExtendedIllegalArgumentException("span", ExtendedIllegalArgumentException.RANGE_NOT_VALID);
//@CRS Integer oldSpan = new Integer(colSpan_);
//@CRS Integer newSpan = new Integer(span);
int oldSpan = colSpan_; //@CRS
if (vetos_ != null) vetos_.fireVetoableChange("span", new Integer(oldSpan), new Integer(span)); //@CRS
colSpan_ = span;
if (changes_ != null) changes_.firePropertyChange("span", new Integer(oldSpan), new Integer(span)); //@CRS
}
/**
* Sets the direction of the text interpretation.
* @param dir The direction. One of the following constants
* defined in HTMLConstants: LTR or RTL.
*
* @see com.ibm.as400.util.html.HTMLConstants
*
* @exception PropertyVetoException If a change is vetoed.
**/
public void setDirection(String dir) //$B1A
throws PropertyVetoException
{
if (dir == null)
throw new NullPointerException("dir");
// If direction is not one of the valid HTMLConstants, throw an exception.
if ( !(dir.equals(HTMLConstants.LTR)) && !(dir.equals(HTMLConstants.RTL)) )
{
throw new ExtendedIllegalArgumentException("dir", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
String old = dir_;
if (vetos_ != null) vetos_.fireVetoableChange("dir", old, dir ); //@CRS
dir_ = dir;
if (changes_ != null) changes_.firePropertyChange("dir", old, dir ); //@CRS
}
/**
* Sets the table cell element.
* @param element The cell element.
* @exception PropertyVetoException If the change is vetoed.
**/
public void setElement(String element) throws PropertyVetoException
{
setElement(new HTMLText(element));
}
/**
* Sets the table cell element.
* @param element The cell element.
* @exception PropertyVetoException If the change is vetoed.
**/
public void setElement(HTMLTagElement element) throws PropertyVetoException
{
if (element == null)
throw new NullPointerException("element");
HTMLTagElement old = element_;
if (vetos_ != null) vetos_.fireVetoableChange("element", old, element ); //@CRS
element_ = element;
if (changes_ != null) changes_.firePropertyChange("element", old, element ); //@CRS
}
/**
* Sets the height relative to the table. The default unit is pixels.
* A table row can only have one height.
* If multiple cell heights are defined for different cells in the row, the outcome is browser
* dependent.
* @param height The height.
* @exception PropertyVetoException If the change is vetoed.
* @see #setHeightInPercent
**/
public void setHeight(int height) throws PropertyVetoException
{
if (height <= 0)
throw new ExtendedIllegalArgumentException("height", ExtendedIllegalArgumentException.RANGE_NOT_VALID);
//@CRS Integer oldHeight = new Integer(height_);
//@CRS Integer newHeight = new Integer(height);
int oldHeight = height_;
if (vetos_ != null) vetos_.fireVetoableChange("height", new Integer(oldHeight), new Integer(height)); //@CRS
height_ = height;
if (changes_ != null) changes_.firePropertyChange("height", new Integer(oldHeight), new Integer(height)); //@CRS
}
/**
* Sets the height relative to the table in pixels or percent.
* A table row can only have one height.
* If multiple cell heights are defined for different cells in the row, the outcome is browser dependent.
* @param height The height.
* @param heightInPercent true if unit is percent; false if pixels.
* @exception PropertyVetoException If the change is vetoed.
**/
public void setHeight(int height, boolean heightInPercent) throws PropertyVetoException
{
int oldHeight = height_;
setHeight(height);
try
{
setHeightInPercent(heightInPercent);
}
catch (PropertyVetoException e)
{
// Restore the original height.
height_ = oldHeight;
throw new PropertyVetoException("heightInPercent", e.getPropertyChangeEvent());
}
}
/**
* Sets the height unit in percent or pixels. The default is false.
* @param heightInPercent true if unit is percent; false if pixels.
* @exception PropertyVetoException If the change is vetoed.
* @see #setHeight
**/
public void setHeightInPercent(boolean heightInPercent) throws PropertyVetoException
{
//@CRS Boolean oldHeight = new Boolean(heightPercent_);
//@CRS Boolean newHeight = new Boolean(heightInPercent);
boolean oldHeight = heightPercent_; //@CRS
if (vetos_ != null) vetos_.fireVetoableChange("heightInPercent", new Boolean(oldHeight), new Boolean(heightInPercent)); //@CRS
heightPercent_ = heightInPercent;
if (changes_ != null) changes_.firePropertyChange("heightInPercent", new Boolean(oldHeight), new Boolean(heightInPercent)); //@CRS
}
/**
* Sets the horizontal alignment. The default value is LEFT.
* @param alignment The horizontal alignment. One of the following constants
* defined in HTMLConstants: CENTER, LEFT, or RIGHT.
* @exception PropertyVetoException If the change is vetoed.
* @see com.ibm.as400.util.html.HTMLConstants
**/
public void setHorizontalAlignment(String alignment) throws PropertyVetoException
{
if (alignment == null)
{
throw new NullPointerException("alignment");
}
else if (alignment.equalsIgnoreCase(LEFT) ||
alignment.equalsIgnoreCase(CENTER) ||
alignment.equalsIgnoreCase(RIGHT))
{
String old = align_;
if (vetos_ != null) vetos_.fireVetoableChange("alignment", old, alignment ); //@CRS
align_ = alignment;
if (changes_ != null) changes_.firePropertyChange("alignment", old, alignment ); //@CRS
}
else
{
throw new ExtendedIllegalArgumentException("alignment", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
}
/**
* Sets the language of the table cell.
* @param lang The language. Example language tags include:
* en and en-US.
*
* @exception PropertyVetoException If a change is vetoed.
**/
public void setLanguage(String lang) //$B1A
throws PropertyVetoException
{
if (lang == null)
throw new NullPointerException("lang");
String old = lang_;
if (vetos_ != null) vetos_.fireVetoableChange("lang", old, lang ); //@CRS
lang_ = lang;
if (changes_ != null) changes_.firePropertyChange("lang", old, lang ); //@CRS
}
/**
* Sets the row span. The default value is one.
* @param span The row span.
* @exception PropertyVetoException If the change is vetoed.
**/
public void setRowSpan(int span) throws PropertyVetoException
{
if (span <= 0)
throw new ExtendedIllegalArgumentException("span", ExtendedIllegalArgumentException.RANGE_NOT_VALID);
//@CRS Integer oldSpan = new Integer(rowSpan_);
//@CRS Integer newSpan = new Integer(span);
int oldSpan = rowSpan_; //@CRS
if (vetos_ != null) vetos_.fireVetoableChange("span", new Integer(oldSpan), new Integer(span)); //@CRS
rowSpan_ = span;
if (changes_ != null) changes_.firePropertyChange("span", new Integer(oldSpan), new Integer(span)); //@CRS
}
/**
* Sets if Formatting Object tags should be used.
* The default value is false.
* @param useFO - true if output generated is a XSL formatting object, false if the output generated is HTML.
**/
public void setUseFO(boolean useFO) // @D1A
{
boolean old = useFO_;
useFO_ = useFO;
if (changes_ != null) changes_.firePropertyChange("useFO", old, useFO );
}
/**
* Sets the border width in pixels. A value of zero indicates no border.
* The default value is one.
* @param borderWidth The border width.
**/
public void setBorderWidth(int borderWidth) // @D1A
{
Integer oldWidth = new Integer(borderWidth_);
Integer newWidth = new Integer(borderWidth);
borderWidth_ = borderWidth;
if (changes_ != null) changes_.firePropertyChange("borderWidth", oldWidth, newWidth);
}
/**
* Sets the global table cell padding. The cell padding is the spacing between
* data in a table cell and the border of the cell.
* @param cellPadding The cell padding.
**/
public void setCellPadding(int cellPadding) // @D1A
{
Integer oldPadding = new Integer(cellPadding_);
Integer newPadding = new Integer(cellPadding);
cellPadding_ = cellPadding;
if (changes_ != null) changes_.firePropertyChange("cellPadding", oldPadding, newPadding);
}
/**
* Sets the vertical alignment.
* @param alignment The vertical alignment. One of the following constants
* defined in HTMLConstants: BASELINE, BOTTOM, MIDDLE, or TOP.
* @exception PropertyVetoException If the change is vetoed.
* @see com.ibm.as400.util.html.HTMLConstants
**/
public void setVerticalAlignment(String alignment) throws PropertyVetoException
{
if (alignment == null)
{
throw new NullPointerException("alignment");
}
else if (alignment.equalsIgnoreCase(TOP) ||
alignment.equalsIgnoreCase(MIDDLE) ||
alignment.equalsIgnoreCase(BOTTOM) ||
alignment.equalsIgnoreCase(BASELINE))
{
String old = vAlign_;
if (vetos_ != null) vetos_.fireVetoableChange("alignment", old, alignment ); //@CRS
vAlign_ = alignment;
if (changes_ != null) changes_.firePropertyChange("alignment", old, alignment ); //@CRS
}
else
{
throw new ExtendedIllegalArgumentException("alignment", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
}
/**
* Sets the width relative to the table. The default width unit is pixels.
* A table column can only have one width and the width used is usually the widest.
* If multiple cell widths are defined for different cells in the column, the outcome is browser dependent.
* @param width The width.
* @exception PropertyVetoException If the change is vetoed.
* @see #setWidthInPercent
**/
public void setWidth(int width) throws PropertyVetoException
{
if (width <= 0)
throw new ExtendedIllegalArgumentException("width", ExtendedIllegalArgumentException.RANGE_NOT_VALID);
//@CRS Integer oldWidth = new Integer(width_);
//@CRS Integer newWidth = new Integer(width);
int oldWidth = width_; //@CRS //@K1C
if (vetos_ != null) vetos_.fireVetoableChange("width", new Integer(oldWidth), new Integer(width)); //@CRS
width_ = width;
if (changes_ != null) changes_.firePropertyChange("width", new Integer(oldWidth), new Integer(width)); //@CRS
}
/**
* Sets the width relative to the table in percent or pixels.
* A table column can only have one width and the width used is usually the widest.
* If multiple cell widths are defined for different cells in the column, the outcome
* is browser dependent.
* @param width The width.
* @param widthInPercent true if unit is percent; false if pixels.
* @exception PropertyVetoException If the change is vetoed.
**/
public void setWidth(int width, boolean widthInPercent) throws PropertyVetoException
{
int oldWidth = width_;
setWidth(width);
try
{
setWidthInPercent(widthInPercent);
}
catch (PropertyVetoException e)
{
width_ = oldWidth;
throw new PropertyVetoException("widthInPercent", e.getPropertyChangeEvent());
}
}
/**
* Sets the width unit in percent or pixels. The default is false.
* @param widthInPercent true if unit is percent; false if pixels.
* @exception PropertyVetoException If the change is vetoed.
* @see #setWidth
**/
public void setWidthInPercent(boolean widthInPercent) throws PropertyVetoException
{
//@CRS Boolean oldWidth = new Boolean(widthPercent_);
//@CRS Boolean newWidth = new Boolean(widthInPercent);
boolean oldWidth = widthPercent_; //@CRS
if (vetos_ != null) vetos_.fireVetoableChange("widthInPercent", new Boolean(oldWidth), new Boolean(widthInPercent)); //@CRS
widthPercent_ = widthInPercent;
if (changes_ != null) changes_.firePropertyChange("widthInPercent", new Boolean(oldWidth), new Boolean(widthInPercent)); //@CRS
}
/**
* Sets if the cell data will use normal HTML linebreaking conventions.
* The default value is true.
* @param wrap true if normal HTML linebreaking is used; false otherwise.
* @exception PropertyVetoException If the change is vetoed.
**/
public void setWrap(boolean wrap) throws PropertyVetoException
{
//@CRS Boolean oldWrap = new Boolean(wrap_);
//@CRS Boolean newWrap = new Boolean(wrap);
boolean oldWrap = wrap_; //@CRS
if (vetos_ != null) vetos_.fireVetoableChange("wrap", new Boolean(oldWrap), new Boolean(wrap)); //@CRS
wrap_ = wrap;
if (changes_ != null) changes_.firePropertyChange("wrap", new Boolean(oldWrap), new Boolean(wrap)); //@CRS
}
/**
* Returns the HTML table cell tag.
* @return The cell tag.
**/
public String toString()
{
return getTag();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy