|
|
|
@ -5,8 +5,8 @@ local Bastion = _Bastion |
|
|
|
|
|
|
|
|
|
---@alias BigWigsBars table<string, { spellId: number, duration: number, startTime: number, pauseTime: number | nil }> |
|
|
|
|
|
|
|
|
|
---@class MythicPlusUtils |
|
|
|
|
local MythicPlusUtils = { |
|
|
|
|
---@class ContentUtils |
|
|
|
|
local ContentUtils = { |
|
|
|
|
---@type InterruptList |
|
|
|
|
interruptList = {}, |
|
|
|
|
---@type TankBusterList |
|
|
|
@ -16,7 +16,7 @@ local MythicPlusUtils = { |
|
|
|
|
isBigWigsEnabled = false |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
MythicPlusUtils.__index = MythicPlusUtils |
|
|
|
|
ContentUtils.__index = ContentUtils |
|
|
|
|
|
|
|
|
|
local function BWEventCallBack(event, ...) |
|
|
|
|
if event == "BigWigs_StartBar" then |
|
|
|
@ -25,56 +25,56 @@ local function BWEventCallBack(event, ...) |
|
|
|
|
|
|
|
|
|
print('START BAR', text) |
|
|
|
|
|
|
|
|
|
MythicPlusUtils.bars[text] = MythicPlusUtils.bars[text] or {} |
|
|
|
|
ContentUtils.bars[text] = ContentUtils.bars[text] or {} |
|
|
|
|
|
|
|
|
|
MythicPlusUtils.bars[text].duration = duration |
|
|
|
|
MythicPlusUtils.bars[text].startTime = now |
|
|
|
|
MythicPlusUtils.bars[text].spellId = spellId |
|
|
|
|
ContentUtils.bars[text].duration = duration |
|
|
|
|
ContentUtils.bars[text].startTime = now |
|
|
|
|
ContentUtils.bars[text].spellId = spellId |
|
|
|
|
elseif event == "BigWigs_StopBar" then |
|
|
|
|
local addon, text = ... |
|
|
|
|
|
|
|
|
|
print('STOP BAR', text) |
|
|
|
|
|
|
|
|
|
if MythicPlusUtils.bars[text] then |
|
|
|
|
MythicPlusUtils.bars[text] = nil |
|
|
|
|
if ContentUtils.bars[text] then |
|
|
|
|
ContentUtils.bars[text] = nil |
|
|
|
|
end |
|
|
|
|
elseif event == "BigWigs_PauseBar" then |
|
|
|
|
local addon, text = ... |
|
|
|
|
|
|
|
|
|
print('PAUSE BAR', text) |
|
|
|
|
|
|
|
|
|
if MythicPlusUtils.bars[text] then |
|
|
|
|
MythicPlusUtils.bars[text].pauseTime = GetTime() |
|
|
|
|
if ContentUtils.bars[text] then |
|
|
|
|
ContentUtils.bars[text].pauseTime = GetTime() |
|
|
|
|
end |
|
|
|
|
elseif event == "BigWigs_ResumeBar" then |
|
|
|
|
local addon, text = ... |
|
|
|
|
|
|
|
|
|
print('RESUME BAR', text) |
|
|
|
|
|
|
|
|
|
if MythicPlusUtils.bars[text] and MythicPlusUtils.bars[text].pauseTime then |
|
|
|
|
local pauseTime = MythicPlusUtils.bars[text].pauseTime |
|
|
|
|
local startTime = MythicPlusUtils.bars[text].startTime |
|
|
|
|
local duration = MythicPlusUtils.bars[text].duration |
|
|
|
|
if ContentUtils.bars[text] and ContentUtils.bars[text].pauseTime then |
|
|
|
|
local pauseTime = ContentUtils.bars[text].pauseTime |
|
|
|
|
local startTime = ContentUtils.bars[text].startTime |
|
|
|
|
local duration = ContentUtils.bars[text].duration |
|
|
|
|
|
|
|
|
|
local newDuration = duration - (pauseTime - startTime) |
|
|
|
|
|
|
|
|
|
MythicPlusUtils.bars[text].duration = newDuration |
|
|
|
|
MythicPlusUtils.bars[text].startTime = GetTime() |
|
|
|
|
MythicPlusUtils.bars[text].pauseTime = nil |
|
|
|
|
ContentUtils.bars[text].pauseTime = nil |
|
|
|
|
ContentUtils.bars[text].duration = newDuration |
|
|
|
|
ContentUtils.bars[text].startTime = GetTime() |
|
|
|
|
end |
|
|
|
|
elseif event == "BigWigs_StopBars" or event == "BigWigs_OnBossDisable" then |
|
|
|
|
MythicPlusUtils.bars = {} |
|
|
|
|
ContentUtils.bars = {} |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
---@type InterruptList |
|
|
|
|
local _interruptList = Tinkr:require("scripts/bastion/MythicPlusUtils/lists/interrupt-list", Bastion) |
|
|
|
|
local _interruptList = Tinkr:require("scripts/bastion/ContentUtils/lists/interrupt-list", Bastion) |
|
|
|
|
---@type TankBusterList |
|
|
|
|
local _tankBusterList = Tinkr:require("scripts/bastion/MythicPlusUtils/lists/tank-buster-list", Bastion) |
|
|
|
|
local _tankBusterList = Tinkr:require("scripts/bastion/ContentUtils/lists/tank-buster-list", Bastion) |
|
|
|
|
|
|
|
|
|
---@return MythicPlusUtils |
|
|
|
|
function MythicPlusUtils:New() |
|
|
|
|
local self = setmetatable({}, MythicPlusUtils) |
|
|
|
|
---@return ContentUtils |
|
|
|
|
function ContentUtils:New() |
|
|
|
|
local self = setmetatable({}, ContentUtils) |
|
|
|
|
|
|
|
|
|
self.interruptList = _interruptList |
|
|
|
|
self.tankBusterList = _tankBusterList |
|
|
|
@ -95,8 +95,8 @@ end |
|
|
|
|
|
|
|
|
|
---@param unit Unit |
|
|
|
|
---@param percent number |
|
|
|
|
---@return { kickable: boolean, paraliseable: boolean, sweepable: boolean } | nil |
|
|
|
|
function MythicPlusUtils:CastingCriticalStop(unit, percent) |
|
|
|
|
---@return Interrupt | nil |
|
|
|
|
function ContentUtils:CastingCriticalStop(unit, percent) |
|
|
|
|
local castingSpell = unit:GetCastingOrChannelingSpell() |
|
|
|
|
|
|
|
|
|
local npcSpells = self.interruptList[unit:GetID()] |
|
|
|
@ -120,7 +120,7 @@ function MythicPlusUtils:CastingCriticalStop(unit, percent) |
|
|
|
|
return nil |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
function MythicPlusUtils:RefreshBars() |
|
|
|
|
function ContentUtils:RefreshBars() |
|
|
|
|
if self.isBigWigsEnabled then |
|
|
|
|
for key, value in pairs(self.bars) do |
|
|
|
|
local expireTime = value.duration + value.startTime |
|
|
|
@ -135,11 +135,11 @@ end |
|
|
|
|
---@param spellId number |
|
|
|
|
---@param timeUntilCast number |
|
|
|
|
---@return boolean |
|
|
|
|
function MythicPlusUtils:IsSpellCastSoon(spellId, timeUntilCast) |
|
|
|
|
function ContentUtils:IsSpellCastSoon(spellId, timeUntilCast) |
|
|
|
|
if self.isBigWigsEnabled then |
|
|
|
|
self:RefreshBars() |
|
|
|
|
for key, value in pairs(self.bars) do |
|
|
|
|
if value.spellId == spellId then |
|
|
|
|
if value.spellId == spellId and not value.pauseTime then |
|
|
|
|
local expireTime = value.duration + value.startTime |
|
|
|
|
|
|
|
|
|
local timeUntilSpell = expireTime - GetTime() |
|
|
|
@ -155,10 +155,31 @@ end |
|
|
|
|
|
|
|
|
|
---@param unit Unit |
|
|
|
|
---@param timeUntilCast? number |
|
|
|
|
---@return boolean |
|
|
|
|
function MythicPlusUtils:CastingTankBuster(unit, timeUntilCast) |
|
|
|
|
---@return TankBuster | nil |
|
|
|
|
function ContentUtils:CastingTankBuster(unit, timeUntilCast) |
|
|
|
|
local npcSpells = self.tankBusterList[unit:GetID()] |
|
|
|
|
|
|
|
|
|
return false |
|
|
|
|
if npcSpells then |
|
|
|
|
-- If timeUntilCast is provided, check if any of this NPC |
|
|
|
|
if timeUntilCast then |
|
|
|
|
for key, value in pairs(self.bars) do |
|
|
|
|
local spellTraits = npcSpells[value.spellId] |
|
|
|
|
|
|
|
|
|
if spellTraits and not value.pauseTime and ((value.startTime + value.duration) - GetTime()) <= timeUntilCast then |
|
|
|
|
return spellTraits |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
local castingSpell = unit:GetCastingOrChannelingSpell() |
|
|
|
|
|
|
|
|
|
if castingSpell then |
|
|
|
|
if npcSpells[castingSpell:GetID()] then return npcSpells[castingSpell:GetID()] end |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
return nil |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
return MythicPlusUtils |
|
|
|
|
return ContentUtils |