mirror of
https://github.com/Ellpeck/ActuallyAdditions.git
synced 2024-09-20 17:01:04 +02:00
45 lines
1.5 KiB
Java
45 lines
1.5 KiB
Java
package de.ellpeck.actuallyadditions.mod.tile;
|
|
|
|
import de.ellpeck.actuallyadditions.mod.blocks.BlockPhantom;
|
|
import de.ellpeck.actuallyadditions.mod.util.ItemStackHandlerAA.IAcceptor;
|
|
import de.ellpeck.actuallyadditions.mod.util.ItemStackHandlerAA.IRemover;
|
|
import net.minecraft.tileentity.TileEntity;
|
|
import net.minecraft.util.EnumFacing;
|
|
import net.minecraftforge.common.capabilities.Capability;
|
|
import net.minecraftforge.items.CapabilityItemHandler;
|
|
|
|
public class TileEntityPhantomItemface extends TileEntityPhantomface {
|
|
|
|
public TileEntityPhantomItemface() {
|
|
super("phantomface");
|
|
this.type = BlockPhantom.Type.FACE;
|
|
}
|
|
|
|
@Override
|
|
public IAcceptor getAcceptor() {
|
|
return (slot, stack, automation) -> !automation || this.isBoundThingInRange();
|
|
}
|
|
|
|
@Override
|
|
public boolean isBoundThingInRange() {
|
|
if (super.isBoundThingInRange()) {
|
|
TileEntity tile = this.world.getTileEntity(this.getBoundPosition());
|
|
if (tile != null) {
|
|
for (EnumFacing facing : EnumFacing.values()) {
|
|
if (tile.hasCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, facing)) { return true; }
|
|
}
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
protected boolean isCapabilitySupported(Capability<?> capability) {
|
|
return capability == CapabilityItemHandler.ITEM_HANDLER_CAPABILITY;
|
|
}
|
|
|
|
@Override
|
|
public IRemover getRemover() {
|
|
return (slot, automation) -> !automation || this.isBoundThingInRange();
|
|
}
|
|
}
|