Fix drag clicks

This commit is contained in:
TheMode 2021-08-23 04:02:06 +02:00
parent 2450e741e6
commit 8fa590fdcd
2 changed files with 20 additions and 17 deletions

View File

@ -399,7 +399,7 @@ public class Inventory extends AbstractInventory implements Viewable {
ItemStack.AIR; ItemStack.AIR;
final ItemStack cursor = getCursorItem(player); final ItemStack cursor = getCursorItem(player);
final InventoryClickResult clickResult = clickProcessor.dragging(player, final InventoryClickResult clickResult = clickProcessor.dragging(player,
isInWindow ? this : playerInventory, slot != -999 ? (isInWindow ? this : playerInventory) : null,
clickSlot, button, clickSlot, button,
clicked, cursor, clicked, cursor,

View File

@ -19,6 +19,7 @@ import org.jetbrains.annotations.ApiStatus;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Objects; import java.util.Objects;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
@ -140,7 +141,7 @@ public final class InventoryClickProcessor {
return clickResult; return clickResult;
} }
public @Nullable InventoryClickResult dragging(@NotNull Player player, @NotNull AbstractInventory inventory, public @Nullable InventoryClickResult dragging(@NotNull Player player, @Nullable AbstractInventory inventory,
int slot, int button, int slot, int button,
@NotNull ItemStack clicked, @NotNull ItemStack cursor, @NotNull ItemStack clicked, @NotNull ItemStack cursor,
@NotNull Int2ObjectFunction<ItemStack> itemGetter, @NotNull Int2ObjectFunction<ItemStack> itemGetter,
@ -386,7 +387,7 @@ public final class InventoryClickProcessor {
} }
private @NotNull InventoryClickResult startCondition(@NotNull Player player, private @NotNull InventoryClickResult startCondition(@NotNull Player player,
@NotNull AbstractInventory inventory, @Nullable AbstractInventory inventory,
int slot, @NotNull ClickType clickType, int slot, @NotNull ClickType clickType,
@NotNull ItemStack clicked, @NotNull ItemStack cursor) { @NotNull ItemStack clicked, @NotNull ItemStack cursor) {
final InventoryClickResult clickResult = new InventoryClickResult(clicked, cursor); final InventoryClickResult clickResult = new InventoryClickResult(clicked, cursor);
@ -408,22 +409,24 @@ public final class InventoryClickProcessor {
} }
// Inventory conditions // Inventory conditions
{ {
final var inventoryConditions = inventory.getInventoryConditions(); if (inventory != null) {
if (!inventoryConditions.isEmpty()) { final List<InventoryCondition> inventoryConditions = inventory.getInventoryConditions();
for (InventoryCondition inventoryCondition : inventoryConditions) { if (!inventoryConditions.isEmpty()) {
var result = new InventoryConditionResult(clickResult.getClicked(), clickResult.getCursor()); for (InventoryCondition inventoryCondition : inventoryConditions) {
inventoryCondition.accept(player, slot, clickType, result); var result = new InventoryConditionResult(clickResult.getClicked(), clickResult.getCursor());
inventoryCondition.accept(player, slot, clickType, result);
clickResult.setCursor(result.getCursorItem()); clickResult.setCursor(result.getCursorItem());
clickResult.setClicked(result.getClickedItem()); clickResult.setClicked(result.getClickedItem());
if (result.isCancel()) { if (result.isCancel()) {
clickResult.setCancel(true); clickResult.setCancel(true);
}
}
// Cancel the click if the inventory has been closed by Player#closeInventory within an inventory listener
if (player.didCloseInventory()) {
clickResult.setCancel(true);
player.UNSAFE_changeDidCloseInventory(false);
} }
}
// Cancel the click if the inventory has been closed by Player#closeInventory within an inventory listener
if (player.didCloseInventory()) {
clickResult.setCancel(true);
player.UNSAFE_changeDidCloseInventory(false);
} }
} }
} }