Skip to content

piyoki/neovim-server

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

☁️ NeoVim Server

A containerized IDE-like text editor that runs on a web server

CICD License Version NeoVim Platform

This tool is for running NeoVim remotely and continuing the development process at πŸš€ speed. You can use it to implement an IDE-like web-based terminal text editor.

screenshot

🚨 Notifications

This is project is DEPRECATED, and no longer under maintenance. However, contributions are still welcome.

✨ Features

  • Portable and light-weight
  • Support popular languages
  • Syntax highlight
  • Intellisense autocomplete
  • Markdown snippets and preview
  • Easy to deploy
  • Versatile and customizable
  • Containerized
  • Run on a web browser
  • Build with multi-arch (ARM/x86)
  • Supported platforms: arm64, arm64

βš™οΈ Prerequisites

  • Driod Sans Mono Nerd Font is required to be downloaded since its the default font of the container. You may find the installation guide below. To use other fonts, please find the instructions on the Nerd Font repository.
  • Choose a web browser in your preference. Google Chrome, Microsoft Edge, and FireFox should work fine, whereas Safari does not work temporarily.

πŸ“₯ Font Installation

Notes: reboot might be needed after the font installation

Linux

mkdir -p ~/.local/share/fonts
cd ~/.local/share/fonts && curl -fLo "Droid Sans Mono for Powerline Nerd Font Complete.otf" https://github.com/ryanoasis/nerd-fonts/raw/master/patched-fonts/DroidSansMono/complete/Droid%20Sans%20Mono%20Nerd%20Font%20Complete.otf

MacOS

cd ~/Library/Fonts && curl -fLo "Droid Sans Mono for Powerline Nerd Font Complete.otf" https://github.com/ryanoasis/nerd-fonts/raw/master/patched-fonts/DroidSansMono/complete/Droid%20Sans%20Mono%20Nerd%20Font%20Complete.otf

Arch User ONLY

yay -S nerd-fonts-droid-sans-mono

NOTE: if your current browser cannot load the font and the icon, you may manually apply the configuration to the wetty configuration window located on the upper right corner:

{
  "fontSize": 16,
  "fontFamily": "DroidSansMono Nerd Font"
}

πŸ“₯ Installation

Run with the pre-built image

docker run -d \
  --name nvim-server \
  --restart unless-stopped \
  -p 6080:3000 \
  -p 8090:8090 \
  -v ~/workspace:/workspace \
  -v /appdata/nvim-server:/config \
  -e UID=$UID \
  -e GID=$GID \
  -e TZ=Asia/Shanghai \
  -e USER=<USER> \
  -e SECRET=<PASSWORD> \
  hikariai/nvim-server:latest

Watch the logs

$ docker logs nvim-server --follow

Notes:

  • Wait for a couple seconds until the container finishes its bootstrap process, then visit http://localhost:6080/wetty
Parameters Usage
--name nvim-server Specify the name for the container
-p 6080:3000 Map the port for accessing the Web UI
-p 8090:8090 Map the port for the Instant Markdown Preview Server
-v ~/workspace:/workspace Map the working directory
-v /appdata/nvim-server:/config Contain all relevant configuration config directory
-e UID=$UID Map current user ID
-e GID=$GID Map current group ID
-e TZ=<TZ> Specify a timezone to use e.g. Asia/Shanghai
-e USER=<USER> Specify the username for user login, default is set to guest
-e SECRET=<SECRET> Specify the password for user login, default is set to password

Build the image manually

Follow the instruction HERE

UNRAID User ONLY

NeoVim Sever is now available on unRAID CA. Search nvim server and install

Detailed installation guide is available HERE

πŸ’‘ Usage

  • After logging in with username and password in the web console, type vim to finish the initial setup.

  • For the first launch, NeoVim will install the coc-extensions defined in coc.settings. You may also download additional coc-extensions followed by the instructions

  • All the functionalities and usage cases are written in the Wiki Page, feel free to check it out.

  • To get familiar with the default key mappings, please visit the Cheat Sheet Page

  • For accessing the Markdown Preview, simply open a web browser tab and copy the URL display in the status bar when editing a markdown file

πŸ“‹ Wiki

πŸ’¬ F.A.Q

πŸ”¨ Useful Tools for Vim

πŸ“ TODO

  • Add a customizable base image
  • Add more customizable features
  • Add more advanced usage cases
  • Add demo and usage guide for selection, registers, substitution, and macro
  • Add SSL support
  • Add relative number option
  • Add wetty rolling updates

πŸ“ Reference

βš–οΈ License

MIT (C) Kevin Yu