graphite
graphite copied to clipboard
✍️ A local-first Markdown note-taking app built with Vue.js, Tailwind CSS, and Electron.
⚠️ This repo is for demo purposes only ⚠️
⚠️ Don't use Graphite to edit local files ⚠️
✍️ Graphite - Video Explanation
A local-first Markdown note-taking app built with Vue.js, Tailwind, and Electron.
- In 2020, I quit my tech job to focus on creating web development tutorials on YouTube.
- After spending a few months playing around with different technologies, I decided to focus on Vue + Tailwind.
- In order to test how far I've come with the tech stack, I made Graphite, a local-first markdown note-taking app.
- Note: I built Graphite in ~1 week so don't mind the code quality or lack of tests.
Demo GIF (takes a few seconds to load)
data:image/s3,"s3://crabby-images/711b0/711b0b74b6477faf75d2af58ab1c7291c0d4cfb6" alt=""
Images
Dracula Theme
data:image/s3,"s3://crabby-images/eb5db/eb5dbd36669a72f7be5c11cde006e4eef6b8d54e" alt=""
Gruvbox Theme
data:image/s3,"s3://crabby-images/b2ab8/b2ab822203adfe37f97dcc0c13d2c811b751f2fe" alt=""
Monokai Theme
data:image/s3,"s3://crabby-images/63a08/63a086ba983c1241e7855e34878385fed67e1e15" alt=""
File Search
data:image/s3,"s3://crabby-images/4f6fe/4f6fe9acbf7b7b8c1094f576d2ff3c59bb309619" alt=""
Markdown Preview
data:image/s3,"s3://crabby-images/3acf8/3acf85f03a320b76e1d0f652459e2a037e6afe26" alt=""
💻 Tech Stack
- Stack
- Vue.js
- Vuex (state management)
- Electron (desktop apps ftw)
- Tailwind CSS (UI framework)
- Libraries
- Marked (convert markdown to html)
- CodeMirror (builing your own editor is hard)
- Hotkeys (makes keyboard shortcuts easy)
Feature Set
- Basic
- Add/remove/rename/move files
- Markdown preview
- CodeMirror editor
- Keybindings
- Open file search ->
command + o
- Close file search ->
esc
- Toggle sidebar ->
command + b
- Open file search ->
- Configurable Themes with CSS Variables
- Dracula
- Gruvbox
- Monokai
- TODO
- WYSIWYG
- Add/remove/rename/move folders
- Watch for file changes in Electron and persist changes automatically
- Actually release a desktop app for Mac/Windows/Linux