From 446eeb7512a61aa59b292f361fea05b2b48405b3 Mon Sep 17 00:00:00 2001 From: Kiran Hart Date: Mon, 19 Jul 2021 14:32:21 -0400 Subject: [PATCH] 2.21.1 --- pom.xml | 4 +- .../auctionhouse/auction/AuctionPlayer.java | 15 +++-- .../auctionhouse/commands/CommandSell.java | 4 ++ .../auctionhouse/guis/GUIActiveAuctions.java | 19 ++----- .../auctionhouse/guis/GUIAuctionHouse.java | 26 ++++----- .../auctionhouse/guis/GUIExpiredItems.java | 56 ++++++++++--------- .../auctionhouse/guis/GUISellItem.java | 14 +++-- .../guis/confirmation/GUIConfirmPurchase.java | 18 +++--- .../auctionhouse/settings/Settings.java | 8 ++- 9 files changed, 88 insertions(+), 76 deletions(-) diff --git a/pom.xml b/pom.xml index f5d4768..62973e9 100644 --- a/pom.xml +++ b/pom.xml @@ -6,7 +6,7 @@ 4.0.0 ca.tweetzy auctionhouse - 2.20.3 + 2.21.1 UTF-8 @@ -137,7 +137,7 @@ ca.tweetzy tweetycore - 2.5.2 + 2.5.3 com.github.MilkBowl diff --git a/src/main/java/ca/tweetzy/auctionhouse/auction/AuctionPlayer.java b/src/main/java/ca/tweetzy/auctionhouse/auction/AuctionPlayer.java index cff3dd3..644089a 100644 --- a/src/main/java/ca/tweetzy/auctionhouse/auction/AuctionPlayer.java +++ b/src/main/java/ca/tweetzy/auctionhouse/auction/AuctionPlayer.java @@ -6,10 +6,7 @@ import lombok.Getter; import lombok.Setter; import org.bukkit.entity.Player; -import java.util.ArrayList; -import java.util.Collections; -import java.util.List; -import java.util.stream.Collectors; +import java.util.*; /** * The current file has been created by Kiran Hart @@ -35,7 +32,15 @@ public class AuctionPlayer { } public List getItems(boolean getExpired) { - return AuctionHouse.getInstance().getAuctionItemManager().getAuctionItems().values().stream().filter(item -> item.getOwner().equals(this.player.getUniqueId()) && !AuctionHouse.getInstance().getAuctionItemManager().getGarbageBin().contains(item) && item.isExpired() == getExpired).collect(Collectors.toList()); + List items = new ArrayList<>(); + + for (Map.Entry entry : AuctionHouse.getInstance().getAuctionItemManager().getAuctionItems().entrySet()) { + AuctionItem auctionItem = entry.getValue(); + if (auctionItem.getOwner().equals(this.player.getUniqueId()) && auctionItem.isExpired() == getExpired && !AuctionHouse.getInstance().getAuctionItemManager().getGarbageBin().containsKey(auctionItem.getKey())) { + items.add(auctionItem); + } + } + return items; } public void resetFilter() { diff --git a/src/main/java/ca/tweetzy/auctionhouse/commands/CommandSell.java b/src/main/java/ca/tweetzy/auctionhouse/commands/CommandSell.java index bff351d..5502b95 100644 --- a/src/main/java/ca/tweetzy/auctionhouse/commands/CommandSell.java +++ b/src/main/java/ca/tweetzy/auctionhouse/commands/CommandSell.java @@ -57,6 +57,10 @@ public class CommandSell extends AbstractCommand { // open the sell menu if its 0; if (args.length == 0) { + if (!Settings.ALLOW_USAGE_OF_SELL_GUI.getBoolean()) { + return ReturnType.SYNTAX_ERROR; + } + if (itemToSell.getType() == XMaterial.AIR.parseMaterial() && Settings.SELL_MENU_REQUIRES_USER_TO_HOLD_ITEM.getBoolean()) { AuctionHouse.getInstance().getLocale().getMessage("general.air").sendPrefixedMessage(player); return ReturnType.FAILURE; diff --git a/src/main/java/ca/tweetzy/auctionhouse/guis/GUIActiveAuctions.java b/src/main/java/ca/tweetzy/auctionhouse/guis/GUIActiveAuctions.java index f709eca..10c6860 100644 --- a/src/main/java/ca/tweetzy/auctionhouse/guis/GUIActiveAuctions.java +++ b/src/main/java/ca/tweetzy/auctionhouse/guis/GUIActiveAuctions.java @@ -27,12 +27,10 @@ import java.util.stream.Collectors; */ public class GUIActiveAuctions extends Gui { - final AuctionPlayer auctionPlayer; - + private final AuctionPlayer auctionPlayer; private BukkitTask task; - private int taskId; - List items; + private List items; public GUIActiveAuctions(AuctionPlayer auctionPlayer) { this.auctionPlayer = auctionPlayer; @@ -69,6 +67,7 @@ public class GUIActiveAuctions extends Gui { if (((item.getBidStartPrice() > 0 || item.getBidIncPrice() > 0) && Settings.ASK_FOR_CANCEL_CONFIRM_ON_BID_ITEMS.getBoolean()) || Settings.ASK_FOR_CANCEL_CONFIRM_ON_NON_BID_ITEMS.getBoolean()) { if (item.getHighestBidder().equals(e.player.getUniqueId())) { item.setExpired(true); + item.setRemainingTime(0); draw(); return; } @@ -119,18 +118,10 @@ public class GUIActiveAuctions extends Gui { ====================== AUTO REFRESH ====================== */ private void makeMess() { - if (Settings.USE_ASYNC_GUI_REFRESH.getBoolean()) { - task = Bukkit.getServer().getScheduler().runTaskTimerAsynchronously(AuctionHouse.getInstance(), this::drawItems, 0L, (long) 20 * Settings.TICK_UPDATE_GUI_TIME.getInt()); - } else { - taskId = Bukkit.getServer().getScheduler().scheduleSyncRepeatingTask(AuctionHouse.getInstance(), this::drawItems, 0L, (long) 20 * Settings.TICK_UPDATE_GUI_TIME.getInt()); - } + task = Bukkit.getServer().getScheduler().runTaskTimerAsynchronously(AuctionHouse.getInstance(), this::drawItems, 0L, (long) 20 * Settings.TICK_UPDATE_GUI_TIME.getInt()); } private void cleanup() { - if (Settings.USE_ASYNC_GUI_REFRESH.getBoolean()) { - task.cancel(); - } else { - Bukkit.getServer().getScheduler().cancelTask(taskId); - } + task.cancel(); } } diff --git a/src/main/java/ca/tweetzy/auctionhouse/guis/GUIAuctionHouse.java b/src/main/java/ca/tweetzy/auctionhouse/guis/GUIAuctionHouse.java index 4218115..476bb41 100644 --- a/src/main/java/ca/tweetzy/auctionhouse/guis/GUIAuctionHouse.java +++ b/src/main/java/ca/tweetzy/auctionhouse/guis/GUIAuctionHouse.java @@ -11,6 +11,7 @@ import ca.tweetzy.auctionhouse.helpers.ConfigurationItemHelper; import ca.tweetzy.auctionhouse.managers.SoundManager; import ca.tweetzy.auctionhouse.settings.Settings; import ca.tweetzy.core.compatibility.ServerVersion; +import ca.tweetzy.core.compatibility.XMaterial; import ca.tweetzy.core.gui.Gui; import ca.tweetzy.core.gui.events.GuiClickEvent; import ca.tweetzy.core.utils.TextUtils; @@ -38,7 +39,6 @@ public class GUIAuctionHouse extends Gui { final AuctionPlayer auctionPlayer; private List items; - private int taskId; private BukkitTask task; private String searchPhrase = ""; @@ -67,7 +67,6 @@ public class GUIAuctionHouse extends Gui { drawItems(); } - // TODO FIX VISUAL BUG THAT MAKES IT LOOK THERE IS A DUPLICATED ITEM private void drawItems() { AuctionHouse.newChain().asyncFirst(() -> { this.items = new ArrayList<>(); @@ -307,7 +306,16 @@ public class GUIAuctionHouse extends Gui { put("%total_items_sold%", AuctionHouse.getInstance().getTransactionManager().getTotalItemsSold(auctionPlayer.getPlayer().getUniqueId())); }}), e -> e.manager.showGUI(e.player, new GUITransactionList(this.auctionPlayer))); - setButton(5, 7, ConfigurationItemHelper.createConfigurationItem(Settings.GUI_AUCTION_HOUSE_ITEMS_HOW_TO_SELL_ITEM.getString(), Settings.GUI_AUCTION_HOUSE_ITEMS_HOW_TO_SELL_NAME.getString(), Settings.GUI_AUCTION_HOUSE_ITEMS_HOW_TO_SELL_LORE.getStringList(), null), null); + if (Settings.REPLACE_HOW_TO_SELL_WITH_LIST_BUTTON.getBoolean()) { + setButton(5, 7, ConfigurationItemHelper.createConfigurationItem(Settings.GUI_AUCTION_HOUSE_ITEMS_LIST_ITEM_ITEM.getString(), Settings.GUI_AUCTION_HOUSE_ITEMS_LIST_ITEM_NAME.getString(), Settings.GUI_AUCTION_HOUSE_ITEMS_LIST_ITEM_LORE.getStringList(), null), e -> { + // using this will ignore the "SELL_MENU_REQUIRES_USER_TO_HOLD_ITEM" setting + AuctionHouse.getInstance().getGuiManager().showGUI(e.player, new GUISellItem(auctionPlayer, XMaterial.AIR.parseItem())); + AuctionHouse.getInstance().getAuctionPlayerManager().addItemToSellHolding(e.player.getUniqueId(), XMaterial.AIR.parseItem()); + }); + } else { + setButton(5, 7, ConfigurationItemHelper.createConfigurationItem(Settings.GUI_AUCTION_HOUSE_ITEMS_HOW_TO_SELL_ITEM.getString(), Settings.GUI_AUCTION_HOUSE_ITEMS_HOW_TO_SELL_NAME.getString(), Settings.GUI_AUCTION_HOUSE_ITEMS_HOW_TO_SELL_LORE.getStringList(), null), null); + } + setButton(5, 8, ConfigurationItemHelper.createConfigurationItem(Settings.GUI_AUCTION_HOUSE_ITEMS_GUIDE_ITEM.getString(), Settings.GUI_AUCTION_HOUSE_ITEMS_GUIDE_NAME.getString(), Settings.GUI_AUCTION_HOUSE_ITEMS_GUIDE_LORE.getStringList(), null), null); setButton(5, 4, new TItemBuilder(Objects.requireNonNull(Settings.GUI_REFRESH_BTN_ITEM.getMaterial().parseMaterial())).setName(Settings.GUI_REFRESH_BTN_NAME.getString()).setLore(Settings.GUI_REFRESH_BTN_LORE.getStringList()).toItemStack(), e -> { @@ -422,19 +430,11 @@ public class GUIAuctionHouse extends Gui { ====================== AUTO REFRESH ====================== */ private void makeMess() { - if (Settings.USE_ASYNC_GUI_REFRESH.getBoolean()) { - task = Bukkit.getServer().getScheduler().runTaskTimerAsynchronously(AuctionHouse.getInstance(), this::drawItems, 0L, (long) 20 * Settings.TICK_UPDATE_GUI_TIME.getInt()); - } else { - taskId = Bukkit.getServer().getScheduler().scheduleSyncRepeatingTask(AuctionHouse.getInstance(), this::drawItems, 0L, (long) 20 * Settings.TICK_UPDATE_GUI_TIME.getInt()); - } + task = Bukkit.getServer().getScheduler().runTaskTimerAsynchronously(AuctionHouse.getInstance(), this::drawItems, 0L, (long) 20 * Settings.TICK_UPDATE_GUI_TIME.getInt()); } private void cleanup() { - if (Settings.USE_ASYNC_GUI_REFRESH.getBoolean()) { - task.cancel(); - } else { - Bukkit.getServer().getScheduler().cancelTask(taskId); - } + task.cancel(); } } diff --git a/src/main/java/ca/tweetzy/auctionhouse/guis/GUIExpiredItems.java b/src/main/java/ca/tweetzy/auctionhouse/guis/GUIExpiredItems.java index 16aeedb..8731ce0 100644 --- a/src/main/java/ca/tweetzy/auctionhouse/guis/GUIExpiredItems.java +++ b/src/main/java/ca/tweetzy/auctionhouse/guis/GUIExpiredItems.java @@ -26,6 +26,7 @@ import java.util.stream.Collectors; public class GUIExpiredItems extends Gui { final AuctionPlayer auctionPlayer; + private List items; public GUIExpiredItems(AuctionPlayer auctionPlayer) { this.auctionPlayer = auctionPlayer; @@ -38,34 +39,39 @@ public class GUIExpiredItems extends Gui { private void draw() { reset(); - // Pagination - pages = (int) Math.max(1, Math.ceil(this.auctionPlayer.getItems(true).size() / (double) 45)); - setPrevPage(5, 3, new TItemBuilder(Objects.requireNonNull(Settings.GUI_BACK_BTN_ITEM.getMaterial().parseMaterial())).setName(Settings.GUI_BACK_BTN_NAME.getString()).setLore(Settings.GUI_BACK_BTN_LORE.getStringList()).toItemStack()); - setButton(5, 4, new TItemBuilder(Objects.requireNonNull(Settings.GUI_REFRESH_BTN_ITEM.getMaterial().parseMaterial())).setName(Settings.GUI_REFRESH_BTN_NAME.getString()).setLore(Settings.GUI_REFRESH_BTN_LORE.getStringList()).toItemStack(), e -> draw()); - setNextPage(5, 5, new TItemBuilder(Objects.requireNonNull(Settings.GUI_NEXT_BTN_ITEM.getMaterial().parseMaterial())).setName(Settings.GUI_NEXT_BTN_NAME.getString()).setLore(Settings.GUI_NEXT_BTN_LORE.getStringList()).toItemStack()); - setOnPage(e -> { - draw(); - SoundManager.getInstance().playSound(this.auctionPlayer.getPlayer(), Settings.SOUNDS_NAVIGATE_GUI_PAGES.getString(), 1.0F, 1.0F); - }); - - // Other Buttons setButton(5, 0, ConfigurationItemHelper.createConfigurationItem(Settings.GUI_CLOSE_BTN_ITEM.getString(), Settings.GUI_CLOSE_BTN_NAME.getString(), Settings.GUI_CLOSE_BTN_LORE.getStringList(), null), e -> e.manager.showGUI(e.player, new GUIAuctionHouse(this.auctionPlayer))); - setButton(5, 1, ConfigurationItemHelper.createConfigurationItem(Settings.GUI_EXPIRED_AUCTIONS_ITEM.getString(), Settings.GUI_EXPIRED_AUCTIONS_NAME.getString(), Settings.GUI_EXPIRED_AUCTIONS_LORE.getStringList(), null), e -> { - this.auctionPlayer.getItems(true).forEach(item -> { - AuctionHouse.getInstance().getAuctionItemManager().sendToGarbage(item); - PlayerUtils.giveItem(e.player, AuctionAPI.getInstance().deserializeItem(item.getRawItem())); - }); - draw(); - }); - List data = this.auctionPlayer.getItems(true).stream().sorted(Comparator.comparingInt(AuctionItem::getRemainingTime).reversed()).skip((page - 1) * 45L).limit(45).collect(Collectors.toList()); - int slot = 0; - for (AuctionItem item : data) { - setButton(slot++, AuctionAPI.getInstance().deserializeItem(item.getRawItem()), e -> { - AuctionHouse.getInstance().getAuctionItemManager().sendToGarbage(item); - PlayerUtils.giveItem(e.player, AuctionAPI.getInstance().deserializeItem(item.getRawItem())); + AuctionHouse.newChain().asyncFirst(() -> { + this.items = this.auctionPlayer.getItems(true); + return this.items.stream().sorted(Comparator.comparingInt(AuctionItem::getRemainingTime).reversed()).skip((page - 1) * 45L).limit(45).collect(Collectors.toList()); + }).asyncLast((data) -> { + pages = (int) Math.max(1, Math.ceil(this.auctionPlayer.getItems(true).size() / (double) 45)); + setPrevPage(5, 3, new TItemBuilder(Objects.requireNonNull(Settings.GUI_BACK_BTN_ITEM.getMaterial().parseMaterial())).setName(Settings.GUI_BACK_BTN_NAME.getString()).setLore(Settings.GUI_BACK_BTN_LORE.getStringList()).toItemStack()); + setButton(5, 4, new TItemBuilder(Objects.requireNonNull(Settings.GUI_REFRESH_BTN_ITEM.getMaterial().parseMaterial())).setName(Settings.GUI_REFRESH_BTN_NAME.getString()).setLore(Settings.GUI_REFRESH_BTN_LORE.getStringList()).toItemStack(), e -> draw()); + setNextPage(5, 5, new TItemBuilder(Objects.requireNonNull(Settings.GUI_NEXT_BTN_ITEM.getMaterial().parseMaterial())).setName(Settings.GUI_NEXT_BTN_NAME.getString()).setLore(Settings.GUI_NEXT_BTN_LORE.getStringList()).toItemStack()); + setOnPage(e -> { + draw(); + SoundManager.getInstance().playSound(this.auctionPlayer.getPlayer(), Settings.SOUNDS_NAVIGATE_GUI_PAGES.getString(), 1.0F, 1.0F); + }); + + + setButton(5, 1, ConfigurationItemHelper.createConfigurationItem(Settings.GUI_EXPIRED_AUCTIONS_ITEM.getString(), Settings.GUI_EXPIRED_AUCTIONS_NAME.getString(), Settings.GUI_EXPIRED_AUCTIONS_LORE.getStringList(), null), e -> { + for (AuctionItem auctionItem : data) { + PlayerUtils.giveItem(e.player, AuctionAPI.getInstance().deserializeItem(auctionItem.getRawItem())); + AuctionHouse.getInstance().getAuctionItemManager().sendToGarbage(auctionItem); + } draw(); }); - } + + int slot = 0; + for (AuctionItem auctionItem : data) { + setButton(slot++, AuctionAPI.getInstance().deserializeItem(auctionItem.getRawItem()), e -> { + PlayerUtils.giveItem(e.player, AuctionAPI.getInstance().deserializeItem(auctionItem.getRawItem())); + AuctionHouse.getInstance().getAuctionItemManager().sendToGarbage(auctionItem); + e.manager.showGUI(e.player, new GUIExpiredItems(this.auctionPlayer)); + }); + } + + }).execute(); } } diff --git a/src/main/java/ca/tweetzy/auctionhouse/guis/GUISellItem.java b/src/main/java/ca/tweetzy/auctionhouse/guis/GUISellItem.java index 0b915c2..1079846 100644 --- a/src/main/java/ca/tweetzy/auctionhouse/guis/GUISellItem.java +++ b/src/main/java/ca/tweetzy/auctionhouse/guis/GUISellItem.java @@ -53,7 +53,6 @@ public class GUISellItem extends Gui { setTitle(TextUtils.formatText(Settings.GUI_SELL_TITLE.getString())); setDefaultItem(Settings.GUI_SELL_BG_ITEM.getMaterial().parseItem()); setUseLockedCells(true); - setAcceptsItems(true); setAllowDrops(false); setRows(5); draw(); @@ -64,6 +63,9 @@ public class GUISellItem extends Gui { AuctionHouse.getInstance().getLocale().getMessage("general.finishenteringprice").sendPrefixedMessage(open.player); open.gui.exit(); } + + ItemStack held = AuctionHouse.getInstance().getAuctionPlayerManager().getSellHolding().get(open.player.getUniqueId()); + setAcceptsItems(held.getType() == XMaterial.AIR.parseMaterial()); }); setOnClose(close -> { @@ -121,8 +123,8 @@ public class GUISellItem extends Gui { } this.buyNowPrice = Double.parseDouble(msg); + reopen(e); } - reopen(e); }).setOnCancel(() -> reopen(e)).setOnClose(() -> reopen(e)); }); @@ -165,8 +167,6 @@ public class GUISellItem extends Gui { if (Settings.ALLOW_USAGE_OF_BID_SYSTEM.getBoolean()) { setButton(3, 5, ConfigurationItemHelper.createConfigurationItem(this.isBiddingItem ? Settings.GUI_SELL_ITEMS_BIDDING_ENABLED_ITEM.getString() : Settings.GUI_SELL_ITEMS_BIDDING_DISABLED_ITEM.getString(), this.isBiddingItem ? Settings.GUI_SELL_ITEMS_BIDDING_ENABLED_NAME.getString() : Settings.GUI_SELL_ITEMS_BIDDING_DISABLED_NAME.getString(), this.isBiddingItem ? Settings.GUI_SELL_ITEMS_BIDDING_ENABLED_LORE.getStringList() : Settings.GUI_SELL_ITEMS_BIDDING_DISABLED_LORE.getStringList(), null), e -> { - - this.isBiddingItem = !this.isBiddingItem; setTheItemToBeListed(); draw(); @@ -174,6 +174,12 @@ public class GUISellItem extends Gui { } setButton(3, 7, ConfigurationItemHelper.createConfigurationItem(Settings.GUI_SELL_ITEMS_CONFIRM_LISTING_ITEM.getString(), Settings.GUI_SELL_ITEMS_CONFIRM_LISTING_NAME.getString(), Settings.GUI_SELL_ITEMS_CONFIRM_LISTING_LORE.getStringList(), null), e -> { + // are they even allowed to sell more items + if (this.auctionPlayer.isAtSellLimit()) { + AuctionHouse.getInstance().getLocale().getMessage("general.sellinglimit").sendPrefixedMessage(e.player); + return; + } + // if the item in the sell slot is null then stop the listing if (getItem(1, 4) == null || getItem(1, 4).getType() == XMaterial.AIR.parseMaterial()) return; setTheItemToBeListed(); diff --git a/src/main/java/ca/tweetzy/auctionhouse/guis/confirmation/GUIConfirmPurchase.java b/src/main/java/ca/tweetzy/auctionhouse/guis/confirmation/GUIConfirmPurchase.java index a749ad9..453cbd5 100644 --- a/src/main/java/ca/tweetzy/auctionhouse/guis/confirmation/GUIConfirmPurchase.java +++ b/src/main/java/ca/tweetzy/auctionhouse/guis/confirmation/GUIConfirmPurchase.java @@ -66,6 +66,10 @@ public class GUIConfirmPurchase extends Gui { this.pricePerItem = this.auctionItem.getBasePrice() / this.maxStackSize; } + setOnOpen(open -> { + AuctionHouse.getInstance().getLogger().info("Added " + open.player.getName() + " to confirmation pre purchase"); + }); + setOnClose(close -> { AuctionHouse.getInstance().getTransactionManager().getPrePurchaseHolding().remove(close.player); close.manager.showGUI(close.player, new GUIAuctionHouse(this.auctionPlayer)); @@ -101,10 +105,10 @@ public class GUIConfirmPurchase extends Gui { if (AuctionHouse.getInstance().getAuctionItemManager().getGarbageBin().containsKey(this.auctionItem.getKey())) return; AuctionItem located = AuctionHouse.getInstance().getAuctionItemManager().getItem(this.auctionItem.getKey()); - preItemChecks(e, located); - if (located == null) { - e.gui.close(); + if (located == null || located.isExpired()) { + AuctionHouse.getInstance().getLocale().getMessage("auction.itemnotavailable").sendPrefixedMessage(e.player); + e.manager.showGUI(e.player, new GUIAuctionHouse(this.auctionPlayer)); return; } @@ -199,14 +203,6 @@ public class GUIConfirmPurchase extends Gui { setItem(3, 4, getPurchaseInfoItem(amt)); } - private void preItemChecks(GuiClickEvent e, AuctionItem located) { - if (located == null || located.isExpired()) { - AuctionHouse.getInstance().getLocale().getMessage("auction.itemnotavailable").sendPrefixedMessage(e.player); - e.manager.showGUI(e.player, new GUIAuctionHouse(this.auctionPlayer)); - return; - } - } - private ItemStack getPurchaseInfoItem(int qty) { ItemStack stack = ConfigurationItemHelper.createConfigurationItem(Settings.GUI_CONFIRM_QTY_INFO_ITEM.getString(), Settings.GUI_CONFIRM_QTY_INFO_NAME.getString(), Settings.GUI_CONFIRM_QTY_INFO_LORE.getStringList(), new HashMap() {{ put("%original_stack_size%", maxStackSize); diff --git a/src/main/java/ca/tweetzy/auctionhouse/settings/Settings.java b/src/main/java/ca/tweetzy/auctionhouse/settings/Settings.java index e369323..b2d6abd 100644 --- a/src/main/java/ca/tweetzy/auctionhouse/settings/Settings.java +++ b/src/main/java/ca/tweetzy/auctionhouse/settings/Settings.java @@ -43,8 +43,6 @@ public class Settings { public static final ConfigSetting RECORD_TRANSACTIONS = new ConfigSetting(config, "auction setting.record transactions", true, "Should every transaction be recorded (everything an auction is won or an item is bought)"); public static final ConfigSetting BROADCAST_AUCTION_LIST = new ConfigSetting(config, "auction setting.broadcast auction list", false, "Should the entire server be alerted when a player lists an item?"); public static final ConfigSetting PLAYER_NEEDS_TOTAL_PRICE_TO_BID = new ConfigSetting(config, "auction setting.bidder must have funds in account", false, "Should the player who is placing a bid on an item have the money in their account to cover the cost?"); - public static final ConfigSetting USE_ASYNC_GUI_REFRESH = new ConfigSetting(config, "auction setting.use async gui refresh", true, "Should the gui refresh be done using asynchronous tasks?", "This may reduce lag that can be caused, but", "items may have a flickering effect inside the gui."); - public static final ConfigSetting SEND_REMOVED_ITEM_BACK_TO_PLAYER = new ConfigSetting(config, "auction setting.send removed item back to player", true, "Should items removed by staff from the auction house be sent back to the player?"); public static final ConfigSetting ALLOW_USAGE_OF_BID_SYSTEM = new ConfigSetting(config, "auction setting.allow bid system usage", true, "Should players be allowed to use the bid option cmd params?"); public static final ConfigSetting ALLOW_USAGE_OF_BUY_NOW_SYSTEM = new ConfigSetting(config, "auction setting.allow buy now system usage", true, "Should players be allowed to use the right-click buy now feature on biddable items?"); public static final ConfigSetting AUTO_SAVE_ENABLED = new ConfigSetting(config, "auction setting.auto save.enabled", true, "Should the auto save task be enabled?"); @@ -54,6 +52,8 @@ public class Settings { public static final ConfigSetting REFRESH_COOL_DOWN = new ConfigSetting(config, "auction setting.refresh cool down", 2, "How many seconds should pass before the player can refresh the auction house again?"); public static final ConfigSetting ALLOW_PURCHASE_IF_INVENTORY_FULL = new ConfigSetting(config, "auction setting.allow purchase with full inventory", true, "Should auction house allow players to buy items even if their", "inventory is full, if true, items will be dropped on the floor if there is no room."); public static final ConfigSetting ASK_FOR_BID_CONFIRMATION = new ConfigSetting(config, "auction setting.ask for bid confirmation", true, "Should Auction House open the confirmation menu for the user to confirm", "whether they actually meant to place a bid or not?"); + public static final ConfigSetting REPLACE_HOW_TO_SELL_WITH_LIST_BUTTON = new ConfigSetting(config, "auction setting.replace how to sell with list button", false, "This will replace the \"How to Sell\" button with a List Item button"); + public static final ConfigSetting ALLOW_USAGE_OF_SELL_GUI = new ConfigSetting(config, "auction setting.allow usage of sell gui", true, "Should the sell menu be enabled?"); public static final ConfigSetting ASK_FOR_CANCEL_CONFIRM_ON_BID_ITEMS = new ConfigSetting(config, "auction setting.ask for cancel confirm on bid items", true, "Should Auction House ask the user if they want to cancel the item?"); public static final ConfigSetting ASK_FOR_CANCEL_CONFIRM_ON_NON_BID_ITEMS = new ConfigSetting(config, "auction setting.ask for cancel confirm on non bid items", false, "Should Auction House ask the user if they want to cancel the item?"); @@ -293,6 +293,10 @@ public class Settings { "&e/ah sell [startPrice] [bidIncrement]" )); + public static final ConfigSetting GUI_AUCTION_HOUSE_ITEMS_LIST_ITEM_ITEM = new ConfigSetting(config, "gui.auction house.items.list new item.item", "CLOCK"); + public static final ConfigSetting GUI_AUCTION_HOUSE_ITEMS_LIST_ITEM_NAME = new ConfigSetting(config, "gui.auction house.items.list new item.name", "&e&lList Item"); + public static final ConfigSetting GUI_AUCTION_HOUSE_ITEMS_LIST_ITEM_LORE = new ConfigSetting(config, "gui.auction house.items.list new item.lore", Collections.singletonList("&7Click to list an item on the auction house.")); + public static final ConfigSetting GUI_AUCTION_HOUSE_ITEMS_YOUR_AUCTIONS_ITEM = new ConfigSetting(config, "gui.auction house.items.your auctions.item", "DIAMOND"); public static final ConfigSetting GUI_AUCTION_HOUSE_ITEMS_YOUR_AUCTIONS_NAME = new ConfigSetting(config, "gui.auction house.items.your auctions.name", "&e&lYour Auctions"); public static final ConfigSetting GUI_AUCTION_HOUSE_ITEMS_YOUR_AUCTIONS_LORE = new ConfigSetting(config, "gui.auction house.items.your auctions.lore", Arrays.asList(