A dedicated scratchpad for developers
Go to file
2025-08-04 23:09:34 +02:00
.github Rename notarization environment variable 2025-04-22 14:13:51 +02:00
assets Tweak tab bar colors 2025-08-02 14:56:20 +02:00
build Remove unnessecary entitlements 2024-01-25 23:09:30 +01:00
docs Alt key no longer opens the main menu on Windows/Linux 2025-08-04 20:11:32 +02:00
electron Persist recent buffers in settings 2025-08-04 22:52:59 +02:00
public Elixir language support 2025-01-04 14:01:55 +01:00
resources
shared-utils Alt key no longer opens the main menu on Windows/Linux 2025-08-04 20:11:32 +02:00
src Clear open tabs and recent buffers when changing library location 2025-08-04 23:09:34 +02:00
tests Add basic tests for tabs 2025-08-03 14:17:46 +02:00
webapp Add basic tests for tabs 2025-08-03 14:17:46 +02:00
.gitignore
electron-builder.json5 Remove electron-builder-notarize, since electron-builder should now have built in notarization 2025-04-22 14:13:51 +02:00
index.html
LICENSE
package-lock.json Update Electron to latest version (should hopefully add a border to frameless window on Windows) 2025-08-02 16:58:36 +02:00
package.json Update Electron to latest version (should hopefully add a border to frameless window on Windows) 2025-08-02 16:58:36 +02:00
playwright.config.ts Retry tests on CI 2025-07-18 23:30:15 +02:00
README.md Update Readme and docs 2025-06-18 11:37:05 +02:00
tsconfig.json Fix issue causing vite build not to work 2025-01-07 23:37:36 +01:00
tsconfig.node.json Avoid code duplication by auto building the GUESSLANG_LANGUAGES list in langdetect-worker.js from the src/editor/languages.js:LANGUAGES list. 2024-02-09 16:02:07 +01:00
vite.config.mjs Fix issue with new newlines getting inserted into docs 2025-06-27 15:55:46 +02:00

Heynote

GitHub release (latest SemVer) Build Status

General Information

Heynote is a dedicated scratchpad for developers. It functions as a large persistent text buffer where you can write down anything you like. Works great for that Slack message you don't want to accidentally send, a JSON response from an API you're working with, notes from a meeting, your daily to-do list, etc.

The Heynote buffer is divided into blocks, and each block can have its own Language set (e.g. JavaScript, JSON, Markdown, etc.). This gives you syntax highlighting and lets you auto-format that JSON response.

Available for Mac, Windows, and Linux.

Features

  • Persistent text buffer(s)

  • Block-based

  • Syntax highlighting:

    C++, C#, Clojure, CSS, Erlang, Dart, Go, Groovy, HTML, Java, JavaScript, JSX, Kotlin, TypeScript, TOML, TSX, JSON, Lezer, Markdown, PHP, Python, Ruby, Rust, Scala, Shell, SQL, Swift, Vue, XML, YAML

  • Language auto-detection

  • Auto-formatting

  • Math/Calculator mode

  • Currency conversion

  • Multiple buffers

  • Multi-cursor editing

  • Dark & Light themes

  • Option to set a global hotkey to show/hide the app

  • Default, Emacs-like or custom key bindings

Documentation

Documentation is available on the Heynote website.

Development

To develop Heynote you need Node.js and you should (hopefully) just need to check out the code and then run:

> npm install
> npm run dev

Run Tests

To run the tests:

> npm run test

To run the tests in the Playwright UI:

> npm run test:ui

Contributions

I'm happy to merge contributions that fit my vision for the app. Bug fixes are always welcome.

FAQ

Where is the buffer data stored?

See the documentation.

Can you make a mobile app?

No, at the moment this is out of scope, sorry.

What are the default keyboard shortcuts?

See the documentation.

Thanks!

Heynote is built upon CodeMirror, Vue, Electron, Math.js, Prettier and other great open-source projects.