//######################################################################################### //★★★★★★★ http://www.cnpopsoft.com [华普软件] ★★★★★★★ //★★★★★★★ 华普软件 - VB & C#.NET 专业论文与源码荟萃! ★★★★★★★ //######################################################################################### /* * Copyright ?2005, Mathew Hall * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * * - Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * * - Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY * OF SUCH DAMAGE. */ using System; using System.ComponentModel; using System.Drawing; using System.Globalization; using System.Windows.Forms; using XPTable.Editors; using XPTable.Events; using XPTable.Models.Design; using XPTable.Renderers; using XPTable.Sorting; namespace XPTable.Models { /// /// Represents a Column whose Cells are displayed as a DateTime /// [DesignTimeVisible(false), ToolboxItem(false)] public class DateTimeColumn : DropDownColumn { #region Class Data /// /// Default long date format /// public static readonly string LongDateFormat = DateTimeFormatInfo.CurrentInfo.LongDatePattern; /// /// Default short date format /// public static readonly string ShortDateFormat = DateTimeFormatInfo.CurrentInfo.ShortDatePattern; /// /// Default time format /// public static readonly string TimeFormat = DateTimeFormatInfo.CurrentInfo.LongTimePattern; /// /// The format of the date and time displayed in the Cells /// private DateTimePickerFormat dateFormat; /// /// The custom date/time format string /// private string customFormat; #endregion #region Constructor /// /// Creates a new DateTimeColumn with default values /// public DateTimeColumn() : base() { this.Init(); } /// /// Creates a new DateTimeColumn with the specified header text /// /// The text displayed in the column's header public DateTimeColumn(string text) : base(text) { this.Init(); } /// /// Creates a new DateTimeColumn with the specified header text and width /// /// The text displayed in the column's header /// The column's width public DateTimeColumn(string text, int width) : base(text, width) { this.Init(); } /// /// Creates a new DateTimeColumn with the specified header text, width and visibility /// /// The text displayed in the column's header /// The column's width /// Specifies whether the column is visible public DateTimeColumn(string text, int width, bool visible) : base(text, width, visible) { this.Init(); } /// /// Creates a new DateTimeColumn with the specified header text and image /// /// The text displayed in the column's header /// The image displayed on the column's header public DateTimeColumn(string text, Image image) : base(text, image) { this.Init(); } /// /// Creates a new DateTimeColumn with the specified header text, image and width /// /// The text displayed in the column's header /// The image displayed on the column's header /// The column's width public DateTimeColumn(string text, Image image, int width) : base(text, image, width) { this.Init(); } /// /// Creates a new DateTimeColumn with the specified header text, image, width and visibility /// /// The text displayed in the column's header /// The image displayed on the column's header /// The column's width /// Specifies whether the column is visible public DateTimeColumn(string text, Image image, int width, bool visible) : base(text, image, width, visible) { this.Init(); } /// /// Initializes the DateTimeColumn with default values /// internal void Init() { this.dateFormat = DateTimePickerFormat.Long; this.customFormat = DateTimeFormatInfo.CurrentInfo.ShortDatePattern + " " + DateTimeFormatInfo.CurrentInfo.LongTimePattern; } #endregion #region Methods /// /// Gets a string that specifies the name of the Column's default CellRenderer /// /// A string that specifies the name of the Column's default /// CellRenderer public override string GetDefaultRendererName() { return "DATETIME"; } /// /// Gets the Column's default CellRenderer /// /// The Column's default CellRenderer public override ICellRenderer CreateDefaultRenderer() { return new DateTimeCellRenderer(); } /// /// Gets a string that specifies the name of the Column's default CellEditor /// /// A string that specifies the name of the Column's default /// CellEditor public override string GetDefaultEditorName() { return "DATETIME"; } /// /// Gets the Column's default CellEditor /// /// The Column's default CellEditor public override ICellEditor CreateDefaultEditor() { return new DateTimeCellEditor(); } #endregion #region Properties /// /// Gets or sets the format of the date and time displayed in the Column's Cells /// [Category("Appearance"), DefaultValue(DateTimePickerFormat.Long), Description("The format of the date and time displayed in the Column's Cells")] public DateTimePickerFormat DateTimeFormat { get { return this.dateFormat; } set { if (!Enum.IsDefined(typeof(DateTimePickerFormat), value)) { throw new InvalidEnumArgumentException("value", (int) value, typeof(DateTimePickerFormat)); } if (this.dateFormat != value) { this.dateFormat = value; this.OnPropertyChanged(new ColumnEventArgs(this, ColumnEventType.RendererChanged, null)); } } } /// /// Gets or sets the custom date/time format string /// [Category("Appearance"), Description("The custom date/time format string")] public string CustomDateTimeFormat { get { return this.customFormat; } set { if (value == null) { throw new ArgumentNullException("CustomFormat cannot be null"); } if (!this.customFormat.Equals(value)) { this.customFormat = value; this.OnPropertyChanged(new ColumnEventArgs(this, ColumnEventType.RendererChanged, null)); } DateTime.Now.ToString(DateTimeFormatInfo.CurrentInfo.ShortDatePattern); } } /// /// Specifies whether the CustomDateTimeFormat property should be serialized at /// design time /// /// true if the CustomDateTimeFormat property should be serialized, /// false otherwise private bool ShouldSerializeCustomDateTimeFormat() { return !this.customFormat.Equals(DateTimeFormatInfo.CurrentInfo.ShortDatePattern + " " + DateTimeFormatInfo.CurrentInfo.LongTimePattern); } /// /// Gets or sets the string that specifies how the Column's Cell contents /// are formatted /// [Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)] public new string Format { get { return this.CustomDateTimeFormat; } set { this.CustomDateTimeFormat = value; } } /// /// Gets the Type of the Comparer used to compare the Column's Cells when /// the Column is sorting /// public override Type DefaultComparerType { get { return typeof(DateTimeComparer); } } #endregion } }