Revive old profile viewer
This commit is contained in:
@@ -82,7 +82,6 @@ val hotswap by configurations.creating {
|
||||
}
|
||||
|
||||
val nonModImplentation by configurations.creating {
|
||||
extendsFrom(shadowMe)
|
||||
configurations.implementation.get().extendsFrom(this)
|
||||
}
|
||||
|
||||
@@ -106,6 +105,8 @@ dependencies {
|
||||
implementation(libs.mixinextras)
|
||||
include(libs.mixinextras)
|
||||
|
||||
nonModImplentation(libs.nealisp)
|
||||
shadowMe(libs.nealisp)
|
||||
|
||||
modApi(libs.fabric.api)
|
||||
modApi(libs.architectury)
|
||||
@@ -117,7 +118,9 @@ dependencies {
|
||||
exclude(module = "architectury")
|
||||
exclude(module = "architectury-fabric")
|
||||
}
|
||||
nonModImplentation(libs.repoparser)
|
||||
shadowMe(libs.repoparser)
|
||||
nonModImplentation(libs.bundles.dbus)
|
||||
shadowMe(libs.bundles.dbus)
|
||||
|
||||
fun ktor(mod: String) = "io.ktor:ktor-$mod-jvm:${libs.versions.ktor.get()}"
|
||||
|
||||
@@ -24,6 +24,7 @@ freecammod = "1.2.0-mc1.20"
|
||||
ncr = "Fabric-1.20-v2.2.0"
|
||||
mixinextras = "0.2.0-beta.9"
|
||||
jarvis = "1.1.1"
|
||||
nealisp = "1.0.0"
|
||||
|
||||
|
||||
[libraries]
|
||||
@@ -40,6 +41,7 @@ libgui = { module = "io.github.cottonmc:LibGui", version.ref = "libgui" }
|
||||
mixinextras = { module = "com.github.llamalad7.mixinextras:mixinextras-fabric", version.ref = "mixinextras" }
|
||||
jarvis_api = { module = "moe.nea.jarvis:jarvis-api", version.ref = "jarvis" }
|
||||
jarvis_fabric = { module = "moe.nea.jarvis:jarvis-fabric", version.ref = "jarvis" }
|
||||
nealisp = { module = "moe.nea:nealisp", version.ref = "nealisp" }
|
||||
|
||||
# Runtime:
|
||||
hotswap = { module = "virtual.github.hotswapagent:hotswap-agent", version.ref = "hotswap_agent" }
|
||||
|
||||
@@ -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")
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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))
|
||||
}
|
||||
}
|
||||
@@ -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 {
|
||||
|
||||
@@ -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.
|
||||
|
||||
Reference in New Issue
Block a user