Go to file
2025-03-21 17:45:13 -04:00
db Split out user data from auth-code & add auth code to repo. 2024-09-23 12:57:02 -04:00
views Remove codemirror build step from Dockerfile so it builds on janus & i can get app running again; add vim config to index view (not fully working). 2024-09-14 15:32:27 -04:00
.gitignore Split out user data from auth-code & add auth code to repo. 2024-09-23 12:57:02 -04:00
Dockerfile Upgrade node version past 20 to get easy ENV variables so session secret can be removed from source code. 2024-09-22 18:09:05 -04:00
LICENSE Add LICENSE and README. 2025-03-21 17:45:13 -04:00
nodemon.json Add file storage for sessions; Fix unstable restarts from nodemon (started notes-app Dockerfile to isolate npm packages and add nodemon.json config to ignore some dirs, but no real difference from alertmon/Dockerfile). 2017-04-20 08:33:12 -04:00
package.json Add file storage for sessions; Fix unstable restarts from nodemon (started notes-app Dockerfile to isolate npm packages and add nodemon.json config to ignore some dirs, but no real difference from alertmon/Dockerfile). 2017-04-20 08:33:12 -04:00
README.md Add LICENSE and README. 2025-03-21 17:45:13 -04:00
server.js Split out user data from auth-code & add auth code to repo. 2024-09-23 12:57:02 -04:00

notes.kaplon.us

Minimum viable notes app. All notes go into a single, plaintext file. All changes are backed up and synced to multiple clients thanks to websockets, node, and git.

vim mode is strictly enforced highly encouraged (apologies for forcing my keybindings on you):

  • : and ; are swapped
  • jj escapes insert mode / ctrl + c works as well

Markdown is highlighted, but not rendered.

A working demo is hosted at notes.kaplon.us. Login with credentials demo/demo. Open a new incognito browser window, log in again, and watch your changes appear in the other window. Complete version history is committed to a separate data repo.

This side-project uses the excellent CodeMirror editor. The experience from a mobile-browser isn't great, but my main use case is within a desktop browser.