add viu
This commit is contained in:
parent
30666dca52
commit
589c03f4ec
2 changed files with 65 additions and 1 deletions
64
.config/yazi/plugins/viu.yazi/init.lua
Normal file
64
.config/yazi/plugins/viu.yazi/init.lua
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
local M = {}
|
||||||
|
|
||||||
|
function M:peek()
|
||||||
|
local child = Command("viu")
|
||||||
|
:args({
|
||||||
|
"--width",
|
||||||
|
tostring(self.area.w),
|
||||||
|
tostring(self.file.url),
|
||||||
|
})
|
||||||
|
:stdout(Command.PIPED)
|
||||||
|
:stderr(Command.PIPED)
|
||||||
|
:spawn()
|
||||||
|
|
||||||
|
if not child then
|
||||||
|
return self:fallback_to_builtin()
|
||||||
|
end
|
||||||
|
|
||||||
|
local limit = self.area.h
|
||||||
|
local i, lines = 0, ""
|
||||||
|
repeat
|
||||||
|
local next, event = child:read_line()
|
||||||
|
if event == 1 then
|
||||||
|
return self:fallback_to_builtin()
|
||||||
|
elseif event ~= 0 then
|
||||||
|
break
|
||||||
|
end
|
||||||
|
|
||||||
|
i = i + 1
|
||||||
|
if i > self.skip then
|
||||||
|
lines = lines .. next
|
||||||
|
end
|
||||||
|
until i >= self.skip + limit
|
||||||
|
|
||||||
|
child:start_kill()
|
||||||
|
if self.skip > 0 and i < self.skip + limit then
|
||||||
|
ya.manager_emit(
|
||||||
|
"peek",
|
||||||
|
{ tostring(math.max(0, i - limit)), only_if = tostring(self.file.url), upper_bound = "" }
|
||||||
|
)
|
||||||
|
else
|
||||||
|
lines = lines:gsub("\t", string.rep(" ", PREVIEW.tab_size))
|
||||||
|
ya.preview_widgets(self, { ui.Paragraph.parse(self.area, lines) })
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function M:seek(units)
|
||||||
|
local h = cx.active.current.hovered
|
||||||
|
if h and h.url == self.file.url then
|
||||||
|
local step = math.floor(units * self.area.h / 10)
|
||||||
|
ya.manager_emit("peek", {
|
||||||
|
tostring(math.max(0, cx.active.preview.skip + step)),
|
||||||
|
only_if = tostring(self.file.url),
|
||||||
|
})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function M:fallback_to_builtin()
|
||||||
|
local _, bound = ya.preview_code(self)
|
||||||
|
if bound then
|
||||||
|
ya.manager_emit("peek", { tostring(bound), only_if = tostring(self.file.url), upper_bound = "" })
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return M
|
|
@ -92,7 +92,7 @@ previewers = [
|
||||||
{ mime = "application/json", exec = "json" },
|
{ mime = "application/json", exec = "json" },
|
||||||
# Image
|
# Image
|
||||||
{ mime = "image/vnd.djvu", exec = "noop" },
|
{ mime = "image/vnd.djvu", exec = "noop" },
|
||||||
{ mime = "image/*", exec = "image" },
|
{ mime = "image/*", exec = "viu" },
|
||||||
# Video
|
# Video
|
||||||
{ mime = "video/*", exec = "video" },
|
{ mime = "video/*", exec = "video" },
|
||||||
# PDF
|
# PDF
|
||||||
|
|
Loading…
Add table
Reference in a new issue