using System;
using System.Drawing;
using System.ComponentModel;
using System.Windows.Forms;
using DevComponents.AdvTree.Display;
using DevComponents.DotNetBar;
using System.Collections;
namespace DevComponents.AdvTree
{
	/// Represents a cell assigned to the Node.
	/// 
	/// 	The Cell with Index 0 (zero) always exists for a Node and it is a cell that
	///     you can interact with through the properties on a node, which are forwarding to the
	///     Cell(0), or you can go directly to the Cell(0).
	/// 	When Node has multiple columns defined each column corresponds to Cell in
	///     Node's Cells collection. The first Column has Index 0, second Column Index 1 and so
	///     forth.
	/// 	Note that there is always at least one Cell in a Node even if multiple
	///     columns are not used.
	/// 
	[DesignTimeVisible(false),ToolboxItem(false)]
	public class Cell:Component
	{
		#region Private Variables
		private ElementStyle m_StyleNormal=null;
		private ElementStyle m_StyleDisabled=null;
		private ElementStyle m_StyleMouseDown=null;
		private ElementStyle m_StyleMouseOver=null;
		private ElementStyle m_StyleSelected=null;
		private bool m_Enabled=true;
		private CellImages m_Images=null;
		private Rectangle m_Bounds=Rectangle.Empty;
		private Rectangle m_TextBounds=Rectangle.Empty;
		private Rectangle m_TextContentBounds=Rectangle.Empty;
		private Rectangle m_ImageBounds=Rectangle.Empty;
		private Rectangle m_CheckBoxBounds=Rectangle.Empty;
		private object m_Tag=null;
		private string m_Text="";
		private eCellPartAlignment m_ImageAlignment=eCellPartAlignment.Default;
		private eCellPartAlignment m_CheckBoxAlignment=eCellPartAlignment.Default;
		private bool m_CheckBoxVisible=false;
		private bool m_Checked=false;
		private bool m_MouseDown=false;
		private bool m_MouseOver=false;
		private bool m_Selected=false;
		private Node m_Parent=null;
		private bool m_Visible=true;
		private eTreeAction m_ActionSource=eTreeAction.Code;
		private eCellPartLayout m_Layout=eCellPartLayout.Default;
		private System.Windows.Forms.Cursor m_Cursor=null;
		private bool m_WordWrap=false;
		private string m_Name="";
		private Control m_HostedControl=null;
		private Size m_HostedControlSize=Size.Empty;
		private bool m_IgnoreHostedControlSizeChange=false;
		#endregion
		#region Constructor/Dispose
		/// 
		/// Initializes new instance of Cell class.
		/// 
		public Cell():this("")
		{
		}
		/// 
		/// Initializes new instance of Cell class.
		/// 
		/// Cell text.
		public Cell(string text)
		{
			Text=text;
			m_Images=new CellImages(this);
		}
        /// 
        /// Initializes new instance of Cell class.
        /// 
        /// Cell text.
        public Cell(string text, ElementStyle styleNormal)
            : this(text)
        {
            this.StyleNormal = styleNormal;
        }
        /// 
        /// Initializes new instance of Cell class.
        /// 
        /// Cell text.
        public Cell(string text, string styleNormalName)
            : this(text)
        {
            this.StyleNormalName = styleNormalName;
        }
		/// 
		/// Releases the resources used by the Component.
		/// 
		/// true to release both managed and unmanaged resources; false to release only unmanaged resources.
		protected override void Dispose(bool disposing)
		{
			if(m_HostedControl!=null)
				m_HostedControl.SizeChanged-=new EventHandler(this.HostedControlSizedChanged);
			m_HostedControl=null;
            if (m_Images != null)
            {
                m_Images.Dispose();
            }
			base.Dispose(disposing);
		}
		#endregion
		#region Properties
        /// 
        /// Occurs after Tooltip text has changed.
        /// 
        protected virtual void OnTooltipChanged() { }
        private string _Tooltip = "";
        /// 
        /// Gets/Sets informational text (tooltip) for the cell.
        /// 
        [Browsable(true), DefaultValue(""), Category("Appearance"), Description("Indicates the text that is displayed when mouse hovers over the cell."), Localizable(true)]
        public string Tooltip
        {
            get
            {
                return _Tooltip;
            }
            set
            {
                if (_Tooltip == value)
                    return;
                if (value == null) value = "";
                _Tooltip = value;
                if (this.ToolTipVisible)
                {
                    if (string.IsNullOrEmpty(_Tooltip))
                        this.HideToolTip();
                    else
                    {
                        DevComponents.DotNetBar.ToolTip tooltipWindow = _ToolTipWnd;
                        tooltipWindow.Text = _Tooltip;
                        tooltipWindow.ShowToolTip();
                        tooltipWindow.Invalidate();
                    }
                }
                OnTooltipChanged();
            }
        }
        /// 
        /// Gets whether tooltip is visible or not.
        /// 
        internal protected bool ToolTipVisible
        {
            get
            {
                return (_ToolTipWnd != null);
            }
        }
        /// 
        /// Called when tooltip is shown and hidden.
        /// 
        /// true if tooltip is being shown otherwise false.
        protected virtual void OnTooltip(bool isShown)
        {
        }
        private DevComponents.DotNetBar.ToolTip _ToolTipWnd = null;
        /// 
        /// Shows tooltip for this item.
        /// 
        public virtual void ShowToolTip()
        {
            if (this.DesignMode)
                return;
            if (IsVisible)
            {
                AdvTree tree = TreeControl;
                if (tree != null && !tree.ShowToolTips || !this.ShowToolTips)
                    return;
                OnTooltip(true);
                if (_Tooltip != "")
                {
                    if (_ToolTipWnd == null)
                        _ToolTipWnd = new DevComponents.DotNetBar.ToolTip();
                    _ToolTipWnd.Style = StyleManager.GetEffectiveStyle();
                    _ToolTipWnd.Text = _Tooltip;
                    _ToolTipWnd.ReferenceRectangle = ScreenRectangle;
                    OnToolTipVisibleChanged(new EventArgs());
                    _ToolTipWnd.ShowToolTip();
                }
            }
        }
        /// 
        /// Destroys tooltip window.
        /// 
        internal protected void HideToolTip()
        {
            if (_ToolTipWnd != null)
            {
                System.Drawing.Rectangle tipRect = _ToolTipWnd.Bounds;
                tipRect.Width += 5;
                tipRect.Height += 6;
                OnTooltip(false);
                OnToolTipVisibleChanged(new EventArgs());
                try
                {
                    if (_ToolTipWnd != null)
                    {
                        _ToolTipWnd.Hide();
                        _ToolTipWnd.Dispose();
                        _ToolTipWnd = null;
                    }
                }
                catch { }
                AdvTree tree = this.TreeControl;
                if (tree != null)
                {
                    tree.Invalidate(tree.RectangleToClient(tipRect), false);
                }
            }
        }
        /// 
        /// Occurs when item's tooltip visibility has changed.
        /// 
        [System.ComponentModel.Description("Occurs when item's tooltip visibility has changed.")]
        public event EventHandler ToolTipVisibleChanged;
        private void OnToolTipVisibleChanged(EventArgs eventArgs)
        {
            EventHandler h = ToolTipVisibleChanged;
            if (h != null)
                ToolTipVisibleChanged(this, eventArgs);
        }
        private Rectangle ScreenRectangle
        {
            get
            {
                AdvTree tree = this.TreeControl;
                if (tree == null) return Rectangle.Empty;
                return new Rectangle(tree.PointToScreen(this.Bounds.Location), this.Bounds.Size);
            }
        }
        private bool _ShowToolTips = true;
        /// 
        /// Gets or sets whether tooltips are shown when mouse is over the cell when Tooltip property is set.
        /// 
        [DefaultValue(true), Category("Behavior"), Description("Indicates whether tooltips are shown when mouse is over the cell when Tooltip property is set.")]
        public bool ShowToolTips
        {
            get { return _ShowToolTips; }
            set
            {
                _ShowToolTips = value;
            }
        }
        
