Skip to content

Commit

Permalink
Send a packet on shift clicking
Browse files Browse the repository at this point in the history
  • Loading branch information
raoulvdberge committed Apr 9, 2016
1 parent 2b3f2f5 commit 7fe2a89
Show file tree
Hide file tree
Showing 5 changed files with 68 additions and 9 deletions.
5 changes: 0 additions & 5 deletions src/main/java/refinedstorage/container/ContainerBase.java
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@
import net.minecraft.inventory.Slot;
import net.minecraft.item.ItemStack;
import refinedstorage.container.slot.SlotDisabled;
import refinedstorage.container.slot.SlotGridCraftingResult;
import refinedstorage.container.slot.SlotSpecimen;

import java.util.ArrayList;
Expand Down Expand Up @@ -99,10 +98,6 @@ public ItemStack func_184996_a(int id, int clickedButton, ClickType clickType, E
}

return player.inventory.getItemStack();
} else if (slot instanceof SlotGridCraftingResult && slot.getHasStack() && GuiScreen.isShiftKeyDown()) {
((SlotGridCraftingResult) slot).onShiftClick(player);

return null;
} else if (slot instanceof SlotDisabled) {
return null;
}
Expand Down
19 changes: 19 additions & 0 deletions src/main/java/refinedstorage/container/ContainerGrid.java
Original file line number Diff line number Diff line change
@@ -1,11 +1,15 @@
package refinedstorage.container;

import net.minecraft.client.gui.GuiScreen;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.inventory.ClickType;
import net.minecraft.inventory.ICrafting;
import net.minecraft.inventory.Slot;
import net.minecraft.item.ItemStack;
import refinedstorage.RefinedStorage;
import refinedstorage.block.EnumGridType;
import refinedstorage.container.slot.SlotGridCraftingResult;
import refinedstorage.network.MessageGridCraftingShift;
import refinedstorage.tile.grid.IGrid;
import refinedstorage.tile.grid.TileGrid;
import refinedstorage.tile.grid.WirelessGrid;
Expand Down Expand Up @@ -84,4 +88,19 @@ public void onContainerClosed(EntityPlayer player) {
((WirelessGrid) grid).onClose(player);
}
}

@Override
public ItemStack func_184996_a(int id, int clickedButton, ClickType clickType, EntityPlayer player) {
Slot slot = id >= 0 ? getSlot(id) : null;

if (player.worldObj.isRemote && slot instanceof SlotGridCraftingResult && slot.getHasStack()) {
if (GuiScreen.isShiftKeyDown()) {
RefinedStorage.NETWORK.sendToServer(new MessageGridCraftingShift((TileGrid) grid));

return null;
}
}

return super.func_184996_a(id, clickedButton, clickType, player);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -30,8 +30,4 @@ public void onPickupFromSlot(EntityPlayer player, ItemStack stack) {

grid.onCrafted(container);
}

public void onShiftClick(EntityPlayer player) {
grid.onCraftedShift(container, player);
}
}
48 changes: 48 additions & 0 deletions src/main/java/refinedstorage/network/MessageGridCraftingShift.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
package refinedstorage.network;

import io.netty.buffer.ByteBuf;
import net.minecraft.entity.player.EntityPlayerMP;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.math.BlockPos;
import net.minecraftforge.fml.common.network.simpleimpl.IMessage;
import refinedstorage.block.EnumGridType;
import refinedstorage.container.ContainerGrid;
import refinedstorage.tile.grid.TileGrid;

public class MessageGridCraftingShift extends MessageHandlerPlayerToServer<MessageGridCraftingShift> implements IMessage {
private int x;
private int y;
private int z;

public MessageGridCraftingShift() {
}

public MessageGridCraftingShift(TileGrid grid) {
this.x = grid.getPos().getX();
this.y = grid.getPos().getY();
this.z = grid.getPos().getZ();
}

@Override
public void fromBytes(ByteBuf buf) {
x = buf.readInt();
y = buf.readInt();
z = buf.readInt();
}

@Override
public void toBytes(ByteBuf buf) {
buf.writeInt(x);
buf.writeInt(y);
buf.writeInt(z);
}

@Override
public void handle(MessageGridCraftingShift message, EntityPlayerMP player) {
TileEntity tile = player.worldObj.getTileEntity(new BlockPos(message.x, message.y, message.z));

if (tile instanceof TileGrid && ((TileGrid) tile).getType() == EnumGridType.CRAFTING && player.openContainer instanceof ContainerGrid) {
((ContainerGrid) player.openContainer).getGrid().onCraftedShift((ContainerGrid) player.openContainer, player);
}
}
}
1 change: 1 addition & 0 deletions src/main/java/refinedstorage/proxy/CommonProxy.java
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ public void preInit(FMLPreInitializationEvent e) {
RefinedStorage.NETWORK.registerMessage(MessageWirelessGridItems.class, MessageWirelessGridItems.class, 16, Side.CLIENT);
RefinedStorage.NETWORK.registerMessage(MessageWirelessGridStoragePush.class, MessageWirelessGridStoragePush.class, 17, Side.SERVER);
RefinedStorage.NETWORK.registerMessage(MessageWirelessGridStoragePull.class, MessageWirelessGridStoragePull.class, 18, Side.SERVER);
RefinedStorage.NETWORK.registerMessage(MessageGridCraftingShift.class, MessageGridCraftingShift.class, 19, Side.SERVER);

NetworkRegistry.INSTANCE.registerGuiHandler(RefinedStorage.INSTANCE, new GuiHandler());

Expand Down

0 comments on commit 7fe2a89

Please sign in to comment.