Skip to main content

keymap.toml

note

If you want to fine-tune the default settings, the first step is to create your own configuration file.

You can change Yazi's keybindings in your keymap.toml file, which consists of the following 8 layers:

  • [manager] - File list.
  • [tasks] - Task manager.
  • [spot] - File information spotter.
  • [pick] - Pick component. e.g. "open with" for files.
  • [input] - Input component. e.g. create, rename, etc.
  • [confirm] - Confirmation dialog. e.g. remove, overwrite, etc.
  • [completion] - Completion component. e.g. "cd" path completion.
  • [help] - Help menu.

In each layer, there are two attributes: prepend_keymap and append_keymap. Prepend inserts before the default keybindings, while append inserts after them.

Since Yazi selects the first matching key to run, prepend always has a higher priority than default, and append always has a lower priority than default:

[manager]
prepend_keymap = [
{ on = "<C-a>", run = 'my-fev-command1', desc = "Just for test!" },
]
append_keymap = [
{ on = [ "g", "a" ], run = 'my-fev-command2', desc = "Just for test!" },
]

Or in another different style:

[[manager.prepend_keymap]]
on = "<C-a>"
run = 'my-fev-command1'
desc = "Just for test!"

[[manager.prepend_keymap]]
on = [ "g", "a" ]
run = 'my-fev-command2'

[[manager.append_keymap]]
on = "c"
run = 'my-fev-command3'

But keep in mind that you can only choose one of them, and it cannot be a combination of the two, as TOML language does not allow this:

[manager]
prepend_keymap = [
{ on = "<C-a>", run = 'my-fev-command1', desc = "Just for test!" },
]

[[manager.prepend_keymap]]
on = [ "g", "a" ]
run = 'my-fev-command2'
desc = "Just for test!"

When you don't need any default and want to fully customize your keybindings, use keymap, for example:

[manager]
keymap = [
# This will override all default keybindings, and just keep the two below.
{ on = "<C-a>", run = 'my-fev-command1', desc = "Just for test!" },
{ on = [ "g", "a" ], run = 'my-fev-command2', desc = "Just for test!" },
]

Key notation

You can specify one or more keys in the on of each keybinding rule, and each key can be represented with the following notations:

NotationDescriptionNotationDescription
a - zLowercase lettersA - ZUppercase letters
<Space>Space key<Backspace>Backspace key
<Enter>Enter key--
<Left>Left arrow key<Right>Right arrow key
<Up>Up arrow key<Down>Down arrow key
<Home>Home key<End>End key
<PageUp>PageUp key<PageDown>PageDown key
<Tab>Tab key<BackTab>Shift + Tab key
<Delete>Delete key<Insert>Insert key
<F1> - <F19>Function keys<Esc>Escape key

You can combine the following modifiers for the keys above:

ModifierDescription
<S-…>Shift key.
<C-…>Ctrl key.
<A-…>Alt/Meta key.
<D-…>Command/Windows/Super key.

For example:

  • <C-a> for Ctrl + a.
  • <C-S-b> or <C-B> for Ctrl + Shift + b.

Note that:

  1. Not all terminals support <D-...> - make sure your terminal supports and has CSI u enabled if you want to use it.
  2. macOS doesn't have an Alt key, so <A-...> won't work. Some terminals offer a setting to map the Option as the Alt key, make sure you have it enabled.
  3. The legacy terminal keyboard protocol treats <Tab> and <C-i>, <Enter> and <C-m>, etc. as the same key. If you want to distinguish between them, make sure your terminal supports and has CSI u enabled.

[manager]

escape

Cancel find, exit visual mode, clear selected, cancel filter, or cancel search.

Argument/OptionDescription
--allDo all the below.
--findCancel find.
--visualExit visual mode.
--selectClear selected.
--filterCancel filter.
--searchCancel search.

Automatically determine the operation by default, and it will only execute the selected operation after specifying the option; multiple options can be stacked.

quit

Exit the process.

Argument/OptionDescription
--no-cwd-fileDon't output the current directory to the file specified by yazi --cwd-file.

close

Close the current tab; if it's the last tab, exit the process instead.

Argument/OptionDescription
--no-cwd-fileDon't output the current directory to the file specified by yazi --cwd-file on exit. (Nightly only)

suspend

Pauses Yazi and returns to the parent shell to continue with other tasks.

Once those tasks are done, use the fg command of the shell to send a resume signal and return back to Yazi.

arrow

Argument/OptionDescription
[n] / [n%]Move the cursor up or down by n or n% lines. Use negative values to move up and positive values to move down.