        private bool _Editable = true;
        /// 
        /// Gets or sets whether cell content is editable when cell editing is enabled on tree control. Default value is true.
        /// 
        [DefaultValue(true), Category("Behavior"), Description("Indicates whether cell content is editable when cell editing is enabled on tree control.")]
        public bool Editable
        {
            get { return _Editable; }
            set
            {
                _Editable = value;
            }
        }
        /// 
        /// Gets whether cell can be edited. Cell can be edited if both Editable property is set to true and ColumnHeader.Editable property is set to true.
        /// 
        [Browsable(false)]
        public bool IsEditable
        {
            get
            {
                ColumnHeader header = NodeOperations.GetCellColumnHeader(this.TreeControl, this);
                if (header == null) return _Editable;
                return _Editable && header.Editable;
            }
        }
        private BaseItem _HostedItem = null;
        /// 
        /// Gets or sets the item hosted inside of the cell. Only items that do not generate
        /// popups are supported. Note that cell can only host either HostedItem or HostedControl but not both.
        /// 
        [DefaultValue(null), Category("Appearance"), Editor("DevComponents.AdvTree.Design.HostedItemTypeEditor, DevComponents.DotNetBar.Design, Version=14.1.0.37, Culture=neutral,  PublicKeyToken=90f470f34c89ccaf", typeof(System.Drawing.Design.UITypeEditor)), Description("Indicates item hosted inside of the cell. Only items that do not generate popups are supported. Note that cell can only host either HostedItem or HostedControl but not both.")]
        public BaseItem HostedItem
        {
            get { return _HostedItem; }
            set { SetHostedItem(value); }
        }      
		/// 
		/// Gets or sets the control hosted inside of the cell. Note that cell can only host either HostedItem or HostedControl but not both.
		/// 
		/// 
		/// 	When control is hosted inside of the cell, cell size is determined by the
		///     size of the control hosted inside of it. The cell will not display its text but it will display any image assigned
		///     or check box when control is hosted inside of it. The Style settings like Margin
		///     and Padding will still apply.
		/// 
		[Browsable(true),Category("Behavior"),Description("Indicates control hosted inside of the cell."),DefaultValue(null)]
		public Control HostedControl
		{
			get {return m_HostedControl;}
			set
			{
				SetHostedControl(value);
			}
		}
		
		/// 
		/// Gets or sets whether hosted control size change event is ignored.
		/// 
		internal bool IgnoreHostedControlSizeChange
		{
			get { return m_IgnoreHostedControlSizeChange;}
			set { m_IgnoreHostedControlSizeChange=value; }
		}
		
		/// 
		/// Gets or sets the hosted control size. Property is used to correctly scale control when AdvTree.Zoom is used to zoom view.
		/// 
		internal Size HostedControlSize
		{
			get { return m_HostedControlSize;}
			set { m_HostedControlSize = value;}	
		}
		/// 
		/// Returns name of the cell that can be used to identify it from the code.
		/// 
		[Browsable(false),Category("Design"),Description("Indicates the name used to identify cell.")]
		public string Name
		{
			get
			{
				if(this.Site!=null)
					m_Name=this.Site.Name;
				return m_Name;
			}
			set
			{
				if(this.Site!=null)
					this.Site.Name=value;
				if(value==null)
					m_Name="";
				else
					m_Name=value;
			}
		}
		/// 
		/// Gets the relative bounds of the cell.
		/// 
		[Browsable(false)]
		internal Rectangle BoundsRelative
		{
			get
			{
				return m_Bounds;			
			}
		}
		
		/// 
		/// Gets the bounds of the cell.
		/// 
		[Browsable(false)]
		public Rectangle Bounds
		{
			get
			{
				AdvTree tree=this.TreeControl;
				if(tree!=null)
				{
					return NodeDisplay.GetCellRectangle(eCellRectanglePart.CellBounds, this, tree.NodeDisplay.Offset);
				}
				return Rectangle.Empty;			
			}
		}
		/// 
		/// Sets the bounds of the cell.
		/// 
		/// New cell bounds.
		internal void SetBounds(Rectangle bounds)
		{
			m_Bounds=bounds;
		}
//		/// 
//		/// Gets the bounds of the text inside of cell.
//		/// 
//		[Browsable(false)]
//		public Rectangle TextBounds
//		{
//			get
//			{
//				return m_TextBounds;			
//			}
//		}
//		/// 
//		/// Sets the bounds of the text inside of the cell.
//		/// 
//		/// New cell bounds.
//		internal void SetTextBounds(Rectangle bounds)
//		{
//			m_TextBounds=bounds;
//		}
		/// 
		/// Gets or sets the available content bounds for the text. Text will fitted into these bounds
		/// but it's true location can be obtained only after it is displayed.
		/// 
		internal Rectangle TextContentBounds
		{
			get {return m_TextContentBounds;}
			set {m_TextContentBounds=value;}
		}
        /// 
        /// Gets the bounds of the text inside of cell.
        /// 
        [Browsable(false)]
        public Rectangle TextBounds
        {
            get
            {
                AdvTree tree = this.TreeControl;
                if (tree != null)
                {
                    return NodeDisplay.GetCellRectangle(eCellRectanglePart.TextBounds, this, tree.NodeDisplay.Offset);
                }
                return Rectangle.Empty;
            }
        }
		/// 
		/// Gets the relative bounds of the image inside of cell.
		/// 
		[Browsable(false)]
		internal Rectangle ImageBoundsRelative
		{
			get
			{
				return m_ImageBounds;			
			}
		}
		
