mirror of
https://github.com/CitizensDev/Citizens2.git
synced 2025-02-23 07:41:29 +01:00
Fix /npc shop edit multiline item descriptions
This commit is contained in:
parent
9bb88a6db1
commit
ba74dc8ad2
@ -44,8 +44,6 @@ public class HologramTrait extends Trait {
|
||||
private BiFunction<String, Player, String> customHologramSupplier;
|
||||
@Persist
|
||||
private HologramDirection direction = HologramDirection.BOTTOM_UP;
|
||||
@Persist(reify = true)
|
||||
private HologramFilter filter;
|
||||
private double lastEntityHeight = 0;
|
||||
private boolean lastNameplateVisible;
|
||||
@Persist
|
||||
@ -323,6 +321,7 @@ public class HologramTrait extends Trait {
|
||||
if (updatePosition && !useDisplayEntities) {
|
||||
nameLine.hologram.teleport(currentLoc.clone().add(0, getEntityHeight(), 0), TeleportCause.PLUGIN);
|
||||
}
|
||||
|
||||
if (updateName) {
|
||||
nameLine.setText(npc.getRawName());
|
||||
}
|
||||
@ -453,17 +452,6 @@ public class HologramTrait extends Trait {
|
||||
TOP_DOWN;
|
||||
}
|
||||
|
||||
public static class HologramFilter {
|
||||
private HologramFilter() {
|
||||
}
|
||||
|
||||
public static class Builder {
|
||||
public HologramFilter build() {
|
||||
return new HologramFilter();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private class HologramLine implements Function<Player, String> {
|
||||
NPC hologram;
|
||||
double mb, mt;
|
||||
|
@ -135,13 +135,16 @@ public class ShopTrait extends Trait {
|
||||
public void display(Player sender) {
|
||||
if (viewPermission != null && !sender.hasPermission(viewPermission))
|
||||
return;
|
||||
|
||||
if (!Setting.SHOP_GLOBAL_VIEW_PERMISSION.asString().isEmpty()
|
||||
&& !sender.hasPermission(Setting.SHOP_GLOBAL_VIEW_PERMISSION.asString()))
|
||||
return;
|
||||
|
||||
if (pages.size() == 0) {
|
||||
Messaging.sendError(sender, "Empty shop");
|
||||
return;
|
||||
}
|
||||
|
||||
InventoryMenu.createSelfRegistered(new NPCShopViewer(this, sender)).present(sender);
|
||||
}
|
||||
|
||||
@ -294,6 +297,8 @@ public class ShopTrait extends Trait {
|
||||
}
|
||||
|
||||
public static class NPCShopItem implements Cloneable, Persistable {
|
||||
@Persist
|
||||
private String alreadyPurchasedMessage;
|
||||
@Persist
|
||||
private String clickToConfirmMessage;
|
||||
@Persist
|
||||
@ -304,16 +309,14 @@ public class ShopTrait extends Trait {
|
||||
private ItemStack display;
|
||||
@Persist
|
||||
private boolean maxRepeatsOnShiftClick;
|
||||
@Persist(keyType = UUID.class)
|
||||
private final Map<UUID, Integer> purchases = Maps.newHashMap();
|
||||
@Persist
|
||||
private final List<NPCShopAction> result = Lists.newArrayList();
|
||||
@Persist
|
||||
private String resultMessage;
|
||||
@Persist
|
||||
private int timesPurchasable = 0;
|
||||
@Persist
|
||||
private String alreadyPurchasedMessage;
|
||||
@Persist(keyType = UUID.class)
|
||||
private final Map<UUID, Integer> purchases = Maps.newHashMap();
|
||||
|
||||
public List<Transaction> apply(List<NPCShopAction> actions, Function<NPCShopAction, Transaction> func) {
|
||||
List<Transaction> pending = Lists.newArrayList();
|
||||
@ -402,16 +405,15 @@ public class ShopTrait extends Trait {
|
||||
|
||||
public void onClick(NPCShop shop, InventoryClickEvent event, boolean secondClick) {
|
||||
Player player = (Player) event.getWhoClicked();
|
||||
if (purchases.containsKey(player.getUniqueId()) && timesPurchasable > 0 && purchases.get(player.getUniqueId()) == timesPurchasable) {
|
||||
if (purchases.containsKey(player.getUniqueId()) && timesPurchasable > 0
|
||||
&& purchases.get(player.getUniqueId()) == timesPurchasable) {
|
||||
if (alreadyPurchasedMessage != null) {
|
||||
Messaging.sendColorless(event.getWhoClicked(),
|
||||
placeholders(alreadyPurchasedMessage, player));
|
||||
Messaging.sendColorless(event.getWhoClicked(), placeholders(alreadyPurchasedMessage, player));
|
||||
}
|
||||
return;
|
||||
}
|
||||
if (clickToConfirmMessage != null && !secondClick) {
|
||||
Messaging.sendColorless(event.getWhoClicked(),
|
||||
placeholders(clickToConfirmMessage, player));
|
||||
Messaging.sendColorless(event.getWhoClicked(), placeholders(clickToConfirmMessage, player));
|
||||
return;
|
||||
}
|
||||
int max = Integer.MAX_VALUE;
|
||||
@ -429,8 +431,7 @@ public class ShopTrait extends Trait {
|
||||
List<Transaction> take = apply(cost, action -> action.take(event.getWhoClicked(), repeats));
|
||||
if (take == null) {
|
||||
if (costMessage != null) {
|
||||
Messaging.sendColorless(event.getWhoClicked(),
|
||||
placeholders(costMessage, player));
|
||||
Messaging.sendColorless(event.getWhoClicked(), placeholders(costMessage, player));
|
||||
}
|
||||
return;
|
||||
}
|
||||
@ -439,11 +440,11 @@ public class ShopTrait extends Trait {
|
||||
return;
|
||||
}
|
||||
if (resultMessage != null) {
|
||||
Messaging.sendColorless(event.getWhoClicked(),
|
||||
placeholders(resultMessage, player));
|
||||
Messaging.sendColorless(event.getWhoClicked(), placeholders(resultMessage, player));
|
||||
}
|
||||
if (timesPurchasable > 0) {
|
||||
int timesPurchasedAlready = purchases.get(player.getUniqueId()) == null ? 0 : purchases.get(player.getUniqueId());
|
||||
int timesPurchasedAlready = purchases.get(player.getUniqueId()) == null ? 0
|
||||
: purchases.get(player.getUniqueId());
|
||||
purchases.put(player.getUniqueId(), ++timesPurchasedAlready);
|
||||
}
|
||||
}
|
||||
@ -496,17 +497,18 @@ public class ShopTrait extends Trait {
|
||||
if (modified.display != null) {
|
||||
ctx.getSlot(9 * 4 + 4).setItemStack(modified.getDisplayItem(null));
|
||||
}
|
||||
ctx.getSlot(9 * 3 + 2).setItemStack(new ItemStack(Material.EGG),
|
||||
"Only purchasable once per player",
|
||||
"Times purchasable: " + modified.timesPurchasable + (modified.timesPurchasable == 0 ? " (no limit)" : ""));
|
||||
ctx.getSlot(9 * 3 + 2).setClickHandler(
|
||||
e -> ctx.getMenu().transition(InputMenus.stringSetter(() -> String.valueOf(modified.timesPurchasable), s -> {
|
||||
ctx.getSlot(9 * 3 + 2).setItemStack(new ItemStack(Material.EGG), "Only purchasable once per player",
|
||||
"Times purchasable: " + modified.timesPurchasable
|
||||
+ (modified.timesPurchasable == 0 ? " (no limit)" : ""));
|
||||
ctx.getSlot(9 * 3 + 2).setClickHandler(e -> ctx.getMenu()
|
||||
.transition(InputMenus.stringSetter(() -> String.valueOf(modified.timesPurchasable), s -> {
|
||||
modified.timesPurchasable = Integer.parseInt(s);
|
||||
ctx.getSlot(9 * 4 + 2).setDescription("Times purchasable: " + modified.timesPurchasable + (modified.timesPurchasable == 0 ? " (no limit)" : ""));
|
||||
ctx.getSlot(9 * 4 + 2).setDescription("Times purchasable: " + modified.timesPurchasable
|
||||
+ (modified.timesPurchasable == 0 ? " (no limit)" : ""));
|
||||
})));
|
||||
|
||||
ctx.getSlot(9 * 4 + 2).setItemStack(new ItemStack(Util.getFallbackMaterial("OAK_SIGN", "SIGN")),
|
||||
"Set message to send on already purchased, currently:\n",
|
||||
"Set already purchased message, currently:\n",
|
||||
modified.alreadyPurchasedMessage == null ? "Unset" : modified.alreadyPurchasedMessage);
|
||||
ctx.getSlot(9 * 4 + 2).setClickHandler(
|
||||
e -> ctx.getMenu().transition(InputMenus.stringSetter(() -> modified.alreadyPurchasedMessage, s -> {
|
||||
@ -514,8 +516,8 @@ public class ShopTrait extends Trait {
|
||||
ctx.getSlot(9 * 4 + 2).setDescription(modified.alreadyPurchasedMessage);
|
||||
})));
|
||||
|
||||
ctx.getSlot(9 * 3 + 3).setItemStack(new ItemStack(Util.getFallbackMaterial("OAK_SIGN", "SIGN")),
|
||||
"Set message to send on successful click, currently:\n",
|
||||
ctx.getSlot(9 * 3 + 3).setItemStack(new ItemStack(Util.getFallbackMaterial("EMERALD", "OAK_SIGN", "SIGN")),
|
||||
"Set successful click message, currently:\n",
|
||||
modified.resultMessage == null ? "Unset" : modified.resultMessage);
|
||||
ctx.getSlot(9 * 3 + 3).setClickHandler(
|
||||
e -> ctx.getMenu().transition(InputMenus.stringSetter(() -> modified.resultMessage, s -> {
|
||||
@ -524,7 +526,7 @@ public class ShopTrait extends Trait {
|
||||
})));
|
||||
|
||||
ctx.getSlot(9 * 3 + 6).setItemStack(new ItemStack(Util.getFallbackMaterial("BARRIER", "FIRE")),
|
||||
"Set message to send on unsuccessful click, currently:\n",
|
||||
"Set unsuccessful click message, currently:\n",
|
||||
modified.costMessage == null ? "Unset" : modified.costMessage);
|
||||
ctx.getSlot(9 * 3 + 6).setClickHandler(
|
||||
e -> ctx.getMenu().transition(InputMenus.stringSetter(() -> modified.costMessage, s -> {
|
||||
@ -590,8 +592,8 @@ public class ShopTrait extends Trait {
|
||||
? Joiner.on("<br>").skipNulls().join(modified.display.getItemMeta().getLore())
|
||||
: "", description -> {
|
||||
ItemMeta meta = modified.display.getItemMeta();
|
||||
meta.setLore(Lists.newArrayList(
|
||||
Splitter.on("<br>").split(Messaging.parseComponents(description))));
|
||||
meta.setLore(Lists
|
||||
.newArrayList(Splitter.on('\n').split(Messaging.parseComponents(description))));
|
||||
modified.display.setItemMeta(meta);
|
||||
}));
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user