mirror of
https://github.com/osukey/osukey.git
synced 2025-05-18 03:57:32 +09:00
Fix Alt+number shortcuts for tabs in chat overlay (#7687)
Fix Alt+number shortcuts for tabs in chat overlay
This commit is contained in:
commit
b7f4dd8dd4
@ -38,9 +38,21 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
private TestChatOverlay chatOverlay;
|
private TestChatOverlay chatOverlay;
|
||||||
private ChannelManager channelManager;
|
private ChannelManager channelManager;
|
||||||
|
|
||||||
private readonly Channel channel1 = new Channel(new User()) { Name = "test really long username", Topic = "Topic for channel 1" };
|
private readonly List<Channel> channels;
|
||||||
private readonly Channel channel2 = new Channel(new User()) { Name = "test2", Topic = "Topic for channel 2" };
|
|
||||||
private readonly Channel channel3 = new Channel(new User()) { Name = "channel with no topic" };
|
private Channel channel1 => channels[0];
|
||||||
|
private Channel channel2 => channels[1];
|
||||||
|
|
||||||
|
public TestSceneChatOverlay()
|
||||||
|
{
|
||||||
|
channels = Enumerable.Range(1, 10)
|
||||||
|
.Select(index => new Channel(new User())
|
||||||
|
{
|
||||||
|
Name = $"Channel no. {index}",
|
||||||
|
Topic = index == 3 ? null : $"We talk about the number {index} here"
|
||||||
|
})
|
||||||
|
.ToList();
|
||||||
|
}
|
||||||
|
|
||||||
[SetUp]
|
[SetUp]
|
||||||
public void Setup()
|
public void Setup()
|
||||||
@ -49,7 +61,7 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
{
|
{
|
||||||
ChannelManagerContainer container;
|
ChannelManagerContainer container;
|
||||||
|
|
||||||
Child = container = new ChannelManagerContainer(new List<Channel> { channel1, channel2, channel3 })
|
Child = container = new ChannelManagerContainer(channels)
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
};
|
};
|
||||||
@ -103,7 +115,7 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestSearchInSelector()
|
public void TestSearchInSelector()
|
||||||
{
|
{
|
||||||
AddStep("search for 'test2'", () => chatOverlay.ChildrenOfType<SearchTextBox>().First().Text = "test2");
|
AddStep("search for 'no. 2'", () => chatOverlay.ChildrenOfType<SearchTextBox>().First().Text = "no. 2");
|
||||||
AddUntilStep("only channel 2 visible", () =>
|
AddUntilStep("only channel 2 visible", () =>
|
||||||
{
|
{
|
||||||
var listItems = chatOverlay.ChildrenOfType<ChannelListItem>().Where(c => c.IsPresent);
|
var listItems = chatOverlay.ChildrenOfType<ChannelListItem>().Where(c => c.IsPresent);
|
||||||
@ -111,6 +123,36 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestChannelShortcutKeys()
|
||||||
|
{
|
||||||
|
AddStep("join 10 channels", () => channels.ForEach(channel => channelManager.JoinChannel(channel)));
|
||||||
|
AddStep("close channel selector", () =>
|
||||||
|
{
|
||||||
|
InputManager.PressKey(Key.Escape);
|
||||||
|
InputManager.ReleaseKey(Key.Escape);
|
||||||
|
});
|
||||||
|
AddUntilStep("wait for close", () => chatOverlay.SelectionOverlayState == Visibility.Hidden);
|
||||||
|
|
||||||
|
for (int zeroBasedIndex = 0; zeroBasedIndex < 10; ++zeroBasedIndex)
|
||||||
|
{
|
||||||
|
var oneBasedIndex = zeroBasedIndex + 1;
|
||||||
|
var targetNumberKey = oneBasedIndex % 10;
|
||||||
|
var targetChannel = channels[zeroBasedIndex];
|
||||||
|
AddStep($"press Alt+{targetNumberKey}", () => pressChannelHotkey(targetNumberKey));
|
||||||
|
AddAssert($"channel #{oneBasedIndex} is selected", () => channelManager.CurrentChannel.Value == targetChannel);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void pressChannelHotkey(int number)
|
||||||
|
{
|
||||||
|
var channelKey = Key.Number0 + number;
|
||||||
|
InputManager.PressKey(Key.AltLeft);
|
||||||
|
InputManager.PressKey(channelKey);
|
||||||
|
InputManager.ReleaseKey(Key.AltLeft);
|
||||||
|
InputManager.ReleaseKey(channelKey);
|
||||||
|
}
|
||||||
|
|
||||||
private void clickDrawable(Drawable d)
|
private void clickDrawable(Drawable d)
|
||||||
{
|
{
|
||||||
InputManager.MoveMouseTo(d);
|
InputManager.MoveMouseTo(d);
|
||||||
|
@ -321,8 +321,10 @@ namespace osu.Game.Overlays
|
|||||||
|
|
||||||
private void selectTab(int index)
|
private void selectTab(int index)
|
||||||
{
|
{
|
||||||
var channel = ChannelTabControl.Items.Skip(index).FirstOrDefault();
|
var channel = ChannelTabControl.Items
|
||||||
if (channel != null && !(channel is ChannelSelectorTabItem.ChannelSelectorTabChannel))
|
.Where(tab => !(tab is ChannelSelectorTabItem.ChannelSelectorTabChannel))
|
||||||
|
.ElementAtOrDefault(index);
|
||||||
|
if (channel != null)
|
||||||
ChannelTabControl.Current.Value = channel;
|
ChannelTabControl.Current.Value = channel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user