This plugin provide some shortcuts which give Logseq a feeling of VIM-like.
j
: Move to next line, in visual block mode it is for selecting down.k
: Move to previous line in visual block mode it is for selecting up.h
: Outdent.l
: Indent.J
: Move to next sibling, in visual block mode it is for moving down.K
: Move to previous sibling, in visual block node it is for moving up.H
: Highlight focus out to parent level.L
: Highlight focus into child level.i
: Enter edit mode, put the cursor to the end, and alsoa
can do the same thing.I
: Enter edit mode, put the cursor to the start.yy
: Copy current block content. Only support one block, multi blocks copy please usecmd+c
.Y
: Copy current block ref.p
: Paste clipboard content to next sibling. Only support one block, multi blocks paste please usecmd+v
.P
: Paste clipboard content to previous sibling. Only support one block, multi blocks paste please usecmd+v
.o
: Insert a empty block to next sibling.O
: Insert a empty block to previous sibling.dd
: Delete current block, child blocks will also be deleted, but only current block content in the clipboard.T
: Scroll to top, because Logseq use gg to go to graph view.G
: Scroll to bottom.u
: Undo.ctrl+r
: Redo.gu
: Change block content to lower case.gU
: Change block content to upper case.mod+shift+u
: Toggle block content to lower case or upper case.NUMBER
+mod+shift+u
: Trigger different case style, support 1~16.zo
: Extend block.zm
: Collapse block.NUMBER
+m
: Save current page or block as a mark to NUMBER register.NUMBER
+'
: Load saved mark on main region.NUMBER
+mod+'
: Load saved mark on right sidebar.cmd+j cmd+j
: Exit editing mode, alsoctrl+[
can do the same thing.mod+alt+j
: Join next sibling block.mod+shift+enter
: Jumping into internal page or tag.mod+shift+;
: Trigger command mode, provide many handy commands to use, explain below./
: Trigger the search in page panel.sb
: Search block content in Baidu.se
: Search block content in Wikipedia.sg
: Search block content in Google.sh
: Search block content in Github.ss
: Search block content in Stackoverflow.sy
: Search block content in Youtube.ctrl+v
: Toggle visual block mode.ctrl+e
: Trigger emoji picker UI.
A block is focused/highlighted.
You can edit a block
You can select more blocks up and down and move the selected blocks using j
and k
In VIM this mode can be triggered by :
, but here, the shortcut is mod+shift+;
, also can be memorized as mod+:
, After trigger, you can find a input area at the bottom, you can input some commands here like in VIM. For now it's about 10+ commands, but I believe that would be more.
- Autosuggestion when you input.
- Press
Tab
if only one command matched, the matched command will be autocompleted right away. - Press
Up
andDown
to traverse command history, it's a 1000 limit history, I think it's enough to use. - Press
Esc
to close command mode and back to the main window. For now Logseq can not get focused automatically sometime. so you need to click the main window to continue. - Just in case bug stuck, there are
Run
button andClose
at bottom right to help you trigger behaviors.
:s/
and:substitute/
: Replace current block according regex, e.g.s/foo/bar/gi
, Notice it support Regex modifiers.:%s/
a nd:%substitute/
: Replace current page blocks according regex, e.g.%s/foo/bar/gi
.:marks
: Show marks.:delm
and:delmarks
: Delete specific mark ids, e.g.:delm 1 2 3
.:delm!
and:delmarks!
: Delete all marks.:m
and:mark
: Go to specific mark, e.g.:m 1
.:go
: Go to existed page or block, e.g.:go 2022-02-22
or:go ((6219c981-256a-4464-bc62-4ecfab4c2141))
.- There are some shortcuts for page name:
:go @
and:go @index
: Go to Contents page:go @today
Go to today's journal page.:go @yesterday
Go to yesterday's journal page.:go @tomorrow
Go to tomorrow's journal page.:go @prev
Go to prev-day's journal page, if currect page is not a journal page, fallback to @yesterday.:go @next
Go to next-day's journal page, if currect page is not a journal page, fallback to @tomorrow.:go @back
Go to backward page.:go @forward
Go to forward page.
- There are some shortcuts for page name:
:go!
: Go to existed page or block, create one if page not exist, e.g.:go 2022-02-22
or:go ((6219c981-256a-4464-bc62-4ecfab4c2141))
.:re
and:rename
: Rename current page name, if target page exists, page content will be merged.:undo
and:redo
: Undo and redo last edit.:lorem
and:lorem-ipsum
: generate random blocks in same level, with--unit word|paragraph|sentence
to change random block unit.--unit
has a short style as-u
word
,paragraph
andsentence
also have short styles asw
,p
, ands
.
:emo
a nd:emoji
: Insert emojis by searching keyword, you can repeat emoji by appending a number.:w
and:write
: Save current page, actually this is a fake one, because Logseq save automatically.:wq
: Save current page and quit vim command mode.:q
and:quit
: Quit vim command mode.:option-trigger-autocomplete-on-focus
: Option: enable showing autocomplete list when input just get focused.:option-no-trigger-autocomplete-on-focus
: Options: disable showing autocomplete list when input just get focused.h
andhelp
: Show a help message modal.
1
: Toggle upper and lower case, the default behavior.2
: Change to upper case. e.g.LOGSEQ IS SO AWESOME
3
: Change to lower case. e.g.logseq is so awesome
4
: Change to title case. e.g.Logseq Is so Awesome
5
: Change to sentence case. e.g.Logseq is so awesome
6
: Change to path case. e.g.logseq/is/so/awesome
7
: Change to capital case. e.g.Logseq Is So Awesome
8
: Change to constant case. e.g.LOGSEQ_IS_SO_AWESOME
9
: Change to dot case. e.g.logseq.is.so.awesome
10
: Change to header case. e.g.Logseq-Is-So-Awesome
11
: Change to param case. e.g.logseq-is-so-awesome
12
: Change to pascal case. e.g.LogseqIsSoAwesome
13
: Change to camel case. e.g.logseqIsSoAwesome
14
: Change to snake case. e.g.logseq_is_so_awesome
15
: Change to swap case. e.g.lOGSEQ IS SO AWESOME
16
: Change to random case. e.g.logsEQ IS SO awESoME
- Logseq have
Favorites
andRecent
feature, and we also have aTabs
plugins, the mark feature kind of like Tabs position, but give the power to yourself to decide which is which, that feels good to me. - Marked pages and blocks can be persisted automatically and graph separately.
- NUMBER can be more than 10, actually thousands if you wish.
- The
m
shortcut could be conflicted withMarkmap
plugin, so if you met this issue, please upgradeMarkmap
plugin to latest version. - NUMBER=1 is the default one, so you can just press
m
to save and press'
to load for mark 1.
- Logseq keybindings support may be changed in future, so just use it for a while if you need it, and it may be conflicted with Logseq future shortcuts.
- Not exactly same with VIM key-bindings, just mimic.
- If you are on journal home page, some shortcuts will redirect you to specific page, because there is no API can stay journal home page and move block highlight line.
- Some shortcuts are not perfect for now, maybe need more polish and some support from Logseq Team.
- There may be more shortcuts coming soon.
- Stay tuned.
- Copy here not means copy to system clipboard, just in memory of Logseq.
- The
VIM
scroll to top shortcut isgg
, if you want it, you can change Logseq gg shortcut to another one, and set gg in plugin settings JSON file. - Some shortcuts support VIM-like combo actions, that means pressing
N+action
to run actionN
times. - The join shortcuts can only join siblings without children blocks and should not be trigger too fast in editing mode.
- Jumping internal page support combo action to select which page to jump.
- All actions support multiple key bindings in settings JSON file.
mod
meansCmd
on Mac,Ctrl
on Windows/Linux.- Recommend version of Logseq is
v0.5.9
+.
If this plugin solve your situation a little bit and you will, you can choose to buy me a coffee via this and this, that means a lot to me.
MIT