1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-22 15:12:54 +08:00

Decouple LabelledFileChooser from LabelledTextBoxWithPopover

This commit is contained in:
Salman Ahmed 2022-06-15 17:45:31 +03:00
parent 6a8cf514e0
commit 1ff070f5ff
2 changed files with 32 additions and 5 deletions

View File

@ -14,14 +14,20 @@ using osu.Framework.Extensions;
using osu.Framework.Extensions.ObjectExtensions; using osu.Framework.Extensions.ObjectExtensions;
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Cursor;
using osu.Framework.Graphics.UserInterface; using osu.Framework.Graphics.UserInterface;
using osu.Framework.Localisation;
using osu.Game.Database; using osu.Game.Database;
using osu.Game.Graphics.UserInterfaceV2; using osu.Game.Graphics.UserInterfaceV2;
using osuTK; using osuTK;
namespace osu.Game.Screens.Edit.Setup namespace osu.Game.Screens.Edit.Setup
{ {
internal class LabelledFileChooser : LabelledTextBoxWithPopover, ICanAcceptFiles /// <summary>
/// A labelled drawable displaying file chooser on click, with placeholder text support.
/// todo: this should probably not use PopoverTextBox just to display placeholder text, but is the best way for now.
/// </summary>
internal class LabelledFileChooser : LabelledDrawable<LabelledTextBoxWithPopover.PopoverTextBox>, IHasCurrentValue<string>, ICanAcceptFiles, IHasPopover
{ {
private readonly string[] handledExtensions; private readonly string[] handledExtensions;
@ -34,13 +40,25 @@ namespace osu.Game.Screens.Edit.Setup
private readonly BindableWithCurrent<string> current = new BindableWithCurrent<string>(); private readonly BindableWithCurrent<string> current = new BindableWithCurrent<string>();
public override Bindable<string> Current public Bindable<string> Current
{ {
get => current.Current; get => current.Current;
set => current.Current = value; set => current.Current = value;
} }
public LocalisableString Text
{
get => Component.PlaceholderText;
set => Component.PlaceholderText = value;
}
public CompositeDrawable TabbableContentContainer
{
set => Component.TabbableContentContainer = value;
}
public LabelledFileChooser(params string[] handledExtensions) public LabelledFileChooser(params string[] handledExtensions)
: base(false)
{ {
this.handledExtensions = handledExtensions; this.handledExtensions = handledExtensions;
} }
@ -78,7 +96,16 @@ namespace osu.Game.Screens.Edit.Setup
game.UnregisterImportHandler(this); game.UnregisterImportHandler(this);
} }
public override Popover GetPopover() => new FileChooserPopover(handledExtensions, currentFile); protected override LabelledTextBoxWithPopover.PopoverTextBox CreateComponent() => new LabelledTextBoxWithPopover.PopoverTextBox
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
RelativeSizeAxes = Axes.X,
CornerRadius = CORNER_RADIUS,
OnFocused = this.ShowPopover,
};
public Popover GetPopover() => new FileChooserPopover(handledExtensions, currentFile);
private class FileChooserPopover : OsuPopover private class FileChooserPopover : OsuPopover
{ {

View File

@ -121,7 +121,7 @@ namespace osu.Game.Screens.Edit.Setup
private void backgroundChanged(ValueChangedEvent<string> filePath) private void backgroundChanged(ValueChangedEvent<string> filePath)
{ {
backgroundChooser.PlaceholderText = string.IsNullOrEmpty(filePath.NewValue) backgroundChooser.Text = string.IsNullOrEmpty(filePath.NewValue)
? "Click to select a background image" ? "Click to select a background image"
: "Click to replace the background image"; : "Click to replace the background image";
@ -134,7 +134,7 @@ namespace osu.Game.Screens.Edit.Setup
private void audioTrackChanged(ValueChangedEvent<string> filePath) private void audioTrackChanged(ValueChangedEvent<string> filePath)
{ {
audioTrackChooser.PlaceholderText = string.IsNullOrEmpty(filePath.NewValue) audioTrackChooser.Text = string.IsNullOrEmpty(filePath.NewValue)
? "Click to select a track" ? "Click to select a track"
: "Click to replace the track"; : "Click to replace the track";