diff --git a/osu.Game/Beatmaps/BeatmapManager.cs b/osu.Game/Beatmaps/BeatmapManager.cs
index 8e7b38a50c..472e44f36b 100644
--- a/osu.Game/Beatmaps/BeatmapManager.cs
+++ b/osu.Game/Beatmaps/BeatmapManager.cs
@@ -191,11 +191,14 @@ namespace osu.Game.Beatmaps
/// Downloads a beatmap.
///
/// The to be downloaded.
- /// The new , or null if a download already exists for the same beatmap.
+ /// A new , or an existing one if a download is already in progress.
public DownloadBeatmapSetRequest Download(BeatmapSetInfo beatmapSetInfo)
{
- if (api == null || downloadsList.Find(d => d.BeatmapSet.OnlineBeatmapSetID == beatmapSetInfo.OnlineBeatmapSetID) != null)
- return null;
+ var existing = downloadsList.Find(d => d.BeatmapSet.OnlineBeatmapSetID == beatmapSetInfo.OnlineBeatmapSetID);
+
+ if (existing != null) return existing;
+
+ if (api == null) return null;
ProgressNotification downloadNotification = new ProgressNotification
{
diff --git a/osu.Game/Overlays/Direct/DirectPanel.cs b/osu.Game/Overlays/Direct/DirectPanel.cs
index 4bf3442453..66b3ff8bf9 100644
--- a/osu.Game/Overlays/Direct/DirectPanel.cs
+++ b/osu.Game/Overlays/Direct/DirectPanel.cs
@@ -160,13 +160,17 @@ namespace osu.Game.Overlays.Direct
}
// we already have an active download running.
- if ((DownloadRequest = beatmaps.Download(SetInfo)) == null)
+ if (beatmaps.GetExistingDownload(SetInfo) != null)
{
content.MoveToX(-5, 50, Easing.OutSine).Then()
.MoveToX(5, 100, Easing.InOutSine).Then()
.MoveToX(-5, 100, Easing.InOutSine).Then()
.MoveToX(0, 50, Easing.InSine).Then();
+
+ return;
}
+
+ DownloadRequest = beatmaps.Download(SetInfo);
}
protected override void LoadComplete()
diff --git a/osu.Game/Overlays/DirectOverlay.cs b/osu.Game/Overlays/DirectOverlay.cs
index 54fda5a38d..9c07e1087f 100644
--- a/osu.Game/Overlays/DirectOverlay.cs
+++ b/osu.Game/Overlays/DirectOverlay.cs
@@ -176,7 +176,7 @@ namespace osu.Game.Overlays
{
// if a new map was imported, we should remove it from search results (download completed etc.)
panels?.FirstOrDefault(p => p.SetInfo.OnlineBeatmapSetID == set.OnlineBeatmapSetID)?.FadeOut(400).Expire();
- BeatmapSets = BeatmapSets.Where(b => b.OnlineBeatmapSetID != set.OnlineBeatmapSetID);
+ BeatmapSets = BeatmapSets?.Where(b => b.OnlineBeatmapSetID != set.OnlineBeatmapSetID);
}
private void updateResultCounts()