You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
DiesalLibs/DiesalGUI-2.0/Objects/AccordianSection.lua

283 lines
9.3 KiB

1 year ago
---@type Diesal.GUI
local DiesalGUI = LibStub("DiesalGUI-2.0")
---@type Diesal.Tools
local DiesalTools = LibStub("DiesalTools-2.0")
---@type Diesal.Style
local DiesalStyle = LibStub("DiesalStyle-2.0")
local Colors = DiesalStyle.Colors
local HSL, ShadeColor, TintColor = DiesalTools.HSL, DiesalTools.ShadeColor, DiesalTools.TintColor
local Type = "DiesalAccordianSection"
local Version = 3
---@type Diesal.Style.Stylesheet
local Stylesheet = {
["button-background"] = {
type = "texture",
layer = "BACKGROUND",
gradient = { "VERTICAL", Colors.UI_400_GR[1], Colors.UI_400_GR[2] },
alpha = 0.95,
position = { 0, 0, -1, 0 },
},
["button-outline"] = {
type = "outline",
layer = "BACKGROUND",
color = "000000",
position = { 1, 1, 0, 1 },
},
["button-inline"] = {
type = "outline",
layer = "ARTWORK",
gradient = { "VERTICAL", "ffffff", "ffffff" },
alpha = { 0.03, 0.02 },
position = { 0, 0, -1, 0 },
},
["button-hover"] = {
type = "texture",
layer = "HIGHLIGHT",
color = "ffffff",
alpha = 0.1,
},
["button-leftExpandIcon"] = {
type = "texture",
position = { 0, nil, -1, nil },
height = 16,
width = 16,
image = { "DiesalGUIcons", { 3, 6, 16, 256, 128 }, HSL(Colors.UI_Hue, Colors.UI_Saturation, 0.65) },
alpha = 1,
},
["button-leftCollapseIcon"] = {
type = "texture",
position = { 0, nil, -1, nil },
height = 16,
width = 16,
image = { "DiesalGUIcons", { 4, 6, 16, 256, 128 }, HSL(Colors.UI_Hue, Colors.UI_Saturation, 0.65) },
alpha = 1,
},
["content-background"] = {
type = "texture",
layer = "BACKGROUND",
color = Colors.UI_300,
alpha = 0.95,
position = { 0, 0, -1, 0 },
},
["content-topShadow"] = {
type = "texture",
layer = "ARTWORK",
gradient = { "VERTICAL", "000000", "000000" },
alpha = { 0.05, 0 },
position = { 0, 0, -1, nil },
height = 4,
},
["content-bottomShadow"] = {
type = "texture",
layer = "ARTWORK",
gradient = { "VERTICAL", "000000", "000000" },
alpha = { 0, 0.05 },
position = { 0, 0, nil, 0 },
height = 4,
},
["content-inline"] = {
type = "outline",
layer = "ARTWORK",
color = "000000",
alpha = 1,
1 year ago
position = { 0, 0, -1, 0 },
},
["text-Font"] = {
type = "font",
color = Colors.UI_F450,
},
}
local wireFrameSheet = {
["frame-white"] = {
type = "outline",
layer = "OVERLAY",
color = "ffffff",
alpha = 1,
},
["button-purple"] = {
type = "outline",
layer = "OVERLAY",
color = "aa00ff",
alpha = 0.5,
},
["content-yellow"] = {
type = "outline",
layer = "OVERLAY",
color = "fffc00",
alpha = 0.5,
},
}
---@class Diesal.GUI.Accordian.Section.Methods
local methods = {
---@param self DiesalAccordianSection
OnAcquire = function(self)
self:SetStylesheet(Stylesheet)
self:Show()
end,
---@param self DiesalAccordianSection
OnRelease = function(self) end,
---@param self DiesalAccordianSection
ApplySettings = function(self)
self.button:SetHeight(self.settings.buttonHeight)
-- postion
self:ClearAllPoints()
local subsectionXOffset = self.settings.subsection and 5 or 0
local subsectionYOffset = self.settings.subsection and -5 or 0
1 year ago
if self.settings.position == 1 then
self:SetPoint("TOPLEFT", subsectionXOffset, subsectionYOffset)
self:SetPoint("RIGHT", -subsectionXOffset, 0)
elseif self.settings.subsection then
local anchor = self.settings.parentObject.content
self:SetPoint("TOPLEFT", anchor, "BOTTOMLEFT", subsectionXOffset, subsectionYOffset)
self:SetPoint("RIGHT", -subsectionXOffset, 0)
1 year ago
else
local anchor = self.settings.parentObject.children[self.settings.position - 1].frame
self:SetPoint("TOPLEFT", anchor, "BOTTOMLEFT", subsectionXOffset, subsectionYOffset)
self:SetPoint("RIGHT", -subsectionXOffset, 0)
1 year ago
end
-- set section name
self.text:SetText(self.settings.sectionName)
-- set section state
self[self.settings.expanded and "Expand" or "Collapse"](self)
-- set button visibility
self:SetButton(self.settings.button)
end,
---@param self DiesalAccordianSection
Collapse = function(self)
if not self.settings.button then
self:UpdateHeight()
return
end
self.settings.expanded = false
self:FireEvent("OnStateChange", self.settings.position, "Collapse")
self.textures["button-leftCollapseIcon"]:SetAlpha(self.textures["button-leftCollapseIcon"].style.alpha[1])
self.textures["button-leftExpandIcon"]:SetAlpha(0)
self.content:Hide()
self:UpdateHeight()
if self.settings.subsection and self.settings.parentObject then
self.settings.parentObject:ApplySettings()
self.settings.parentObject:UpdateHeight()
end
1 year ago
end,
---@param self DiesalAccordianSection
Expand = function(self)
self.settings.expanded = true
self:FireEvent("OnStateChange", self.settings.position, "Expand")
self.textures["button-leftExpandIcon"]:SetAlpha(self.textures["button-leftExpandIcon"].style.alpha[1])
self.textures["button-leftCollapseIcon"]:SetAlpha(0)
self.content:Show()
self:UpdateHeight()
if self.settings.subsection and self.settings.parentObject then
self.settings.parentObject:ApplySettings()
self.settings.parentObject:UpdateHeight()
end
1 year ago
end,
---@param self DiesalAccordianSection
---@param state boolean
SetButton = function(self, state)
self.settings.button = state
self.button[state and "Show" or "Hide"](self.button)
if not state then
self:Expand()
else
self:UpdateHeight()
end
end,
---@param self DiesalAccordianSection | Diesal.GUI.Object.Accordian.Section
UpdateHeight = function(self)
local settings, children = self.settings, self.children
local contentHeight = 0
self.content:SetPoint("TOPLEFT", self.frame, 0, settings.button and -settings.buttonHeight or 0)
if settings.expanded then
contentHeight = settings.contentPadding[3] + settings.contentPadding[4]
for i = 1, #children do
contentHeight = contentHeight + (children[i].frame:GetHeight() * self.settings.offsetMultiplier)
1 year ago
end
end
self.content:SetHeight(contentHeight)
self:SetHeight((settings.button and settings.buttonHeight or 0) + contentHeight)
self:FireEvent("OnHeightChange", contentHeight)
end,
}
---@class DiesalAccordianSection : Diesal.GUI.Object.Accordian.Section
---@class Diesal.GUI.Object.Accordian.Section.Settings.Default
---@field button boolean
---@field contentPadding Diesal.GUI.Padding
---@field expanded boolean
---@field buttonHeight number
---@field subsection boolean
---@field offsetMultiplier number
1 year ago
---@class Diesal.GUI.Object.Accordian.Section.Settings : Diesal.GUI.Object.Accordian.Section.Settings.Default
---@field sectionName string
---@field position number
---@field parentObject Diesal.GUI.Object.Accordian
local function Constructor()
---@class Diesal.GUI.Object.Accordian.Section : Diesal.GUI.ObjectBase, Diesal.GUI.Accordian.Section.Methods
---@field button Button
---@field text Diesal.GUI.Region.FontString
---@field content Frame
---@field settings Diesal.GUI.Object.Accordian.Section.Settings
---@field defaults Diesal.GUI.Object.Accordian.Section.Settings.Default
local self = DiesalGUI:Create(Type, true)
self.isContainer = true
local frame = CreateFrame("Frame", nil, UIParent)
self.frame = frame
self.defaults = {
button = true,
contentPadding = { 0, 0, 3, 1 },
expanded = true,
buttonHeight = 16,
subsection = false,
offsetMultiplier = 1.5,
1 year ago
}
local button = self:CreateRegion("Button", "button", frame)
button:SetPoint("TOPRIGHT")
button:SetPoint("TOPLEFT")
button:SetScript("OnClick", function(this, b)
DiesalGUI:OnMouse(this, b)
self[self.settings.expanded and "Collapse" or "Expand"](self)
end)
local text = self:CreateRegion("FontString", "text", button)
text:SetPoint("TOPLEFT", 15, -2)
text:SetPoint("BOTTOMRIGHT", -15, 0)
text:SetHeight(0)
text:SetJustifyH("MIDDLE")
text:SetJustifyH("LEFT")
text:SetWordWrap(false)
local content = self:CreateRegion("Frame", "content", frame)
content:SetPoint("TOPLEFT", frame, 0, 0)
content:SetPoint("TOPRIGHT", frame, 0, 0)
content:SetHeight(10)
-- ~~ Methods ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
self:SetMethods(methods)
--[[ for method, func in pairs(methods) do
self[method] = func
end ]]
-- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
return self
end
DiesalGUI:RegisterObjectConstructor(Type, Constructor, Version)