From b0cb9a70cd9a3f02b86e0386ab6bb70974bba35a Mon Sep 17 00:00:00 2001
From: nea <nea@nea.moe>
Date: Thu, 24 Aug 2023 18:12:39 +0200
Subject: Revive old profile viewer

---
 src/main/kotlin/moe/nea/firmament/apis/Routes.kt   | 38 ++++---------
 .../firmament/gui/profileviewer/ProfileViewer.kt   |  2 +-
 .../gui/profileviewer/ProfileViewerLibrary.kt      | 63 ++++++++++++++++++++++
 .../moe/nea/firmament/jarvis/JarvisIntegration.kt  |  4 ++
 .../kotlin/moe/nea/firmament/util/SkyblockId.kt    |  2 +-
 5 files changed, 80 insertions(+), 29 deletions(-)
 create mode 100644 src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewerLibrary.kt

(limited to 'src/main/kotlin/moe')

diff --git a/src/main/kotlin/moe/nea/firmament/apis/Routes.kt b/src/main/kotlin/moe/nea/firmament/apis/Routes.kt
index 71802a5..1d25ac1 100644
--- a/src/main/kotlin/moe/nea/firmament/apis/Routes.kt
+++ b/src/main/kotlin/moe/nea/firmament/apis/Routes.kt
@@ -6,23 +6,23 @@
 
 package moe.nea.firmament.apis
 
-import io.ktor.client.call.body
-import io.ktor.client.request.get
-import io.ktor.client.request.parameter
-import io.ktor.http.URLProtocol
-import io.ktor.http.isSuccess
-import io.ktor.http.path
-import io.ktor.util.CaseInsensitiveMap
-import java.util.UUID
+import io.ktor.client.call.*
+import io.ktor.client.request.*
+import io.ktor.http.*
+import io.ktor.util.*
+import java.util.*
 import kotlinx.coroutines.Deferred
 import kotlinx.coroutines.async
 import kotlinx.coroutines.launch
 import kotlinx.coroutines.withContext
