Files
coa-elvui/ElvUI_OptionsUI/UnitFrames.lua
T
andrew6180 0a792fb7f0 Revert "Add absorbs, heal absorbs (#90)"
This reverts commit 3d456d036a.
2025-12-24 18:11:21 -07:00

8291 lines
246 KiB
Lua

local E, _, V, P, G = unpack(ElvUI); --Import: Engine, Locales, PrivateDB, ProfileDB, GlobalDB
local C, L = unpack(select(2, ...))
local UF = E:GetModule("UnitFrames")
local _G = _G
local select, pairs, ipairs = select, pairs, ipairs
local tremove, tinsert, tconcat, twipe = table.remove, table.insert, table.concat, table.wipe
local format, strmatch, gsub, strsplit = string.format, strmatch, string.gsub, strsplit
local GetScreenWidth = GetScreenWidth
local IsAddOnLoaded = IsAddOnLoaded
local ACD = E.Libs.AceConfigDialog
local positionValues = {
TOPLEFT = "TOPLEFT",
LEFT = "LEFT",
BOTTOMLEFT = "BOTTOMLEFT",
RIGHT = "RIGHT",
TOPRIGHT = "TOPRIGHT",
BOTTOMRIGHT = "BOTTOMRIGHT",
CENTER = "CENTER",
TOP = "TOP",
BOTTOM = "BOTTOM"
}
local orientationValues = {
--["AUTOMATIC"] = L["Automatic"], not sure if i will use this yet
["LEFT"] = L["Left"],
["MIDDLE"] = L["Middle"],
["RIGHT"] = L["Right"]
}
local threatValues = {
["GLOW"] = L["Glow"],
["BORDERS"] = L["Borders"],
["HEALTHBORDER"] = L["Health Border"],
["INFOPANELBORDER"] = L["InfoPanel Border"],
["ICONTOPLEFT"] = L["Icon: TOPLEFT"],
["ICONTOPRIGHT"] = L["Icon: TOPRIGHT"],
["ICONBOTTOMLEFT"] = L["Icon: BOTTOMLEFT"],
["ICONBOTTOMRIGHT"] = L["Icon: BOTTOMRIGHT"],
["ICONLEFT"] = L["Icon: LEFT"],
["ICONRIGHT"] = L["Icon: RIGHT"],
["ICONTOP"] = L["Icon: TOP"],
["ICONBOTTOM"] = L["Icon: BOTTOM"],
["NONE"] = L["NONE"]
}
local petAnchors = {
TOPLEFT = "TOPLEFT",
LEFT = "LEFT",
BOTTOMLEFT = "BOTTOMLEFT",
RIGHT = "RIGHT",
TOPRIGHT = "TOPRIGHT",
BOTTOMRIGHT = "BOTTOMRIGHT",
TOP = "TOP",
BOTTOM = "BOTTOM"
}
local attachToValues = {
["Health"] = L["HEALTH"],
["Power"] = L["Power"],
["InfoPanel"] = L["Information Panel"],
["Frame"] = L["Frame"]
}
local growthDirectionValues = {
DOWN_RIGHT = format(L["%s and then %s"], L["Down"], L["Right"]),
DOWN_LEFT = format(L["%s and then %s"], L["Down"], L["Left"]),
UP_RIGHT = format(L["%s and then %s"], L["Up"], L["Right"]),
UP_LEFT = format(L["%s and then %s"], L["Up"], L["Left"]),
RIGHT_DOWN = format(L["%s and then %s"], L["Right"], L["Down"]),
RIGHT_UP = format(L["%s and then %s"], L["Right"], L["Up"]),
LEFT_DOWN = format(L["%s and then %s"], L["Left"], L["Down"]),
LEFT_UP = format(L["%s and then %s"], L["Left"], L["Up"])
}
local smartAuraPositionValues = {
["DISABLED"] = L["DISABLE"],
["BUFFS_ON_DEBUFFS"] = L["Position Buffs on Debuffs"],
["DEBUFFS_ON_BUFFS"] = L["Position Debuffs on Buffs"],
["FLUID_BUFFS_ON_DEBUFFS"] = L["Fluid Position Buffs on Debuffs"],
["FLUID_DEBUFFS_ON_BUFFS"] = L["Fluid Position Debuffs on Buffs"]
}
local colorOverrideValues = {
["USE_DEFAULT"] = L["Use Default"],
["FORCE_ON"] = L["Force On"],
["FORCE_OFF"] = L["Force Off"]
}
local blendModeValues = {
["DISABLE"] = L["DISABLE"],
["BLEND"] = L["Blend"],
["ADD"] = L["Additive Blend"],
["MOD"] = L["Modulating Blend"],
["ALPHAKEY"] = L["Alpha Key"],
}
local CUSTOMTEXT_CONFIGS = {}
local carryFilterFrom, carryFilterTo
local function filterMatch(s,v)
local m1, m2, m3, m4 = "^"..v.."$", "^"..v..",", ","..v.."$", ","..v..","
return (strmatch(s, m1) and m1) or (strmatch(s, m2) and m2) or (strmatch(s, m3) and m3) or (strmatch(s, m4) and v..",")
end
local function filterPriority(auraType, groupName, value, remove, movehere, friendState)
if not auraType or not value then return end
local filter = E.db.unitframe.units[groupName] and E.db.unitframe.units[groupName][auraType] and E.db.unitframe.units[groupName][auraType].priority
if not filter then return end
local found = filterMatch(filter, E:EscapeString(value))
if found and movehere then
local tbl, sv, sm = {strsplit(",",filter)}
for i in ipairs(tbl) do
if tbl[i] == value then sv = i elseif tbl[i] == movehere then sm = i end
if sv and sm then break end
end
tremove(tbl, sm)
tinsert(tbl, sv, movehere)
E.db.unitframe.units[groupName][auraType].priority = tconcat(tbl,",")
elseif found and friendState then
local realValue = strmatch(value, "^Friendly:([^,]*)") or strmatch(value, "^Enemy:([^,]*)") or value
local friend = filterMatch(filter, E:EscapeString("Friendly:"..realValue))
local enemy = filterMatch(filter, E:EscapeString("Enemy:"..realValue))
local default = filterMatch(filter, E:EscapeString(realValue))
local state =
(friend and (not enemy) and format("%s%s","Enemy:",realValue)) --[x] friend [ ] enemy: > enemy
or ((not enemy and not friend) and format("%s%s","Friendly:",realValue)) --[ ] friend [ ] enemy: > friendly
or (enemy and (not friend) and default and format("%s%s","Friendly:",realValue)) --[ ] friend [x] enemy: (default exists) > friendly
or (enemy and (not friend) and strmatch(value, "^Enemy:") and realValue) --[ ] friend [x] enemy: (no default) > realvalue
or (friend and enemy and realValue) --[x] friend [x] enemy: > default
if state then
local stateFound = filterMatch(filter, E:EscapeString(state))
if not stateFound then
local tbl, sv = {strsplit(",",filter)}
for i in ipairs(tbl) do
if tbl[i] == value then
sv = i
break
end
end
tinsert(tbl, sv, state)
tremove(tbl, sv + 1)
E.db.unitframe.units[groupName][auraType].priority = tconcat(tbl,",")
end
end
elseif found and remove then
E.db.unitframe.units[groupName][auraType].priority = gsub(filter, found, "")
elseif not found and not remove then
E.db.unitframe.units[groupName][auraType].priority = (filter == "" and value) or (filter..","..value)
end
end
-----------------------------------------------------------------------
-- OPTIONS TABLES
-----------------------------------------------------------------------
local function GetOptionsTable_AuraBars(updateFunc, groupName)
local config = {
order = 800,
type = "group",
name = L["Aura Bars"],
get = function(info) return E.db.unitframe.units[groupName].aurabar[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].aurabar[info[#info]] = value updateFunc(UF, groupName) end,
args = {
header = {
order = 1,
type = "header",
name = L["Aura Bars"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
configureButton1 = {
order = 3,
type = "execute",
name = L["Coloring"],
desc = L["This opens the UnitFrames Color settings. These settings affect all unitframes."],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "generalOptionsGroup", "allColorsGroup", "auraBars") end,
},
configureButton2 = {
order = 4,
type = "execute",
name = L["Coloring (Specific)"],
func = function() E:SetToFilterConfig("AuraBar Colors") end
},
anchorPoint = {
order = 5,
type = "select",
name = L["Anchor Point"],
desc = L["What point to anchor to the frame you set to attach to."],
values = {
["ABOVE"] = L["Above"],
["BELOW"] = L["Below"]
}
},
attachTo = {
order = 6,
type = "select",
name = L["Attach To"],
desc = L["The object you want to attach to."],
values = {
["FRAME"] = L["Frame"],
["DEBUFFS"] = L["Debuffs"],
["BUFFS"] = L["Buffs"]
}
},
height = {
order = 7,
type = "range",
name = L["Height"],
min = 6, max = 40, step = 1
},
maxBars = {
order = 8,
type = "range",
name = L["Max Bars"],
min = 1, max = 40, step = 1
},
sort = {
order = 9,
type = "select",
name = L["Sort Method"],
values = {
["TIME_REMAINING"] = L["Time Remaining"],
["TIME_REMAINING_REVERSE"] = L["Time Remaining Reverse"],
["TIME_DURATION"] = L["Duration"],
["TIME_DURATION_REVERSE"] = L["Duration Reverse"],
["NAME"] = L["NAME"],
["NONE"] = L["NONE"]
}
},
friendlyAuraType = {
order = 16,
type = "select",
name = L["Friendly Aura Type"],
desc = L["Set the type of auras to show when a unit is friendly."],
values = {
["HARMFUL"] = L["Debuffs"],
["HELPFUL"] = L["Buffs"]
}
},
enemyAuraType = {
order = 17,
type = "select",
name = L["Enemy Aura Type"],
desc = L["Set the type of auras to show when a unit is a foe."],
values = {
["HARMFUL"] = L["Debuffs"],
["HELPFUL"] = L["Buffs"]
}
},
uniformThreshold = {
order = 18,
type = "range",
name = L["Uniform Threshold"],
desc = L["Seconds remaining on the aura duration before the bar starts moving. Set to 0 to disable."],
min = 0, max = 3600, step = 1
},
yOffset = {
order = 19,
type = "range",
name = L["Y-Offset"],
min = -1000, max = 1000, step = 1,
},
spacing = {
order = 20,
type = "range",
name = L["Spacing"],
min = 0, softMax = 20, step = 1,
},
filters = {
order = 500,
type = "group",
name = L["FILTERS"],
guiInline = true,
args = {}
}
}
}
if groupName == "target" then
config.args.attachTo.values.PLAYER_AURABARS = L["Player Frame Aura Bars"]
end
config.args.filters.args.minDuration = {
order = 16,
type = "range",
name = L["Minimum Duration"],
desc = L["Don't display auras that are shorter than this duration (in seconds). Set to zero to disable."],
min = 0, max = 10800, step = 1,
}
config.args.filters.args.maxDuration = {
order = 17,
type = "range",
name = L["Maximum Duration"],
desc = L["Don't display auras that are longer than this duration (in seconds). Set to zero to disable."],
min = 0, max = 10800, step = 1,
}
config.args.filters.args.jumpToFilter = {
order = 18,
type = "execute",
name = L["Filters Page"],
desc = L["Shortcut to 'Filters' section of the config."],
func = function() ACD:SelectGroup("ElvUI", "filters") end
}
config.args.filters.args.specialPriority = {
order = 19,
type = "select",
sortByValue = true,
name = L["Add Special Filter"],
desc = L["These filters don't use a list of spells like the regular filters. Instead they use the WoW API and some code logic to determine if an aura should be allowed or blocked."],
values = function()
local filters = {}
local list = E.global.unitframe.specialFilters
if not list then return end
for filter in pairs(list) do
filters[filter] = L[filter]
end
return filters
end,
set = function(info, value)
filterPriority("aurabar", groupName, value)
updateFunc(UF, groupName)
end
}
config.args.filters.args.priority = {
order = 20,
type = "select",
name = L["Add Regular Filter"],
desc = L["These filters use a list of spells to determine if an aura should be allowed or blocked. The content of these filters can be modified in the 'Filters' section of the config."],
values = function()
local filters = {}
local list = E.global.unitframe.aurafilters
if not list then return end
for filter in pairs(list) do
filters[filter] = filter
end
return filters
end,
set = function(info, value)
filterPriority("aurabar", groupName, value)
updateFunc(UF, groupName)
end
}
config.args.filters.args.resetPriority = {
order = 21,
type = "execute",
name = L["Reset Priority"],
desc = L["Reset filter priority to the default state."],
func = function()
E.db.unitframe.units[groupName].aurabar.priority = P.unitframe.units[groupName].aurabar.priority
updateFunc(UF, groupName)
end
}
config.args.filters.args.filterPriority = {
order = 22,
type = "multiselect",
dragdrop = true,
name = L["Filter Priority"],
dragOnLeave = E.noop, --keep this here
dragOnEnter = function(info)
carryFilterTo = info.obj.value
end,
dragOnMouseDown = function(info)
carryFilterFrom, carryFilterTo = info.obj.value, nil
end,
dragOnMouseUp = function(info)
filterPriority("aurabar", groupName, carryFilterTo, nil, carryFilterFrom) --add it in the new spot
carryFilterFrom, carryFilterTo = nil, nil
end,
dragOnClick = function(info)
filterPriority("aurabar", groupName, carryFilterFrom, true)
end,
stateSwitchGetText = function(_, TEXT)
local friend, enemy = strmatch(TEXT, "^Friendly:([^,]*)"), strmatch(TEXT, "^Enemy:([^,]*)")
local text = friend or enemy or TEXT
local SF, localized = E.global.unitframe.specialFilters[text], L[text]
local blockText = SF and localized and text:match("^block") and localized:gsub("^%[.-]%s?", "")
local filterText = (blockText and format("|cFF999999%s|r %s", L["BLOCK"], blockText)) or localized or text
return (friend and format("|cFF33FF33%s|r %s", L["FRIEND"], filterText)) or (enemy and format("|cFFFF3333%s|r %s", L["ENEMY"], filterText)) or filterText
end,
stateSwitchOnClick = function(info)
filterPriority("aurabar", groupName, carryFilterFrom, nil, nil, true)
end,
values = function()
local str = E.db.unitframe.units[groupName].aurabar.priority
if str == "" then return nil end
return {strsplit(",",str)}
end,
get = function(info, value)
local str = E.db.unitframe.units[groupName].aurabar.priority
if str == "" then return nil end
local tbl = {strsplit(",",str)}
return tbl[value]
end,
set = function(info)
E.db.unitframe.units[groupName].aurabar[info[#info]] = nil -- this was being set when drag and drop was first added, setting it to nil to clear tester profiles of this variable
updateFunc(UF, groupName)
end
}
config.args.filters.args.spacer1 = {
order = 23,
type = "description",
name = L["Use drag and drop to rearrange filter priority or right click to remove a filter."].."\n"..L["Use Shift+LeftClick to toggle between friendly or enemy or normal state. Normal state will allow the filter to be checked on all units. Friendly state is for friendly units only and enemy state is for enemy units."],
}
return config
end
local function GetOptionsTable_Auras(auraType, updateFunc, groupName, numUnits)
local config = {
order = auraType == "buffs" and 500 or 600,
type = "group",
name = auraType == "buffs" and L["Buffs"] or L["Debuffs"],
get = function(info) return E.db.unitframe.units[groupName][auraType][info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName][auraType][info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
header = {
order = 1,
type = "header",
name = auraType == "buffs" and L["Buffs"] or L["Debuffs"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
perrow = {
order = 3,
type = "range",
name = L["Per Row"],
min = 1, max = 20, step = 1,
},
numrows = {
order = 4,
type = "range",
name = L["Num Rows"],
min = 1, max = 10, step = 1
},
sizeOverride = {
order = 5,
type = "range",
name = L["Size Override"],
desc = L["If not set to 0 then override the size of the aura icon to this."],
min = 0, max = 60, step = 1
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
min = -300, max = 300, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
min = -300, max = 300, step = 1
},
anchorPoint = {
order = 8,
type = "select",
name = L["Anchor Point"],
desc = L["What point to anchor to the frame you set to attach to."],
values = positionValues
},
clickThrough = {
order = 9,
type = "toggle",
name = L["Click Through"],
desc = L["Ignore mouse events."]
},
sortMethod = {
order = 10,
type = "select",
name = L["Sort By"],
desc = L["Method to sort by."],
values = {
["TIME_REMAINING"] = L["Time Remaining"],
["DURATION"] = L["Duration"],
["NAME"] = L["NAME"],
["INDEX"] = L["Index"],
["PLAYER"] = L["PLAYER"]
}
},
sortDirection = {
order = 11,
type = "select",
name = L["Sort Direction"],
desc = L["Ascending or Descending order."],
values = {
["ASCENDING"] = L["Ascending"],
["DESCENDING"] = L["Descending"]
}
},
noDurationLast = {
order = 12,
type = "toggle",
name = L["No Duration Last"],
desc = L["Show buffs with no duration last."],
},
stacks = {
order = 13,
type = "group",
name = L["Stack Counter"],
guiInline = true,
get = function(info, value) return E.db.unitframe.units[groupName][auraType][info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName][auraType][info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
countFont = {
order = 1,
type = "select", dialogControl = "LSM30_Font",
name = L["Font"],
values = _G.AceGUIWidgetLSMlists.font
},
countFontSize = {
order = 2,
type = "range",
name = L["FONT_SIZE"],
min = 4, max = 20, step = 1, -- max 20 cause otherwise it looks weird
},
countFontOutline = {
order = 3,
type = "select",
name = L["Font Outline"],
desc = L["Set the font outline."],
values = C.Values.FontFlags
}
}
},
duration = {
order = 14,
type = "group",
name = L["Duration"],
guiInline = true,
get = function(info) return E.db.unitframe.units[groupName][auraType][info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName][auraType][info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
cooldownShortcut = {
order = 1,
type = "execute",
name = L["Cooldowns"],
func = function() ACD:SelectGroup("ElvUI", "cooldown", "unitframe") end,
},
durationPosition = {
order = 2,
type = "select",
name = L["Position"],
values = {
["TOP"] = "TOP",
["LEFT"] = "LEFT",
["BOTTOM"] = "BOTTOM",
["CENTER"] = "CENTER",
["TOPLEFT"] = "TOPLEFT",
["BOTTOMLEFT"] = "BOTTOMLEFT",
["TOPRIGHT"] = "TOPRIGHT"
}
}
}
},
filters = {
order = 100,
type = "group",
name = L["FILTERS"],
guiInline = true,
args = {}
}
}
}
if auraType == "buffs" then
config.args.attachTo = {
order = 7,
type = "select",
name = L["Attach To"],
desc = L["What to attach the buff anchor frame to."],
values = {
["FRAME"] = L["Frame"],
["DEBUFFS"] = L["Debuffs"],
["HEALTH"] = L["HEALTH"],
["POWER"] = L["Power"]
},
disabled = function()
local smartAuraPosition = E.db.unitframe.units[groupName].smartAuraPosition
return (smartAuraPosition and (smartAuraPosition == "BUFFS_ON_DEBUFFS" or smartAuraPosition == "FLUID_BUFFS_ON_DEBUFFS"))
end
}
else
config.args.attachTo = {
order = 7,
type = "select",
name = L["Attach To"],
desc = L["What to attach the debuff anchor frame to."],
values = {
["FRAME"] = L["Frame"],
["BUFFS"] = L["Buffs"],
["HEALTH"] = L["HEALTH"],
["POWER"] = L["Power"]
},
disabled = function()
local smartAuraPosition = E.db.unitframe.units[groupName].smartAuraPosition
return (smartAuraPosition and (smartAuraPosition == "DEBUFFS_ON_BUFFS" or smartAuraPosition == "FLUID_DEBUFFS_ON_BUFFS"))
end
}
end
config.args.filters.args.minDuration = {
order = 16,
type = "range",
name = L["Minimum Duration"],
desc = L["Don't display auras that are shorter than this duration (in seconds). Set to zero to disable."],
min = 0, max = 10800, step = 1
}
config.args.filters.args.maxDuration = {
order = 17,
type = "range",
name = L["Maximum Duration"],
desc = L["Don't display auras that are longer than this duration (in seconds). Set to zero to disable."],
min = 0, max = 10800, step = 1
}
config.args.filters.args.jumpToFilter = {
order = 18,
type = "execute",
name = L["Filters Page"],
desc = L["Shortcut to 'Filters' section of the config."],
func = function() ACD:SelectGroup("ElvUI", "filters") end
}
config.args.filters.args.specialPriority = {
order = 19,
type = "select",
sortByValue = true,
name = L["Add Special Filter"],
desc = L["These filters don't use a list of spells like the regular filters. Instead they use the WoW API and some code logic to determine if an aura should be allowed or blocked."],
values = function()
local filters = {}
local list = E.global.unitframe.specialFilters
if not list then return end
for filter in pairs(list) do
filters[filter] = L[filter]
end
return filters
end,
set = function(info, value)
filterPriority(auraType, groupName, value)
updateFunc(UF, groupName, numUnits)
end
}
config.args.filters.args.priority = {
order = 20,
type = "select",
name = L["Add Regular Filter"],
desc = L["These filters use a list of spells to determine if an aura should be allowed or blocked. The content of these filters can be modified in the 'Filters' section of the config."],
values = function()
local filters = {}
local list = E.global.unitframe.aurafilters
if not list then return end
for filter in pairs(list) do
filters[filter] = filter
end
return filters
end,
set = function(info, value)
filterPriority(auraType, groupName, value)
updateFunc(UF, groupName, numUnits)
end
}
config.args.filters.args.resetPriority = {
order = 21,
type = "execute",
name = L["Reset Priority"],
desc = L["Reset filter priority to the default state."],
func = function()
E.db.unitframe.units[groupName][auraType].priority = P.unitframe.units[groupName][auraType].priority
updateFunc(UF, groupName, numUnits)
end
}
config.args.filters.args.filterPriority = {
order = 22,
type = "multiselect",
dragdrop = true,
name = L["Filter Priority"],
dragOnLeave = E.noop, --keep this here
dragOnEnter = function(info)
carryFilterTo = info.obj.value
end,
dragOnMouseDown = function(info)
carryFilterFrom, carryFilterTo = info.obj.value, nil
end,
dragOnMouseUp = function(info)
filterPriority(auraType, groupName, carryFilterTo, nil, carryFilterFrom) --add it in the new spot
carryFilterFrom, carryFilterTo = nil, nil
end,
dragOnClick = function(info)
filterPriority(auraType, groupName, carryFilterFrom, true)
end,
stateSwitchGetText = function(_, TEXT)
local friend, enemy = strmatch(TEXT, "^Friendly:([^,]*)"), strmatch(TEXT, "^Enemy:([^,]*)")
local text = friend or enemy or TEXT
local SF, localized = E.global.unitframe.specialFilters[text], L[text]
local blockText = SF and localized and text:match("^block") and localized:gsub("^%[.-]%s?", "")
local filterText = (blockText and format("|cFF999999%s|r %s", L["BLOCK"], blockText)) or localized or text
return (friend and format("|cFF33FF33%s|r %s", L["FRIEND"], filterText)) or (enemy and format("|cFFFF3333%s|r %s", L["ENEMY"], filterText)) or filterText
end,
stateSwitchOnClick = function(info)
filterPriority(auraType, groupName, carryFilterFrom, nil, nil, true)
end,
values = function()
local str = E.db.unitframe.units[groupName][auraType].priority
if str == "" then return nil end
return {strsplit(",",str)}
end,
get = function(info, value)
local str = E.db.unitframe.units[groupName][auraType].priority
if str == "" then return nil end
local tbl = {strsplit(",",str)}
return tbl[value]
end,
set = function(info)
E.db.unitframe.units[groupName][auraType][info[#info]] = nil -- this was being set when drag and drop was first added, setting it to nil to clear tester profiles of this variable
updateFunc(UF, groupName, numUnits)
end
}
config.args.filters.args.spacer1 = {
order = 23,
type = "description",
name = L["Use drag and drop to rearrange filter priority or right click to remove a filter."].."\n"..L["Use Shift+LeftClick to toggle between friendly or enemy or normal state. Normal state will allow the filter to be checked on all units. Friendly state is for friendly units only and enemy state is for enemy units."],
}
return config
end
local function GetOptionsTable_InformationPanel(updateFunc, groupName, numUnits)
local config = {
order = 4000,
type = "group",
name = L["Information Panel"],
get = function(info) return E.db.unitframe.units[groupName].infoPanel[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].infoPanel[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
header = {
order = 1,
type = "header",
name = L["Information Panel"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
transparent = {
order = 3,
type = "toggle",
name = L["Transparent"]
},
height = {
order = 4,
type = "range",
name = L["Height"],
min = 4, max = 30, step = 1
}
}
}
return config
end
local function GetOptionsTable_Health(isGroupFrame, updateFunc, groupName, numUnits)
local config = {
order = 100,
type = "group",
name = L["HEALTH"],
get = function(info) return E.db.unitframe.units[groupName].health[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].health[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
header = {
order = 1,
type = "header",
name = L["HEALTH"]
},
position = {
order = 2,
type = "select",
name = L["Text Position"],
values = positionValues
},
xOffset = {
order = 3,
type = "range",
name = L["Text xOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
yOffset = {
order = 4,
type = "range",
name = L["Text yOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
attachTextTo = {
order = 5,
type = "select",
name = L["Attach Text To"],
values = attachToValues
},
colorOverride = {
order = 6,
type = "select",
name = L["Class Color Override"],
desc = L["Override the default class color setting."],
values = colorOverrideValues,
get = function(info) return E.db.unitframe.units[groupName][info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName][info[#info]] = value; updateFunc(UF, groupName, numUnits) end,
},
configureButton = {
order = 7,
type = "execute",
name = L["Coloring"],
desc = L["This opens the UnitFrames Color settings. These settings affect all unitframes."],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "generalOptionsGroup", "allColorsGroup", "healthGroup") end
},
text_format = {
order = 10,
type = "input",
name = L["Text Format"],
desc = L["TEXT_FORMAT_DESC"],
width = "full"
}
}
}
if isGroupFrame then
config.args.frequentUpdates = {
order = 8,
type = "toggle",
name = L["Frequent Updates"],
desc = L["Rapidly update the health, uses more memory and cpu. Only recommended for healing."]
}
config.args.orientation = {
order = 9,
type = "select",
name = L["Statusbar Fill Orientation"],
desc = L["Direction the health bar moves when gaining/losing health."],
values = {
["HORIZONTAL"] = L["Horizontal"],
["VERTICAL"] = L["Vertical"]
}
}
end
return config
end
local function GetOptionsTable_Power(hasDetatchOption, updateFunc, groupName, numUnits, hasStrataLevel)
local config = {
order = 200,
type = "group",
name = L["Power"],
get = function(info) return E.db.unitframe.units[groupName].power[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].power[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
header = {
order = 1,
type = "header",
name = L["Power"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
width = {
order = 3,
type = "select",
name = L["Style"],
values = {
["fill"] = L["Filled"],
["spaced"] = L["Spaced"],
["inset"] = L["Inset"]
},
set = function(info, value)
E.db.unitframe.units[groupName].power[info[#info]] = value
local frameName = E:StringTitle(groupName)
frameName = "ElvUF_"..frameName
frameName = frameName:gsub("t(arget)", "T%1")
if numUnits then
for i = 1, numUnits do
if _G[frameName..i] then
local min, max = _G[frameName..i].Power:GetMinMaxValues()
_G[frameName..i].Power:SetMinMaxValues(min, max + 500)
_G[frameName..i].Power:SetValue(1)
_G[frameName..i].Power:SetValue(0)
end
end
else
if _G[frameName] and _G[frameName].Power then
local min, max = _G[frameName].Power:GetMinMaxValues()
_G[frameName].Power:SetMinMaxValues(min, max + 500)
_G[frameName].Power:SetValue(1)
_G[frameName].Power:SetValue(0)
else
for i = 1, _G[frameName]:GetNumChildren() do
local child = select(i, _G[frameName]:GetChildren())
if child and child.Power then
local min, max = child.Power:GetMinMaxValues()
child.Power:SetMinMaxValues(min, max + 500)
child.Power:SetValue(1)
child.Power:SetValue(0)
end
end
end
end
updateFunc(UF, groupName, numUnits)
end
},
height = {
order = 4,
type = "range",
name = L["Height"],
min = ((E.db.unitframe.thinBorders or E.PixelMode) and 3 or 7), max = 50, step = 1
},
offset = {
order = 5,
type = "range",
name = L["Offset"],
desc = L["Offset of the powerbar to the healthbar, set to 0 to disable."],
min = 0, max = 20, step = 1
},
configureButton = {
order = 6,
type = "execute",
name = L["Coloring"],
desc = L["This opens the UnitFrames Color settings. These settings affect all unitframes."],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "general", "allColorsGroup", "powerGroup") end,
},
position = {
order = 7,
type = "select",
name = L["Text Position"],
values = positionValues
},
xOffset = {
order = 8,
type = "range",
name = L["Text xOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
yOffset = {
order = 9,
type = "range",
name = L["Text yOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
attachTextTo = {
order = 10,
type = "select",
name = L["Attach Text To"],
values = attachToValues
},
text_format = {
order = 100,
type = "input",
name = L["Text Format"],
width = "full",
desc = L["TEXT_FORMAT_DESC"]
}
}
}
if hasDetatchOption then
config.args.detachFromFrame = {
order = 11,
type = "toggle",
name = L["Detach From Frame"]
}
config.args.detachedWidth = {
order = 12,
type = "range",
name = L["Detached Width"],
disabled = function() return not E.db.unitframe.units[groupName].power.detachFromFrame end,
min = 15, max = 1000, step = 1
}
config.args.parent = {
order = 13,
type = "select",
name = L["Parent"],
desc = L["Choose UIPARENT to prevent it from hiding with the unitframe."],
disabled = function() return not E.db.unitframe.units[groupName].power.detachFromFrame end,
values = {
["FRAME"] = "FRAME",
["UIPARENT"] = "UIPARENT"
}
}
end
if hasStrataLevel then
config.args.strataAndLevel = {
order = 101,
type = "group",
name = L["Strata and Level"],
get = function(info) return E.db.unitframe.units[groupName].power.strataAndLevel[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].power.strataAndLevel[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
guiInline = true,
args = {
useCustomStrata = {
order = 1,
type = "toggle",
name = L["Use Custom Strata"]
},
frameStrata = {
order = 2,
type = "select",
name = L["Frame Strata"],
values = {
["BACKGROUND"] = "BACKGROUND",
["LOW"] = "LOW",
["MEDIUM"] = "MEDIUM",
["HIGH"] = "HIGH",
["DIALOG"] = "DIALOG",
["TOOLTIP"] = "TOOLTIP"
}
},
spacer = {
order = 3,
type = "description",
name = ""
},
useCustomLevel = {
order = 4,
type = "toggle",
name = L["Use Custom Level"]
},
frameLevel = {
order = 5,
type = "range",
name = L["Frame Level"],
min = 2, max = 128, step = 1
}
}
}
end
return config
end
local function GetOptionsTable_Energy(hasDetatchOption, updateFunc, groupName, numUnits, hasStrataLevel)
local config = {
order = 250,
type = "group",
name = L["Energy"],
get = function(info)
return E.db.unitframe.units[groupName].energy[info[#info]]
end,
set = function(info, value)
E.db.unitframe.units[groupName].energy[info[#info]] = value
updateFunc(UF, groupName, numUnits)
end,
args = {
header = {
order = 1,
type = "header",
name = L["Energy"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
width = {
order = 3,
type = "select",
name = L["Style"],
values = {
["fill"] = L["Filled"],
["spaced"] = L["Spaced"],
["inset"] = L["Inset"]
},
set = function(info, value)
E.db.unitframe.units[groupName].energy[info[#info]] = value
local frameName = E:StringTitle(groupName)
frameName = "ElvUF_"..frameName
frameName = frameName:gsub("t(arget)", "T%1")
if numUnits then
for i = 1, numUnits do
if _G[frameName..i] then
local min, max = _G[frameName..i].Power:GetMinMaxValues()
_G[frameName..i].Power:SetMinMaxValues(min, max + 500)
_G[frameName..i].Power:SetValue(1)
_G[frameName..i].Power:SetValue(0)
end
end
else
if _G[frameName] and _G[frameName].Power then
local min, max = _G[frameName].Power:GetMinMaxValues()
_G[frameName].Power:SetMinMaxValues(min, max + 500)
_G[frameName].Power:SetValue(1)
_G[frameName].Power:SetValue(0)
else
for i = 1, _G[frameName]:GetNumChildren() do
local child = select(i, _G[frameName]:GetChildren())
if child and child.Power then
local min, max = child.Power:GetMinMaxValues()
child.Power:SetMinMaxValues(min, max + 500)
child.Power:SetValue(1)
child.Power:SetValue(0)
end
end
end
end
updateFunc(UF, groupName, numUnits)
end
},
height = {
order = 4,
type = "range",
name = L["Height"],
min = ((E.db.unitframe.thinBorders or E.PixelMode) and 3 or 7), max = 50, step = 1
},
offset = {
order = 5,
type = "range",
name = L["Offset"],
desc = L["Offset of the powerbar to the healthbar, set to 0 to disable."],
min = 0, max = 20, step = 1
},
configureButton = {
order = 6,
type = "execute",
name = L["Coloring"],
desc = L["This opens the UnitFrames Color settings. These settings affect all unitframes."],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "general", "allColorsGroup", "powerGroup") end
},
position = {
order = 7,
type = "select",
name = L["Text Position"],
values = positionValues
},
xOffset = {
order = 8,
type = "range",
name = L["Text xOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
yOffset = {
order = 9,
type = "range",
name = L["Text yOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
attachTextTo = {
order = 10,
type = "select",
name = L["Attach Text To"],
values = {
["Health"] = HEALTH,
["Power"] = L["Power"],
["Energy"] = L["Energy"],
["InfoPanel"] = L["Information Panel"],
["Frame"] = L["Frame"]
}
},
text_format = {
order = 100,
type = "input",
name = L["Text Format"],
desc = L["TEXT_FORMAT_DESC"],
width = "full"
}
}
}
if hasDetatchOption then
config.args.detachFromFrame = {
type = "toggle",
order = 11,
name = L["Detach From Frame"]
}
config.args.detachedWidth = {
type = "range",
order = 12,
name = L["Detached Width"],
disabled = function() return not E.db.unitframe.units[groupName].energy.detachFromFrame end,
min = 15, max = 1000, step = 1
}
config.args.parent = {
type = "select",
order = 11,
name = L["Parent"],
desc = L["Choose UIPARENT to prevent it from hiding with the unitframe."],
disabled = function() return not E.db.unitframe.units[groupName].energy.detachFromFrame end,
values = {
["FRAME"] = "FRAME",
["UIPARENT"] = "UIPARENT"
}
}
end
if hasStrataLevel then
config.args.strataAndLevel = {
order = 101,
type = "group",
name = L["Strata and Level"],
get = function(info) return E.db.unitframe.units[groupName]["power"]["strataAndLevel"][ info[#info] ] end,
set = function(info, value) E.db.unitframe.units[groupName]["power"]["strataAndLevel"][ info[#info] ] = value updateFunc(UF, groupName, numUnits) end,
guiInline = true,
args = {
useCustomStrata = {
order = 1,
type = "toggle",
name = L["Use Custom Strata"]
},
frameStrata = {
order = 2,
type = "select",
name = L["Frame Strata"],
values = {
["BACKGROUND"] = "BACKGROUND",
["LOW"] = "LOW",
["MEDIUM"] = "MEDIUM",
["HIGH"] = "HIGH",
["DIALOG"] = "DIALOG",
["TOOLTIP"] = "TOOLTIP"
}
},
spacer = {
order = 3,
type = "description",
name = ""
},
useCustomLevel = {
order = 4,
type = "toggle",
name = L["Use Custom Level"]
},
frameLevel = {
order = 5,
type = "range",
name = L["Frame Level"],
min = 2, max = 128, step = 1
}
}
}
end
return config
end
local function GetOptionsTable_Rage(hasDetatchOption, updateFunc, groupName, numUnits, hasStrataLevel)
local config = {
order = 250,
type = "group",
name = L["Rage"],
get = function(info)
return E.db.unitframe.units[groupName].rage[info[#info]]
end,
set = function(info, value)
E.db.unitframe.units[groupName].rage[info[#info]] = value
updateFunc(UF, groupName, numUnits)
end,
args = {
header = {
order = 1,
type = "header",
name = L["Rage"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
width = {
order = 3,
type = "select",
name = L["Style"],
values = {
["fill"] = L["Filled"],
["spaced"] = L["Spaced"],
["inset"] = L["Inset"]
},
set = function(info, value)
E.db.unitframe.units[groupName].rage[info[#info]] = value
local frameName = E:StringTitle(groupName)
frameName = "ElvUF_"..frameName
frameName = frameName:gsub("t(arget)", "T%1")
if numUnits then
for i = 1, numUnits do
if _G[frameName..i] then
local min, max = _G[frameName..i].Power:GetMinMaxValues()
_G[frameName..i].Power:SetMinMaxValues(min, max + 500)
_G[frameName..i].Power:SetValue(1)
_G[frameName..i].Power:SetValue(0)
end
end
else
if _G[frameName] and _G[frameName].Power then
local min, max = _G[frameName].Power:GetMinMaxValues()
_G[frameName].Power:SetMinMaxValues(min, max + 500)
_G[frameName].Power:SetValue(1)
_G[frameName].Power:SetValue(0)
else
for i = 1, _G[frameName]:GetNumChildren() do
local child = select(i, _G[frameName]:GetChildren())
if child and child.Power then
local min, max = child.Power:GetMinMaxValues()
child.Power:SetMinMaxValues(min, max + 500)
child.Power:SetValue(1)
child.Power:SetValue(0)
end
end
end
end
updateFunc(UF, groupName, numUnits)
end
},
height = {
order = 4,
type = "range",
name = L["Height"],
min = ((E.db.unitframe.thinBorders or E.PixelMode) and 3 or 7), max = 50, step = 1
},
offset = {
order = 5,
type = "range",
name = L["Offset"],
desc = L["Offset of the powerbar to the healthbar, set to 0 to disable."],
min = 0, max = 20, step = 1
},
configureButton = {
order = 6,
type = "execute",
name = L["Coloring"],
desc = L["This opens the UnitFrames Color settings. These settings affect all unitframes."],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "general", "allColorsGroup", "powerGroup") end
},
position = {
order = 7,
type = "select",
name = L["Text Position"],
values = positionValues
},
xOffset = {
order = 8,
type = "range",
name = L["Text xOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
yOffset = {
order = 9,
type = "range",
name = L["Text yOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
attachTextTo = {
order = 10,
type = "select",
name = L["Attach Text To"],
values = {
["Health"] = HEALTH,
["Power"] = L["Power"],
["Rage"] = L["Rage"],
["InfoPanel"] = L["Information Panel"],
["Frame"] = L["Frame"]
}
},
text_format = {
order = 100,
type = "input",
name = L["Text Format"],
desc = L["TEXT_FORMAT_DESC"],
width = "full"
}
}
}
if hasDetatchOption then
config.args.detachFromFrame = {
type = "toggle",
order = 11,
name = L["Detach From Frame"]
}
config.args.detachedWidth = {
type = "range",
order = 12,
name = L["Detached Width"],
disabled = function() return not E.db.unitframe.units[groupName].rage.detachFromFrame end,
min = 15, max = 1000, step = 1
}
config.args.parent = {
type = "select",
order = 11,
name = L["Parent"],
desc = L["Choose UIPARENT to prevent it from hiding with the unitframe."],
disabled = function() return not E.db.unitframe.units[groupName].rage.detachFromFrame end,
values = {
["FRAME"] = "FRAME",
["UIPARENT"] = "UIPARENT"
}
}
end
if hasStrataLevel then
config.args.strataAndLevel = {
order = 101,
type = "group",
name = L["Strata and Level"],
get = function(info) return E.db.unitframe.units[groupName]["power"]["strataAndLevel"][ info[#info] ] end,
set = function(info, value) E.db.unitframe.units[groupName]["power"]["strataAndLevel"][ info[#info] ] = value updateFunc(UF, groupName, numUnits) end,
guiInline = true,
args = {
useCustomStrata = {
order = 1,
type = "toggle",
name = L["Use Custom Strata"]
},
frameStrata = {
order = 2,
type = "select",
name = L["Frame Strata"],
values = {
["BACKGROUND"] = "BACKGROUND",
["LOW"] = "LOW",
["MEDIUM"] = "MEDIUM",
["HIGH"] = "HIGH",
["DIALOG"] = "DIALOG",
["TOOLTIP"] = "TOOLTIP"
}
},
spacer = {
order = 3,
type = "description",
name = ""
},
useCustomLevel = {
order = 4,
type = "toggle",
name = L["Use Custom Level"]
},
frameLevel = {
order = 5,
type = "range",
name = L["Frame Level"],
min = 2, max = 128, step = 1
}
}
}
end
return config
end
local function GetOptionsTable_Name(updateFunc, groupName, numUnits)
local config = {
order = 300,
type = "group",
name = L["NAME"],
get = function(info) return E.db.unitframe.units[groupName].name[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].name[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
header = {
order = 1,
type = "header",
name = L["NAME"]
},
position = {
order = 2,
type = "select",
name = L["Text Position"],
values = positionValues
},
xOffset = {
order = 3,
type = "range",
name = L["Text xOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
yOffset = {
order = 4,
type = "range",
name = L["Text yOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
attachTextTo = {
order = 5,
type = "select",
name = L["Attach Text To"],
values = attachToValues
},
text_format = {
order = 100,
type = "input",
name = L["Text Format"],
desc = L["TEXT_FORMAT_DESC"],
width = "full"
}
}
}
return config
end
local function GetOptionsTable_Portrait(updateFunc, groupName, numUnits)
local config = {
order = 400,
type = "group",
name = L["Portrait"],
get = function(info) return E.db.unitframe.units[groupName].portrait[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].portrait[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
header = {
order = 1,
type = "header",
name = L["Portrait"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"],
desc = L["If you have a lot of 3D Portraits active then it will likely have a big impact on your FPS. Disable some portraits if you experience FPS issues."],
confirmText = L["If you have a lot of 3D Portraits active then it will likely have a big impact on your FPS. Disable some portraits if you experience FPS issues."],
confirm = true
},
overlay = {
order = 3,
type = "toggle",
name = L["Overlay"],
desc = L["The Portrait will overlay the Healthbar. This will be automatically happen if the Frame Orientation is set to Middle."],
disabled = function() return not E.db.unitframe.units[groupName].portrait.enable end
},
fullOverlay = {
order = 4,
type = "toggle",
name = L["Full Overlay"],
desc = L["This option allows the overlay to span the whole health, including the background."],
disabled = function() return not E.db.unitframe.units[groupName].portrait.enable or not E.db.unitframe.units[groupName].portrait.overlay end,
},
style = {
order = 5,
type = "select",
name = L["Style"],
desc = L["Select the display method of the portrait."],
values = {
["2D"] = L["2D"],
["3D"] = L["3D"]
},
disabled = function() return not E.db.unitframe.units[groupName].portrait.enable end
},
width = {
order = 6,
type = "range",
name = L["Width"],
min = 15, max = 150, step = 1,
disabled = function() return not E.db.unitframe.units[groupName].portrait.enable or E.db.unitframe.units[groupName].portrait.overlay end
},
overlayAlpha = {
order = 7,
type = "range",
name = L["Overlay Alpha"],
desc = L["Set the alpha level of portrait when frame is overlayed."],
min = 0.01, max = 1, step = 0.01,
disabled = function() return not E.db.unitframe.units[groupName].portrait.overlay end,
}
}
}
return config
end
local function GetOptionsTable_Fader(updateFunc, groupName, numUnits)
local config = {
order = 550,
type = "group",
name = L["Fader"],
get = function(info) return E.db.unitframe.units[groupName].fader[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].fader[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
header = {
order = 1,
type = "header",
name = L["Fader"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
range = {
order = 3,
type = "toggle",
name = L["Range"],
disabled = function() return not E.db.unitframe.units[groupName].fader.enable end,
hidden = function() return groupName == "player" end
},
hover = {
order = 4,
type = "toggle",
name = L["Hover"],
disabled = function() return not E.db.unitframe.units[groupName].fader.enable or E.db.unitframe.units[groupName].fader.range end
},
combat = {
order = 5,
type = "toggle",
name = L["COMBAT"],
disabled = function() return not E.db.unitframe.units[groupName].fader.enable or E.db.unitframe.units[groupName].fader.range end
},
unittarget = {
order = 6,
type = "toggle",
name = L["Unit Target"],
disabled = function() return not E.db.unitframe.units[groupName].fader.enable or E.db.unitframe.units[groupName].fader.range end,
hidden = function() return groupName == "player" end
},
playertarget = {
order = 7,
type = "toggle",
name = (groupName == "player" and L["TARGET"]) or L["Player Target"],
disabled = function() return not E.db.unitframe.units[groupName].fader.enable or E.db.unitframe.units[groupName].fader.range end
},
focus = {
order = 8,
type = "toggle",
name = L["Focus"],
disabled = function() return not E.db.unitframe.units[groupName].fader.enable or E.db.unitframe.units[groupName].fader.range end
},
health = {
order = 9,
type = "toggle",
name = L["HEALTH"],
disabled = function() return not E.db.unitframe.units[groupName].fader.enable or E.db.unitframe.units[groupName].fader.range end
},
power = {
order = 10,
type = "toggle",
name = L["Power"],
disabled = function() return not E.db.unitframe.units[groupName].fader.enable or E.db.unitframe.units[groupName].fader.range end
},
vehicle = {
order = 11,
type = "toggle",
name = L["Vehicle"],
disabled = function() return not E.db.unitframe.units[groupName].fader.enable or E.db.unitframe.units[groupName].fader.range end
},
casting = {
order = 12,
type = "toggle",
name = L["Casting"],
disabled = function() return not E.db.unitframe.units[groupName].fader.enable or E.db.unitframe.units[groupName].fader.range end
},
spacer = {
order = 13,
type = "description",
name = " ",
width = "full"
},
delay = {
order = 14,
type = "range",
name = L["Fade Out Delay"],
min = 0, max = 3, step = 0.01,
disabled = function() return not E.db.unitframe.units[groupName].fader.enable or E.db.unitframe.units[groupName].fader.range end
},
smooth = {
order = 15,
type = "range",
name = L["Smooth"],
min = 0, max = 1, step = 0.01,
disabled = function() return not E.db.unitframe.units[groupName].fader.enable end
},
minAlpha = {
order = 16,
type = "range",
name = L["Min Alpha"],
min = 0, max = 1, step = 0.01,
disabled = function() return not E.db.unitframe.units[groupName].fader.enable end
},
maxAlpha = {
order = 17,
type = "range",
name = L["Max Alpha"],
min = 0, max = 1, step = 0.01,
disabled = function() return not E.db.unitframe.units[groupName].fader.enable end
}
}
}
return config
end
local function GetOptionsTable_Castbar(hasTicks, updateFunc, groupName, numUnits)
local config = {
order = 700,
type = "group",
name = L["Castbar"],
get = function(info) return E.db.unitframe.units[groupName].castbar[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].castbar[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
header = {
order = 1,
type = "header",
name = L["Castbar"]
},
matchsize = {
order = 2,
type = "execute",
name = L["Match Frame Width"],
func = function() E.db.unitframe.units[groupName].castbar.width = E.db.unitframe.units[groupName].width updateFunc(UF, groupName, numUnits) end
},
forceshow = {
order = 3,
type = "execute",
name = L["SHOW"].." / "..L["HIDE"],
func = function()
local frameName = E:StringTitle(groupName)
frameName = "ElvUF_"..frameName
frameName = frameName:gsub("t(arget)", "T%1")
if groupName == "party" then
local header = UF.headers[groupName]
for i = 1, header:GetNumChildren() do
local group = select(i, header:GetChildren())
for j = 1, group:GetNumChildren() do
--Party unitbutton
local unitbutton = select(j, group:GetChildren())
local castbar = unitbutton.Castbar
if not castbar.oldHide then
castbar.oldHide = castbar.Hide
castbar.Hide = castbar.Show
castbar:Show()
else
castbar.Hide = castbar.oldHide
castbar.oldHide = nil
castbar:Hide()
end
end
end
elseif numUnits then
for i = 1, numUnits do
local castbar = _G[frameName..i].Castbar
if not castbar.oldHide then
castbar.oldHide = castbar.Hide
castbar.Hide = castbar.Show
castbar:Show()
else
castbar.Hide = castbar.oldHide
castbar.oldHide = nil
castbar:Hide()
end
end
else
local castbar = _G[frameName].Castbar
if not castbar.oldHide then
castbar.oldHide = castbar.Hide
castbar.Hide = castbar.Show
castbar:Show()
else
castbar.Hide = castbar.oldHide
castbar.oldHide = nil
castbar:Hide()
end
end
end
},
configureButton = {
order = 4,
type = "execute",
name = L["Coloring"],
desc = L["This opens the UnitFrames Color settings. These settings affect all unitframes."],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "generalOptionsGroup", "allColorsGroup", "castBars") end
},
enable = {
order = 5,
type = "toggle",
name = L["Enable"]
},
width = {
order = 6,
type = "range",
name = L["Width"],
softMax = 600,
min = 50, max = GetScreenWidth(), step = 1
},
height = {
order = 7,
type = "range",
name = L["Height"],
min = 10, max = 85, step = 1
},
timeToHold = {
order = 8,
type = "range",
name = L["Time To Hold"],
desc = L["How many seconds the castbar should stay visible after the cast failed or was interrupted."],
min = 0, max = 10, step = .1
},
latency = {
order = 9,
type = "toggle",
name = L["Latency"]
},
format = {
order = 10,
type = "select",
name = L["Format"],
values = {
["CURRENTMAX"] = L["Current / Max"],
["CURRENT"] = L["Current"],
["REMAINING"] = L["Remaining"],
["REMAININGMAX"] = L["Remaining / Max"]
}
},
spark = {
order = 11,
type = "toggle",
name = L["Spark"],
desc = L["Display a spark texture at the end of the castbar statusbar to help show the differance between castbar and backdrop."]
},
insideInfoPanel = {
order = 12,
type = "toggle",
name = L["Inside Information Panel"],
desc = L["Display the castbar inside the information panel, the icon will be displayed outside the main unitframe."],
disabled = function() return not E.db.unitframe.units[groupName].infoPanel or not E.db.unitframe.units[groupName].infoPanel.enable end
},
iconSettings = {
order = 13,
type = "group",
name = L["Icon"],
guiInline = true,
get = function(info) return E.db.unitframe.units[groupName].castbar[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].castbar[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
icon = {
order = 1,
type = "toggle",
name = L["Enable"]
},
iconAttached = {
order = 2,
type = "toggle",
name = L["Icon Inside Castbar"],
desc = L["Display the castbar icon inside the castbar."]
},
iconSize = {
order = 3,
type = "range",
name = L["Icon Size"],
desc = L["This dictates the size of the icon when it is not attached to the castbar."],
min = 8, max = 150, step = 1,
disabled = function() return E.db.unitframe.units[groupName].castbar.iconAttached end
},
iconAttachedTo = {
order = 4,
type = "select",
name = L["Attach To"],
disabled = function() return E.db.unitframe.units[groupName].castbar.iconAttached end,
values = {
["Frame"] = L["Frame"],
["Castbar"] = L["Castbar"]
}
},
iconPosition = {
order = 5,
type = "select",
name = L["Position"],
values = positionValues,
disabled = function() return E.db.unitframe.units[groupName].castbar.iconAttached end
},
iconXOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
min = -300, max = 300, step = 1,
disabled = function() return E.db.unitframe.units[groupName].castbar.iconAttached end
},
iconYOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
min = -300, max = 300, step = 1,
disabled = function() return E.db.unitframe.units[groupName].castbar.iconAttached end
}
}
},
strataAndLevel = {
order = 14,
type = "group",
name = L["Strata and Level"],
get = function(info) return E.db.unitframe.units[groupName].castbar.strataAndLevel[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].castbar.strataAndLevel[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
guiInline = true,
args = {
useCustomStrata = {
order = 1,
type = "toggle",
name = L["Use Custom Strata"]
},
frameStrata = {
order = 2,
type = "select",
name = L["Frame Strata"],
values = {
["BACKGROUND"] = "BACKGROUND",
["LOW"] = "LOW",
["MEDIUM"] = "MEDIUM",
["HIGH"] = "HIGH",
["DIALOG"] = "DIALOG",
["TOOLTIP"] = "TOOLTIP"
}
},
spacer = {
order = 3,
type = "description",
name = ""
},
useCustomLevel = {
order = 4,
type = "toggle",
name = L["Use Custom Level"]
},
frameLevel = {
order = 5,
type = "range",
name = L["Frame Level"],
min = 2, max = 128, step = 1
}
}
}
}
}
if hasTicks then
config.args.displayTarget = {
order = 11,
type = "toggle",
name = L["Display Target"],
desc = L["Display the target of your current cast. Useful for mouseover casts."]
}
config.args.ticks = {
order = 12,
type = "group",
name = L["Ticks"],
guiInline = true,
args = {
ticks = {
order = 1,
type = "toggle",
name = L["Ticks"],
desc = L["Display tick marks on the castbar for channelled spells. This will adjust automatically for spells like Drain Soul and add additional ticks based on haste."]
},
tickColor = {
order = 2,
type = "color",
name = L["COLOR"],
hasAlpha = true,
get = function(info)
local c = E.db.unitframe.units[groupName].castbar.tickColor
local d = P.unitframe.units[groupName].castbar.tickColor
return c.r, c.g, c.b, c.a, d.r, d.g, d.b, d.a
end,
set = function(info, r, g, b, a)
local c = E.db.unitframe.units[groupName].castbar.tickColor
c.r, c.g, c.b, c.a = r, g, b, a
updateFunc(UF, groupName, numUnits)
end
},
tickWidth = {
order = 3,
type = "range",
name = L["Width"],
min = 1, max = 20, step = 1
}
}
}
end
return config
end
local function GetOptionsTable_RaidIcon(updateFunc, groupName, numUnits)
local config = {
order = 1000,
type = "group",
name = L["Raid Icon"],
get = function(info) return E.db.unitframe.units[groupName].raidicon[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].raidicon[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
header = {
order = 1,
type = "header",
name = L["Raid Icon"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"],
},
attachTo = {
order = 3,
type = "select",
name = L["Position"],
values = positionValues,
disabled = function() return not E.db.unitframe.units[groupName].raidicon.enable end
},
attachToObject = {
order = 4,
type = "select",
name = L["Attach To"],
values = attachToValues
},
size = {
order = 5,
type = "range",
name = L["Size"],
min = 8, max = 60, step = 1,
disabled = function() return not E.db.unitframe.units[groupName].raidicon.enable end
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
min = -300, max = 300, step = 1,
disabled = function() return not E.db.unitframe.units[groupName].raidicon.enable end
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
min = -300, max = 300, step = 1,
disabled = function() return not E.db.unitframe.units[groupName].raidicon.enable end
}
}
}
return config
end
local function GetOptionsTable_ResurrectIcon(updateFunc, groupName, numUnits)
local config = {
order = 5001,
type = "group",
name = L["Resurrect Icon"],
get = function(info) return E.db.unitframe.units[groupName].resurrectIcon[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].resurrectIcon[info[#info]] = value updateFunc(UF, groupName, numUnits) end,
args = {
header = {
order = 1,
type = "header",
name = L["Resurrect Icon"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
attachTo = {
order = 3,
type = "select",
name = L["Position"],
values = positionValues
},
attachToObject = {
order = 4,
type = "select",
name = L["Attach To"],
values = attachToValues
},
size = {
order = 5,
type = "range",
name = L["Size"],
min = 8, max = 60, step = 1
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
min = -300, max = 300, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
min = -300, max = 300, step = 1
}
}
}
return config
end
local function GetOptionsTable_RaidDebuff(updateFunc, groupName)
local config = {
order = 800,
type = "group",
name = L["RaidDebuff Indicator"],
get = function(info) return E.db.unitframe.units[groupName].rdebuffs[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].rdebuffs[info[#info]] = value updateFunc(UF, groupName) end,
args = {
header = {
order = 1,
type = "header",
name = L["RaidDebuff Indicator"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
showDispellableDebuff = {
order = 3,
type = "toggle",
name = L["Show Dispellable Debuffs"]
},
onlyMatchSpellID = {
order = 4,
type = "toggle",
name = L["Only Match SpellID"],
desc = L["When enabled it will only show spells that were added to the filter using a spell ID and not a name."],
},
size = {
order = 5,
type = "range",
name = L["Size"],
min = 8, max = 100, step = 1
},
font = {
order = 6,
type = "select", dialogControl = "LSM30_Font",
name = L["Font"],
values = AceGUIWidgetLSMlists.font
},
fontSize = {
order = 7,
type = "range",
name = L["FONT_SIZE"],
min = 7, max = 22, step = 1
},
fontOutline = {
order = 8,
type = "select",
name = L["Font Outline"],
values = C.Values.FontFlags
},
xOffset = {
order = 9,
type = "range",
name = L["X-Offset"],
min = -300, max = 300, step = 1
},
yOffset = {
order = 10,
type = "range",
name = L["Y-Offset"],
min = -300, max = 300, step = 1
},
configureButton = {
order = 11,
type = "execute",
name = L["Configure Auras"],
func = function() E:SetToFilterConfig("RaidDebuffs") end
},
duration = {
order = 12,
type = "group",
guiInline = true,
name = L["Duration Text"],
get = function(info) return E.db.unitframe.units[groupName].rdebuffs.duration[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].rdebuffs.duration[info[#info]] = value updateFunc(UF, groupName) end,
args = {
position = {
order = 1,
type = "select",
name = L["Position"],
values = positionValues
},
xOffset = {
order = 2,
type = "range",
name = L["X-Offset"],
min = -10, max = 10, step = 1
},
yOffset = {
order = 3,
type = "range",
name = L["Y-Offset"],
min = -10, max = 10, step = 1
},
color = {
order = 4,
type = "color",
name = L["COLOR"],
hasAlpha = true,
get = function(info)
local c = E.db.unitframe.units.raid.rdebuffs.duration.color
local d = P.unitframe.units.raid.rdebuffs.duration.color
return c.r, c.g, c.b, c.a, d.r, d.g, d.b, d.a
end,
set = function(info, r, g, b, a)
local c = E.db.unitframe.units.raid.rdebuffs.duration.color
c.r, c.g, c.b, c.a = r, g, b, a
UF:CreateAndUpdateHeaderGroup("raid")
end
}
}
},
stack = {
order = 13,
type = "group",
guiInline = true,
name = L["Stack Counter"],
get = function(info) return E.db.unitframe.units[groupName].rdebuffs.stack[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].rdebuffs.stack[info[#info]] = value updateFunc(UF, groupName) end,
args = {
position = {
order = 1,
type = "select",
name = L["Position"],
values = positionValues
},
xOffset = {
order = 2,
type = "range",
name = L["X-Offset"],
min = -10, max = 10, step = 1
},
yOffset = {
order = 3,
type = "range",
name = L["Y-Offset"],
min = -10, max = 10, step = 1
},
color = {
order = 4,
type = "color",
name = L["COLOR"],
hasAlpha = true,
get = function(info)
local c = E.db.unitframe.units[groupName].rdebuffs.stack.color
local d = P.unitframe.units[groupName].rdebuffs.stack.color
return c.r, c.g, c.b, c.a, d.r, d.g, d.b, d.a
end,
set = function(info, r, g, b, a)
local c = E.db.unitframe.units[groupName].rdebuffs.stack.color
c.r, c.g, c.b, c.a = r, g, b, a
updateFunc(UF, groupName)
end
}
}
}
}
}
return config
end
local function GetOptionsTable_ReadyCheckIcon(updateFunc, groupName)
local config = {
order = 700,
type = "group",
name = L["Ready Check Icon"],
get = function(info) return E.db.unitframe.units[groupName].readycheckIcon[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].readycheckIcon[info[#info]] = value updateFunc(UF, groupName) end,
args = {
header = {
order = 1,
type = "header",
name = L["Ready Check Icon"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
size = {
order = 3,
type = "range",
name = L["Size"],
min = 8, max = 60, step = 1
},
attachTo = {
order = 4,
type = "select",
name = L["Attach To"],
values = attachToValues
},
position = {
order = 5,
type = "select",
name = L["Position"],
values = positionValues
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
min = -300, max = 300, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
min = -300, max = 300, step = 1
}
}
}
return config
end
local function GetOptionsTable_HealPrediction(updateFunc, groupName, numGroup)
local config = {
order = 101,
type = "group",
name = L["Heal Prediction"],
desc = L["Show an incoming heal prediction bar on the unitframe. Also display a slightly different colored bar for incoming overheals."],
get = function(info) return E.db.unitframe.units[groupName].healPrediction[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].healPrediction[info[#info]] = value updateFunc(UF, groupName, numGroup) end,
args = {
header = {
order = 1,
type = "header",
name = L["Heal Prediction"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
colors = {
order = 3,
type = "execute",
name = L["COLORS"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "generalOptionsGroup", "allColorsGroup", "healPrediction") end,
disabled = function() return not E.UnitFrames.Initialized end
}
}
}
return config
end
local function CreateCustomTextGroup(unit, objectName)
if not E.Options.args.unitframe.args[unit] then
return
elseif E.Options.args.unitframe.args[unit].args.customText.args[objectName] then
E.Options.args.unitframe.args[unit].args.customText.args[objectName].hidden = false -- Re-show existing custom texts which belong to current profile and were previously hidden
tinsert(CUSTOMTEXT_CONFIGS, E.Options.args.unitframe.args[unit].args.customText.args[objectName]) --Register this custom text config to be hidden again on profile change
return
end
E.Options.args.unitframe.args[unit].args.customText.args[objectName] = {
order = -1,
type = "group",
name = objectName,
get = function(info) return E.db.unitframe.units[unit].customTexts[objectName][info[#info]] end,
set = function(info, value)
E.db.unitframe.units[unit].customTexts[objectName][info[#info]] = value
if unit == "party" or unit:find("raid") then
UF:CreateAndUpdateHeaderGroup(unit)
elseif unit == "boss" then
UF:CreateAndUpdateUFGroup("boss", MAX_BOSS_FRAMES)
elseif unit == "arena" then
UF:CreateAndUpdateUFGroup("arena", 5)
else
UF:CreateAndUpdateUF(unit)
end
end,
args = {
header = {
order = 1,
type = "header",
name = objectName,
},
delete = {
order = 2,
type = "execute",
name = L["DELETE"],
func = function()
E.Options.args.unitframe.args[unit].args.customText.args[objectName] = nil
E.db.unitframe.units[unit].customTexts[objectName] = nil
if unit == "boss" or unit == "arena" then
for i = 1, 5 do
if UF[unit..i] then
UF[unit..i]:Untag(UF[unit..i].customTexts[objectName])
UF[unit..i].customTexts[objectName]:Hide()
UF[unit..i].customTexts[objectName] = nil
end
end
elseif unit == "party" or unit:find("raid") then
for i = 1, UF[unit]:GetNumChildren() do
local child = select(i, UF[unit]:GetChildren())
if child.Untag then
child:Untag(child.customTexts[objectName])
child.customTexts[objectName]:Hide()
child.customTexts[objectName] = nil
else
for x = 1, child:GetNumChildren() do
local c2 = select(x, child:GetChildren())
if c2.Untag then
c2:Untag(c2.customTexts[objectName])
c2.customTexts[objectName]:Hide()
c2.customTexts[objectName] = nil
end
end
end
end
elseif UF[unit] then
UF[unit]:Untag(UF[unit].customTexts[objectName])
UF[unit].customTexts[objectName]:Hide()
UF[unit].customTexts[objectName] = nil
end
end
},
enable = {
order = 3,
type = "toggle",
name = L["Enable"],
},
font = {
order = 4,
type = "select", dialogControl = "LSM30_Font",
name = L["Font"],
values = AceGUIWidgetLSMlists.font
},
size = {
order = 5,
type = "range",
name = L["FONT_SIZE"],
min = 6, max = 32, step = 1
},
fontOutline = {
order = 6,
type = "select",
name = L["Font Outline"],
desc = L["Set the font outline."],
values = C.Values.FontFlags
},
justifyH = {
order = 7,
type = "select",
name = L["JustifyH"],
desc = L["Sets the font instance's horizontal text alignment style."],
values = {
["CENTER"] = L["Center"],
["LEFT"] = L["Left"],
["RIGHT"] = L["Right"]
}
},
xOffset = {
order = 8,
type = "range",
name = L["X-Offset"],
min = -400, max = 400, step = 1
},
yOffset = {
order = 9,
type = "range",
name = L["Y-Offset"],
min = -400, max = 400, step = 1
},
attachTextTo = {
order = 10,
type = "select",
name = L["Attach Text To"],
values = attachToValues
},
text_format = {
order = 100,
type = "input",
name = L["Text Format"],
desc = L["TEXT_FORMAT_DESC"],
width = "full"
}
}
}
tinsert(CUSTOMTEXT_CONFIGS, E.Options.args.unitframe.args[unit].args.customText.args[objectName]) --Register this custom text config to be hidden on profile change
end
local function GetOptionsTable_CustomText(updateFunc, groupName, numUnits)
local config = {
order = 5100,
type = "group",
name = L["Custom Texts"],
args = {
header = {
order = 1,
type = "header",
name = L["Custom Texts"],
},
createCustomText = {
order = 2,
type = "input",
name = L["Create Custom Text"],
width = "full",
get = function() return "" end,
set = function(info, textName)
for object in pairs(E.db.unitframe.units[groupName]) do
if object:lower() == textName:lower() then
E:Print(L["The name you have selected is already in use by another element."])
return
end
end
if not E.db.unitframe.units[groupName].customTexts then
E.db.unitframe.units[groupName].customTexts = {}
end
local frameName = "ElvUF_"..E:StringTitle(groupName)
if E.db.unitframe.units[groupName].customTexts[textName] or (_G[frameName] and _G[frameName].customTexts and _G[frameName].customTexts[textName] or _G[frameName.."Group1UnitButton1"] and _G[frameName.."Group1UnitButton1"].customTexts and _G[frameName.."Group1UnitButton1"][textName]) then
E:Print(L["The name you have selected is already in use by another element."])
return
end
E.db.unitframe.units[groupName].customTexts[textName] = {
["text_format"] = "",
["size"] = E.db.unitframe.fontSize,
["font"] = E.db.unitframe.font,
["xOffset"] = 0,
["yOffset"] = 0,
["justifyH"] = "CENTER",
["fontOutline"] = E.db.unitframe.fontOutline,
["attachTextTo"] = "Health"
}
CreateCustomTextGroup(groupName, textName)
updateFunc(UF, groupName, numUnits)
end
}
}
}
return config
end
local function GetOptionsTable_GPS(groupName)
local config = {
order = 3000,
type = "group",
name = L["GPS Arrow"],
get = function(info) return E.db.unitframe.units[groupName].GPSArrow[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].GPSArrow[info[#info]] = value UF:CreateAndUpdateHeaderGroup(groupName) end,
args = {
header = {
order = 1,
type = "header",
name = L["GPS Arrow"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
onMouseOver = {
order = 3,
type = "toggle",
name = L["Mouseover"],
desc = L["Only show when you are mousing over a frame."]
},
outOfRange = {
order = 4,
type = "toggle",
name = L["Out of Range"],
desc = L["Only show when the unit is not in range."]
},
size = {
order = 5,
type = "range",
name = L["Size"],
min = 8, max = 60, step = 1
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
min = -300, max = 300, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
min = -300, max = 300, step = 1
}
}
}
return config
end
local function GetOptionsTableForNonGroup_GPS(unit)
local config = {
order = 3000,
type = "group",
name = L["GPS Arrow"],
get = function(info) return E.db.unitframe.units[unit].GPSArrow[info[#info]] end,
set = function(info, value) E.db.unitframe.units[unit].GPSArrow[info[#info]] = value UF:CreateAndUpdateUF(unit) end,
args = {
header = {
order = 1,
type = "header",
name = L["GPS Arrow"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
onMouseOver = {
order = 3,
type = "toggle",
name = L["Mouseover"],
desc = L["Only show when you are mousing over a frame."]
},
outOfRange = {
order = 4,
type = "toggle",
name = L["Out of Range"],
desc = L["Only show when the unit is not in range."]
},
size = {
order = 5,
type = "range",
name = L["Size"],
min = 8, max = 60, step = 1
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
min = -300, max = 300, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
min = -300, max = 300, step = 1
}
}
}
return config
end
local function GetOptionsTable_Cutaway(updateFunc, groupName, numGroup)
local config = {
order = 1021,
type = "group",
childGroups = "tabs",
name = L["Cutaway Bars"],
args = {
health = {
order = 1,
type = "group",
guiInline = true,
name = L["HEALTH"],
get = function(info) return E.db.unitframe.units[groupName].cutaway.health[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].cutaway.health[info[#info]] = value; updateFunc(UF, groupName, numGroup) end,
args = {
enabled = {
order = 1,
type = "toggle",
name = L["Enable"]
},
lengthBeforeFade = {
order = 2,
type = "range",
name = L["Fade Out Delay"],
desc = L["How much time before the cutaway health starts to fade."],
min = 0.1, max = 1, step = 0.1,
disabled = function() return not E.db.unitframe.units[groupName].cutaway.health.enabled end
},
fadeOutTime = {
order = 3,
type = "range",
name = L["Fade Out"],
desc = L["How long the cutaway health will take to fade out."],
min = 0.1, max = 1, step = 0.1,
disabled = function() return not E.db.unitframe.units[groupName].cutaway.health.enabled end
}
}
}
}
}
if E.db.unitframe.units[groupName].cutaway.power then
config.args.power = {
order = 2,
type = "group",
name = L["Power"],
guiInline = true,
get = function(info) return E.db.unitframe.units[groupName].cutaway.power[info[#info]] end,
set = function(info, value) E.db.unitframe.units[groupName].cutaway.power[info[#info]] = value updateFunc(UF, groupName, numGroup) end,
args = {
enabled = {
order = 1,
type = "toggle",
name = L["Enable"]
},
lengthBeforeFade = {
order = 2,
type = "range",
name = L["Fade Out Delay"],
desc = L["How much time before the cutaway power starts to fade."],
min = 0.1, max = 1, step = 0.1,
disabled = function() return not E.db.unitframe.units[groupName].cutaway.power.enabled end
},
fadeOutTime = {
type = "range",
order = 3,
name = L["Fade Out"],
desc = L["How long the cutaway power will take to fade out."],
min = 0.1, max = 1, step = 0.1,
disabled = function() return not E.db.unitframe.units[groupName].cutaway.power.enabled end
}
}
}
end
return config
end
E.Options.args.unitframe = {
type = "group",
name = L["UnitFrames"],
childGroups = "tree",
get = function(info) return E.db.unitframe[info[#info]] end,
set = function(info, value) E.db.unitframe[info[#info]] = value end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"],
get = function(info) return E.private.unitframe.enable end,
set = function(info, value) E.private.unitframe.enable = value E:StaticPopup_Show("PRIVATE_RL") end
},
intro = {
order = 2,
type = "description",
name = L["UNITFRAME_DESC"]
},
header = {
order = 3,
type = "header",
name = L["Shortcuts"]
},
spacer1 = {
order = 4,
type = "description",
name = " "
},
generalShortcut = {
order = 5,
type = "execute",
name = L["General"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "generalOptionsGroup", "generalGroup") end,
disabled = function() return not E.UnitFrames.Initialized end
},
frameGlowShortcut = {
order = 6,
type = "execute",
name = L["Frame Glow"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "generalOptionsGroup", "frameGlowGroup") end,
disabled = function() return not E.UnitFrames.Initialized end
},
cooldownShortcut = {
order = 7,
type = "execute",
name = L["Cooldowns"],
func = function() ACD:SelectGroup("ElvUI", "cooldown", "unitframe") end,
disabled = function() return not E.UnitFrames.Initialized end
},
colorsShortcut = {
order = 8,
type = "execute",
name = L["COLORS"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "generalOptionsGroup", "allColorsGroup") end,
disabled = function() return not E.UnitFrames.Initialized end,
},
spacer2 = {
order = 9,
type = "description",
name = " "
},
blizzardShortcut = {
order = 10,
type = "execute",
name = L["Disabled Blizzard Frames"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "generalOptionsGroup", "disabledBlizzardFrames") end,
disabled = function() return not E.UnitFrames.Initialized end
},
playerShortcut = {
order = 11,
type = "execute",
name = L["Player"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "player") end,
disabled = function() return not E.UnitFrames.Initialized end
},
targetShortcut = {
order = 12,
type = "execute",
name = L["TARGET"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "target") end,
disabled = function() return not E.UnitFrames.Initialized end
},
targettargetShortcut = {
order = 13,
type = "execute",
name = L["TargetTarget"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "targettarget") end,
disabled = function() return not E.UnitFrames.Initialized end
},
spacer3 = {
order = 14,
type = "description",
name = " "
},
targettargettargetShortcut = {
order = 15,
type = "execute",
name = L["TargetTargetTarget"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "targettargettarget") end,
disabled = function() return not E.UnitFrames.Initialized end
},
focusShortcut = {
order = 16,
type = "execute",
name = L["Focus"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "focus") end,
disabled = function() return not E.UnitFrames.Initialized end
},
focustargetShortcut = {
order = 17,
type = "execute",
name = L["FocusTarget"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "focustarget") end,
disabled = function() return not E.UnitFrames.Initialized end
},
petShortcut = {
order = 18,
type = "execute",
name = L["PET"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "pet") end,
disabled = function() return not E.UnitFrames.Initialized end
},
spacer4 = {
order = 19,
type = "description",
name = " "
},
pettargetShortcut = {
order = 20,
type = "execute",
name = L["PetTarget"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "pettarget") end,
disabled = function() return not E.UnitFrames.Initialized end
},
arenaShortcut = {
order = 21,
type = "execute",
name = L["ARENA"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "arena") end,
disabled = function() return not E.UnitFrames.Initialized end
},
bossShortcut = {
order = 22,
type = "execute",
name = L["BOSS"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "boss") end,
disabled = function() return not E.UnitFrames.Initialized end
},
partyShortcut = {
order = 23,
type = "execute",
name = L["PARTY"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "party") end,
disabled = function() return not E.UnitFrames.Initialized end
},
spacer6 = {
order = 24,
type = "description",
name = " "
},
raidShortcut = {
order = 25,
type = "execute",
name = L["RAID"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "raid") end,
disabled = function() return not E.UnitFrames.Initialized end
},
raid40Shortcut = {
order = 26,
type = "execute",
name = L["Raid-40"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "raid40") end,
disabled = function() return not E.UnitFrames.Initialized end
},
raidpetShortcut = {
order = 29,
type = "execute",
name = L["Raid Pet"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "raidpet") end,
disabled = function() return not E.UnitFrames.Initialized end
},
assistShortcut = {
order = 30,
type = "execute",
name = L["Assist"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "assist") end,
disabled = function() return not E.UnitFrames.Initialized end
},
spacer7 = {
order = 31,
type = "description",
name = " "
},
tankShortcut = {
order = 32,
type = "execute",
name = L["TANK"],
func = function() ACD:SelectGroup("ElvUI", "unitframe", "tank") end,
disabled = function() return not E.UnitFrames.Initialized end
},
generalOptionsGroup = {
order = 33,
type = "group",
name = L["General Options"],
childGroups = "tab",
disabled = function() return not E.UnitFrames.Initialized end,
args = {
generalGroup = {
order = 1,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
thinBorders = {
order = 2,
type = "toggle",
name = L["Thin Borders"],
desc = L["Use thin borders on certain unitframe elements."],
disabled = function() return E.private.general.pixelPerfect end,
set = function(info, value) E.db.unitframe[info[#info]] = value E:StaticPopup_Show("CONFIG_RL") end
},
smartRaidFilter = {
order = 3,
type = "toggle",
name = L["Smart Raid Filter"],
desc = L["Override any custom visibility setting in certain situations, EX: Only show groups 1 and 2 inside a 10 man instance."],
set = function(info, value) E.db.unitframe[info[#info]] = value UF:UpdateAllHeaders() end
},
targetOnMouseDown = {
order = 4,
type = "toggle",
name = L["Target On Mouse-Down"],
desc = L["Target units on mouse down rather than mouse up. \n\n|cffFF0000Warning: If you are using the addon 'Clique' you may have to adjust your clique settings when changing this."],
set = function(info, value) E.db.unitframe[info[#info]] = value E:StaticPopup_Show("CONFIG_RL") end
},
auraBlacklistModifier = {
order = 5,
type = "select",
name = L["Blacklist Modifier"],
desc = L["You need to hold this modifier down in order to blacklist an aura by right-clicking the icon. Set to None to disable the blacklist functionality."],
values = {
["NONE"] = L["NONE"],
["SHIFT"] = L["SHIFT_KEY"],
["ALT"] = L["ALT_KEY_TEXT"],
["CTRL"] = L["CTRL_KEY"]
}
},
resetFilters = {
order = 6,
type = "execute",
name = L["Reset Aura Filters"],
func = function(info)
E:StaticPopup_Show("RESET_UF_AF") --reset unitframe aurafilters
end
},
barGroup = {
order = 7,
type = "group",
guiInline = true,
name = L["Bars"],
args = {
smoothbars = {
order = 1,
type = "toggle",
name = L["Smooth Bars"],
desc = L["Bars will transition smoothly."],
set = function(info, value) E.db.unitframe[info[#info]] = value UF:Update_AllFrames() end
},
statusbar = {
order = 3,
type = "select", dialogControl = "LSM30_Statusbar",
name = L["StatusBar Texture"],
desc = L["Main statusbar texture."],
values = AceGUIWidgetLSMlists.statusbar,
set = function(info, value) E.db.unitframe[info[#info]] = value UF:Update_StatusBars() end
}
}
},
fontGroup = {
order = 8,
type = "group",
guiInline = true,
name = L["Fonts"],
args = {
font = {
order = 4,
type = "select", dialogControl = "LSM30_Font",
name = L["Default Font"],
desc = L["The font that the unitframes will use."],
values = AceGUIWidgetLSMlists.font,
set = function(info, value) E.db.unitframe[info[#info]] = value UF:Update_FontStrings() end
},
fontSize = {
order = 5,
type = "range",
name = L["FONT_SIZE"],
desc = L["Set the font size for unitframes."],
min = 4, max = 32, step = 1,
set = function(info, value) E.db.unitframe[info[#info]] = value UF:Update_FontStrings() end
},
fontOutline = {
order = 6,
type = "select",
name = L["Font Outline"],
desc = L["Set the font outline."],
values = C.Values.FontFlags,
set = function(info, value) E.db.unitframe[info[#info]] = value UF:Update_FontStrings() end
}
}
}
}
},
frameGlowGroup = {
order = 2,
type = "group",
childGroups = "tree",
name = L["Frame Glow"],
args = {
header = {
order = 1,
type = "header",
name = L["Frame Glow"]
},
mainGlow = {
order = 2,
type = "group",
guiInline = true,
name = L["Mouseover Glow"],
get = function(info)
local t = E.db.unitframe.colors.frameGlow.mainGlow[info[#info]]
if type(t) == "boolean" then return t end
local d = P.unitframe.colors.frameGlow.mainGlow[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b, d.a
end,
set = function(info, r, g, b, a)
local t = E.db.unitframe.colors.frameGlow.mainGlow[info[#info]]
if type(t) == "boolean" then
E.db.unitframe.colors.frameGlow.mainGlow[info[#info]] = r
else
t.r, t.g, t.b, t.a = r, g, b, a
end
UF:FrameGlow_UpdateFrames()
end,
disabled = function() return not E.db.unitframe.colors.frameGlow.mainGlow.enable end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"],
disabled = false
},
spacer = {
order = 2,
type = "description",
name = ""
},
class = {
order = 3,
type = "toggle",
name = L["Use Class Color"],
desc = L["Alpha channel is taken from the color option."]
},
color = {
order = 4,
type = "color",
name = L["COLOR"],
hasAlpha = true,
disabled = function() return not E.db.unitframe.colors.frameGlow.mainGlow.enable or E.db.unitframe.colors.frameGlow.mainGlow.class end
}
}
},
targetGlow = {
order = 3,
type = "group",
guiInline = true,
name = L["Targeted Glow"],
get = function(info)
local t = E.db.unitframe.colors.frameGlow.targetGlow[info[#info]]
if type(t) == "boolean" then return t end
local d = P.unitframe.colors.frameGlow.targetGlow[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b, d.a
end,
set = function(info, r, g, b, a)
local t = E.db.unitframe.colors.frameGlow.targetGlow[info[#info]]
if type(t) == "boolean" then
E.db.unitframe.colors.frameGlow.targetGlow[info[#info]] = r
else
t.r, t.g, t.b, t.a = r, g, b, a
end
UF:FrameGlow_UpdateFrames()
end,
disabled = function() return not E.db.unitframe.colors.frameGlow.targetGlow.enable end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"],
disabled = false
},
spacer = {
order = 2,
type = "description",
name = ""
},
class = {
order = 3,
type = "toggle",
name = L["Use Class Color"],
desc = L["Alpha channel is taken from the color option."]
},
color = {
order = 4,
type = "color",
name = L["COLOR"],
hasAlpha = true,
disabled = function() return not E.db.unitframe.colors.frameGlow.targetGlow.enable or E.db.unitframe.colors.frameGlow.targetGlow.class end
}
}
},
mouseoverGlow = {
order = 4,
type = "group",
guiInline = true,
name = L["Mouseover Highlight"],
get = function(info)
local t = E.db.unitframe.colors.frameGlow.mouseoverGlow[info[#info]]
if type(t) == "boolean" then return t end
local d = P.unitframe.colors.frameGlow.mouseoverGlow[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b, d.a
end,
set = function(info, r, g, b, a)
local t = E.db.unitframe.colors.frameGlow.mouseoverGlow[info[#info]]
if type(t) == "boolean" then
E.db.unitframe.colors.frameGlow.mouseoverGlow[info[#info]] = r
else
t.r, t.g, t.b, t.a = r, g, b, a
end
UF:FrameGlow_UpdateFrames()
end,
disabled = function() return not E.db.unitframe.colors.frameGlow.mouseoverGlow.enable end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"],
disabled = false
},
texture = {
order = 2,
type = "select",
dialogControl = "LSM30_Statusbar",
name = L["Texture"],
values = AceGUIWidgetLSMlists.statusbar,
get = function(info)
return E.db.unitframe.colors.frameGlow.mouseoverGlow[info[#info]]
end,
set = function(info, value)
E.db.unitframe.colors.frameGlow.mouseoverGlow[info[#info]] = value
UF:FrameGlow_UpdateFrames()
end
},
spacer = {
order = 3,
type = "description",
name = ""
},
class = {
order = 4,
type = "toggle",
name = L["Use Class Color"],
desc = L["Alpha channel is taken from the color option."]
},
color = {
order = 5,
type = "color",
name = L["COLOR"],
hasAlpha = true,
disabled = function() return not E.db.unitframe.colors.frameGlow.mouseoverGlow.enable or E.db.unitframe.colors.frameGlow.mouseoverGlow.class end
}
}
}
}
},
allColorsGroup = {
order = 3,
type = "group",
childGroups = "tree",
name = L["COLORS"],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end,
args = {
header = {
order = 1,
type = "header",
name = L["COLORS"]
},
borderColor = {
order = 2,
type = "color",
name = L["Border Color"],
get = function(info)
local t = E.db.unitframe.colors.borderColor
local d = P.unitframe.colors.borderColor
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors.borderColor
t.r, t.g, t.b = r, g, b
E:UpdateMedia()
E:UpdateBorderColors()
end
},
healthGroup = {
order = 3,
type = "group",
name = L["HEALTH"],
get = function(info)
local t = E.db.unitframe.colors[info[#info]]
local d = P.unitframe.colors[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors[info[#info]]
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end,
args = {
header = {
order = 1,
type = "header",
name = L["HEALTH"]
},
colorhealthbyvalue = {
order = 2,
type = "toggle",
name = L["Health By Value"],
desc = L["Color health by amount remaining."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end,
disabled = function() return E.db.unitframe.colors.colorhealthbyvalue_threshold end
},
healthclass = {
order = 3,
type = "toggle",
name = L["Class Health"],
desc = L["Color health by classcolor or reaction."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
forcehealthreaction = {
order = 4,
type = "toggle",
name = L["Force Reaction Color"],
desc = L["Forces reaction color instead of class color on units controlled by players."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end,
disabled = function() return not E.db.unitframe.colors.healthclass end
},
--[=[healththreat = {
order = 5,
type = "toggle",
name = L["Threat Health"],
desc = L["Color health by threat status."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},]=]
transparentHealth = {
order = 6,
type = "toggle",
name = L["Transparent"],
desc = L["Make textures transparent."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
spacer1 = {
order = 7,
type = "description",
name = " ",
width = "full"
},
customhealthbackdrop = {
order = 8,
type = "toggle",
name = L["Custom Backdrop"],
desc = L["Use the custom backdrop color instead of a multiple of the main color."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
health_backdrop = {
order = 9,
type = "color",
name = L["Health Backdrop"],
disabled = function() return not E.db.unitframe.colors.customhealthbackdrop end
},
spacer2 = {
order = 10,
type = "description",
name = " ",
width = "full"
},
useDeadBackdrop = {
order = 11,
type = "toggle",
name = L["Use Dead Backdrop"],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
health_backdrop_dead = {
order = 12,
type = "color",
name = L["Custom Dead Backdrop"],
desc = L["Use this backdrop color for units that are dead or ghosts."],
customWidth = 250,
disabled = function() return not E.db.unitframe.colors.useDeadBackdrop end
},
spacer3 = {
order = 13,
type = "description",
name = " ",
width = "full"
},
classbackdrop = {
order = 14,
type = "toggle",
name = L["Class Backdrop"],
desc = L["Color the health backdrop by class or reaction."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end,
disabled = function() return E.db.unitframe.colors.customhealthbackdrop end
},
healthMultiplier = {
order = 15,
type = "range",
name = L["Health Backdrop Multiplier"],
min = 0, softMax = 0.75, max = 1, step = .01,
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end,
disabled = function() return E.db.unitframe.colors.customhealthbackdrop end
},
spacer4 = {
order = 16,
type = "description",
name = " ",
width = "full"
},
tapped = {
order = 17,
type = "color",
name = L["Tapped"]
},
health = {
order = 18,
type = "color",
name = L["HEALTH"]
},
disconnected = {
order = 19,
type = "color",
name = L["Disconnected"]
},
spacer5 = {
order = 20,
type = "description",
name = " ",
width = "full"
},
colorhealthbyvalue_threshold = {
order = 21,
type = "toggle",
name = L["Health By Threshold"],
desc = L["Color health by specific thresholds."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end,
disabled = function() return E.db.unitframe.colors.colorhealthbyvalue end
},
colorhealthbyvalue_thresholdgradient = {
order = 22,
type = "toggle",
name = L["Slight Gradient"],
desc = L["Allow a small gradient between each threshold"],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end,
disabled = function() return not E.db.unitframe.colors.colorhealthbyvalue_threshold end
},
spacer6 = {
order = 23,
type = "description",
name = " ",
width = "full"
},
threshold_20 = {
order = 24,
type = "color",
name = L["Threshold 20"]
},
threshold_35 = {
order = 25,
type = "color",
name = L["Threshold 35"]
},
threshold_50 = {
order = 26,
type = "color",
name = L["Threshold 50"]
},
threshold_75 = {
order = 27,
type = "color",
name = L["Threshold 75"]
}
}
},
powerGroup = {
order = 4,
type = "group",
name = L["Powers"],
get = function(info)
local t = E.db.unitframe.colors.power[info[#info]]
local d = P.unitframe.colors.power[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors.power[info[#info]]
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end,
args = {
header = {
order = 1,
type = "header",
name = L["Powers"]
},
transparentPower = {
order = 2,
type = "toggle",
name = L["Transparent"],
desc = L["Make textures transparent."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
invertPower = {
order = 3,
type = "toggle",
name = L["Invert Colors"],
desc = L["Invert foreground and background colors."],
disabled = function() return not E.db.unitframe.colors.transparentPower end,
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end,
},
powerclass = {
order = 4,
type = "toggle",
name = L["Class Power"],
desc = L["Color power by classcolor or reaction."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
--[=[powerthreat = {
order = 5,
type = "toggle",
name = L["Threat Power"],
desc = L["Color power by threat status."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},]=]
spacer2 = {
order = 6,
type = "description",
name = " ",
width = "full"
},
custompowerbackdrop = {
order = 7,
type = "toggle",
name = L["Custom Backdrop"],
desc = L["Use the custom backdrop color instead of a multiple of the main color."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end,
},
power_backdrop = {
order = 8,
type = "color",
name = L["Custom Backdrop"],
desc = L["Use the custom backdrop color instead of a multiple of the main color."],
disabled = function() return not E.db.unitframe.colors.custompowerbackdrop end,
get = function(info)
local t = E.db.unitframe.colors[info[#info]]
local d = P.unitframe.colors[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors[info[#info]]
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end,
},
spacer3 = {
order = 9,
type = "description",
name = " ",
width = "full"
},
MANA = {
order = 10,
type = "color",
name = L["MANA"]
},
RAGE = {
order = 11,
type = "color",
name = L["RAGE"]
},
FOCUS = {
order = 12,
type = "color",
name = L["FOCUS"]
},
ENERGY = {
order = 13,
type = "color",
name = L["ENERGY"]
},
RUNIC_POWER = {
order = 14,
type = "color",
name = L["RUNIC_POWER"]
}
}
},
castBars = {
order = 5,
type = "group",
name = L["Castbar"],
get = function(info)
local t = E.db.unitframe.colors[info[#info]]
local d = P.unitframe.colors[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors[info[#info]]
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end,
args = {
header = {
order = 1,
type = "header",
name = L["Castbar"]
},
transparentCastbar = {
order = 2,
type = "toggle",
name = L["Transparent"],
desc = L["Make textures transparent."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
invertCastbar = {
order = 3,
type = "toggle",
name = L["Invert Colors"],
desc = L["Invert foreground and background colors."],
disabled = function() return not E.db.unitframe.colors.transparentCastbar end,
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
castClassColor = {
order = 4,
type = "toggle",
name = L["Class Castbars"],
desc = L["Color castbars by the class of player units."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
castReactionColor = {
order = 5,
type = "toggle",
name = L["Reaction Castbars"],
desc = L["Color castbars by the reaction type of non-player units."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
spacer1 = {
order = 6,
type = "description",
name = " ",
width = "full"
},
customcastbarbackdrop = {
order = 7,
type = "toggle",
name = L["Custom Backdrop"],
desc = L["Use the custom backdrop color instead of a multiple of the main color."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
castbar_backdrop = {
order = 8,
type = "color",
name = L["Custom Backdrop"],
desc = L["Use the custom backdrop color instead of a multiple of the main color."],
disabled = function() return not E.db.unitframe.colors.customcastbarbackdrop end
},
spacer2 = {
order = 9,
type = "description",
name = " ",
width = "full"
},
castColor = {
order = 10,
type = "color",
name = L["Interruptable"]
},
castNoInterrupt = {
order = 11,
type = "color",
name = L["Non-Interruptable"]
}
}
},
auraBars = {
order = 6,
type = "group",
name = L["Aura Bars"],
args = {
header = {
order = 1,
type = "header",
name = L["Aura Bars"]
},
transparentAurabars = {
order = 2,
type = "toggle",
name = L["Transparent"],
desc = L["Make textures transparent."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
invertAurabars = {
order = 3,
type = "toggle",
name = L["Invert Colors"],
desc = L["Invert foreground and background colors."],
disabled = function() return not E.db.unitframe.colors.transparentAurabars end,
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end
},
auraBarByType = {
order = 4,
type = "toggle",
name = L["By Type"],
desc = L["Color aurabar debuffs by type."]
},
auraBarTurtle = {
order = 5,
type = "toggle",
name = L["Color Turtle Buffs"],
desc = L["Color all buffs that reduce the unit's incoming damage."]
},
spacer1 = {
order = 6,
type = "description",
name = " ",
width = "full"
},
customaurabarbackdrop = {
order = 7,
type = "toggle",
name = L["Custom Backdrop"],
desc = L["Use the custom backdrop color instead of a multiple of the main color."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end,
},
aurabar_backdrop = {
order = 8,
type = "color",
name = L["Custom Backdrop"],
desc = L["Use the custom backdrop color instead of a multiple of the main color."],
disabled = function() return not E.db.unitframe.colors.customaurabarbackdrop end,
get = function(info)
local t = E.db.unitframe.colors[info[#info]]
local d = P.unitframe.colors[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors[info[#info]]
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end,
},
spacer2 = {
order = 9,
type = "description",
name = " ",
width = "full"
},
BUFFS = {
order = 10,
type = "color",
name = L["Buffs"],
get = function(info)
local t = E.db.unitframe.colors.auraBarBuff
local d = P.unitframe.colors.auraBarBuff
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors.auraBarBuff
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end
},
DEBUFFS = {
order = 11,
type = "color",
name = L["Debuffs"],
get = function(info)
local t = E.db.unitframe.colors.auraBarDebuff
local d = P.unitframe.colors.auraBarDebuff
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors.auraBarDebuff
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end
},
auraBarTurtleColor = {
order = 12,
type = "color",
name = L["Turtle Color"],
get = function(info)
local t = E.db.unitframe.colors.auraBarTurtleColor
local d = P.unitframe.colors.auraBarTurtleColor
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors.auraBarTurtleColor
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end
}
}
},
reactionGroup = {
order = 7,
type = "group",
name = L["Reactions"],
get = function(info)
local t = E.db.unitframe.colors.reaction[info[#info]]
local d = P.unitframe.colors.reaction[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors.reaction[info[#info]]
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end,
args = {
header = {
order = 1,
type = "header",
name = L["Reactions"]
},
BAD = {
order = 2,
type = "color",
name = L["Bad"]
},
NEUTRAL = {
order = 3,
type = "color",
name = L["Neutral"]
},
GOOD = {
order = 4,
type = "color",
name = L["Good"]
}
}
},
--[[threatGroup = {
order = 8,
type = "group",
name = L["Threat"],
get = function(info)
local n = tonumber(info[#info])
local t = E.db.unitframe.colors.threat[n]
local d = P.unitframe.colors.threat[n]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local n = tonumber(info[#info])
local t = E.db.unitframe.colors.threat[n]
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end,
args = {
["0"] = {
order = 1,
type = "color",
name = L["Low Threat"]
},
["1"] = {
order = 2,
type = "color",
name = L["Overnuking"]
},
["2"] = {
order = 3,
type = "color",
name = L["Losing Threat"]
},
["3"] = {
order = 4,
type = "color",
name = L["Securely Tanking"]
}
}
},]]
healPrediction = {
order = 8,
type = "group",
name = L["Heal Prediction"],
get = function(info)
local t = E.db.unitframe.colors.healPrediction[info[#info]]
local d = P.unitframe.colors.healPrediction[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b, d.a
end,
set = function(info, r, g, b, a)
local t = E.db.unitframe.colors.healPrediction[info[#info]]
t.r, t.g, t.b, t.a = r, g, b, a
UF:Update_AllFrames()
end,
args = {
header = {
order = 1,
type = "header",
name = L["Heal Prediction"]
},
personal = {
order = 2,
type = "color",
name = L["Personal"],
hasAlpha = true
},
others = {
order = 3,
type = "color",
name = L["Others"],
hasAlpha = true
},
maxOverflow = {
order = 4,
type = "range",
name = L["Max Overflow"],
desc = L["Max amount of overflow allowed to extend past the end of the health bar."],
isPercent = true,
min = 0, max = 1, step = 0.01,
get = function(info) return E.db.unitframe.colors.healPrediction.maxOverflow end,
set = function(info, value) E.db.unitframe.colors.healPrediction.maxOverflow = value UF:Update_AllFrames() end
}
}
},
debuffHighlight = {
order = 9,
type = "group",
name = L["Debuff Highlighting"],
get = function(info)
local t = E.db.unitframe.colors.debuffHighlight[info[#info]]
local d = P.unitframe.colors.debuffHighlight[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b, d.a
end,
set = function(info, r, g, b, a)
local t = E.db.unitframe.colors.debuffHighlight[info[#info]]
t.r, t.g, t.b, t.a = r, g, b, a
UF:Update_AllFrames()
end,
args = {
header = {
order = 1,
type = "header",
name = L["Debuff Highlighting"]
},
debuffHighlighting = {
order = 2,
type = "select",
name = L["Debuff Highlighting"],
desc = L["Color the unit healthbar if there is a debuff that can be dispelled by you."],
get = function(info) return E.db.unitframe[info[#info]] end,
set = function(info, value) E.db.unitframe[info[#info]] = value end,
values = {
["NONE"] = L["NONE"],
["GLOW"] = L["Glow"],
["FILL"] = L["Fill"]
}
},
blendMode = {
order = 3,
type = "select",
name = L["Blend Mode"],
values = blendModeValues,
get = function(info) return E.db.unitframe.colors.debuffHighlight[info[#info]] end,
set = function(info, value) E.db.unitframe.colors.debuffHighlight[info[#info]] = value UF:Update_AllFrames() end
},
spacer1 = {
order = 4,
type = "description",
name = " ",
width = "full"
},
Magic = {
order = 5,
type = "color",
name = L["Magic Effect"],
hasAlpha = true
},
Curse = {
order = 6,
type = "color",
name = L["Curse Effect"],
hasAlpha = true
},
Disease = {
order = 7,
type = "color",
name = L["Disease Effect"],
hasAlpha = true
},
Poison = {
order = 8,
type = "color",
name = L["Poison Effect"],
hasAlpha = true
}
}
}
}
},
disabledBlizzardFrames = {
order = 4,
type = "group",
name = L["Disabled Blizzard Frames"],
get = function(info) return E.private.unitframe.disabledBlizzardFrames[info[#info]] end,
set = function(info, value) E.private.unitframe.disabledBlizzardFrames[info[#info]] = value E:StaticPopup_Show("PRIVATE_RL") end,
args = {
header = {
order = 1,
type = "header",
name = L["Disabled Blizzard Frames"]
},
player = {
order = 2,
type = "toggle",
name = L["Player"],
desc = L["Disables the player and pet unitframes."]
},
target = {
order = 3,
type = "toggle",
name = L["TARGET"],
desc = L["Disables the target and target of target unitframes."]
},
focus = {
order = 4,
type = "toggle",
name = L["Focus"],
desc = L["Disables the focus and target of focus unitframes."]
},
boss = {
order = 5,
type = "toggle",
name = L["BOSS"]
},
arena = {
order = 6,
type = "toggle",
name = L["Arena"]
},
party = {
order = 7,
type = "toggle",
name = L["PARTY"]
},
raid = {
order = 8,
type = "toggle",
name = L["RAID"]
}
}
},
raidDebuffIndicator = {
order = 5,
type = "group",
name = L["RaidDebuff Indicator"],
args = {
header = {
order = 1,
type = "header",
name = L["RaidDebuff Indicator"],
},
instanceFilter = {
order = 2,
type = "select",
name = L["Dungeon & Raid Filter"],
values = function()
local filters = {}
local list = E.global.unitframe.aurafilters
if not list then return end
for filter in pairs(list) do
filters[filter] = filter
end
return filters
end,
get = function(info) return E.global.unitframe.raidDebuffIndicator.instanceFilter end,
set = function(info, value) E.global.unitframe.raidDebuffIndicator.instanceFilter = value UF:UpdateAllHeaders() end
},
otherFilter = {
order = 3,
type = "select",
name = L["Other Filter"],
values = function()
local filters = {}
local list = E.global.unitframe.aurafilters
if not list then return end
for filter in pairs(list) do
filters[filter] = filter
end
return filters
end,
get = function(info) return E.global.unitframe.raidDebuffIndicator.otherFilter end,
set = function(info, value) E.global.unitframe.raidDebuffIndicator.otherFilter = value UF:UpdateAllHeaders() end
}
}
}
}
}
}
}
--Player
E.Options.args.unitframe.args.player = {
order = 300,
type = "group",
name = L["Player"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.player[info[#info]] end,
set = function(info, value) E.db.unitframe.units.player[info[#info]] = value UF:CreateAndUpdateUF("player") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"],
set = function(info, value)
E.db.unitframe.units.player[info[#info]] = value
UF:CreateAndUpdateUF("player")
end
},
showAuras = {
order = 2,
type = "execute",
name = L["Show Auras"],
func = function()
local frame = ElvUF_Player
if frame.forceShowAuras then
frame.forceShowAuras = nil
else
frame.forceShowAuras = true
end
UF:CreateAndUpdateUF("player")
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["Player"], nil, {unit="player", mover="Player Frame"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = UF.units,
set = function(info, value) UF:MergeUnitSettings(value, "player") end
},
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 2,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1,
set = function(info, value)
if E.db.unitframe.units.player.castbar.width == E.db.unitframe.units.player[info[#info]] then
E.db.unitframe.units.player.castbar.width = value
end
E.db.unitframe.units.player[info[#info]] = value
UF:CreateAndUpdateUF("player")
end
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
hideonnpc = {
order = 4,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.player.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.player.power.hideonnpc = value UF:CreateAndUpdateUF("player") end
},
threatStyle = {
order = 5,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
smartAuraPosition = {
order = 6,
type = "select",
name = L["Smart Aura Position"],
desc = L["Will show Buffs in the Debuff position when there are no Debuffs active, or vice versa."],
values = smartAuraPositionValues
},
orientation = {
order = 7,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 10,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 11,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
healPredction = GetOptionsTable_HealPrediction(UF.CreateAndUpdateUF, "player"),
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateUF, "player"),
health = GetOptionsTable_Health(false, UF.CreateAndUpdateUF, "player"),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateUF, "player"),
power = GetOptionsTable_Power(true, UF.CreateAndUpdateUF, "player", nil, true),
name = GetOptionsTable_Name(UF.CreateAndUpdateUF, "player"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateUF, "player"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateUF, "player"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateUF, "player"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateUF, "player"),
castbar = GetOptionsTable_Castbar(true, UF.CreateAndUpdateUF, "player"),
aurabar = GetOptionsTable_AuraBars(UF.CreateAndUpdateUF, "player"),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateUF, "player"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateUF, "player"),
classbar = {
order = 750,
type = "group",
name = L["Classbar"],
get = function(info) return E.db.unitframe.units.player.classbar[info[#info]] end,
set = function(info, value) E.db.unitframe.units.player.classbar[info[#info]] = value UF:CreateAndUpdateUF("player") end,
args = {
header = {
order = 1,
type = "header",
name = L["Classbar"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = ((E.db.unitframe.thinBorders or E.PixelMode) and 3 or 7),
max = (E.db.unitframe.units.player.classbar.detachFromFrame and 300 or 30),
step = 1,
disabled = function() return not E.db.unitframe.units.player.classbar.enable end
},
fill = {
order = 4,
type = "select",
name = L["Fill"],
values = {
["fill"] = L["Filled"],
["spaced"] = L["Spaced"]
},
disabled = function() return not E.db.unitframe.units.player.classbar.enable end
},
autoHide = {
order = 5,
type = "toggle",
name = L["Auto-Hide"],
disabled = function() return not E.db.unitframe.units.player.classbar.enable end
},
additionalPowerText = {
order = 6,
type = "toggle",
name = L["Additional Power Text"],
hidden = function() return false end,
disabled = function() return not E.db.unitframe.units.player.classbar.enable end
},
spacer = {
order = 7,
type = "description",
name = ""
},
detachGroup = {
order = 8,
type = "group",
name = L["Detach From Frame"],
get = function(info) return E.db.unitframe.units.player.classbar[info[#info]] end,
set = function(info, value) E.db.unitframe.units.player.classbar[info[#info]] = value UF:CreateAndUpdateUF("player") end,
guiInline = true,
args = {
detachFromFrame = {
order = 1,
type = "toggle",
name = L["Enable"],
width = "full",
set = function(info, value)
if value == true then
E.Options.args.unitframe.args.player.args.classbar.args.height.max = 300
else
E.Options.args.unitframe.args.player.args.classbar.args.height.max = 30
end
E.db.unitframe.units.player.classbar[info[#info]] = value
UF:CreateAndUpdateUF("player")
end,
disabled = function() return not E.db.unitframe.units.player.classbar.enable end
},
detachedWidth = {
order = 2,
type = "range",
name = L["Detached Width"],
disabled = function() return not E.db.unitframe.units.player.classbar.detachFromFrame or not E.db.unitframe.units.player.classbar.enable end,
min = ((E.db.unitframe.thinBorders or E.PixelMode) and 3 or 7), max = 800, step = 1
},
orientation = {
order = 3,
type = "select",
name = L["Frame Orientation"],
disabled = function()
return (E.db.unitframe.units.player.classbar.fill and (E.db.unitframe.units.player.classbar.fill == "fill"))
or not E.db.unitframe.units.player.classbar.detachFromFrame
or not E.db.unitframe.units.player.classbar.enable
end,
values = {
["HORIZONTAL"] = L["Horizontal"],
["VERTICAL"] = L["Vertical"]
}
},
verticalOrientation = {
order = 4,
type = "toggle",
name = L["Vertical Fill Direction"],
disabled = function() return not E.db.unitframe.units.player.classbar.detachFromFrame or not E.db.unitframe.units.player.classbar.enable end
},
spacing = {
order = 5,
type = "range",
name = L["Spacing"],
min = ((E.db.unitframe.thinBorders or E.PixelMode) and -1 or -4), max = 20, step = 1,
disabled = function()
return E.db.unitframe.units.player.classbar.fill and (E.db.unitframe.units.player.classbar.fill == "fill")
or not E.db.unitframe.units.player.classbar.detachFromFrame
or not E.db.unitframe.units.player.classbar.enable
end
},
parent = {
order = 6,
type = "select",
name = L["Parent"],
desc = L["Choose UIPARENT to prevent it from hiding with the unitframe."],
disabled = function() return not E.db.unitframe.units.player.classbar.detachFromFrame or not E.db.unitframe.units.player.classbar.enable end,
values = {
["FRAME"] = "FRAME",
["UIPARENT"] = "UIPARENT"
}
},
strataAndLevel = {
order = 7,
type = "group",
name = L["Strata and Level"],
get = function(info) return E.db.unitframe.units.player.classbar.strataAndLevel[info[#info]] end,
set = function(info, value) E.db.unitframe.units.player.classbar.strataAndLevel[info[#info]] = value UF:CreateAndUpdateUF("player") end,
guiInline = true,
disabled = function() return not E.db.unitframe.units.player.classbar.detachFromFrame end,
hidden = function() return not E.db.unitframe.units.player.classbar.detachFromFrame end,
args = {
useCustomStrata = {
order = 1,
type = "toggle",
name = L["Use Custom Strata"],
disabled = function() return not E.db.unitframe.units.player.classbar.enable end
},
frameStrata = {
order = 2,
type = "select",
name = L["Frame Strata"],
values = {
["BACKGROUND"] = "BACKGROUND",
["LOW"] = "LOW",
["MEDIUM"] = "MEDIUM",
["HIGH"] = "HIGH",
["DIALOG"] = "DIALOG",
["TOOLTIP"] = "TOOLTIP"
},
disabled = function() return not E.db.unitframe.units.player.classbar.enable end
},
spacer = {
order = 3,
type = "description",
name = ""
},
useCustomLevel = {
order = 4,
type = "toggle",
name = L["Use Custom Level"],
disabled = function() return not E.db.unitframe.units.player.classbar.enable end
},
frameLevel = {
order = 5,
type = "range",
name = L["Frame Level"],
min = 2, max = 128, step = 1,
disabled = function() return not E.db.unitframe.units.player.classbar.enable end
}
}
}
}
}
}
},
RestIcon = {
order = 430,
type = "group",
name = L["Rest Icon"],
get = function(info) return E.db.unitframe.units.player.RestIcon[info[#info]] end,
set = function(info, value) E.db.unitframe.units.player.RestIcon[info[#info]] = value UF:CreateAndUpdateUF("player") end,
args = {
header = {
order = 1,
type = "header",
name = L["Rest Icon"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
defaultColor = {
order = 3,
type = "toggle",
name = L["Default Color"]
},
color = {
order = 4,
type = "color",
name = L["COLOR"],
hasAlpha = true,
disabled = function()
return E.db.unitframe.units.player.RestIcon.defaultColor
end,
get = function()
local c = E.db.unitframe.units.player.RestIcon.color
local d = P.unitframe.units.player.RestIcon.color
return c.r, c.g, c.b, c.a, d.r, d.g, d.b, d.a
end,
set = function(_, r, g, b, a)
local c = E.db.unitframe.units.player.RestIcon.color
c.r, c.g, c.b, c.a = r, g, b, a
UF:CreateAndUpdateUF("player")
end
},
size = {
order = 5,
type = "range",
name = L["Size"],
min = 10, max = 60, step = 1
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
min = -100, max = 100, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
min = -100, max = 100, step = 1
},
spacer2 = {
order = 8,
type = "description",
name = " "
},
anchorPoint = {
order = 9,
type = "select",
name = L["Anchor Point"],
values = positionValues
},
texture = {
order = 10,
type = "select",
sortByValue = true,
name = L["Texture"],
values = {
["CUSTOM"] = L["CUSTOM"],
["DEFAULT"] = L["DEFAULT"],
["RESTING"] = E:TextureString(E.Media.Textures.Resting, ":14"),
["RESTING1"] = E:TextureString(E.Media.Textures.Resting1, ":14")
}
},
customTexture = {
order = 11,
type = "input",
customWidth = 250,
name = L["Custom Texture"],
disabled = function()
return E.db.unitframe.units.player.RestIcon.texture ~= "CUSTOM"
end,
set = function(_, value)
E.db.unitframe.units.player.RestIcon.customTexture = (value and (not value:match("^%s-$")) and value) or nil
UF:CreateAndUpdateUF("player")
end
}
}
},
CombatIcon = {
order = 440,
type = "group",
name = L["Combat Icon"],
get = function(info) return E.db.unitframe.units.player.CombatIcon[info[#info]] end,
set = function(info, value) E.db.unitframe.units.player.CombatIcon[info[#info]] = value UF:CreateAndUpdateUF("player") end,
args = {
header = {
order = 1,
type = "header",
name = L["Combat Icon"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
defaultColor = {
order = 3,
type = "toggle",
name = L["Default Color"]
},
color = {
order = 4,
type = "color",
name = L["COLOR"],
hasAlpha = true,
disabled = function()
return E.db.unitframe.units.player.CombatIcon.defaultColor
end,
get = function()
local c = E.db.unitframe.units.player.CombatIcon.color
local d = P.unitframe.units.player.CombatIcon.color
return c.r, c.g, c.b, c.a, d.r, d.g, d.b, d.a
end,
set = function(_, r, g, b, a)
local c = E.db.unitframe.units.player.CombatIcon.color
c.r, c.g, c.b, c.a = r, g, b, a
UF:CreateAndUpdateUF("player")
end
},
size = {
order = 5,
type = "range",
name = L["Size"],
min = 10, max = 60, step = 1
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
min = -100, max = 100, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
min = -100, max = 100, step = 1
},
spacer2 = {
order = 8,
type = "description",
name = " "
},
anchorPoint = {
order = 9,
type = "select",
name = L["Anchor Point"],
values = positionValues
},
texture = {
order = 10,
type = "select",
sortByValue = true,
name = L["Texture"],
values = {
["CUSTOM"] = L["CUSTOM"],
["DEFAULT"] = L["DEFAULT"],
["COMBAT"] = E:TextureString(E.Media.Textures.Combat, ":14"),
--["PLATINUM"] = [[|TInterface\Challenges\ChallengeMode_Medal_Platinum:14|t]],
["ATTACK"] = [[|TInterface\CURSOR\Attack:14|t]],
["ALERT"] = [[|TInterface\DialogFrame\UI-Dialog-Icon-AlertNew:14|t]],
["ALERT2"] = [[|TInterface\OptionsFrame\UI-OptionsFrame-NewFeatureIcon:14|t]],
["ARTHAS"] =[[|TInterface\LFGFRAME\UI-LFR-PORTRAIT:14|t]],
["SKULL"] = [[|TInterface\LootFrame\LootPanel-Icon:14|t]]
}
},
customTexture = {
order = 11,
type = "input",
customWidth = 250,
name = L["Custom Texture"],
disabled = function()
return E.db.unitframe.units.player.CombatIcon.texture ~= "CUSTOM"
end,
set = function(_, value)
E.db.unitframe.units.player.CombatIcon.customTexture = (value and (not value:match("^%s-$")) and value) or nil
UF:CreateAndUpdateUF("player")
end
}
}
},
pvpIcon = {
order = 449,
type = "group",
name = L["PvP Icon"],
get = function(info) return E.db.unitframe.units.player.pvpIcon[info[#info]] end,
set = function(info, value) E.db.unitframe.units.player.pvpIcon[info[#info]] = value UF:CreateAndUpdateUF("player") end,
args = {
header = {
order = 1,
type = "header",
name = L["PvP Icon"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
scale = {
order = 3,
type = "range",
name = L["Scale"],
isPercent = true,
min = 0.1, max = 2, step = 0.01
},
spacer = {
order = 4,
type = "description",
name = " "
},
anchorPoint = {
order = 5,
type = "select",
name = L["Anchor Point"],
values = positionValues
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
min = -100, max = 100, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
min = -100, max = 100, step = 1
}
}
},
pvpText = {
order = 850,
type = "group",
name = L["PvP Text"],
get = function(info) return E.db.unitframe.units.player.pvp[info[#info]] end,
set = function(info, value) E.db.unitframe.units.player.pvp[info[#info]] = value UF:CreateAndUpdateUF("player") end,
args = {
header = {
order = 1,
type = "header",
name = L["PvP Text"]
},
position = {
order = 2,
type = "select",
name = L["Position"],
values = positionValues
},
text_format = {
order = 100,
type = "input",
name = L["Text Format"],
desc = L["TEXT_FORMAT_DESC"],
width = "full"
}
}
},
raidRoleIcons = {
order = 703,
type = "group",
name = L["RL / ML Icons"],
get = function(info) return E.db.unitframe.units.player.raidRoleIcons[info[#info]] end,
set = function(info, value) E.db.unitframe.units.player.raidRoleIcons[info[#info]] = value UF:CreateAndUpdateUF("player") end,
args = {
header = {
order = 1,
type = "header",
name = L["RL / ML Icons"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
position = {
order = 3,
type = "select",
name = L["Position"],
values = {
["TOPLEFT"] = "TOPLEFT",
["TOPRIGHT"] = "TOPRIGHT"
}
}
}
}
}
}
if C_Player:IsHero() then
E.Options.args.unitframe.args.player.args.energy = GetOptionsTable_Energy(true, UF.CreateAndUpdateUF, "player", nil, true)
E.Options.args.unitframe.args.player.args.rage = GetOptionsTable_Rage(true, UF.CreateAndUpdateUF, "player", nil, true)
end
--Target Frame
E.Options.args.unitframe.args.target = {
order = 400,
type = "group",
name = L["TARGET"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.target[info[#info]] end,
set = function(info, value) E.db.unitframe.units.target[info[#info]] = value UF:CreateAndUpdateUF("target") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
showAuras = {
order = 2,
type = "execute",
name = L["Show Auras"],
func = function()
local frame = ElvUF_Target
if frame.forceShowAuras then
frame.forceShowAuras = nil
else
frame.forceShowAuras = true
end
UF:CreateAndUpdateUF("target")
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["TARGET"], nil, {unit="target", mover="Target Frame"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = UF.units,
set = function(info, value) UF:MergeUnitSettings(value, "target") end
},
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 6,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1,
set = function(info, value)
if E.db.unitframe.units.target.castbar.width == E.db.unitframe.units.target[info[#info]] then
E.db.unitframe.units.target.castbar.width = value
end
E.db.unitframe.units.target[info[#info]] = value
UF:CreateAndUpdateUF("target")
end
},
height = {
order = 7,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
hideonnpc = {
order = 8,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.target.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.target.power.hideonnpc = value UF:CreateAndUpdateUF("target") end
},
middleClickFocus = {
order = 9,
type = "toggle",
name = L["Middle Click - Set Focus"],
desc = L["Middle clicking the unit frame will cause your focus to match the unit."],
disabled = function() return IsAddOnLoaded("Clique") end
},
threatStyle = {
order = 10,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
smartAuraPosition = {
order = 11,
type = "select",
name = L["Smart Aura Position"],
desc = L["Will show Buffs in the Debuff position when there are no Debuffs active, or vice versa."],
values = smartAuraPositionValues
},
orientation = {
order = 12,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 15,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 16,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
healPredction = GetOptionsTable_HealPrediction(UF.CreateAndUpdateUF, "target"),
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateUF, "target"),
health = GetOptionsTable_Health(false, UF.CreateAndUpdateUF, "target"),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateUF, "target"),
power = GetOptionsTable_Power(true, UF.CreateAndUpdateUF, "target", nil, true),
name = GetOptionsTable_Name(UF.CreateAndUpdateUF, "target"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateUF, "target"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateUF, "target"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateUF, "target"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateUF, "target"),
castbar = GetOptionsTable_Castbar(false, UF.CreateAndUpdateUF, "target"),
aurabar = GetOptionsTable_AuraBars(UF.CreateAndUpdateUF, "target"),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateUF, "target"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateUF, "target"),
GPSArrow = GetOptionsTableForNonGroup_GPS("target"),
combobar = {
order = 850,
type = "group",
name = L["COMBO_POINTS"],
get = function(info) return E.db.unitframe.units.target.combobar[info[#info]] end,
set = function(info, value) E.db.unitframe.units.target.combobar[info[#info]] = value UF:CreateAndUpdateUF("target") end,
args = {
header = {
order = 1,
type = "header",
name = L["COMBO_POINTS"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = ((E.db.unitframe.thinBorders or E.PixelMode) and 3 or 7),
max = (E.db.unitframe.units.target.combobar.detachFromFrame and 300 or 30),
step = 1,
disabled = function() return not E.db.unitframe.units.target.combobar.enable end
},
fill = {
order = 4,
type = "select",
name = L["Fill"],
values = {
["fill"] = L["Filled"],
["spaced"] = L["Spaced"]
},
disabled = function() return not E.db.unitframe.units.target.combobar.enable end
},
autoHide = {
order = 5,
type = "toggle",
name = L["Auto-Hide"],
disabled = function() return not E.db.unitframe.units.target.combobar.enable end
},
spacer = {
order = 6,
type = "description",
name = ""
},
detachGroup = {
order = 8,
type = "group",
name = L["Detach From Frame"],
get = function(info) return E.db.unitframe.units.target.combobar[info[#info]] end,
set = function(info, value) E.db.unitframe.units.target.combobar[info[#info]] = value UF:CreateAndUpdateUF("target") end,
guiInline = true,
args = {
detachFromFrame = {
order = 1,
type = "toggle",
name = L["Enable"],
width = "full",
set = function(info, value)
if value == true then
E.Options.args.unitframe.args.target.args.combobar.args.height.max = 300
else
E.Options.args.unitframe.args.target.args.combobar.args.height.max = 30
end
E.db.unitframe.units.target.combobar[info[#info]] = value
UF:CreateAndUpdateUF("target")
end,
disabled = function() return not E.db.unitframe.units.target.combobar.enable end
},
detachedWidth = {
order = 2,
type = "range",
name = L["Detached Width"],
disabled = function() return not E.db.unitframe.units.target.combobar.detachFromFrame or not E.db.unitframe.units.target.combobar.enable end,
min = ((E.db.unitframe.thinBorders or E.PixelMode) and 3 or 7), max = 800, step = 1
},
orientation = {
order = 3,
type = "select",
name = L["Frame Orientation"],
disabled = function()
return (E.db.unitframe.units.target.combobar.fill and (E.db.unitframe.units.target.combobar.fill == "fill"))
or not E.db.unitframe.units.target.combobar.detachFromFrame
or not E.db.unitframe.units.target.combobar.enable
end,
values = {
["HORIZONTAL"] = L["Horizontal"],
["VERTICAL"] = L["Vertical"]
}
},
spacer = {
order = 4,
type = "description",
name = ""
},
spacing = {
order = 5,
type = "range",
name = L["Spacing"],
min = ((E.db.unitframe.thinBorders or E.PixelMode) and -1 or -4), max = 20, step = 1,
disabled = function()
return (E.db.unitframe.units.target.combobar.fill and (E.db.unitframe.units.target.combobar.fill == "fill"))
or not E.db.unitframe.units.target.combobar.detachFromFrame
or not E.db.unitframe.units.target.combobar.enable
end
},
parent = {
order = 6,
type = "select",
name = L["Parent"],
desc = L["Choose UIPARENT to prevent it from hiding with the unitframe."],
disabled = function() return not E.db.unitframe.units.target.combobar.detachFromFrame or not E.db.unitframe.units.target.combobar.enable end,
values = {
["FRAME"] = "FRAME",
["UIPARENT"] = "UIPARENT"
}
},
strataAndLevel = {
order = 7,
type = "group",
name = L["Strata and Level"],
get = function(info) return E.db.unitframe.units.target.combobar.strataAndLevel[info[#info]] end,
set = function(info, value) E.db.unitframe.units.target.combobar.strataAndLevel[info[#info]] = value UF:CreateAndUpdateUF("target") end,
guiInline = true,
disabled = function() return not E.db.unitframe.units.target.combobar.detachFromFrame end,
hidden = function() return not E.db.unitframe.units.target.combobar.detachFromFrame end,
args = {
useCustomStrata = {
order = 1,
type = "toggle",
name = L["Use Custom Strata"],
disabled = function() return not E.db.unitframe.units.target.combobar.enable end
},
frameStrata = {
order = 2,
type = "select",
name = L["Frame Strata"],
values = {
["BACKGROUND"] = "BACKGROUND",
["LOW"] = "LOW",
["MEDIUM"] = "MEDIUM",
["HIGH"] = "HIGH",
["DIALOG"] = "DIALOG",
["TOOLTIP"] = "TOOLTIP"
},
disabled = function() return not E.db.unitframe.units.target.combobar.enable end
},
spacer = {
order = 3,
type = "description",
name = ""
},
useCustomLevel = {
order = 4,
type = "toggle",
name = L["Use Custom Level"],
disabled = function() return not E.db.unitframe.units.target.combobar.enable end
},
frameLevel = {
order = 5,
type = "range",
name = L["Frame Level"],
min = 2, max = 128, step = 1,
disabled = function() return not E.db.unitframe.units.target.combobar.enable end
}
}
}
}
}
}
},
pvpIcon = {
order = 449,
type = "group",
name = L["PvP Icon"],
get = function(info) return E.db.unitframe.units.target.pvpIcon[info[#info]] end,
set = function(info, value) E.db.unitframe.units.target.pvpIcon[info[#info]] = value UF:CreateAndUpdateUF("target") end,
args = {
header = {
order = 1,
type = "header",
name = L["PvP Icon"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
scale = {
order = 3,
type = "range",
name = L["Scale"],
isPercent = true,
min = 0.1, max = 2, step = 0.01
},
spacer = {
order = 4,
type = "description",
name = " "
},
anchorPoint = {
order = 5,
type = "select",
name = L["Anchor Point"],
values = positionValues
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
min = -100, max = 100, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
min = -100, max = 100, step = 1
}
}
}
}
}
--TargetTarget
E.Options.args.unitframe.args.targettarget = {
order = 500,
type = "group",
name = L["TargetTarget"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.targettarget[info[#info]] end,
set = function(info, value) E.db.unitframe.units.targettarget[info[#info]] = value UF:CreateAndUpdateUF("targettarget") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
showAuras = {
order = 2,
type = "execute",
name = L["Show Auras"],
func = function()
local frame = ElvUF_TargetTarget
if frame.forceShowAuras then
frame.forceShowAuras = nil
else
frame.forceShowAuras = true
end
UF:CreateAndUpdateUF("targettarget")
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["TargetTarget"], nil, {unit="targettarget", mover="TargetTarget Frame"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = UF.units,
set = function(info, value) UF:MergeUnitSettings(value, "targettarget") end
},
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 2,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
hideonnpc = {
order = 4,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.targettarget.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.targettarget.power.hideonnpc = value UF:CreateAndUpdateUF("targettarget") end
},
threatStyle = {
order = 5,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
smartAuraPosition = {
order = 6,
type = "select",
name = L["Smart Aura Position"],
desc = L["Will show Buffs in the Debuff position when there are no Debuffs active, or vice versa."],
values = smartAuraPositionValues
},
orientation = {
order = 7,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 10,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 11,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateUF, "targettarget"),
health = GetOptionsTable_Health(false, UF.CreateAndUpdateUF, "targettarget"),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateUF, "targettarget"),
power = GetOptionsTable_Power(nil, UF.CreateAndUpdateUF, "targettarget"),
name = GetOptionsTable_Name(UF.CreateAndUpdateUF, "targettarget"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateUF, "targettarget"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateUF, "targettarget"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateUF, "targettarget"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateUF, "targettarget"),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateUF, "targettarget"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateUF, "targettarget")
}
}
--TargetTargetTarget
E.Options.args.unitframe.args.targettargettarget = {
order = 550,
type = "group",
name = L["TargetTargetTarget"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.targettargettarget[info[#info]] end,
set = function(info, value) E.db.unitframe.units.targettargettarget[info[#info]] = value UF:CreateAndUpdateUF("targettargettarget") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
showAuras = {
order = 2,
type = "execute",
name = L["Show Auras"],
func = function()
local frame = ElvUF_TargetTargetTarget
if frame.forceShowAuras then
frame.forceShowAuras = nil
else
frame.forceShowAuras = true
end
UF:CreateAndUpdateUF("targettargettarget")
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["TargetTargetTarget"], nil, {unit="targettargettarget", mover="TargetTargetTarget Frame"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = UF.units,
set = function(info, value) UF:MergeUnitSettings(value, "targettargettarget") end
},
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 2,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
hideonnpc = {
order = 4,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.targettargettarget.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.targettargettarget.power.hideonnpc = value UF:CreateAndUpdateUF("targettargettarget") end
},
threatStyle = {
order = 5,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
smartAuraPosition = {
order = 6,
type = "select",
name = L["Smart Aura Position"],
desc = L["Will show Buffs in the Debuff position when there are no Debuffs active, or vice versa."],
values = smartAuraPositionValues
},
orientation = {
order = 7,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 10,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 11,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateUF, "targettargettarget"),
health = GetOptionsTable_Health(false, UF.CreateAndUpdateUF, "targettargettarget"),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateUF, "targettargettarget"),
power = GetOptionsTable_Power(nil, UF.CreateAndUpdateUF, "targettargettarget"),
name = GetOptionsTable_Name(UF.CreateAndUpdateUF, "targettargettarget"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateUF, "targettargettarget"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateUF, "targettargettarget"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateUF, "targettargettarget"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateUF, "targettargettarget"),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateUF, "targettargettarget"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateUF, "targettargettarget")
}
}
--Focus
E.Options.args.unitframe.args.focus = {
order = 600,
type = "group",
name = L["Focus"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.focus[info[#info]] end,
set = function(info, value) E.db.unitframe.units.focus[info[#info]] = value UF:CreateAndUpdateUF("focus") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
showAuras = {
order = 2,
type = "execute",
name = L["Show Auras"],
func = function()
local frame = ElvUF_Focus
if frame.forceShowAuras then
frame.forceShowAuras = nil
else
frame.forceShowAuras = true
end
UF:CreateAndUpdateUF("focus")
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["Focus"], nil, {unit="focus", mover="Focus Frame"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = UF.units,
set = function(info, value) UF:MergeUnitSettings(value, "focus") end
},
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 2,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
hideonnpc = {
order = 4,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.focus.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.focus.power.hideonnpc = value UF:CreateAndUpdateUF("focus") end
},
threatStyle = {
order = 5,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
smartAuraPosition = {
order = 6,
type = "select",
name = L["Smart Aura Position"],
desc = L["Will show Buffs in the Debuff position when there are no Debuffs active, or vice versa."],
values = smartAuraPositionValues
},
orientation = {
order = 7,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 10,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 11,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
healPredction = GetOptionsTable_HealPrediction(UF.CreateAndUpdateUF, "focus"),
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateUF, "focus"),
health = GetOptionsTable_Health(false, UF.CreateAndUpdateUF, "focus"),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateUF, "focus"),
power = GetOptionsTable_Power(nil, UF.CreateAndUpdateUF, "focus"),
name = GetOptionsTable_Name(UF.CreateAndUpdateUF, "focus"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateUF, "focus"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateUF, "focus"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateUF, "focus"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateUF, "focus"),
castbar = GetOptionsTable_Castbar(false, UF.CreateAndUpdateUF, "focus"),
aurabar = GetOptionsTable_AuraBars(UF.CreateAndUpdateUF, "focus"),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateUF, "focus"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateUF, "focus"),
GPSArrow = GetOptionsTableForNonGroup_GPS("focus")
}
}
--Focus Target
E.Options.args.unitframe.args.focustarget = {
order = 700,
type = "group",
name = L["FocusTarget"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.focustarget[info[#info]] end,
set = function(info, value) E.db.unitframe.units.focustarget[info[#info]] = value UF:CreateAndUpdateUF("focustarget") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
showAuras = {
order = 2,
type = "execute",
name = L["Show Auras"],
func = function()
local frame = ElvUF_FocusTarget
if frame.forceShowAuras then
frame.forceShowAuras = nil
else
frame.forceShowAuras = true
end
UF:CreateAndUpdateUF("focustarget")
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["FocusTarget"], nil, {unit="focustarget", mover="FocusTarget Frame"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = UF.units,
set = function(info, value) UF:MergeUnitSettings(value, "focustarget") end
},
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 6,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1
},
height = {
order = 7,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
hideonnpc = {
order = 9,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.focustarget.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.focustarget.power.hideonnpc = value UF:CreateAndUpdateUF("focustarget") end
},
threatStyle = {
order = 10,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
smartAuraPosition = {
order = 11,
type = "select",
name = L["Smart Aura Position"],
desc = L["Will show Buffs in the Debuff position when there are no Debuffs active, or vice versa."],
values = smartAuraPositionValues
},
orientation = {
order = 12,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 15,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 16,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateUF, "focustarget"),
health = GetOptionsTable_Health(false, UF.CreateAndUpdateUF, "focustarget"),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateUF, "focustarget"),
power = GetOptionsTable_Power(false, UF.CreateAndUpdateUF, "focustarget"),
name = GetOptionsTable_Name(UF.CreateAndUpdateUF, "focustarget"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateUF, "focustarget"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateUF, "focustarget"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateUF, "focustarget"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateUF, "focustarget"),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateUF, "focustarget"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateUF, "focustarget")
}
}
--Pet
E.Options.args.unitframe.args.pet = {
order = 800,
type = "group",
name = L["PET"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.pet[info[#info]] end,
set = function(info, value) E.db.unitframe.units.pet[info[#info]] = value UF:CreateAndUpdateUF("pet") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
showAuras = {
order = 2,
type = "execute",
name = L["Show Auras"],
func = function()
local frame = ElvUF_Pet
if frame.forceShowAuras then
frame.forceShowAuras = nil
else
frame.forceShowAuras = true
end
UF:CreateAndUpdateUF("pet")
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["PET"], nil, {unit="pet", mover="Pet Frame"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = UF.units,
set = function(info, value) UF:MergeUnitSettings(value, "pet") end
},
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 2,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
hideonnpc = {
order = 4,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.pet.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.pet.power.hideonnpc = value UF:CreateAndUpdateUF("pet") end
},
threatStyle = {
order = 5,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
smartAuraPosition = {
order = 6,
type = "select",
name = L["Smart Aura Position"],
desc = L["Will show Buffs in the Debuff position when there are no Debuffs active, or vice versa."],
values = smartAuraPositionValues
},
orientation = {
order = 7,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 10,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 11,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
buffIndicator = {
order = 600,
type = "group",
name = L["Buff Indicator"],
get = function(info) return E.db.unitframe.units.pet.buffIndicator[info[#info]] end,
set = function(info, value) E.db.unitframe.units.pet.buffIndicator[info[#info]] = value UF:CreateAndUpdateUF("pet") end,
args = {
header = {
order = 1,
type = "header",
name = L["Buff Indicator"],
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
size = {
order = 3,
type = "range",
name = L["Size"],
desc = L["Size of the indicator icon."],
min = 4, max = 50, step = 1
},
fontSize = {
order = 4,
type = "range",
name = L["FONT_SIZE"],
min = 7, max = 22, step = 1
}
}
},
healPredction = GetOptionsTable_HealPrediction(UF.CreateAndUpdateUF, "pet"),
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateUF, "pet"),
health = GetOptionsTable_Health(false, UF.CreateAndUpdateUF, "pet"),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateUF, "pet"),
power = GetOptionsTable_Power(false, UF.CreateAndUpdateUF, "pet"),
name = GetOptionsTable_Name(UF.CreateAndUpdateUF, "pet"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateUF, "pet"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateUF, "pet"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateUF, "pet"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateUF, "pet"),
castbar = GetOptionsTable_Castbar(false, UF.CreateAndUpdateUF, "pet"),
aurabar = GetOptionsTable_AuraBars(UF.CreateAndUpdateUF, "pet"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateUF, "pet"),
happiness = {
order = 700,
type = "group",
name = HAPPINESS,
get = function(info) return E.db.unitframe.units.pet.happiness[info[#info]] end,
set = function(info, value) E.db.unitframe.units.pet.happiness[info[#info]] = value; UF:CreateAndUpdateUF("pet") end,
disabled = false,
args = {
header = {
order = 1,
type = "header",
name = L["HAPPINESS"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
autoHide = {
order = 3,
type = "toggle",
name = L["Auto-Hide"]
},
width = {
order = 4,
type = "range",
name = L["Size"],
min = 5, max = 40, step = 1
}
}
}
}
}
--Pet Target
E.Options.args.unitframe.args.pettarget = {
order = 900,
type = "group",
name = L["PetTarget"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.pettarget[info[#info]] end,
set = function(info, value) E.db.unitframe.units.pettarget[info[#info]] = value UF:CreateAndUpdateUF("pettarget") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
showAuras = {
order = 2,
type = "execute",
name = L["Show Auras"],
func = function()
local frame = ElvUF_PetTarget
if frame.forceShowAuras then
frame.forceShowAuras = nil
else
frame.forceShowAuras = true
end
UF:CreateAndUpdateUF("pettarget")
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["PetTarget"], nil, {unit="pettarget", mover="PetTarget Frame"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = UF.units,
set = function(info, value) UF:MergeUnitSettings(value, "pettarget") end
},
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 2,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
hideonnpc = {
order = 4,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.pettarget.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.pettarget.power.hideonnpc = value UF:CreateAndUpdateUF("pettarget") end
},
threatStyle = {
order = 5,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
smartAuraPosition = {
order = 6,
type = "select",
name = L["Smart Aura Position"],
desc = L["Will show Buffs in the Debuff position when there are no Debuffs active, or vice versa."],
values = smartAuraPositionValues
},
orientation = {
order = 7,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 10,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 11,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateUF, "pettarget"),
health = GetOptionsTable_Health(false, UF.CreateAndUpdateUF, "pettarget"),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateUF, "pettarget"),
power = GetOptionsTable_Power(false, UF.CreateAndUpdateUF, "pettarget"),
name = GetOptionsTable_Name(UF.CreateAndUpdateUF, "pettarget"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateUF, "pettarget"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateUF, "pettarget"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateUF, "pettarget"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateUF, "pettarget"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateUF, "pettarget")
}
}
--Boss Frames
E.Options.args.unitframe.args.boss = {
order = 1000,
type = "group",
name = L["BOSS"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.boss[info[#info]] end,
set = function(info, value) E.db.unitframe.units.boss[info[#info]] = value UF:CreateAndUpdateUFGroup("boss", MAX_BOSS_FRAMES) end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
displayFrames = {
order = 2,
type = "execute",
name = L["Display Frames"],
desc = L["Force the frames to show, they will act as if they are the player frame."],
func = function() UF:ToggleForceShowGroupFrames("boss", _G.MAX_BOSS_FRAMES) end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["BOSS"], nil, {unit="boss", mover="Boss Frames"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = {
["boss"] = "boss",
["arena"] = "arena"
},
set = function(info, value) UF:MergeUnitSettings(value, "boss") end
},
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 2,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1,
set = function(info, value)
if E.db.unitframe.units.boss.castbar.width == E.db.unitframe.units.boss[info[#info]] then
E.db.unitframe.units.boss.castbar.width = value
end
E.db.unitframe.units.boss[info[#info]] = value
UF:CreateAndUpdateUFGroup("boss", MAX_BOSS_FRAMES)
end
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
hideonnpc = {
order = 4,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.boss.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.boss.power.hideonnpc = value UF:CreateAndUpdateUFGroup("boss", MAX_BOSS_FRAMES) end
},
growthDirection = {
order = 5,
type = "select",
name = L["Growth Direction"],
values = {
["UP"] = L["Bottom to Top"],
["DOWN"] = L["Top to Bottom"],
["LEFT"] = L["Right to Left"],
["RIGHT"] = L["Left to Right"]
}
},
spacing = {
order = 6,
type = "range",
name = L["Spacing"],
min = 0, max = 400, step = 1
},
threatStyle = {
order = 7,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
smartAuraPosition = {
order = 8,
type = "select",
name = L["Smart Aura Position"],
desc = L["Will show Buffs in the Debuff position when there are no Debuffs active, or vice versa."],
values = smartAuraPositionValues
},
orientation = {
order = 9,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 11,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 12,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES),
health = GetOptionsTable_Health(false, UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES),
power = GetOptionsTable_Power(false, UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES),
name = GetOptionsTable_Name(UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES),
castbar = GetOptionsTable_Castbar(false, UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateUFGroup, "boss", MAX_BOSS_FRAMES)
}
}
--Arena Frames
E.Options.args.unitframe.args.arena = {
order = 1100,
type = "group",
name = L["ARENA"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.arena[info[#info]] end,
set = function(info, value) E.db.unitframe.units.arena[info[#info]] = value UF:CreateAndUpdateUFGroup("arena", 5) end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
displayFrames = {
order = 2,
type = "execute",
name = L["Display Frames"],
desc = L["Force the frames to show, they will act as if they are the player frame."],
func = function() UF:ToggleForceShowGroupFrames("arena", 5) end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["ARENA"], nil, {unit="arena", mover="Arena Frames"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = {
["boss"] = "boss",
["arena"] = "arena"
},
set = function(info, value) UF:MergeUnitSettings(value, "arena") end
},
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 2,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1,
set = function(info, value)
if E.db.unitframe.units.arena.castbar.width == E.db.unitframe.units.arena[info[#info]] then
E.db.unitframe.units.arena.castbar.width = value
end
E.db.unitframe.units.arena[info[#info]] = value
UF:CreateAndUpdateUFGroup("arena", 5)
end
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
hideonnpc = {
order = 4,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.arena.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.arena.power.hideonnpc = value UF:CreateAndUpdateUFGroup("arena", 5) end
},
growthDirection = {
order = 5,
type = "select",
name = L["Growth Direction"],
values = {
["UP"] = L["Bottom to Top"],
["DOWN"] = L["Top to Bottom"],
["LEFT"] = L["Right to Left"],
["RIGHT"] = L["Left to Right"]
}
},
spacing = {
order = 6,
type = "range",
name = L["Spacing"],
min = 0, max = 400, step = 1
},
smartAuraPosition = {
order = 8,
type = "select",
name = L["Smart Aura Position"],
desc = L["Will show Buffs in the Debuff position when there are no Debuffs active, or vice versa."],
values = smartAuraPositionValues
},
orientation = {
order = 9,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = {
--["AUTOMATIC"] = L["Automatic"], not sure if i will use this yet
["LEFT"] = L["Left"],
--["MIDDLE"] = L["Middle"], --no way to handle this with trinket
["RIGHT"] = L["Right"]
}
},
spacer = {
order = 10,
type = "description",
name = " "
},
disableMouseoverGlow = {
order = 11,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 12,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
pvpTrinket = {
order = 750,
type = "group",
name = L["PVP Trinket"],
get = function(info) return E.db.unitframe.units.arena.pvpTrinket[info[#info]] end,
set = function(info, value) E.db.unitframe.units.arena.pvpTrinket[info[#info]] = value UF:CreateAndUpdateUFGroup("arena", 5) end,
args = {
header = {
order = 1,
type = "header",
name = L["PVP Trinket"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
position = {
order = 3,
type = "select",
name = L["Position"],
values = {
["LEFT"] = L["Left"],
["RIGHT"] = L["Right"]
}
},
size = {
order = 4,
type = "range",
name = L["Size"],
min = 10, max = 60, step = 1
},
xOffset = {
order = 5,
type = "range",
name = L["X-Offset"],
min = -60, max = 60, step = 1
},
yOffset = {
order = 6,
type = "range",
name = L["Y-Offset"],
min = -60, max = 60, step = 1
}
}
},
healPredction = GetOptionsTable_HealPrediction(UF.CreateAndUpdateUFGroup, "arena", 5),
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateUFGroup, "arena", 5),
health = GetOptionsTable_Health(false, UF.CreateAndUpdateUFGroup, "arena", 5),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateUFGroup, "arena", 5),
power = GetOptionsTable_Power(false, UF.CreateAndUpdateUFGroup, "arena", 5),
name = GetOptionsTable_Name(UF.CreateAndUpdateUFGroup, "arena", 5),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateUFGroup, "arena", 5),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateUFGroup, "arena", 5),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateUFGroup, "arena", 5),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateUFGroup, "arena", 5),
castbar = GetOptionsTable_Castbar(false, UF.CreateAndUpdateUFGroup, "arena", 5),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateUFGroup, "arena", 5)
}
}
--Party Frames
E.Options.args.unitframe.args.party = {
order = 1200,
type = "group",
name = L["PARTY"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.party[info[#info]] end,
set = function(info, value) E.db.unitframe.units.party[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
configureToggle = {
order = 2,
type = "execute",
name = L["Display Frames"],
func = function()
UF:HeaderConfig(ElvUF_Party, ElvUF_Party.forceShow ~= true or nil)
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["PARTY"], nil, {unit="party", mover="Party Frames"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = {
["raid"] = L["RAID"],
["raid40"] = L["Raid-40"]
},
set = function(info, value) UF:MergeUnitSettings(value, "party", true) end
},
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateHeaderGroup, "party"),
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
hideonnpc = {
order = 3,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.party.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.party.power.hideonnpc = value UF:CreateAndUpdateHeaderGroup("party") end
},
threatStyle = {
order = 5,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
orientation = {
order = 7,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 8,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 9,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
},
positionsGroup = {
order = 100,
name = L["Size and Positions"],
type = "group",
guiInline = true,
set = function(info, value) E.db.unitframe.units.party[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party", nil, nil, true) end,
args = {
width = {
order = 1,
type = "range",
name = L["Width"],
min = 10, max = 500, step = 1,
set = function(info, value) E.db.unitframe.units.party[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party") end
},
height = {
order = 2,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1,
set = function(info, value) E.db.unitframe.units.party[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party") end
},
spacer = {
order = 3,
type = "description",
name = "",
width = "full"
},
growthDirection = {
order = 4,
type = "select",
name = L["Growth Direction"],
desc = L["Growth direction from the first unitframe."],
values = growthDirectionValues
},
numGroups = {
order = 5,
type = "range",
name = L["Number of Groups"],
min = 1, max = 8, step = 1,
set = function(info, value)
E.db.unitframe.units.party[info[#info]] = value
UF:CreateAndUpdateHeaderGroup("party")
if ElvUF_Party.isForced then
UF:HeaderConfig(ElvUF_Party)
UF:HeaderConfig(ElvUF_Party, true)
end
end
},
groupsPerRowCol = {
order = 6,
type = "range",
name = L["Groups Per Row/Column"],
min = 1, max = 8, step = 1,
set = function(info, value)
E.db.unitframe.units.party[info[#info]] = value
UF:CreateAndUpdateHeaderGroup("party")
if ElvUF_Party.isForced then
UF:HeaderConfig(ElvUF_Party)
UF:HeaderConfig(ElvUF_Party, true)
end
end
},
horizontalSpacing = {
order = 7,
type = "range",
name = L["Horizontal Spacing"],
min = -1, max = 50, step = 1
},
verticalSpacing = {
order = 8,
type = "range",
name = L["Vertical Spacing"],
min = -1, max = 50, step = 1
},
groupSpacing = {
order = 9,
type = "range",
name = L["Group Spacing"],
desc = L["Additional spacing between each individual group."],
min = 0, softMax = 50, step = 1
}
}
},
visibilityGroup = {
order = 200,
type = "group",
name = L["Visibility"],
guiInline = true,
set = function(info, value) E.db.unitframe.units.party[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party", nil, nil, true) end,
args = {
showPlayer = {
order = 1,
type = "toggle",
name = L["Display Player"],
desc = L["When true, the header includes the player when not in a raid."],
},
visibility = {
order = 2,
type = "input",
name = L["Visibility"],
desc = L["The following macro must be true in order for the group to be shown, in addition to any filter that may already be set."],
width = "full"
}
}
},
sortingGroup = {
order = 300,
type = "group",
guiInline = true,
name = L["Grouping & Sorting"],
set = function(info, value) E.db.unitframe.units.party[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party", nil, nil, true) end,
args = {
groupBy = {
order = 1,
type = "select",
name = L["Group By"],
desc = L["Set the order that the group will sort."],
values = {
["CLASS"] = L["CLASS"],
["NAME"] = L["NAME"],
["MTMA"] = L["Main Tanks / Main Assist"],
["GROUP"] = L["GROUP"]
}
},
sortDir = {
order = 2,
type = "select",
name = L["Sort Direction"],
desc = L["Defines the sort order of the selected sort method."],
values = {
["ASC"] = L["Ascending"],
["DESC"] = L["Descending"]
}
},
spacer = {
order = 3,
type = "description",
width = "full",
name = " "
},
raidWideSorting = {
order = 4,
type = "toggle",
name = L["Raid-Wide Sorting"],
desc = L["Enabling this allows raid-wide sorting however you will not be able to distinguish between groups."]
},
invertGroupingOrder = {
order = 5,
type = "toggle",
name = L["Invert Grouping Order"],
desc = L["Enabling this inverts the grouping order when the raid is not full, this will reverse the direction it starts from."],
disabled = function() return not E.db.unitframe.units.party.raidWideSorting end
},
startFromCenter = {
order = 6,
type = "toggle",
name = L["Start Near Center"],
desc = L["The initial group will start near the center and grow out."],
disabled = function() return not E.db.unitframe.units.party.raidWideSorting end
}
}
}
}
},
buffIndicator = {
order = 600,
type = "group",
name = L["Buff Indicator"],
get = function(info) return E.db.unitframe.units.party.buffIndicator[info[#info]] end,
set = function(info, value) E.db.unitframe.units.party.buffIndicator[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party") end,
args = {
header = {
order = 1,
type = "header",
name = L["Buff Indicator"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
size = {
order = 3,
type = "range",
name = L["Size"],
desc = L["Size of the indicator icon."],
min = 4, max = 50, step = 1
},
fontSize = {
order = 4,
type = "range",
name = L["FONT_SIZE"],
min = 7, max = 22, step = 1
},
profileSpecific = {
order = 5,
type = "toggle",
name = L["Profile Specific"],
desc = L["Use the profile specific filter 'Buff Indicator (Profile)' instead of the global filter 'Buff Indicator'."]
},
configureButton = {
order = 6,
type = "execute",
name = L["Configure Auras"],
func = function()
if E.db.unitframe.units.party.buffIndicator.profileSpecific then
E:SetToFilterConfig("Buff Indicator (Profile)")
else
E:SetToFilterConfig("Buff Indicator")
end
end
}
}
},
roleIcon = {
order = 700,
type = "group",
name = L["Role Icon"],
get = function(info) return E.db.unitframe.units.party.roleIcon[info[#info]] end,
set = function(info, value) E.db.unitframe.units.party.roleIcon[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party") end,
args = {
header = {
order = 1,
type = "header",
name = L["Role Icon"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
position = {
order = 3,
type = "select",
name = L["Position"],
values = positionValues
},
attachTo = {
order = 4,
type = "select",
name = L["Attach To"],
values = attachToValues
},
xOffset = {
order = 5,
type = "range",
name = L["X-Offset"],
min = -300, max = 300, step = 1
},
yOffset = {
order = 6,
type = "range",
name = L["Y-Offset"],
min = -300, max = 300, step = 1
},
size = {
order = 7,
type = "range",
name = L["Size"],
min = 4, max = 100, step = 1
},
tank = {
order = 8,
type = "toggle",
name = L["Show For Tanks"]
},
healer = {
order = 9,
type = "toggle",
name = L["Show For Healers"]
},
damager = {
order = 10,
type = "toggle",
name = L["Show For DPS"],
},
combatHide = {
order = 11,
type = "toggle",
name = L["Hide In Combat"]
}
}
},
raidRoleIcons = {
order = 750,
type = "group",
name = L["RL / ML Icons"],
get = function(info) return E.db.unitframe.units.party.raidRoleIcons[info[#info]] end,
set = function(info, value) E.db.unitframe.units.party.raidRoleIcons[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party") end,
args = {
header = {
order = 1,
type = "header",
name = L["RL / ML Icons"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
position = {
order = 3,
type = "select",
name = L["Position"],
values = {
["TOPLEFT"] = "TOPLEFT",
["TOPRIGHT"] = "TOPRIGHT"
}
}
}
},
health = GetOptionsTable_Health(true, UF.CreateAndUpdateHeaderGroup, "party"),
healPredction = GetOptionsTable_HealPrediction(UF.CreateAndUpdateHeaderGroup, "party"),
power = GetOptionsTable_Power(false, UF.CreateAndUpdateHeaderGroup, "party"),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateHeaderGroup, "party"),
name = GetOptionsTable_Name(UF.CreateAndUpdateHeaderGroup, "party"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateHeaderGroup, "party"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateHeaderGroup, "party"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateHeaderGroup, "party"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateHeaderGroup, "party"),
rdebuffs = GetOptionsTable_RaidDebuff(UF.CreateAndUpdateHeaderGroup, "party"),
castbar = GetOptionsTable_Castbar(false, UF.CreateAndUpdateHeaderGroup, "party", 5),
petsGroup = {
order = 850,
type = "group",
name = L["Party Pets"],
get = function(info) return E.db.unitframe.units.party.petsGroup[info[#info]] end,
set = function(info, value) E.db.unitframe.units.party.petsGroup[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party") end,
args = {
header = {
order = 1,
type = "header",
name = L["Party Pets"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
width = {
order = 3,
type = "range",
name = L["Width"],
min = 10, max = 500, step = 1
},
height = {
order = 4,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
anchorPoint = {
order = 5,
type = "select",
name = L["Anchor Point"],
desc = L["What point to anchor to the frame you set to attach to."],
values = petAnchors
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
desc = L["An X offset (in pixels) to be used when anchoring new frames."],
min = -500, max = 500, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
desc = L["An Y offset (in pixels) to be used when anchoring new frames."],
min = -500, max = 500, step = 1
},
name = {
order = 8,
type = "group",
name = L["NAME"],
guiInline = true,
get = function(info) return E.db.unitframe.units.party.petsGroup.name[info[#info]] end,
set = function(info, value) E.db.unitframe.units.party.petsGroup.name[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party") end,
args = {
position = {
order = 1,
type = "select",
name = L["Text Position"],
values = positionValues
},
xOffset = {
order = 2,
type = "range",
name = L["Text xOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
yOffset = {
order = 3,
type = "range",
name = L["Text yOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
text_format = {
order = 100,
type = "input",
name = L["Text Format"],
desc = L["TEXT_FORMAT_DESC"],
width = "full"
}
}
}
}
},
targetsGroup = {
order = 900,
type = "group",
name = L["Party Targets"],
get = function(info) return E.db.unitframe.units.party.targetsGroup[info[#info]] end,
set = function(info, value) E.db.unitframe.units.party.targetsGroup[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party") end,
args = {
header = {
order = 1,
type = "header",
name = L["Party Targets"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
width = {
order = 3,
type = "range",
name = L["Width"],
min = 10, max = 500, step = 1
},
height = {
order = 4,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
anchorPoint = {
order = 5,
type = "select",
name = L["Anchor Point"],
desc = L["What point to anchor to the frame you set to attach to."],
values = petAnchors
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
desc = L["An X offset (in pixels) to be used when anchoring new frames."],
min = -500, max = 500, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
desc = L["An Y offset (in pixels) to be used when anchoring new frames."],
min = -500, max = 500, step = 1
},
name = {
order = 8,
type = "group",
name = L["Name"],
guiInline = true,
get = function(info) return E.db.unitframe.units.party.targetsGroup.name[info[#info]] end,
set = function(info, value) E.db.unitframe.units.party.targetsGroup.name[info[#info]] = value UF:CreateAndUpdateHeaderGroup("party") end,
args = {
position = {
order = 1,
type = "select",
name = L["Text Position"],
values = positionValues
},
xOffset = {
order = 2,
type = "range",
name = L["Text xOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
yOffset = {
order = 3,
type = "range",
name = L["Text yOffset"],
desc = L["Offset position for text."],
min = -300, max = 300, step = 1
},
text_format = {
order = 100,
type = "input",
name = L["Text Format"],
desc = L["TEXT_FORMAT_DESC"],
width = "full"
}
}
}
}
},
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateHeaderGroup, "party"),
readycheckIcon = GetOptionsTable_ReadyCheckIcon(UF.CreateAndUpdateHeaderGroup, "party"),
resurrectIcon = GetOptionsTable_ResurrectIcon(UF.CreateAndUpdateHeaderGroup, "party"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateHeaderGroup, "party"),
GPSArrow = GetOptionsTable_GPS("party")
}
}
--Raid Frames
E.Options.args.unitframe.args.raid = {
order = 1300,
type = "group",
name = L["RAID"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.raid[info[#info]] end,
set = function(info, value) E.db.unitframe.units.raid[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
configureToggle = {
order = 2,
type = "execute",
name = L["Display Frames"],
func = function()
UF:HeaderConfig(ElvUF_Raid, ElvUF_Raid.forceShow ~= true or nil)
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["RAID"], nil, {unit="raid", mover="Raid Frames"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = {
["party"] = L["PARTY"],
["raid40"] = L["Raid-40"]
},
set = function(info, value) UF:MergeUnitSettings(value, "raid", true) end
},
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateHeaderGroup, "raid"),
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
hideonnpc = {
order = 2,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.raid.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.raid.power.hideonnpc = value UF:CreateAndUpdateHeaderGroup("raid") end
},
threatStyle = {
order = 3,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
orientation = {
order = 5,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 6,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 7,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
},
positionsGroup = {
order = 100,
type = "group",
name = L["Size and Positions"],
guiInline = true,
set = function(info, value) E.db.unitframe.units.raid[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid", nil, nil, true) end,
args = {
width = {
order = 1,
type = "range",
name = L["Width"],
min = 10, max = 500, step = 1,
set = function(info, value) E.db.unitframe.units.raid[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid") end
},
height = {
order = 2,
name = L["Height"],
type = "range",
min = 10, max = 500, step = 1,
set = function(info, value) E.db.unitframe.units.raid[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid") end,
},
spacer = {
order = 3,
type = "description",
name = "",
width = "full"
},
growthDirection = {
order = 4,
type = "select",
name = L["Growth Direction"],
desc = L["Growth direction from the first unitframe."],
values = growthDirectionValues
},
numGroups = {
order = 7,
type = "range",
name = L["Number of Groups"],
min = 1, max = 8, step = 1,
set = function(info, value)
E.db.unitframe.units.raid[info[#info]] = value
UF:CreateAndUpdateHeaderGroup("raid")
if ElvUF_Raid.isForced then
UF:HeaderConfig(ElvUF_Raid)
UF:HeaderConfig(ElvUF_Raid, true)
end
end
},
groupsPerRowCol = {
order = 8,
type = "range",
name = L["Groups Per Row/Column"],
min = 1, max = 8, step = 1,
set = function(info, value)
E.db.unitframe.units.raid[info[#info]] = value
UF:CreateAndUpdateHeaderGroup("raid")
if ElvUF_Raid.isForced then
UF:HeaderConfig(ElvUF_Raid)
UF:HeaderConfig(ElvUF_Raid, true)
end
end
},
horizontalSpacing = {
order = 9,
type = "range",
name = L["Horizontal Spacing"],
min = -1, max = 50, step = 1
},
verticalSpacing = {
order = 10,
type = "range",
name = L["Vertical Spacing"],
min = -1, max = 50, step = 1
},
groupSpacing = {
order = 11,
type = "range",
name = L["Group Spacing"],
desc = L["Additional spacing between each individual group."],
min = 0, softMax = 50, step = 1
}
}
},
visibilityGroup = {
order = 200,
name = L["Visibility"],
type = "group",
guiInline = true,
set = function(info, value) E.db.unitframe.units.raid[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid", nil, nil, true) end,
args = {
showPlayer = {
order = 1,
type = "toggle",
name = L["Display Player"],
desc = L["When true, the header includes the player when not in a raid."]
},
visibility = {
order = 2,
type = "input",
name = L["Visibility"],
desc = L["The following macro must be true in order for the group to be shown, in addition to any filter that may already be set."],
width = "full"
}
}
},
sortingGroup = {
order = 300,
type = "group",
guiInline = true,
name = L["Grouping & Sorting"],
set = function(info, value) E.db.unitframe.units.raid[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid", nil, nil, true) end,
args = {
groupBy = {
order = 1,
type = "select",
name = L["Group By"],
desc = L["Set the order that the group will sort."],
values = {
["CLASS"] = L["CLASS"],
["NAME"] = L["NAME"],
["MTMA"] = L["Main Tanks / Main Assist"],
["GROUP"] = L["GROUP"]
}
},
sortDir = {
order = 2,
type = "select",
name = L["Sort Direction"],
desc = L["Defines the sort order of the selected sort method."],
values = {
["ASC"] = L["Ascending"],
["DESC"] = L["Descending"]
}
},
spacer = {
order = 3,
type = "description",
width = "full",
name = " "
},
raidWideSorting = {
order = 4,
type = "toggle",
name = L["Raid-Wide Sorting"],
desc = L["Enabling this allows raid-wide sorting however you will not be able to distinguish between groups."]
},
invertGroupingOrder = {
order = 5,
type = "toggle",
name = L["Invert Grouping Order"],
desc = L["Enabling this inverts the grouping order when the raid is not full, this will reverse the direction it starts from."],
disabled = function() return not E.db.unitframe.units.raid.raidWideSorting end
},
startFromCenter = {
order = 6,
type = "toggle",
name = L["Start Near Center"],
desc = L["The initial group will start near the center and grow out."],
disabled = function() return not E.db.unitframe.units.raid.raidWideSorting end
}
}
}
}
},
health = GetOptionsTable_Health(true, UF.CreateAndUpdateHeaderGroup, "raid"),
healPredction = GetOptionsTable_HealPrediction(UF.CreateAndUpdateHeaderGroup, "raid"),
power = GetOptionsTable_Power(false, UF.CreateAndUpdateHeaderGroup, "raid"),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateHeaderGroup, "raid"),
name = GetOptionsTable_Name(UF.CreateAndUpdateHeaderGroup, "raid"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateHeaderGroup, "raid"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateHeaderGroup, "raid"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateHeaderGroup, "raid"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateHeaderGroup, "raid"),
buffIndicator = {
order = 600,
type = "group",
name = L["Buff Indicator"],
get = function(info) return E.db.unitframe.units.raid.buffIndicator[info[#info]] end,
set = function(info, value) E.db.unitframe.units.raid.buffIndicator[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid") end,
args = {
header = {
order = 1,
type = "header",
name = L["Buff Indicator"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
size = {
order = 3,
type = "range",
name = L["Size"],
desc = L["Size of the indicator icon."],
min = 4, max = 50, step = 1
},
fontSize = {
order = 4,
type = "range",
name = L["FONT_SIZE"],
min = 7, max = 22, step = 1
},
profileSpecific = {
order = 5,
type = "toggle",
name = L["Profile Specific"],
desc = L["Use the profile specific filter 'Buff Indicator (Profile)' instead of the global filter 'Buff Indicator'."]
},
configureButton = {
order = 6,
type = "execute",
name = L["Configure Auras"],
func = function()
if E.db.unitframe.units.raid.buffIndicator.profileSpecific then
E:SetToFilterConfig("Buff Indicator (Profile)")
else
E:SetToFilterConfig("Buff Indicator")
end
end
}
}
},
raidRoleIcons = {
order = 750,
type = "group",
name = L["RL / ML Icons"],
get = function(info) return E.db.unitframe.units.raid.raidRoleIcons[info[#info]] end,
set = function(info, value) E.db.unitframe.units.raid.raidRoleIcons[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid") end,
args = {
header = {
order = 1,
type = "header",
name = L["RL / ML Icons"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
position = {
order = 3,
type = "select",
name = L["Position"],
values = {
["TOPLEFT"] = "TOPLEFT",
["TOPRIGHT"] = "TOPRIGHT"
}
},
size = {
order = 4,
type = "range",
name = L["Size"],
min = 4, max = 100, step = 1
}
}
},
rdebuffs = GetOptionsTable_RaidDebuff(UF.CreateAndUpdateHeaderGroup, "raid"),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateHeaderGroup, "raid"),
readycheckIcon = GetOptionsTable_ReadyCheckIcon(UF.CreateAndUpdateHeaderGroup, "raid"),
resurrectIcon = GetOptionsTable_ResurrectIcon(UF.CreateAndUpdateHeaderGroup, "raid"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateHeaderGroup, "raid"),
GPSArrow = GetOptionsTable_GPS("raid")
}
}
--Raid-40 Frames
E.Options.args.unitframe.args.raid40 = {
order = 1350,
type = "group",
name = L["Raid-40"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.raid40[info[#info]] end,
set = function(info, value) E.db.unitframe.units.raid40[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid40") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
configureToggle = {
order = 2,
type = "execute",
name = L["Display Frames"],
func = function()
UF:HeaderConfig(ElvUF_Raid40, ElvUF_Raid40.forceShow ~= true or nil)
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["Raid-40"], nil, {unit="raid40", mover="Raid Frames"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = {
["party"] = L["PARTY"],
["raid"] = L["RAID"]
},
set = function(info, value) UF:MergeUnitSettings(value, "raid40", true) end
},
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateHeaderGroup, "raid40"),
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
hideonnpc = {
order = 2,
type = "toggle",
name = L["Text Toggle On NPC"],
desc = L["Power text will be hidden on NPC targets, in addition the name text will be repositioned to the power texts anchor point."],
get = function(info) return E.db.unitframe.units.raid40.power.hideonnpc end,
set = function(info, value) E.db.unitframe.units.raid40.power.hideonnpc = value UF:CreateAndUpdateHeaderGroup("raid40") end
},
threatStyle = {
order = 3,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
orientation = {
order = 5,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 6,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 7,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
},
positionsGroup = {
order = 100,
type = "group",
name = L["Size and Positions"],
guiInline = true,
set = function(info, value) E.db.unitframe.units.raid40[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid40", nil, nil, true) end,
args = {
width = {
order = 1,
type = "range",
name = L["Width"],
min = 10, max = 500, step = 1,
set = function(info, value) E.db.unitframe.units.raid40[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid40") end
},
height = {
order = 2,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1,
set = function(info, value) E.db.unitframe.units.raid40[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid40") end
},
spacer = {
order = 3,
type = "description",
name = "",
width = "full"
},
growthDirection = {
order = 4,
type = "select",
name = L["Growth Direction"],
desc = L["Growth direction from the first unitframe."],
values = growthDirectionValues
},
numGroups = {
order = 7,
type = "range",
name = L["Number of Groups"],
min = 1, max = 8, step = 1,
set = function(info, value)
E.db.unitframe.units.raid40[info[#info]] = value
UF:CreateAndUpdateHeaderGroup("raid40")
if ElvUF_Raid40.isForced then
UF:HeaderConfig(ElvUF_Raid40)
UF:HeaderConfig(ElvUF_Raid40, true)
end
end
},
groupsPerRowCol = {
order = 8,
type = "range",
name = L["Groups Per Row/Column"],
min = 1, max = 8, step = 1,
set = function(info, value)
E.db.unitframe.units.raid40[info[#info]] = value
UF:CreateAndUpdateHeaderGroup("raid40")
if ElvUF_Raid40.isForced then
UF:HeaderConfig(ElvUF_Raid40)
UF:HeaderConfig(ElvUF_Raid40, true)
end
end
},
horizontalSpacing = {
order = 9,
type = "range",
name = L["Horizontal Spacing"],
min = -1, max = 50, step = 1
},
verticalSpacing = {
order = 10,
type = "range",
name = L["Vertical Spacing"],
min = -1, max = 50, step = 1
},
groupSpacing = {
order = 11,
type = "range",
name = L["Group Spacing"],
desc = L["Additional spacing between each individual group."],
min = 0, softMax = 50, step = 1
}
}
},
visibilityGroup = {
order = 200,
type = "group",
name = L["Visibility"],
guiInline = true,
set = function(info, value) E.db.unitframe.units.raid40[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid40", nil, nil, true) end,
args = {
showPlayer = {
order = 1,
type = "toggle",
name = L["Display Player"],
desc = L["When true, the header includes the player when not in a raid."]
},
visibility = {
order = 2,
type = "input",
name = L["Visibility"],
desc = L["The following macro must be true in order for the group to be shown, in addition to any filter that may already be set."],
width = "full"
}
}
},
sortingGroup = {
order = 300,
type = "group",
guiInline = true,
name = L["Grouping & Sorting"],
set = function(info, value) E.db.unitframe.units.raid40[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid40", nil, nil, true) end,
args = {
groupBy = {
order = 1,
type = "select",
name = L["Group By"],
desc = L["Set the order that the group will sort."],
values = {
["CLASS"] = L["CLASS"],
["NAME"] = L["NAME"],
["MTMA"] = L["Main Tanks / Main Assist"],
["GROUP"] = L["GROUP"]
}
},
sortDir = {
order = 2,
type = "select",
name = L["Sort Direction"],
desc = L["Defines the sort order of the selected sort method."],
values = {
["ASC"] = L["Ascending"],
["DESC"] = L["Descending"]
}
},
spacer = {
order = 3,
type = "description",
width = "full",
name = " "
},
raidWideSorting = {
order = 4,
type = "toggle",
name = L["Raid-Wide Sorting"],
desc = L["Enabling this allows raid-wide sorting however you will not be able to distinguish between groups."]
},
invertGroupingOrder = {
order = 5,
type = "toggle",
name = L["Invert Grouping Order"],
desc = L["Enabling this inverts the grouping order when the raid is not full, this will reverse the direction it starts from."],
disabled = function() return not E.db.unitframe.units.raid40.raidWideSorting end
},
startFromCenter = {
order = 6,
type = "toggle",
name = L["Start Near Center"],
desc = L["The initial group will start near the center and grow out."],
disabled = function() return not E.db.unitframe.units.raid40.raidWideSorting end
}
}
}
}
},
health = GetOptionsTable_Health(true, UF.CreateAndUpdateHeaderGroup, "raid40"),
healPredction = GetOptionsTable_HealPrediction(UF.CreateAndUpdateHeaderGroup, "raid40"),
power = GetOptionsTable_Power(false, UF.CreateAndUpdateHeaderGroup, "raid40"),
infoPanel = GetOptionsTable_InformationPanel(UF.CreateAndUpdateHeaderGroup, "raid40"),
name = GetOptionsTable_Name(UF.CreateAndUpdateHeaderGroup, "raid40"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateHeaderGroup, "raid40"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateHeaderGroup, "raid40"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateHeaderGroup, "raid40"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateHeaderGroup, "raid40"),
buffIndicator = {
order = 600,
type = "group",
name = L["Buff Indicator"],
get = function(info) return E.db.unitframe.units.raid40.buffIndicator[info[#info]] end,
set = function(info, value) E.db.unitframe.units.raid40.buffIndicator[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid40") end,
args = {
header = {
order = 1,
type = "header",
name = L["Buff Indicator"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
size = {
order = 3,
type = "range",
name = L["Size"],
desc = L["Size of the indicator icon."],
min = 4, max = 50, step = 1
},
fontSize = {
order = 4,
type = "range",
name = L["FONT_SIZE"],
min = 7, max = 22, step = 1
},
profileSpecific = {
order = 5,
type = "toggle",
name = L["Profile Specific"],
desc = L["Use the profile specific filter 'Buff Indicator (Profile)' instead of the global filter 'Buff Indicator'."]
},
configureButton = {
order = 6,
type = "execute",
name = L["Configure Auras"],
func = function()
if E.db.unitframe.units.raid40.buffIndicator.profileSpecific then
E:SetToFilterConfig("Buff Indicator (Profile)")
else
E:SetToFilterConfig("Buff Indicator")
end
end
}
}
},
raidRoleIcons = {
order = 750,
type = "group",
name = L["RL / ML Icons"],
get = function(info) return E.db.unitframe.units.raid40.raidRoleIcons[info[#info]] end,
set = function(info, value) E.db.unitframe.units.raid40.raidRoleIcons[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raid40") end,
args = {
header = {
order = 1,
type = "header",
name = L["RL / ML Icons"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
position = {
order = 3,
type = "select",
name = L["Position"],
values = {
["TOPLEFT"] = "TOPLEFT",
["TOPRIGHT"] = "TOPRIGHT"
}
}
}
},
rdebuffs = GetOptionsTable_RaidDebuff(UF.CreateAndUpdateHeaderGroup, "raid40"),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateHeaderGroup, "raid40"),
readycheckIcon = GetOptionsTable_ReadyCheckIcon(UF.CreateAndUpdateHeaderGroup, "raid40"),
resurrectIcon = GetOptionsTable_ResurrectIcon(UF.CreateAndUpdateHeaderGroup, "raid40"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateHeaderGroup, "raid40"),
GPSArrow = GetOptionsTable_GPS("raid40")
}
}
--Raid Pet Frames
E.Options.args.unitframe.args.raidpet = {
order = 1400,
type = "group",
name = L["Raid Pet"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.raidpet[info[#info]] end,
set = function(info, value) E.db.unitframe.units.raidpet[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raidpet") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
configureToggle = {
order = 2,
type = "execute",
name = L["Display Frames"],
func = function()
UF:HeaderConfig(ElvUF_Raidpet, ElvUF_Raidpet.forceShow ~= true or nil)
end
},
resetSettings = {
order = 3,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["Raid Pet"], nil, {unit="raidpet", mover="Raid Pet Frames"}) end
},
copyFrom = {
order = 4,
type = "select",
name = L["Copy From"],
desc = L["Select a unit to copy settings from."],
values = {
["party"] = L["PARTY"],
["raid"] = L["RAID"]
},
set = function(info, value) UF:MergeUnitSettings(value, "raidpet", true) end
},
customText = GetOptionsTable_CustomText(UF.CreateAndUpdateHeaderGroup, "raidpet"),
generalGroup = {
order = 5,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
threatStyle = {
order = 2,
type = "select",
name = L["Threat Display Mode"],
values = threatValues
},
orientation = {
order = 4,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 5,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 6,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
},
positionsGroup = {
order = 100,
type = "group",
name = L["Size and Positions"],
guiInline = true,
set = function(info, value) E.db.unitframe.units.raidpet[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raidpet", nil, nil, true) end,
args = {
width = {
order = 1,
type = "range",
name = L["Width"],
min = 10, max = 500, step = 1,
set = function(info, value) E.db.unitframe.units.raidpet[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raidpet") end,
},
height = {
order = 2,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1,
set = function(info, value) E.db.unitframe.units.raidpet[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raidpet") end,
},
spacer = {
order = 3,
type = "description",
name = "",
width = "full"
},
growthDirection = {
order = 4,
type = "select",
name = L["Growth Direction"],
desc = L["Growth direction from the first unitframe."],
values = growthDirectionValues
},
numGroups = {
order = 7,
type = "range",
name = L["Number of Groups"],
min = 1, max = 8, step = 1,
set = function(info, value)
E.db.unitframe.units.raidpet[info[#info]] = value
UF:CreateAndUpdateHeaderGroup("raidpet")
if ElvUF_Raidpet.isForced then
UF:HeaderConfig(ElvUF_Raidpet)
UF:HeaderConfig(ElvUF_Raidpet, true)
end
end
},
groupsPerRowCol = {
order = 8,
type = "range",
name = L["Groups Per Row/Column"],
min = 1, max = 8, step = 1,
set = function(info, value)
E.db.unitframe.units.raidpet[info[#info]] = value
UF:CreateAndUpdateHeaderGroup("raidpet")
if ElvUF_Raidpet.isForced then
UF:HeaderConfig(ElvUF_Raidpet)
UF:HeaderConfig(ElvUF_Raidpet, true)
end
end
},
horizontalSpacing = {
order = 9,
type = "range",
name = L["Horizontal Spacing"],
min = -1, max = 50, step = 1
},
verticalSpacing = {
order = 10,
type = "range",
name = L["Vertical Spacing"],
min = -1, max = 50, step = 1
},
groupSpacing = {
order = 11,
type = "range",
name = L["Group Spacing"],
desc = L["Additional spacing between each individual group."],
min = 0, softMax = 50, step = 1
}
}
},
visibilityGroup = {
order = 200,
type = "group",
name = L["Visibility"],
guiInline = true,
set = function(info, value) E.db.unitframe.units.raidpet[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raidpet", nil, nil, true) end,
args = {
visibility = {
order = 2,
type = "input",
name = L["Visibility"],
desc = L["The following macro must be true in order for the group to be shown, in addition to any filter that may already be set."],
width = "full"
}
}
},
sortingGroup = {
order = 300,
type = "group",
guiInline = true,
name = L["Grouping & Sorting"],
set = function(info, value) E.db.unitframe.units.raidpet[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raidpet", nil, nil, true) end,
args = {
groupBy = {
order = 1,
type = "select",
name = L["Group By"],
desc = L["Set the order that the group will sort."],
values = {
["NAME"] = L["Owners Name"],
["PETNAME"] = L["Pet Name"],
["GROUP"] = L["GROUP"]
}
},
sortDir = {
order = 2,
type = "select",
name = L["Sort Direction"],
desc = L["Defines the sort order of the selected sort method."],
values = {
["ASC"] = L["Ascending"],
["DESC"] = L["Descending"]
}
},
spacer = {
order = 3,
type = "description",
width = "full",
name = " "
},
raidWideSorting = {
order = 4,
type = "toggle",
name = L["Raid-Wide Sorting"],
desc = L["Enabling this allows raid-wide sorting however you will not be able to distinguish between groups."]
},
invertGroupingOrder = {
order = 5,
type = "toggle",
name = L["Invert Grouping Order"],
desc = L["Enabling this inverts the grouping order when the raid is not full, this will reverse the direction it starts from."],
disabled = function() return not E.db.unitframe.units.raidpet.raidWideSorting end
},
startFromCenter = {
order = 6,
type = "toggle",
name = L["Start Near Center"],
desc = L["The initial group will start near the center and grow out."],
disabled = function() return not E.db.unitframe.units.raidpet.raidWideSorting end
}
}
}
}
},
health = GetOptionsTable_Health(true, UF.CreateAndUpdateHeaderGroup, "raidpet"),
healPredction = GetOptionsTable_HealPrediction(UF.CreateAndUpdateHeaderGroup, "raidpet"),
name = GetOptionsTable_Name(UF.CreateAndUpdateHeaderGroup, "raidpet"),
portrait = GetOptionsTable_Portrait(UF.CreateAndUpdateHeaderGroup, "raidpet"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateHeaderGroup, "raidpet"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateHeaderGroup, "raidpet"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateHeaderGroup, "raidpet"),
rdebuffs = GetOptionsTable_RaidDebuff(UF.CreateAndUpdateHeaderGroup, "raidpet"),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateHeaderGroup, "raidpet"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateHeaderGroup, "raidpet"),
buffIndicator = {
order = 600,
type = "group",
name = L["Buff Indicator"],
get = function(info) return E.db.unitframe.units.raidpet.buffIndicator[info[#info]] end,
set = function(info, value) E.db.unitframe.units.raidpet.buffIndicator[info[#info]] = value UF:CreateAndUpdateHeaderGroup("raidpet") end,
args = {
header = {
order = 1,
type = "header",
name = L["Buff Indicator"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
size = {
order = 3,
type = "range",
name = L["Size"],
desc = L["Size of the indicator icon."],
min = 4, max = 50, step = 1
},
fontSize = {
order = 4,
type = "range",
name = L["FONT_SIZE"],
min = 7, max = 22, step = 1
},
configureButton = {
order = 5,
type = "execute",
name = L["Configure Auras"],
func = function() E:SetToFilterConfig("Buff Indicator") end
}
}
}
}
}
--Tank Frames
E.Options.args.unitframe.args.tank = {
order = 1500,
type = "group",
name = L["TANK"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.tank[info[#info]] end,
set = function(info, value) E.db.unitframe.units.tank[info[#info]] = value UF:CreateAndUpdateHeaderGroup("tank") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
resetSettings = {
order = 2,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["TANK"], nil, {unit="tank"}) end
},
generalGroup = {
order = 3,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 2,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
disableDebuffHighlight = {
order = 5,
type = "toggle",
name = L["Disable Debuff Highlight"],
desc = L["Forces Debuff Highlight to be disabled for these frames"],
disabled = function() return E.db.unitframe.debuffHighlighting == "NONE" end
},
orientation = {
order = 6,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 8,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 9,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
targetsGroup = {
order = 4,
type = "group",
name = L["Tank Target"],
get = function(info) return E.db.unitframe.units.tank.targetsGroup[info[#info]] end,
set = function(info, value) E.db.unitframe.units.tank.targetsGroup[info[#info]] = value UF:CreateAndUpdateHeaderGroup("tank") end,
args = {
header = {
order = 1,
type = "header",
name = L["Tank Target"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
width = {
order = 3,
type = "range",
name = L["Width"],
min = 10, max = 500, step = 1
},
height = {
order = 4,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
anchorPoint = {
order = 5,
type = "select",
name = L["Anchor Point"],
desc = L["What point to anchor to the frame you set to attach to."],
values = petAnchors
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
desc = L["An X offset (in pixels) to be used when anchoring new frames."],
min = -500, max = 500, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
desc = L["An Y offset (in pixels) to be used when anchoring new frames."],
min = -500, max = 500, step = 1
},
name = GetOptionsTable_Name(UF.CreateAndUpdateHeaderGroup, "tank")
}
},
name = GetOptionsTable_Name(UF.CreateAndUpdateHeaderGroup, "tank"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateHeaderGroup, "tank"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateHeaderGroup, "tank"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateHeaderGroup, "tank"),
rdebuffs = GetOptionsTable_RaidDebuff(UF.CreateAndUpdateHeaderGroup, "tank"),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateHeaderGroup, "tank"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateHeaderGroup, "tank"),
buffIndicator = {
order = 800,
type = "group",
name = L["Buff Indicator"],
get = function(info) return E.db.unitframe.units.tank.buffIndicator[info[#info]] end,
set = function(info, value) E.db.unitframe.units.tank.buffIndicator[info[#info]] = value UF:CreateAndUpdateHeaderGroup("tank") end,
args = {
header = {
order = 1,
type = "header",
name = L["Buff Indicator"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
size = {
order = 3,
type = "range",
name = L["Size"],
desc = L["Size of the indicator icon."],
min = 4, max = 50, step = 1
},
fontSize = {
order = 4,
type = "range",
name = L["FONT_SIZE"],
min = 7, max = 22, step = 1
},
profileSpecific = {
order = 5,
type = "toggle",
name = L["Profile Specific"],
desc = L["Use the profile specific filter 'Buff Indicator (Profile)' instead of the global filter 'Buff Indicator'."]
},
configureButton = {
order = 6,
type = "execute",
name = L["Configure Auras"],
func = function()
if E.db.unitframe.units.tank.buffIndicator.profileSpecific then
E:SetToFilterConfig("Buff Indicator (Profile)")
else
E:SetToFilterConfig("Buff Indicator")
end
end
}
}
}
}
}
E.Options.args.unitframe.args.tank.args.name.args.attachTextTo.values = {["Health"] = L["HEALTH"], ["Frame"] = L["Frame"]}
E.Options.args.unitframe.args.tank.args.targetsGroup.args.name.args.attachTextTo.values = {["Health"] = L["HEALTH"], ["Frame"] = L["Frame"]}
E.Options.args.unitframe.args.tank.args.targetsGroup.args.name.get = function(info) return E.db.unitframe.units.tank.targetsGroup.name[info[#info]] end
E.Options.args.unitframe.args.tank.args.targetsGroup.args.name.set = function(info, value) E.db.unitframe.units.tank.targetsGroup.name[info[#info]] = value UF.CreateAndUpdateHeaderGroup(UF, "tank") end
--Assist Frames
E.Options.args.unitframe.args.assist = {
order = 1600,
type = "group",
name = L["Assist"],
childGroups = "tab",
get = function(info) return E.db.unitframe.units.assist[info[#info]] end,
set = function(info, value) E.db.unitframe.units.assist[info[#info]] = value UF:CreateAndUpdateHeaderGroup("assist") end,
disabled = function() return not E.UnitFrames.Initialized end,
args = {
enable = {
order = 1,
type = "toggle",
name = L["Enable"]
},
resetSettings = {
order = 2,
type = "execute",
name = L["Restore Defaults"],
func = function(info) E:StaticPopup_Show("RESET_UF_UNIT", L["Assist"], nil, {unit="assist"}) end
},
generalGroup = {
order = 3,
type = "group",
name = L["General"],
args = {
header = {
order = 1,
type = "header",
name = L["General"]
},
width = {
order = 2,
type = "range",
name = L["Width"],
min = 50, max = 1000, step = 1
},
height = {
order = 3,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
disableDebuffHighlight = {
order = 5,
type = "toggle",
name = L["Disable Debuff Highlight"],
desc = L["Forces Debuff Highlight to be disabled for these frames"],
disabled = function() return E.db.unitframe.debuffHighlighting == "NONE" end
},
orientation = {
order = 6,
type = "select",
name = L["Frame Orientation"],
desc = L["Set the orientation of the UnitFrame."],
values = orientationValues
},
disableMouseoverGlow = {
order = 8,
type = "toggle",
name = L["Block Mouseover Glow"],
desc = L["Forces Mouseover Glow to be disabled for these frames"]
},
disableTargetGlow = {
order = 9,
type = "toggle",
name = L["Block Target Glow"],
desc = L["Forces Target Glow to be disabled for these frames"]
}
}
},
targetsGroup = {
order = 4,
type = "group",
name = L["Assist Target"],
get = function(info) return E.db.unitframe.units.assist.targetsGroup[info[#info]] end,
set = function(info, value) E.db.unitframe.units.assist.targetsGroup[info[#info]] = value UF:CreateAndUpdateHeaderGroup("assist") end,
args = {
header = {
order = 1,
type = "header",
name = L["Assist Target"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
width = {
order = 3,
type = "range",
name = L["Width"],
min = 10, max = 500, step = 1
},
height = {
order = 4,
type = "range",
name = L["Height"],
min = 10, max = 500, step = 1
},
anchorPoint = {
order = 5,
type = "select",
name = L["Anchor Point"],
desc = L["What point to anchor to the frame you set to attach to."],
values = petAnchors
},
xOffset = {
order = 6,
type = "range",
name = L["X-Offset"],
desc = L["An X offset (in pixels) to be used when anchoring new frames."],
min = -500, max = 500, step = 1
},
yOffset = {
order = 7,
type = "range",
name = L["Y-Offset"],
desc = L["An Y offset (in pixels) to be used when anchoring new frames."],
min = -500, max = 500, step = 1
},
name = GetOptionsTable_Name(UF.CreateAndUpdateHeaderGroup, "assist")
}
},
name = GetOptionsTable_Name(UF.CreateAndUpdateHeaderGroup, "assist"),
fader = GetOptionsTable_Fader(UF.CreateAndUpdateHeaderGroup, "assist"),
buffs = GetOptionsTable_Auras("buffs", UF.CreateAndUpdateHeaderGroup, "assist"),
debuffs = GetOptionsTable_Auras("debuffs", UF.CreateAndUpdateHeaderGroup, "assist"),
rdebuffs = GetOptionsTable_RaidDebuff(UF.CreateAndUpdateHeaderGroup, "assist"),
raidicon = GetOptionsTable_RaidIcon(UF.CreateAndUpdateHeaderGroup, "assist"),
cutaway = GetOptionsTable_Cutaway(UF.CreateAndUpdateHeaderGroup, "assist"),
buffIndicator = {
order = 800,
type = "group",
name = L["Buff Indicator"],
get = function(info) return E.db.unitframe.units.assist.buffIndicator[info[#info]] end,
set = function(info, value) E.db.unitframe.units.assist.buffIndicator[info[#info]] = value UF:CreateAndUpdateHeaderGroup("assist") end,
args = {
header = {
order = 1,
type = "header",
name = L["Buff Indicator"]
},
enable = {
order = 2,
type = "toggle",
name = L["Enable"]
},
size = {
order = 3,
type = "range",
name = L["Size"],
desc = L["Size of the indicator icon."],
min = 4, max = 50, step = 1
},
fontSize = {
order = 4,
type = "range",
name = L["FONT_SIZE"],
min = 7, max = 22, step = 1
},
profileSpecific = {
order = 5,
type = "toggle",
name = L["Profile Specific"],
desc = L["Use the profile specific filter 'Buff Indicator (Profile)' instead of the global filter 'Buff Indicator'."]
},
configureButton = {
order = 6,
type = "execute",
name = L["Configure Auras"],
func = function()
if E.db.unitframe.units.assist.buffIndicator.profileSpecific then
E:SetToFilterConfig("Buff Indicator (Profile)")
else
E:SetToFilterConfig("Buff Indicator")
end
end
}
}
}
}
}
E.Options.args.unitframe.args.assist.args.name.args.attachTextTo.values = {["Health"] = L["HEALTH"], ["Frame"] = L["Frame"]}
E.Options.args.unitframe.args.assist.args.targetsGroup.args.name.args.attachTextTo.values = {["Health"] = L["HEALTH"], ["Frame"] = L["Frame"]}
E.Options.args.unitframe.args.assist.args.targetsGroup.args.name.get = function(info) return E.db.unitframe.units.assist.targetsGroup.name[info[#info]] end
E.Options.args.unitframe.args.assist.args.targetsGroup.args.name.set = function(info, value) E.db.unitframe.units.assist.targetsGroup.name[info[#info]] = value UF.CreateAndUpdateHeaderGroup(UF, "assist") end
--MORE COLORING STUFF YAY
E.Options.args.unitframe.args.generalOptionsGroup.args.allColorsGroup.args.classResourceGroup = {
order = -10,
type = "group",
name = L["Class Resources"],
get = function(info)
local t = E.db.unitframe.colors.classResources[info[#info]]
local d = P.unitframe.colors.classResources[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors.classResources[info[#info]]
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end,
args = {
header = {
order = 0,
type = "header",
name = L["Class Resources"]
},
customclasspowerbackdrop = {
order = 0.1,
type = "toggle",
name = L["Custom Backdrop"],
desc = L["Use the custom backdrop color instead of a multiple of the main color."],
get = function(info) return E.db.unitframe.colors[info[#info]] end,
set = function(info, value) E.db.unitframe.colors[info[#info]] = value UF:Update_AllFrames() end,
},
classpower_backdrop = {
order = 0.2,
type = "color",
name = L["Custom Backdrop"],
desc = L["Use the custom backdrop color instead of a multiple of the main color."],
disabled = function() return not E.db.unitframe.colors.customclasspowerbackdrop end,
get = function(info)
local t = E.db.unitframe.colors[info[#info]]
local d = P.unitframe.colors[info[#info]]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors[info[#info]]
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end,
},
spacer2 = {
order = 0.3,
type = "description",
name = " ",
width = "full"
}
}
}
for i = 1, 5 do
E.Options.args.unitframe.args.generalOptionsGroup.args.allColorsGroup.args.classResourceGroup.args["combo"..i] = {
order = i + 2,
type = "color",
name = L["Combo Point"].." #"..i,
get = function(info)
local t = E.db.unitframe.colors.classResources.comboPoints[i]
local d = P.unitframe.colors.classResources.comboPoints[i]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors.classResources.comboPoints[i]
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end
}
end
if P.unitframe.colors.classResources[E.myclass] then
E.Options.args.unitframe.args.generalOptionsGroup.args.allColorsGroup.args.classResourceGroup.args.spacer3 = {
order = 10,
type = "description",
name = " ",
width = "full"
}
local ORDER = 20
if E.myclass == "DEATHKNIGHT" then
local names = {
[1] = L["COMBAT_TEXT_RUNE_BLOOD"],
[2] = L["COMBAT_TEXT_RUNE_UNHOLY"],
[3] = L["COMBAT_TEXT_RUNE_FROST"],
[4] = L["COMBAT_TEXT_RUNE_DEATH"]
}
for i = 1, 4 do
E.Options.args.unitframe.args.generalOptionsGroup.args.allColorsGroup.args.classResourceGroup.args["resource"..i] = {
order = ORDER + i,
type = "color",
name = names[i],
get = function(info)
local t = E.db.unitframe.colors.classResources.DEATHKNIGHT[i]
local d = P.unitframe.colors.classResources.DEATHKNIGHT[i]
return t.r, t.g, t.b, t.a, d.r, d.g, d.b
end,
set = function(info, r, g, b)
local t = E.db.unitframe.colors.classResources.DEATHKNIGHT[i]
t.r, t.g, t.b = r, g, b
UF:Update_AllFrames()
end
}
end
end
end
--Custom Texts
function E:RefreshCustomTextsConfigs()
--Hide any custom texts that don't belong to current profile
for _, customText in pairs(CUSTOMTEXT_CONFIGS) do
customText.hidden = true
end
twipe(CUSTOMTEXT_CONFIGS)
for unit in pairs(E.db.unitframe.units) do
if E.db.unitframe.units[unit].customTexts then
for objectName in pairs(E.db.unitframe.units[unit].customTexts) do
CreateCustomTextGroup(unit, objectName)
end
end
end
end
E:RefreshCustomTextsConfigs()