//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//------------------------------------------------------------------------------
namespace System.Web.UI.WebControls {
using System;
using System.ComponentModel;
using System.Drawing;
using System.Drawing.Design;
using System.Globalization;
using System.Web;
using System.Web.Util;
///
/// Constructs a table and defines its properties.
///
[
DefaultProperty("Rows"),
ParseChildren(true, "Rows"),
Designer("System.Web.UI.Design.WebControls.TableDesigner, " + AssemblyRef.SystemDesign),
SupportsEventValidation,
]
public class Table : WebControl, IPostBackEventHandler {
private TableRowCollection _rows;
private bool _hasRowSections;
///
///
/// Initializes a new instance of the class.
///
///
public Table() : base(HtmlTextWriterTag.Table) {
}
///
/// Indicates the URL of the background image to display
/// behind the table. The image will be tiled if it is smaller than the table.
///
[
WebCategory("Appearance"),
DefaultValue(""),
Editor("System.Web.UI.Design.ImageUrlEditor, " + AssemblyRef.SystemDesign, typeof(UITypeEditor)),
UrlProperty(),
WebSysDescription(SR.Table_BackImageUrl)
]
public virtual string BackImageUrl {
get {
if (ControlStyleCreated == false) {
return String.Empty;
}
return((TableStyle)ControlStyle).BackImageUrl;
}
set {
((TableStyle)ControlStyle).BackImageUrl = value;
}
}
[
DefaultValue(""),
Localizable(true),
WebCategory("Accessibility"),
WebSysDescription(SR.Table_Caption)
]
public virtual string Caption {
get {
string s = (string)ViewState["Caption"];
return (s != null) ? s : String.Empty;
}
set {
ViewState["Caption"] = value;
}
}
[
DefaultValue(TableCaptionAlign.NotSet),
WebCategory("Accessibility"),
WebSysDescription(SR.WebControl_CaptionAlign)
]
public virtual TableCaptionAlign CaptionAlign {
get {
object o = ViewState["CaptionAlign"];
return (o != null) ? (TableCaptionAlign)o : TableCaptionAlign.NotSet;
}
set {
if ((value < TableCaptionAlign.NotSet) ||
(value > TableCaptionAlign.Right)) {
throw new ArgumentOutOfRangeException("value");
}
ViewState["CaptionAlign"] = value;
}
}
///
/// Gets or sets
/// the distance (in pixels) between the border and
/// the contents of the table cell.
///
[
WebCategory("Appearance"),
DefaultValue(-1),
WebSysDescription(SR.Table_CellPadding)
]
public virtual int CellPadding {
get {
if (ControlStyleCreated == false) {
return -1;
}
return((TableStyle)ControlStyle).CellPadding;
}
set {
((TableStyle)ControlStyle).CellPadding = value;
}
}
///
/// Gets or
/// sets
/// the distance (in pixels) between table cells.
///
[
WebCategory("Appearance"),
DefaultValue(-1),
WebSysDescription(SR.Table_CellSpacing)
]
public virtual int CellSpacing {
get {
if (ControlStyleCreated == false) {
return -1;
}
return((TableStyle)ControlStyle).CellSpacing;
}
set {
((TableStyle)ControlStyle).CellSpacing = value;
}
}
///
/// Gets or sets the gridlines property of the
/// class.
///
[
WebCategory("Appearance"),
DefaultValue(GridLines.None),
WebSysDescription(SR.Table_GridLines)
]
public virtual GridLines GridLines {
get {
if (ControlStyleCreated == false) {
return GridLines.None;
}
return((TableStyle)ControlStyle).GridLines;
}
set {
((TableStyle)ControlStyle).GridLines = value;
}
}
internal bool HasRowSections {
get {
return _hasRowSections;
}
set {
_hasRowSections = value;
}
}
///
/// Gets or sets the horizontal alignment of the table within the page.
///
[
WebCategory("Layout"),
DefaultValue(HorizontalAlign.NotSet),
WebSysDescription(SR.Table_HorizontalAlign)
]
public virtual HorizontalAlign HorizontalAlign {
get {
if (ControlStyleCreated == false) {
return HorizontalAlign.NotSet;
}
return((TableStyle)ControlStyle).HorizontalAlign;
}
set {
((TableStyle)ControlStyle).HorizontalAlign = value;
}
}
public override bool SupportsDisabledAttribute {
get {
return RenderingCompatibility < VersionUtil.Framework40;
}
}
///
/// Gets the collection of rows within
/// the table.
///
[
MergableProperty(false),
WebSysDescription(SR.Table_Rows),
PersistenceMode(PersistenceMode.InnerDefaultProperty)
]
public virtual TableRowCollection Rows {
get {
if (_rows == null)
_rows = new TableRowCollection(this);
return _rows;
}
}
///
///
/// A protected method. Adds information about the border
/// color and border width HTML attributes to the list of attributes to render.
///
protected override void AddAttributesToRender(HtmlTextWriter writer) {
base.AddAttributesToRender(writer);
if (ControlStyleCreated) {
if (EnableLegacyRendering || writer is Html32TextWriter) {
// Must render bordercolor attribute to affect cell borders.
Color borderColor = BorderColor;
if (!borderColor.IsEmpty) {
writer.AddAttribute(HtmlTextWriterAttribute.Bordercolor, ColorTranslator.ToHtml(borderColor));
}
}
}
string borderWidthString = "0";
bool renderBorder = false;
if (ControlStyleCreated) {
// GridLines property controls whether we render the "border" attribute, as "border" controls
// whether gridlines appear in HTML 3.2. Always render a value for the border attribute.
Unit borderWidth = BorderWidth;
GridLines gridLines = GridLines;
if (gridLines != GridLines.None) {
if (borderWidth.IsEmpty || borderWidth.Type != UnitType.Pixel) {
borderWidthString = "1";
renderBorder = true;
}
else {
borderWidthString = ((int)borderWidth.Value).ToString(NumberFormatInfo.InvariantInfo);
}
}
}
if ((RenderingCompatibility < VersionUtil.Framework40) || renderBorder) {
writer.AddAttribute(HtmlTextWriterAttribute.Border, borderWidthString);
}
}
///
/// [To be supplied.]
///
protected override ControlCollection CreateControlCollection() {
return new RowControlCollection(this);
}
///
///
/// A protected method. Creates a table control style.
///
protected override Style CreateControlStyle() {
return new TableStyle(ViewState);
}
///
/// [To be supplied.]
///
protected virtual void RaisePostBackEvent(string argument) {
ValidateEvent(UniqueID, argument);
if (AdapterInternal != null) {
IPostBackEventHandler pbeh = AdapterInternal as IPostBackEventHandler;
if (pbeh != null) {
pbeh.RaisePostBackEvent(argument);
}
}
}
///
///
/// Renders out the caption of the table if needed, before any rows get rendered.
///
public override void RenderBeginTag(HtmlTextWriter writer) {
base.RenderBeginTag(writer);
string caption = Caption;
if (caption.Length != 0) {
TableCaptionAlign alignment = CaptionAlign;
if (alignment != TableCaptionAlign.NotSet) {
string alignValue = "Right";
switch (alignment) {
case TableCaptionAlign.Top:
alignValue = "Top";
break;
case TableCaptionAlign.Bottom:
alignValue = "Bottom";
break;
case TableCaptionAlign.Left:
alignValue = "Left";
break;
}
writer.AddAttribute(HtmlTextWriterAttribute.Align, alignValue);
}
writer.RenderBeginTag(HtmlTextWriterTag.Caption);
writer.Write(caption);
writer.RenderEndTag();
}
}
///
/// Render the table rows.
///
protected internal override void RenderContents(HtmlTextWriter writer) {
TableRowCollection rows = Rows;
int rowCount = rows.Count;
if (rowCount > 0) {
if (HasRowSections) {
TableRowSection currentSection = TableRowSection.TableHeader;
bool openedTag = false;
foreach (TableRow row in rows) {
if (row.TableSection < currentSection) {
// throw if table sections aren't in order
throw new HttpException(SR.GetString(SR.Table_SectionsMustBeInOrder, ID));
}
if (currentSection < row.TableSection || (row.TableSection == TableRowSection.TableHeader && !openedTag)) {
if (openedTag) {
writer.RenderEndTag();
}
currentSection = row.TableSection;
openedTag = true;
switch (currentSection) {
case TableRowSection.TableHeader:
writer.RenderBeginTag(HtmlTextWriterTag.Thead);
break;
case TableRowSection.TableBody:
writer.RenderBeginTag(HtmlTextWriterTag.Tbody);
break;
case TableRowSection.TableFooter:
writer.RenderBeginTag(HtmlTextWriterTag.Tfoot);
break;
}
}
row.RenderControl(writer);
}
writer.RenderEndTag();
}
else {
foreach (TableRow row in rows) {
row.RenderControl(writer);
}
}
}
}
void IPostBackEventHandler.RaisePostBackEvent(string eventArgument) {
RaisePostBackEvent(eventArgument);
}
///
/// [To be supplied.]
///
protected class RowControlCollection : ControlCollection {
internal RowControlCollection (Control owner) : base(owner) {
}
///
/// Adds the specified object to the collection. The new control is added
/// to the end of the array.
///
public override void Add(Control child) {
if (child is TableRow)
base.Add(child);
else
throw new ArgumentException(SR.GetString(SR.Cannot_Have_Children_Of_Type, "Table", child.GetType().Name.ToString(CultureInfo.InvariantCulture))); // throw an exception here
}
///
/// Adds the specified object to the collection. The new control is added
/// to the array at the specified index location.
///
public override void AddAt(int index, Control child) {
if (child is TableRow)
base.AddAt(index, child);
else
throw new ArgumentException(SR.GetString(SR.Cannot_Have_Children_Of_Type, "Table", child.GetType().Name.ToString(CultureInfo.InvariantCulture))); // throw an exception here
}
} // class RowControlCollection
} // class Table
}