diff --git a/Documents/Help/Changelog.md b/Documents/Help/Changelog.md index acd41bbf16..7c22f80c02 100644 --- a/Documents/Help/Changelog.md +++ b/Documents/Help/Changelog.md @@ -1,6 +1,8 @@ # Standard Toolkit - Changelog ## 2022-01-05 - Build 2201 - January 2022 +* Fixed [#511](https://github.com/Krypton-Suite/Standard-Toolkit/issues/511), KryptonRibbonGroupComboBox does not have tooltips +* Fixed [#382](https://github.com/Krypton-Suite/Standard-Toolkit/issues/382), RibbonGroupNumericUpDown does not have tooltips * Fixed [#453](https://github.com/Krypton-Suite/Standard-Toolkit/issues/453), KryptonDataGridView's cell cannot display multiple lines when DefaultCellStyle.WrapMode set true * Fixed [#499](https://github.com/Krypton-Suite/Standard-Toolkit/issues/499), `KDataGridView` Cell Borders * Fixed [#502](https://github.com/Krypton-Suite/Standard-Toolkit/issues/502),KNumericUpDowner, when told to display 1 decimal place, does not display a 0 when needed diff --git a/README.md b/README.md index ff4966209b..9b50e3c579 100644 --- a/README.md +++ b/README.md @@ -106,6 +106,14 @@ Follow the links to see the different objects and layouts that this framework al +## Breaking Changes +There are list of changes that have occurred during the development of the V6.## version + +### Ribbon Tooltips +- https://github.com/Krypton-Suite/Standard-Toolkit/issues/382 +- https://github.com/Krypton-Suite/Standard-Toolkit/issues/511 +![][image_ref_tnqwpvc0]### Ribbon Tooltips + ======= ## Introduction @@ -133,3 +141,6 @@ The Krypton Workspace allows a document area to be created that the user can cus ### Krypton Docking The Krypton Docking set of components allow the user to drag and drop docking pages into new locations in order to customise the organisation of the application content. It allows this in a way similar to that of Visual Studio 2008/2010. Each docking area uses an instance of the Krypton Workspace allowing a wide range of options for organising and displaying pages. It integrates with the Krypton Toolkit architecture to ensure a consistent look and feel. + + +[image_ref_tnqwpvc0]:  diff --git a/Source/Krypton Components/Krypton.Ribbon/General/Definitions.cs b/Source/Krypton Components/Krypton.Ribbon/General/Definitions.cs index f3ac1a1920..8ab7ebb9f6 100644 --- a/Source/Krypton Components/Krypton.Ribbon/General/Definitions.cs +++ b/Source/Krypton Components/Krypton.Ribbon/General/Definitions.cs @@ -158,6 +158,12 @@ public interface IRibbonGroupItem /// Delegate for notifying changes in display. /// ViewBase derived instance. ViewBase CreateView(KryptonRibbon ribbon, NeedPaintHandler needPaint); + + ToolTipValues ToolTipValues + { + // Return base objects tooltip + get; + } } #endregion diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupButton.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupButton.cs index 645bb6450b..cf9decc72d 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupButton.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupButton.cs @@ -101,10 +101,6 @@ public KryptonRibbonGroupButton() _itemSizeMax = GroupItemSize.Large; _itemSizeMin = GroupItemSize.Small; _itemSizeCurrent = GroupItemSize.Large; - ToolTipImageTransparentColor = Color.Empty; - ToolTipTitle = string.Empty; - ToolTipBody = string.Empty; - ToolTipStyle = LabelStyle.SuperTip; } #endregion @@ -353,55 +349,11 @@ public void ResetShortcutKeys() ShortcutKeys = Keys.None; } - /// - /// Gets and sets the tooltip label style for group button. - /// - [Category("Appearance")] - [Description("Tooltip style for the group button.")] - [DefaultValue(typeof(LabelStyle), "SuperTip")] - public LabelStyle ToolTipStyle { get; set; } - - /// - /// Gets and sets the image for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Display image associated ToolTip.")] - [DefaultValue(null)] - [Localizable(true)] - public Image ToolTipImage { get; set; } /// - /// Gets and sets the color to draw as transparent in the ToolTipImage. + /// Gets access to the Wrapped Controls Tooltips. /// - [Bindable(true)] - [Category("Appearance")] - [Description("Color to draw as transparent in the ToolTipImage.")] - [KryptonDefaultColor()] - [Localizable(true)] - public Color ToolTipImageTransparentColor { get; set; } - - /// - /// Gets and sets the title text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Title text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipTitle { get; set; } - - /// - /// Gets and sets the body text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Body text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipBody { get; set; } + public override ToolTipValues ToolTipValues => _toolTipValues; /// /// Gets and sets the context strip for showing when the button is pressed. @@ -541,8 +493,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewDrawRibbonGroupButton(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewDrawRibbonGroupButton(ribbon, this, needPaint); + } /// /// Generates a Click event for a button. @@ -839,17 +794,6 @@ internal override bool ProcessCmdKey(ref Message msg, Keys keyData) return false; } - - internal override LabelStyle InternalToolTipStyle => ToolTipStyle; - - internal override Image InternalToolTipImage => ToolTipImage; - - internal override Color InternalToolTipImageTransparentColor => ToolTipImageTransparentColor; - - internal override string InternalToolTipTitle => ToolTipTitle; - - internal override string InternalToolTipBody => ToolTipBody; - #endregion #region Implementation diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCheckBox.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCheckBox.cs index 89c4a58012..64bfe3a93d 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCheckBox.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCheckBox.cs @@ -99,10 +99,6 @@ public KryptonRibbonGroupCheckBox() _itemSizeMax = GroupItemSize.Large; _itemSizeMin = GroupItemSize.Small; _itemSizeCurrent = GroupItemSize.Large; - ToolTipImageTransparentColor = Color.Empty; - ToolTipTitle = string.Empty; - ToolTipBody = string.Empty; - ToolTipStyle = LabelStyle.SuperTip; } #endregion @@ -360,55 +356,11 @@ public void ResetShortcutKeys() ShortcutKeys = Keys.None; } + /// - /// Gets and sets the tooltip label style for group check box. + /// Gets access to the Wrapped Controls Tooltips. /// - [Category("Appearance")] - [Description("Tooltip style for the group check box.")] - [DefaultValue(typeof(LabelStyle), "SuperTip")] - public LabelStyle ToolTipStyle { get; set; } - - /// - /// Gets and sets the image for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Display image associated ToolTip.")] - [DefaultValue(null)] - [Localizable(true)] - public Image ToolTipImage { get; set; } - - /// - /// Gets and sets the color to draw as transparent in the ToolTipImage. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Color to draw as transparent in the ToolTipImage.")] - [KryptonDefaultColor()] - [Localizable(true)] - public Color ToolTipImageTransparentColor { get; set; } - - /// - /// Gets and sets the title text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Title text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipTitle { get; set; } - - /// - /// Gets and sets the body text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Body text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipBody { get; set; } + public override ToolTipValues ToolTipValues => _toolTipValues; /// /// Gets and sets the associated KryptonCommand. @@ -508,8 +460,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewDrawRibbonGroupCheckBox(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewDrawRibbonGroupCheckBox(ribbon, this, needPaint); + } /// /// Generates a Click event for a check box. @@ -690,16 +645,6 @@ internal override bool ProcessCmdKey(ref Message msg, Keys keyData) return false; } - internal override LabelStyle InternalToolTipStyle => ToolTipStyle; - - internal override Image InternalToolTipImage => ToolTipImage; - - internal override Color InternalToolTipImageTransparentColor => ToolTipImageTransparentColor; - - internal override string InternalToolTipTitle => ToolTipTitle; - - internal override string InternalToolTipBody => ToolTipBody; - #endregion } } diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCluster.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCluster.cs index f6941664d9..3c3cc6e268 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCluster.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCluster.cs @@ -276,6 +276,11 @@ public override GroupItemSize ItemSizeCurrent // We always want 3 pixels space between previous item and us 3; + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => _toolTipValues; + /// /// Creates an appropriate view element for this item. /// @@ -284,8 +289,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewLayoutRibbonGroupCluster(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewLayoutRibbonGroupCluster(ribbon, this, needPaint); + } /// /// Gets the collection of ribbon group button cluster items. diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupClusterButton.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupClusterButton.cs index 5ace3bcb3e..1ed96146ab 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupClusterButton.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupClusterButton.cs @@ -97,10 +97,6 @@ public KryptonRibbonGroupClusterButton() _buttonType = GroupButtonType.Push; _contextMenuStrip = null; _kryptonContextMenu = null; - ToolTipImageTransparentColor = Color.Empty; - ToolTipTitle = string.Empty; - ToolTipBody = string.Empty; - ToolTipStyle = LabelStyle.SuperTip; } #endregion @@ -296,55 +292,11 @@ public void ResetShortcutKeys() ShortcutKeys = Keys.None; } + /// - /// Gets and sets the tooltip label style for group cluster button. + /// Gets access to the Wrapped Controls Tooltips. /// - [Category("Appearance")] - [Description("Tooltip style for the group cluster button.")] - [DefaultValue(typeof(LabelStyle), "SuperTip")] - public LabelStyle ToolTipStyle { get; set; } - - /// - /// Gets and sets the image for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Display image associated ToolTip.")] - [DefaultValue(null)] - [Localizable(true)] - public Image ToolTipImage { get; set; } - - /// - /// Gets and sets the color to draw as transparent in the ToolTipImage. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Color to draw as transparent in the ToolTipImage.")] - [KryptonDefaultColor()] - [Localizable(true)] - public Color ToolTipImageTransparentColor { get; set; } - - /// - /// Gets and sets the title text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Title text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipTitle { get; set; } - - /// - /// Gets and sets the body text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Body text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipBody { get; set; } + public override ToolTipValues ToolTipValues => _toolTipValues; /// /// Gets and sets the context strip for showing when the button is pressed. @@ -512,8 +464,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewDrawRibbonGroupClusterButton(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewDrawRibbonGroupClusterButton(ribbon, this, needPaint); + } /// /// Generates a Click event for a button. @@ -807,16 +762,6 @@ internal override bool ProcessCmdKey(ref Message msg, Keys keyData) return false; } - internal override LabelStyle InternalToolTipStyle => ToolTipStyle; - - internal override Image InternalToolTipImage => ToolTipImage; - - internal override Color InternalToolTipImageTransparentColor => ToolTipImageTransparentColor; - - internal override string InternalToolTipTitle => ToolTipTitle; - - internal override string InternalToolTipBody => ToolTipBody; - #endregion #region Implementation diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupClusterColorButton.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupClusterColorButton.cs index c53439a198..d6e4fdaf0e 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupClusterColorButton.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupClusterColorButton.cs @@ -155,10 +155,6 @@ public KryptonRibbonGroupClusterColorButton() _itemSizeCurrent = GroupItemSize.Medium; _imageSmall = _defaultButtonImageSmall; _buttonType = GroupButtonType.Split; - ToolTipImageTransparentColor = Color.Empty; - ToolTipTitle = string.Empty; - ToolTipBody = string.Empty; - ToolTipStyle = LabelStyle.SuperTip; _maxRecentColors = 10; _recentColors = new List(); @@ -280,9 +276,9 @@ public string TextLine /// [Bindable(true)] [Localizable(true)] - [Category("Appearance")] - [Description("Ribbon group cluster color button key tip.")] - [DefaultValue("B")] + [Category(@"Appearance")] + [Description(@"Ribbon group cluster color button key tip.")] + [DefaultValue(@"B")] public string KeyTip { get => _keyTip; @@ -291,7 +287,7 @@ public string KeyTip { if (string.IsNullOrEmpty(value)) { - value = "B"; + value = @"B"; } _keyTip = value.ToUpper(); @@ -624,54 +620,9 @@ public void ResetShortcutKeys() } /// - /// Gets and sets the tooltip label style for group color cluster button. - /// - [Category("Appearance")] - [Description("Tooltip style for the group color cluster button.")] - [DefaultValue(typeof(LabelStyle), "SuperTip")] - public LabelStyle ToolTipStyle { get; set; } - - /// - /// Gets and sets the image for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Display image associated ToolTip.")] - [DefaultValue(null)] - [Localizable(true)] - public Image ToolTipImage { get; set; } - - /// - /// Gets and sets the color to draw as transparent in the ToolTipImage. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Color to draw as transparent in the ToolTipImage.")] - [KryptonDefaultColor()] - [Localizable(true)] - public Color ToolTipImageTransparentColor { get; set; } - - /// - /// Gets and sets the title text for the item ToolTip. + /// Gets access to the Wrapped Controls Tooltips. /// - [Bindable(true)] - [Category("Appearance")] - [Description("Title text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipTitle { get; set; } - - /// - /// Gets and sets the body text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Body text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipBody { get; set; } + public override ToolTipValues ToolTipValues => _toolTipValues; /// /// Gets and sets the set of recent colors. @@ -824,8 +775,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewDrawRibbonGroupClusterColorButton(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewDrawRibbonGroupClusterColorButton(ribbon, this, needPaint); + } /// /// Generates a Click event for a button. @@ -1117,16 +1071,6 @@ internal override bool ProcessCmdKey(ref Message msg, Keys keyData) return false; } - internal override LabelStyle InternalToolTipStyle => ToolTipStyle; - - internal override Image InternalToolTipImage => ToolTipImage; - - internal override Color InternalToolTipImageTransparentColor => ToolTipImageTransparentColor; - - internal override string InternalToolTipTitle => ToolTipTitle; - - internal override string InternalToolTipBody => ToolTipBody; - #endregion #region Implementation diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupColorButton.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupColorButton.cs index 445f2d2357..12d153e5c0 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupColorButton.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupColorButton.cs @@ -162,10 +162,6 @@ public KryptonRibbonGroupColorButton() _itemSizeMax = GroupItemSize.Large; _itemSizeMin = GroupItemSize.Small; _itemSizeCurrent = GroupItemSize.Large; - ToolTipImageTransparentColor = Color.Empty; - ToolTipTitle = string.Empty; - ToolTipBody = string.Empty; - ToolTipStyle = LabelStyle.SuperTip; _maxRecentColors = 10; _recentColors = new List(); @@ -696,54 +692,9 @@ public void ResetShortcutKeys() } /// - /// Gets and sets the tooltip label style for group color button. + /// Gets access to the Wrapped Controls Tooltips. /// - [Category("Appearance")] - [Description("Tooltip style for the group color button.")] - [DefaultValue(typeof(LabelStyle), "SuperTip")] - public LabelStyle ToolTipStyle { get; set; } - - /// - /// Gets and sets the image for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Display image associated ToolTip.")] - [DefaultValue(null)] - [Localizable(true)] - public Image ToolTipImage { get; set; } - - /// - /// Gets and sets the color to draw as transparent in the ToolTipImage. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Color to draw as transparent in the ToolTipImage.")] - [KryptonDefaultColor()] - [Localizable(true)] - public Color ToolTipImageTransparentColor { get; set; } - - /// - /// Gets and sets the title text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Title text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipTitle { get; set; } - - /// - /// Gets and sets the body text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Body text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipBody { get; set; } + public override ToolTipValues ToolTipValues => _toolTipValues; /// /// Gets and sets the set of recent colors. @@ -872,8 +823,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewDrawRibbonGroupColorButton(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewDrawRibbonGroupColorButton(ribbon, this, needPaint); + } /// /// Generates a Click event for a button. @@ -1173,16 +1127,6 @@ internal override bool ProcessCmdKey(ref Message msg, Keys keyData) return false; } - internal override LabelStyle InternalToolTipStyle => ToolTipStyle; - - internal override Image InternalToolTipImage => ToolTipImage; - - internal override Color InternalToolTipImageTransparentColor => ToolTipImageTransparentColor; - - internal override string InternalToolTipTitle => ToolTipTitle; - - internal override string InternalToolTipBody => ToolTipBody; - #endregion #region Implementation diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupComboBox.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupComboBox.cs index 616bf46f99..d89a268c22 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupComboBox.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupComboBox.cs @@ -584,6 +584,12 @@ public bool Sorted set => ComboBox.Sorted = value; } + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => ComboBox.ToolTipValues; + + /// /// Gets or sets the items in the KryptonComboBox. /// diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupContainer.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupContainer.cs index 4281169c16..509616873d 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupContainer.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupContainer.cs @@ -35,6 +35,7 @@ public KryptonRibbonGroupContainer() #endregion #region Public + /// /// Gets access to the parent group instance. /// diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCustomControl.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCustomControl.cs index 19277800b4..83c6ff3079 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCustomControl.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupCustomControl.cs @@ -121,13 +121,29 @@ public string KeyTip { if (string.IsNullOrEmpty(value)) { - value = "X"; + value = @"X"; } _keyTip = value.ToUpper(); } } + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues + { + get + { + // TODO: This will not be here when the designer is performing it's actions ?? + if (CustomControl is VisualControlBase vcb) + return vcb.ToolTipValues; + // TODO: Should really pass these values into the `CustomControl` after it has been created ! + return _toolTipValues; + } + } + + /// /// Gets and sets the custom control for display inside ribbon element. /// diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupDateTimePicker.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupDateTimePicker.cs index aebc596b11..0b0696f166 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupDateTimePicker.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupDateTimePicker.cs @@ -368,6 +368,11 @@ public KryptonContextMenu KryptonContextMenu set => DateTimePicker.KryptonContextMenu = value; } + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => DateTimePicker.ToolTipValues; + /// /// Gets and sets a value indicating if tooltips should be displayed for button specs. /// diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupDomainUpDown.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupDomainUpDown.cs index 7e3a1f10d3..b03ea8ee6f 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupDomainUpDown.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupDomainUpDown.cs @@ -469,6 +469,12 @@ public KryptonContextMenu KryptonContextMenu set => DomainUpDown.KryptonContextMenu = value; } + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => DomainUpDown.ToolTipValues; + + /// /// Gets and sets a value indicating if tooltips should be displayed for button specs. /// diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupGallery.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupGallery.cs index cb77155600..b4c411b76e 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupGallery.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupGallery.cs @@ -124,10 +124,6 @@ public KryptonRibbonGroupGallery() _imageLarge = _defaultButtonImageLarge; _textLine1 = "Gallery"; _textLine2 = string.Empty; - ToolTipImageTransparentColor = Color.Empty; - ToolTipTitle = string.Empty; - ToolTipBody = string.Empty; - ToolTipStyle = LabelStyle.SuperTip; // Create the actual text box control and set initial settings Gallery = new KryptonGallery @@ -462,56 +458,11 @@ public string TextLine2 } } } - - /// - /// Gets and sets the tooltip label style for group button. - /// - [Category("Appearance")] - [Description("Tooltip style for the group button.")] - [DefaultValue(typeof(LabelStyle), "SuperTip")] - public LabelStyle ToolTipStyle { get; set; } - /// - /// Gets and sets the image for the item ToolTip. + /// Gets access to the Wrapped Controls Tooltips. /// - [Bindable(true)] - [Category("Appearance")] - [Description("Display image associated ToolTip.")] - [DefaultValue(null)] - [Localizable(true)] - public Image ToolTipImage { get; set; } + public override ToolTipValues ToolTipValues => _toolTipValues; - /// - /// Gets and sets the color to draw as transparent in the ToolTipImage. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Color to draw as transparent in the ToolTipImage.")] - [KryptonDefaultColor()] - [Localizable(true)] - public Color ToolTipImageTransparentColor { get; set; } - - /// - /// Gets and sets the title text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Title text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipTitle { get; set; } - - /// - /// Gets and sets the body text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Body text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipBody { get; set; } /// /// Gets and sets the visible state of the group gallery. @@ -682,8 +633,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewDrawRibbonGroupGallery(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewDrawRibbonGroupGallery(ribbon, this, needPaint); + } /// /// Gets and sets the associated designer. @@ -717,16 +671,6 @@ internal void OnDesignTimeContextMenu(MouseEventArgs e) internal int InternalItemCount { get; set; } - internal override LabelStyle InternalToolTipStyle => ToolTipStyle; - - internal override Image InternalToolTipImage => ToolTipImage; - - internal override Color InternalToolTipImageTransparentColor => ToolTipImageTransparentColor; - - internal override string InternalToolTipTitle => ToolTipTitle; - - internal override string InternalToolTipBody => ToolTipBody; - internal override bool ProcessCmdKey(ref Message msg, Keys keyData) => false; #endregion diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupItem.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupItem.cs index b68339f596..fdc9a828a7 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupItem.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupItem.cs @@ -1,4 +1,5 @@ -#region BSD License + +#region BSD License /* * * Original BSD 3-Clause License (https://github.com/ComponentFactory/Krypton/blob/master/LICENSE) @@ -25,6 +26,7 @@ public abstract class KryptonRibbonGroupItem : Component, { #region Instance Fields private object _tag; + protected ToolTipValues _toolTipValues; #endregion @@ -32,11 +34,13 @@ public abstract class KryptonRibbonGroupItem : Component, /// /// Initialise a new instance of the KryptonRibbonGroupItem class. /// - public KryptonRibbonGroupItem() + protected KryptonRibbonGroupItem() { + // Do the Tooltip Magic + _toolTipValues = new ToolTipValues(null/*NeedPaintDelegate*/); // Must be replaced by appropriate call } - #endregion - + #endregion Identity + #region Public /// /// Gets access to the owning ribbon control. @@ -104,7 +108,6 @@ public KryptonRibbonGroupItem() // If the previous item is a group button cluster then we want 3 pixels previousItem is KryptonRibbonGroupCluster ? 3 : 1; - // By default we just want a single pixel gap /// /// Creates an appropriate view element for this item. /// @@ -140,7 +143,27 @@ private void ResetTag() { Tag = null; } - #endregion + + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + [Category("ToolTip")] + [Description("Control ToolTip Text")] + [DesignerSerializationVisibility(DesignerSerializationVisibility.Content)] + public abstract ToolTipValues ToolTipValues + { + // Return base objects tooltip + get; + } + + private bool ShouldSerializeToolTipValues() => !ToolTipValues.IsDefault; + + /// + /// Resets the ToolTipValues property to its default value. + /// + public void ResetToolTipValues() => ToolTipValues.Reset(); + + #endregion#endregion #region Protected /// @@ -173,16 +196,6 @@ protected bool ChainVisible #region Internal internal abstract bool ProcessCmdKey(ref Message msg, Keys keyData); - internal virtual Image InternalToolTipImage => null; - - internal virtual LabelStyle InternalToolTipStyle => LabelStyle.SuperTip; - - internal virtual Color InternalToolTipImageTransparentColor => Color.Empty; - - internal virtual string InternalToolTipTitle => string.Empty; - - internal virtual string InternalToolTipBody => string.Empty; - #endregion #region IBindableComponent Members diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupLabel.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupLabel.cs index 55016e6c14..52770e462b 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupLabel.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupLabel.cs @@ -71,10 +71,6 @@ public KryptonRibbonGroupLabel() _textLine1 = "Label"; _textLine2 = string.Empty; _itemSizeCurrent = GroupItemSize.Medium; - ToolTipImageTransparentColor = Color.Empty; - ToolTipTitle = string.Empty; - ToolTipBody = string.Empty; - ToolTipStyle = LabelStyle.SuperTip; // Create delegate fired by a change to one of the state palettes _needPaintDelegate = OnPaletteNeedPaint; @@ -269,54 +265,10 @@ public bool Enabled private bool ShouldSerializeStateDisabled() => !_stateDisabled.IsDefault; /// - /// Gets and sets the tooltip label style for group label. + /// Gets access to the Wrapped Controls Tooltips. /// - [Category("Appearance")] - [Description("Tooltip style for the group label.")] - [DefaultValue(typeof(LabelStyle), "SuperTip")] - public LabelStyle ToolTipStyle { get; set; } - - /// - /// Gets and sets the image for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Display image associated ToolTip.")] - [DefaultValue(null)] - [Localizable(true)] - public Image ToolTipImage { get; set; } - - /// - /// Gets and sets the color to draw as transparent in the ToolTipImage. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Color to draw as transparent in the ToolTipImage.")] - [KryptonDefaultColor()] - [Localizable(true)] - public Color ToolTipImageTransparentColor { get; set; } - - /// - /// Gets and sets the title text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Title text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor,", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipTitle { get; set; } + public override ToolTipValues ToolTipValues => _toolTipValues; - /// - /// Gets and sets the body text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Body text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipBody { get; set; } /// /// Gets and sets the associated KryptonCommand. @@ -400,8 +352,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewDrawRibbonGroupLabel(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewDrawRibbonGroupLabel(ribbon, this, needPaint); + } /// /// Internal design time property. @@ -463,16 +418,6 @@ internal void OnDesignTimeContextMenu(MouseEventArgs e) // A label never has any command keys to process false; - internal override LabelStyle InternalToolTipStyle => ToolTipStyle; - - internal override Image InternalToolTipImage => ToolTipImage; - - internal override Color InternalToolTipImageTransparentColor => ToolTipImageTransparentColor; - - internal override string InternalToolTipTitle => ToolTipTitle; - - internal override string InternalToolTipBody => ToolTipBody; - #endregion #region Implementation diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupLines.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupLines.cs index ce0b29ffff..ef78f3afcc 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupLines.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupLines.cs @@ -423,6 +423,11 @@ public override GroupItemSize ItemSizeCurrent } } + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => _toolTipValues; + /// /// Creates an appropriate view element for this item. /// @@ -431,8 +436,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewLayoutRibbonGroupLines(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewLayoutRibbonGroupLines(ribbon, this, needPaint); + } /// /// Gets the collection of ribbon group line items. diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupMaskedTextBox.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupMaskedTextBox.cs index b3cf6dc0a3..1add94b50f 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupMaskedTextBox.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupMaskedTextBox.cs @@ -794,6 +794,11 @@ public KryptonContextMenu KryptonContextMenu set => MaskedTextBox.KryptonContextMenu = value; } + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => MaskedTextBox.ToolTipValues; + /// /// Gets and sets a value indicating if tooltips should be displayed for button specs. /// diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupNumericUpDown.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupNumericUpDown.cs index 6dc866e867..3bf135cf4a 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupNumericUpDown.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupNumericUpDown.cs @@ -122,14 +122,6 @@ public KryptonRibbonGroupNumericUpDown() TabStop = false }; - ToolTipImageTransparentColor = Color.Empty; - - ToolTipTitle = string.Empty; - - ToolTipBody = string.Empty; - - ToolTipStyle = LabelStyle.SuperTip; - // Hook into events to expose via this container NumericUpDown.ValueChanged += OnNumericUpDownValueChanged; NumericUpDown.GotFocus += OnNumericUpDownGotFocus; @@ -164,6 +156,12 @@ protected override void Dispose(bool disposing) #endregion #region Public + + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => NumericUpDown.ToolTipValues; + /// /// Gets access to the owning ribbon control. /// @@ -204,56 +202,6 @@ public void ResetShortcutKeys() ShortcutKeys = Keys.None; } - /// - /// Gets and sets the tooltip label style for group numeric up down button. - /// - [Category("Appearance")] - [Description("Tooltip style for the group numeric up down button.")] - [DefaultValue(typeof(LabelStyle), "SuperTip")] - public LabelStyle ToolTipStyle { get; set; } - - /// - /// Gets and sets the image for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Display image associated ToolTip.")] - [DefaultValue(null)] - [Localizable(true)] - public Image ToolTipImage { get; set; } - - /// - /// Gets and sets the numeric up down to draw as transparent in the ToolTipImage. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Color to draw as transparent in the ToolTipImage.")] - [KryptonDefaultColor()] - [Localizable(true)] - public Color ToolTipImageTransparentColor { get; set; } - - /// - /// Gets and sets the title text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Title text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipTitle { get; set; } - - /// - /// Gets and sets the body text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Body text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipBody { get; set; } - /// /// Access to the actual embedded KryptonNumericUpDown instance. /// @@ -761,15 +709,6 @@ internal override bool ProcessCmdKey(ref Message msg, Keys keyData) return false; } - internal override LabelStyle InternalToolTipStyle => ToolTipStyle; - - internal override Image InternalToolTipImage => ToolTipImage; - - internal override Color InternalToolTipImageTransparentColor => ToolTipImageTransparentColor; - - internal override string InternalToolTipTitle => ToolTipTitle; - - internal override string InternalToolTipBody => ToolTipBody; #endregion #region Implementation diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupRadioButton.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupRadioButton.cs index 39fc9adcf1..48dea4807c 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupRadioButton.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupRadioButton.cs @@ -88,10 +88,6 @@ public KryptonRibbonGroupRadioButton() _itemSizeMax = GroupItemSize.Large; _itemSizeMin = GroupItemSize.Small; _itemSizeCurrent = GroupItemSize.Large; - ToolTipImageTransparentColor = Color.Empty; - ToolTipTitle = string.Empty; - ToolTipBody = string.Empty; - ToolTipStyle = LabelStyle.SuperTip; } #endregion @@ -155,7 +151,7 @@ public string TextLine2 [Localizable(true)] [Category("Appearance")] [Description("Ribbon group radio button key tip.")] - [DefaultValue("R")] + [DefaultValue(@"R")] public string KeyTip { get => _keyTip; @@ -164,7 +160,7 @@ public string KeyTip { if (string.IsNullOrEmpty(value)) { - value = "R"; + value = @"R"; } _keyTip = value.ToUpper(); @@ -304,54 +300,9 @@ public void ResetShortcutKeys() } /// - /// Gets and sets the tooltip label style for group radio button. + /// Gets access to the Wrapped Controls Tooltips. /// - [Category("Appearance")] - [Description("Tooltip style for the group radio button.")] - [DefaultValue(typeof(LabelStyle), "SuperTip")] - public LabelStyle ToolTipStyle { get; set; } - - /// - /// Gets and sets the image for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Display image associated ToolTip.")] - [DefaultValue(null)] - [Localizable(true)] - public Image ToolTipImage { get; set; } - - /// - /// Gets and sets the color to draw as transparent in the ToolTipImage. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Color to draw as transparent in the ToolTipImage.")] - [KryptonDefaultColor()] - [Localizable(true)] - public Color ToolTipImageTransparentColor { get; set; } - - /// - /// Gets and sets the title text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Title text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipTitle { get; set; } - - /// - /// Gets and sets the body text for the item ToolTip. - /// - [Bindable(true)] - [Category("Appearance")] - [Description("Body text for use in associated ToolTip.")] - [Editor("System.ComponentModel.Design.MultilineStringEditor", typeof(UITypeEditor))] - [DefaultValue("")] - [Localizable(true)] - public string ToolTipBody { get; set; } + public override ToolTipValues ToolTipValues => _toolTipValues; /// /// Gets and sets the maximum allowed size of the item. @@ -421,8 +372,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewDrawRibbonGroupRadioButton(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewDrawRibbonGroupRadioButton(ribbon, this, needPaint); + } /// /// Generates a Click event for a check box. @@ -542,16 +496,6 @@ internal override bool ProcessCmdKey(ref Message msg, Keys keyData) return false; } - internal override LabelStyle InternalToolTipStyle => ToolTipStyle; - - internal override Image InternalToolTipImage => ToolTipImage; - - internal override Color InternalToolTipImageTransparentColor => ToolTipImageTransparentColor; - - internal override string InternalToolTipTitle => ToolTipTitle; - - internal override string InternalToolTipBody => ToolTipBody; - #endregion #region Implementation diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupRichTextBox.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupRichTextBox.cs index 612a73f082..688b7bae02 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupRichTextBox.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupRichTextBox.cs @@ -642,6 +642,11 @@ public bool ShortcutsEnabled set => RichTextBox.ShortcutsEnabled = value; } + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => RichTextBox.ToolTipValues; + /// /// Gets and sets a value indicating if tooltips should be displayed for button specs. /// diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupSeparator.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupSeparator.cs index 38c99ce881..166133a7b9 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupSeparator.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupSeparator.cs @@ -134,6 +134,11 @@ public override GroupItemSize ItemSizeCurrent set { } } + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => _toolTipValues; + /// /// Creates an appropriate view element for this item. /// @@ -142,8 +147,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewDrawRibbonGroupSeparator(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewDrawRibbonGroupSeparator(ribbon, this, needPaint); + } /// /// Internal design time properties. diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTextBox.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTextBox.cs index 08262fd01a..6a022a8741 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTextBox.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTextBox.cs @@ -619,6 +619,11 @@ public AutoCompleteSource AutoCompleteSource set => TextBox.AutoCompleteSource = value; } + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => TextBox.ToolTipValues; + /// /// Gets and sets a value indicating if tooltips should be displayed for button specs. /// diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTrackBar.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTrackBar.cs index f8b03c42b6..b10e6e026f 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTrackBar.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTrackBar.cs @@ -158,6 +158,11 @@ public override KryptonRibbon Ribbon [DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)] public KryptonTrackBar TrackBar { get; private set; } + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => TrackBar.ToolTipValues; + /// /// Gets and sets the key tip for the ribbon group track bar. /// diff --git a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTriple.cs b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTriple.cs index 294f359f40..7998bb3bfa 100644 --- a/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTriple.cs +++ b/Source/Krypton Components/Krypton.Ribbon/Group Contents/KryptonRibbonGroupTriple.cs @@ -441,6 +441,11 @@ public override GroupItemSize ItemSizeCurrent } } + /// + /// Gets access to the Wrapped Controls Tooltips. + /// + public override ToolTipValues ToolTipValues => _toolTipValues; + /// /// Creates an appropriate view element for this item. /// @@ -449,8 +454,11 @@ public override GroupItemSize ItemSizeCurrent /// ViewBase derived instance. [EditorBrowsable(EditorBrowsableState.Never)] public override ViewBase CreateView(KryptonRibbon ribbon, - NeedPaintHandler needPaint) => - new ViewLayoutRibbonGroupTriple(ribbon, this, needPaint); + NeedPaintHandler needPaint) + { + _toolTipValues.NeedPaint = needPaint; + return new ViewLayoutRibbonGroupTriple(ribbon, this, needPaint); + } /// /// Gets the collection of ribbon group triple items. diff --git a/Source/Krypton Components/Krypton.Ribbon/Palette/GroupItemToolTipToContent.cs b/Source/Krypton Components/Krypton.Ribbon/Palette/GroupItemToolTipToContent.cs deleted file mode 100644 index db4ed1c9c4..0000000000 --- a/Source/Krypton Components/Krypton.Ribbon/Palette/GroupItemToolTipToContent.cs +++ /dev/null @@ -1,76 +0,0 @@ -#region BSD License -/* - * - * Original BSD 3-Clause License (https://github.com/ComponentFactory/Krypton/blob/master/LICENSE) - * © Component Factory Pty Ltd, 2006 - 2016, (Version 4.5.0.0) All rights reserved. - * - * New BSD 3-Clause License (https://github.com/Krypton-Suite/Standard-Toolkit/blob/master/LICENSE) - * Modifications by Peter Wagner(aka Wagnerp) & Simon Coghlan(aka Smurf-IV), et al. 2017 - 2022. All rights reserved. - * - */ -#endregion - - -namespace Krypton.Ribbon -{ - /// - /// Map group item tooltip values to content values. - /// - internal class GroupItemToolTipToContent : IContentValues - { - #region Instance Fields - private readonly KryptonRibbonGroupItem _groupItem; - #endregion - - #region Identity - /// - /// Initialize a new instance of the GroupItemToolTipToContent class. - /// - /// Source ribbon group item. - public GroupItemToolTipToContent(KryptonRibbonGroupItem groupItem) - { - Debug.Assert(groupItem != null); - _groupItem = groupItem; - } - #endregion - - #region HasContent - /// - /// Gets a value indicating if the mapping produces any content. - /// - public bool HasContent => (GetImage(PaletteState.Normal) != null) || - !string.IsNullOrEmpty(GetShortText()) || - !string.IsNullOrEmpty(GetLongText()); - - #endregion - - #region IContentValues - /// - /// Gets the content image. - /// - /// The state for which the image is needed. - /// Image value. - public Image GetImage(PaletteState state) => _groupItem.InternalToolTipImage; - - /// - /// Gets the image color that should be transparent. - /// - /// The state for which the image is needed. - /// Color value. - public Color GetImageTransparentColor(PaletteState state) => _groupItem.InternalToolTipImageTransparentColor; - - /// - /// Gets the content short text. - /// - /// String value. - public string GetShortText() => _groupItem.InternalToolTipTitle; - - /// - /// Gets the content long text. - /// - /// String value. - public string GetLongText() => _groupItem.InternalToolTipBody; - - #endregion - } -} diff --git a/Source/Krypton Components/Krypton.Ribbon/View Layout/ViewLayoutRibbonTabsArea.cs b/Source/Krypton Components/Krypton.Ribbon/View Layout/ViewLayoutRibbonTabsArea.cs index 488cb7378f..8eae59588c 100644 --- a/Source/Krypton Components/Krypton.Ribbon/View Layout/ViewLayoutRibbonTabsArea.cs +++ b/Source/Krypton Components/Krypton.Ribbon/View Layout/ViewLayoutRibbonTabsArea.cs @@ -833,136 +833,57 @@ private void OnShowToolTip(object sender, ToolTipEventArgs e) } break; default: - if (e.Target.Parent is ViewDrawRibbonGroupLabel viewElement2) { - // Cast to correct type + // Find the button spec associated with the tooltip request + ButtonSpec buttonSpec = ButtonSpecManager.ButtonSpecFromView(e.Target); - // Create a content that recovers values from a KryptonRibbonGroupItem - GroupItemToolTipToContent groupItemContent = new(viewElement2.GroupLabel); - - // Is there actually anything to show for the tooltip - if (groupItemContent.HasContent) + // If the tooltip is for a button spec + if (buttonSpec != null) { - sourceContent = groupItemContent; + // Are we allowed to show page related tooltips + if (_ribbon.AllowButtonSpecToolTips) + { + // Create a helper object to provide tooltip values + ButtonSpecToContent buttonSpecMapping = new(_ribbon.GetRedirector(), buttonSpec); + + // Is there actually anything to show for the tooltip + if (buttonSpecMapping.HasContent) + { + sourceContent = buttonSpecMapping; - // Grab the style from the group label settings - toolTipStyle = viewElement2.GroupLabel.ToolTipStyle; + // Grab the style from the button spec settings + toolTipStyle = buttonSpec.ToolTipStyle; - // Display below the bottom of the ribbon control - Rectangle ribbonScreenRect = _ribbon.ToolTipScreenRectangle; - screenRect.Y = ribbonScreenRect.Y; - screenRect.Height = ribbonScreenRect.Height; - screenRect.X = ribbonScreenRect.X + viewElement2.ClientLocation.X; - screenRect.Width = viewElement2.ClientWidth; + // Display below the mouse cursor + screenRect.Height += SystemInformation.CursorSize.Height / 3 * 2; + } + } } - } - else - { - switch (e.Target) + else { - case ViewDrawRibbonGroupButtonBackBorder viewElement3: - { - // Is the target is a button or cluster button - // Cast to correct type - - // Create a content that recovers values from a KryptonRibbonGroupItem - GroupItemToolTipToContent groupItemContent = new(viewElement3.GroupItem); - - // Is there actually anything to show for the tooltip - if (groupItemContent.HasContent) - { - sourceContent = groupItemContent; - - // Grab the style from the group button/group cluster button settings - toolTipStyle = viewElement3.GroupItem.InternalToolTipStyle; - - // Display below the bottom of the ribbon control - Rectangle ribbonScreenRect = _ribbon.ToolTipScreenRectangle; - screenRect.Y = ribbonScreenRect.Y; - screenRect.Height = ribbonScreenRect.Height; - screenRect.X = ribbonScreenRect.X + viewElement3.ClientLocation.X; - screenRect.Width = viewElement3.ClientWidth; - } - break; - } - case ViewLayoutRibbonCheckBox _: - { - // Cast to correct type - ViewDrawRibbonGroupCheckBox viewElement = (ViewDrawRibbonGroupCheckBox)e.Target.Parent; - - // Create a content that recovers values from a KryptonRibbonGroupItem - GroupItemToolTipToContent groupItemContent = new(viewElement.GroupCheckBox); - - // Is there actually anything to show for the tooltip - if (groupItemContent.HasContent) - { - sourceContent = groupItemContent; - - // Grab the style from the group check box cluster button settings - toolTipStyle = viewElement.GroupCheckBox.InternalToolTipStyle; - - // Display below the bottom of the ribbon control - Rectangle ribbonScreenRect = _ribbon.ToolTipScreenRectangle; - screenRect.Y = ribbonScreenRect.Y; - screenRect.Height = ribbonScreenRect.Height; - screenRect.X = ribbonScreenRect.X + viewElement.ClientLocation.X; - screenRect.Width = viewElement.ClientWidth; - } - break; - } - case ViewLayoutRibbonRadioButton _: - { - // Cast to correct type - ViewDrawRibbonGroupRadioButton viewElement = (ViewDrawRibbonGroupRadioButton)e.Target.Parent; - - // Create a content that recovers values from a KryptonRibbonGroupItem - GroupItemToolTipToContent groupItemContent = new(viewElement.GroupRadioButton); - - // Is there actually anything to show for the tooltip - if (groupItemContent.HasContent) - { - sourceContent = groupItemContent; - - // Grab the style from the group radio button button settings - toolTipStyle = viewElement.GroupRadioButton.InternalToolTipStyle; - - // Display below the bottom of the ribbon control - Rectangle ribbonScreenRect = _ribbon.ToolTipScreenRectangle; - screenRect.Y = ribbonScreenRect.Y; - screenRect.Height = ribbonScreenRect.Height; - screenRect.X = ribbonScreenRect.X + viewElement.ClientLocation.X; - screenRect.Width = viewElement.ClientWidth; - } - break; - } - default: - // Find the button spec associated with the tooltip request - ButtonSpec buttonSpec = ButtonSpecManager.ButtonSpecFromView(e.Target); + // Cast to correct type + if (e.Target.Parent is { Component: IRibbonGroupItem groupItem }) + { - // If the tooltip is for a button spec - if (buttonSpec != null) + // Is there actually anything to show for the tooltip + if (groupItem.ToolTipValues.EnableToolTips) { - // Are we allowed to show page related tooltips - if (_ribbon.AllowButtonSpecToolTips) - { - // Create a helper object to provide tooltip values - ButtonSpecToContent buttonSpecMapping = new(_ribbon.GetRedirector(), buttonSpec); - - // Is there actually anything to show for the tooltip - if (buttonSpecMapping.HasContent) - { - sourceContent = buttonSpecMapping; - - // Grab the style from the button spec settings - toolTipStyle = buttonSpec.ToolTipStyle; - - // Display below the mouse cursor - screenRect.Height += SystemInformation.CursorSize.Height / 3 * 2; - } - } + sourceContent = groupItem.ToolTipValues; + + // Grab the style from the group radio button button settings + toolTipStyle = groupItem.ToolTipValues.ToolTipStyle; + + // Display below the bottom of the ribbon control + Rectangle ribbonScreenRect = _ribbon.ToolTipScreenRectangle; + screenRect.Y = ribbonScreenRect.Y; + screenRect.Height = ribbonScreenRect.Height; + screenRect.X = ribbonScreenRect.X + e.Target.Parent.ClientLocation.X; + screenRect.Width = e.Target.Parent.ClientWidth; } - break; + + } } + } break; }