From bc75c7e9fac00562beaed15e5f91ae1f4df01249 Mon Sep 17 00:00:00 2001 From: mobius <8391001+MobiusDevelopment@users.noreply.github.com> Date: Tue, 27 Jan 2015 18:24:57 +0000 Subject: [PATCH] Fated Support Box handler. --- trunk/dist/game/data/categoryData.xml | 8 ++ .../data/scripts/handlers/MasterHandler.java | 2 + .../itemhandlers/FatedSupportBox.java | 128 ++++++++++++++++++ .../game/data/stats/items/37300-37399.xml | 5 + 4 files changed, 143 insertions(+) create mode 100644 trunk/dist/game/data/scripts/handlers/itemhandlers/FatedSupportBox.java diff --git a/trunk/dist/game/data/categoryData.xml b/trunk/dist/game/data/categoryData.xml index 33e9c17a3f..e1069ac2e8 100644 --- a/trunk/dist/game/data/categoryData.xml +++ b/trunk/dist/game/data/categoryData.xml @@ -67,6 +67,10 @@ 134 135 136 + 182 + 184 + 186 + 188 10 @@ -106,6 +110,10 @@ 112 115 116 + 183 + 185 + 187 + 189 10 diff --git a/trunk/dist/game/data/scripts/handlers/MasterHandler.java b/trunk/dist/game/data/scripts/handlers/MasterHandler.java index 5a03dcb5e8..ebadf88b44 100644 --- a/trunk/dist/game/data/scripts/handlers/MasterHandler.java +++ b/trunk/dist/game/data/scripts/handlers/MasterHandler.java @@ -168,6 +168,7 @@ import handlers.itemhandlers.EnchantAttribute; import handlers.itemhandlers.EnchantScrolls; import handlers.itemhandlers.EventItem; import handlers.itemhandlers.ExtractableItems; +import handlers.itemhandlers.FatedSupportBox; import handlers.itemhandlers.FishShots; import handlers.itemhandlers.Harvester; import handlers.itemhandlers.ItemAppearance; @@ -473,6 +474,7 @@ public class MasterHandler EnchantScrolls.class, EventItem.class, ExtractableItems.class, + FatedSupportBox.class, FishShots.class, Harvester.class, ItemAppearance.class, diff --git a/trunk/dist/game/data/scripts/handlers/itemhandlers/FatedSupportBox.java b/trunk/dist/game/data/scripts/handlers/itemhandlers/FatedSupportBox.java new file mode 100644 index 0000000000..5aad0cfa99 --- /dev/null +++ b/trunk/dist/game/data/scripts/handlers/itemhandlers/FatedSupportBox.java @@ -0,0 +1,128 @@ +/* + * Copyright (C) 2004-2015 L2J DataPack + * + * This file is part of L2J DataPack. + * + * L2J DataPack is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * L2J DataPack is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ +package handlers.itemhandlers; + +import com.l2jserver.gameserver.data.xml.impl.CategoryData; +import com.l2jserver.gameserver.enums.CategoryType; +import com.l2jserver.gameserver.enums.Race; +import com.l2jserver.gameserver.handler.IItemHandler; +import com.l2jserver.gameserver.model.actor.L2Playable; +import com.l2jserver.gameserver.model.actor.instance.L2PcInstance; +import com.l2jserver.gameserver.model.base.ClassId; +import com.l2jserver.gameserver.model.items.instance.L2ItemInstance; +import com.l2jserver.gameserver.network.SystemMessageId; +import com.l2jserver.gameserver.network.serverpackets.InventoryUpdate; +import com.l2jserver.gameserver.network.serverpackets.SystemMessage; + +/** + * @author Mobius + */ +public class FatedSupportBox implements IItemHandler +{ + @Override + public boolean useItem(L2Playable playable, L2ItemInstance item, boolean forceUse) + { + if (!playable.isPlayer()) + { + playable.sendPacket(SystemMessageId.YOUR_PET_CANNOT_CARRY_THIS_ITEM); + return false; + } + + final L2PcInstance player = playable.getActingPlayer(); + final Race race = player.getRace(); + final ClassId classId = player.getClassId(); + + // Characters that have gone through their 2nd class transfer/1st liberation will be able to open the Fated Support Box at level 40. + if ((player.getLevel() < 40) || (classId.level() < (race == Race.ERTHEIA ? 1 : 2))) + { + player.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.S1_CANNOT_BE_USED_DUE_TO_UNSUITABLE_TERMS).addItemName(item)); + return false; + } + + player.getInventory().destroyItem(getClass().getSimpleName(), item, 1, player, null); + player.sendPacket(new InventoryUpdate(item)); + + // It will stay in your inventory after use until you reach level 84. + if (player.getLevel() > 84) + { + player.sendMessage("Fated Support Box was removed because your level has exceeded the maximum requirement."); // custom message + return true; + } + + switch (race) + { + case HUMAN: + case ELF: + case DARK_ELF: + case DWARF: + { + if (player.isMageClass()) + { + player.addItem(getClass().getSimpleName(), 37316, 1, player, true); + } + else + { + if (CategoryData.getInstance().isInCategory(CategoryType.SUB_GROUP_ROGUE, classId.getId())) + { + player.addItem(getClass().getSimpleName(), 37318, 1, player, true); + } + else if (CategoryData.getInstance().isInCategory(CategoryType.SUB_GROUP_KNIGHT, classId.getId())) + { + player.addItem(getClass().getSimpleName(), 37315, 1, player, true); + } + else + { + player.addItem(getClass().getSimpleName(), 37317, 1, player, true); + } + } + break; + } + case ORC: + { + if (player.isMageClass()) + { + player.addItem(getClass().getSimpleName(), 37321, 1, player, true); + } + else + { + player.addItem(getClass().getSimpleName(), 37320, 1, player, true); + } + break; + } + case KAMAEL: + { + player.addItem(getClass().getSimpleName(), 37319, 1, player, true); + break; + } + case ERTHEIA: + { + if (player.isMageClass()) + { + player.addItem(getClass().getSimpleName(), 26229, 1, player, true); + } + else + { + player.addItem(getClass().getSimpleName(), 26230, 1, player, true); + } + break; + } + } + return true; + } +} diff --git a/trunk/dist/game/data/stats/items/37300-37399.xml b/trunk/dist/game/data/stats/items/37300-37399.xml index cc6efce933..a212973bb1 100644 --- a/trunk/dist/game/data/stats/items/37300-37399.xml +++ b/trunk/dist/game/data/stats/items/37300-37399.xml @@ -209,6 +209,11 @@ + + + + +