From 9713b856f8abdb003824fd3d0ef4bc8a8bfc5b06 Mon Sep 17 00:00:00 2001 From: nea Date: Sun, 7 Aug 2022 23:51:45 +0200 Subject: progress bar --- .../moe/nea/notenoughupdates/repo/ItemCache.kt | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) (limited to 'src/main/kotlin/moe/nea/notenoughupdates/repo/ItemCache.kt') diff --git a/src/main/kotlin/moe/nea/notenoughupdates/repo/ItemCache.kt b/src/main/kotlin/moe/nea/notenoughupdates/repo/ItemCache.kt index 8deb4c3..9255867 100644 --- a/src/main/kotlin/moe/nea/notenoughupdates/repo/ItemCache.kt +++ b/src/main/kotlin/moe/nea/notenoughupdates/repo/ItemCache.kt @@ -1,6 +1,7 @@ package moe.nea.notenoughupdates.repo import com.mojang.serialization.Dynamic +import io.github.cottonmc.cotton.gui.client.CottonHud import io.github.moulberry.repo.IReloadable import io.github.moulberry.repo.NEURepository import io.github.moulberry.repo.data.NEUItem @@ -79,11 +80,22 @@ object ItemCache : IReloadable { val j = job if (j != null && j.isActive) { j.cancel() - job = NotEnoughUpdates.coroutineScope.launch { - repository.items?.items?.values?.forEach { - it.asItemStack() // Rebuild cache - } + } + + job = NotEnoughUpdates.coroutineScope.launch { + val items = repository.items?.items + if (items == null) { + CottonHud.remove(RepoManager.progressBar) + return@launch + } + RepoManager.progressBar.reportProgress("Recache Items", 0, items.size) + CottonHud.add(RepoManager.progressBar) + var i = 0 + items.values.forEach { + it.asItemStack() // Rebuild cache + RepoManager.progressBar.reportProgress("Recache Items", i++, items.size) } + CottonHud.remove(RepoManager.progressBar) } } } -- cgit