+import kotlin.collections.MutableMap
+import kotlin.collections.listOf
+import kotlin.collections.mutableMapOf
+import kotlin.collections.set
 import moe.nea.firmament.Firmament
 import moe.nea.firmament.util.MinecraftDispatcher
 
 object Routes {
-    val apiKey = "e721a103-96e0-400f-af2a-73b2a91007b1"
     private val nameToUUID: MutableMap<String, Deferred<UUID?>> = CaseInsensitiveMap()
     private val profiles: MutableMap<UUID, Deferred<Profiles?>> = mutableMapOf()
     private val accounts: MutableMap<UUID, Deferred<PlayerData?>> = mutableMapOf()
@@ -64,15 +64,7 @@ object Routes {
         return withContext(MinecraftDispatcher) {
             accounts.computeIfAbsent(uuid) {
                 async(Firmament.coroutineScope.coroutineContext) {
-                    val response = Firmament.httpClient.get {
-                        url {
-                            protocol = URLProtocol.HTTPS
-                            host = "api.hypixel.net"
-                            path("player")
-                            parameter("key", apiKey)
-                            parameter("uuid", uuid)
-                        }
-                    }
+                    val response = UrsaManager.request(listOf("v1", "hypixel","player", uuid.toString()))
                     if (!response.status.isSuccess()) {
                         launch(MinecraftDispatcher) {
                             @Suppress("DeferredResultUnused")
@@ -90,15 +82,7 @@ object Routes {
         return withContext(MinecraftDispatcher) {
             profiles.computeIfAbsent(uuid) {
                 async(Firmament.coroutineScope.coroutineContext) {
-                    val response = Firmament.httpClient.get {
-                        url {
-                            protocol = URLProtocol.HTTPS
-                            host = "api.hypixel.net"
-                            path("skyblock", "profiles")
-                            parameter("key", apiKey)
-                            parameter("uuid", uuid)
-                        }
-                    }
+                    val response = UrsaManager.request(listOf("v1", "hypixel","profiles", uuid.toString()))
                     if (!response.status.isSuccess()) {
                         launch(MinecraftDispatcher) {
                             @Suppress("DeferredResultUnused")
diff --git a/src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewer.kt b/src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewer.kt
index bebcbcc..5561476 100644
--- a/src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewer.kt
+++ b/src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewer.kt
@@ -9,7 +9,7 @@ package moe.nea.firmament.gui.profileviewer
 import io.github.cottonmc.cotton.gui.client.CottonClientScreen
 import io.github.cottonmc.cotton.gui.client.LightweightGuiDescription
 import io.github.cottonmc.cotton.gui.widget.WTabPanel
-import java.util.UUID
+import java.util.*
 import net.fabricmc.fabric.api.client.command.v2.FabricClientCommandSource
 import kotlinx.coroutines.launch
 import net.minecraft.text.Text
diff --git a/src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewerLibrary.kt b/src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewerLibrary.kt
new file mode 100644
index 0000000..3c49443
--- /dev/null
+++ b/src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewerLibrary.kt
@@ -0,0 +1,63 @@
+package moe.nea.firmament.gui.profileviewer
+
+import com.mojang.brigadier.StringReader
+import io.github.cottonmc.cotton.gui.client.CottonClientScreen
+import io.github.cottonmc.cotton.gui.client.LightweightGuiDescription
+import io.github.cottonmc.cotton.gui.widget.WGridPanel
+import io.github.cottonmc.cotton.gui.widget.WText
+import io.github.cottonmc.cotton.gui.widget.data.VerticalAlignment
+import moe.nea.firmament.gui.WTitledItem
+import moe.nea.firmament.util.ScreenUtil
+import moe.nea.firmament.util.modifyLore
+import moe.nea.lisp.LispData
+import moe.nea.lisp.LispExecutionContext
+import moe.nea.lisp.LispParser
+import moe.nea.lisp.bind.AutoBinder
+import moe.nea.lisp.bind.LispBinding
+import moe.nea.lisp.bind.UnmapForeignObject
+import net.minecraft.command.argument.ItemStringReader
+import net.minecraft.item.ItemStack
+import net.minecraft.registry.Registries
+import net.minecraft.text.Text
+
+class ProfileViewerLibrary {
+
+    @LispBinding("mk-item")
+    fun makeItem(itemType: String, title: String, vararg lore: String): LispData.ForeignObject<ItemStack> {
+        val item = ItemStringReader.item(Registries.ITEM.readOnlyWrapper, StringReader(itemType))
+        val itemStack = ItemStack(item.item.value())
+        itemStack.nbt = item.nbt
+        itemStack.modifyLore { lore.map { Text.literal(it) } }
+        itemStack.setCustomName(Text.literal(title))
+        return LispData.ForeignObject(itemStack)
+    }
+
+    @LispBinding("def-page")
+    fun defPage(name: String, @UnmapForeignObject icon: ItemStack) {
+        pages.add(Pair(name, icon))
+    }
+
+    val pages = mutableListOf<Pair<String, ItemStack>>()
+    val coreEnvironment = LispExecutionContext()
+
+    fun run() {
+        val t = coreEnvironment.genBindings()
+        val ab = AutoBinder()
+        ab.bindTo(this, t)
+        val prog = LispParser.parse(
+            "testfile.lisp", """
+        (def-page "Test" (mk-item "minecraft:tnt" "§aThis is a test page" "§aMore text"))
+        (def-page "Skills" (mk-item "minecraft:diamond_sword" "§aThis is a test page" "§aMore text"))
+        """.trimIndent()
+        )
+        coreEnvironment.executeProgram(t, prog)
+        val light = LightweightGuiDescription()
+        val root = light.rootPanel as WGridPanel
+        root.setGaps(8, 8)
+        pages.forEachIndexed { i, (name, item) ->
+            root.add(WTitledItem(item), 0, i)
+            root.add(WText(Text.literal(name)).also { it.verticalAlignment = VerticalAlignment.CENTER }, 1, i, 6, 1)
+        }
+        ScreenUtil.setScreenLater(CottonClientScreen(light))
+    }
+}
diff --git a/src/main/kotlin/moe/nea/firmament/jarvis/JarvisIntegration.kt b/src/main/kotlin/moe/nea/firmament/jarvis/JarvisIntegration.kt
index 9c27030..d760862 100644
--- a/src/main/kotlin/moe/nea/firmament/jarvis/JarvisIntegration.kt
+++ b/src/main/kotlin/moe/nea/firmament/jarvis/JarvisIntegration.kt
@@ -42,6 +42,10 @@ class JarvisIntegration : JarvisPlugin {
         }
     }
 
+    override fun onHudEditorClosed() {
+        configs.forEach { it.save() }
+    }
+
     override fun getAllConfigOptions(): List<JarvisConfigOption> {
         return configs.flatMap { config ->
             config.sortedOptions.map {
diff --git a/src/main/kotlin/moe/nea/firmament/util/SkyblockId.kt b/src/main/kotlin/moe/nea/firmament/util/SkyblockId.kt
index 51c8c22..fe2b4e5 100644
--- a/src/main/kotlin/moe/nea/firmament/util/SkyblockId.kt
+++ b/src/main/kotlin/moe/nea/firmament/util/SkyblockId.kt
@@ -28,7 +28,7 @@ import moe.nea.firmament.util.json.DashlessUUIDSerializer
 @JvmInline
 @Serializable
 value class SkyblockId(val neuItem: String) {
-    val identifier get() = Identifier("skyblockitem", neuItem.lowercase().replace(";", "__"))
+    val identifier get() = Identifier("skyblockitem", neuItem.lowercase().replace(";", "__").replace(":", "___"))
 
     /**
      * A bazaar stock item id, as returned by the HyPixel bazaar api endpoint.
-- 
cgit