mirror of
https://github.com/GeyserMC/Geyser.git
synced 2025-01-09 19:49:24 +01:00
Fix attribute display text
This commit is contained in:
parent
29a613b85c
commit
60f8532be3
1 changed files with 17 additions and 4 deletions
|
@ -62,6 +62,7 @@ import org.geysermc.mcprotocollib.protocol.data.game.item.component.ItemAttribut
|
||||||
|
|
||||||
import java.text.DecimalFormat;
|
import java.text.DecimalFormat;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.EnumMap;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -71,9 +72,21 @@ public final class ItemTranslator {
|
||||||
/**
|
/**
|
||||||
* The order of these slots is their display order on Java Edition clients
|
* The order of these slots is their display order on Java Edition clients
|
||||||
*/
|
*/
|
||||||
private static final ItemAttributeModifiers.EquipmentSlotGroup[] ALL_SLOTS = ItemAttributeModifiers.EquipmentSlotGroup.values();
|
private static final EnumMap<ItemAttributeModifiers.EquipmentSlotGroup, String> SLOT_NAMES;
|
||||||
private static final DecimalFormat ATTRIBUTE_FORMAT = new DecimalFormat("0.#####");
|
private static final DecimalFormat ATTRIBUTE_FORMAT = new DecimalFormat("0.#####");
|
||||||
|
|
||||||
|
static {
|
||||||
|
// These are the only slots that are used and have translation strings
|
||||||
|
SLOT_NAMES = new EnumMap<>(ItemAttributeModifiers.EquipmentSlotGroup.class);
|
||||||
|
SLOT_NAMES.put(ItemAttributeModifiers.EquipmentSlotGroup.MAIN_HAND, "mainhand");
|
||||||
|
SLOT_NAMES.put(ItemAttributeModifiers.EquipmentSlotGroup.OFF_HAND, "offhand");
|
||||||
|
SLOT_NAMES.put(ItemAttributeModifiers.EquipmentSlotGroup.FEET, "feet");
|
||||||
|
SLOT_NAMES.put(ItemAttributeModifiers.EquipmentSlotGroup.LEGS, "legs");
|
||||||
|
SLOT_NAMES.put(ItemAttributeModifiers.EquipmentSlotGroup.CHEST, "chest");
|
||||||
|
SLOT_NAMES.put(ItemAttributeModifiers.EquipmentSlotGroup.HEAD, "head");
|
||||||
|
SLOT_NAMES.put(ItemAttributeModifiers.EquipmentSlotGroup.BODY, "body");
|
||||||
|
}
|
||||||
|
|
||||||
private ItemTranslator() {
|
private ItemTranslator() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -208,7 +221,7 @@ public final class ItemTranslator {
|
||||||
ItemAttributeModifiers.EquipmentSlotGroup slotGroup = entry.getSlot();
|
ItemAttributeModifiers.EquipmentSlotGroup slotGroup = entry.getSlot();
|
||||||
if (slotGroup == ItemAttributeModifiers.EquipmentSlotGroup.ANY) {
|
if (slotGroup == ItemAttributeModifiers.EquipmentSlotGroup.ANY) {
|
||||||
// modifier applies to all slots implicitly
|
// modifier applies to all slots implicitly
|
||||||
for (var slot : ALL_SLOTS) {
|
for (var slot : SLOT_NAMES.keySet()) {
|
||||||
slotsToModifiers.computeIfAbsent(slot, s -> new ArrayList<>()).add(loreEntry);
|
slotsToModifiers.computeIfAbsent(slot, s -> new ArrayList<>()).add(loreEntry);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -218,7 +231,7 @@ public final class ItemTranslator {
|
||||||
}
|
}
|
||||||
|
|
||||||
// iterate through the small array, not the map, so that ordering matches Java Edition
|
// iterate through the small array, not the map, so that ordering matches Java Edition
|
||||||
for (var slot : ALL_SLOTS) {
|
for (var slot : SLOT_NAMES.keySet()) {
|
||||||
List<String> modifierStrings = slotsToModifiers.get(slot);
|
List<String> modifierStrings = slotsToModifiers.get(slot);
|
||||||
if (modifierStrings == null || modifierStrings.isEmpty()) {
|
if (modifierStrings == null || modifierStrings.isEmpty()) {
|
||||||
continue;
|
continue;
|
||||||
|
@ -228,7 +241,7 @@ public final class ItemTranslator {
|
||||||
Component slotComponent = Component.text()
|
Component slotComponent = Component.text()
|
||||||
.resetStyle()
|
.resetStyle()
|
||||||
.color(NamedTextColor.GRAY)
|
.color(NamedTextColor.GRAY)
|
||||||
.append(Component.newline(), Component.translatable("item.modifiers." + slot))
|
.append(Component.newline(), Component.translatable("item.modifiers." + SLOT_NAMES.get(slot)))
|
||||||
.build();
|
.build();
|
||||||
builder.getOrCreateLore().add(MessageTranslator.convertMessage(slotComponent, language));
|
builder.getOrCreateLore().add(MessageTranslator.convertMessage(slotComponent, language));
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue