Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rhysd/vim-notes-cli
Vim plugin for notes-cli
https://github.com/rhysd/vim-notes-cli
note-taking vim vim-plugin
Last synced: 3 months ago
JSON representation
Vim plugin for notes-cli
- Host: GitHub
- URL: https://github.com/rhysd/vim-notes-cli
- Owner: rhysd
- License: mit
- Created: 2018-11-08T00:07:03.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2019-01-07T13:39:02.000Z (about 6 years ago)
- Last Synced: 2024-11-01T11:51:29.348Z (3 months ago)
- Topics: note-taking, vim, vim-plugin
- Language: Vim script
- Homepage: https://github.com/rhysd/notes-cli
- Size: 21.5 KB
- Stars: 18
- Watchers: 3
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
Vim + [notes-cli][] for Markdown note taking
============================================This is a Vim plugin to use [notes-cli][] more effectively on Vim (Vim8 or later).
![screencast](https://github.com/rhysd/ss/blob/master/vim-notes-cli/demo.gif?raw=true)
## Installation
If you use any package manager, please follow its instruction.
With [vim-plug](https://github.com/junegunn/vim-plug):
```vim
Plug 'rhysd/vim-notes-cli'
```With [dein.vim](https://github.com/Shougo/dein.vim):
```vim
call dein#add('rhysd/vim-notes-cli', {
\ 'lazy' : 1,
\ 'on_cmd' : ['Notes', 'NotesSelect', 'NotesNew', 'NotesList', 'NotesGrep'],
\ })
```With [minpac](https://github.com/k-takata/minpac):
```vim
call minpac#add('rhysd/vim-notes-cli')
```When you're using Vim's builtin packager, please follow instruction at `:help pack-add`.
Even if you didn't install [notes-cli][], you don't need to install it. vim-notes-cli automatically
installs `notes` executable and uses it locally.## Usage
You can read manual by `:help vim-notes-cli` after installation.
All commands can be completed while input. Please input `` to complete arguments.
### `:NotesSelect [{args}...]`
It selects one (or multiple) of candidates with [peco][] or [fzf][] and opens selected notes with new Vim buffers.
You can specify a command to select by `g:notes_cli_select_cmd` and how to open buffer by `g:notes_cli_edit_cmd`.All arguments are passed to `notes list` command. You can specify category and/or tags by `-c` and/or `-t` options.
**Example:** Only targets 'blog' category and 'Go' tag.
```
:NotesSelect -c blog -t Go
```And you can specify the order of list by `-s`.
**Example:** Sort the list with modified date (default is created date)
```
:NotesSelect -s modified
```### `:NotesFeelingLucky [{args}...]`
It is similar to `:NotesSelect`, but does not select one from list. It always select the first candidate like
`notes list | head -1`.
This is useful when you want to open the last created/modified note.**Example:** Open last-modified note
```
:NotesFeelingLucky
```**Example:** Open last-created note
```
:NotesFeelingLucky -s created
````{args}` is passed to `notes list` command.
### `:NotesNew [{category} [{file}]]`
It creates new note with specified category and file name. If they are omitted, it asks them interactively
with prompt.**Example:** Create 'how-to-open-file.md' with 'memo' category
```
:NotesNew memo how-to-open-file
```### `:NotesGrep [[{args}] /pattern/]`
It searches notes with `:vimgrep`. `/pattern/` is passed to first argument of `:vimgrep`. If `{args}` is given,
it is passed to `notes list` to get file paths of notes. By default, `:vimgrep` searches all notes. Please see
`:help vimgrep` for details of `:vimgrep` command.When no argument is given, it asks a pattern with propmt.
**Example:** Search 'open file' in all notes
```
:NotesGrep /open file/
```**Example:** Search 'open file' in notes tagged with 'Go'
```
:NotesGrep -t Go /open file/
```### `:NotesList [{args}...]`
It shows list of notes with colors. By default, it outputs the result of `notes --oneline`.
**Example:** Output list of note with one note per line
```
:NotesList
```**Example:** Output full information of each note (path, metadata, title, body)
```
:NotesList -f
```When the cursor is on file path, entering `` opens the note in new buffer.
### `:Notes {args}...`
It runs `notes` command with `{args}`. Command is run with `:terminal`.
**Example:** Show help of `notes` command
```
:Notes help
```**Example:** Update `notes` executable
```
:Notes selfupdate
```## License
[MIT License](LICENSE.txt)
[notes-cli]: https://github.com/rhysd/notes-cli
[peco]: https://github.com/peco/peco
[fzf]: https://github.com/junegunn/fzf