diff --git a/Documents/Help/Changelog.md b/Documents/Help/Changelog.md
index ccbe1659b..4f0c2820b 100644
--- a/Documents/Help/Changelog.md
+++ b/Documents/Help/Changelog.md
@@ -3,12 +3,15 @@
=======
## 2024-11-xx - Build 2411 - November 2024
+* Implemented [#1204](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1204), Build on `KryptonCommandLinkButtons`
+ - [#1216](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1216), Add support for fonts
+ - [#1217](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1217), Add support for text alignment
* Resolved [#996](https://github.com/Krypton-Suite/Standard-Toolkit/issues/996), DataGridView ComboBox Adding list over and over
* Resolved [#1207](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1207), Microsoft 365 - Black (Dark Mode) Drop button is not visible
* Resolved [#1206](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1206), Remove the Font Size (as it is already covered by the actual font !)
* Resolved [#1197](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1197), `KryptonTaskDialog` Footer Images
* Resolved [#1189](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1189), The Context and Next/Pervious buttons of the `KryptonDockableNavigator` cannot be used
-* Implement [#1187](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1187), Bring over the `KryptonCommandLinkButtons`
+* Implemented [#1187](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1187), Bring over the `KryptonCommandLinkButtons`
* Resolved [#1176](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1176), KryptonProgressBar: small values escape drawing area
* Resolved [#1169](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1169), Button Spec Krypton Context Menu (Canary)
* Implemented [#1166](https://github.com/Krypton-Suite/Standard-Toolkit/issues/1166), Use a struct to contain `KryptonMessageBox` data
diff --git a/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonAlternateCommandLinkButton.cs b/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonAlternateCommandLinkButton.cs
index 60ed3cb06..27863eff7 100644
--- a/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonAlternateCommandLinkButton.cs
+++ b/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonAlternateCommandLinkButton.cs
@@ -2,7 +2,7 @@
/*
*
* 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. 2023 - 2023. All rights reserved.
+ * Modifications by Peter Wagner(aka Wagnerp) & Simon Coghlan(aka Smurf-IV), et al. 2017 - 2023. All rights reserved.
*
*/
#endregion
diff --git a/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonButton.cs b/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonButton.cs
index 526fbcd97..1c8ea3443 100644
--- a/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonButton.cs
+++ b/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonButton.cs
@@ -971,6 +971,7 @@ private void SetCornerRoundingRadius(float? radius)
/// Paints the drop-down arrow.
/// The drop-down arrow graphics.
/// The drop-down rectangle area.
+ /// The color of the drop-down arrow.
private static void PaintArrow(Color? dropDownArrowColor, Graphics graphics, Rectangle rectangle)
{
var midPoint = new Point(Convert.ToInt32(rectangle.Left + rectangle.Width / 2),
diff --git a/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonCommandLinkButton.cs b/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonCommandLinkButton.cs
index d22d78500..e84599891 100644
--- a/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonCommandLinkButton.cs
+++ b/Source/Krypton Components/Krypton.Toolkit/Controls Toolkit/KryptonCommandLinkButton.cs
@@ -2,7 +2,7 @@
/*
*
* 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. 2023 - 2023. All rights reserved.
+ * Modifications by Peter Wagner(aka Wagnerp) & Simon Coghlan(aka Smurf-IV), et al. 2017 - 2023. All rights reserved.
*
*/
#endregion
@@ -75,6 +75,7 @@ public KryptonCommandLinkButton()
// Create content storage
CommandLinkImageValues = new CommandLinkImageValues(NeedPaintDelegate);
+ CommandLinkImageValues.Image = CommandLinkImageResources.Windows_11_CommandLink_Arrow;
CommandLinkTextValues = new CommandLinkTextValues(NeedPaintDelegate);
// Create the palette storage
@@ -182,19 +183,14 @@ public override string Text
set => CommandLinkTextValues.Heading = value;
}
- private bool ShouldSerializeText()
- {
+ private bool ShouldSerializeText() =>
// Never serialize, let the button values serialize instead
- return false;
- }
+ false;
///
/// Resets the Text property to its default value.
///
- public override void ResetText()
- {
- CommandLinkTextValues.ResetText();
- }
+ public override void ResetText() => CommandLinkTextValues.ResetText();
///
/// Gets and sets the visual orientation of the control.
@@ -240,15 +236,9 @@ public ButtonStyle ButtonStyle
}
}
- private bool ShouldSerializeButtonStyle()
- {
- return (ButtonStyle != ButtonStyle.Command);
- }
+ private bool ShouldSerializeButtonStyle() => (ButtonStyle != ButtonStyle.Command);
- private void ResetButtonStyle()
- {
- ButtonStyle = ButtonStyle.Command;
- }
+ private void ResetButtonStyle() => ButtonStyle = ButtonStyle.Command;
///
/// Gets access to the button content.
@@ -266,10 +256,7 @@ private void ResetButtonStyle()
[DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
public CommandLinkImageValues CommandLinkImageValues { get; }
- private bool ShouldSerializeValues()
- {
- return false;
- }
+ private bool ShouldSerializeValues() => false;
///
/// Gets access to the common button appearance that other states can override.
@@ -279,10 +266,7 @@ private bool ShouldSerializeValues()
[DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
public PaletteTripleRedirect StateCommon { get; }
- private bool ShouldSerializeStateCommon()
- {
- return !StateCommon.IsDefault;
- }
+ private bool ShouldSerializeStateCommon() => !StateCommon.IsDefault;
///
/// Gets access to the disabled button appearance entries.
@@ -292,10 +276,7 @@ private bool ShouldSerializeStateCommon()
[DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
public PaletteTriple StateDisabled { get; }
- private bool ShouldSerializeStateDisabled()
- {
- return !StateDisabled.IsDefault;
- }
+ private bool ShouldSerializeStateDisabled() => !StateDisabled.IsDefault;
///
/// Gets access to the normal button appearance entries.
@@ -305,10 +286,7 @@ private bool ShouldSerializeStateDisabled()
[DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
public PaletteTriple StateNormal { get; }
- private bool ShouldSerializeStateNormal()
- {
- return !StateNormal.IsDefault;
- }
+ private bool ShouldSerializeStateNormal() => !StateNormal.IsDefault;
///
/// Gets access to the hot tracking button appearance entries.
@@ -318,10 +296,7 @@ private bool ShouldSerializeStateNormal()
[DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
public PaletteTriple StateTracking { get; }
- private bool ShouldSerializeStateTracking()
- {
- return !StateTracking.IsDefault;
- }
+ private bool ShouldSerializeStateTracking() => !StateTracking.IsDefault;
///
/// Gets access to the pressed button appearance entries.
@@ -331,10 +306,7 @@ private bool ShouldSerializeStateTracking()
[DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
public PaletteTriple StatePressed { get; }
- private bool ShouldSerializeStatePressed()
- {
- return !StatePressed.IsDefault;
- }
+ private bool ShouldSerializeStatePressed() => !StatePressed.IsDefault;
///
/// Gets access to the normal button appearance when default.
@@ -344,10 +316,7 @@ private bool ShouldSerializeStatePressed()
[DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
public PaletteTripleRedirect OverrideDefault { get; }
- private bool ShouldSerializeOverrideDefault()
- {
- return !OverrideDefault.IsDefault;
- }
+ private bool ShouldSerializeOverrideDefault() => !OverrideDefault.IsDefault;
///
/// Gets access to the button appearance when it has focus.
@@ -357,10 +326,7 @@ private bool ShouldSerializeOverrideDefault()
[DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
public PaletteTripleRedirect OverrideFocus { get; }
- private bool ShouldSerializeOverrideFocus()
- {
- return !OverrideFocus.IsDefault;
- }
+ private bool ShouldSerializeOverrideFocus() => !OverrideFocus.IsDefault;
///
/// Gets or sets the value returned to the parent form when the button is clicked.
@@ -469,7 +435,7 @@ public virtual void SetFixedState(PaletteState state)
{
if (state == PaletteState.NormalDefaultOverride)
{
- // Setup the overrides correctly to match state
+ // Set up the overrides correctly to match state
_overrideFocus.Apply = true;
_overrideNormal.Apply = true;
@@ -499,7 +465,7 @@ public virtual void SetFixedState(PaletteState state)
///
/// Gets the default size of the control.
///
- protected override Size DefaultSize => new Size(287, 61);
+ protected override Size DefaultSize => new Size(319, 61);
///
/// Gets the default Input Method Editor (IME) mode supported by this control.
@@ -618,11 +584,30 @@ protected override void ContextMenuClosed()
///
protected override void OnPaint(PaintEventArgs? e)
{
- //if (CommandLinkImageValues.ShowUACShield)
- //{
- // SendMessage(new HandleRef(this, Handle), BCM_SETSHIELD, IntPtr.Zero,
- // CommandLinkImageValues.ShowUACShield);
- //}
+ StateCommon.Content.LongText.Font = CommandLinkTextValues.DescriptionFont != null
+ ? CommandLinkTextValues.DescriptionFont
+ : null;
+
+ StateCommon.Content.ShortText.Font =
+ CommandLinkTextValues.HeadingFont != null
+ ? CommandLinkTextValues.HeadingFont
+ : null;
+
+ StateCommon.Content.LongText.TextH = CommandLinkTextValues.DescriptionTextHAlignment != null
+ ? CommandLinkTextValues.DescriptionTextHAlignment ?? PaletteRelativeAlign.Near
+ : PaletteRelativeAlign.Near;
+
+ StateCommon.Content.LongText.TextV = CommandLinkTextValues.DescriptionTextVAlignment != null
+ ? CommandLinkTextValues.DescriptionTextVAlignment ?? PaletteRelativeAlign.Far
+ : PaletteRelativeAlign.Far;
+
+ StateCommon.Content.ShortText.TextH = CommandLinkTextValues.HeadingTextHAlignment != null
+ ? CommandLinkTextValues.HeadingTextHAlignment ?? PaletteRelativeAlign.Near
+ : PaletteRelativeAlign.Near;
+
+ StateCommon.Content.ShortText.TextV = CommandLinkTextValues.HeadingTextVAlignment != null
+ ? CommandLinkTextValues.HeadingTextVAlignment ?? PaletteRelativeAlign.Center
+ : PaletteRelativeAlign.Center;
base.OnPaint(e);
}
diff --git a/Source/Krypton Components/Krypton.Toolkit/Global/GlobalDeclarations.cs b/Source/Krypton Components/Krypton.Toolkit/Global/GlobalDeclarations.cs
index 2b69b7d55..5afe795c8 100644
--- a/Source/Krypton Components/Krypton.Toolkit/Global/GlobalDeclarations.cs
+++ b/Source/Krypton Components/Krypton.Toolkit/Global/GlobalDeclarations.cs
@@ -48,6 +48,7 @@
global using Krypton.Toolkit.ResourceFiles.Arrows;
global using Krypton.Toolkit.ResourceFiles.ButtonSpecs;
global using Krypton.Toolkit.ResourceFiles.CheckBoxes;
+global using Krypton.Toolkit.ResourceFiles.CommandLink;
global using Krypton.Toolkit.ResourceFiles.ControlBox;
global using Krypton.Toolkit.ResourceFiles.Dialogs;
global using Krypton.Toolkit.ResourceFiles.DropDown;
diff --git a/Source/Krypton Components/Krypton.Toolkit/Krypton.Toolkit 2022.csproj b/Source/Krypton Components/Krypton.Toolkit/Krypton.Toolkit 2022.csproj
index 408e28c06..a87a10b5e 100644
--- a/Source/Krypton Components/Krypton.Toolkit/Krypton.Toolkit 2022.csproj
+++ b/Source/Krypton Components/Krypton.Toolkit/Krypton.Toolkit 2022.csproj
@@ -204,6 +204,11 @@
True
ColourScaleImageResources.resx
+
+ True
+ True
+ CommandLinkImageResources.resx
+
True
True
@@ -633,6 +638,10 @@
ResXFileCodeGenerator
ColourScaleImageResources.Designer.cs
+
+ ResXFileCodeGenerator
+ CommandLinkImageResources.Designer.cs
+
ResXFileCodeGenerator
Microsoft365ControlBoxResources.Designer.cs
diff --git a/Source/Krypton Components/Krypton.Toolkit/Palette Base/PaletteContent/PaletteContentText.cs b/Source/Krypton Components/Krypton.Toolkit/Palette Base/PaletteContent/PaletteContentText.cs
index e351fa045..ce65988fb 100644
--- a/Source/Krypton Components/Krypton.Toolkit/Palette Base/PaletteContent/PaletteContentText.cs
+++ b/Source/Krypton Components/Krypton.Toolkit/Palette Base/PaletteContent/PaletteContentText.cs
@@ -273,7 +273,7 @@ public virtual PaletteTextHotkeyPrefix Prefix
}
}
#endregion
-
+
#region TextH
///
/// Gets the horizontal relative alignment of the text.
diff --git a/Source/Krypton Components/Krypton.Toolkit/ResourceFiles/CommandLink/CommandLinkImageResources.Designer.cs b/Source/Krypton Components/Krypton.Toolkit/ResourceFiles/CommandLink/CommandLinkImageResources.Designer.cs
new file mode 100644
index 000000000..6ab65a537
--- /dev/null
+++ b/Source/Krypton Components/Krypton.Toolkit/ResourceFiles/CommandLink/CommandLinkImageResources.Designer.cs
@@ -0,0 +1,83 @@
+//------------------------------------------------------------------------------
+//
+// This code was generated by a tool.
+// Runtime Version:4.0.30319.42000
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//
+//------------------------------------------------------------------------------
+
+namespace Krypton.Toolkit.ResourceFiles.CommandLink {
+ using System;
+
+
+ ///
+ /// A strongly-typed resource class, for looking up localized strings, etc.
+ ///
+ // This class was auto-generated by the StronglyTypedResourceBuilder
+ // class via a tool like ResGen or Visual Studio.
+ // To add or remove a member, edit your .ResX file then rerun ResGen
+ // with the /str option, or rebuild your VS project.
+ [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "17.0.0.0")]
+ [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
+ [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()]
+ internal class CommandLinkImageResources {
+
+ private static global::System.Resources.ResourceManager resourceMan;
+
+ private static global::System.Globalization.CultureInfo resourceCulture;
+
+ [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")]
+ internal CommandLinkImageResources() {
+ }
+
+ ///
+ /// Returns the cached ResourceManager instance used by this class.
+ ///
+ [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)]
+ internal static global::System.Resources.ResourceManager ResourceManager {
+ get {
+ if (object.ReferenceEquals(resourceMan, null)) {
+ global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("Krypton.Toolkit.ResourceFiles.CommandLink.CommandLinkImageResources", typeof(CommandLinkImageResources).Assembly);
+ resourceMan = temp;
+ }
+ return resourceMan;
+ }
+ }
+
+ ///
+ /// Overrides the current thread's CurrentUICulture property for all
+ /// resource lookups using this strongly typed resource class.
+ ///
+ [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)]
+ internal static global::System.Globalization.CultureInfo Culture {
+ get {
+ return resourceCulture;
+ }
+ set {
+ resourceCulture = value;
+ }
+ }
+
+ ///
+ /// Looks up a localized resource of type System.Drawing.Bitmap.
+ ///
+ internal static System.Drawing.Bitmap Windows_10_CommandLink_Arrow {
+ get {
+ object obj = ResourceManager.GetObject("Windows_10_CommandLink_Arrow", resourceCulture);
+ return ((System.Drawing.Bitmap)(obj));
+ }
+ }
+
+ ///
+ /// Looks up a localized resource of type System.Drawing.Bitmap.
+ ///
+ internal static System.Drawing.Bitmap Windows_11_CommandLink_Arrow {
+ get {
+ object obj = ResourceManager.GetObject("Windows_11_CommandLink_Arrow", resourceCulture);
+ return ((System.Drawing.Bitmap)(obj));
+ }
+ }
+ }
+}
diff --git a/Source/Krypton Components/Krypton.Toolkit/ResourceFiles/CommandLink/CommandLinkImageResources.resx b/Source/Krypton Components/Krypton.Toolkit/ResourceFiles/CommandLink/CommandLinkImageResources.resx
new file mode 100644
index 000000000..3530f23ae
--- /dev/null
+++ b/Source/Krypton Components/Krypton.Toolkit/ResourceFiles/CommandLink/CommandLinkImageResources.resx
@@ -0,0 +1,127 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ text/microsoft-resx
+
+
+ 2.0
+
+
+ System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
+
+
+ System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
+
+
+
+ ..\..\Resources\Windows 10 CommandLink Arrow.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a
+
+
+ ..\..\Resources\Windows 11 CommandLink Arrow.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a
+
+
\ No newline at end of file
diff --git a/Source/Krypton Components/Krypton.Toolkit/Resources/Windows 10 CommandLink Arrow.png b/Source/Krypton Components/Krypton.Toolkit/Resources/Windows 10 CommandLink Arrow.png
new file mode 100644
index 000000000..8c850f59d
Binary files /dev/null and b/Source/Krypton Components/Krypton.Toolkit/Resources/Windows 10 CommandLink Arrow.png differ
diff --git a/Source/Krypton Components/Krypton.Toolkit/Resources/Windows 11 CommandLink Arrow.png b/Source/Krypton Components/Krypton.Toolkit/Resources/Windows 11 CommandLink Arrow.png
new file mode 100644
index 000000000..f90e44ca0
Binary files /dev/null and b/Source/Krypton Components/Krypton.Toolkit/Resources/Windows 11 CommandLink Arrow.png differ
diff --git a/Source/Krypton Components/Krypton.Toolkit/Values/CaptionValues.cs b/Source/Krypton Components/Krypton.Toolkit/Values/CaptionValues.cs
index 5f1fa05b0..3e743d18c 100644
--- a/Source/Krypton Components/Krypton.Toolkit/Values/CaptionValues.cs
+++ b/Source/Krypton Components/Krypton.Toolkit/Values/CaptionValues.cs
@@ -63,6 +63,7 @@ public override string Description
get => base.Description;
set => base.Description = value;
}
+
#endregion
}
}
diff --git a/Source/Krypton Components/Krypton.Toolkit/Values/CommandLinkImageValues.cs b/Source/Krypton Components/Krypton.Toolkit/Values/CommandLinkImageValues.cs
index 39600a039..1be1cefcb 100644
--- a/Source/Krypton Components/Krypton.Toolkit/Values/CommandLinkImageValues.cs
+++ b/Source/Krypton Components/Krypton.Toolkit/Values/CommandLinkImageValues.cs
@@ -15,6 +15,10 @@ public class CommandLinkImageValues : Storage, IContentValues
private static readonly Image DEFAULT_IMAGE = MessageBoxImageResources.GenericQuestion;
+ private static readonly Image DEFAULT_WINDOWS_11_IMAGE = CommandLinkImageResources.Windows_11_CommandLink_Arrow;
+
+ private static readonly Image DEFAULT_WINDOWS_10_IMAGE = CommandLinkImageResources.Windows_10_CommandLink_Arrow;
+
#endregion
#region Instance Fields
@@ -31,6 +35,7 @@ public class CommandLinkImageValues : Storage, IContentValues
#region Public
+ [DefaultValue(false)]
public bool DisplayUACShield
{
get => _displayUACShield;
@@ -101,6 +106,7 @@ public Color ImageTransparentColor
[Category("Visuals")]
[Description("The image.")]
[RefreshProperties(RefreshProperties.All)]
+ //[DefaultValue()]
public Image? Image
{
get => _image;
@@ -115,9 +121,29 @@ public Image? Image
}
- private bool ShouldSerializeImage() => Image != DEFAULT_IMAGE;
+ private bool ShouldSerializeImage() => Image != DEFAULT_WINDOWS_11_IMAGE;
- public void ResetImage() => Image = DEFAULT_IMAGE;
+ public void ResetImage()
+ {
+ //if (OSUtilities.IsWindowsEleven)
+ //{
+ // Image = DEFAULT_WINDOWS_11_IMAGE;
+ //}
+ //else if (OSUtilities.IsWindowsTen)
+ //{
+ // Image = DEFAULT_WINDOWS_10_IMAGE;
+ //}
+ //else if (OSUtilities.IsWindowsEightPointOne || OSUtilities.IsWindowsEight || OSUtilities.IsWindowsSeven)
+ //{
+
+ //}
+ //else
+ //{
+ // Image = DEFAULT_IMAGE;
+ //}
+
+ Image = DEFAULT_WINDOWS_11_IMAGE;
+ }
[DefaultValue(UACShieldIconSize.Small), Description(@"")]
public UACShieldIconSize UACShieldIconSize
diff --git a/Source/Krypton Components/Krypton.Toolkit/Values/CommandLinkTextValues.cs b/Source/Krypton Components/Krypton.Toolkit/Values/CommandLinkTextValues.cs
index 0fc04cab8..f79ff9450 100644
--- a/Source/Krypton Components/Krypton.Toolkit/Values/CommandLinkTextValues.cs
+++ b/Source/Krypton Components/Krypton.Toolkit/Values/CommandLinkTextValues.cs
@@ -7,6 +7,7 @@
*/
#endregion
+// ReSharper disable PossibleUnintendedReferenceComparison
namespace Krypton.Toolkit
{
public class CommandLinkTextValues : CaptionValues
@@ -19,12 +20,39 @@ public class CommandLinkTextValues : CaptionValues
#endregion
+ #region Instance Fields
+
+ private Font? _descriptionFont;
+
+ private Font? _headingFont;
+
+ private PaletteRelativeAlign? _descriptionTextHAlignment;
+
+ private PaletteRelativeAlign? _descriptionTextVAlignment;
+
+ private PaletteRelativeAlign? _headingTextHAlignment;
+
+ private PaletteRelativeAlign? _headingTextVAlignment;
+
+ #endregion
+
#region Identity
/// Initializes a new instance of the class.
/// Delegate for notifying paint requests.
public CommandLinkTextValues(NeedPaintHandler needPaint) : base(needPaint)
{
+ _descriptionFont = null;
+
+ _headingFont = null;
+
+ _descriptionTextHAlignment = PaletteRelativeAlign.Near;
+
+ _descriptionTextVAlignment = PaletteRelativeAlign.Far;
+
+ _headingTextHAlignment = PaletteRelativeAlign.Near;
+
+ _headingTextVAlignment = PaletteRelativeAlign.Center;
}
#endregion
@@ -42,6 +70,8 @@ public CommandLinkTextValues(NeedPaintHandler needPaint) : base(needPaint)
#region Implementation
///
+ [Category(@"CommandLink")]
+ [Description(@"The description text for the command link button.")]
[DefaultValue(DEFAULT_DESCRIPTION)]
public override string Description { get => base.Description; set => base.Description = value; }
@@ -51,6 +81,131 @@ public void ResetText()
Heading = DEFAULT_HEADING;
Description = DEFAULT_DESCRIPTION;
+
+ DescriptionFont = _descriptionFont;
+
+ HeadingFont = _headingFont;
+ }
+
+ /// Gets or sets the description font.
+ /// The description font.
+ [Category(@"CommandLink")]
+ [Description(@"The description text font for the command link button.")]
+
+ [DefaultValue(null)]
+ public Font? DescriptionFont
+ {
+ get => _descriptionFont;
+
+ set
+ {
+ if (_descriptionFont != value)
+ {
+ _descriptionFont = value;
+
+ PerformNeedPaint(true);
+ }
+ }
+ }
+
+ /// Gets or sets the heading font.
+ /// The heading font.
+ [Category(@"CommandLink")]
+ [Description(@"The heading text font for the command link button.")]
+ [DefaultValue(null)]
+ public Font? HeadingFont
+ {
+ get => _headingFont;
+
+ set
+ {
+ if (_headingFont != value)
+ {
+ _headingFont = value;
+
+ PerformNeedPaint(true);
+ }
+ }
+ }
+
+ /// Gets or sets the description text horizontal alignment.
+ /// The description text horizontal alignment.
+ [Category(@"CommandLink")]
+ [Description(@"The description text horizontal alignment for the command link button.")]
+ [DefaultValue(null)]
+ public PaletteRelativeAlign? DescriptionTextHAlignment
+ {
+ get => _descriptionTextHAlignment;
+
+ set
+ {
+ if (_descriptionTextHAlignment != value)
+ {
+ _descriptionTextHAlignment = value;
+
+ PerformNeedPaint(true);
+ }
+ }
+ }
+
+ /// Gets or sets the description text vertical alignment.
+ /// The description text vertical alignment.
+ [Category(@"CommandLink")]
+ [Description(@"The description text verticl alignment for the command link button.")]
+ [DefaultValue(null)]
+ public PaletteRelativeAlign? DescriptionTextVAlignment
+ {
+ get => _descriptionTextVAlignment;
+
+ set
+ {
+ if (_descriptionTextVAlignment != value)
+ {
+ _descriptionTextVAlignment = value;
+
+ PerformNeedPaint(true);
+ }
+ }
+ }
+
+ /// Gets or sets the heading text horizontal alignment.
+ /// The heading text horizontal alignment.
+ [Category(@"CommandLink")]
+ [Description(@"The heading text horizontal alignment for the command link button.")]
+ [DefaultValue(null)]
+ public PaletteRelativeAlign? HeadingTextHAlignment
+ {
+ get => _headingTextHAlignment;
+
+ set
+ {
+ if (_headingTextHAlignment != value)
+ {
+ _headingTextHAlignment = value;
+
+ PerformNeedPaint(true);
+ }
+ }
+ }
+
+ /// Gets or sets the heading text vertical alignment.
+ /// The heading text vertical alignment.
+ [Category(@"CommandLink")]
+ [Description(@"The heading text vertical alignment for the command link button.")]
+ [DefaultValue(null)]
+ public PaletteRelativeAlign? HeadingTextVAlignment
+ {
+ get => _headingTextVAlignment;
+
+ set
+ {
+ if (_headingTextVAlignment != value)
+ {
+ _headingTextVAlignment = value;
+
+ PerformNeedPaint(true);
+ }
+ }
}
#endregion
diff --git a/Source/Krypton Components/Krypton.Toolkit/Values/HeaderValuesBase.cs b/Source/Krypton Components/Krypton.Toolkit/Values/HeaderValuesBase.cs
index 25e3e7e80..5e4756502 100644
--- a/Source/Krypton Components/Krypton.Toolkit/Values/HeaderValuesBase.cs
+++ b/Source/Krypton Components/Krypton.Toolkit/Values/HeaderValuesBase.cs
@@ -19,7 +19,9 @@ public abstract class HeaderValuesBase : Storage,
IContentValues
{
#region Static Fields
+
private static readonly Image _defaultImage = GenericImageResources.KryptonLogoGeneric;
+
#endregion
#region Instance Fields
@@ -35,7 +37,7 @@ public abstract class HeaderValuesBase : Storage,
///
public event EventHandler? TextChanged;
#endregion
-
+
#region Identity
///
/// Initialize a new instance of the HeaderValuesBase class.
@@ -45,7 +47,7 @@ protected HeaderValuesBase(NeedPaintHandler? needPaint)
{
// Store the provided paint notification delegate
NeedPaint = needPaint;
-
+
// Set initial values to the default
_image = GetImageDefault();
_transparent = Color.Empty;
@@ -67,6 +69,7 @@ protected HeaderValuesBase(NeedPaintHandler? needPaint)
#endregion
#region Default Values
+
///
/// Gets the default image value.
///
@@ -162,7 +165,7 @@ public Color ImageTransparentColor
public virtual Color GetImageTransparentColor(PaletteState state) => ImageTransparentColor;
#endregion
-
+
#region Heading
///
/// Gets and sets the heading text.
diff --git a/Source/Krypton Components/TestForm/Form7.Designer.cs b/Source/Krypton Components/TestForm/Form7.Designer.cs
index 601d117bd..081a28a52 100644
--- a/Source/Krypton Components/TestForm/Form7.Designer.cs
+++ b/Source/Krypton Components/TestForm/Form7.Designer.cs
@@ -57,8 +57,6 @@ private void InitializeComponent()
// kryptonCommandLinkButton5
//
this.kryptonCommandLinkButton5.ButtonStyle = Krypton.Toolkit.ButtonStyle.Standalone;
- this.kryptonCommandLinkButton5.CommandLinkImageValues.DisplayUACShield = false;
- this.kryptonCommandLinkButton5.CommandLinkImageValues.Image = null;
this.kryptonCommandLinkButton5.CommandLinkTextValues.Description = "What happens when the text is really long, \r\nand wants to go off the edge?\r\nThen " +
"Use a Multi-line ;-)\r\n";
this.kryptonCommandLinkButton5.CommandLinkTextValues.Heading = "&Control the World";
@@ -86,7 +84,6 @@ private void InitializeComponent()
this.kryptonCommandLinkButton5.StateCommon.Content.LongText.TextH = Krypton.Toolkit.PaletteRelativeAlign.Near;
this.kryptonCommandLinkButton5.StateCommon.Content.LongText.TextV = Krypton.Toolkit.PaletteRelativeAlign.Far;
this.kryptonCommandLinkButton5.StateCommon.Content.LongText.Trim = Krypton.Toolkit.PaletteTextTrim.Word;
- this.kryptonCommandLinkButton5.StateCommon.Content.ShortText.Font = new System.Drawing.Font("Segoe UI", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
this.kryptonCommandLinkButton5.StateCommon.Content.ShortText.TextH = Krypton.Toolkit.PaletteRelativeAlign.Near;
this.kryptonCommandLinkButton5.StateCommon.Content.ShortText.TextV = Krypton.Toolkit.PaletteRelativeAlign.Center;
this.kryptonCommandLinkButton5.TabIndex = 5;
@@ -94,7 +91,6 @@ private void InitializeComponent()
// kryptonCommandLinkButton4
//
this.kryptonCommandLinkButton4.ButtonStyle = Krypton.Toolkit.ButtonStyle.NavigatorMini;
- this.kryptonCommandLinkButton4.CommandLinkImageValues.DisplayUACShield = false;
this.kryptonCommandLinkButton4.CommandLinkImageValues.Image = ((System.Drawing.Image)(resources.GetObject("kryptonCommandLinkButton4.CommandLinkImageValues.Image")));
this.kryptonCommandLinkButton4.CommandLinkTextValues.Description = " Demo the Shortcut display and rounded borders";
this.kryptonCommandLinkButton4.CommandLinkTextValues.Heading = "&Disabled Navigator Mini style";
@@ -116,7 +112,6 @@ private void InitializeComponent()
this.kryptonCommandLinkButton4.StateCommon.Border.Width = 2;
this.kryptonCommandLinkButton4.StateCommon.Content.LongText.TextH = Krypton.Toolkit.PaletteRelativeAlign.Near;
this.kryptonCommandLinkButton4.StateCommon.Content.LongText.TextV = Krypton.Toolkit.PaletteRelativeAlign.Far;
- this.kryptonCommandLinkButton4.StateCommon.Content.ShortText.Font = new System.Drawing.Font("Segoe UI", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
this.kryptonCommandLinkButton4.StateCommon.Content.ShortText.TextH = Krypton.Toolkit.PaletteRelativeAlign.Near;
this.kryptonCommandLinkButton4.StateCommon.Content.ShortText.TextV = Krypton.Toolkit.PaletteRelativeAlign.Center;
this.kryptonCommandLinkButton4.TabIndex = 4;
@@ -124,8 +119,6 @@ private void InitializeComponent()
// kryptonCommandLinkButton3
//
this.kryptonCommandLinkButton3.ButtonStyle = Krypton.Toolkit.ButtonStyle.NavigatorMini;
- this.kryptonCommandLinkButton3.CommandLinkImageValues.DisplayUACShield = false;
- this.kryptonCommandLinkButton3.CommandLinkImageValues.Image = null;
this.kryptonCommandLinkButton3.CommandLinkTextValues.Description = " Demo the Shortcut display and rounded borders";
this.kryptonCommandLinkButton3.CommandLinkTextValues.Heading = "&Navigator Mini style";
this.kryptonCommandLinkButton3.Location = new System.Drawing.Point(12, 247);
@@ -145,7 +138,6 @@ private void InitializeComponent()
this.kryptonCommandLinkButton3.StateCommon.Border.Width = 2;
this.kryptonCommandLinkButton3.StateCommon.Content.LongText.TextH = Krypton.Toolkit.PaletteRelativeAlign.Near;
this.kryptonCommandLinkButton3.StateCommon.Content.LongText.TextV = Krypton.Toolkit.PaletteRelativeAlign.Far;
- this.kryptonCommandLinkButton3.StateCommon.Content.ShortText.Font = new System.Drawing.Font("Segoe UI", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
this.kryptonCommandLinkButton3.StateCommon.Content.ShortText.TextH = Krypton.Toolkit.PaletteRelativeAlign.Near;
this.kryptonCommandLinkButton3.StateCommon.Content.ShortText.TextV = Krypton.Toolkit.PaletteRelativeAlign.Center;
this.kryptonCommandLinkButton3.TabIndex = 3;
@@ -153,8 +145,6 @@ private void InitializeComponent()
// kryptonCommandLinkButton2
//
this.kryptonCommandLinkButton2.ButtonStyle = Krypton.Toolkit.ButtonStyle.Standalone;
- this.kryptonCommandLinkButton2.CommandLinkImageValues.DisplayUACShield = false;
- this.kryptonCommandLinkButton2.CommandLinkImageValues.Image = null;
this.kryptonCommandLinkButton2.CommandLinkTextValues.Description = " Here be the extra Text with some spaces";
this.kryptonCommandLinkButton2.CommandLinkTextValues.Heading = "Standalone Style";
this.kryptonCommandLinkButton2.Location = new System.Drawing.Point(12, 180);
@@ -167,7 +157,6 @@ private void InitializeComponent()
this.kryptonCommandLinkButton2.Size = new System.Drawing.Size(341, 61);
this.kryptonCommandLinkButton2.StateCommon.Content.LongText.TextH = Krypton.Toolkit.PaletteRelativeAlign.Near;
this.kryptonCommandLinkButton2.StateCommon.Content.LongText.TextV = Krypton.Toolkit.PaletteRelativeAlign.Far;
- this.kryptonCommandLinkButton2.StateCommon.Content.ShortText.Font = new System.Drawing.Font("Segoe UI", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
this.kryptonCommandLinkButton2.StateCommon.Content.ShortText.TextH = Krypton.Toolkit.PaletteRelativeAlign.Near;
this.kryptonCommandLinkButton2.StateCommon.Content.ShortText.TextV = Krypton.Toolkit.PaletteRelativeAlign.Center;
this.kryptonCommandLinkButton2.TabIndex = 2;
@@ -190,8 +179,6 @@ private void InitializeComponent()
//
// kryptonCommandLinkButton1
//
- this.kryptonCommandLinkButton1.CommandLinkImageValues.DisplayUACShield = false;
- this.kryptonCommandLinkButton1.CommandLinkImageValues.UACShieldIconSize = Krypton.Toolkit.UACShieldIconSize.Small;
this.kryptonCommandLinkButton1.CommandLinkTextValues.Description = "Here be the \"Note Text\"";
this.kryptonCommandLinkButton1.CommandLinkTextValues.Heading = "Default Ext Command Link";
this.kryptonCommandLinkButton1.Location = new System.Drawing.Point(12, 99);
@@ -204,7 +191,6 @@ private void InitializeComponent()
this.kryptonCommandLinkButton1.Size = new System.Drawing.Size(341, 61);
this.kryptonCommandLinkButton1.StateCommon.Content.LongText.TextH = Krypton.Toolkit.PaletteRelativeAlign.Near;
this.kryptonCommandLinkButton1.StateCommon.Content.LongText.TextV = Krypton.Toolkit.PaletteRelativeAlign.Far;
- this.kryptonCommandLinkButton1.StateCommon.Content.ShortText.Font = new System.Drawing.Font("Segoe UI", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
this.kryptonCommandLinkButton1.StateCommon.Content.ShortText.TextH = Krypton.Toolkit.PaletteRelativeAlign.Near;
this.kryptonCommandLinkButton1.StateCommon.Content.ShortText.TextV = Krypton.Toolkit.PaletteRelativeAlign.Center;
this.kryptonCommandLinkButton1.TabIndex = 0;
diff --git a/Source/Krypton Components/TestForm/Form7.resx b/Source/Krypton Components/TestForm/Form7.resx
index 224a170ed..dcaac645d 100644
--- a/Source/Krypton Components/TestForm/Form7.resx
+++ b/Source/Krypton Components/TestForm/Form7.resx
@@ -165,7 +165,7 @@
XTesb3QPLh88M+QwdP6m681Lt7xuXbu94vbgcOjwnZHokdE77DtTd1PuvriXeW/h/sYH6AdFD6UeVjxS
fNTws+7PbaOWo6fHXMf6Hwc/vj/OGn/2S8Yv7ycKnpCfVEyqTDZPmU2dmnafvvF05dOJZ+nPFmYKf5X+
tfa5zvMffnP8rX82YnbiBf/Fp99LXsq/PPRq2aueuYC5R69TXy/MF72Rf3P4LeNt37vwd5MLWe+x7ys/
- 6H7o/ujz8cGn1E+f/gUDmPP8usTo0wAAAAlwSFlzAAALEAAACxABrSO9dQAAA2ZJREFUWEftl+lOU0EU
+ 6H7o/ujz8cGn1E+f/gUDmPP8usTo0wAAAAlwSFlzAAALDAAACwwBP0AiyAAAA2ZJREFUWEftl+lOU0EU
x3kK30JfQF+D730Al0QTWQqlYIMBIVAoCFUsFgHZZAfZkRLQgFIWQYSutKUbhUJpWXOcM8lc59Jb29uE
fvLDLyXnP3Pmz6znZu1durLN0TVD5lk1NG8a72bNRucMrf42qHfXZw5XPTQ49VDQX6igBrSuGvhxNAF9
vhZYOZqEF7YiyLE8h7FAJyyGhuHb4Sh89nfA78gCaJ3lVJNLi6cBpoOfYCE0BM3EhNqsFhv4TgzggEuH
@@ -230,7 +230,7 @@
XTesb3QPLh88M+QwdP6m681Lt7xuXbu94vbgcOjwnZHokdE77DtTd1PuvriXeW/h/sYH6AdFD6UeVjxS
fNTws+7PbaOWo6fHXMf6Hwc/vj/OGn/2S8Yv7ycKnpCfVEyqTDZPmU2dmnafvvF05dOJZ+nPFmYKf5X+
tfa5zvMffnP8rX82YnbiBf/Fp99LXsq/PPRq2aueuYC5R69TXy/MF72Rf3P4LeNt37vwd5MLWe+x7ys/
- 6H7o/ujz8cGn1E+f/gUDmPP8usTo0wAAAAlwSFlzAAALEAAACxABrSO9dQAAA2ZJREFUWEftl+lOU0EU
+ 6H7o/ujz8cGn1E+f/gUDmPP8usTo0wAAAAlwSFlzAAALDAAACwwBP0AiyAAAA2ZJREFUWEftl+lOU0EU
x3kK30JfQF+D730Al0QTWQqlYIMBIVAoCFUsFgHZZAfZkRLQgFIWQYSutKUbhUJpWXOcM8lc59Jb29uE
fvLDLyXnP3Pmz6znZu1durLN0TVD5lk1NG8a72bNRucMrf42qHfXZw5XPTQ49VDQX6igBrSuGvhxNAF9
vhZYOZqEF7YiyLE8h7FAJyyGhuHb4Sh89nfA78gCaJ3lVJNLi6cBpoOfYCE0BM3EhNqsFhv4TgzggEuH