mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 16:12:54 +08:00
Add import/deletion progress notifications
This commit is contained in:
parent
4737add00b
commit
06328e0000
@ -57,6 +57,10 @@ namespace osu.Game.Collections
|
|||||||
c.Changed += backgroundSave;
|
c.Changed += backgroundSave;
|
||||||
Collections.CollectionChanged += (_, __) => backgroundSave();
|
Collections.CollectionChanged += (_, __) => backgroundSave();
|
||||||
}
|
}
|
||||||
|
/// <summary>
|
||||||
|
/// Set an endpoint for notifications to be posted to.
|
||||||
|
/// </summary>
|
||||||
|
public Action<Notification> PostNotification { protected get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Set a storage with access to an osu-stable install for import purposes.
|
/// Set a storage with access to an osu-stable install for import purposes.
|
||||||
@ -93,9 +97,25 @@ namespace osu.Game.Collections
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task Import(Stream stream) => await Task.Run(async () =>
|
public async Task Import(Stream stream)
|
||||||
{
|
{
|
||||||
var collection = readCollections(stream);
|
var notification = new ProgressNotification
|
||||||
|
{
|
||||||
|
State = ProgressNotificationState.Active,
|
||||||
|
Text = "Collections import is initialising..."
|
||||||
|
};
|
||||||
|
|
||||||
|
PostNotification?.Invoke(notification);
|
||||||
|
|
||||||
|
await import(stream, notification);
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task import(Stream stream, ProgressNotification notification = null) => await Task.Run(async () =>
|
||||||
|
{
|
||||||
|
if (notification != null)
|
||||||
|
notification.Progress = 0;
|
||||||
|
|
||||||
|
var collection = readCollections(stream, notification);
|
||||||
bool importCompleted = false;
|
bool importCompleted = false;
|
||||||
|
|
||||||
Schedule(() =>
|
Schedule(() =>
|
||||||
@ -106,6 +126,12 @@ namespace osu.Game.Collections
|
|||||||
|
|
||||||
while (!IsDisposed && !importCompleted)
|
while (!IsDisposed && !importCompleted)
|
||||||
await Task.Delay(10);
|
await Task.Delay(10);
|
||||||
|
|
||||||
|
if (notification != null)
|
||||||
|
{
|
||||||
|
notification.CompletionText = $"Imported {collection.Count} collections";
|
||||||
|
notification.State = ProgressNotificationState.Completed;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
private void importCollections(List<BeatmapCollection> newCollections)
|
private void importCollections(List<BeatmapCollection> newCollections)
|
||||||
@ -124,8 +150,14 @@ namespace osu.Game.Collections
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<BeatmapCollection> readCollections(Stream stream)
|
private List<BeatmapCollection> readCollections(Stream stream, ProgressNotification notification = null)
|
||||||
{
|
{
|
||||||
|
if (notification != null)
|
||||||
|
{
|
||||||
|
notification.Text = "Reading collections...";
|
||||||
|
notification.Progress = 0;
|
||||||
|
}
|
||||||
|
|
||||||
var result = new List<BeatmapCollection>();
|
var result = new List<BeatmapCollection>();
|
||||||
|
|
||||||
try
|
try
|
||||||
@ -139,11 +171,17 @@ namespace osu.Game.Collections
|
|||||||
|
|
||||||
for (int i = 0; i < collectionCount; i++)
|
for (int i = 0; i < collectionCount; i++)
|
||||||
{
|
{
|
||||||
|
if (notification?.CancellationToken.IsCancellationRequested == true)
|
||||||
|
return result;
|
||||||
|
|
||||||
var collection = new BeatmapCollection { Name = { Value = sr.ReadString() } };
|
var collection = new BeatmapCollection { Name = { Value = sr.ReadString() } };
|
||||||
int mapCount = sr.ReadInt32();
|
int mapCount = sr.ReadInt32();
|
||||||
|
|
||||||
for (int j = 0; j < mapCount; j++)
|
for (int j = 0; j < mapCount; j++)
|
||||||
{
|
{
|
||||||
|
if (notification?.CancellationToken.IsCancellationRequested == true)
|
||||||
|
return result;
|
||||||
|
|
||||||
string checksum = sr.ReadString();
|
string checksum = sr.ReadString();
|
||||||
|
|
||||||
var beatmap = beatmaps.QueryBeatmap(b => b.MD5Hash == checksum);
|
var beatmap = beatmaps.QueryBeatmap(b => b.MD5Hash == checksum);
|
||||||
@ -151,6 +189,12 @@ namespace osu.Game.Collections
|
|||||||
collection.Beatmaps.Add(beatmap);
|
collection.Beatmaps.Add(beatmap);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (notification != null)
|
||||||
|
{
|
||||||
|
notification.Text = $"Imported {i + 1} of {collectionCount} collections";
|
||||||
|
notification.Progress = (float)(i + 1) / collectionCount;
|
||||||
|
}
|
||||||
|
|
||||||
result.Add(collection);
|
result.Add(collection);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -163,6 +207,12 @@ namespace osu.Game.Collections
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void DeleteAll()
|
||||||
|
{
|
||||||
|
Collections.Clear();
|
||||||
|
PostNotification?.Invoke(new SimpleNotification { Text = "Deleted all collections!" });
|
||||||
|
}
|
||||||
|
|
||||||
private readonly object saveLock = new object();
|
private readonly object saveLock = new object();
|
||||||
private int lastSave;
|
private int lastSave;
|
||||||
private int saveFailures;
|
private int saveFailures;
|
||||||
|
@ -537,6 +537,7 @@ namespace osu.Game
|
|||||||
ScoreManager.GetStableStorage = GetStorageForStableInstall;
|
ScoreManager.GetStableStorage = GetStorageForStableInstall;
|
||||||
ScoreManager.PresentImport = items => PresentScore(items.First());
|
ScoreManager.PresentImport = items => PresentScore(items.First());
|
||||||
|
|
||||||
|
CollectionManager.PostNotification = n => notifications.Post(n);
|
||||||
CollectionManager.GetStableStorage = GetStorageForStableInstall;
|
CollectionManager.GetStableStorage = GetStorageForStableInstall;
|
||||||
|
|
||||||
Container logoContainer;
|
Container logoContainer;
|
||||||
|
@ -126,7 +126,7 @@ namespace osu.Game.Overlays.Settings.Sections.Maintenance
|
|||||||
Text = "Delete ALL collections",
|
Text = "Delete ALL collections",
|
||||||
Action = () =>
|
Action = () =>
|
||||||
{
|
{
|
||||||
dialogOverlay?.Push(new DeleteAllBeatmapsDialog(() => collectionManager.Collections.Clear()));
|
dialogOverlay?.Push(new DeleteAllBeatmapsDialog(collectionManager.DeleteAll));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user