Merge pull request #2843 from BDisp/v2_statusitem-can-execute-fix_2789

Fixes #2789. StatusItem should have a disabled attribute if it can't execute.
This commit is contained in:
Tig
2023-09-29 11:15:03 -06:00
committed by GitHub
2 changed files with 80 additions and 6 deletions

View File

@@ -23,7 +23,7 @@ namespace Terminal.Gui.ViewsTests {
}
[Fact]
public void StatusBar_Contructor_Default ()
public void StatusBar_Constructor_Default ()
{
var sb = new StatusBar ();
@@ -160,5 +160,43 @@ CTRL-O Open {CM.Glyphs.VLine} CTRL-Q Quit
Assert.Equal ("~^A~ Save As", sb.Items [1].Title);
Assert.Equal ("~^Q~ Quit", sb.Items [^1].Title);
}
[Fact, AutoInitShutdown]
public void CanExecute_ProcessHotKey ()
{
Window win = null;
var statusBar = new StatusBar (new StatusItem [] {
new StatusItem (Key.CtrlMask | Key.N, "~^N~ New", New, CanExecuteNew),
new StatusItem (Key.CtrlMask | Key.C, "~^C~ Close", Close, CanExecuteClose)
});
var top = Application.Top;
top.Add (statusBar);
bool CanExecuteNew () => win == null;
void New ()
{
win = new Window ();
}
bool CanExecuteClose () => win != null;
void Close ()
{
win = null;
}
Application.Begin (top);
Assert.Null (win);
Assert.True (CanExecuteNew ());
Assert.False (CanExecuteClose ());
Assert.True (top.ProcessHotKey (new KeyEvent (Key.N | Key.CtrlMask, new KeyModifiers () { Alt = true })));
Application.MainLoop.RunIteration ();
Assert.NotNull (win);
Assert.False (CanExecuteNew ());
Assert.True (CanExecuteClose ());
}
}
}