OVIWrite is a NeoVim powered Integrated Writing Environment (IWE) built using LazyVim and 💤 lazy.nvim.
The goal is to make it as easy as possible for writers to start using NeoVim out of the box.
This begs the question: what kind of writer would gravitate towards OVIWrite in the first place? Good question. I spend some time discussing it below.
At first Vim, and now NeoVim, have formed the basis of my dream writing environment. Who even dreams of their writing tools? I have no answers except to say that I do venture outside regularly to touch grass and talk to people - don’t worry.
I wanted a writing tool that ticked these boxes:
This is a tall order to ask for word processors. It is why conventional word processing software such as MS Word fails, at least for me.
Granted I wrote my first novel on MS Word, I came to find that it wasn’t extensible enough to scale with my needs, nor was it nimble and fast.
An ideal writing tool should adapt to a writer’s needs at a moment’s notice.
Here are two demos I presented at the NeoVimConf where I presented two early versions of OVIWrite.
Essentially, these two talks served as early demos of OVIWrite versions 0.1 and 0.2. However, the eagle-eyed among you will notice I used a combination of Vim and NeoVim during these talks. This was because I couldn’t get some Vim-specific plugins to work with NeoVim, a problem that has since been solved.
This version of OVIWrite is built entirely in Lua, and follows the modular structure of LazyVim.
This is version 0.4 (Dec 11th 2023)
You will notice that Vim and NeoVim are used interchangeably here. This might appear confusing at first so let’s be clear:
I hear you: Who is this for?
Personally, I think of Vim/NeoVim as analogous to a musical instrument, say a piano. Are pianos meant only for world-class pianists? No.
The first interaction with a piano is often messy, confusing and overwhelming; stick with it, and there is a little bit of magic waiting to be experienced.
This mindset has helped immensely in scaling the steep learning curve that comes with Vim’s modal editing philosophy.
But unlike me, writers like you don’t have to invest the additional time in learning how to wrangle Vim to be a tool for writing. All you need is a couple of weeks practicing Vim motions and understanding its different modes.
Once you overcome that hurdle, install OVIWrite and get writing!
Only you can answer that. I don’t consider myself to be a tech person - tech savvy, yes but I can barely read code myself.
So no lies here: (Neo)Vim motions and modal editing requires a rewiring of our writer brains. But the good news is that it shouldn’t take more than two weeks of 10-15 minutes a day. Vimtutor, built into Vim, is the best place to practice.
There is also some steep knowledge acquisition required to understand NeoVim’s internal nuts and bolts. This is only required if you want Vim to work exactly as you want it to. I did, which is why I set off on this journey three years ago.
You don’t.
OVIWrite offers a higher floor from which to start your own explorations.
You don’t need to know how to program or read Lua code, to use OVIWrite. All that work has been done for you. Nothing is stopping you from peaking behind the curtains at the source code. Add or modify the code as you see fit if you are feeling extra adventurous
More good news: Vim is almost 40 years old. The community has been around for decades, and have extensively documented tips, tricks and hacks. Chances are the error message you are seeing has been seen countless times before by countless people, and in all those occasions there was an experienced Vim user helping out a new-comer. I can speak from experience on this last fact.
Once again, thinking of OVIWrite as akin to a musical instrument might be the best way to overcome its apparent complexity; instead of music, OVIWrite is purpose-built for efficient (and damn near magical) textual recall, creation and manipulation.
TL;DR:
Being tech-savvy will make this easier but it is not a requirement.
Being patient is.
Heavy Googling is (as any programmer will tell you).
I can only offer personal anecdotes here in lieu of a more scientific approach.
I have steadily become very productive in the three years since my first encounter with Vim.
The procrastination associated with writing has disappeared, and I believe part of that is because I don’t have to struggle through the bloated mess that is MSWord.
Editing, too, has become a joy because editing is Vim’s superpower. Combined with the curated plugins included in OVIWrite, you should be writing, editing and world-building at the speed of thought!
Most writers writing on word processors use Rich Text. Rich Text, for all its benefits, does come back with significant drawbacks: vendor lock-in being a primary concern. Rich Text also doesn’t age well. Rich text’s older, less glamorous kin, Plain Text ages better, doesn’t lock you into a vendor, and gives you the freedom to choose the tools that are suited for your work. For more, read The Case for Plain Text
Git is a robust version control system initially designed for software development, and has emerged as an invaluable asset for my writing workflow. Really, I think it’s damn near criminal that we don’t teach writers Git at some point in their developmental stage. Read more here
I use OVIWrite for the following use-cases:
See screenshots below.
I needed an Integrated Writing Environment, a toolkit that was fast, yet extensible enough to scale with a writer’s changing requirements.
I spent a lot of time writing on diverse IDEs to get a sense of what I wanted out of my IWE; in fact, my inspirations for OVIWrite were VSCode, PyCharm and indeed the many Vim/NeoVim inspired distros like NVChad, LunarVim, and Doom Emacs.
I currently run this version of OVIWrite on my Mac (MacOS Sonoma 14.1.2), Linux (popOS 22.04 on my desktop, and Ubuntu Server 22.04 on my server), and Android 12 (OxygenOS 12.1 on a OnePlus 7T). I don’t have a Windows machine to test at the moment. iPad testing is ongoing. I am fairly confident that OVIWrite will work pretty great on a semi-recent Android tablet (I don’t have an Android tablet to test), as long as Termux is installed.
Plugins | Type |
---|---|
LanguageTool.lua | Spelling and Grammar |
alpha.lua | Splash Screen |
autopairs.lua | Automatically close brackets and quotation marks |
catppuccin.lua | Color Scheme |
comment.lua | Commenting of text |
fountain.lua | Screenwriting |
fzf-vim.lua | Fast search for files and words |
goyo.lua | Distraction Free Writing |
gruvbox.lua | Color Scheme |
img-clip.lua | Paste images into Markdown and LaTeX buffers |
lazygit.lua | Version control for GitHub |
limelight.lua | Distraction free writing |
markdown-preview.lua | Preview Markdown files |
mason-lspconfig.lua | LSP |
mason.lua | LSP |
nightfox.lua | Color scheme |
noice.lua | System notifications |
nvim-tree.lua | File explorer |
nvim-treesitter.lua | Treesitter integration |
nvim-web-devicons.lua | Pretty icons |
nvimorgmode.lua | Org-mode |
obsidianNvim.lua | Support for editing Obsidian files |
pomo.lua | Pomodoro timer |
telescope.lua | Telescope, for fast search across buffers, directories, help documentation, etc., |
translate.lua | Translate to and from English, Tamil, Sinhala and French |
twilight.lua | Yet another distraction free writing aid |
vim-grammarous.lua | Grammar checker |
vim-latex-preview.lua | Preview LaTeX documents |
vim-pencil.lua | line wrapping for prose |
vim-wiki.lua | Personal knowledge management tool |
vim-zettel.lua | Zettelkasten function |
vimorg.lua | additional Org-Mode support within NeoVim |
vimtex.lua | LaTeX support |
whichkey.lua | Keyboard binding lookup |
zen-mode.lua | Distraction Free writing |
Note: The screenshots below show a variety of color schemes at play: Nightfox, DawnFox and NordFox. Also included in the config: Gruvbox and flavours of Catppuccin. I’ve included my favourite color schemes; users are, of course, free to add whatever color scheme that is available in the NeoVim ecosystem.
Detailed Installation instructions can be found on our wiki
You can download the zip file containing all the source code. Copy it into the appropriate folder.
git clone https://github.com/MiragianCycle/OVIWrite.git "${XDG_CONFIG_HOME:-$HOME/.config}"/nvim
Command Prompt
git clone https://github.com/MiragianCycle/OVIWrite.git %userprofile%\AppData\Local\nvim\
Powershell
git clone https://github.com/MiragianCycle/OVIWrite.git $env:USERPROFILE\AppData\Local\nvim\
OVIWrite uses which-key.nvim to help you remember your
keymaps. Just press any key like <space>
and you’ll see a popup with all
possible keymaps starting with <space>
.
<leader>
is <space>
Key | Mode | Description |
---|---|---|
f | Normal | Find files |
n | Normal | New |
r | Normal | Recent files |
g | Normal | Grep (find word) |
l | Normal | Lazy Package Manager |
q | Normal | Quit OVIWrite |
- [ ] Public demo on YouTube
- [X] LSP integrations for Grammarly, Proselint
- [X] Autocomplete
- [ ] Testing
- [X] Linux (Debian and Ubuntu-based): ✅
- [X] MacOS (> 10.0): ✅
- [X] Linux: ✅
- [X] Android (> Android 10)(via Termux): ✅
- [X] iPad: ❌
- [0] Windows:
- [ ] Documentation
- [X] Website on GitHub maybe?
- [X] Blog: The Case For Plain Text
- [ ] In-depth Help Documentation
- [ ] Installation streamlining
- [ ] Features planned for version 0.5
- [ ] Snippets
- [ ] BibTex and Zotero integrations
Please, and thank you.
Contributions are encouraged. Feel free to make a pull request with modifications. If you want to contribute at a deeper level - maybe even forking NeoVim for writing outright - do reach out to me. I will be happy to collaborate and learn from the community.
None of this would be possible without the contributions of the entire Vim and NeoVim eco-systems. Please contribute in anyway, financial or otherwise, to these incredible projects and the tireless people who maintain them.