2022-03-14 18:31:13 +00:00
|
|
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
|
|
|
// See the LICENCE file in the repository root for full licence text.
|
|
|
|
|
|
|
|
using System;
|
2022-03-19 21:36:11 +00:00
|
|
|
using System.Linq;
|
2022-03-14 18:31:13 +00:00
|
|
|
using osu.Framework.Allocation;
|
|
|
|
using osu.Framework.Bindables;
|
|
|
|
using osu.Framework.Graphics;
|
|
|
|
using osu.Framework.Graphics.Containers;
|
|
|
|
using osu.Framework.Graphics.Shapes;
|
|
|
|
using osu.Framework.Input.Events;
|
2022-03-19 16:44:58 +00:00
|
|
|
using osu.Game.Graphics;
|
2022-03-14 18:31:13 +00:00
|
|
|
using osu.Game.Graphics.Containers;
|
2022-03-19 16:44:58 +00:00
|
|
|
using osu.Game.Graphics.Sprites;
|
2022-03-14 18:31:13 +00:00
|
|
|
using osu.Game.Online.Chat;
|
2022-05-19 10:26:14 +00:00
|
|
|
using osu.Game.Overlays.Chat.Listing;
|
2022-03-19 21:36:11 +00:00
|
|
|
using osu.Game.Users.Drawables;
|
|
|
|
using osuTK;
|
2022-03-14 18:31:13 +00:00
|
|
|
|
2022-03-19 21:49:14 +00:00
|
|
|
namespace osu.Game.Overlays.Chat.ChannelList
|
2022-03-14 18:31:13 +00:00
|
|
|
{
|
2022-03-19 21:49:14 +00:00
|
|
|
public class ChannelListItem : OsuClickableContainer
|
2022-03-14 18:31:13 +00:00
|
|
|
{
|
|
|
|
public event Action<Channel>? OnRequestSelect;
|
|
|
|
public event Action<Channel>? OnRequestLeave;
|
|
|
|
|
2022-04-29 20:33:32 +00:00
|
|
|
public readonly Channel Channel;
|
|
|
|
|
2022-03-14 21:26:33 +00:00
|
|
|
public readonly BindableInt Mentions = new BindableInt();
|
2022-03-14 18:31:13 +00:00
|
|
|
|
2022-03-14 21:32:30 +00:00
|
|
|
public readonly BindableBool Unread = new BindableBool();
|
2022-03-14 18:31:13 +00:00
|
|
|
|
2022-04-20 18:12:43 +00:00
|
|
|
private Box hoverBox = null!;
|
|
|
|
private Box selectBox = null!;
|
|
|
|
private OsuSpriteText text = null!;
|
2022-05-18 00:35:39 +00:00
|
|
|
private ChannelListItemCloseButton? close;
|
2022-03-14 18:31:13 +00:00
|
|
|
|
|
|
|
[Resolved]
|
2022-03-14 20:14:04 +00:00
|
|
|
private Bindable<Channel> selectedChannel { get; set; } = null!;
|
2022-03-14 18:31:13 +00:00
|
|
|
|
2022-03-19 16:44:58 +00:00
|
|
|
[Resolved]
|
|
|
|
private OverlayColourProvider colourProvider { get; set; } = null!;
|
|
|
|
|
2022-03-19 21:49:14 +00:00
|
|
|
public ChannelListItem(Channel channel)
|
2022-03-14 18:31:13 +00:00
|
|
|
{
|
2022-04-29 20:33:32 +00:00
|
|
|
Channel = channel;
|
2022-03-14 18:31:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
[BackgroundDependencyLoader]
|
2022-03-19 16:44:58 +00:00
|
|
|
private void load()
|
2022-03-14 18:31:13 +00:00
|
|
|
{
|
|
|
|
Height = 30;
|
|
|
|
RelativeSizeAxes = Axes.X;
|
|
|
|
|
|
|
|
Children = new Drawable[]
|
|
|
|
{
|
|
|
|
hoverBox = new Box
|
|
|
|
{
|
|
|
|
RelativeSizeAxes = Axes.Both,
|
2022-03-14 20:14:04 +00:00
|
|
|
Colour = colourProvider.Background3,
|
2022-03-14 18:31:13 +00:00
|
|
|
Alpha = 0f,
|
|
|
|
},
|
|
|
|
selectBox = new Box
|
|
|
|
{
|
|
|
|
RelativeSizeAxes = Axes.Both,
|
2022-03-14 20:14:04 +00:00
|
|
|
Colour = colourProvider.Background4,
|
2022-03-14 18:31:13 +00:00
|
|
|
Alpha = 0f,
|
|
|
|
},
|
|
|
|
new Container
|
|
|
|
{
|
|
|
|
RelativeSizeAxes = Axes.Both,
|
2022-03-14 21:39:57 +00:00
|
|
|
Padding = new MarginPadding { Left = 18, Right = 10 },
|
2022-03-14 18:31:13 +00:00
|
|
|
Child = new GridContainer
|
|
|
|
{
|
|
|
|
RelativeSizeAxes = Axes.Both,
|
|
|
|
ColumnDimensions = new[]
|
|
|
|
{
|
|
|
|
new Dimension(GridSizeMode.AutoSize),
|
|
|
|
new Dimension(),
|
|
|
|
new Dimension(GridSizeMode.AutoSize),
|
|
|
|
new Dimension(GridSizeMode.AutoSize),
|
|
|
|
},
|
|
|
|
Content = new[]
|
|
|
|
{
|
2022-05-18 00:35:39 +00:00
|
|
|
new Drawable?[]
|
2022-03-14 18:31:13 +00:00
|
|
|
{
|
2022-03-18 05:03:52 +00:00
|
|
|
createIcon(),
|
2022-03-19 16:44:58 +00:00
|
|
|
text = new OsuSpriteText
|
2022-03-14 18:31:13 +00:00
|
|
|
{
|
|
|
|
Anchor = Anchor.CentreLeft,
|
|
|
|
Origin = Anchor.CentreLeft,
|
2022-04-29 20:33:32 +00:00
|
|
|
Text = Channel.Name,
|
2022-03-19 16:44:58 +00:00
|
|
|
Font = OsuFont.Torus.With(size: 17, weight: FontWeight.SemiBold),
|
|
|
|
Colour = colourProvider.Light3,
|
|
|
|
Margin = new MarginPadding { Bottom = 2 },
|
|
|
|
RelativeSizeAxes = Axes.X,
|
|
|
|
Truncate = true,
|
2022-03-14 18:31:13 +00:00
|
|
|
},
|
2022-05-15 18:38:37 +00:00
|
|
|
createMentionPill(),
|
|
|
|
close = createCloseButton(),
|
2022-03-14 18:31:13 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
2022-03-15 22:19:58 +00:00
|
|
|
|
2022-04-29 20:33:32 +00:00
|
|
|
Action = () => OnRequestSelect?.Invoke(Channel);
|
2022-03-14 18:31:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
protected override void LoadComplete()
|
|
|
|
{
|
|
|
|
base.LoadComplete();
|
|
|
|
|
2022-05-02 21:32:25 +00:00
|
|
|
selectedChannel.BindValueChanged(_ => updateState(), true);
|
|
|
|
Unread.BindValueChanged(_ => updateState(), true);
|
2022-03-14 18:31:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
protected override bool OnHover(HoverEvent e)
|
|
|
|
{
|
2022-04-20 18:12:43 +00:00
|
|
|
hoverBox.FadeIn(300, Easing.OutQuint);
|
2022-05-17 17:52:19 +00:00
|
|
|
close?.FadeIn(300, Easing.OutQuint);
|
2022-05-15 18:38:37 +00:00
|
|
|
|
2022-03-14 18:31:13 +00:00
|
|
|
return base.OnHover(e);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected override void OnHoverLost(HoverLostEvent e)
|
|
|
|
{
|
2022-04-20 18:12:43 +00:00
|
|
|
hoverBox.FadeOut(200, Easing.OutQuint);
|
2022-05-17 17:52:19 +00:00
|
|
|
close?.FadeOut(200, Easing.OutQuint);
|
2022-05-15 18:38:37 +00:00
|
|
|
|
2022-03-14 18:31:13 +00:00
|
|
|
base.OnHoverLost(e);
|
|
|
|
}
|
|
|
|
|
2022-05-17 17:52:19 +00:00
|
|
|
private UpdateableAvatar? createIcon()
|
2022-03-14 18:31:13 +00:00
|
|
|
{
|
2022-04-29 20:33:32 +00:00
|
|
|
if (Channel.Type != ChannelType.PM)
|
2022-05-17 17:52:19 +00:00
|
|
|
return null;
|
2022-03-14 18:31:13 +00:00
|
|
|
|
2022-04-29 20:33:32 +00:00
|
|
|
return new UpdateableAvatar(Channel.Users.First(), isInteractive: false)
|
2022-03-14 18:31:13 +00:00
|
|
|
{
|
2022-03-19 21:36:11 +00:00
|
|
|
Size = new Vector2(20),
|
|
|
|
Margin = new MarginPadding { Right = 5 },
|
2022-03-14 18:31:13 +00:00
|
|
|
Anchor = Anchor.CentreLeft,
|
|
|
|
Origin = Anchor.CentreLeft,
|
2022-03-19 21:36:11 +00:00
|
|
|
CornerRadius = 10,
|
|
|
|
Masking = true,
|
2022-03-14 18:31:13 +00:00
|
|
|
};
|
|
|
|
}
|
2022-04-20 18:12:43 +00:00
|
|
|
|
2022-05-17 17:52:19 +00:00
|
|
|
private ChannelListItemMentionPill? createMentionPill()
|
2022-05-15 18:38:37 +00:00
|
|
|
{
|
|
|
|
if (isSelector)
|
2022-05-17 17:52:19 +00:00
|
|
|
return null;
|
2022-05-15 18:38:37 +00:00
|
|
|
|
|
|
|
return new ChannelListItemMentionPill
|
|
|
|
{
|
|
|
|
Anchor = Anchor.CentreLeft,
|
|
|
|
Origin = Anchor.CentreLeft,
|
|
|
|
Margin = new MarginPadding { Right = 3 },
|
|
|
|
Mentions = { BindTarget = Mentions },
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-05-17 17:52:19 +00:00
|
|
|
private ChannelListItemCloseButton? createCloseButton()
|
2022-05-15 18:38:37 +00:00
|
|
|
{
|
|
|
|
if (isSelector)
|
2022-05-17 17:52:19 +00:00
|
|
|
return null;
|
2022-05-15 18:38:37 +00:00
|
|
|
|
|
|
|
return new ChannelListItemCloseButton
|
|
|
|
{
|
|
|
|
Anchor = Anchor.CentreLeft,
|
|
|
|
Origin = Anchor.CentreLeft,
|
|
|
|
Margin = new MarginPadding { Right = 3 },
|
|
|
|
Action = () => OnRequestLeave?.Invoke(Channel),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-05-02 21:32:25 +00:00
|
|
|
private void updateState()
|
2022-04-20 18:12:43 +00:00
|
|
|
{
|
2022-05-19 10:45:39 +00:00
|
|
|
bool selected = selectedChannel.Value == Channel;
|
2022-05-04 12:00:11 +00:00
|
|
|
|
|
|
|
if (selected)
|
2022-04-20 18:12:43 +00:00
|
|
|
selectBox.FadeIn(300, Easing.OutQuint);
|
|
|
|
else
|
|
|
|
selectBox.FadeOut(200, Easing.OutQuint);
|
2022-05-02 21:32:25 +00:00
|
|
|
|
2022-05-04 12:00:11 +00:00
|
|
|
if (Unread.Value || selected)
|
2022-05-02 21:32:25 +00:00
|
|
|
text.FadeColour(colourProvider.Content1, 300, Easing.OutQuint);
|
|
|
|
else
|
|
|
|
text.FadeColour(colourProvider.Light3, 200, Easing.OutQuint);
|
2022-04-20 18:12:43 +00:00
|
|
|
}
|
2022-05-15 18:38:37 +00:00
|
|
|
|
2022-05-19 10:26:14 +00:00
|
|
|
private bool isSelector => Channel is ChannelListing.ChannelListingChannel;
|
2022-03-14 18:31:13 +00:00
|
|
|
}
|
|
|
|
}
|