		/// 
		/// Gets the bounds of the image inside of cell.
		/// 
		[Browsable(false)]
		public Rectangle ImageBounds
		{
			get
			{
				AdvTree tree=this.TreeControl;
				if(tree!=null)
				{
					return NodeDisplay.GetCellRectangle(eCellRectanglePart.ImageBounds, this, tree.NodeDisplay.Offset);
				}
				return Rectangle.Empty;			
			}
		}
		/// 
		/// Sets the bounds of the image inside of the cell.
		/// 
		/// New cell bounds.
		internal void SetImageBounds(Rectangle bounds)
		{
			m_ImageBounds=bounds;
		}
		/// 
		/// Gets the bounds of the image inside of cell.
		/// 
		[Browsable(false)]
		internal Rectangle CheckBoxBoundsRelative
		{
			get
			{
				return m_CheckBoxBounds;			
			}
		}
		
		/// 
		/// Gets the bounds of the check box inside of cell.
		/// 
		[Browsable(false)]
		public Rectangle CheckBoxBounds
		{
			get
			{
				AdvTree tree=this.TreeControl;
                if (tree != null)
                {
                    return NodeDisplay.GetCellRectangle(eCellRectanglePart.CheckBoxBounds, this, tree.NodeDisplay.Offset);
                }
				return Rectangle.Empty;			
			}
		}
		/// 
		/// Sets the bounds of the check box inside of the cell.
		/// 
		/// New cell bounds.
		internal void SetCheckBoxBounds(Rectangle bounds)
		{
			m_CheckBoxBounds=bounds;
		}
		/// 
		/// Gets a value indicating whether the cell is in an editable state. true if the cell is in editable state; otherwise, false.
		/// 
		[Browsable(false)]
		public bool IsEditing
		{
			get
			{
				return false;
			}
		}
		/// 
		/// Gets a value indicating whether the cell is in the selected state. true if the cell is in the selected state; otherwise, false.
		/// 
		[Browsable(false)]
		public bool IsSelected
		{
			get
			{
				return m_Selected;
			}
		}
		internal void SetSelected(bool selected, eTreeAction actionSource)
		{
            m_Selected = selected;
		}
		/// 
		/// Gets a value indicating whether the cell is visible. Cell is considered to be visible when it's parent column is visible.
		/// 
		[Browsable(false)]
		public bool IsVisible
		{
			get
			{
				return m_Visible;
			}
		}
		/// 
		/// Sets whether cells is visible or not. This is set by node layout manager and it is based on column visibility.
		/// 
		/// True if visible otherwise false.
		internal void SetVisible(bool visible)
		{
			if(m_Visible!=visible)
			{
				m_Visible=visible;
				OnVisibleChanged();
			}
		}
		/// 
		/// Gets the parent node of the current cell.
		/// 
		[Browsable(false)]
		public Node Parent
		{
			get
			{
				return m_Parent;
			}
		}
		/// 
		/// Sets the parent of the cell.
		/// 
		/// Parent node.
		internal void SetParent(Node parent)
		{
			m_Parent=parent;
		}
		/// 
		/// Gets or sets the object that contains data about the cell. Any Object derived type can be assigned to this property. If this property is being set through the Windows Forms designer, only text can be assigned.
		/// 
		[Browsable(false),DefaultValue(null),Category("Data"),Description("Indicates text that contains data about the cell.")]
		public object Tag
		{
			get
			{
				return m_Tag;
			}
			set
			{
				m_Tag=value;
			}
		}
		/// 
		/// Gets or sets the object that contains data about the cell. Any Object derived type can be assigned to this property. If this property is being set through the Windows Forms designer, only text can be assigned.
		/// 
		[Browsable(true),DefaultValue(""),Category("Data"),Description("Indicates text that contains data about the cell."),DevCoSerialize()]
		public string TagString
		{
			get
			{
				if(m_Tag==null)
					return "";
				return m_Tag.ToString();
			}
			set
			{
				m_Tag=value;
			}
		}
        private string _TextDisplayFormat = "";
        /// 
        /// Gets or sets the format that is applied to the value of Text property for display purposes. See "Formatting Overview" in MSDN
        /// for description on available format strings. For example you can specify "C" to format text as currency, or "D" to format text as decimal number etc.
        /// 
        /// 
        [Browsable(true), DefaultValue(""), Category("Appearance"), Description("Indicates format that is applied to the value of Text property for display purposes.")]
        public string TextDisplayFormat
        {
            get { return _TextDisplayFormat; }
            set
            {
                _TextDisplayFormat = value;
                UpdateDisplayText();
                this.OnSizeChanged();
            }
        }
        private string _DisplayText = string.Empty;
        /// 
        /// Gets the formatted display text.
        /// 
        internal string DisplayText
        {
            get
            {
                return _DisplayText;
            }
        }
        private void UpdateDisplayText()
        {
            if (string.IsNullOrEmpty(_TextDisplayFormat))
            {
                _DisplayText = m_Text;
                return;
            }
            long longNumber = 0;
            double number = 0;
            DateTime date = DateTime.MinValue;
            if (long.TryParse(m_Text, out longNumber))
            {
                _DisplayText = longNumber.ToString(_TextDisplayFormat);
            }
            else if (double.TryParse(m_Text, out number))
            {
                _DisplayText = number.ToString(_TextDisplayFormat);
            }
            else if (DateTime.TryParse(m_Text, out date))
            {
                _DisplayText = date.ToString(_TextDisplayFormat);
            }
            else
                _DisplayText = m_Text;
        }
        /// 
		/// Gets or sets the text displayed in the cell.
		/// 
        [Browsable(true), DefaultValue(""), Editor("DevComponents.DotNetBar.Design.TextMarkupUIEditor, DevComponents.DotNetBar.Design, Version=14.1.0.37, Culture=neutral,  PublicKeyToken=90f470f34c89ccaf", typeof(System.Drawing.Design.UITypeEditor)), Category("Appearance"), Localizable(true), Description("Indicates text displayed in the cell."), DevCoSerialize()]
		public string Text
		{
			get
			{
				return m_Text;
			}
			set
			{
                if (value == null) value = "";
                if (m_Text != value)
                {
                    m_Text = value;
                    UpdateDisplayText();
                    OnTextChanged();
                    this.OnSizeChanged();
                }
			}
		}
		
		/// 
		/// Occurs after text has changed.
		/// 
		protected virtual void OnTextChanged()
		{
			MarkupTextChanged();
		}
		/// 
		/// Gets the parent tree control that the cell belongs to.
		/// 
		[Browsable(false)]
		public AdvTree TreeControl
		{
			get
			{
				if(this.Parent!=null)
					return this.Parent.TreeControl;
				return null;
			}
		}
		/// 
		/// Gets or sets the style class assigned to the cell. Null value indicates that
		/// default style is used as specified on cell's parent.
		/// 
		/// 
		/// Reference to the style assigned to the cell or null (VB Nothing) indicating that default
		/// style setting from tree control is applied. Default value is null.
		/// 
		/// 
		/// When property is set to null (VB Nothing) the style setting from parent tree
		/// controls is used. CellStyleNormal on AdvTree control is a root style for a cell.
		/// 
		/// StyleDisabled Property
		/// StyleMouseDown Property
		/// StyleMouseOver Property
		/// StyleSelected Property
		[Browsable(true),DefaultValue(null),Category("Style"),Editor("DevComponents.AdvTree.Design.ElementStyleTypeEditor, DevComponents.DotNetBar.Design, Version=14.1.0.37, Culture=neutral,  PublicKeyToken=90f470f34c89ccaf",typeof(System.Drawing.Design.UITypeEditor)),Description("Indicates the style class assigned to the cell.")]
		public ElementStyle StyleNormal
		{
			get {return m_StyleNormal;}
			set
			{
				m_StyleNormal=value;
			}
		}
		
