init: fmt

This commit is contained in:
notohh 2024-01-22 08:34:29 -05:00
parent 6efe8282ce
commit 635457948c
Signed by: notohh
GPG key ID: BD47506D475EE86D

View file

@ -1,45 +1,37 @@
function Manager:render(area) function Manager:render(area)
self.area = area self.area = area
local chunks = ui.Layout() local chunks = ui.Layout():direction(ui.Layout.HORIZONTAL):constraints({
:direction(ui.Layout.HORIZONTAL)
:constraints({
ui.Constraint.Ratio(MANAGER.ratio.parent, MANAGER.ratio.all), ui.Constraint.Ratio(MANAGER.ratio.parent, MANAGER.ratio.all),
ui.Constraint.Ratio(MANAGER.ratio.current, MANAGER.ratio.all), ui.Constraint.Ratio(MANAGER.ratio.current, MANAGER.ratio.all),
ui.Constraint.Ratio(MANAGER.ratio.preview, MANAGER.ratio.all), ui.Constraint.Ratio(MANAGER.ratio.preview, MANAGER.ratio.all)
}) }):split(area)
:split(area)
local bar = function(c, x, y) local bar = function(c, x, y)
return ui.Bar( return ui.Bar(ui.Rect {
ui.Rect { x = math.max(0, x), y = math.max(0, y), w = math.min(1, area.w), h = math.min(1, area.h) }, x = math.max(0, x),
ui.Bar.TOP y = math.max(0, y),
):symbol(c) w = math.min(1, area.w),
h = math.min(1, area.h)
}, ui.Bar.TOP):symbol(c)
end end
return ya.flat { return ya.flat {
-- Borders -- Borders
ui.Border(area, ui.Border.ALL):type(ui.Border.ROUNDED), ui.Border(area, ui.Border.ALL):type(ui.Border.ROUNDED),
ui.Bar(chunks[1], ui.Bar.RIGHT), ui.Bar(chunks[1], ui.Bar.RIGHT), ui.Bar(chunks[3], ui.Bar.LEFT),
ui.Bar(chunks[3], ui.Bar.LEFT),
bar("", chunks[1].right - 1, chunks[1].y), bar("", chunks[1].right - 1, chunks[1].y),
bar("", chunks[1].right - 1, chunks[1].bottom - 1), bar("", chunks[1].right - 1, chunks[1].bottom - 1),
bar("", chunks[2].right, chunks[2].y), bar("", chunks[2].right, chunks[2].y),
bar("", chunks[2].right, chunks[1].bottom - 1), bar("", chunks[2].right, chunks[1].bottom - 1), -- Parent
Parent:render(chunks[1]:padding(ui.Padding.xy(1))), -- Current
-- Parent Current:render(chunks[2]:padding(ui.Padding.y(1))), -- Preview
Parent:render(chunks[1]:padding(ui.Padding.xy(1))), Preview:render(chunks[3]:padding(ui.Padding.xy(1)))
-- Current
Current:render(chunks[2]:padding(ui.Padding.y(1))),
-- Preview
Preview:render(chunks[3]:padding(ui.Padding.xy(1))),
} }
end end
Status = { Status = {area = ui.Rect.default}
area = ui.Rect.default,
}
function Status.style() function Status.style()
if cx.active.mode.is_select then if cx.active.mode.is_select then
@ -53,52 +45,41 @@ end
function Status:mode() function Status:mode()
local mode = tostring(cx.active.mode):upper() local mode = tostring(cx.active.mode):upper()
if mode == "UNSET" then if mode == "UNSET" then mode = "UN-SET" end
mode = "UN-SET"
end
local style = self.style() local style = self.style()
return ui.Line { return ui.Line {
ui.Span(THEME.status.separator_open):fg(style.bg), ui.Span(THEME.status.separator_open):fg(style.bg),
ui.Span(" " .. mode .. " "):style(style), ui.Span(" " .. mode .. " "):style(style)
} }
end end
function Status:size() function Status:size()
local h = cx.active.current.hovered local h = cx.active.current.hovered
if h == nil then if h == nil then return ui.Line {} end
return ui.Line {}
end
local style = self.style() local style = self.style()
return ui.Line { return ui.Line {
ui.Span(" " .. ya.readable_size(h:size() or h.cha.length) .. " "):fg(style.bg):bg(THEME.status.separator_style.bg), ui.Span(" " .. ya.readable_size(h:size() or h.cha.length) .. " "):fg(
ui.Span(THEME.status.separator_close):fg(THEME.status.separator_style.fg), style.bg):bg(THEME.status.separator_style.bg),
ui.Span(THEME.status.separator_close):fg(THEME.status.separator_style.fg)
} }
end end
function Status:name() function Status:name()
local h = cx.active.current.hovered local h = cx.active.current.hovered
if h == nil then if h == nil then return ui.Span("") end
return ui.Span("")
end
local linked = "" local linked = ""
if h.link_to ~= nil then if h.link_to ~= nil then linked = " -> " .. tostring(h.link_to) end
linked = " -> " .. tostring(h.link_to)
end
return ui.Span(" " .. h.name .. linked) return ui.Span(" " .. h.name .. linked)
end end
function Status:permissions() function Status:permissions()
local h = cx.active.current.hovered local h = cx.active.current.hovered
if h == nil then if h == nil then return ui.Line {} end
return ui.Line {}
end
local perm = h.cha:permissions() local perm = h.cha:permissions()
if perm == nil then if perm == nil then return ui.Line {} end
return ui.Line {}
end
local spans = {} local spans = {}
for i = 1, #perm do for i = 1, #perm do
@ -134,8 +115,9 @@ function Status:percentage()
local style = self.style() local style = self.style()
return ui.Line { return ui.Line {
ui.Span(" " .. THEME.status.separator_open):fg(THEME.status.separator_style.fg), ui.Span(" " .. THEME.status.separator_open):fg(THEME.status
ui.Span(percent):fg(style.bg):bg(THEME.status.separator_style.bg), .separator_style.fg),
ui.Span(percent):fg(style.bg):bg(THEME.status.separator_style.bg)
} }
end end
@ -146,7 +128,7 @@ function Status:position()
local style = self.style() local style = self.style()
return ui.Line { return ui.Line {
ui.Span(string.format(" %2d/%-2d ", cursor + 1, length)):style(style), ui.Span(string.format(" %2d/%-2d ", cursor + 1, length)):style(style),
ui.Span(THEME.status.separator_close):fg(style.bg), ui.Span(THEME.status.separator_close):fg(style.bg)
} }
end end
@ -154,24 +136,24 @@ function Status:render(area)
self.area = area self.area = area
local left = ui.Line {self:mode(), self:size(), self:name()} local left = ui.Line {self:mode(), self:size(), self:name()}
local right = ui.Line { self:owner(), self:permissions(), self:percentage(), self:position() } local right = ui.Line {
self:owner(), self:permissions(), self:percentage(), self:position()
}
return { return {
ui.Paragraph(area, {left}), ui.Paragraph(area, {left}),
ui.Paragraph(area, {right}):align(ui.Paragraph.RIGHT), ui.Paragraph(area, {right}):align(ui.Paragraph.RIGHT),
table.unpack(Progress:render(area, right:width())), table.unpack(Progress:render(area, right:width()))
} }
end end
function Status:owner() function Status:owner()
local h = cx.active.current.hovered local h = cx.active.current.hovered
if h == nil or ya.target_family() ~= "unix" then if h == nil or ya.target_family() ~= "unix" then return ui.Line {} end
return ui.Line {}
end
return ui.Line { return ui.Line {
ui.Span(ya.user_name(h.cha.uid) or tostring(h.cha.uid)):fg("magenta"), ui.Span(ya.user_name(h.cha.uid) or tostring(h.cha.uid)):fg("magenta"),
ui.Span(":"), ui.Span(":"),
ui.Span(ya.group_name(h.cha.gid) or tostring(h.cha.gid)):fg("magenta"), ui.Span(ya.group_name(h.cha.gid) or tostring(h.cha.gid)):fg("magenta"),
ui.Span(" "), ui.Span(" ")
} }
end end