1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
package moe.nea.firmament.features.inventory
import org.joml.Vector2i
import net.minecraft.item.ItemStack
import net.minecraft.text.Text
import net.minecraft.util.Formatting
import moe.nea.firmament.Firmament
import moe.nea.firmament.annotations.Subscribe
import moe.nea.firmament.events.HudRenderEvent
import moe.nea.firmament.events.SlotRenderEvents
import moe.nea.firmament.jarvis.JarvisIntegration
import moe.nea.firmament.util.FirmFormatters.formatPercent
import moe.nea.firmament.util.FirmFormatters.shortFormat
import moe.nea.firmament.util.MC
import moe.nea.firmament.util.SBData
import moe.nea.firmament.util.data.Config
import moe.nea.firmament.util.data.ManagedConfig
import moe.nea.firmament.util.petData
import moe.nea.firmament.util.render.drawGuiTexture
import moe.nea.firmament.util.skyblock.Rarity
import moe.nea.firmament.util.titleCase
import moe.nea.firmament.util.useMatch
import moe.nea.firmament.util.withColor
object PetFeatures {
val identifier: String
get() = "pets"
@Config
object TConfig : ManagedConfig(identifier, Category.INVENTORY) {
val highlightEquippedPet by toggle("highlight-pet") { true }
var petOverlay by toggle("pet-overlay") { false }
val petOverlayHud by position("pet-overlay-hud", 80, 10) {
Vector2i()
}
}
val petMenuTitle = "Pets(?: \\([0-9]+/[0-9]+\\))?".toPattern()
var petItemStack: ItemStack? = null
@Subscribe
fun onSlotRender(event: SlotRenderEvents.Before) {
if (!TConfig.highlightEquippedPet) return
val stack = event.slot.stack
if (stack.petData?.active == true)
petMenuTitle.useMatch(MC.screenName ?: return) {
petItemStack = stack
event.context.drawGuiTexture(
Firmament.identifier("selected_pet_background"),
event.slot.x, event.slot.y, 16, 16,
)
}
}
@Subscribe
fun onRenderHud(it: HudRenderEvent) {
if (!TConfig.petOverlay || !SBData.isOnSkyblock) return
val itemStack = petItemStack ?: return
val petData = petItemStack?.petData ?: return
val rarity = Rarity.fromNeuRepo(petData.tier)
val rarityCode = Rarity.colourMap[rarity] ?: Formatting.WHITE
val xp = petData.level
val petType = titleCase(petData.type)
val heldItem = petData.heldItem?.let { item -> "Held Item: ${titleCase(item)}" }
it.context.matrices.pushMatrix()
TConfig.petOverlayHud.applyTransformations(JarvisIntegration.jarvis, it.context.matrices)
val lines = mutableListOf<Text>()
it.context.matrices.pushMatrix()
it.context.matrices.translate(-0.5F, -0.5F)
it.context.matrices.scale(2f, 2f)
it.context.drawItem(itemStack, 0, 0)
it.context.matrices.popMatrix()
lines.add(Text.literal("[Lvl ${xp.currentLevel}] ").append(Text.literal(petType).withColor(rarityCode)))
if (heldItem != null) lines.add(Text.literal(heldItem))
if (xp.currentLevel != xp.maxLevel) lines.add(
Text.literal(
"Required L${xp.currentLevel + 1}: ${shortFormat(xp.expInCurrentLevel.toDouble())}/${
shortFormat(
xp.expRequiredForNextLevel.toDouble()
)
} (${formatPercent(xp.percentageToNextLevel.toDouble())})"
)
)
lines.add(
Text.literal(
"Required L100: ${shortFormat(xp.expTotal.toDouble())}/${shortFormat(xp.expRequiredForMaxLevel.toDouble())} (${
formatPercent(
xp.percentageToMaxLevel.toDouble()
)
})"
)
)
for ((index, line) in lines.withIndex()) {
it.context.drawText(
MC.font,
line.copy().withColor(Formatting.GRAY),
36,
MC.font.fontHeight * index,
-1,
true
)
}
it.context.matrices.popMatrix()
}
}
|