		/// 
		/// Gets or sets the style name used by cell. This member is provided for internal use only. To set or get the style use StyleNormal property instead.
		/// 
		[Browsable(false), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden), EditorBrowsable(EditorBrowsableState.Never) , DevCoSerialize()]
		public string StyleNormalName
		{
			get
			{
				if(m_StyleNormal!=null)
					return m_StyleNormal.Name;
				return "";
			}
			set
			{
				if(value.Length==0)
				{
					TypeDescriptor.GetProperties(this)["StyleNormal"].SetValue(this, null);
					return;
				}
				
				AdvTree tree=this.TreeControl;
				if(tree!=null)
				{
					TypeDescriptor.GetProperties(this)["StyleNormal"].SetValue(this, tree.Styles[value]);
				}
			}
		}
		/// 
		/// Gets or sets the style class that is to when cell is selected. Null value indicates that
		/// default style is used as specified on cell's parent.
		/// 
		/// 
		/// Reference to the style assigned to the cell or null value indicating that default
		/// style setting from tree control is applied. Default is null value.
		/// 
		/// 
		/// When property is set to null value the style setting from parent tree
		/// controls is used. CellStyleSelected on AdvTree control is a root style for a cell.
		/// 
		/// StyleNormal Property
		/// StyleDisabled Property
		/// StyleMouseDown Property
		/// StyleMouseOver Property
		[Browsable(true),DefaultValue(null),Category("Style"),Editor("DevComponents.AdvTree.Design.ElementStyleTypeEditor, DevComponents.DotNetBar.Design, Version=14.1.0.37, Culture=neutral,  PublicKeyToken=90f470f34c89ccaf",typeof(System.Drawing.Design.UITypeEditor)),Description("Indicates the style class assigned to the cell.")]
		public ElementStyle StyleSelected
		{
			get {return m_StyleSelected;}
			set
			{
				m_StyleSelected=value;
			}
		}
		
