This is a note taking plugin for Neovim, aiming to help you quickly create, delete, read, and edit notes.
A note can be associated with current cursor line, or current working directory, or be put in global. Thus, for example, a typical use case is that when you are reading source code, you can quickly create note associated with the cursor line where the source code may confuse you, then write down some notes and continue reading. A while later, when you want to read the note you have created at that cursor line, just go back to that cursor line and open the note associated with it.
🎉 All main features have already been implemented. New features may probabily be introduced after fixing potential bugs, optimizing, and writing instruction/tutorial.
- In-place notes: no worrying about jumpping out of current workflow to take notes or managing the notes tediously. Just take notes in-place and make the notes associate with current cursor line, working directory or global directory.
- Jump between notes: easily jump between notes in current buffer.
- List notes: list the notes you have writen.
- Delete notes: delete notes you do not need quickly and in-place
- Export notes: export all notes in current buffer, working directory, or global directory to your destination folder.
- Import notes: import all notes for current buffer, working directory, or global directory from your external note folder.
- Signs: signs show you which line is associated with a note.
- Portable: notes can be portable, stored at
.quicknote
folder at your CWD.
Use any plugin manager you like.
Note: This plugin uses nvim-lua/plenary.nvim, thus please make sure it is in the dependencies or in your plugin list.
For lazy.nvim plugin manager:
require("lazy").setup({
{ "RutaTang/quicknote.nvim", config=function()
-- you must call setup to let quicknote.nvim works correctly
require("quicknote").setup({})
end
, dependencies = { "nvim-lua/plenary.nvim"} },
})
Currently, there are only two config options, but more options might be coming.
require("lazy").setup({
{ "RutaTang/quicknote.nvim", config=function()
require("quicknote").setup({
mode = "portable", -- "portable" | "resident", default to "portable"
sign = "N" -- This is used for the signs on the left side (refer to ShowNoteSigns() api).
-- You can change it to whatever you want (eg. some nerd fonts icon), 'N' is default
})
end
, dependencies = { "nvim-lua/plenary.nvim"} },
})
- Open a file.
- At a certain line, in Command-line mode, run
:lua require('quicknote').NewNoteAtCurrentLine()
. Now, a note has been created and associated with current cursor line. But you do not see any signs on the left side now. - At the same line, in Command-line mode, run
:lua require('quicknote').ShowNoteSigns()
. Now you can say a sign just on the left side at the current cursor line, which shows you that the note you have created is at this line. - At the same line, when you want to reread or edit the note you just created, run
:lua require('quicknote').OpenNoteAtCurrentLine()
. Now, the note will be opened and you can edit it. It is just a markdown file.
Whenever you create a note associated to the current cursor line, CWD or global, a folder named by the hashed path of current buffer or CWD will be created and I call it "Note Directory" which will store all your notes associated with a certain buffer, CWD or global (Global note directory is not hashed and just named as "global").
For example, when you create a note at line 2 in a file named hello_world.lua
, you will have a "Note Directory" created at "Data Path" (in "resident" mode, it is vim.fn.stdpath("state") .. "/quicknote"
; in "portable" mode, it is ".quicknote" at root of your CWD). In the "Data Path", you will see a folder with hashed name, and if you open it, you will see "2.md" which is the note you have just created for this file and "2" means it is associated with line 2.
There are two modes in quicknote.nvim, "resident" mode and "protable" mode. They are almost similar. The big differences are:
Global
API: in resident mode, you can use API ended withGlobal
and notes stored globally can be accessed whenever you use Neovim, even if you are not in the working directory where you created your notes. In portable note, you can not use API ended withGlobal
.- Pollution or not:In resident mode, all notes, regardless of whether they are associated with files, CWD or global, will be put in
$XDG_STATE_PATH
and will never pollute your project. But in portable mode, since notes will be located in the.quicknote
folder in your CWD, it may pollute your project if you consider it as a "pollution". - Portable or not: In resident mode, the notes you have created will be hard to transfer to another computer. And if you move project which have notes associated with it to another computer or even another directory, all notes associated with it will be lost. But in protable note, you can transfer your project from one path to another or from one computer to another without worrying about lossing notes. You can even share the project with notes to your colleagues or friends who use Neovim and this plugin. They will be able to see the notes you have created.
I do not want to break any APIs when you are using this plugin, but it is still possible if some APIs are not rational or potential bugs force them to be changed. I may use semantic versioning later to avoid breaking APIs in the major version.
- New note
Function | Description |
---|---|
NewNoteAtCWD() |
create a note at current working directory |
NewNoteAtLine(line) |
create a note at a give line |
NewNoteAtCurrentLine() |
create a note at current cursor line |
NewNoteAtGlobal |
create a note which can be accessed globally |
- Open note
Function | Description |
---|---|
OpenNoteAtCWD() |
open a note at CWD, you will input the name of the note |
OpenNoteAtLine(line) |
open a note associated with a given line |
OpenNoteAtCurrentLine() |
open a note associated with the current cursor line |
OpenNoteAtGlobal() |
open a note in global, you will input the name of the note |
- Delete note
Function | Description |
---|---|
DeleteNoteAtCWD() |
delete a note at CWD, you will input the name of the note |
DeleteNoteAtLine(line) |
delete a note associated with a given line |
DeleteNoteAtCurrentLine() |
delete a note associated with the current cursor line |
DeleteNoteAtGlobal() |
delete a note in global, you will input the name of the note |
- List note
Funtion | Description |
---|---|
ListNotesForCurrentBuffer() |
list all notes associated with current buffer |
ListNotesForCWD() |
list all notes created in CWD |
ListNotesForGlobal() |
list all notes in global |
ListNotesForAFileOrWDInCWD() |
list all notes for a certain file or directory under CWD |
- Jump to note
Function | Description |
---|---|
JumpToNextNote() |
jump to next avaiable note in current buffer |
JumpToPreviousNote() |
jump to previous avaiable note in current buffer |
- Notes count
Function | Description |
---|---|
GetNotesCountForCurrentBuffer() |
get notes count for current buffer |
GetNotesCountForCWD() |
get notes count for CWD |
GetNotesCountForGlobal() |
get notes count for global |
- Signs
Funtion | Description |
---|---|
ShowNoteSigns() |
show signs for current buffer |
HideNoteSigns() |
hide signs for current buffer |
ToggleNoteSigns() |
toggle signs |
- Export notes
Funtion | Description |
---|---|
ExportNotesForCurrentBuffer() |
export all notes associated with the current buffer to a destination dir |
ExportNotesForCWD() |
export all notes associated with CWD, but notes associated with the files under CWD are not exported |
ExportNotesForGlobal() |
export all notes that have been put in global |
- Import notes
Funtion | Description |
---|---|
ImportNotesForCurrentBuffer() |
import notes from external note folder to current buffer |
ImportNotesForCWD() |
import notes from external note folder to CWD |
ImportNotesForGlobal() |
import notes from external note folder to global |
- Switch Mode
Funtion | Description |
---|---|
SwitchToResidentMode() |
swicth to resident mode |
SwitchToPortableMode() |
switch to portable mode |
ToggleMode() |
toggle mode |
For example, you can use the code below to map a key to one of the function above:
vim.api.nvim_set_keymap("n", "<leader>p", "<cmd>:lua require('quicknote').NewNoteAtCurrentLine()<cr>",{})