using System;
using System.Collections.Generic;
using System.Text;
using System.ComponentModel;
using System.Drawing;
using System.Drawing.Drawing2D;
using System.Drawing.Text;
using System.Windows.Forms;
using DevComponents.DotNetBar.MicroCharts;
namespace DevComponents.DotNetBar
{
    /// 
    /// Represents Micro-Chart Control.
    /// 
    [ToolboxBitmap(typeof(MicroChart), "MicroCharts.MicroChart.ico"), ToolboxItem(true), DefaultEvent("Click"), Designer("DevComponents.DotNetBar.Design.MicroChartDesigner, DevComponents.DotNetBar.Design, Version=14.1.0.37, Culture=neutral,  PublicKeyToken=90f470f34c89ccaf"), System.Runtime.InteropServices.ComVisible(false)]
    public class MicroChart : BaseItemControl, ICommandSource
    {
        #region Events
        #endregion
        #region Constructor
        private MicroChartItem _MicroChart = null;
        /// 
        /// Initializes a new instance of the MicroChart class.
        /// 
        public MicroChart()
        {
            this.SetStyle(ControlStyles.Selectable, false);
            _MicroChart = new MicroChartItem();
            _MicroChart.TextVisible = false;
            _MicroChart.MouseOverDataPointChanged += new EventHandler(MicroChartMouseOverDataPointChanged);
            this.HostItem = _MicroChart;
        }
        #endregion
        #region Implementation
        protected override void OnHandleCreated(EventArgs e)
        {
            this.RecalcLayout();
            base.OnHandleCreated(e);
        }
        /// 
        /// Forces the button to perform internal layout.
        /// 
        public override void RecalcLayout()
        {
            if (_MicroChart == null) return;
            Rectangle bounds = this.ClientRectangle;
            bounds.Inflate(-4, -4);
            if (bounds.Width < 4) bounds.Width = 4;
            if (bounds.Height < 4) bounds.Height = 4;
            _MicroChart.Bounds = bounds;
            _MicroChart.ChartHeight = bounds.Height;
            _MicroChart.ChartWidth = bounds.Width;
            base.RecalcLayout();
        }
        protected override Size DefaultSize
        {
            get
            {
                return new Size(96, 24);
            }
        }
        /// 
        /// Gets or sets whether mouse over tooltip for data point is enabled. Default value is true.
        /// 
        [Category("Behavior"), DefaultValue(true), Description("Indicates whether mouse over tooltip for data point is enabled")]
        public bool MouseOverDataPointTooltipEnabled
        {
            get { return _MicroChart.MouseOverDataPointTooltipEnabled; }
            set
            {
                _MicroChart.MouseOverDataPointTooltipEnabled = value;
            }
        }
        /// 
        /// Gets the index of data point (DataPoints collection) that mouse is over or returns -1 if mouse is not over any data-point.
        /// 
        [Browsable(false)]
        public int MouseOverDataPointIndex
        {
            get
            {
                return _MicroChart.MouseOverDataPointIndex;
            }
        }
        private void MicroChartMouseOverDataPointChanged(object sender, EventArgs e)
        {
            OnMouseOverDataPointChanged(e);
        }
        /// 
        /// Occurs when MouseOverDataPointIndex property changes due to user moving the mouse and pointing it to different data point on chart.
        /// 
        public event EventHandler MouseOverDataPointChanged;
        /// 
        /// Raises MouseOverDataPointChanged event.
        /// 
        /// Provides event arguments.
        protected virtual void OnMouseOverDataPointChanged(EventArgs e)
        {
            EventHandler handler = MouseOverDataPointChanged;
            if (handler != null)
                handler(this, e);
        }
        /// 
        /// Gets or sets the tooltips for each data-point assigned through DataPoints property. If not set control will automatically 
        /// show tooltip based on the data-point value.
        /// 
        [Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
        public List DataPointTooltips
        {
            get { return _MicroChart.DataPointTooltips; }
            set
            {
                _MicroChart.DataPointTooltips = value;
            }
        }
        /// 
        /// Gets or sets the chart data points. Note that if you are adding or removing points directly from this collection you must call
        /// Refresh() method on the control to refresh the display.
        /// 
        [Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
        public List DataPoints
        {
            get { return _MicroChart.DataPoints; }
            set
            {
                if (value != _MicroChart.DataPoints)
                {
                    List oldValue = _MicroChart.DataPoints;
                    _MicroChart.DataPoints = value;
                    OnDataPointsChanged(oldValue, value);
                }
            }
        }
        private void OnDataPointsChanged(List oldValue, List newValue)
        {
        }
        /// 
        /// Gets or sets the format string for the value when it is displayed as tool-tip for data point.
        /// 
        [DefaultValue(""), Category("Appearance"), Description("Indicates format string for the value when it is displayed as tool-tip for data point.")]
        public string TooltipValueFormatString
        {
            get { return _MicroChart.TooltipValueFormatString; }
            set
            {
                _MicroChart.TooltipValueFormatString = value;
            }
        }
        /// 
        /// Gets or sets whether chart is tracking mouse movement to show data-point and its value on tooltip. Default value is true.
        /// 
        [DefaultValue(true), Category("Behavior"), Description("Indicates whether chart is tracking mouse movement to show data-point and its value on tooltip.")]
        public bool TrackChartPoints
        {
            get { return _MicroChart.TrackChartPoints; }
            set
            {
                _MicroChart.TrackChartPoints = value;
            }
        }
        /// 
        /// Gets or sets whether transition animation between same chart with different data-points is enabled. Default value is true.
        /// 
        [DefaultValue(true), Category("Behavior"), Description("Indicates  whether transition animation between same chart with different data-points is enabled.")]
        public bool AnimationEnabled
        {
            get { return _MicroChart.AnimationEnabled; }
            set
            {
                _MicroChart.AnimationEnabled = value;
            }
        }
        internal bool IsAnimationEnabled
        {
            get
            {
                if (this.DesignMode || NativeFunctions.IsTerminalSession())
                    return false;
                return true;
            }
        }
        /// 
        /// Gets or sets whether button like mouse over tracking is enabled for whole control. When enabled control looks like a button when mouse is over it. Default value is false.
        /// 
        [DefaultValue(false), Category("Behavior"), Description("Indicates whether button like mouse over tracking is enabled for whole control. When enabled control looks like a button when mouse is over it.")]
        public bool MouseOverEnabled
        {
            get { return _MicroChart.MouseOverEnabled; }
            set
            {
                _MicroChart.MouseOverEnabled = value;
            }
        }
        /// 
        /// Invalidates the chart display and requests the re-paint.
        /// 
        /// Indicates whether to animate transition to new chart
        public void InvalidateChart(bool animateTransition)
        {
            _MicroChart.InvalidateChart(animateTransition);
        }
        /// 
        /// Gets the style used to customize appearance of Line micro-chart.
        /// 
        [Category("Style"), Description("Identifies style used to customize appearance of Line micro-chart."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        public LineMicroChartStyle LineChartStyle
        {
            get
            {
                return _MicroChart.LineChartStyle;
            }
        }
        /// 
        /// Gets the style used to customize appearance of Plot micro-chart.
        /// 
        [Category("Style"), Description("Identifies style used to customize appearance of Plot micro-chart."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        public PlotMicroChartStyle PlotChartStyle
        {
            get
            {
                return _MicroChart.PlotChartStyle;
            }
        }
        /// 
        /// Gets the style used to customize appearance of Column micro-chart.
        /// 
        [Category("Style"), Description("Identifies style used to customize appearance of Column micro-chart."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        public BarMicroChartStyle ColumnChartStyle
        {
            get
            {
                return _MicroChart.ColumnChartStyle;
            }
        }
        /// 
        /// Gets the style used to customize appearance of Bar micro-chart.
        /// 
        [Category("Style"), Description("Identifies style used to customize appearance of Bar micro-chart."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        public BarMicroChartStyle BarChartStyle
        {
            get
            {
                return _MicroChart.BarChartStyle;
            }
        }
        /// 
        /// Gets the style used to customize appearance of Win-Lose micro-chart.
        /// 
        [Category("Style"), Description("Identifies style used to customize appearance of Win-Lose micro-chart."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        public BarMicroChartStyle WinLoseChartStyle
        {
            get
            {
                return _MicroChart.WinLoseChartStyle;
            }
        }
        /// 
        /// Gets the style used to customize appearance of Pie micro-chart.
        /// 
        [Category("Style"), Description("Identifies style used to customize appearance of Pie micro-chart."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        public PieMicroChartStyle PieChartStyle
        {
            get
            {
                return _MicroChart.PieChartStyle;
            }
        }
        /// 
        /// Gets the style used to customize appearance of Area micro-chart.
        /// 
        [Category("Style"), Description("Identifies style used to customize appearance of Area micro-chart."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        public AreaMicroChartStyle AreaChartStyle
        {
            get
            {
                return _MicroChart.AreaChartStyle;
            }
        }
        /// 
        /// Gets the style used to customize appearance of 100% micro-chart.
        /// 
        [Category("Style"), Description("Identifies style used to customize appearance of 100% micro-chart."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        public HundredPctMicroChartStyle HundredPctChartStyle
        {
            get
            {
                return _MicroChart.HundredPctChartStyle;
            }
        }
        ///// 
        ///// Gets or sets the width of the chart part of the control.
        ///// 
        //[DefaultValue(54), Category("Appearance"), Description("Indicates width of the chart part of the control.")]
        //public int ChartWidth
        //{
        //    get { return _MicroChart.ChartWidth; }
        //    set
        //    {
        //        _MicroChart.ChartWidth = value;
        //    }
        //}
        ///// 
        ///// Gets or sets the height of the chart part of the control.
        ///// 
        //[DefaultValue(15), Category("Appearance"), Description("Indicates height of the chart part of the control.")]
        //public int ChartHeight
        //{
        //    get { return _MicroChart.ChartHeight; }
        //    set
        //    {
        //        _MicroChart.ChartHeight = value;
        //    }
        //}
        /// 
        /// Gets or sets the type of the chart rendered.
        /// 
        [DefaultValue(eMicroChartType.Line), Category("Appearance"), Description("Indicates type of the chart rendered.")]
        public eMicroChartType ChartType
        {
            get { return _MicroChart.ChartType; }
            set
            {
                _MicroChart.ChartType = value;
            }
        }
        /// 
        /// Gets or sets the maximum value for data points. By default maximum data point is calculated based on that data displayed by the chart, but when
        /// two charts need to be scaled the same setting maximum and minimum values for them will ensure that scales are visually the same.
        /// 
        [DefaultValue(double.NaN), Category("Behavior"), Description("Indicates maximum value for data points. By default maximum data point is calculated based on that data displayed by the chart, but when two charts need to be scaled the same setting maximum and minimum values for them will ensure that scales are visually the same.")]
        public double DataMaxValue
        {
            get { return _MicroChart.DataMaxValue; }
            set
            {
                _MicroChart.DataMaxValue = value;
            }
        }
        /// 
        /// Gets or sets the minimum value for data points. By default minimum data point is calculated based on that data displayed by the chart, but when
        /// two charts need to be scaled the same setting maximum and minimum values for them will ensure that scales are visually the same.
        /// 
        [DefaultValue(double.NaN), Category("Behavior"), Description("Indicates minimum value for data points. By default minimum data point is calculated based on that data displayed by the chart, but when two charts need to be scaled the same setting maximum and minimum values for them will ensure that scales are visually the same.")]
        public double DataMinValue
        {
            get { return _MicroChart.DataMinValue; }
            set
            {
                _MicroChart.DataMinValue = value;
            }
        }
        ///// 
        ///// Gets or sets whether text-markup support is enabled for items Text property. Default value is true.
        ///// Set this property to false to display HTML or other markup in the item instead of it being parsed as text-markup.
        ///// 
        //[DefaultValue(true), Category("Appearance"), Description("Indicates whether text-markup support is enabled for items Text property.")]
        //public bool EnableMarkup
        //{
        //    get { return _MicroChart.EnableMarkup; }
        //    set
        //    {
        //        _MicroChart.EnableMarkup = value;
        //    }
        //}
        ///// 
        ///// Gets or sets text-position in relation to the chart.
        ///// 
        //[DefaultValue(eMicroChartTextPosition.Left), Category("Appearance"), Description("Indicates text-position in relation to the chart.")]
        //public eMicroChartTextPosition TextPosition
        //{
        //    get { return _MicroChart.TextPosition; }
        //    set
        //    {
        //        _MicroChart.TextPosition = value;
        //    }
        //}
        ///// 
        ///// Gets or sets whether caption/label set using Text property is visible.
        ///// 
        //[DefaultValue(true), Category("Appearance"), Description("Indicates whether caption/label set using Text property is visible.")]
        //public bool TextVisible
        //{
        //    get { return _MicroChart.TextVisible; }
        //    set
        //    {
        //        _MicroChart.TextVisible = value;
        //    }
        //}
        ///// 
        ///// Gets or sets text padding.
        ///// 
        //[Browsable(true), Category("Appearance"), Description("Gets or sets text padding."), DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
        //public Padding TextPadding
        //{
        //    get { return _MicroChart.TextPadding; }
        //}
        //[EditorBrowsable(EditorBrowsableState.Never)]
        //public bool ShouldSerializeTextPadding()
        //{
        //    return _MicroChart.ShouldSerializeTextPadding();
        //}
        //[EditorBrowsable(EditorBrowsableState.Never)]
        //public void ResetTextPadding()
        //{
        //    _MicroChart.ResetTextPadding();
        //}
        /// 
        ///// Gets or sets the text color.
        ///// 
        //[Category("Appearance"), Description("Indicates text color.")]
        //public Color TextColor
        //{
        //    get { return _MicroChart.TextColor; }
        //    set { _MicroChart.TextColor = value; }
        //}
        ///// 
        ///// Gets whether property should be serialized.
        ///// 
        //[EditorBrowsable(EditorBrowsableState.Never)]
        //public bool ShouldSerializeTextColor()
        //{
        //    return _MicroChart.ShouldSerializeTextColor();
        //}
        ///// 
        ///// Resets property to its default value.
        ///// 
        //[EditorBrowsable(EditorBrowsableState.Never)]
        //public void ResetTextColor()
        //{
        //    _MicroChart.ResetTextColor();
        //}
        #endregion
        #region ICommandSource Members
        /// 
        /// Gets whether command is executed when control is clicked.
        /// 
        protected virtual bool ExecuteCommandOnClick
        {
            get { return true; }
        }
        protected virtual void ExecuteCommand()
        {
            if (_Command == null) return;
            CommandManager.ExecuteCommand(this);
        }
        /// 
        /// Gets or sets the command assigned to the item. Default value is null.
        /// Note that if this property is set to null Enabled property will be set to false automatically to disable the item.
        /// 
        [DefaultValue(null), Category("Commands"), Description("Indicates the command assigned to the item.")]
        public Command Command
        {
            get { return (Command)((ICommandSource)this).Command; }
            set
            {
                ((ICommandSource)this).Command = value;
            }
        }
        private ICommand _Command = null;
        //[Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
        ICommand ICommandSource.Command
        {
            get
            {
                return _Command;
            }
            set
            {
                bool changed = false;
                if (_Command != value)
                    changed = true;
                if (_Command != null)
                    CommandManager.UnRegisterCommandSource(this, _Command);
                _Command = value;
                if (value != null)
                    CommandManager.RegisterCommand(this, value);
                if (changed)
                    OnCommandChanged();
            }
        }
        /// 
        /// Called when Command property value changes.
        /// 
        protected virtual void OnCommandChanged()
        {
        }
        private object _CommandParameter = null;
        /// 
        /// Gets or sets user defined data value that can be passed to the command when it is executed.
        /// 
        [Browsable(true), DefaultValue(null), Category("Commands"), Description("Indicates user defined data value that can be passed to the command when it is executed."), System.ComponentModel.TypeConverter(typeof(System.ComponentModel.StringConverter)), System.ComponentModel.Localizable(true)]
        public object CommandParameter
        {
            get
            {
                return _CommandParameter;
            }
            set
            {
                _CommandParameter = value;
            }
        }
        #endregion
    }
}