aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sql/updates/world/master/2021_12_12_15_world_2019_06_29_01_world.sql2
-rw-r--r--src/server/game/Spells/SpellEffects.cpp53
-rw-r--r--src/server/scripts/Spells/spell_item.cpp75
3 files changed, 69 insertions, 61 deletions
diff --git a/sql/updates/world/master/2021_12_12_15_world_2019_06_29_01_world.sql b/sql/updates/world/master/2021_12_12_15_world_2019_06_29_01_world.sql
new file mode 100644
index 00000000000..7e5afdfc8e0
--- /dev/null
+++ b/sql/updates/world/master/2021_12_12_15_world_2019_06_29_01_world.sql
@@ -0,0 +1,2 @@
+DELETE FROM `spell_script_names` WHERE `ScriptName`='spell_item_ultrasafe_transporter';
+INSERT INTO `spell_script_names` VALUES (36941,'spell_item_ultrasafe_transporter');
diff --git a/src/server/game/Spells/SpellEffects.cpp b/src/server/game/Spells/SpellEffects.cpp
index f8d4783fa6b..1916f6b4ad5 100644
--- a/src/server/game/Spells/SpellEffects.cpp
+++ b/src/server/game/Spells/SpellEffects.cpp
@@ -917,59 +917,6 @@ void Spell::EffectTeleportUnits()
}
return;
}
- // Ultrasafe Transporter: Toshley's Station
- case 36941:
- {
- if (roll_chance_i(50)) // 50% success
- {
- int32 rand_eff = urand(1, 7);
- switch (rand_eff)
- {
- case 1:
- // soul split - evil
- m_caster->CastSpell(m_caster, 36900, CastSpellExtraArgs(TRIGGERED_FULL_MASK)
- .SetOriginalCastId(m_castId));
- break;
- case 2:
- // soul split - good
- m_caster->CastSpell(m_caster, 36901, CastSpellExtraArgs(TRIGGERED_FULL_MASK)
- .SetOriginalCastId(m_castId));
- break;
- case 3:
- // Increase the size
- m_caster->CastSpell(m_caster, 36895, CastSpellExtraArgs(TRIGGERED_FULL_MASK)
- .SetOriginalCastId(m_castId));
- break;
- case 4:
- // Decrease the size
- m_caster->CastSpell(m_caster, 36893, CastSpellExtraArgs(TRIGGERED_FULL_MASK)
- .SetOriginalCastId(m_castId));
- break;
- case 5:
- // Transform
- {
- if (m_caster->ToPlayer()->GetTeam() == ALLIANCE)
- m_caster->CastSpell(m_caster, 36897, CastSpellExtraArgs(TRIGGERED_FULL_MASK)
- .SetOriginalCastId(m_castId));
- else
- m_caster->CastSpell(m_caster, 36899, CastSpellExtraArgs(TRIGGERED_FULL_MASK)
- .SetOriginalCastId(m_castId));
- break;
- }
- case 6:
- // chicken
- m_caster->CastSpell(m_caster, 36940, CastSpellExtraArgs(TRIGGERED_FULL_MASK)
- .SetOriginalCastId(m_castId));
- break;
- case 7:
- // evil twin
- m_caster->CastSpell(m_caster, 23445, CastSpellExtraArgs(TRIGGERED_FULL_MASK)
- .SetOriginalCastId(m_castId));
- break;
- }
- }
- return;
- }
}
}
diff --git a/src/server/scripts/Spells/spell_item.cpp b/src/server/scripts/Spells/spell_item.cpp
index dc4b3a24ba2..2538f536ff6 100644
--- a/src/server/scripts/Spells/spell_item.cpp
+++ b/src/server/scripts/Spells/spell_item.cpp
@@ -1710,16 +1710,74 @@ class spell_item_scroll_of_recall : public SpellScript
}
};
-// 36890 - Dimensional Ripper - Area 52
-enum DimensionalRipperArea52
+enum TransporterSpells
+{
+ SPELL_EVIL_TWIN = 23445,
+ SPELL_TRANSPORTER_MALFUNCTION_SMALLER = 36893,
+ SPELL_TRANSPORTER_MALFUNCTION_BIGGER = 36895,
+ SPELL_TRANSPORTER_MALFUNCTION_CHICKEN = 36940,
+ SPELL_TRANSFORM_HORDE = 36897,
+ SPELL_TRANSFORM_ALLIANCE = 36899,
+ SPELL_SOUL_SPLIT_EVIL = 36900,
+ SPELL_SOUL_SPLIT_GOOD = 36901
+};
+
+// 36941 - Ultrasafe Transporter: Toshley's Station
+class spell_item_ultrasafe_transporter : public SpellScript
{
- SPELL_TRANSPORTER_MALFUNCTION = 36895,
- SPELL_TRANSFORM_HORDE = 36897,
- SPELL_TRANSFORM_ALLIANCE = 36899,
- SPELL_SOUL_SPLIT_EVIL = 36900,
- SPELL_SOUL_SPLIT_GOOD = 36901
+ PrepareSpellScript(spell_item_ultrasafe_transporter);
+
+ bool Load() override
+ {
+ return GetCaster()->GetTypeId() == TYPEID_PLAYER;
+ }
+
+ void HandleScript(SpellEffIndex /* effIndex */)
+ {
+ if (!roll_chance_i(50)) // 50% success
+ return;
+
+ Unit* caster = GetCaster();
+
+ uint32 spellId = 0;
+ switch (urand(0, 6))
+ {
+ case 0:
+ spellId = SPELL_TRANSPORTER_MALFUNCTION_SMALLER;
+ break;
+ case 1:
+ spellId = SPELL_TRANSPORTER_MALFUNCTION_BIGGER;
+ break;
+ case 2:
+ spellId = SPELL_SOUL_SPLIT_EVIL;
+ break;
+ case 3:
+ spellId = SPELL_SOUL_SPLIT_GOOD;
+ break;
+ case 4:
+ if (caster->ToPlayer()->GetTeamId() == TEAM_ALLIANCE)
+ spellId = SPELL_TRANSFORM_HORDE;
+ else
+ spellId = SPELL_TRANSFORM_ALLIANCE;
+ break;
+ case 5:
+ spellId = SPELL_TRANSPORTER_MALFUNCTION_CHICKEN;
+ break;
+ case 6:
+ spellId = SPELL_EVIL_TWIN;
+ break;
+ }
+
+ caster->CastSpell(caster, spellId, true);
+ }
+
+ void Register() override
+ {
+ OnEffectHitTarget += SpellEffectFn(spell_item_ultrasafe_transporter::HandleScript, EFFECT_0, SPELL_EFFECT_TELEPORT_UNITS);
+ }
};
+// 36890 - Dimensional Ripper - Area 52
class spell_item_dimensional_ripper_area52 : public SpellScript
{
PrepareSpellScript(spell_item_dimensional_ripper_area52);
@@ -1740,7 +1798,7 @@ class spell_item_dimensional_ripper_area52 : public SpellScript
switch (urand(0, 3))
{
case 0:
- spellId = SPELL_TRANSPORTER_MALFUNCTION;
+ spellId = SPELL_TRANSPORTER_MALFUNCTION_BIGGER;
break;
case 1:
spellId = SPELL_SOUL_SPLIT_EVIL;
@@ -4296,6 +4354,7 @@ void AddSC_item_spell_scripts()
RegisterAuraScript(spell_item_power_circle);
RegisterSpellScript(spell_item_savory_deviate_delight);
RegisterSpellScript(spell_item_scroll_of_recall);
+ RegisterSpellScript(spell_item_ultrasafe_transporter);
RegisterSpellScript(spell_item_dimensional_ripper_area52);
RegisterAuraScript(spell_item_unsated_craving);
RegisterAuraScript(spell_item_shadows_fate);