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 @@
-
+
+
+
+
+
-