From 9d0d74a3ba0aeca9f1130d1228fa4b9ef08d19d6 Mon Sep 17 00:00:00 2001 From: OnyxDarkKnight Date: Sun, 30 Mar 2014 22:59:36 +0300 Subject: Added a gui! Yaaay! --- .../jewelrycraft/events/EntityEventHandler.java | 48 ++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 common/darkknight/jewelrycraft/events/EntityEventHandler.java (limited to 'common/darkknight/jewelrycraft/events/EntityEventHandler.java') diff --git a/common/darkknight/jewelrycraft/events/EntityEventHandler.java b/common/darkknight/jewelrycraft/events/EntityEventHandler.java new file mode 100644 index 0000000..a3af5f9 --- /dev/null +++ b/common/darkknight/jewelrycraft/events/EntityEventHandler.java @@ -0,0 +1,48 @@ +package darkknight.jewelrycraft.events; + +import net.minecraft.entity.Entity; +import net.minecraft.entity.player.EntityPlayer; +import net.minecraft.item.ItemStack; +import net.minecraft.nbt.NBTTagCompound; +import net.minecraftforge.event.ForgeSubscribe; +import net.minecraftforge.event.entity.EntityJoinWorldEvent; +import darkknight.jewelrycraft.item.ItemList; +import darkknight.jewelrycraft.util.BlockUtils; +import darkknight.jewelrycraft.util.PlayerUtils; + +/** + * Code taken from OpenBlocks + */ +public class EntityEventHandler +{ + + public static final String OPENBLOCKS_PERSIST_TAG = "Jewelrycraft"; + public static final String GIVEN_GUIDE_TAG = "givenGuive"; + + @ForgeSubscribe + public void onEntityJoinWorld(EntityJoinWorldEvent event) + { + + final Entity entity = event.entity; + /** + * If the player hasn't been given a manual, we'll give him one! (or + * throw it on the floor..) + */ + if (!event.world.isRemote && entity instanceof EntityPlayer) + { + EntityPlayer player = (EntityPlayer)entity; + NBTTagCompound persistTag = PlayerUtils.getModPlayerPersistTag(player, "Jewelrycraft"); + + boolean shouldGiveManual = ItemList.guide != null && !persistTag.getBoolean(GIVEN_GUIDE_TAG); + if (shouldGiveManual) + { + ItemStack manual = new ItemStack(ItemList.guide); + if (!player.inventory.addItemStackToInventory(manual)) + { + BlockUtils.dropItemStackInWorld(player.worldObj, player.posX, player.posY, player.posZ, manual); + } + persistTag.setBoolean(GIVEN_GUIDE_TAG, true); + } + } + } +} \ No newline at end of file -- cgit v1.2.3