diff options
Diffstat (limited to 'src/main/kotlin/moe/nea/firmament/util/ScreenUtil.kt')
-rw-r--r-- | src/main/kotlin/moe/nea/firmament/util/ScreenUtil.kt | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/src/main/kotlin/moe/nea/firmament/util/ScreenUtil.kt b/src/main/kotlin/moe/nea/firmament/util/ScreenUtil.kt new file mode 100644 index 0000000..74b750b --- /dev/null +++ b/src/main/kotlin/moe/nea/firmament/util/ScreenUtil.kt @@ -0,0 +1,36 @@ +package moe.nea.firmament.util + +import moe.nea.firmament.Firmament +import net.fabricmc.fabric.api.client.event.lifecycle.v1.ClientTickEvents +import net.minecraft.client.MinecraftClient +import net.minecraft.client.gui.screen.Screen + +object ScreenUtil { + init { + ClientTickEvents.START_CLIENT_TICK.register(::onTick) + } + + private fun onTick(minecraft: MinecraftClient) { + if (nextOpenedGui != null) { + val p = minecraft.player + if (p?.currentScreenHandler != null) { + p.closeHandledScreen() + } + minecraft.setScreen(nextOpenedGui) + nextOpenedGui = null + } + } + + private var nextOpenedGui: Screen? = null + + fun setScreenLater(nextScreen: Screen) { + val nog = nextOpenedGui + if (nog != null) { + Firmament.logger.warn("Setting screen ${nextScreen::class.qualifiedName} to be opened later, but ${nog::class.qualifiedName} is already queued.") + return + } + nextOpenedGui = nextScreen + } + + +} |