First you need to install and configure the Himalaya CLI. Then you can install this plugin with your favorite plugin manager:
Using packer
use "https://github.com/pimalaya/himalaya-vim"
:PackerSync
Using vim-plug
Plug 'https://github.com/pimalaya/himalaya-vim'
:PlugInstall
It is highly recommanded to have those Vim options on:
syntax on
filetype plugin on
set hidden
Defines a custom path for the himalaya binary. Defaults to himalaya
.
Override the default TOML configuration file.
Defines the provider used for selecting folders (default keybind: gm
):
native
(default): a vim native inputfzf
: https://github.com/junegunn/fzf.vimfzflua
: https://github.com/ibhagwan/fzf-luatelescope
: https://github.com/nvim-telescope/telescope.nvim
If no value given, the first loaded (and available) provider will be used (telescope > fzf > native).
let g:himalaya_folder_picker = 'native' | 'fzf' | 'fzflua' | 'telescope'
Enables folder preview when picking a folder with the telescope.nvim
provider.
let g:himalaya_folder_picker_telescope_preview = 1
Defines the command to use for contact completion. When this is set, completefunc
will be set when composing emails so that contacts can be completed with <C-x><C-u>
.
The command must print each possible result on its own line. Each line must contain tab-separated fields; the first must be the email address, and the second, if present, must be the name. %s
in the command will be replaced with the search query.
let g:himalaya_complete_contact_cmd = '<your completion command>'
Defines the list of additional custom flags that himalaya-vim should be aware of. They should be specified as a list of strings:
let g:himalaya_custom_email_flags = ['custom1', 'custom2']
With the native picker (default):
With the telescope.nvim picker:
With the fzf.vim picker:
:Himalaya
Function | Keybind |
---|---|
Change the current folder | gm |
Show previous page | gp |
Show next page | gn |
Read email under cursor | <Enter> |
Write a new email | gw |
Reply to the email under cursor | gr |
Reply all to the email under cursor | gR |
Forward the email under cursor | gf |
Download all attachments of email under cursor | ga |
Copy the email under cursor | gC |
Move the email under cursor | gM |
Delete email(s) under cursor or visual selection | gD |
Add the specified flag to the selected email(s) | gFa |
Remove the specified flag from the selected email(s) | gFr |
Filter and sort envelopes according to the given query | g/ |
Keybinds can be customized:
nmap gm <plug>(himalaya-folder-select)
nmap gp <plug>(himalaya-folder-select-previous-page)
nmap gn <plug>(himalaya-folder-select-next-page)
nmap <cr> <plug>(himalaya-email-read)
nmap gw <plug>(himalaya-email-write)
nmap gr <plug>(himalaya-email-reply)
nmap gR <plug>(himalaya-email-reply-all)
nmap gf <plug>(himalaya-email-forward)
nmap ga <plug>(himalaya-email-download-attachments)
nmap gC <plug>(himalaya-email-copy)
nmap gM <plug>(himalaya-email-move)
nmap gD <plug>(himalaya-email-delete)
nmap gFa <plug>(himalaya-email-flag-add)
nmap gFr <plug>(himalaya-email-flag-remove)
nmap g/ <plug>(himalaya-set-list-envelopes-query)
Note: see the documentation for more detailed information about the query API.
Function | Keybind |
---|---|
Write a new email | gw |
Reply to the email | gr |
Reply all to the email | gR |
Forward the email | gf |
Download all email attachments | ga |
Copy the email | gC |
Move the email | gM |
Delete the email | gD |
Keybinds can be customized:
nmap gw <plug>(himalaya-email-write)
nmap gr <plug>(himalaya-email-reply)
nmap gR <plug>(himalaya-email-reply-all)
nmap gf <plug>(himalaya-email-forward)
nmap ga <plug>(himalaya-email-download-attachments)
nmap gC <plug>(himalaya-email-copy)
nmap gM <plug>(himalaya-email-move)
nmap gD <plug>(himalaya-email-delete)
Function | Keybind |
---|---|
Add attachment | ga |
Keybinds can be customized:
nmap ga <plug>(himalaya-email-add-attachment)
When you exit this special buffer, you will be prompted 4 choices:
send
: sends the emaildraft
: saves the email locallyquit
: quits the buffer without savingcancel
: goes back to the email edition
The development environment is managed by Nix. Running nix-shell
will spawn a shell with everything you need to get started with this plugin:
# starts a nix shell
$ nix-shell
# starts Vim and the :Himalaya command
$ vim +Himalaya
# starts Neovim and the :Himalaya command
$ nvim +Himalaya
Special thanks to the NLnet foundation and the European Commission that helped the project to receive financial support from:
- NGI Assure in 2022
- NGI Zero Entrust in 2023
If you appreciate the project, feel free to donate using one of the following providers: