mirror of
https://github.com/gui-cs/Terminal.Gui.git
synced 2026-01-01 16:59:35 +01:00
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:
@@ -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 ());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user