diff --git a/pom.xml b/pom.xml
index a571f63..c991526 100644
--- a/pom.xml
+++ b/pom.xml
@@ -6,7 +6,7 @@
com.artillexstudios
AxTrade
- 1.2.0
+ 1.3.0
jar
AxTrade
diff --git a/src/main/java/com/artillexstudios/axtrade/trade/TradeGui.java b/src/main/java/com/artillexstudios/axtrade/trade/TradeGui.java
index 00b6c3d..41915b9 100644
--- a/src/main/java/com/artillexstudios/axtrade/trade/TradeGui.java
+++ b/src/main/java/com/artillexstudios/axtrade/trade/TradeGui.java
@@ -16,6 +16,7 @@ import dev.triumphteam.gui.guis.StorageGui;
import net.kyori.adventure.text.Component;
import net.kyori.adventure.text.serializer.plain.PlainTextComponentSerializer;
import org.bukkit.event.inventory.ClickType;
+import org.bukkit.event.inventory.InventoryAction;
import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.ItemStack;
import org.jetbrains.annotations.NotNull;
@@ -120,9 +121,15 @@ public class TradeGui extends GuiFrame {
return;
}
- if (event.isShiftClick() && !slots.contains(event.getView().getTopInventory().firstEmpty())) {
+ if (event.getCurrentItem() != null && event.isShiftClick() && event.getAction() == InventoryAction.MOVE_TO_OTHER_INVENTORY && !slots.contains(event.getView().getTopInventory().firstEmpty())) {
event.setCancelled(true);
- return;
+ for (int i : slots) {
+ if (gui.getInventory().getItem(i) == null) {
+ gui.getInventory().setItem(i, event.getCurrentItem().clone());
+ event.getCurrentItem().setAmount(0);
+ break;
+ }
+ }
}
player.cancel();
@@ -230,8 +237,6 @@ public class TradeGui extends GuiFrame {
gui.updateItem(slot, new GuiItem(otherItems.get(n), event -> event.setCancelled(true)));
n++;
}
-
- updateTitle();
}
public List getItems() {
diff --git a/src/main/java/com/artillexstudios/axtrade/trade/TradePlayer.java b/src/main/java/com/artillexstudios/axtrade/trade/TradePlayer.java
index fe121b3..c7ec833 100644
--- a/src/main/java/com/artillexstudios/axtrade/trade/TradePlayer.java
+++ b/src/main/java/com/artillexstudios/axtrade/trade/TradePlayer.java
@@ -7,6 +7,7 @@ import com.artillexstudios.axtrade.utils.SoundUtils;
import org.bukkit.entity.Player;
import java.util.HashMap;
+import java.util.Objects;
import static com.artillexstudios.axtrade.AxTrade.CONFIG;
@@ -57,19 +58,30 @@ public class TradePlayer {
trade.update();
SoundUtils.playSound(player, "accept");
SoundUtils.playSound(otherPlayer.getPlayer(), "accept");
+
+ getTradeGui().updateTitle();
+ otherPlayer.getTradeGui().updateTitle();
}
public void cancel() {
if (confirmed != null) {
this.confirmed = null;
+ otherPlayer.setConfirmed(null);
SoundUtils.playSound(player, "cancel");
SoundUtils.playSound(otherPlayer.getPlayer(), "cancel");
+
+ getTradeGui().updateTitle();
+ otherPlayer.getTradeGui().updateTitle();
+ return;
}
- otherPlayer.setConfirmed(null);
+ if (otherPlayer.setConfirmed(null)) getTradeGui().updateTitle();
}
- public void setConfirmed(Integer confirmed) {
+ public boolean setConfirmed(Integer confirmed) {
+ if (Objects.equals(this.confirmed, confirmed)) return false;
this.confirmed = confirmed;
+ getTradeGui().updateTitle();
+ return true;
}
public void tick() {