Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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

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