Compare commits

..

No commits in common. "159346814bd18497daa38ce45b04a7d5d7b6b003" and "2d311af09f021913f61bc36318cd87b5acd25f40" have entirely different histories.

2 changed files with 131 additions and 155 deletions

View file

@ -1,4 +1,4 @@
local wezterm = require("wezterm")
local wezterm = require('wezterm')
local config = {
@ -6,16 +6,16 @@ local config = {
webgpu_preferred_adapter = {
backend = "Vulkan",
device_type = "DiscreteGpu",
name = "NVIDIA GeForce GTX 1070 Ti",
name = "NVIDIA GeForce GTX 1070 Ti"
},
enable_wayland = false,
font = wezterm.font("Monaspace Krypton"),
font = wezterm.font 'Monaspace Krypton',
font_size = 12.0,
window_background_opacity = 0.6,
text_background_opacity = 1.0,
enable_tab_bar = false,
color_scheme = "tokyonight",
window_padding = { top = 20, bottom = 20, left = 20, right = 20 },
color_scheme = 'tokyonight',
window_padding = {top = 20, bottom = 20, left = 20, right = 20}
}
return config

View file

@ -1,32 +1,25 @@
function Manager:render(area)
self.area = area
local chunks = ui.Layout()
:direction(ui.Layout.HORIZONTAL)
:constraints({
local chunks = ui.Layout():direction(ui.Layout.HORIZONTAL):constraints({
ui.Constraint.Ratio(MANAGER.ratio.parent, MANAGER.ratio.all),
ui.Constraint.Ratio(MANAGER.ratio.current, MANAGER.ratio.all),
ui.Constraint.Ratio(MANAGER.ratio.preview, MANAGER.ratio.all),
})
:split(area)
ui.Constraint.Ratio(MANAGER.ratio.preview, MANAGER.ratio.all)
}):split(area)
local bar = function(c, x, y)
return ui.Bar(
ui.Rect({
return ui.Bar(ui.Rect {
x = math.max(0, x),
y = math.max(0, y),
w = math.min(1, area.w),
h = math.min(1, area.h),
}),
ui.Bar.TOP
):symbol(c)
h = math.min(1, area.h)
}, ui.Bar.TOP):symbol(c)
end
return ya.flat({
return ya.flat {
-- Borders
ui.Border(area, ui.Border.ALL):type(ui.Border.ROUNDED),
ui.Bar(chunks[1], ui.Bar.RIGHT),
ui.Bar(chunks[3], ui.Bar.LEFT),
ui.Bar(chunks[1], ui.Bar.RIGHT), ui.Bar(chunks[3], ui.Bar.LEFT),
bar("", chunks[1].right - 1, chunks[1].y),
bar("", chunks[1].right - 1, chunks[1].bottom - 1),
@ -34,8 +27,8 @@ function Manager:render(area)
bar("", chunks[2].right, chunks[1].bottom - 1), -- Parent
Parent:render(chunks[1]: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))),
})
Preview:render(chunks[3]:padding(ui.Padding.xy(1)))
}
end
Status = {area = ui.Rect.default}
@ -52,54 +45,41 @@ end
function Status:mode()
local mode = tostring(cx.active.mode):upper()
if mode == "UNSET" then
mode = "UN-SET"
end
if mode == "UNSET" then mode = "UN-SET" end
local style = self.style()
return ui.Line({
return ui.Line {
ui.Span(THEME.status.separator_open):fg(style.bg),
ui.Span(" " .. mode .. " "):style(style),
})
ui.Span(" " .. mode .. " "):style(style)
}
end
function Status:size()
local h = cx.active.current.hovered
if h == nil then
return ui.Line({})
end
if h == nil then return ui.Line {} end
local style = self.style()
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(THEME.status.separator_close):fg(THEME.status.separator_style.fg),
})
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(THEME.status.separator_close):fg(THEME.status.separator_style.fg)
}
end
function Status:name()
local h = cx.active.current.hovered
if h == nil then
return ui.Span("")
end
if h == nil then return ui.Span("") end
local linked = ""
if h.link_to ~= nil then
linked = " -> " .. tostring(h.link_to)
end
if h.link_to ~= nil then linked = " -> " .. tostring(h.link_to) end
return ui.Span(" " .. h.name .. linked)
end
function Status:permissions()
local h = cx.active.current.hovered
if h == nil then
return ui.Line({})
end
if h == nil then return ui.Line {} end
local perm = h.cha:permissions()
if perm == nil then
return ui.Line({})
end
if perm == nil then return ui.Line {} end
local spans = {}
for i = 1, #perm do
@ -134,10 +114,11 @@ function Status:percentage()
end
local style = self.style()
return ui.Line({
ui.Span(" " .. THEME.status.separator_open):fg(THEME.status.separator_style.fg),
ui.Span(percent):fg(style.bg):bg(THEME.status.separator_style.bg),
})
return ui.Line {
ui.Span(" " .. THEME.status.separator_open):fg(THEME.status
.separator_style.fg),
ui.Span(percent):fg(style.bg):bg(THEME.status.separator_style.bg)
}
end
function Status:position()
@ -145,39 +126,34 @@ function Status:position()
local length = #cx.active.current.files
local style = self.style()
return ui.Line({
return ui.Line {
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
function Status:render(area)
self.area = area
local left = ui.Line({ self:mode(), self:size(), self:name() })
local right = ui.Line({
self:owner(),
self:permissions(),
self:percentage(),
self:position(),
})
local left = ui.Line {self:mode(), self:size(), self:name()}
local right = ui.Line {
self:owner(), self:permissions(), self:percentage(), self:position()
}
return {
ui.Paragraph(area, {left}),
ui.Paragraph(area, {right}):align(ui.Paragraph.RIGHT),
table.unpack(Progress:render(area, right:width())),
table.unpack(Progress:render(area, right:width()))
}
end
function Status:owner()
local h = cx.active.current.hovered
if h == nil or ya.target_family() ~= "unix" then
return ui.Line({})
end
if h == nil or ya.target_family() ~= "unix" then 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(":"),
ui.Span(ya.group_name(h.cha.gid) or tostring(h.cha.gid)):fg("magenta"),
ui.Span(" "),
})
ui.Span(" ")
}
end