leave

Go back to the parent directory of the hovered file, or the parent of the current working directory if no file is hovered on.

enter

Enter the child directory.

back

Go back to the previous directory.

forward

Go forward to the next directory.

seek

Scroll the contents in the preview panel.

Argument/OptionDescription
[n]Use negative values to seek up and positive values to seek down.

spot

Display file information with the preset or user-customized spotter.

cd

Change the current directory.

Argument/OptionDescription
[path]The path to change to.
--interactiveUse an interactive UI to input the path.

You can add your own g series keys to achieve a simple bookmark feature:

[[manager.prepend_keymap]]
on = [ "g", "d" ]
run = "cd ~/Downloads"
desc = "Cd to ~/Downloads"

[[manager.prepend_keymap]]
on = [ "g", "p" ]
run = "cd ~/Pictures"
desc = "Cd to ~/Pictures"

For Windows users, you can also switch drives using the cd command:

[[manager.prepend_keymap]]
on = [ "g", "d" ]
run = "cd D:"
desc = "Switch to D drive"

[[manager.prepend_keymap]]
on = [ "g", "p" ]
run = 'cd "E:\\Pictures"' # We need to escape the backslash
desc = 'Cd to E:\Pictures'

Check out the resources page for a more comprehensive bookmark plugin.

reveal

Change the current directory to the parent of specified file, and hover on it.

Argument/OptionDescription
[path]The path to reveal.

toggle

Toggle the selection state of the hovered file.

Argument/OptionDescription
N/AReverse the selection.
--state=onSelect the file.
--state=offDeselect the file.

toggle_all

Toggle the selection state of all files in the current working directory.

Argument/OptionDescription
N/AReverse the selections.
--state=onSelect the files.
--state=offDeselect the files.

Note that toggle_all --state=off only deselect the files in CWD, if you have selected files across multiple directories, and want to deselect all of them, use escape --select.

visual_mode

Enter visual mode (selection mode).

Argument/OptionDescription
--unsetEnter visual mode (unset mode).

open

Open the selected files using the rules in [open].

Argument/OptionDescription
--interactiveOpen the hovered/selected file(s) with an interactive UI to choose the opening method.
--hoveredAlways open the hovered file regardless of the selection state.

yank

Yank the selected files.

Argument/OptionDescription
--cutCut the selected files.

unyank

Cancel the yank status of files.

paste

Paste the yanked files.

Argument/OptionDescription
--forceOverwrite the destination file if it exists.
--followCopy the file pointed to by a symbolic link, rather than the link itself. Only can be used during copying.

Create a symbolic link to the yanked files. (This is a privileged action on Windows and must be run as an administrator.)

Argument/OptionDescription
--relativeUse a relative path for the symbolic link.
--forceOverwrite the destination file if it exists.

Hardlink the yanked files.

Argument/OptionDescription
--forceOverwrite the destination file if it exists.
--followHardlink the file pointed to by a symbolic link, not the symlink itself.

remove

Move the files to the trash/recycle bin on macOS/Windows. For Linux, it will follow The FreeDesktop.org Trash specification.

In the Android platform, you can only use it with the --permanently option, since there lacks the concept of a trash bin.

Argument/OptionDescription
--forceDon't show the confirmation dialog, and trash/delete files directly.
--permanentlyPermanently delete the files.
--hoveredAlways remove the hovered file regardless of the selection state.

create

Create a file or directory. Ends with / (Unix) or \ (Windows) for directories.

Argument/OptionDescription
--dirAlways create directories, regardless of whether end with / or \.
--forceOverwrite the destination file directly if it exists, without showing the confirmation dialog.

rename

Rename a file or directory, or bulk rename if multiple files are selected ($EDITOR is used to edit the filenames by default, see Specify a different editor for bulk renaming for details).

  • --hovered: Always rename the hovered file regardless of the selection state.
  • --force: Overwrite the destination file directly if it exists, without showing the confirmation dialog.
  • --empty: Empty a part of the filename.
    • "stem": Empty the stem. e.g. "foo.jpg" -> ".jpg".
    • "ext": Empty the extension. e.g. "foo.jpg" -> "foo.".
    • "dot_ext": Empty the dot and extension. e.g. "foo.jpg" -> "foo".
    • "all": Empty the whole filename. e.g. "foo.jpg" -> "".
  • --cursor: Specify the cursor position of the renaming input box.
    • "end": The end of the filename.
    • "start": The start of the filename.
    • "before_ext": Before the extension of the filename.

