#if FRAMEWORK20
using System;
using System.Collections.Generic;
using System.Text;
using System.ComponentModel;
using DevComponents.DotNetBar;
using System.Windows.Forms;
using System.Drawing;
using System.Globalization;
namespace DevComponents.Editors.DateTimeAdv
{
    /// 
    /// Represents a control that enables the user to select a date using a visual monthly calendar display. 
    /// 
    [ToolboxBitmap(typeof(DotNetBarManager), "MonthCalendarAdv.ico"), ToolboxItem(true), Designer("DevComponents.DotNetBar.Design.MonthCalendarAdvDesigner, DevComponents.DotNetBar.Design, Version=14.1.0.37, Culture=neutral,  PublicKeyToken=90f470f34c89ccaf")]
    public class MonthCalendarAdv : ItemControl
    {
        #region Private Variables
        private MonthCalendarItem _MonthCalendar = null;
        #endregion
        #region Events
        /// 
        /// Occurs when month displayed by the item has changed.
        /// 
        public event EventHandler MonthChanged;
        /// 
        /// Occurs before the month that is displayed is changed.
        /// 
        public event EventHandler MonthChanging;
        /// 
        /// Occurs when child label representing days is rendered and it allows you to override default rendering.
        /// 
        public event DayPaintEventHandler PaintLabel;
        /// 
        /// Occurs when mouse button is pressed over the day/week label inside of the calendar.
        /// 
        [System.ComponentModel.Description("Occurs when mouse button is pressed over the day/week label inside of the calendar.")]
        public event System.Windows.Forms.MouseEventHandler LabelMouseDown;
        /// 
        /// Occurs when mouse button is released over day/week label inside of the calendar.
        /// 
        [System.ComponentModel.Description("Occurs when mouse button is released over day/week label inside of the calendar.")]
        public event System.Windows.Forms.MouseEventHandler LabelMouseUp;
        /// 
        /// Occurs when mouse enters the day/week label inside of the calendar.
        /// 
        [System.ComponentModel.Description("Occurs when mouse enters the day/week label inside of the calendar.")]
        public event EventHandler LabelMouseEnter;
        /// 
        /// Occurs when mouse leaves the day/week label inside of the calendar.
        /// 
        [System.ComponentModel.Description("Occurs when mouse leaves the day/week label inside of the calendar.")]
        public event EventHandler LabelMouseLeave;
        /// 
        /// Occurs when mouse moves over the day/week label inside of the calendar.
        /// 
        [System.ComponentModel.Description("Occurs when mouse moves over the day/week label inside of the calendar.")]
        public event System.Windows.Forms.MouseEventHandler LabelMouseMove;
        /// 
        /// Occurs when mouse remains still inside an day/week label of the calendar for an amount of time.
        /// 
        [System.ComponentModel.Description("Occurs when mouse remains still inside an day/week label of the calendar for an amount of time.")]
        public event EventHandler LabelMouseHover;
        /// 
        /// Occurs when SelectedDate property has changed.
        /// 
        [System.ComponentModel.Description("Occurs when SelectedDate property has changed.")]
        public event EventHandler DateChanged;
        /// 
        /// Occurs when the user makes an explicit date selection using the mouse. 
        /// 
        /// 
        /// This event is similar to the DateChanged event, but it occurs at the end of a date selection made using the mouse.
        /// The DateChanged event occurs during any date selection, whether by mouse, keyboard, or code. You should handle this event
        /// when you enable multiple date selection through MultiSelect property and want to be notified after the date selection has been
        /// made. DateChanged event would fire each time selection changes during the selection of multiple dates.
        /// 
        [Description("Occurs when the user makes an explicit date selection using the mouse.")]
        public event DateRangeEventHandler DateSelected;
        #endregion
        #region Constructor
        /// 
        /// Initializes a new instance of the MonthCalendarAdv class.
        /// 
        public MonthCalendarAdv()
        {
            _MonthCalendar = new MonthCalendarItem();
            _MonthCalendar.GlobalItem = false;
            _MonthCalendar.ContainerControl = this;
            _MonthCalendar.Stretch = false;
            _MonthCalendar.Displayed = true;
            _MonthCalendar.Style = eDotNetBarStyle.StyleManagerControlled;
            this.ColorScheme.Style = eDotNetBarStyle.StyleManagerControlled;
            _MonthCalendar.SetOwner(this);
            _MonthCalendar.MonthChanged += new EventHandler(MonthCalendar_MonthChanged);
            _MonthCalendar.MonthChanging += new EventHandler(MonthCalendar_MonthChanging);
            _MonthCalendar.PaintLabel += new DayPaintEventHandler(MonthCalendar_PaintLabel);
            _MonthCalendar.LabelMouseDown += new MouseEventHandler(MonthCalendar_LabelMouseDown);
            _MonthCalendar.LabelMouseUp += new MouseEventHandler(MonthCalendar_LabelMouseUp);
            _MonthCalendar.LabelMouseEnter += new EventHandler(MonthCalendar_LabelMouseEnter);
            _MonthCalendar.LabelMouseLeave += new EventHandler(MonthCalendar_LabelMouseLeave);
            _MonthCalendar.LabelMouseMove += new MouseEventHandler(MonthCalendar_LabelMouseMove);
            _MonthCalendar.LabelMouseHover += new EventHandler(MonthCalendar_LabelMouseHover);
            _MonthCalendar.DateChanged += new EventHandler(MonthCalendar_DateChanged);
            _MonthCalendar.DateSelected += new DateRangeEventHandler(MonthCalendar_DateSelected);
            this.SetBaseItemContainer(_MonthCalendar);
        }
        #endregion
        #region Internal Implementation
        protected override void ScaleControl(SizeF factor, BoundsSpecified specified)
        {
            if (Dpi.RecordScalePerControl)
                Dpi.SetScaling(factor);
            base.ScaleControl(factor, specified);
            AdjustSize();
        }
        private void MonthCalendar_DateSelected(object sender, DateRangeEventArgs e)
        {
            OnDateSelected(e);
        }
        private void MonthCalendar_DateChanged(object sender, EventArgs e)
        {
            OnDateChanged(e);
        }
        private void MonthCalendar_LabelMouseHover(object sender, EventArgs e)
        {
            OnLabelMouseHover(sender, e);
        }
        private void MonthCalendar_LabelMouseMove(object sender, MouseEventArgs e)
        {
            OnLabelMouseMove(sender, e);
        }
        private void MonthCalendar_LabelMouseLeave(object sender, EventArgs e)
        {
            OnLabelMouseLeave(sender, e);
        }
        private void MonthCalendar_LabelMouseEnter(object sender, EventArgs e)
        {
            OnLabelMouseEnter(sender, e);
        }
        private void MonthCalendar_LabelMouseUp(object sender, MouseEventArgs e)
        {
            OnLabelMouseUp(sender, e);
        }
        private void MonthCalendar_LabelMouseDown(object sender, MouseEventArgs e)
        {
            OnLabelMouseDown(sender, e);
        }
        private void MonthCalendar_PaintLabel(object sender, DayPaintEventArgs e)
        {
            OnPaintLabel(sender, e);
        }
        private void MonthCalendar_MonthChanging(object sender, EventArgs e)
        {
            OnMonthChanging(e);
        }
        private void MonthCalendar_MonthChanged(object sender, EventArgs e)
        {
            OnMonthChanged(e);
        }
        //protected override Rectangle GetItemContainerRectangle()
        //{
        //    Rectangle r = base.GetItemContainerRectangle();
        //    ElementStyle style = GetBackgroundStyle();
        //    if (style != null)
        //    {
        //        if (style.PaintBorder && (style.CornerType == eCornerType.Rounded || style.CornerType == eCornerType.Diagonal))
        //            r.Inflate(-style.BorderWidth / 2, -style.BorderWidth / 2);
        //    }
        //    return r;
        //}
        /// 
        /// Returns the DayLabel at given client coordinates or null/nothing if there is no label at give location.
        /// 
        /// X - position in client coordinates.
        /// Y - position in client coordinates.
        /// DayLabel at given coordinates or null/nothing.
        public DayLabel GetDayAt(int x, int y)
        {
            return _MonthCalendar.GetDayAt(x, y);
        }
        /// 
        /// Returns the DayLabel that represents the date.
        /// 
        /// Date to find label for.
        /// DayLabel object or nothing if date cannot be founds.
        public DayLabel GetDay(DateTime date)
        {
            return _MonthCalendar.GetDay(date);
        }
        /// 
        /// Gets or sets the array of DateTime objects that determine which monthly days to mark using Colors.MonthlyMarker settings. 
        /// Make sure to call UpdateMarkedDates() method to update calendar display with marked dates.
        /// 
        [Localizable(true), Description("Indicates array of DateTime objects that determine which monthly days to mark using Colors.MonthlyMarker settings. ")]
        public DateTime[] MonthlyMarkedDates
        {
            get { return _MonthCalendar.MonthlyMarkedDates; }
            set { _MonthCalendar.MonthlyMarkedDates = value; }
        }
        /// 
        /// Returns whether property should be serialized. Provided for Windows Forms designer support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public bool ShouldSerializeMonthlyMarkedDates()
        {
            return _MonthCalendar.ShouldSerializeMonthlyMarkedDates();
        }
        /// 
        /// Resets property to its default value. Provided for Windows Forms designer support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public void ResetMonthlyMarkedDates()
        {
            _MonthCalendar.ResetMonthlyMarkedDates();
        }
        /// 
        /// Removes all monthly marked dates. Note that you must call UpdateMarkedDates method to reflect these changes on calendar.
        /// 
        public void RemoveAllMonthlyMarkedDates()
        {
            _MonthCalendar.RemoveAllMonthlyMarkedDates();
        }
        /// 
        /// Removes the date from the MonthlyMarkedDates. Note that you must call UpdateMarkedDates method to reflect these changes on calendar.
        /// 
        /// 
        public void RemoveMonthlyMarkedDate(DateTime dt)
        {
            _MonthCalendar.RemoveMonthlyMarkedDate(dt);
        }
        /// 
        /// Gets or sets the array of DayOfWeek members that determine which days of week to mark using Colors.WeeklyMarker settings. 
        /// 
        [Localizable(true), Description("Indicates array of DateTime objects that determine which monthly days to mark using Colors.MonthlyMarker settings. ")]
        public DayOfWeek[] WeeklyMarkedDays
        {
            get { return _MonthCalendar.WeeklyMarkedDays; }
            set { _MonthCalendar.WeeklyMarkedDays = value; }
        }
        /// 
        /// Returns whether property should be serialized. Provided for Windows Forms designer support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public bool ShouldSerializeWeeklyMarkedDays()
        {
            return _MonthCalendar.ShouldSerializeWeeklyMarkedDays();
        }
        /// 
        /// Resets property to its default value. Provided for Windows Forms designer support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public void ResetWeeklyMarkedDays()
        {
            _MonthCalendar.ResetWeeklyMarkedDays();
        }
        /// 
        /// Removes all weekly marked dates. Note that you must call UpdateMarkedDates method to reflect these changes on calendar.
        /// 
        public void RemoveAllWeeklyMarkedDays()
        {
            _MonthCalendar.RemoveAllWeeklyMarkedDays();
        }
        /// 
        /// Removes the day from the WeeklyMarkedDays. Note that you must call UpdateMarkedDates method to reflect these changes on calendar.
        /// 
        /// 
        public void RemoveWeeklyMarkedDay(DayOfWeek dt)
        {
            _MonthCalendar.RemoveWeeklyMarkedDay(dt);
        }
        /// 
        /// Gets or sets the array of DateTime objects that determines which annual days are marked using Colors.AnnualMarker settings.
        /// Make sure to call UpdateMarkedDates() method to update calendar display with marked dates.
        /// 
        [Localizable(true), Description("Indicates array of DateTime objects that determines which annual days are marked using Colors.AnnualMarker settings.")]
        public DateTime[] AnnuallyMarkedDates
        {
            get { return _MonthCalendar.AnnuallyMarkedDates; }
            set { _MonthCalendar.AnnuallyMarkedDates = value; }
        }
        /// 
        /// Returns whether property should be serialized. Provided for Windows Forms designer support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public bool ShouldSerializeAnnuallyMarkedDates()
        {
            return _MonthCalendar.ShouldSerializeAnnuallyMarkedDates();
        }
        /// 
        /// Resets property to its default value. Provided for Windows Forms designer support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public void ResetAnnuallyMarkedDates()
        {
            _MonthCalendar.ResetAnnuallyMarkedDates();
        }
        /// 
        /// Removes all annually marked dates. Note that you must call UpdateMarkedDates method to reflect these changes on calendar.
        /// 
        public void RemoveAllAnnuallyMarkedDates()
        {
            _MonthCalendar.RemoveAllAnnuallyMarkedDates();
        }
        /// 
        /// Removes the date from the AnnuallyMarkedDates. Note that you must call UpdateMarkedDates method to reflect these changes on calendar.
        /// 
        /// 
        public void RemoveAnnuallyMarkedDate(DateTime dt)
        {
            _MonthCalendar.RemoveAnnuallyMarkedDate(dt);
        }
        /// 
        /// Gets or sets the array of DateTime objects that determines which non-recurring dates are marked using Colors.DayMarker settings. 
        /// Make sure to call UpdateMarkedDates() method to update calendar display with marked dates.
        /// 
        [Localizable(true), Description("Indicates array of DateTime objects that determines which non-recurring dates are marked using Colors.DayMarker settings.")]
        public DateTime[] MarkedDates
        {
            get { return _MonthCalendar.MarkedDates; }
            set { _MonthCalendar.MarkedDates = value; }
        }
        /// 
        /// Returns whether property should be serialized. Provided for Windows Forms designer support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public bool ShouldSerializeMarkedDates()
        {
            return _MonthCalendar.ShouldSerializeMarkedDates();
        }
        /// 
        /// Resets property to its default value. Provided for Windows Forms designer support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public void ResetMarkedDates()
        {
            _MonthCalendar.ResetMarkedDates();
        }
        /// 
        /// Removes all marked dates set through MarkedDates property. Note that you must call UpdateMarkedDates method to reflect these changes on calendar.
        /// 
        public void RemoveAllMarkedDates()
        {
            _MonthCalendar.RemoveAllMarkedDates();
        }
        /// 
        /// Removes the date from the MarkedDates collection. Note that you must call UpdateMarkedDates method to reflect these changes on calendar.
        /// 
        /// 
        public void RemoveMarkedDate(DateTime dt)
        {
            _MonthCalendar.RemoveMarkedDate(dt);
        }
        /// 
        /// Repaints the marked dates to reflect the dates set in the lists of marked dates.
        /// Use this method to reflect the changes made to the AnnuallyMarkedDates, MonthlyMarkedDates or MarkedDates properties as well
        /// as change to the marked Colors properties.
        /// 
        public void UpdateMarkedDates()
        {
            _MonthCalendar.UpdateMarkedDates();
        }
        internal bool GetDesignModeInternal()
        {
            return DesignMode;
        }
        /// 
        /// Gets or sets the first month displayed by the control.
        /// 
        [Description("Indicates the first month displayed on the control.")]
        public DateTime DisplayMonth
        {
            get { return _MonthCalendar.DisplayMonth; }
            set { _MonthCalendar.DisplayMonth = value; }
        }
        /// 
        /// Gets number of months displayed on the control.
        /// 
        [Browsable(false)]
        public int DisplayedMonthCount
        {
            get
            {
                return _MonthCalendar.DisplayedMonthCount;
            }
        }
        /// 
        /// Gets the calendar colors used by the control.
        /// 
        [NotifyParentPropertyAttribute(true), Category("Appearance"), Description("Gets colors used by control."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        public MonthCalendarColors Colors
        {
            get { return _MonthCalendar.Colors; }
        }
        /// 
        /// Raises the DateChanged event.
        /// 
        /// Provides event data.
        protected virtual void OnDateChanged(EventArgs e)
        {
            if (DateChanged != null)
                DateChanged(this, e);
        }
        /// 
        /// Raises the DateSelected event.
        /// 
        /// Provides event data.
        protected virtual void OnDateSelected(DateRangeEventArgs e)
        {
            if (DateSelected != null)
                DateSelected(this, e);
        }
        /// 
        /// Raises the MonthChanged event.
        /// 
        /// Provides additional event data.
        protected virtual void OnMonthChanged(EventArgs e)
        {
            if (MonthChanged != null)
                MonthChanged(this, e);
        }
        /// 
        /// Raises the MonthChanging event.
        /// 
        /// Provides additional event data.
        protected virtual void OnMonthChanging(EventArgs e)
        {
            if (MonthChanging != null)
                MonthChanging(this, e);
        }
        /// 
        /// Raises the PaintLabel event.
        /// 
        /// Provides event data.
        protected virtual void OnPaintLabel(object label, DayPaintEventArgs e)
        {
            if (PaintLabel != null)
                PaintLabel(label, e);
        }
        /// 
        /// Raises the LabelMouseDown event.
        /// 
        /// Provides event data.
        protected virtual void OnLabelMouseDown(object sender, MouseEventArgs e)
        {
            if (LabelMouseDown != null)
                LabelMouseDown(sender, e);
        }
        /// 
        /// Raises the LabelMouseUp event.
        /// 
        /// Provides event data.
        protected virtual void OnLabelMouseUp(object sender, MouseEventArgs e)
        {
            if (LabelMouseUp != null)
                LabelMouseUp(sender, e);
        }
        /// 
        /// Raises the LabelMouseEnter event.
        /// 
        /// Provides event data.
        protected virtual void OnLabelMouseEnter(object sender, EventArgs e)
        {
            if (LabelMouseEnter != null)
                LabelMouseEnter(sender, e);
        }
        /// 
        /// Raises the LabelMouseLeave event.
        /// 
        /// Provides event data.
        protected virtual void OnLabelMouseLeave(object sender, EventArgs e)
        {
            if (LabelMouseLeave != null)
                LabelMouseLeave(sender, e);
        }
        /// 
        /// Raises the LabelMouseMove event.
        /// 
        /// Provides event data.
        protected virtual void OnLabelMouseMove(object sender, MouseEventArgs e)
        {
            if (LabelMouseMove != null)
                LabelMouseMove(sender, e);
        }
        /// 
        /// Raises the LabelMouseHover event.
        /// 
        /// Provides event data.
        protected virtual void OnLabelMouseHover(object sender, EventArgs e)
        {
            if (LabelMouseHover != null)
                LabelMouseHover(sender, e);
        }
        /// 
        /// Gets or sets the size of each day item on the calendar. Default value is 24, 15.
        /// 
        [Description("Indicate size of each day item on the calendar.")]
        public Size DaySize
        {
            get { return _MonthCalendar.DaySize; }
            set
            {
                _MonthCalendar.DaySize = value;
                InvalidateAutoSize();
            }
        }
        /// 
        /// Gets whether property should be serialized. Provided for designer support.
        /// 
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public bool ShouldSerializeDaySize()
        {
            return _MonthCalendar.ShouldSerializeDaySize();
        }
        /// 
        /// Reset property to default value. Provided for designer support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public void ResetDaySize()
        {
            _MonthCalendar.ResetDaySize();
        }
        /// 
        /// Gets or sets the size of date navigation buttons on the calendar. Default value is 13, 18. If you increase size of the navigation
        /// buttons change DaySize as well so everything fits.
        /// 
        [Description("Indicate size of date navigation buttons on the calendar. If you increase size of the navigation buttons change DaySize as well so everything fits.")]
        public Size NavigationButtonSize
        {
            get { return _MonthCalendar.NavigationButtonSize; }
            set
            {
                _MonthCalendar.NavigationButtonSize = value;
                InvalidateAutoSize();
            }
        }
        /// 
        /// Gets whether property should be serialized. Provided for designer support.
        /// 
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public bool ShouldSerializeNavigationButtonSize()
        {
            return _MonthCalendar.ShouldSerializeNavigationButtonSize();
        }
        /// 
        /// Reset property to default value. Provided for designer support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public void ResetNavigationButtonSize()
        {
            _MonthCalendar.ResetNavigationButtonSize();
        }
        /// 
        /// Gets or sets the minimum date and time that can be selected in the control.
        /// 
        [Description("Indicates minimum date and time that can be selected in the control.")]
        public System.DateTime MinDate
        {
            get { return _MonthCalendar.MinDate; }
            set { _MonthCalendar.MinDate = value; }
        }
        /// 
        /// Gets whether Value property should be serialized by Windows Forms designer.
        /// 
        /// true if value serialized otherwise false.
        public bool ShouldSerializeMinDate()
        {
            return _MonthCalendar.ShouldSerializeMinDate();
        }
        /// 
        /// Reset the MinDate property to its default value.
        /// 
        public void ResetMinDate()
        {
            _MonthCalendar.ResetMinDate();
        }
        /// 
        /// Gets or sets the maximum date and time that can be selected in the control.
        /// 
        [Description("Indicates maximum date and time that can be selected in the control.")]
        public System.DateTime MaxDate
        {
            get { return _MonthCalendar.MaxDate; }
            set { _MonthCalendar.MaxDate = value; }
        }
        /// 
        /// Gets whether Value property should be serialized by Windows Forms designer.
        /// 
        /// true if value serialized otherwise false.
        public bool ShouldSerializeMaxDate()
        {
            return _MonthCalendar.ShouldSerializeMaxDate();
        }
        /// 
        /// Reset the MaxDate property to its default value.
        /// 
        public void ResetMaxDate()
        {
            _MonthCalendar.ResetMaxDate();
        }
        /// 
        /// Specifies the commands container background style. Commands container displays Today and Clear buttons if they are visible.
        /// 
        [Browsable(true), Category("Style"), Description("Specifies the commands container background style. Commands container displays Today and Clear buttons if they are visible."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        public ElementStyle CommandsBackgroundStyle
        {
            get { return _MonthCalendar.CommandsBackgroundStyle; }
        }
        /// 
        /// Specifies the navigation container background style. Navigation container displays month, year and optional buttons. Default value is an empty style which means that container does not display any background.
        /// BeginGroup property set to true will override this style on some styles.
        /// 
        [Browsable(true), Category("Style"), Description("Indicates navigation container background style."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        public ElementStyle NavigationBackgroundStyle
        {
            get { return _MonthCalendar.NavigationBackgroundStyle; }
        }
        /// 
        /// Gets or sets the number of columns and rows of months displayed on control. Default value is 0,0 which indicates that
        /// calendar will display as many columns and rows as it is possible to fit into container space available.
        /// 
        [Description("Indicates number of columns and rows of months displayed on control.")]
        public Size CalendarDimensions
        {
            get { return _MonthCalendar.CalendarDimensions; }
            set { _MonthCalendar.CalendarDimensions = value; InvalidateAutoSize(); }
        }
        /// 
        /// Resets property to its default value. Provided for design-time support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public void ResetCalendarDimensions()
        {
            _MonthCalendar.ResetCalendarDimensions();
            InvalidateAutoSize();
        }
        /// 
        /// Gets whether property should be serialized. Provided for design-time support.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public bool ShouldSerializeCalendarDimensions()
        {
            return _MonthCalendar.ShouldSerializeCalendarDimensions();
        }
        /// 
        /// Sets the number of columns and rows of months to display. 
        /// 
        /// The number of columns. 
        /// The number of rows. 
        /// ArgumentOutOfRangeException will be raised if any value is less than zero or one value is grater than zero and other is zero.
        public void SetCalendarDimensions(int columns, int rows)
        {
            _MonthCalendar.SetCalendarDimensions(columns, rows);
        }
        /// 
        /// Gets or sets whether weekend days can be selected. Default value is true.
        /// 
        [DefaultValue(true), Description("Indicates whether weekend days can be selected.")]
        public bool WeekendDaysSelectable
        {
            get { return _MonthCalendar.WeekendDaysSelectable; }
            set { _MonthCalendar.WeekendDaysSelectable = value; }
        }
        /// 
        /// Gets or sets the rule used to determine first week of the year for week of year display on calendar. Default value is first-day.
        /// 
        [DefaultValue(CalendarWeekRule.FirstDay), Description("Indicates rule used to determine first week of the year for week of year display on calendar.")]
        public CalendarWeekRule WeekOfYearRule
        {
            get { return _MonthCalendar.WeekOfYearRule; }
            set { _MonthCalendar.WeekOfYearRule = value; }
        }
        /// 
        /// Gets or sets the value that is used by calendar as today's date.
        /// 
        [Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
        public DateTime TodayDate
        {
            get { return _MonthCalendar.TodayDate; }
            set { _MonthCalendar.TodayDate = value; }
        }
        /// 
        /// Gets a value indicating whether the TodayDate property has been explicitly set. 
        /// 
        [Browsable(false)]
        public bool TodayDateSet
        {
            get { return _MonthCalendar.TodayDateSet; }
        }
        /// 
        /// Gets or sets whether today marker that indicates TodayDate is visible on the calendar. Default value is true.
        /// 
        [DefaultValue(true), Description("Indicates whether today marker that indicates TodayDate is visible on the calendar.")]
        public bool ShowTodayMarker
        {
            get { return _MonthCalendar.ShowTodayMarker; }
            set { _MonthCalendar.ShowTodayMarker = value; }
        }
        /// 
        /// Gets or sets whether week of year is visible. Default value is false.
        /// 
        [DefaultValue(false), Description("Indicates whether week of year is visible.")]
        public bool ShowWeekNumbers
        {
            get { return _MonthCalendar.ShowWeekNumbers; }
            set { _MonthCalendar.ShowWeekNumbers = value; InvalidateAutoSize(); }
        }
        /// 
        /// Gets or sets the array of custom names for days displayed on calendar header. The array must have exactly 7 elements representing day names from 0 to 6.
        /// 
        [DefaultValue(null), Description("Indicates array of custom names for days displayed on calendar header."), Localizable(true)]
        public string[] DayNames
        {
            get { return _MonthCalendar.DayNames; }
            set { _MonthCalendar.DayNames = value; }
        }
        /// 
        /// Gets or sets the first day of week displayed on the calendar. Default value is Sunday.
        /// 
        [DefaultValue(DayOfWeek.Sunday), Description("Indicates first day of week displayed on the calendar.")]
        public DayOfWeek FirstDayOfWeek
        {
            get { return _MonthCalendar.FirstDayOfWeek; }
            set { _MonthCalendar.FirstDayOfWeek = value; }
        }
        /// 
        /// Gets or sets whether control uses the two letter day names. Default value is true.
        /// 
        [DefaultValue(true), Description("Indicates whether control uses the two letter day names.")]
        public bool TwoLetterDayName
        {
            get { return _MonthCalendar.TwoLetterDayName; }
            set
            {
                _MonthCalendar.TwoLetterDayName = value;
            }
        }
        /// 
        /// Gets or sets the calendar selected date. Note that SelectedDate property should be used only when MultiSelect property is set to false.
        /// When multiple dates can be selected use range selection properties: SelectionStart, SelectionEnd and SelectionRange.
        /// 
        [Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
        public DateTime SelectedDate
        {
            get
            {
                return _MonthCalendar.SelectedDate;
            }
            set
            {
                _MonthCalendar.SelectedDate = value;
            }
        }
        /// 
        /// Gets or sets whether selection of multiple dates up to the MaxSelectionCount is enabled. Default value is false which indicates that only
        /// single day can be selected.
        /// 
        [DefaultValue(false), Description("Indicates whether selection of multiple dates up to the MaxSelectionCount is enabled.")]
        public bool MultiSelect
        {
            get { return _MonthCalendar.MultiSelect; }
            set { _MonthCalendar.MultiSelect = value; }
        }
        /// 
        /// Gets the reference to the bottom container that parents the Today, and Clear system buttons.
        /// 
        [Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
        public ItemContainer BottomContainer
        {
            get
            {
                return _MonthCalendar.BottomContainer;
            }
        }
        /// 
        /// Gets or sets whether Today button displayed at the bottom of the calendar is visible. Default value is false.
        /// 
        [DefaultValue(false), Description("Indicates whether Today button displayed at the bottom of the calendar is visible.")]
        public bool TodayButtonVisible
        {
            get { return _MonthCalendar.TodayButtonVisible; }
            set { _MonthCalendar.TodayButtonVisible = value; }
        }
        /// 
        /// Gets or sets whether Clear button displayed at the bottom of the calendar is visible. Clear button clears the currently selected date. Default value is false.
        /// 
        [DefaultValue(false), Description("Indicates whether Clear button displayed at the bottom of the calendar is visible. Clear button clears the currently selected date.")]
        public bool ClearButtonVisible
        {
            get { return _MonthCalendar.ClearButtonVisible; }
            set { _MonthCalendar.ClearButtonVisible = value; }
        }
        /// 
        /// Gets or sets the maximum number of days that can be selected in a month calendar control. 
        /// 
        [DefaultValue(7), Description("Gets or sets the maximum number of days that can be selected in a month calendar control.")]
        public int MaxSelectionCount
        {
            get { return _MonthCalendar.MaxSelectionCount; }
            set { _MonthCalendar.MaxSelectionCount = value; }
        }
        /// 
        /// Gets or sets the start date of the selected range of dates. 
        /// 
        [Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
        public DateTime SelectionStart
        {
            get { return _MonthCalendar.SelectionStart; }
            set
            {
                _MonthCalendar.SelectionStart = value;
            }
        }
        /// 
        /// Gets or sets the end date of the selected range of dates. 
        /// 
        [Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
        public DateTime SelectionEnd
        {
            get { return _MonthCalendar.SelectionEnd; }
            set
            {
                _MonthCalendar.SelectionEnd = value;
            }
        }
        /// 
        /// Gets or sets the selected range of dates for a month calendar control. 
        /// 
        /// Setting this property is functionally equivalent to using the SetSelectionRange method. You can set the start and end dates separately by setting either the SelectionStart or SelectionEnd properties. You cannot change the start and end dates by setting the SelectionRange.Start or SelectionRange.End property values of the SelectionRange property. You should use SelectionStart, SelectionEnd, or SetSelectionRange.
        /// If the Start property value of the SelectionRange is greater than its End property value, the dates are swapped; the End property value becomes the starting date, and Start property value becomes the end date.
        /// 
        [Bindable(true), Description("Indicates selected range of dates for a month calendar control. ")]
        public SelectionRange SelectionRange
        {
            get
            {
                return _MonthCalendar.SelectionRange;
            }
            set
            {
                _MonthCalendar.SelectionRange = value;
            }
        }
        /// 
        /// Returns whether property should be serialized by Windows Forms designer.
        /// 
        [EditorBrowsable(EditorBrowsableState.Never)]
        public bool ShouldSerializeSelectionRange()
        {
            return _MonthCalendar.ShouldSerializeSelectionRange();
        }
        /// 
        /// Sets the selected dates in a month calendar control to the specified date range. 
        /// 
        /// The beginning date of the selection range.
        /// The end date of the selection range.
        /// startDate is less than the minimum date allowable for a month calendar control.
        /// -or- 
        /// startDate is greater than the maximum allowable date for a month calendar control.
        /// -or- 
        /// endDate is less than the minimum date allowable for a month calendar control.
        /// -or- endDate is greater than the maximum allowable date for a month calendar control. 
        /// 
        /// 
        /// If the startDate value is greater than endDate property value, the dates are swapped; the endDate value becomes the starting date, and startDate value becomes the end date.
        /// 
        public void SetSelectionRange(DateTime startDate, DateTime endDate)
        {
            _MonthCalendar.SetSelectionRange(startDate, endDate);
        }
        /// 
        /// Gets or sets whether Year/Century selection is enabled when calendar is displaying single month.
        /// 
        [DefaultValue(true), Category("Behavior"), Description("Indicates whether Year/Century selection is enabled when calendar is displaying single month.")]
        public bool YearSelectionEnabled
        {
            get { return _MonthCalendar.YearSelectionEnabled; }
            set { _MonthCalendar.YearSelectionEnabled = value; }
        }
        /// 
        /// Indicates whether month selector which is displayed when month label is clicked is using abbreviated month names instead of month number.
        /// 
        [DefaultValue(true), Category("Behavior"), Description("Indicates whether month selector which is displayed when month label is clicked is using abbreviated month names instead of month number.")]
        public bool MonthSelectorShortMonthNames
        {
            get { return _MonthCalendar.MonthSelectorShortMonthNames; }
            set { _MonthCalendar.MonthSelectorShortMonthNames = value; }
        }
        /// 
        /// Indicates whether calendar is used in month selection mode which shows only month and year.
        /// 
        [DefaultValue(false), Category("Behavior"), Description("Indicates whether calendar is used in month selection mode which shows only month and year.")]
        public bool MonthSelectionMode
        {
            get { return _MonthCalendar.MonthSelectionMode; }
            set { _MonthCalendar.MonthSelectionMode = value; InvalidateAutoSize(); }
        }
        private Size _PreferredSize = Size.Empty;
        /// 
        /// Invalidates control auto-size and resizes the control if AutoSize is set to true.
        /// 
        public void InvalidateAutoSize()
        {
            _PreferredSize = Size.Empty;
            AdjustSize();
        }
#if FRAMEWORK20
        /// 
        /// Gets or sets a value indicating whether the control is automatically resized to display its entire contents. You can set MaximumSize.Width property to set the maximum width used by the control.
        /// 
        [Browsable(true), DefaultValue(false), EditorBrowsable(EditorBrowsableState.Always), DesignerSerializationVisibility(DesignerSerializationVisibility.Visible)]
        public override bool AutoSize
        {
            get
            {
                return base.AutoSize;
            }
            set
            {
                if (this.AutoSize != value)
                {
                    base.AutoSize = value;
                    AdjustSize();
                }
            }
        }
        private void AdjustSize()
        {
            if (this.AutoSize)
            {
                this.Size = base.PreferredSize;
            }
        }
        protected override void OnFontChanged(EventArgs e)
        {
            InvalidateAutoSize();
            base.OnFontChanged(e);
        }
        public override Size GetPreferredSize(Size proposedSize)
        {
            if (!_PreferredSize.IsEmpty) return _PreferredSize;
            if (!BarFunctions.IsHandleValid(this))
                return base.GetPreferredSize(proposedSize);
            ElementStyle style = this.GetBackgroundStyle();
            _MonthCalendar.RecalcSize();
            _PreferredSize = _MonthCalendar.Size;
            if (style != null)
            {
                _PreferredSize.Width += ElementStyleLayout.HorizontalStyleWhiteSpace(style);
                _PreferredSize.Height += ElementStyleLayout.VerticalStyleWhiteSpace(style);
            }
            return _PreferredSize;
        }
        protected override void SetBoundsCore(int x, int y, int width, int height, BoundsSpecified specified)
        {
            if (this.AutoSize)
            {
                Size preferredSize = base.PreferredSize;
                width = preferredSize.Width;
                height = preferredSize.Height;
            }
            base.SetBoundsCore(x, y, width, height, specified);
        }
        protected override void OnHandleCreated(EventArgs e)
        {
            if (this.AutoSize)
                this.AdjustSize();
            base.OnHandleCreated(e);
        }
        [Browsable(false)]
        public override bool ThemeAware
        {
            get
            {
                return base.ThemeAware;
            }
            set
            {
                base.ThemeAware = value;
            }
        }
#endif
        #endregion
    }
}
#endif