		/// 
		/// Gets or sets the selected style name used by cell. This member is provided for internal use only. To set or get the style use StyleSelected property instead.
		/// 
		[Browsable(false), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden), EditorBrowsable(EditorBrowsableState.Never) , DevCoSerialize()]
		public string StyleSelectedName
		{
			get
			{
				if(m_StyleSelected!=null)
					return m_StyleSelected.Name;
				return "";
			}
			set
			{
				if(value.Length==0)
				{
					TypeDescriptor.GetProperties(this)["StyleSelected"].SetValue(this, null);
					return;
				}
				
				AdvTree tree=this.TreeControl;
				if(tree!=null)
				{
					TypeDescriptor.GetProperties(this)["StyleSelected"].SetValue(this, tree.Styles[value]);
				}
			}
		}
		/// 
		/// Gets or sets the disabled style class assigned to the cell. Null value indicates
		/// that default style is used as specified on cell's parent.
		/// 
		/// 
		/// Reference to the style assigned to the cell or null value indicating that default
		/// style setting from tree control is applied. Default value is null.
		/// 
		/// 
		/// When property is set to null value the style setting from parent tree
		/// controls is used. CellStyleDisabled on AdvTree control is a root style for a
		/// cell.
		/// 
		/// StyleNormal Property
		/// StyleMouseDown Property
		/// StyleMouseOver Property
		/// StyleSelected Property
		[Browsable(true),DefaultValue(null),Category("Style"),Editor("DevComponents.AdvTree.Design.ElementStyleTypeEditor, DevComponents.DotNetBar.Design, Version=14.1.0.37, Culture=neutral,  PublicKeyToken=90f470f34c89ccaf",typeof(System.Drawing.Design.UITypeEditor)),Description("Indicates the disabled style class assigned to the cell.")]
		public ElementStyle StyleDisabled
		{
			get {return m_StyleDisabled;}
			set
			{
				m_StyleDisabled=value;
			}
		}
		
		/// 
		/// Gets or sets the disabled style name used by cell. This member is provided for internal use only. To set or get the style use StyleDisabled property instead.
		/// 
		[Browsable(false), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden), EditorBrowsable(EditorBrowsableState.Never) , DevCoSerialize()]
		public string StyleDisabledName
		{
			get
			{
				if(m_StyleDisabled!=null)
					return m_StyleDisabled.Name;
				return "";
			}
			set
			{
				if(value.Length==0)
				{
					TypeDescriptor.GetProperties(this)["StyleDisabled"].SetValue(this, null);
					return;
				}
				
				AdvTree tree=this.TreeControl;
				if(tree!=null)
				{
					TypeDescriptor.GetProperties(this)["StyleDisabled"].SetValue(this, tree.Styles[value]);
				}
			}
		}
		/// 
		/// Gets or sets the style class assigned to the cell which is applied when mouse
		/// button is pressed while mouse is over the cell. Null value indicates that default
		/// style is used as specified on cell's parent.
		/// 
		/// 
		/// Reference to the style assigned to the cell or null value indicating that default
		/// style setting from tree control is applied. Default value is null.
		/// 
		/// 
		/// When property is set to null value style setting from parent tree
		/// controls is used. CellStyleMouseDown on AdvTree control is a root style for a
		/// cell.
		/// 
		/// StyleNormal Property
		/// StyleDisabled Property
		/// StyleMouseOver Property
		/// StyleSelected Property
		[Browsable(true),DefaultValue(null),Category("Style"),Editor("DevComponents.AdvTree.Design.ElementStyleTypeEditor, DevComponents.DotNetBar.Design, Version=14.1.0.37, Culture=neutral,  PublicKeyToken=90f470f34c89ccaf",typeof(System.Drawing.Design.UITypeEditor)),Description("Indicates the style class assigned to the cell when mouse is down.")]
		public ElementStyle StyleMouseDown
		{
			get {return m_StyleMouseDown;}
			set
			{
				m_StyleMouseDown=value;
			}
		}
		
		/// 
		/// Gets or sets the mouse down style name used by cell. This member is provided for internal use only. To set or get the style use StyleMouseDown property instead.
		/// 
		[Browsable(false), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden), EditorBrowsable(EditorBrowsableState.Never) , DevCoSerialize()]
		public string StyleMouseDownName
		{
			get
			{
				if(m_StyleMouseDown!=null)
					return m_StyleMouseDown.Name;
				return "";
			}
			set
			{
				if(value.Length==0)
				{
					TypeDescriptor.GetProperties(this)["StyleMouseDown"].SetValue(this, null);
					return;
				}
				
				AdvTree tree=this.TreeControl;
				if(tree!=null)
				{
					TypeDescriptor.GetProperties(this)["StyleMouseDown"].SetValue(this, tree.Styles[value]);
				}
			}
		}
		/// 
		/// Gets or sets the style class assigned to the cell which is applied when mouse is
		/// over the cell. Null value indicates that default style is used as specified on cell's
		/// parent.
		/// 
		/// 
		/// Reference to the style assigned to the cell or null value indicating that default
		/// style setting from tree control is applied. Default value is null.
		/// 
		/// 
		/// When property is set to null value the style setting from parent tree
		/// controls is used. CellStyleMouseOver on AdvTree control is a root style for a
		/// cell.
		/// 
		/// StyleNormal Property
		/// StyleDisabled Property
		/// StyleMouseDown Property
		/// StyleSelected Property
		[Browsable(true),DefaultValue(""),Category("Style"),Editor("DevComponents.AdvTree.Design.ElementStyleTypeEditor, DevComponents.DotNetBar.Design, Version=14.1.0.37, Culture=neutral,  PublicKeyToken=90f470f34c89ccaf",typeof(System.Drawing.Design.UITypeEditor)),Description("Indicates the style class assigned to the cell when mouse is over the cell.")]
		public ElementStyle StyleMouseOver
		{
			get {return m_StyleMouseOver;}
			set
			{
				m_StyleMouseOver=value;
			}
		}
		
		/// 
		/// Gets or sets the mouse over style name used by cell. This member is provided for internal use only. To set or get the style use StyleMouseOver property instead.
		/// 
		[Browsable(false), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden), EditorBrowsable(EditorBrowsableState.Never) , DevCoSerialize()]
		public string StyleMouseOverName
		{
			get
			{
				if(m_StyleMouseOver!=null)
					return m_StyleMouseOver.Name;
				return "";
			}
			set
			{
				if(value.Length==0)
				{
					TypeDescriptor.GetProperties(this)["StyleMouseOver"].SetValue(this, null);
					return;
				}
				
				AdvTree tree=this.TreeControl;
				if(tree!=null)
				{
					TypeDescriptor.GetProperties(this)["StyleMouseOver"].SetValue(this, tree.Styles[value]);
				}
			}
		}
		/// 
		/// Gets or sets whether cell is enabled or not.
		/// 
		[Browsable(true),DefaultValue(true),Category("Behavior"),Description("Gets or sets whether cell is enabled or not."),DevCoSerialize()]
		public bool Enabled
		{
			get {return m_Enabled;}
			set
			{
				m_Enabled=value;
                if (this.Parent != null)
                {
                    this.Parent.OnDisplayChanged();
                }
			}
		}
		/// 
		/// Gets the reference to images associated with this cell.
		/// 
		[Browsable(true),Category("Images"),Description("Gets the reference to images associated with this cell."),DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
		public CellImages Images
		{
			get {return m_Images;}
		}
		/// 
		/// Sets the Images to the new CellImages object.
		/// 
		/// CellImages object.
		internal void SetCellImages(CellImages ci)
		{
			m_Images=ci;
			m_Images.Parent=this;
		}
		/// 
		/// Returns whether Images property should be serialized. Used internally for windows forms designer support.
		/// 
		[EditorBrowsable(EditorBrowsableState.Never)]
		internal bool ShouldSerializeImages()
		{
			return m_Images.ShouldSerialize;
		}
		/// 
		/// Gets or sets the image alignment in relation to the text displayed by cell.
		/// 
		[Browsable(true),Category("Image Properties"),DefaultValue(eCellPartAlignment.Default),Description("Gets or sets the image alignment in relation to the text displayed by cell."),DevCoSerialize()]
		public eCellPartAlignment ImageAlignment
		{
			get
			{
				return m_ImageAlignment;
			}
			set
			{
				if(m_ImageAlignment!=value)
				{
					m_ImageAlignment=value;
					this.OnAppearanceChanged();
				}
			}
		}
		/// 
		/// Gets or sets the checkbox alignment in relation to the text displayed by cell.
		/// 
		[Browsable(true),Category("Check-box Properties"),DefaultValue(eCellPartAlignment.Default),Description("Indicates checkbox alignment in relation to the text displayed by cell.")]
		public eCellPartAlignment CheckBoxAlignment
		{
			get
			{
				return m_CheckBoxAlignment;
			}
			set
			{
				if(m_CheckBoxAlignment!=value)
				{
					m_CheckBoxAlignment=value;
					this.OnAppearanceChanged();
				}
			}
		}
		/// 
		/// Gets or sets whether check box is visible inside the cell.
		/// 
		[Browsable(true),Category("Check-box Properties"),DefaultValue(false),Description("Indicates whether check box is visible inside the cell."),DevCoSerialize()]
		public bool CheckBoxVisible
		{
			get
			{
				return m_CheckBoxVisible;
			}
			set
			{
				if(m_CheckBoxVisible!=value)
				{
					m_CheckBoxVisible=value;
					this.OnAppearanceChanged();
				}
			}
		}
		/// 
		/// Gets or set a value indicating whether the check box is in the checked state.
		/// 
		[Browsable(true),Category("Check-box Properties"),DefaultValue(false),Description("Indicates whether the check box is in the checked state."),DevCoSerialize()]
		public bool Checked
		{
			get {return m_Checked;}
			set
			{
				if(m_Checked!=value)
				{
                    if (_ThreeState && value && _CheckState != CheckState.Unchecked) return;
                    SetChecked(value ? CheckState.Checked : CheckState.Unchecked, eTreeAction.Code);
				}
			}
		}
        private bool _ThreeState = false;
        /// 
        /// Gets or sets a value indicating whether the CheckBox will allow three check states rather than two. If the ThreeState property is set to true
        /// CheckState property should be used instead of Checked property to set the extended state of the control.
        /// 
        [Browsable(true), Category("Check-box Properties"), DefaultValue(false), Description("Indicates whether the CheckBox will allow three check states rather than two.")]
        public bool CheckBoxThreeState
        {
            get { return _ThreeState; }
            set { _ThreeState = value; }
        }
        private CheckState _CheckState = CheckState.Unchecked;
        /// 
        /// Specifies the state of a control, such as a check box, that can be checked, unchecked, or set to an indeterminate state. 
        /// 
        [Browsable(true), Category("Check-box Properties"), DefaultValue(CheckState.Unchecked), RefreshProperties(RefreshProperties.All), Description("Specifies the state of a control, such as a check box, that can be checked, unchecked, or set to an indeterminate state")]
        public CheckState CheckState
        {
            get { return _CheckState; }
            set
            {
                if (value != _CheckState)
                    SetChecked(value, eTreeAction.Code);
            }
        }
        /// 
        /// Sets the Checked or CheckState properties.
        /// 
        /// New value for checked state.
        /// Action source.
        public void SetChecked(bool value, eTreeAction actionSource)
        {
            SetChecked(value ? CheckState.Checked : CheckState.Unchecked, actionSource);
        }
        /// 
        /// Sets the Checked or CheckState properties.
        /// 
        /// New value for checked state.
        /// Action source.
        public void SetChecked(CheckState value, eTreeAction actionSource)
        {
            AdvTreeCellBeforeCheckEventArgs beforeCheckArgs = new AdvTreeCellBeforeCheckEventArgs(actionSource, this, value);
            InvokeBeforeCheck(beforeCheckArgs);
            if (beforeCheckArgs.Cancel) return;
            _CheckState = value;
            m_Checked = value == CheckState.Checked;
            OnAppearanceChanged();
            if (this.CheckBoxStyle == eCheckBoxStyle.RadioButton && value == CheckState.Checked && this.Parent != null)
            {
                Node parent = this.Parent;
                AdvTree tree = parent.TreeControl;
                if (tree != null) tree.BeginUpdate();
                bool processNodes = true;
                foreach (Cell item in parent.Cells)
                {
                    if (item == this) continue;
                    if (item.CheckBoxStyle == eCheckBoxStyle.RadioButton)
                    {
                        item.Checked = false;
                        processNodes = false;
                    }
                }
                if (processNodes)
                {
                    if (parent.Parent != null)
                    {
                        foreach (Node item in parent.Parent.Nodes)
                        {
                            if (item != parent && item.CheckBoxStyle == eCheckBoxStyle.RadioButton)
                                item.Checked = false;
                        }
                    }
                    else
                    {
                        if (tree != null && NodeOperations.IsRootNode(tree, parent))
                        {
                            foreach (Node item in tree.Nodes)
                            {
                                if (item != parent && item.CheckBoxStyle == eCheckBoxStyle.RadioButton)
                                    item.Checked = false;
                            }
                        }
                    }
                }
                if (tree != null) tree.EndUpdate();
            }
            InvokeAfterCheck(actionSource);
        }
        private eCheckBoxStyle _CheckBoxStyle = eCheckBoxStyle.CheckBox;
        /// 
        /// Gets or sets the appearance style of the item. Default value is CheckBox. Item can also assume the style of radio-button.
        /// 
        [Browsable(true), DefaultValue(eCheckBoxStyle.CheckBox), Category("Check-box Properties"), Description("Indicates appearance style of the item. Default value is CheckBox. Item can also assume the style of radio-button.")]
        public eCheckBoxStyle CheckBoxStyle
        {
            get { return _CheckBoxStyle; }
            set
            {
                _CheckBoxStyle = value;
                OnAppearanceChanged();
            }
        }
		/// 
		/// Gets whether mouse is over the cell.
		/// 
		[Browsable(false)]
		public bool IsMouseOver
		{
			get{return m_MouseOver;}
		}
		/// 
		/// Sets the mouse over flag.
		/// 
		/// true if mouse is over the cell otherwise false.
		internal void SetMouseOver(bool over)
		{
			m_MouseOver=over;
		}
		/// 
		/// Gets whether left mouse button is pressed while over the cell.
		/// 
		[Browsable(false)]
		public bool IsMouseDown
		{
			get{return m_MouseDown;}
		}
		/// 
		/// Sets the mouse down flag.
		/// 
		/// true if left mouse button is pressed while over the cell otherwise false.
		internal void SetMouseDown(bool over)
		{
			m_MouseDown=over;
		}
		/// 
		/// Gets or sets the layout of the cell parts like check box, image and text. Layout can be horizontal (default)
		/// where parts of the cell are positioned next to each other horizontally, or vertical where
		/// parts of the cell are positioned on top of each other vertically.
		/// Alignment of the each part is controlled by alignment properties.
		/// 
		/// ImageAlignment Property
		/// CheckBoxAlignment Property
		[Browsable(true),DefaultValue(eCellPartLayout.Default),Category("Cells"),Description("Indicates the layout of the cell parts like check box, image and text."), DevCoSerialize()]
		public eCellPartLayout Layout
		{
			get {return m_Layout;}
			set
			{
				if(m_Layout!=value)
				{
					m_Layout=value;
					this.OnAppearanceChanged();
				}
			}
		}
		/// 
		/// Specifies the mouse cursor displayed when mouse is over the cell.
		/// 
		[Browsable(true),DefaultValue(null),Category("Appearance"),Description("Specifies the mouse cursor displayed when mouse is over the cell.")]
		public System.Windows.Forms.Cursor Cursor
		{
			get
			{
				return m_Cursor;
			}
			set
			{
				if(m_Cursor!=value)
				{
					m_Cursor=value;
				}
			}
		}
        internal bool GetEnabled()
        {
            return m_Enabled;
        }
		/// 
		/// Gets or sets whether cell wrapped the text during the layout.
		/// 
		internal bool WordWrap
		{
			get {return m_WordWrap;}
			set {m_WordWrap=value;}
		}
        private eCellEditorType _EditorType = eCellEditorType.Default;
        /// 
        /// Gets or sets the editor type used to edit the cell. Setting this property to value other than Default
        /// overrides the cell editor type specified on column cell belongs to.
        /// 
        [DefaultValue(eCellEditorType.Default), Category("Behavior"), Description("Indicates editor type used to edit the cell.")]
        public eCellEditorType EditorType
        {
            get { return _EditorType; }
            set { _EditorType = value; }
        }
        /// 
        /// Returns effective editor type used for cell editing.
        /// 
        /// Editor type.
        internal eCellEditorType GetEffectiveEditorType()
        {
            if (_EditorType != eCellEditorType.Default) return _EditorType;
            int index = -1;
            if (this.Parent != null) index = this.Parent.Cells.IndexOf(this);
            if (index == -1) return _EditorType;
            if (this.Parent != null && this.Parent.Parent != null && this.Parent.Parent.NodesColumns.Count > 0 && index < this.Parent.Parent.NodesColumns.Count)
            {
                return this.Parent.Parent.NodesColumns[index].EditorType;
            }
            AdvTree tree=TreeControl;
            if (tree != null && tree.Columns.Count > 0 && index < tree.Columns.Count)
                return tree.Columns[index].EditorType;
            return _EditorType;
        }
		#endregion
		#region Methods
		/// Makes a copy of a Cell.
		public virtual Cell Copy()
		{
			// TODO: Make sure that new properties are copied
			Cell c=new Cell();
			c.CheckBoxAlignment=this.CheckBoxAlignment;
			c.CheckBoxVisible=this.CheckBoxVisible;
            c.CheckBoxStyle = this.CheckBoxStyle;
            if (this.CheckBoxThreeState)
                c.CheckState = this.CheckState;
            else
			    c.Checked=this.Checked;
			c.Cursor=this.Cursor;
			c.Enabled=this.Enabled;
			c.ImageAlignment=this.ImageAlignment;
			c.SetCellImages(this.Images.Copy());
			c.Layout=this.Layout;
			c.StyleDisabled=this.StyleDisabled;
			c.StyleMouseDown=this.StyleMouseDown;
			c.StyleMouseOver=this.StyleMouseOver;
			c.StyleNormal=this.StyleNormal;
			c.StyleSelected=this.StyleSelected;
			c.Tag=this.Tag;
			c.Text=this.Text;
            c.Editable = this.Editable;
            c.EditorType = this.EditorType;
			return c;
		}
        /// 
        /// Ensures that the cell is visible, expanding nodes and scrolling the control as necessary.
        /// 
        public void EnsureVisible()
        {
            NodeOperations.EnsureVisible(this);
        }
		private void OnAppearanceChanged()
		{
			if(this.Parent!=null)
			{
				this.Parent.SizeChanged=true;
				this.Parent.OnDisplayChanged();
			}
		}
		private void OnSizeChanged()
		{
			if(this.Parent!=null)
			{
				this.Parent.SizeChanged=true;
				this.Parent.OnDisplayChanged();
			}
		}
		/// 
		/// Occurs when any image property for the cell has changed.
		/// 
		internal void OnImageChanged()
		{
			if(m_Parent!=null)
				m_Parent.OnImageChanged();
		}
		/// 
		/// Invokes AfterCheck event on AdvTree
		/// control.
		/// 
		protected virtual void InvokeAfterCheck(eTreeAction actionSource)
		{
			AdvTree tree=this.TreeControl;
			if(tree!=null)
			{
                tree.InvokeAfterCheck(new AdvTreeCellEventArgs(actionSource, this));
			}
			m_ActionSource=eTreeAction.Code;
		}
        /// 
        /// Invokes BeforeCheck event on AdvTree
        /// control.
        /// 
        protected virtual void InvokeBeforeCheck(AdvTreeCellBeforeCheckEventArgs e)
        {
            AdvTree tree = this.TreeControl;
            if (tree != null)
            {
                tree.InvokeBeforeCheck(e);
            }
            if (this.Parent != null)
                this.Parent.BeforeCellCheck(this, e);
        }
		/// 
		/// Called just before cell layout is to be performed.
		/// 
		internal void OnLayoutCell()
		{
            if (m_HostedControl != null && !_HostedControlAdded)
            {
                AddHostedControlToTree();
            }
            else if (_HostedItem != null && !_HostedItemAdded)
                AddHostedItemToTree();
		}
        private void SetHostedItem(BaseItem value)
        {
            // Note that hosted item when set is guided by the size of the text. So the TextContentBounds are actually bounds of the control.
            if (m_HostedControl != null)
                throw new InvalidOperationException("HostedItem cannot be set if HostedControl property is set to non-null value.");
            if (_HostedItem != null)
            {
                RemoveHostedItemFromTree();
            }
            _HostedItem = value;
            if (_HostedItem != null)
            {
                if (_HostedItem.Parent != null)
                    _HostedItem.Parent.SubItems.Remove(_HostedItem);
                _HostedItem.Visible = true;
                _HostedItem.Style = eDotNetBarStyle.StyleManagerControlled;
                AddHostedItemToTree();
            }
            OnSizeChanged();
        }
        private void RemoveHostedItemFromTree()
        {
            if (_HostedItem != null)
                _HostedItem.ContainerControl = null;
            _HostedItemAdded = false;
        }
        private bool _HostedItemAdded = false;
        private void AddHostedItemToTree()
        {
            if (_HostedItemAdded) return;
            AdvTree tree = this.TreeControl;
            if (tree != null)
            {
                if (_HostedItem.ContainerControl != tree)
                {
                    _HostedItem.ContainerControl = tree;
                }
                _HostedItemAdded = true;
            }
        }
        private bool _HostedControlAdded = false;
		internal void AddHostedControlToTree()
		{
            if (_HostedControlAdded) return;
			AdvTree tree = this.TreeControl;
			if(tree!=null)
			{
                if (m_HostedControl.Parent != tree)
                {
                    if (m_HostedControl.Parent != null)
                        m_HostedControl.Parent.Controls.Remove(m_HostedControl);
                    tree.Controls.Add(m_HostedControl);
                    tree.InvalidControlBorder = true;
                    m_HostedControl.SendToBack();
                }
				tree.HostedControlCells.Add(this);
                _HostedControlAdded = true;
			}
		}
		
		internal void RemoveHostedControlFromTree()
		{
			AdvTree tree = m_HostedControl.Parent as AdvTree;
            if (tree == null) tree = this.TreeControl;
            if (tree != null)
            {
                tree.Controls.Remove(m_HostedControl);
                tree.HostedControlCells.Remove(this);
                _HostedControlAdded = false;
            }
		}
		private void SetHostedControl(Control value)
		{
			// Note that hosted control when set is guided by the size of the text. So the TextContentBounds are actually bounds of the control.
			if(value==this.TreeControl)
				return;
            if (_HostedItem != null)
                throw new InvalidOperationException("HostedControl cannot be set when HostedItem is set to non-null value.");
			
			if(m_HostedControl!=null)
			{
				m_HostedControl.SizeChanged-=new EventHandler(this.HostedControlSizedChanged);
                m_HostedControl.Enter -= new EventHandler(HostedControlEnter);
				RemoveHostedControlFromTree();
			}
			
			m_HostedControl=value;
			if(m_HostedControl!=null)
			{
				m_HostedControl.SizeChanged+=new EventHandler(this.HostedControlSizedChanged);
                m_HostedControl.Enter += new EventHandler(HostedControlEnter);
				TypeDescriptor.GetProperties(m_HostedControl)["Dock"].SetValue(m_HostedControl,DockStyle.None);
				if(m_HostedControl.Parent!=null)
					m_HostedControl.Parent.Controls.Remove(m_HostedControl);
				
				if(!this.DesignMode)
					m_HostedControl.Visible = false;
				if(this.DesignMode || this.Parent!=null && this.Parent.Site!=null && this.Parent.Site.DesignMode)
				{
					bool visible=GetVisible();
					TypeDescriptor.GetProperties(m_HostedControl)["Visible"].SetValue(m_HostedControl,visible);
				}
				
				AddHostedControlToTree();
			}
			OnSizeChanged();
		}
        private void HostedControlEnter(object sender, EventArgs e)
        {
            AdvTree tree = this.TreeControl;
            if (tree != null)
                tree.SelectedNode = this.Parent;
        }
		private void HostedControlSizedChanged(object sender, EventArgs e)
		{
			if(!m_HostedControlSize.IsEmpty && m_HostedControl!=null)
				m_HostedControlSize = m_HostedControl.Size;
            if (m_IgnoreHostedControlSizeChange)
                return;
			OnSizeChanged();
		}
		internal void OnVisibleChanged()
		{
			if(m_HostedControl!=null)
			{
				TypeDescriptor.GetProperties(m_HostedControl)["Visible"].SetValue(m_HostedControl,GetVisible());
			}
		}
		
		private bool GetVisible()
		{
			if(m_Parent!=null && !NodeOperations.GetIsNodeVisible(m_Parent))
				return false;
			return m_Visible;
		}
		
		internal void OnParentExpandedChanged(bool expanded)
		{
			if(m_HostedControl!=null && m_HostedControl.Visible != expanded)
			{
				bool visible=GetVisible();
				m_HostedControl.Visible = visible;
				if(this.DesignMode || this.Parent!=null && this.Parent.Site!=null && this.Parent.Site.DesignMode)
					TypeDescriptor.GetProperties(m_HostedControl)["Visible"].SetValue(m_HostedControl,visible);
			}
		}
        private bool _Selectable = true;
        /// 
        /// Gets or sets whether cell can be selected by user by clicking it with the mouse or using keyboard. Default value is true.
        /// 
        [DefaultValue(true), Category("Behavior"), Description("Indicates whether cell can be selected by user by clicking it with the mouse or using keyboard.")]
        public bool Selectable
        {
            get { return _Selectable; }
            set
            {
                _Selectable = value;
            }
        }
        /// 
        /// Gets whether cell can be selected. Cell must be Visible, Enabled and Selectable in order for it to be selected.
        /// 
        [Browsable(false)]
        public bool CanSelect
        {
            get
            {
                return this.Enabled & this.IsVisible & this.Selectable;
            }
        }
        /// 
        /// Returns ColumnHeader cell is under if one is defined and cell is already parented to the tree. Otherwise it returns null/nothing.
        /// 
        [Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
        public ColumnHeader ColumnHeader
        {
            get
            {
                AdvTree tree = this.TreeControl;
                if (this.Parent == null || tree == null) return null;
                int index = this.Parent.Cells.IndexOf(this);
                if (this.Parent.HasColumns && this.Parent.NodesColumns.Count > index)
                    return this.Parent.NodesColumns[index];
                if (tree.Columns.Count > index)
                    return tree.Columns[index];
                return null;
            }
        }
		#endregion
		
		#region Markup Implementation
        private DevComponents.DotNetBar.TextMarkup.BodyElement m_TextMarkup = null;
		private void MarkupTextChanged()
		{
			if (!IsMarkupSupported)
				return;
			if(m_TextMarkup!=null)
				m_TextMarkup.HyperLinkClick -= new EventHandler(this.TextMarkupLinkClick);
			
			m_TextMarkup = null;
            if (!DevComponents.DotNetBar.TextMarkup.MarkupParser.IsMarkup(ref m_Text))
				return;
            m_TextMarkup = DevComponents.DotNetBar.TextMarkup.MarkupParser.Parse(m_Text);
            if (m_TextMarkup != null)
                m_TextMarkup.HyperLinkClick += new EventHandler(TextMarkupLinkClick);
		}
		/// 
		/// Occurs when text markup link is clicked.
		/// 
		protected virtual void TextMarkupLinkClick(object sender, EventArgs e)
		{
            DevComponents.DotNetBar.TextMarkup.HyperLink link = sender as DevComponents.DotNetBar.TextMarkup.HyperLink;
			
			if(link!=null && this.Parent!=null)
				this.Parent.InvokeMarkupLinkClick(this, new MarkupLinkClickEventArgs(link.Name, link.HRef));
		}
		/// 
		/// Gets reference to parsed markup body element if text was markup otherwise returns null.
		/// 
        internal DevComponents.DotNetBar.TextMarkup.BodyElement TextMarkupBody
		{
			get { return m_TextMarkup; }
		}
        private bool _TextMarkupEnabled = true;
        /// 
        /// Gets or sets whether cell supports and renders text markup. Default value is true.
        /// 
        [DefaultValue(true), Category("Behavior"), Description("Gets or sets whether cell supports and renders text markup.")]
        public bool TextMarkupEnabled
        {
            get { return _TextMarkupEnabled; }
            set
            {
                _TextMarkupEnabled = value;
            }
        }
		/// 
		/// Gets whether item supports text markup. Default is false.
		/// 
		protected virtual bool IsMarkupSupported
		{
			get { return _TextMarkupEnabled; }
		}
        private bool _HostedItemMouseEntered = false;
		protected internal virtual void InvokeNodeMouseMove(object sender, MouseEventArgs e)
		{
			if(m_TextMarkup!=null)
				m_TextMarkup.MouseMove(sender as Control, e);
            if (_HostedItem != null)
            {
                if (_HostedItem.DisplayRectangle.Contains(e.X, e.Y))
                {
                    if (!_HostedItemMouseEntered)
                    {
                        _HostedItem.InternalMouseEnter();
                        _HostedItemMouseEntered = true;
                    }
                    _HostedItem.InternalMouseMove(e);
                }
                else if(_HostedItemMouseEntered)
                {
                    _HostedItem.InternalMouseLeave();
                    _HostedItemMouseEntered = false;
                }
            }
            if (!IsMouseOver) HideToolTip();
		}
        private bool _HostedItemMouseDown = false;
		protected internal virtual void InvokeNodeMouseDown(object sender, MouseEventArgs e)
		{
            HideToolTip();
			if(m_TextMarkup!=null)
				m_TextMarkup.MouseDown(sender as Control, e);
            if (_HostedItem != null && _HostedItem.DisplayRectangle.Contains(e.X, e.Y))
            {
                _HostedItem.InternalMouseDown(e);
                _HostedItemMouseDown = true;
            }
		}
		
		protected internal virtual void InvokeNodeMouseUp(object sender, MouseEventArgs e)
		{
			if(m_TextMarkup!=null)
				m_TextMarkup.MouseUp(sender as Control, e);
            if (_HostedItem != null && _HostedItemMouseDown)
            {
                _HostedItem.InternalMouseUp(e);
                _HostedItemMouseDown = false;
            }
		}
		
		protected internal virtual void InvokeNodeMouseLeave(object sender, EventArgs e)
		{
            HideToolTip();
			if(m_TextMarkup!=null)
				m_TextMarkup.MouseLeave(sender as Control);
            if (_HostedItem != null)
            {
                if (_HostedItemMouseEntered)
                {
                    _HostedItem.InternalMouseLeave();
                    _HostedItemMouseEntered = false;
                }
            }
		}
		
		protected internal virtual void InvokeNodeClick(object sender, EventArgs e)
		{
			if(m_TextMarkup!=null)
				m_TextMarkup.Click(sender as Control);
            if (_HostedItem != null && e is TreeNodeMouseEventArgs)
            {
                TreeNodeMouseEventArgs me = (TreeNodeMouseEventArgs)e;
                if (this.Bounds.Contains(me.X, me.Y))
                    _HostedItem.InternalClick(me.Button, new Point(me.X, me.Y));
            }
		}
        protected internal virtual void InvokeNodeMouseHover(object sender, EventArgs e)
        {
            if (_HostedItem != null)
                _HostedItem.InternalMouseHover();
            if (System.Windows.Forms.Control.MouseButtons == System.Windows.Forms.MouseButtons.None)
                this.ShowToolTip();
        }
		#endregion
    }
}