As an aside, what is the motivation? There are some out there already. Truly just curious.
Neovim
I have not found any that match the criteria I mentioned.
Just to summarize it better, I want something that has:
- vim-like philosophy of editing, with keybindings, motions and the like
- does not struggle with supporting RTL languages like Arabic (the terminal world struggles with that unfortunately)
- allows rich formatting, such as using non-monospaced fonts, and having the possibility to make different rows of text have different sizes (such as headings being bigger)
tbh if I can find something with only the first two, I can sacrifice the third one. But I still can't find anything like that.
You probably don't want the entire terminal rendered in your UI for the reason you gave that it is intended for monospace.
Rather, you want the buffer which is markdown and contextual info like cursor position.
You might hit some challenges like how to handle style elements. For example:
<cursor>*bold*
Moving the cursor to the right of the b
will take two key presses in nvim but would typically be one key press in a WYSIWYG editor.
There are probably many ways to handle this in nvim through the plugin system, but both paths of embedding vs emulating nvim has a good chunk of dev work to be completed.
Emulating will likely be more rewarding at the start as you can get incremental improvements pretty quickly.
Embedding is a cool idea, but likely a ton of upfront work to get your first tangible results.
You might be interested in reviewing https://github.com/MeanderingProgrammer/render-markdown.nvim which attempts to render Markdown in the terminal. They have logic for rendering things like the bold example in bold while hiding the markup.
I personally just use https://github.com/iamcco/markdown-preview.nvim to render in a different window when render-markdown.nvim isn't enough.
Thanks for the pointers!
You might hit some challenges like how to handle style elements. For example:
<cursor>*bold*
Moving the cursor to the right of the
b
will take two key presses in nvim but would typically be one key press in a WYSIWYG editor.
I've thought about this actually, and Youre right it will require some handling. In the first version of the editor, I will still include the special characters, such as the * for bolding. But I will also style it and what's after as bold.
I really like the render-markdown plugin, but my deal breaker was RTL language, since Arabic is a native language to me that I wish to write in vim.
Best of luck! Sounds like a cool project.
Not sure if NeoVim uses tree-sitter as the default syntax highlighter, but it will give you Abstract Syntax Tree info if you can jack into it for the document so you don't have to parse the markdown. Your WYSIWYG view just has to translate the AST which may help with removing style symbols.
One of many ways to tackle I'm sure.
There are plugins for other editors that use neovim as a headless server, which is how I'd do what you want here. You just pass all input events straight through to neovim, read the buffer back and render it as you want. At least that's how I imagine it would work, I've never done it myself.