aboutsummaryrefslogtreecommitdiff
path: root/README.md
diff options
context:
space:
mode:
Diffstat (limited to 'README.md')
-rw-r--r--README.md80
1 files changed, 23 insertions, 57 deletions
diff --git a/README.md b/README.md
index e2d7df1..3e10359 100644
--- a/README.md
+++ b/README.md
@@ -24,51 +24,37 @@ Using [lazy.nvim](https://github.com/folke/lazy.nvim):
```lua
{
url = "https://git.3kgcat.fi/muwiki.nvim",
+ keys = {
+ { "<leader>ww", function() require("muwiki").open_index("default") end, desc = "Open wiki index" },
+ },
opts = {
-- Wiki directories (REQUIRED - configure at least one)
dirs = {{ name = 'default', path = '~/wiki' }},
},
- -- No defaults, add your own:
- keys = {
- { "<leader>ww", function() require("muwiki").open_index("default") end, desc = "Open wiki index" },
- { "<CR>", function() require("muwiki").open_link() end, ft = "markdown", desc = "Open wiki link" },
- { "<Tab>", function() require("muwiki").next_link() end, ft = "markdown", desc = "Next wiki link" },
- { "<S-Tab>", function() require("muwiki").prev_link() end, ft = "markdown", desc = "Previous wiki link" },
- { "<CR>", function() require("muwiki").create_link() end, ft = "markdown", mode = "v", desc = "Create wiki link from selection" },
- },
-}
-```
-
-## Keymaps
-
-Configure keymaps using lazy.nvim's `keys` option or set them up manually:
-
-**Keymaps (lazy.nvim):**
-```lua
-keys = {
- { "<CR>", function() require("muwiki").open_link() end, ft = "markdown" },
- { "<Tab>", function() require("muwiki").next_link() end, ft = "markdown" },
- { "<S-Tab>", function() require("muwiki").prev_link() end, ft = "markdown" },
- { "<CR>", function() require("muwiki").create_link() end, ft = "markdown", mode = "v" },
-}
-```
-**Manual setup (for other plugin managers):**
-```lua
--- Set up your own autocmds
-vim.api.nvim_create_autocmd('BufEnter', {
- pattern = '*.md',
- callback = function()
- vim.keymap.set('n', '<CR>', require('muwiki').open_link, { buffer = true })
- vim.keymap.set('n', '<Tab>', require('muwiki').next_link, { buffer = true })
- vim.keymap.set('n', '<S-Tab>', require('muwiki').prev_link, { buffer = true })
- vim.keymap.set('v', '<CR>', require('muwiki').create_link, { buffer = true })
+ -- autogroup only loads keymaps in wiki files
+ config = function(_, opts)
+ local muwiki = require('muwiki')
+ muwiki.setup(opts)
+
+ local group = vim.api.nvim_create_augroup("MuWikiKeymaps", { clear = true })
+
+ vim.api.nvim_create_autocmd("FileType", {
+ group = group,
+ pattern = "markdown",
+ callback = function(ev)
+ if not muwiki.wiki_root(ev.buf) then return end
+ local keymap_opts = { buffer = ev.buf, silent = true, nowait = true }
+ vim.keymap.set('n', '<CR>', muwiki.open_link, keymap_opts)
+ vim.keymap.set('n', '<Tab>', muwiki.next_link, keymap_opts)
+ vim.keymap.set('n', '<S-Tab>', muwiki.prev_link, keymap_opts)
+ vim.keymap.set('v', '<CR>', muwiki.create_link, keymap_opts)
+ end,
+ })
end,
-})
+}
```
-Note: Actions check if the buffer is within a configured wiki directory and do nothing if not.
-
**Available actions:**
- `open_link()` - Open link under cursor
@@ -151,26 +137,6 @@ external_handlers = {
**Note:** Files with extensions in `text_extensions` will always open in Neovim, bypassing external handlers.
-## Automatic Directory Creation
-
-Automatically create missing parent directories when creating wiki files with nested paths:
-
-```lua
--- Example: [Project notes](projects/myapp/notes.md)
--- Will create projects/myapp/ directory if it doesn't exist
-
-create_missing_dirs = 'notify', -- or 'silent', 'prompt', or false (default)
-```
-
-**Options:**
-
-- `false` - Don't create directories (default)
-- `true` or `'notify'` - Create directories and show notification
-- `'silent'` - Create directories without notification
-- `'prompt'` - Ask before creating directories
-
-**Security:** Directories are only created within your configured wiki root directories.
-
## Recommended Plugins
These plugins work well with muwiki.nvim: