-- Add the key mappings only for Markdown files in a zk notebook. -- if require('zk.util').notebook_root(vim.fn.expand('%:p')) ~= nil then local function map(...) vim.api.nvim_buf_set_keymap(0, ...) end local opts = { noremap = true, silent = false } map("n", "", "lua vim.lsp.buf.definition()", opts) -- Create a new note after asking for its title. -- This overrides the global `zn` mapping to create the note in the same directory as the current buffer. vim.keymap.set('n', 'zn', "ZkNew { dir = vim.fn.expand('%:p:h'), title = vim.fn.input('Title: ') }", { noremap = true, silent = false, desc = 'Create a new note' }) -- Create a new note in the same directory as the current buffer, using the current selection for title. vim.keymap.set('v', 'znt', ":'<,'>ZkNewFromTitleSelection { dir = vim.fn.expand('%:p:h') }", { noremap = true, silent = false, desc = 'Create a new note' }) -- Create a new note in the same directory as the current buffer, using the current selection for note content and asking for its title. map('v', 'znc', ":'<,'>ZkNewFromContentSelection { dir = vim.fn.expand('%:p:h'), title = vim.fn.input('Title: ') }", opts) -- Open notes linking to the current buffer. map('n', 'zb', 'ZkBacklinks', opts) -- Alternative for backlinks using pure LSP and showing the source context. --map('n', 'zb', 'lua vim.lsp.buf.references()', opts) -- Open notes linked by the current buffer. map('n', 'zl', 'ZkLinks', opts) -- Preview a linked note. map('n', 'K', 'lua vim.lsp.buf.hover()', opts) -- Open the code actions for a visual selection. map('v', 'za', ":'<,'>lua vim.lsp.buf.range_code_action()", opts) -- end