190 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			190 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using System;
 | 
						|
using System.Text;
 | 
						|
using System.Drawing;
 | 
						|
 | 
						|
#if AdvTree
 | 
						|
namespace DevComponents.Tree.TextMarkup
 | 
						|
#elif DOTNETBAR
 | 
						|
namespace DevComponents.DotNetBar.TextMarkup
 | 
						|
#elif SUPERGRID
 | 
						|
namespace DevComponents.SuperGrid.TextMarkup
 | 
						|
#elif LAYOUT
 | 
						|
namespace DevComponents.DotNetBar.Layout.TextMarkup
 | 
						|
#endif
 | 
						|
{
 | 
						|
#if FRAMEWORK20
 | 
						|
    public static class MarkupSettings
 | 
						|
#else
 | 
						|
    public class MarkupSettings
 | 
						|
#endif
 | 
						|
    {
 | 
						|
        private static HyperlinkStyle _NormalHyperlink = new HyperlinkStyle(Color.Blue, eHyperlinkUnderlineStyle.SolidLine);
 | 
						|
        /// <summary>
 | 
						|
        /// Gets the style of the hyperlink in its default state.
 | 
						|
        /// </summary>
 | 
						|
        public static HyperlinkStyle NormalHyperlink
 | 
						|
        {
 | 
						|
            get { return _NormalHyperlink; }
 | 
						|
        }
 | 
						|
 | 
						|
        private static HyperlinkStyle _MouseOverHyperlink = new HyperlinkStyle();
 | 
						|
        /// <summary>
 | 
						|
        /// Gets the style of the hyperlink when mouse is over the link.
 | 
						|
        /// </summary>
 | 
						|
        public static HyperlinkStyle MouseOverHyperlink
 | 
						|
        {
 | 
						|
            get { return _MouseOverHyperlink; }
 | 
						|
        }
 | 
						|
 | 
						|
        private static HyperlinkStyle _VisitedHyperlink = new HyperlinkStyle();
 | 
						|
        /// <summary>
 | 
						|
        /// Gets the style of the visited hyperlink.
 | 
						|
        /// </summary>
 | 
						|
        public static HyperlinkStyle VisitedHyperlink
 | 
						|
        {
 | 
						|
            get { return _VisitedHyperlink; }
 | 
						|
        }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// Represents the method that will handle the ResolveImage event.
 | 
						|
        /// </summary>
 | 
						|
        public delegate void ResolveImageEventHandler(object sender, ResolveImageEventArgs e);
 | 
						|
        // <summary>
 | 
						|
        /// Occurs when DotNetBar is looking for an image for one of the internal img tags that is
 | 
						|
        /// used within the minimarkup. You need to set Handled=true if you want your custom image
 | 
						|
        /// to be used instead of the built-in resource resolving mechanism.
 | 
						|
        /// </summary>
 | 
						|
        public static event ResolveImageEventHandler ResolveImage;
 | 
						|
        internal static void InvokeResolveImage(ResolveImageEventArgs e)
 | 
						|
        {
 | 
						|
            if (ResolveImage != null)
 | 
						|
                ResolveImage(null, e);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Defines the text-markup hyperlink appearance style.
 | 
						|
    /// </summary>
 | 
						|
    public class HyperlinkStyle
 | 
						|
    {
 | 
						|
        /// <summary>
 | 
						|
        /// Initializes a new instance of the HyperlinkStyle class.
 | 
						|
        /// </summary>
 | 
						|
        public HyperlinkStyle()
 | 
						|
        {
 | 
						|
        }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// Initializes a new instance of the HyperlinkStyle class.
 | 
						|
        /// </summary>
 | 
						|
        /// <param name="textColor"></param>
 | 
						|
        /// <param name="underlineStyle"></param>
 | 
						|
        public HyperlinkStyle(Color textColor, eHyperlinkUnderlineStyle underlineStyle)
 | 
						|
        {
 | 
						|
            _TextColor = textColor;
 | 
						|
            _UnderlineStyle = underlineStyle;
 | 
						|
        }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// Initializes a new instance of the HyperlinkStyle class.
 | 
						|
        /// </summary>
 | 
						|
        /// <param name="textColor"></param>
 | 
						|
        /// <param name="backColor"></param>
 | 
						|
        /// <param name="underlineStyle"></param>
 | 
						|
        public HyperlinkStyle(Color textColor, Color backColor, eHyperlinkUnderlineStyle underlineStyle)
 | 
						|
        {
 | 
						|
            _TextColor = textColor;
 | 
						|
            _BackColor = backColor;
 | 
						|
            _UnderlineStyle = underlineStyle;
 | 
						|
        }
 | 
						|
        private Color _TextColor = Color.Empty;
 | 
						|
        /// <summary>
 | 
						|
        /// Gets or sets hyperlink text color.
 | 
						|
        /// </summary>
 | 
						|
        public Color TextColor
 | 
						|
        {
 | 
						|
            get { return _TextColor; }
 | 
						|
            set
 | 
						|
            {
 | 
						|
                if (_TextColor != value)
 | 
						|
                {
 | 
						|
                    _TextColor = value;
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        private Color _BackColor = Color.Empty;
 | 
						|
        /// <summary>
 | 
						|
        /// Gets or sets hyperlink back color.
 | 
						|
        /// </summary>
 | 
						|
        public Color BackColor
 | 
						|
        {
 | 
						|
            get { return _BackColor; }
 | 
						|
            set
 | 
						|
            {
 | 
						|
                if (_BackColor != value)
 | 
						|
                {
 | 
						|
                    _BackColor = value;
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        private eHyperlinkUnderlineStyle _UnderlineStyle = eHyperlinkUnderlineStyle.None;
 | 
						|
        /// <summary>
 | 
						|
        /// Gets or sets the underline style for the hyperlink.
 | 
						|
        /// </summary>
 | 
						|
        public eHyperlinkUnderlineStyle UnderlineStyle
 | 
						|
        {
 | 
						|
            get { return _UnderlineStyle; }
 | 
						|
            set
 | 
						|
            {
 | 
						|
                if (_UnderlineStyle != value)
 | 
						|
                {
 | 
						|
                    _UnderlineStyle = value;
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// Gets whether style has been changed from its default state.
 | 
						|
        /// </summary>
 | 
						|
        public bool IsChanged
 | 
						|
        {
 | 
						|
            get { return !_TextColor.IsEmpty || !_BackColor.IsEmpty || _UnderlineStyle != eHyperlinkUnderlineStyle.None; }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    public enum eHyperlinkUnderlineStyle
 | 
						|
    {
 | 
						|
        None,
 | 
						|
        SolidLine,
 | 
						|
        DashedLine
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// <summary>
 | 
						|
    /// Event arguments for ResolveImage event.
 | 
						|
    /// </summary>
 | 
						|
    public class ResolveImageEventArgs : EventArgs
 | 
						|
    {
 | 
						|
        /// <summary>
 | 
						|
        /// Indicates that event has been handled and that ResolvedImage should be used.
 | 
						|
        /// </summary>
 | 
						|
        public bool Handled = false;
 | 
						|
        /// <summary>
 | 
						|
        /// Indicates the string key parameters in url-style for the image that needs to be resolved.
 | 
						|
        /// </summary>
 | 
						|
        public string Key = "";
 | 
						|
        /// <summary>
 | 
						|
        /// Indicates the resolved image value.
 | 
						|
        /// you need to set this value to the resolved image and you need to set Handled property to true.
 | 
						|
        /// </summary>
 | 
						|
       public Image ResolvedImage = null;
 | 
						|
        /// <summary>
 | 
						|
        /// Default constructor.
 | 
						|
        /// </summary>
 | 
						|
        public ResolveImageEventArgs() { }
 | 
						|
    }
 | 
						|
 | 
						|
}
 |