123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- #nullable enable
- namespace Terminal.Gui;
- internal enum VariationMode
- {
- Decrease,
- Increase
- }
- internal class ScrollButton : View
- {
- public ScrollButton ()
- {
- TextAlignment = Alignment.Center;
- VerticalTextAlignment = Alignment.Center;
- Id = "scrollButton";
- //Width = Dim.Auto (DimAutoStyle.Content, 1);
- //Height = Dim.Auto (DimAutoStyle.Content, 1);
- WantContinuousButtonPressed = true;
- }
- private ColorScheme? _savedColorScheme;
- public void AdjustButton ()
- {
- if (!IsInitialized)
- {
- return;
- }
- Width = SupView.Orientation == Orientation.Vertical ? Dim.Fill () : 1;
- Height = SupView.Orientation == Orientation.Vertical ? 1 : Dim.Fill ();
- switch (VariationMode)
- {
- case VariationMode.Decrease:
- X = 0;
- Y = 0;
- break;
- case VariationMode.Increase:
- X = SupView.Orientation == Orientation.Vertical ? 0 : Pos.AnchorEnd (1);
- Y = SupView.Orientation == Orientation.Vertical ? Pos.AnchorEnd (1) : 0;
- break;
- default:
- throw new ArgumentOutOfRangeException ();
- }
- SetButtonText ();
- }
- /// <inheritdoc/>
- public override Attribute GetNormalColor ()
- {
- if (_savedColorScheme is null)
- {
- ColorScheme = new () { Normal = new (SupView.ColorScheme.HotNormal.Foreground, SupView.ColorScheme.HotNormal.Background) };
- }
- else
- {
- ColorScheme = new () { Normal = new (SupView.ColorScheme.Normal.Background, SupView.ColorScheme.Normal.Foreground) };
- }
- return base.GetNormalColor ();
- }
- public VariationMode VariationMode { get; init; }
- /// <inheritdoc/>
- protected internal override bool? OnMouseEnter (MouseEvent mouseEvent)
- {
- _savedColorScheme ??= SupView.ColorScheme;
- ColorScheme = new ()
- {
- Normal = new (_savedColorScheme.HotNormal.Foreground, _savedColorScheme.HotNormal.Foreground),
- Focus = new (_savedColorScheme.Focus.Foreground, _savedColorScheme.Focus.Foreground),
- HotNormal = new (_savedColorScheme.Normal.Foreground, _savedColorScheme.Normal.Foreground),
- HotFocus = new (_savedColorScheme.HotFocus.Foreground, _savedColorScheme.HotFocus.Foreground),
- Disabled = new (_savedColorScheme.Disabled.Foreground, _savedColorScheme.Disabled.Foreground)
- };
- return base.OnMouseEnter (mouseEvent);
- }
- /// <inheritdoc/>
- protected internal override bool OnMouseEvent (MouseEvent mouseEvent)
- {
- if (mouseEvent.Flags.HasFlag (MouseFlags.Button1Pressed))
- {
- switch (VariationMode)
- {
- case VariationMode.Decrease:
- SupView.Position--;
- return true;
- case VariationMode.Increase:
- SupView.Position++;
- return true;
- default:
- throw new ArgumentOutOfRangeException ();
- }
- }
- return base.OnMouseEvent (mouseEvent);
- }
- /// <inheritdoc/>
- protected internal override bool OnMouseLeave (MouseEvent mouseEvent)
- {
- if (_savedColorScheme is { })
- {
- ColorScheme = _savedColorScheme;
- _savedColorScheme = null;
- }
- return base.OnMouseLeave (mouseEvent);
- }
- private void SetButtonText ()
- {
- switch (VariationMode)
- {
- case VariationMode.Decrease:
- Text = SupView.Orientation == Orientation.Vertical ? Glyphs.UpArrow.ToString () : Glyphs.LeftArrow.ToString ();
- break;
- case VariationMode.Increase:
- Text = SupView.Orientation == Orientation.Vertical ? Glyphs.DownArrow.ToString () : Glyphs.RightArrow.ToString ();
- break;
- default:
- throw new ArgumentOutOfRangeException ();
- }
- }
- private ScrollBar SupView => (SuperView as ScrollBar)!;
- }
|