Skip to content

Commit

Permalink
fix: handle base64 separately from file path (#53)
Browse files Browse the repository at this point in the history
  • Loading branch information
HakonHarnes authored Mar 21, 2024
1 parent 5a8efb3 commit 22f1870
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 1 deletion.
51 changes: 51 additions & 0 deletions lua/img-clip/markup.lua
Original file line number Diff line number Diff line change
Expand Up @@ -128,4 +128,55 @@ function M.insert_markup(file_path, opts)
return true
end

---@param base64 string the file path or base64 string
---@param opts? table
---@return boolean
function M.insert_base64_markup(base64, opts)
-- pass args to template
local template_args = {
file_path = "",
file_name = "",
file_name_no_ext = "",
cursor = "$CURSOR",
label = "",
}
local template = config.get_opt("template", opts, template_args)
if not template then
return false
end

template = template:gsub("$FILE_NAME_NO_EXT", "")
template = template:gsub("$FILE_NAME", "")
template = template:gsub("$FILE_PATH", base64)
template = template:gsub("$LABEL", "")

if not config.get_opt("use_cursor_in_template", opts) then
template = template:gsub("$CURSOR", "")
end

local lines = M.split_lines(template)

local cur_pos = vim.api.nvim_win_get_cursor(0)
local cur_row = cur_pos[1]

local new_row, line, index = M.get_new_cursor_row(cur_row, lines)
local new_col = M.get_new_cursor_col(line)

lines[index] = line:gsub("$CURSOR", "")

vim.api.nvim_put(lines, "l", true, true)

vim.api.nvim_win_set_cursor(0, { new_row, new_col })

if config.get_opt("insert_mode_after_paste", opts) and vim.api.nvim_get_mode().mode ~= "i" then
if new_col == string.len(line) - 1 then
vim.api.nvim_input("a")
else
vim.api.nvim_input("i")
end
end

return true
end

return M
2 changes: 1 addition & 1 deletion lua/img-clip/paste.lua
Original file line number Diff line number Diff line change
Expand Up @@ -196,7 +196,7 @@ M.embed_image_as_base64 = function(file_path, opts)
end

local prefix = M.get_base64_prefix()
if not markup.insert_markup(prefix .. base64, opts) then
if not markup.insert_base64_markup(prefix .. base64, opts) then
util.error("Could not insert markup code.")
return false
end
Expand Down

0 comments on commit 22f1870

Please sign in to comment.