|
|
|
@ -36,7 +36,7 @@ IceHUD.CanTrackOtherUnitBuffs = not IceHUD.WowClassic
|
|
|
|
|
IceHUD.CanTrackGCD = not IceHUD.WowClassic
|
|
|
|
|
IceHUD.GetSpellInfoReturnsFunnel = IceHUD.WowMain and IceHUD.WowVer < 60000
|
|
|
|
|
IceHUD.CanHookDestroyTotem = IceHUD.WowClassic or IceHUD.WowClassicBC
|
|
|
|
|
IceHUD.ShouldUpdateTargetHealthEveryTick = IceHUD.WowClassicBC and GetCVarBool("predictedHealth")
|
|
|
|
|
IceHUD.ShouldUpdateTargetHealthEveryTick = (IceHUD.WowClassic or IceHUD.WowClassicBC) and GetCVarBool("predictedHealth")
|
|
|
|
|
|
|
|
|
|
IceHUD.UnitPowerEvent = "UNIT_POWER_UPDATE"
|
|
|
|
|
|
|
|
|
@ -44,6 +44,8 @@ IceHUD.validBarList = { "Bar", "HiBar", "RoundBar", "ColorBar", "RivetBar", "Riv
|
|
|
|
|
"BloodGlaives", "ArcHUD", "FangRune", "DHUD", "CleanCurvesOut", "CleanTank", "PillTank", "GemTank" }
|
|
|
|
|
IceHUD.validCustomModules = {Bar="Buff/Debuff watcher", Counter="Buff/Debuff stack counter", CD="Cooldown bar", Health="Health bar", Mana="Mana bar", CounterBar="Stack count bar"}
|
|
|
|
|
|
|
|
|
|
IceHUD_UnitFrame_DropDown = CreateFrame("Frame", "IceHUD_UnitFrame_DropDown", UIParent, "UIDropDownMenuTemplate")
|
|
|
|
|
|
|
|
|
|
--@debug@
|
|
|
|
|
IceHUD.optionsLoaded = true
|
|
|
|
|
--@end-debug@
|
|
|
|
@ -684,31 +686,69 @@ function IceHUD:GetIsInLFGGroup()
|
|
|
|
|
return IsInLFGGroup
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
local BLACKLISTED_UNIT_MENU_OPTIONS = {
|
|
|
|
|
SET_FOCUS = "ICEHUD_SET_FOCUS",
|
|
|
|
|
CLEAR_FOCUS = "ICEHUD_CLEAR_FOCUS",
|
|
|
|
|
PET_DISMISS = "ICEHUD_PET_DISMISS",
|
|
|
|
|
LOCK_FOCUS_FRAME = true,
|
|
|
|
|
UNLOCK_FOCUS_FRAME = true,
|
|
|
|
|
}
|
|
|
|
|
local BLACKLISTED_UNIT_MENU_OPTIONS = {}
|
|
|
|
|
if UnitPopupButtons then
|
|
|
|
|
BLACKLISTED_UNIT_MENU_OPTIONS = {
|
|
|
|
|
SET_FOCUS = "ICEHUD_SET_FOCUS",
|
|
|
|
|
CLEAR_FOCUS = "ICEHUD_CLEAR_FOCUS",
|
|
|
|
|
LOCK_FOCUS_FRAME = true,
|
|
|
|
|
UNLOCK_FOCUS_FRAME = true,
|
|
|
|
|
}
|
|
|
|
|
if select(2, UnitClass("player")) ~= "WARLOCK" then
|
|
|
|
|
BLACKLISTED_UNIT_MENU_OPTIONS[PET_DISMISS] = "ICEHUD_PET_DISMISS"
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
UnitPopupButtons["ICEHUD_SET_FOCUS"] = {
|
|
|
|
|
text = L["Type %s to set focus"]:format(SLASH_FOCUS1),
|
|
|
|
|
tooltipText = L["Blizzard currently does not provide a proper way to right-click focus with custom unit frames."],
|
|
|
|
|
dist = 0,
|
|
|
|
|
}
|
|
|
|
|
UnitPopupButtons["ICEHUD_SET_FOCUS"] = {
|
|
|
|
|
text = L["Type %s to set focus"]:format(SLASH_FOCUS1),
|
|
|
|
|
tooltipText = L["Blizzard currently does not provide a proper way to right-click focus with custom unit frames."],
|
|
|
|
|
dist = 0,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
UnitPopupButtons["ICEHUD_CLEAR_FOCUS"] = {
|
|
|
|
|
text = L["Type %s to clear focus"]:format(SLASH_CLEARFOCUS1),
|
|
|
|
|
tooltipText = L["Blizzard currently does not provide a proper way to right-click focus with custom unit frames."],
|
|
|
|
|
dist = 0,
|
|
|
|
|
}
|
|
|
|
|
UnitPopupButtons["ICEHUD_CLEAR_FOCUS"] = {
|
|
|
|
|
text = L["Type %s to clear focus"]:format(SLASH_CLEARFOCUS1),
|
|
|
|
|
tooltipText = L["Blizzard currently does not provide a proper way to right-click focus with custom unit frames."],
|
|
|
|
|
dist = 0,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
UnitPopupButtons["ICEHUD_PET_DISMISS"] = {
|
|
|
|
|
text = L["Use your Dismiss Pet spell to dismiss a pet"],
|
|
|
|
|
tooltipText = L["Blizzard currently does not provide a proper way to right-click dismiss a pet with custom unit frames."],
|
|
|
|
|
dist = 0,
|
|
|
|
|
}
|
|
|
|
|
UnitPopupButtons["ICEHUD_PET_DISMISS"] = {
|
|
|
|
|
text = L["Use your Dismiss Pet spell to dismiss a pet"],
|
|
|
|
|
tooltipText = L["Blizzard currently does not provide a proper way to right-click dismiss a pet with custom unit frames."],
|
|
|
|
|
dist = 0,
|
|
|
|
|
}
|
|
|
|
|
elseif UnitPopupSetFocusButtonMixin then
|
|
|
|
|
IceHUDUnitPopupSetFocusButtonMixin = CreateFromMixins(UnitPopupButtonBaseMixin)
|
|
|
|
|
function IceHUDUnitPopupSetFocusButtonMixin:GetText()
|
|
|
|
|
return L["Type %s to set focus"]:format(SLASH_FOCUS1)
|
|
|
|
|
end
|
|
|
|
|
function IceHUDUnitPopupSetFocusButtonMixin:OnClick()
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
IceHUDUnitPopupClearFocusButtonMixin = CreateFromMixins(UnitPopupButtonBaseMixin)
|
|
|
|
|
function IceHUDUnitPopupClearFocusButtonMixin:GetText()
|
|
|
|
|
return L["Type %s to clear focus"]:format(SLASH_CLEARFOCUS1)
|
|
|
|
|
end
|
|
|
|
|
function IceHUDUnitPopupClearFocusButtonMixin:OnClick()
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
IceHUDUnitPopupPetDismissButtonMixin = CreateFromMixins(UnitPopupButtonBaseMixin)
|
|
|
|
|
function IceHUDUnitPopupPetDismissButtonMixin:GetText()
|
|
|
|
|
return L["Use your Dismiss Pet spell to dismiss a pet"]
|
|
|
|
|
end
|
|
|
|
|
function IceHUDUnitPopupPetDismissButtonMixin:CanShow()
|
|
|
|
|
return UnitPopupPetDismissButtonMixin:CanShow()
|
|
|
|
|
end
|
|
|
|
|
function IceHUDUnitPopupPetDismissButtonMixin:OnClick()
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
BLACKLISTED_UNIT_MENU_OPTIONS[SET_FOCUS] = IceHUDUnitPopupSetFocusButtonMixin
|
|
|
|
|
BLACKLISTED_UNIT_MENU_OPTIONS[CLEAR_FOCUS] = IceHUDUnitPopupClearFocusButtonMixin
|
|
|
|
|
BLACKLISTED_UNIT_MENU_OPTIONS[LOCK_FOCUS_FRAME] = true
|
|
|
|
|
BLACKLISTED_UNIT_MENU_OPTIONS[UNLOCK_FOCUS_FRAME] = true
|
|
|
|
|
|
|
|
|
|
if select(2, UnitClass("player")) ~= "WARLOCK" then
|
|
|
|
|
BLACKLISTED_UNIT_MENU_OPTIONS[PET_DISMISS] = IceHUDUnitPopupPetDismissButtonMixin
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
local munged_unit_menus = {}
|
|
|
|
|
local function munge_unit_menu(menu)
|
|
|
|
@ -729,11 +769,34 @@ local function munge_unit_menu(menu)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
local found = false
|
|
|
|
|
local _, v
|
|
|
|
|
for _, v in ipairs(data) do
|
|
|
|
|
if BLACKLISTED_UNIT_MENU_OPTIONS[v] then
|
|
|
|
|
found = true
|
|
|
|
|
break
|
|
|
|
|
if data.GetMenuButtons then
|
|
|
|
|
local btns = data.GetMenuButtons()
|
|
|
|
|
for i=1, #btns do
|
|
|
|
|
if btns[i].IsMenu() then
|
|
|
|
|
local subbtns = btns[i].GetMenuButtons()
|
|
|
|
|
for j=1, #subbtns do
|
|
|
|
|
if BLACKLISTED_UNIT_MENU_OPTIONS[subbtns[j]:GetText()] then
|
|
|
|
|
found = true
|
|
|
|
|
break
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
else
|
|
|
|
|
if BLACKLISTED_UNIT_MENU_OPTIONS[btns[i]:GetText()] then
|
|
|
|
|
found = true
|
|
|
|
|
break
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
if found then
|
|
|
|
|
break
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
else
|
|
|
|
|
for _, v in ipairs(data) do
|
|
|
|
|
if BLACKLISTED_UNIT_MENU_OPTIONS[v] then
|
|
|
|
|
found = true
|
|
|
|
|
break
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
@ -744,15 +807,42 @@ local function munge_unit_menu(menu)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
local new_data = {}
|
|
|
|
|
for _, v in ipairs(data) do
|
|
|
|
|
local blacklisted = BLACKLISTED_UNIT_MENU_OPTIONS[v]
|
|
|
|
|
if v == "PET_DISMISS" and select(2, UnitClass("player")) == "WARLOCK" then
|
|
|
|
|
blacklisted = false
|
|
|
|
|
if data.GetMenuButtons then
|
|
|
|
|
local new_buttons_list = {}
|
|
|
|
|
local btns = data.GetMenuButtons()
|
|
|
|
|
for i=1, #btns do
|
|
|
|
|
if btns[i].IsMenu() then
|
|
|
|
|
local subbtns = btns[i].GetMenuButtons()
|
|
|
|
|
for j=1, #subbtns do
|
|
|
|
|
local blacklisted = BLACKLISTED_UNIT_MENU_OPTIONS[subbtns[j]:GetText()]
|
|
|
|
|
if not blacklisted then
|
|
|
|
|
new_buttons_list[#new_buttons_list+1] = subbtns[j]
|
|
|
|
|
elseif blacklisted ~= true then
|
|
|
|
|
new_buttons_list[#new_buttons_list+1] = blacklisted
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
else
|
|
|
|
|
local blacklisted = BLACKLISTED_UNIT_MENU_OPTIONS[btns[i]:GetText()]
|
|
|
|
|
if not blacklisted then
|
|
|
|
|
new_buttons_list[#new_buttons_list+1] = btns[i]
|
|
|
|
|
elseif blacklisted ~= true then
|
|
|
|
|
new_buttons_list[#new_buttons_list+1] = blacklisted
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
if not blacklisted then
|
|
|
|
|
new_data[#new_data+1] = v
|
|
|
|
|
elseif blacklisted ~= true then
|
|
|
|
|
new_data[#new_data+1] = blacklisted
|
|
|
|
|
|
|
|
|
|
new_data = data
|
|
|
|
|
function new_data:GetMenuButtons()
|
|
|
|
|
return new_buttons_list
|
|
|
|
|
end
|
|
|
|
|
else
|
|
|
|
|
for _, v in ipairs(data) do
|
|
|
|
|
local blacklisted = BLACKLISTED_UNIT_MENU_OPTIONS[v]
|
|
|
|
|
if not blacklisted then
|
|
|
|
|
new_data[#new_data+1] = v
|
|
|
|
|
elseif blacklisted ~= true then
|
|
|
|
|
new_data[#new_data+1] = blacklisted
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
local new_menu_name = "ICEHUD_" .. menu
|
|
|
|
@ -798,7 +888,6 @@ local function figure_unit_menu(unit)
|
|
|
|
|
return "PLAYER"
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
IceHUD_UnitFrame_DropDown = CreateFrame("Frame", "IceHUD_UnitFrame_DropDown", UIParent, "UIDropDownMenuTemplate")
|
|
|
|
|
if UnitPopupFrames then
|
|
|
|
|
UnitPopupFrames[#UnitPopupFrames+1] = "IceHUD_UnitFrame_DropDown"
|
|
|
|
|
end
|
|
|
|
|