added aura tracker frame /details auras
This commit is contained in:
@@ -0,0 +1,385 @@
|
||||
|
||||
local Details = Details
|
||||
local DF = DetailsFramework
|
||||
local _
|
||||
|
||||
--namespace
|
||||
Details.AuraTracker = {
|
||||
buff = {},
|
||||
debuff = {},
|
||||
}
|
||||
|
||||
--frame options
|
||||
local windowWidth = 800
|
||||
local windowHeight = 670
|
||||
local scrollWidth = 790
|
||||
local scrollHeightBuff = 400
|
||||
local scrollHeightDebuff = 200
|
||||
local scrollLineAmountBuff = 20
|
||||
local scrollLineAmountDebuff = 10
|
||||
local scrollLineHeight = 20
|
||||
|
||||
--templates
|
||||
local dropdownTemplate = DetailsFramework:GetTemplate("dropdown", "OPTIONS_DROPDOWNDARK_TEMPLATE")
|
||||
|
||||
function Details.AuraTracker.AddAura(auraType, spellid)
|
||||
Details.AuraTracker[auraType][spellid] = true
|
||||
end
|
||||
|
||||
local doFullAuraUpdate = function()
|
||||
wipe(Details.AuraTracker.buff)
|
||||
wipe(Details.AuraTracker.debuff)
|
||||
|
||||
local function HandleAuraBuff(aura)
|
||||
local auraInfo = C_UnitAuras.GetAuraDataByAuraInstanceID("player", aura.auraInstanceID)
|
||||
|
||||
local spellId = auraInfo.spellId
|
||||
local isBossAura = auraInfo.isBossAura --"] = false
|
||||
local duration = auraInfo.duration --"] = 0
|
||||
local expirationTime = auraInfo.expirationTime --"] = 0
|
||||
local isFromPlayerOrPlayerPet = auraInfo.isFromPlayerOrPlayerPet --"] = true
|
||||
local points = auraInfo.points --"] = table { ["1"] = 200 ["2"] = 0 ["3"] = 400 }
|
||||
local icon = auraInfo.icon --"] = 135922
|
||||
local nameplateShowPersonal = auraInfo.nameplateShowPersonal --"] = false
|
||||
local nameplateShowAll = auraInfo.nameplateShowAll --"] = false
|
||||
local auraInstanceID = auraInfo.auraInstanceID --"] = 8871
|
||||
local timeMod = auraInfo.timeMod --"] = 1
|
||||
local isRaid = auraInfo.isRaid --"] = false
|
||||
local isHarmful = auraInfo.isHarmful --"] = false
|
||||
local canApplyAura = auraInfo.canApplyAura --"] = false
|
||||
local name = auraInfo.name --"] = 'Rhapsody'
|
||||
local isHelpful = auraInfo.isHelpful --"] = true
|
||||
local applications = auraInfo.applications --"] = 20
|
||||
local isNameplateOnly = auraInfo.isNameplateOnly --"] = false
|
||||
local sourceUnit = auraInfo.sourceUnit --"] = 'player'
|
||||
local isStealable = auraInfo.isStealable --"] = false
|
||||
|
||||
Details.AuraTracker.buff[aura.auraInstanceID] = auraInfo
|
||||
end
|
||||
|
||||
local function HandleAuraDebuff(aura)
|
||||
local auraInfo = C_UnitAuras.GetAuraDataByAuraInstanceID("player", aura.auraInstanceID)
|
||||
Details.AuraTracker.debuff[aura.auraInstanceID] = auraInfo
|
||||
end
|
||||
|
||||
local batchCount = nil
|
||||
local usePackedAura = true
|
||||
AuraUtil.ForEachAura("player", "HELPFUL", batchCount, HandleAuraBuff, usePackedAura)
|
||||
AuraUtil.ForEachAura("player", "HARMFUL", batchCount, HandleAuraDebuff, usePackedAura)
|
||||
|
||||
Details.AuraTracker.RefreshScrollData()
|
||||
end
|
||||
|
||||
local doIncrementalAuraUpdate = function(aurasUpdated)
|
||||
for _, auraInstanceId in ipairs(aurasUpdated) do
|
||||
local auraInfo = C_UnitAuras.GetAuraDataByAuraInstanceID("player", auraInstanceId)
|
||||
if (auraInfo.isHelpful) then
|
||||
Details.AuraTracker.buff[auraInstanceId] = auraInfo
|
||||
else
|
||||
Details.AuraTracker.debuff[auraInstanceId] = auraInfo
|
||||
end
|
||||
end
|
||||
Details.AuraTracker.RefreshScrollData()
|
||||
end
|
||||
|
||||
local doAddedAuraUpdate = function(aurasAdded)
|
||||
for _, auraInfo in ipairs(aurasAdded) do
|
||||
if (auraInfo.isHelpful) then
|
||||
Details.AuraTracker.buff[auraInfo.auraInstanceID] = auraInfo
|
||||
else
|
||||
Details.AuraTracker.debuff[auraInfo.auraInstanceID] = auraInfo
|
||||
end
|
||||
end
|
||||
Details.AuraTracker.RefreshScrollData()
|
||||
end
|
||||
|
||||
local doRemovedAuraUpdate = function(aurasRemoved)
|
||||
for _, auraInstanceId in ipairs(aurasRemoved) do
|
||||
if (Details.AuraTracker.buff[auraInstanceId]) then
|
||||
Details.AuraTracker.buff[auraInstanceId] = nil
|
||||
|
||||
elseif (Details.AuraTracker.debuff[auraInstanceId]) then
|
||||
Details.AuraTracker.debuff[auraInstanceId] = nil
|
||||
end
|
||||
end
|
||||
Details.AuraTracker.RefreshScrollData()
|
||||
end
|
||||
|
||||
function Details.AuraTracker.OnShowAuraTrackerFrame(auraTrackerFrame)
|
||||
doFullAuraUpdate()
|
||||
auraTrackerFrame.EventFrame:RegisterUnitEvent("UNIT_AURA", "player")
|
||||
end
|
||||
|
||||
function Details.AuraTracker.OnHideAuraTrackerFrame(auraTrackerFrame)
|
||||
auraTrackerFrame.EventFrame:UnregisterEvent("UNIT_AURA")
|
||||
end
|
||||
|
||||
function Details.AuraTracker.CreatePanel()
|
||||
--create a panel
|
||||
local auraTrackerFrame = DetailsFramework:CreateSimplePanel(UIParent)
|
||||
auraTrackerFrame:SetSize(windowWidth, windowHeight)
|
||||
auraTrackerFrame:SetTitle("Details! Aura Tracker")
|
||||
|
||||
--disable the buil-in mouse integration of the simple panel, doing this to use LibWindow-1.1 as the window management
|
||||
auraTrackerFrame:SetScript("OnMouseDown", nil)
|
||||
auraTrackerFrame:SetScript("OnMouseUp", nil)
|
||||
|
||||
Details.AuraTracker.AuraTrackerFrame = auraTrackerFrame
|
||||
auraTrackerFrame.data = {
|
||||
buffs = {},
|
||||
debuffs = {},
|
||||
}
|
||||
|
||||
auraTrackerFrame.EventFrame = CreateFrame("frame")
|
||||
auraTrackerFrame.EventFrame:SetScript("OnEvent", Details.AuraTracker.OnUnitAuraEvent)
|
||||
|
||||
--register in the libWindow
|
||||
local LibWindow = LibStub("LibWindow-1.1")
|
||||
LibWindow.RegisterConfig(auraTrackerFrame, Details.aura_tracker_frame.position)
|
||||
LibWindow.MakeDraggable(auraTrackerFrame)
|
||||
LibWindow.RestorePosition(auraTrackerFrame)
|
||||
|
||||
--scale bar
|
||||
local scaleBar = DetailsFramework:CreateScaleBar(auraTrackerFrame, Details.aura_tracker_frame.scaletable)
|
||||
auraTrackerFrame:SetScale(Details.aura_tracker_frame.scaletable.scale)
|
||||
|
||||
--status bar
|
||||
local statusBar = DetailsFramework:CreateStatusBar(auraTrackerFrame)
|
||||
statusBar.text = statusBar:CreateFontString(nil, "overlay", "GameFontNormal")
|
||||
statusBar.text:SetPoint("left", statusBar, "left", 5, 0)
|
||||
statusBar.text:SetText("Details! Damage Meter")
|
||||
DetailsFramework:SetFontSize(statusBar.text, 11)
|
||||
DetailsFramework:SetFontColor(statusBar.text, "gray")
|
||||
|
||||
--header
|
||||
local headerTable = {
|
||||
{text = "", width = 20},
|
||||
{text = "Aura Name", width = 162},
|
||||
{text = "Spell Id", width = 100},
|
||||
{text = "Lua Table", width = 250},
|
||||
{text = "Points", width = 100},
|
||||
}
|
||||
local headerOptions = {
|
||||
padding = 2,
|
||||
}
|
||||
|
||||
auraTrackerFrame.Header = DetailsFramework:CreateHeader(auraTrackerFrame, headerTable, headerOptions)
|
||||
auraTrackerFrame.Header:SetPoint("topleft", auraTrackerFrame, "topleft", 5, -22)
|
||||
|
||||
--create a scroll to show all buffs
|
||||
local buffScroll = DetailsFramework:CreateScrollBox(auraTrackerFrame, "$parentBuffScrollBox", Details.AuraTracker.RefreshScroll, auraTrackerFrame.data.buffs, scrollWidth, scrollHeightBuff, scrollLineAmountBuff, scrollLineHeight)
|
||||
DetailsFramework:ReskinSlider(buffScroll)
|
||||
buffScroll:CreateLines(Details.AuraTracker.CreateScrollLine, scrollLineAmountBuff)
|
||||
buffScroll:SetPoint("topleft", auraTrackerFrame, "topleft", 5, -42)
|
||||
auraTrackerFrame.BuffScroll = buffScroll
|
||||
|
||||
--create a scroll to show all debuffs
|
||||
local debuffScroll = DetailsFramework:CreateScrollBox(auraTrackerFrame, "$parentDebuffScrollBox", Details.AuraTracker.RefreshScroll, auraTrackerFrame.data.debuffs, scrollWidth, scrollHeightDebuff, scrollLineAmountDebuff, scrollLineHeight)
|
||||
debuffScroll:CreateLines(Details.AuraTracker.CreateScrollLine, scrollLineAmountDebuff)
|
||||
DetailsFramework:ReskinSlider(debuffScroll)
|
||||
debuffScroll:SetPoint("topleft", buffScroll, "bottomleft", 0, -2)
|
||||
auraTrackerFrame.DebuffScroll = debuffScroll
|
||||
end
|
||||
|
||||
local cachedPoints = {}
|
||||
local storeAuraPointsOnCache = function(auraInfo)
|
||||
local thisAuraCache = cachedPoints[auraInfo.spellId]
|
||||
if (not thisAuraCache) then
|
||||
thisAuraCache = {}
|
||||
cachedPoints[auraInfo.spellId] = thisAuraCache
|
||||
end
|
||||
|
||||
for i = 1, #auraInfo.points do
|
||||
thisAuraCache[auraInfo.points[i]] = 1
|
||||
end
|
||||
end
|
||||
|
||||
local formatToLuaTable = {
|
||||
--[232698] = 1, --Shadowform
|
||||
doFormat1 = function(auraInfo)
|
||||
return "[" .. auraInfo.spellId .. "] = 1, --" .. auraInfo.name
|
||||
end,
|
||||
|
||||
--[390636] = {[1] = 200, [200] = 1, [2] = 0, [0] = 2, [3] = 400, [400] = 3}, --Rhapsody
|
||||
doFormat2 = function(auraInfo)
|
||||
local pointsTable = {}
|
||||
for i = 1, #auraInfo.points do
|
||||
pointsTable[#pointsTable+1] = "[" .. i .. "] = " .. auraInfo.points[i]
|
||||
pointsTable[#pointsTable+1] = "[" .. auraInfo.points[i] .. "] = " .. i
|
||||
end
|
||||
return "[" .. auraInfo.spellId .. "] = {" .. table.concat(pointsTable, ", ") .. "}, --" .. auraInfo.name
|
||||
end,
|
||||
|
||||
--[371172] = {[236] = 1}, --Phial of Tepid Versatility
|
||||
doFormat2NoIndex = function(auraInfo)
|
||||
local pointsTable = {}
|
||||
for i = 1, #auraInfo.points do
|
||||
pointsTable[#pointsTable+1] = "[" .. auraInfo.points[i] .. "] = " .. i
|
||||
end
|
||||
return "[" .. auraInfo.spellId .. "] = {" .. table.concat(pointsTable, ", ") .. "}, --" .. auraInfo.name
|
||||
end,
|
||||
|
||||
--[572] = 1, [432] = 1, [75] = 1, [497] = 1
|
||||
doFormat2NoIndexFromCache = function(auraInfo)
|
||||
local points = cachedPoints[auraInfo.spellId] or {}
|
||||
local pointsTable = {}
|
||||
|
||||
for point in pairs(points) do
|
||||
pointsTable[#pointsTable+1] = "[" .. point .. "] = 1"
|
||||
end
|
||||
return table.concat(pointsTable, ", ")
|
||||
end,
|
||||
|
||||
--{[1] = 131, [131] = 1, [2] = 0, [0] = 2},
|
||||
doFormat3 = function(auraInfo)
|
||||
local pointsTable = {}
|
||||
for i = 1, #auraInfo.points do
|
||||
pointsTable[#pointsTable+1] = "[" .. i .. "] = " .. auraInfo.points[i]
|
||||
pointsTable[#pointsTable+1] = "[" .. auraInfo.points[i] .. "] = " .. i
|
||||
end
|
||||
return "{" .. table.concat(pointsTable, ", ") .. "},"
|
||||
end,
|
||||
|
||||
--same as 3 but ignore zeros
|
||||
doFormat4 = function(auraInfo)
|
||||
local pointsTable = {}
|
||||
for i = 1, #auraInfo.points do
|
||||
if (auraInfo.points[i] ~= 0) then
|
||||
pointsTable[#pointsTable+1] = "[" .. i .. "] = " .. auraInfo.points[i]
|
||||
pointsTable[#pointsTable+1] = "[" .. auraInfo.points[i] .. "] = " .. i
|
||||
end
|
||||
end
|
||||
return "{" .. table.concat(pointsTable, ", ") .. "},"
|
||||
end,
|
||||
|
||||
--200, 0, 400
|
||||
doFormat5 = function(auraInfo)
|
||||
return table.concat(auraInfo.points, ", ")
|
||||
end,
|
||||
}
|
||||
|
||||
--[371354] = {[131] = 1, [151] = 2, [174] = 3, [1] = 131, [2] = 151, [3] = 174}, --Phial of the Eye in the Storm
|
||||
|
||||
function Details.AuraTracker.RefreshScroll(self, data, offset, totalLines)
|
||||
for i = 1, totalLines do
|
||||
local index = i + offset
|
||||
local auraInfo = data[index]
|
||||
|
||||
if (auraInfo) then
|
||||
local line = self:GetLine(i)
|
||||
storeAuraPointsOnCache(auraInfo)
|
||||
line.Icon.texture = auraInfo.icon
|
||||
line.Name.text = auraInfo.name
|
||||
line.SpellId.text = auraInfo.spellId
|
||||
line.LuaTableEntry.text = formatToLuaTable.doFormat2NoIndex(auraInfo)
|
||||
line.Points.text = formatToLuaTable.doFormat2NoIndexFromCache(auraInfo)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
function Details.AuraTracker.RefreshScrollData()
|
||||
local buffData = {}
|
||||
for spellId, auraInfo in pairs(Details.AuraTracker.buff) do
|
||||
buffData[#buffData+1] = auraInfo
|
||||
end
|
||||
|
||||
local debuffData = {}
|
||||
for spellId, auraInfo in pairs(Details.AuraTracker.debuff) do
|
||||
debuffData[#debuffData+1] = auraInfo
|
||||
end
|
||||
|
||||
Details.AuraTracker.AuraTrackerFrame.BuffScroll:SetData(buffData)
|
||||
Details.AuraTracker.AuraTrackerFrame.BuffScroll:Refresh()
|
||||
Details.AuraTracker.AuraTrackerFrame.DebuffScroll:SetData(debuffData)
|
||||
Details.AuraTracker.AuraTrackerFrame.DebuffScroll:Refresh()
|
||||
end
|
||||
|
||||
function Details.AuraTracker.OnUnitAuraEvent(self, event, unit, unitAuraUpdateInfo)
|
||||
if (unitAuraUpdateInfo == nil or unitAuraUpdateInfo.isFullUpdate) then
|
||||
doFullAuraUpdate()
|
||||
else
|
||||
if (unitAuraUpdateInfo.removedAuraInstanceIDs) then
|
||||
doRemovedAuraUpdate(unitAuraUpdateInfo.removedAuraInstanceIDs)
|
||||
end
|
||||
|
||||
if (unitAuraUpdateInfo.updatedAuraInstanceIDs) then
|
||||
doIncrementalAuraUpdate(unitAuraUpdateInfo.updatedAuraInstanceIDs)
|
||||
end
|
||||
|
||||
if (unitAuraUpdateInfo.addedAuras) then
|
||||
doAddedAuraUpdate(unitAuraUpdateInfo.addedAuras)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
function Details.AuraTracker.CreateScrollLine(self, lineId)
|
||||
local line = CreateFrame("frame", "$parentLine" .. lineId, self, "BackdropTemplate")
|
||||
line.lineId = lineId
|
||||
|
||||
line:SetPoint("topleft", self, "topleft", 2, (scrollLineHeight * (lineId - 1) * -1) - 2)
|
||||
line:SetPoint("topright", self, "topright", -2, (scrollLineHeight * (lineId - 1) * -1) - 2)
|
||||
line:SetHeight(scrollLineHeight)
|
||||
|
||||
DetailsFramework:Mixin(line, DetailsFramework.HeaderFunctions)
|
||||
DetailsFramework.BackdropUtil:SetColorStripe(line, lineId)
|
||||
|
||||
local header = self:GetParent().Header
|
||||
|
||||
--aura icon
|
||||
local auraIconTexture = DetailsFramework:CreateTexture(line, "", scrollLineHeight - 2, scrollLineHeight - 2, "overlay", {.1, .9, .1, .9})
|
||||
|
||||
--aura name
|
||||
local auraNameTextField = DetailsFramework:CreateTextEntry(line, function()end, header:GetColumnWidth(2), scrollLineHeight, _, _, _, dropdownTemplate)
|
||||
auraNameTextField:SetJustifyH("left")
|
||||
auraNameTextField:SetTextInsets(3, 3, 0, 0)
|
||||
auraNameTextField:SetAutoSelectTextOnFocus(true)
|
||||
|
||||
--spellId text field
|
||||
local spellIdTextField = DetailsFramework:CreateTextEntry(line, function()end, header:GetColumnWidth(3), scrollLineHeight, _, _, _, dropdownTemplate)
|
||||
spellIdTextField:SetJustifyH("left")
|
||||
spellIdTextField:SetTextInsets(3, 3, 0, 0)
|
||||
spellIdTextField:SetAutoSelectTextOnFocus(true)
|
||||
|
||||
--formatted lua table
|
||||
local luaTableEntryTextField = DetailsFramework:CreateTextEntry(line, function()end, header:GetColumnWidth(4), scrollLineHeight, _, _, _, dropdownTemplate)
|
||||
luaTableEntryTextField:SetJustifyH("left")
|
||||
luaTableEntryTextField:SetTextInsets(3, 3, 0, 0)
|
||||
luaTableEntryTextField:SetAutoSelectTextOnFocus(true)
|
||||
|
||||
--points
|
||||
local pointsTextField = DetailsFramework:CreateTextEntry(line, function()end, header:GetColumnWidth(5), scrollLineHeight, _, _, _, dropdownTemplate)
|
||||
pointsTextField:SetJustifyH("left")
|
||||
pointsTextField:SetTextInsets(3, 3, 0, 0)
|
||||
pointsTextField:SetAutoSelectTextOnFocus(true)
|
||||
|
||||
line:AddFrameToHeaderAlignment(auraIconTexture)
|
||||
line:AddFrameToHeaderAlignment(auraNameTextField)
|
||||
line:AddFrameToHeaderAlignment(spellIdTextField)
|
||||
line:AddFrameToHeaderAlignment(luaTableEntryTextField)
|
||||
line:AddFrameToHeaderAlignment(pointsTextField)
|
||||
|
||||
line:AlignWithHeader(header, "left")
|
||||
|
||||
line.Icon = auraIconTexture
|
||||
line.Name = auraNameTextField
|
||||
line.SpellId = spellIdTextField
|
||||
line.LuaTableEntry = luaTableEntryTextField
|
||||
line.Points = pointsTextField
|
||||
|
||||
return line
|
||||
end
|
||||
|
||||
function Details.AuraTracker.Open()
|
||||
if (not Details.AuraTracker.framesCreated) then
|
||||
Details.AuraTracker.CreatePanel()
|
||||
end
|
||||
Details.AuraTracker.AuraTrackerFrame:Show()
|
||||
Details.AuraTracker.OnShowAuraTrackerFrame(Details.AuraTracker.AuraTrackerFrame)
|
||||
end
|
||||
|
||||
function Details.AuraTracker.Close()
|
||||
if (Details.AuraTracker.framesCreated) then
|
||||
Details.AuraTracker.AuraTrackerFrame:Hide()
|
||||
Details.AuraTracker.OnHideAuraTrackerFrame(Details.AuraTracker.AuraTrackerFrame)
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user