cn.nukkit.inventory.transaction.action.SlotChangeAction Maven / Gradle / Ivy
package cn.nukkit.inventory.transaction.action;
import cn.nukkit.Player;
import cn.nukkit.api.PowerNukkitXDifference;
import cn.nukkit.inventory.Inventory;
import cn.nukkit.inventory.transaction.InventoryTransaction;
import cn.nukkit.item.Item;
import java.util.HashSet;
import java.util.Set;
/**
* @author CreeperFace
*/
public class SlotChangeAction extends InventoryAction {
protected Inventory inventory;
private final int inventorySlot;
public SlotChangeAction(Inventory inventory, int inventorySlot, Item sourceItem, Item targetItem) {
super(sourceItem, targetItem);
this.inventory = inventory;
this.inventorySlot = inventorySlot;
}
/**
* Returns the inventory involved in this action.
*
* @return inventory
*/
public Inventory getInventory() {
return this.inventory;
}
/**
* Returns the inventorySlot in the inventory which this action modified.
*
* @return slot
*/
public int getSlot() {
return inventorySlot;
}
/**
* Checks if the item in the inventory at the specified inventorySlot is the same as this action's source item.
*
* @param source player
* @return valid
*/
@Override
public boolean isValid(Player source) {
Item check = inventory.getItem(this.inventorySlot);
return check.equalsExact(this.sourceItem);
}
/**
* Sets the item into the target inventory.
*
* @param source player
* @return successfully executed
*/
@Override
@PowerNukkitXDifference(info = "Use setItemByPlayer", since = "1.19.50-r3")
public boolean execute(Player source) {
return this.inventory.setItemByPlayer(source, this.inventorySlot, this.targetItem, false);
}
/**
* Sends inventorySlot changes to other viewers of the inventory. This will not send any change back to the source Player.
*
* @param source player
*/
@Override
public void onExecuteSuccess(Player source) {
Set viewers = new HashSet<>(this.inventory.getViewers());
viewers.remove(source);
this.inventory.sendSlot(this.inventorySlot, viewers);
}
/**
* Sends the original inventorySlot contents to the source player to revert the action.
*
* @param source player
*/
@Override
public void onExecuteFail(Player source) {
this.inventory.sendSlot(this.inventorySlot, source);
}
@Override
public void onAddToTransaction(InventoryTransaction transaction) {
transaction.addInventory(this.inventory);
}
@Override
public String toString() {
return "SlotChangeAction{" +
"inventory=" + inventory +
", inventorySlot=" + inventorySlot +
", sourceItem=" + sourceItem +
", targetItem=" + targetItem +
'}';
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy