-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathOptionSelectorExtensions.cs
More file actions
81 lines (75 loc) · 3.69 KB
/
Copy pathOptionSelectorExtensions.cs
File metadata and controls
81 lines (75 loc) · 3.69 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
using Terminal.Gui.App;
using Terminal.Gui.ViewBase;
using Terminal.Gui.Views;
namespace TerminalGui.Extensions.Extensions.ViewExtensions;
/// <summary>
/// Extension methods for <see cref="OptionSelector" /> and <see cref="OptionSelector{TEnum}" />.
/// </summary>
public static class OptionSelectorExtensions
{
extension(OptionSelector optionSelector)
{
/// <summary>
/// Subscribes to the <see cref="SelectorBase.ValueChanged" /> event.
/// </summary>
/// <param name="callback">
/// The callback to invoke with the <see cref="ValueChangedEventArgs{T}" /> containing old and new
/// values.
/// </param>
/// <returns>The <see cref="OptionSelector" /> instance.</returns>
public OptionSelector OnValueChanged(Action<ValueChangedEventArgs<int?>> callback)
{
optionSelector.ValueChanged += (_, e) => callback(e);
return optionSelector;
}
/// <summary>
/// Subscribes to the <see cref="SelectorBase.ValueChanging" /> event.
/// Set <see cref="ValueChangingEventArgs{T}.Handled" /> to <see langword="true" /> in the callback to cancel the
/// change.
/// </summary>
/// <param name="callback">
/// The callback to invoke with the <see cref="ValueChangingEventArgs{T}" /> containing current and
/// proposed values.
/// </param>
/// <returns>The <see cref="OptionSelector" /> instance.</returns>
public OptionSelector OnValueChanging(Action<ValueChangingEventArgs<int?>> callback)
{
optionSelector.ValueChanging += (_, e) => callback(e);
return optionSelector;
}
/// <summary>
/// Subscribes to the <see cref="SelectorBase.OrientationChanged" /> event.
/// </summary>
/// <param name="callback">The callback to invoke with the <see cref="EventArgs{T}" /> containing the new <see cref="Orientation" />.</param>
/// <returns>The <see cref="OptionSelector" /> instance.</returns>
public OptionSelector OnOrientationChanged(Action<EventArgs<Orientation>> callback)
{
optionSelector.OrientationChanged += (_, e) => callback(e);
return optionSelector;
}
/// <summary>
/// Subscribes to the <see cref="SelectorBase.OrientationChanging" /> event.
/// Set <see cref="CancelEventArgs{T}.Cancel" /> to <see langword="true" /> to cancel the change.
/// </summary>
/// <param name="callback">The callback to invoke with the <see cref="CancelEventArgs{T}" /> containing the proposed <see cref="Orientation" />.</param>
/// <returns>The <see cref="OptionSelector" /> instance.</returns>
public OptionSelector OnOrientationChanging(Action<CancelEventArgs<Orientation>> callback)
{
optionSelector.OrientationChanging += (_, e) => callback(e);
return optionSelector;
}
}
extension<TEnum>(OptionSelector<TEnum> optionSelector) where TEnum : struct, Enum
{
/// <summary>
/// Subscribes to the <see cref="OptionSelector{TEnum}.ValueChanged" /> event.
/// </summary>
/// <param name="callback">The callback to invoke with the <see cref="EventArgs{T}" /> containing the new value.</param>
/// <returns>The <see cref="OptionSelector{TEnum}" /> instance.</returns>
public OptionSelector<TEnum> OnValueChanged(Action<EventArgs<TEnum?>> callback)
{
optionSelector.ValueChanged += (_, e) => callback(e);
return optionSelector;
}
}
}