FlagSelectorTEnum.cs 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. using System;
  2. namespace Terminal.Gui.Views;
  3. /// <summary>
  4. /// Provides a user interface for displaying and selecting non-mutually-exclusive flags in a type-safe way.
  5. /// <see cref="FlagSelector"/> provides a non-type-safe version. <c>TFlagsEnum</c> must be a valid enum type with
  6. /// the '[Flags]' attribute.
  7. /// </summary>
  8. public sealed class FlagSelector<TFlagsEnum> : FlagSelector where TFlagsEnum : struct, Enum
  9. {
  10. /// <summary>
  11. /// Initializes a new instance of the <see cref="FlagSelector{TFlagsEnum}"/> class.
  12. /// </summary>
  13. public FlagSelector ()
  14. {
  15. SetValuesAndLabels<TFlagsEnum> ();
  16. }
  17. /// <summary>
  18. /// Gets or sets the value of the selected flags.
  19. /// </summary>
  20. public new TFlagsEnum? Value
  21. {
  22. get => base.Value.HasValue ? (TFlagsEnum)Enum.ToObject (typeof (TFlagsEnum), base.Value.Value) : (TFlagsEnum?)null;
  23. set => base.Value = value.HasValue ? Convert.ToInt32 (value.Value) : (int?)null;
  24. }
  25. /// <summary>
  26. /// Raised when <see cref="Value"/> has changed. Provides the new value as <typeparamref name="TFlagsEnum"/>?.
  27. /// </summary>
  28. public new event EventHandler<EventArgs<TFlagsEnum?>>? ValueChanged;
  29. /// <summary>
  30. /// Called when <see cref="Value"/> has changed. Raises the generic <see cref="ValueChanged"/> event.
  31. /// </summary>
  32. protected override void OnValueChanged (int? value, int? previousValue)
  33. {
  34. base.OnValueChanged (value, previousValue);
  35. TFlagsEnum? newValue = value.HasValue ? (TFlagsEnum)Enum.ToObject (typeof (TFlagsEnum), value.Value) : null;
  36. ValueChanged?.Invoke (this, new EventArgs<TFlagsEnum?> (newValue));
  37. }
  38. }