You can also use --cursor with --empty, for example, rename --empty=stem --cursor=start will empty the file's stem, and move the cursor to the start.

Which causes the input box content for the filename foo.jpg to be |.jpg, where "|" represents the cursor position.

copy

Copy the path of files or directories that are selected or hovered on.

Argument/OptionDescription
pathCopy the absolute path.
dirnameCopy the path of the parent directory.
filenameCopy the name of the file.
name_without_extCopy the name of the file without the extension.

shell

Run a shell command.

Argument/OptionDescription
[template]Optional, command template to be run.
--blockOpen in a blocking manner. After setting this, Yazi will hide into a secondary screen and display the program on the main screen until it exits. During this time, it can receive I/O signals, which is useful for interactive programs.
--orphanKeep the process running even if Yazi has exited, once specified, the process will be detached from the task scheduling system.
--interactiveRequest the user to input the command to be run interactively
--cursorSet the initial position of the cursor in the interactive command input box. For example, shell 'zip -r .zip "$0"' --cursor=7 --interactive places the cursor before .zip.

You can use the following shell variables in [run]:

  • $n (Unix) / %n (Windows): The N-th selected file, starting from 1. e.g. $2 represents the second selected file.
  • $@ (Unix) / %* (Windows): All selected files, i.e. $1, $2, ..., $n.
  • $0 (Unix) / %0 (Windows): The hovered file.

hidden

Set the visibility of hidden files.

Argument/OptionDescription
showShow hidden files.
hideHide hidden files.
toggleDefault, toggle the hidden state.

linemode

Set the line mode.

Argument/OptionDescription
noneNo line mode.
sizeDisplay the size in bytes of the file. Note that currently directory sizes are only evaluated when sort_by = "size", and this might change in the future.
btimeDisplay the birth time of the file.
mtimeDisplay the last modified time of the file.
permissionsDisplay the permissions of the file, only available on Unix-like systems.
ownerDisplay the owner of the file, only available on Unix-like systems.

search

Argument/OptionDescription
[engine]Search engine, available values: fd, rg, none (cancel search)
--argsAdditional arguments passed to the specified engine, for example search fd --args='-e -H'

You can search with an empty keyword ("") via fd to achieve flat view.

Demonstrate flat view

Or bind a key to the search_do command to quickly switch to the flat view:

[[manager.prepend_keymap]]
on = [ "g", "f" ]
run = 'search_do --via=fd --args="-d 3"'
desc = "Switch to the flat view with a max depth of 3"

find

Find files in the current working directory interactively and incrementally.

Argument/OptionDescription
--previousFind for the previous occurrence.
--smartUse smart-case when finding, i.e. case-sensitive if the query contains uppercase characters, otherwise case-insensitive.
--insensitiveUse case-insensitive find.

find_arrow

Move the cursor to the next or previous occurrence.

Argument/OptionDescription
--previousMove to the previous occurrence.

filter

Argument/OptionDescription
[query]Optional, the query to filter for. If not provided, an interactive UI will be used to input with.
--smartUse smart-case when filtering, i.e. case-sensitive if the query contains uppercase characters, otherwise case-insensitive.
--insensitiveUse case-insensitive filter.

sort

  • [by]: Optional, if not provided, the sort method will be kept unchanged.
    • "none": Don't sort.
    • "mtime": Sort by last modified time.
    • "btime": Sort by birth time.
    • "extension": Sort by file extension.
    • "alphabetical": Sort alphabetically, e.g. 1.md < 10.md < 2.md
    • "natural": Sort naturally, e.g. 1.md < 2.md < 10.md
    • "size": Sort by file size.
    • "random": Sort randomly.
  • --reverse: Display files in reverse order. --reverse or --reverse=yes to reverse, --reverse=no to cancel.
  • --dir-first: Display directories first. --dir-first or --dir-first=yes to enable, --dir-first=no to cancel.
  • --translit: Transliterate filenames for sorting, see sort_translit for details. --translit or --translit=yes to enable, --translit=no to cancel.

tab_create

Argument/OptionDescription
[path]Optional, create a new tab using the specified path.
--currentOptional, create a new tab using the current path.

If neither [path] nor --current is specified, will use the startup directory to create the tab.

tab_close

Argument/OptionDescription
[n]Close the tab at position n, starting from 0.

If you want to close the current tab, use the close command instead.

tab_switch

Argument/OptionDescription
[n]Switch to the tab at position n, starting from 0.
--relativeSwitch to the tab at a position relative to the current tab. The value of n can be negative when using this parameter.

