1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-28 06:42:54 +08:00

Refactor LoadRepliesButton to inherit LoadingButton

This commit is contained in:
Andrei Zavatski 2020-07-14 15:02:29 +03:00
parent 4b22832cc8
commit 4c2294f0cd
5 changed files with 34 additions and 34 deletions

View File

@ -33,7 +33,10 @@ namespace osu.Game.Tests.Visual.UserInterface
Children = new Drawable[]
{
button = new TestButton(),
new LoadRepliesButton(),
new LoadRepliesButton
{
Action = () => { }
},
new ShowRepliesButton(1),
new ShowRepliesButton(2)
}

View File

@ -1,7 +1,6 @@
// 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;
using osu.Framework.Allocation;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
@ -17,8 +16,6 @@ namespace osu.Game.Overlays.Comments.Buttons
{
public abstract class CommentRepliesButton : CompositeDrawable
{
public Action Action { get; set; }
protected string Text
{
get => text.Text;
@ -72,6 +69,7 @@ namespace osu.Game.Overlays.Comments.Buttons
{
Anchor = Anchor.CentreLeft,
Origin = Anchor.CentreLeft,
AlwaysPresent = true,
Font = OsuFont.GetFont(size: 12, weight: FontWeight.SemiBold)
},
icon = new SpriteIcon
@ -99,6 +97,8 @@ namespace osu.Game.Overlays.Comments.Buttons
protected void SetIconDirection(bool upwards) => icon.ScaleTo(new Vector2(1, upwards ? -1 : 1));
public void ToggleTextVisibility(bool visible) => text.FadeTo(visible ? 1 : 0, 200, Easing.OutQuint);
protected override bool OnHover(HoverEvent e)
{
base.OnHover(e);
@ -113,11 +113,5 @@ namespace osu.Game.Overlays.Comments.Buttons
background.FadeColour(colourProvider.Background2, 200, Easing.OutQuint);
icon.FadeColour(colourProvider.Foreground1, 200, Easing.OutQuint);
}
protected override bool OnClick(ClickEvent e)
{
Action?.Invoke();
return base.OnClick(e);
}
}
}

View File

@ -1,13 +1,32 @@
// 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 osu.Framework.Graphics;
using osu.Game.Graphics.UserInterface;
namespace osu.Game.Overlays.Comments.Buttons
{
public class LoadRepliesButton : CommentRepliesButton
public class LoadRepliesButton : LoadingButton
{
private ButtonContent content;
public LoadRepliesButton()
{
Text = "load replies";
AutoSizeAxes = Axes.Both;
}
protected override Drawable CreateContent() => content = new ButtonContent();
protected override void OnLoadStarted() => content.ToggleTextVisibility(false);
protected override void OnLoadFinished() => content.ToggleTextVisibility(true);
private class ButtonContent : CommentRepliesButton
{
public ButtonContent()
{
Text = "load replies";
}
}
}
}

View File

@ -1,6 +1,7 @@
// 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;
using Humanizer;
using osu.Framework.Bindables;
using osu.Framework.Input.Events;
@ -9,6 +10,8 @@ namespace osu.Game.Overlays.Comments.Buttons
{
public class ShowRepliesButton : CommentRepliesButton
{
public Action Action;
public readonly BindableBool Expanded = new BindableBool(true);
public ShowRepliesButton(int count)
@ -25,6 +28,7 @@ namespace osu.Game.Overlays.Comments.Buttons
protected override bool OnClick(ClickEvent e)
{
Expanded.Toggle();
Action?.Invoke();
return base.OnClick(e);
}
}

View File

@ -22,7 +22,6 @@ using osu.Framework.Graphics.Shapes;
using osu.Framework.Extensions.IEnumerableExtensions;
using System.Collections.Specialized;
using osu.Game.Overlays.Comments.Buttons;
using osu.Game.Graphics.UserInterface;
namespace osu.Game.Overlays.Comments
{
@ -52,7 +51,6 @@ namespace osu.Game.Overlays.Comments
private ShowRepliesButton showRepliesButton;
private ChevronButton chevronButton;
private DeletedCommentsCounter deletedCommentsCounter;
private LoadingSpinner loading;
public DrawableComment(Comment comment)
{
@ -194,12 +192,7 @@ namespace osu.Game.Overlays.Comments
},
loadRepliesButton = new LoadRepliesButton
{
Action = () =>
{
RepliesRequested(this, ++currentPage);
loadRepliesButton.Hide();
loading.Show();
}
Action = () => RepliesRequested(this, ++currentPage)
}
}
}
@ -209,17 +202,6 @@ namespace osu.Game.Overlays.Comments
}
}
},
loading = new LoadingSpinner
{
Anchor = Anchor.TopLeft,
Origin = Anchor.TopLeft,
Size = new Vector2(15),
Margin = new MarginPadding
{
Vertical = 5,
Left = 80
}
},
childCommentsVisibilityContainer = new FillFlowContainer
{
RelativeSizeAxes = Axes.X,
@ -372,9 +354,7 @@ namespace osu.Game.Overlays.Comments
if (Comment.IsTopLevel)
chevronButton.FadeTo(loadedReplesCount != 0 ? 1 : 0);
showMoreButton.IsLoading = false;
loading.Hide();
loading.FinishTransforms();
showMoreButton.IsLoading = loadRepliesButton.IsLoading = false;
}
private class ChevronButton : ShowChildrenButton