mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 06:30:46 +01:00
ItemStack Tooltip API
This commit is contained in:
parent
eb68d0e1b5
commit
de70580ea9
4 changed files with 112 additions and 0 deletions
|
@ -0,0 +1,76 @@
|
||||||
|
package io.papermc.paper.inventory.tooltip;
|
||||||
|
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.jetbrains.annotations.Contract;
|
||||||
|
import org.jspecify.annotations.NullMarked;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Context for computing itemstack tooltips via
|
||||||
|
* {@link org.bukkit.inventory.ItemStack#computeTooltipLines(TooltipContext, Player)}
|
||||||
|
*/
|
||||||
|
@NullMarked
|
||||||
|
public interface TooltipContext {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new context with the given advanced and creative
|
||||||
|
* mode settings.
|
||||||
|
*
|
||||||
|
* @param advanced whether the context is for advanced tooltips
|
||||||
|
* @param creative whether the context is for the creative inventory
|
||||||
|
* @return a new context
|
||||||
|
*/
|
||||||
|
@Contract("_, _ -> new")
|
||||||
|
static TooltipContext create(final boolean advanced, final boolean creative) {
|
||||||
|
return new TooltipContextImpl(advanced, creative);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new context that is neither advanced nor creative.
|
||||||
|
*
|
||||||
|
* @return a new context
|
||||||
|
*/
|
||||||
|
@Contract("-> new")
|
||||||
|
static TooltipContext create() {
|
||||||
|
return new TooltipContextImpl(false, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns whether the context is for advanced
|
||||||
|
* tooltips.
|
||||||
|
* <p>
|
||||||
|
* Advanced tooltips are shown by default
|
||||||
|
* when a player has {@code F3+H} enabled.
|
||||||
|
*
|
||||||
|
* @return true if for advanced tooltips
|
||||||
|
*/
|
||||||
|
boolean isAdvanced();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns whether the context is for the creative
|
||||||
|
* mode inventory.
|
||||||
|
* <p>
|
||||||
|
* Creative tooltips are shown by default when a player is
|
||||||
|
* in the creative inventory.
|
||||||
|
*
|
||||||
|
* @return true if for creative mode inventory
|
||||||
|
*/
|
||||||
|
boolean isCreative();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a new context with {@link #isAdvanced()}
|
||||||
|
* set to true.
|
||||||
|
*
|
||||||
|
* @return a new context
|
||||||
|
*/
|
||||||
|
@Contract("-> new")
|
||||||
|
TooltipContext asAdvanced();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a new context with {@link #isCreative()}
|
||||||
|
* set to true.
|
||||||
|
*
|
||||||
|
* @return a new context
|
||||||
|
*/
|
||||||
|
@Contract("-> new")
|
||||||
|
TooltipContext asCreative();
|
||||||
|
}
|
|
@ -0,0 +1,17 @@
|
||||||
|
package io.papermc.paper.inventory.tooltip;
|
||||||
|
|
||||||
|
import org.jspecify.annotations.NullMarked;
|
||||||
|
|
||||||
|
@NullMarked
|
||||||
|
record TooltipContextImpl(boolean isAdvanced, boolean isCreative) implements TooltipContext {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TooltipContext asCreative() {
|
||||||
|
return new TooltipContextImpl(this.isAdvanced, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TooltipContext asAdvanced() {
|
||||||
|
return new TooltipContextImpl(true, this.isCreative);
|
||||||
|
}
|
||||||
|
}
|
|
@ -279,4 +279,6 @@ public interface UnsafeValues {
|
||||||
@org.jetbrains.annotations.ApiStatus.Internal
|
@org.jetbrains.annotations.ApiStatus.Internal
|
||||||
io.papermc.paper.plugin.lifecycle.event.LifecycleEventManager<org.bukkit.plugin.Plugin> createPluginLifecycleEventManager(final org.bukkit.plugin.java.JavaPlugin plugin, final java.util.function.BooleanSupplier registrationCheck);
|
io.papermc.paper.plugin.lifecycle.event.LifecycleEventManager<org.bukkit.plugin.Plugin> createPluginLifecycleEventManager(final org.bukkit.plugin.java.JavaPlugin plugin, final java.util.function.BooleanSupplier registrationCheck);
|
||||||
// Paper end - lifecycle event API
|
// Paper end - lifecycle event API
|
||||||
|
|
||||||
|
@NotNull java.util.List<net.kyori.adventure.text.Component> computeTooltipLines(@NotNull ItemStack itemStack, @NotNull io.papermc.paper.inventory.tooltip.TooltipContext tooltipContext, @Nullable org.bukkit.entity.Player player); // Paper - expose itemstack tooltip lines
|
||||||
}
|
}
|
||||||
|
|
|
@ -1124,4 +1124,21 @@ public class ItemStack implements Cloneable, ConfigurationSerializable, Translat
|
||||||
return type.isAir() || amount <= 0;
|
return type.isAir() || amount <= 0;
|
||||||
}
|
}
|
||||||
// Paper end
|
// Paper end
|
||||||
|
// Paper start - expose itemstack tooltip lines
|
||||||
|
/**
|
||||||
|
* Computes the tooltip lines for this stack.
|
||||||
|
* <p>
|
||||||
|
* <b>Disclaimer:</b>
|
||||||
|
* Tooltip contents are not guaranteed to be consistent across different
|
||||||
|
* Minecraft versions.
|
||||||
|
*
|
||||||
|
* @param tooltipContext the tooltip context
|
||||||
|
* @param player a player for player-specific tooltip lines
|
||||||
|
* @return an immutable list of components (can be empty)
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("deprecation") // abusing unsafe as a bridge
|
||||||
|
public java.util.@NotNull @org.jetbrains.annotations.Unmodifiable List<net.kyori.adventure.text.Component> computeTooltipLines(final @NotNull io.papermc.paper.inventory.tooltip.TooltipContext tooltipContext, final @Nullable org.bukkit.entity.Player player) {
|
||||||
|
return Bukkit.getUnsafe().computeTooltipLines(this, tooltipContext, player);
|
||||||
|
}
|
||||||
|
// Paper end - expose itemstack tooltip lines
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue