diff --git a/pom.xml b/pom.xml
index cea30d2..c7f192d 100644
--- a/pom.xml
+++ b/pom.xml
@@ -6,7 +6,7 @@
me.olliejw
OreMarket
- 2.2.5
+ 2.2.6
jar
OreMarket
diff --git a/src/main/java/me/olliejw/oremarket/OreMarket.java b/src/main/java/me/olliejw/oremarket/OreMarket.java
index 22bb2bd..9751aa3 100644
--- a/src/main/java/me/olliejw/oremarket/OreMarket.java
+++ b/src/main/java/me/olliejw/oremarket/OreMarket.java
@@ -154,13 +154,6 @@ private void createMsgConfig() {
e.printStackTrace();
}
}
- public void reloadMsgConfig() {
- try {
- msgConfig.load(msgFile);
- } catch (IOException | InvalidConfigurationException e) {
- e.printStackTrace();
- }
- }
public static OreMarket main(){
return instance;
diff --git a/src/main/java/me/olliejw/oremarket/listeners/InventoryEvents.java b/src/main/java/me/olliejw/oremarket/listeners/InventoryEvents.java
index 010e8dd..c75cac3 100644
--- a/src/main/java/me/olliejw/oremarket/listeners/InventoryEvents.java
+++ b/src/main/java/me/olliejw/oremarket/listeners/InventoryEvents.java
@@ -51,6 +51,29 @@ private void changePlayerBalance(double Money, HumanEntity player, boolean opera
private double balance (HumanEntity Player) {
return OreMarket.getEconomy().getBalance((OfflinePlayer) Player);
}
+ /*SPOILER! private int getItemAmount (HumanEntity player, ItemStack item) {
+ if (item == null) {
+ return 0;
+ }
+ int amount = 0;
+ for (int i = 0; i < 36; i++) {
+ ItemStack slot = player.getInventory().getItem(i);
+ if (slot == null || !slot.isSimilar(item)) {
+ continue;
+ }
+ amount += slot.getAmount();
+ }
+ return amount;
+ }
+ private void removeItemAmount (HumanEntity player, ItemStack item) {
+ for (int i = 0; i < 36; i++) {
+ ItemStack slot = player.getInventory().getItem(i);
+ if (slot == null || !slot.equals(item)) {
+ continue;
+ }
+ slot.setAmount(0);
+ }
+ }*/
String title = ChatColor.translateAlternateColorCodes('&', Objects.requireNonNull(OreMarket.main().getGuiConfig().getString("gui.title")));
Placeholders plh = new Placeholders();
@@ -112,11 +135,15 @@ else if (toSend.contains("[msg]")) {
int itemStock = OreMarket.main().getGuiConfig().getInt("items." + slot + ".stock");
if (OreMarket.main().getGuiConfig().getBoolean("items." + slot + ".copymeta")) {
- // Take any type of the clicked item (e.g. custom name)
- playerInventory.removeItem(event.getCurrentItem());
- }
- else {
// Take the EXACT item (e.g. exact custom name)
+ if (!(playerInventory.containsAtLeast(event.getCurrentItem(), 1))) {
+ String message = OreMarket.main().getMsgConfig().getString("messages.no-item", "&cYou don't have that item!");
+ player.sendMessage(ChatColor.translateAlternateColorCodes('&', message));
+ return;
+ }
+ playerInventory.removeItem(event.getCurrentItem());
+ } else {
+ // Take any type of the clicked item (e.g. custom name)
playerInventory.removeItem(clickedItem);
}
@@ -127,6 +154,45 @@ else if (toSend.contains("[msg]")) {
String message = OreMarket.main().getMsgConfig().getString("messages.successfully-sold", "&aYou have successfully sold this item!");
player.sendMessage(ChatColor.translateAlternateColorCodes('&', message));
}
+ /* SPOILER!: if ((event.getClick() == ClickType.SHIFT_LEFT)) { // Sell ALL Mode
+ if (OreMarket.main().getGuiConfig().getBoolean("items." + event.getSlot() + ".buyonly")) {
+ // You cannot sell this, Buy only item
+ String message = OreMarket.main().getMsgConfig().getString("messages.buy-only", "&cThis item can only be bought");
+ player.sendMessage(ChatColor.translateAlternateColorCodes('&', message));
+ return;
+ }
+
+ if (!(playerInventory.containsAtLeast(clickedItem, 1))) {
+ String message = OreMarket.main().getMsgConfig().getString("messages.no-item", "&cYou don't have that item!");
+ player.sendMessage(ChatColor.translateAlternateColorCodes('&', message));
+ return;
+ }
+
+ double itemValue = OreMarket.main().getGuiConfig().getDouble("items." + slot + ".value");
+ int itemStock = OreMarket.main().getGuiConfig().getInt("items." + slot + ".stock");
+ int itemAmount = getItemAmount(player, clickedItem);
+
+ if (OreMarket.main().getGuiConfig().getBoolean("items." + slot + ".copymeta")) {
+ // Take the EXACT item and amount (e.g. exact custom name)
+ if (!(playerInventory.containsAtLeast(event.getCurrentItem(), 1))) {
+ String message = OreMarket.main().getMsgConfig().getString("messages.no-item", "&cYou don't have that item!");
+ player.sendMessage(ChatColor.translateAlternateColorCodes('&', message));
+ return;
+ }
+ removeItemAmount(player, event.getCurrentItem());
+ }
+ else {
+ // Take any type of the clicked item (e.g. custom name)
+ removeItemAmount(player, clickedItem);
+ }
+
+ changePlayerBalance(itemValue*itemAmount, player, false, slot);
+ OreMarket.main().getGuiConfig().set("items." + slot + ".stock", itemStock+itemAmount);
+ OreMarket.main().saveGuiConfig();
+
+ String message = OreMarket.main().getMsgConfig().getString("messages.successfully-sold", "&aYou have successfully sold this item!");
+ player.sendMessage(ChatColor.translateAlternateColorCodes('&', message));
+ }*/
if ((event.getClick() == ClickType.RIGHT)) { // Buy Mode
if (OreMarket.main().getGuiConfig().getBoolean("items." + event.getSlot() + ".sellonly")) {
// You cannot buy this, Sell only item
@@ -138,7 +204,13 @@ else if (toSend.contains("[msg]")) {
double itemValue = OreMarket.main().getGuiConfig().getDouble("items." + slot + ".value");
int itemStock = OreMarket.main().getGuiConfig().getInt("items." + slot + ".stock");
+ if (itemStock > 0) {
+ // Is there any stock?
+ return;
+ }
+
if (balance(player) < itemValue) {
+ // Player has enough money?
String message = OreMarket.main().getMsgConfig().getString("messages.insufficient-balance", "&cYou don't have enough money to buy this item!");
player.sendMessage(ChatColor.translateAlternateColorCodes('&', message));
return;
@@ -147,8 +219,7 @@ else if (toSend.contains("[msg]")) {
if (OreMarket.main().getGuiConfig().getBoolean("items." + slot + ".copymeta")) {
// Take any type of the clicked item (e.g. custom name)
playerInventory.addItem(event.getCurrentItem());
- }
- else {
+ } else {
// Take the EXACT item (e.g. exact custom name)
playerInventory.addItem(clickedItem);
}
@@ -160,6 +231,7 @@ else if (toSend.contains("[msg]")) {
String message = OreMarket.main().getMsgConfig().getString("messages.successfully-bought", "&aYou have successfully bought the item!");
player.sendMessage(ChatColor.translateAlternateColorCodes('&', message));
}
+
mainGUI.createGUI((Player) player); // Reload GUI
}
}