completely hide nameplate TotemPlates added

This commit is contained in:
Sumsebrum 2022-02-05 04:19:53 +01:00
parent 09bfb99681
commit 5212479dae

View File

@ -98,6 +98,18 @@ local function GetTotemColorDefaultOptions()
end) end)
for i=1,#indexedList do for i=1,#indexedList do
defaultDB["totem" .. indexedList[i].id] = {color = indexedList[i].color, enabled = indexedList[i].enabled, alpha = 0.6, customText = ""} defaultDB["totem" .. indexedList[i].id] = {color = indexedList[i].color, enabled = indexedList[i].enabled, alpha = 0.6, customText = ""}
options["npTotemsHideDisabledTotems"] = {
order = 1,
name = L["Hide Disabled Totem Plates"],
desc = L["Hide Disabled Totem Plates"],
type = "toggle",
width = "full",
get = function() return Gladdy.dbi.profile.npTotemsHideDisabledTotems end,
set = function(_, value)
Gladdy.dbi.profile.npTotemsHideDisabledTotems = value
Gladdy:UpdateFrame()
end
}
options["totem" .. indexedList[i].id] = { options["totem" .. indexedList[i].id] = {
order = i+1, order = i+1,
name = select(1, GetSpellInfo(indexedList[i].id)), name = select(1, GetSpellInfo(indexedList[i].id)),
@ -198,7 +210,8 @@ local TotemPlates = Gladdy:NewModule("Totem Plates", nil, {
npTotemPlatesAlpha = 0.6, npTotemPlatesAlpha = 0.6,
npTotemPlatesAlphaAlways = false, npTotemPlatesAlphaAlways = false,
npTotemPlatesAlphaAlwaysTargeted = false, npTotemPlatesAlphaAlwaysTargeted = false,
npTotemColors = select(1, GetTotemColorDefaultOptions()) npTotemColors = select(1, GetTotemColorDefaultOptions()),
npTotemsHideDisabledTotems = false,
}) })
LibStub("AceHook-3.0"):Embed(TotemPlates) LibStub("AceHook-3.0"):Embed(TotemPlates)
@ -295,6 +308,18 @@ function TotemPlates:UpdateFrameOnce()
nameplate.gladdyTotemFrame:Hide() nameplate.gladdyTotemFrame:Hide()
self:ToggleAddon(nameplate, true) self:ToggleAddon(nameplate, true)
end end
if Gladdy.db.npTotems and Gladdy.db.npTotemColors["totem" .. totemDataEntry.id].enabled then
nameplate.gladdyTotemFrame:Show()
self:ToggleAddon(nameplate)
end
if Gladdy.db.npTotems and not Gladdy.db.npTotemColors["totem" .. totemDataEntry.id].enabled then
nameplate.gladdyTotemFrame:Hide()
self:ToggleAddon(nameplate, true)
end
if Gladdy.db.npTotems and not Gladdy.db.npTotemColors["totem" .. totemDataEntry.id].enabled and Gladdy.db.npTotemsHideDisabledTotems then
nameplate.gladdyTotemFrame:Hide()
self:ToggleAddon(nameplate)
end
end end
for _,gladdyTotemFrame in ipairs(self.totemPlateCache) do for _,gladdyTotemFrame in ipairs(self.totemPlateCache) do
gladdyTotemFrame:SetWidth(Gladdy.db.npTotemPlatesSize * Gladdy.db.npTotemPlatesWidthFactor) gladdyTotemFrame:SetWidth(Gladdy.db.npTotemPlatesSize * Gladdy.db.npTotemPlatesWidthFactor)
@ -395,7 +420,7 @@ function TotemPlates:ToggleAddon(nameplate, show)
end end
function TotemPlates.OnUpdate(self) function TotemPlates.OnUpdate(self)
if (UnitIsUnit("mouseover", self.unitID) or UnitIsUnit("target", self.unitID)) then if (UnitIsUnit("mouseover", self.unitID) or UnitIsUnit("target", self.unitID)) and Gladdy.db.npTotemColors["totem" .. self.totemDataEntry.id].alpha > 0 then
self.selectionHighlight:SetAlpha(.25) self.selectionHighlight:SetAlpha(.25)
else else
self.selectionHighlight:SetAlpha(0) self.selectionHighlight:SetAlpha(0)
@ -452,6 +477,14 @@ function TotemPlates:OnUnitEvent(unitID)
TotemPlates:SetTotemAlpha(nameplate.gladdyTotemFrame, unitID) TotemPlates:SetTotemAlpha(nameplate.gladdyTotemFrame, unitID)
self:ToggleAddon(nameplate) self:ToggleAddon(nameplate)
self.activeTotemNameplates[unitID] = nameplate self.activeTotemNameplates[unitID] = nameplate
elseif totemDataEntry and not Gladdy.db.npTotemColors["totem" .. totemDataEntry.id].enabled and Gladdy.db.npTotemsHideDisabledTotems then
if nameplate.gladdyTotemFrame then
nameplate.gladdyTotemFrame:Hide()
nameplate.gladdyTotemFrame:SetParent(nil)
tinsert(self.totemPlateCache, nameplate.gladdyTotemFrame)
nameplate.gladdyTotemFrame = nil
end
self:ToggleAddon(nameplate)
else else
self:ToggleAddon(nameplate, true) self:ToggleAddon(nameplate, true)
end end