tab_swap

Argument/OptionDescription
[n]Swap the current tab with the tab at position n, where negative values move the tab forward, and positive values move it backward.

tasks_show

Show the task manager.

help

Open the help menu.

plugin

See Functional plugin.

noop

If you want to disable certain preset keybindings without rewriting the entire keymap, you can use the virtual noop command.

For example, to disable the default keybinding of gc, use:

[[manager.prepend_keymap]]
on = [ "g", "c" ]
run = "noop"

Or, if you prefer an array style:

[[manager.prepend_keymap]]
on = [ "g", "c" ]
run = [ "noop" ] # The array can only have one element and must be "noop"

The disabled keys won't trigger any actions when pressed and won't show up in the which component.

[tasks]

close

Hide the task manager.

arrow

Argument/OptionDescription
-1Move the cursor up 1 line.
1Move the cursor down 1 line.

inspect

Inspect the task (press q to exit the inspect view).

cancel

Cancel the task.

help

Open the help menu.

plugin

See Functional plugin.

noop

See noop command.

[spot]

close

Hide the spotter.

arrow

Argument/OptionDescription
[n]Move the cursor up or down n lines. Negative value for up, positive value for down.

swipe

Argument/OptionDescription
[n]Swipe n files up or down in the file list. Negative value for up, positive value for down.

copy

Copy the content from the spotter.

Argument/OptionDescription
cellCopy the selected table cell

plugin

See Functional plugin.

noop

See noop command.

help

Open the help menu.

[pick]

close

Cancel the picker.

Argument/OptionDescription
--submitSubmit the picker.

arrow

Argument/OptionDescription
[n]Move the cursor up or down n lines. Negative value for up, positive value for down.

help

Open the help menu.

plugin

See Functional plugin.

noop

See noop command.

[input]

close

Cancel input.

Argument/OptionDescription
--submitSubmit the input.

escape

Go back the normal mode, or cancel input.

move

Move the cursor left or right.

Argument/OptionDescription
[n]Move the cursor n characters left or right. Negative value for left, positive value for right.
--in-operatingMove the cursor only if it's currently waiting for an operation.

backward

Move back to the start of the current or previous word.

forward

Move forward to the start of the next word.

Argument/OptionDescription
--end-of-wordMove forward to the end of the current or next word.

insert

Enter insert mode. This command is only available in normal mode.

Argument/OptionDescription
--appendInsert after the cursor.

visual

Enter visual mode. This command is only available in normal mode.

delete

Delete the selected characters. This command is only available in normal mode.

Argument/OptionDescription
--cutCut the selected characters into clipboard, instead of only deleting them.
--insertDelete and enter insert mode.

yank

Copy the selected characters. This command is only available in normal mode.

paste

Paste the copied characters after the cursor. This command is only available in normal mode.

Argument/OptionDescription
--beforePaste the copied characters before the cursor.

undo

Undo the last operation. This command is only available in normal mode.

redo

Redo the last operation. This command is only available in normal mode.

help

Open the help menu. This command is only available in normal mode.

backspace

Delete the character before the cursor. This command is only available in insert mode.

Argument/OptionDescription
--underDelete the character under the cursor.

kill

Kill the specified range of characters. This command is only available in insert mode.

Argument/OptionDescription
bolKill backwards to the BOL.
eolKill forwards to the EOL.
backwardKill backwards to the start of the current word.
forwardKill forwards to the end of the current word.

plugin

See Functional plugin. This command is only available in insert mode.

noop

See noop command.

[confirm]

close

Cancel and close the confirmation dialog.

Argument/OptionDescription
--submitSubmit the confirmation.

arrow

Move the confirmation cursor.

Argument/OptionDescription
[n]Move the cursor up or down n lines. Negative value for up, positive value for down.

help

Open the help menu.

[completion]

close

Hide the completion menu.

Argument/OptionDescription
--submitSubmit the completion.

close_input

Close the input box. Arguments are the same as [input] close.

arrow

Argument/OptionDescription
[n]Move the cursor up or down n lines. Negative value for up, positive value for down.

help

Open the help menu.

plugin

See Functional plugin.

noop

See noop command.

[help]

close

Hide the help menu.

escape

Clear the filter, or hide the help menu.

arrow

Argument/OptionDescription
[n]Move the cursor up or down n lines. Negative value for up, positive value for down.

filter

Apply a filter for the help items.

plugin

See Functional plugin.

noop

See noop command.