mirror of
https://github.com/Ascyii/telekasten.nvim.git
synced 2026-01-01 06:14:23 -05:00
add prompt before saving buffers
This commit is contained in:
@@ -1438,34 +1438,47 @@ end
|
|||||||
-- Prompt for new note title, rename the note and update all links.
|
-- Prompt for new note title, rename the note and update all links.
|
||||||
--
|
--
|
||||||
local function RenameNote()
|
local function RenameNote()
|
||||||
local oldname = Pinfo:new({ filepath = vim.fn.expand("%:p"), M.Cfg }).title
|
local oldfile = Pinfo:new({ filepath = vim.fn.expand("%:p"), M.Cfg })
|
||||||
local subdir = Pinfo:new({ filepath = vim.fn.expand("%:p"), M.Cfg }).sub_dir
|
|
||||||
|
|
||||||
local newname = vim.fn.input("New name: ")
|
local newname = vim.fn.input("New name: ")
|
||||||
newname = newname:gsub("[" .. M.Cfg.extension .. "]+$", "")
|
newname = newname:gsub("[" .. M.Cfg.extension .. "]+$", "")
|
||||||
local newpath = newname:match("(.*/)")
|
local newpath = newname:match("(.*/)")
|
||||||
|
|
||||||
-- If no subdir specified, place the new note in the same place as old note
|
-- If no subdir specified, place the new note in the same place as old note
|
||||||
if M.Cfg.subdirs_in_links == true and newpath == nil and subdir ~= "" then
|
if
|
||||||
newname = subdir .. "/" .. newname
|
M.Cfg.subdirs_in_links == true
|
||||||
|
and newpath == nil
|
||||||
|
and oldfile.sub_dir ~= ""
|
||||||
|
then
|
||||||
|
newname = oldfile.sub_dir .. "/" .. newname
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Savas newfile, delete buffer of old one and remove old file
|
-- Savas newfile, delete buffer of old one and remove old file
|
||||||
if newname ~= "" and newname ~= oldname then
|
if newname ~= "" and newname ~= oldfile.title then
|
||||||
vim.cmd("saveas " .. newname .. M.Cfg.extension)
|
vim.cmd("saveas " .. newname .. M.Cfg.extension)
|
||||||
vim.cmd("bdelete " .. oldname .. M.Cfg.extension)
|
vim.cmd("bdelete " .. oldfile.title .. M.Cfg.extension)
|
||||||
os.execute("rm " .. M.Cfg.home .. "/" .. oldname .. M.Cfg.extension)
|
os.execute(
|
||||||
|
"rm " .. M.Cfg.home .. "/" .. oldfile.title .. M.Cfg.extension
|
||||||
|
)
|
||||||
vim.cmd("redraw!")
|
vim.cmd("redraw!")
|
||||||
end
|
end
|
||||||
|
|
||||||
if M.Cfg.rename_update_links == true then
|
if M.Cfg.rename_update_links == true then
|
||||||
-- Only look for the first part of the link, so we do not touch to #heading or #^paragraph
|
-- Only look for the first part of the link, so we do not touch to #heading or #^paragraph
|
||||||
-- Should use regex instead to ensure it is a proper link
|
-- Should use regex instead to ensure it is a proper link
|
||||||
local oldlink = "\\[\\[" .. oldname
|
local oldlink = "\\[\\[" .. oldfile.title
|
||||||
local newlink = "\\[\\[" .. newname
|
local newlink = "\\[\\[" .. newname
|
||||||
|
|
||||||
-- Save all open buffers before looking for links to replace
|
-- Save all open buffers before looking for links to replace
|
||||||
|
if #(vim.fn.getbufinfo({ buflisted = 1 })) > 1 then
|
||||||
|
local answer = vim.fn.input(
|
||||||
|
"Telekasten.nvim: Save all current buffers before updating links? [Y/n]"
|
||||||
|
)
|
||||||
|
answer = vim.fn.trim(answer)
|
||||||
|
if answer ~= "n" and answer ~= "N" then
|
||||||
vim.cmd("wa")
|
vim.cmd("wa")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
recursive_substitution(M.Cfg.home, oldlink, newlink)
|
recursive_substitution(M.Cfg.home, oldlink, newlink)
|
||||||
recursive_substitution(M.Cfg.dailies, oldlink, newlink)
|
recursive_substitution(M.Cfg.dailies, oldlink, newlink)
|
||||||
|
|||||||
Reference in New Issue
Block a user