My growing gallery of Electron boilerplates and experiments.
Examples favor simplicity. Most choose the electron-builder path instead of Electron's many others. I'm intentionally avoiding CLIs and Webpack to preserve View, Source awesomeness, and not need a local webserver.
- master This readme, and a blank starting point for the other branches.
Hello
- hello The code snippets from Electron Development in a Nutshell. 🎂 #helloworld
- single That code, collapsed into as few files as possible. 🤯 #experimental
- drag Download Electron as a
.zip
and drag in your project files, no binaries or command line required. 🤯 #experimental - cli Alternatively, try the Electron Forge CLI, figure out where your code goes, and check out live reload. 🎂 #helloworld
Build
- build Build binaries and installers for Windows, macOS, and Linux.
- name Trying a short executable name with a long product name with spaces.
- pretty Custom graphics for each part of the install process on all the platforms.
- sign Sign and notarize on Windows and macOS.
- cylinder Build the same Electron app to easily install on a virtual server instance. Now instead of desktop windows, navigate your browser to its UI. 🤯 #experimental
Update
- update Update from your own web site.
- updateui Click to accept a new update.
- updatepage A page refresh updates the app without even blinking the window. 🤯 #experimental
Portable
- portable Run the Electron app entirely from a USB stick plugged into Windows, macOS, or Linux. Carry it from platform to platform. Quit and unplug, and leave no trace. A well-behaved portable app has no interaction with the files, settings, and other running applications on the host computer. 🤯 #experimental
- native Require a native module.
- wasm Build the native module using WebAssembly instead of C.
- xasar The same
.asar
runs on Windows, macOS, and Linux. 🤯 #experimental
UI
- multi Two windows means three processes.
- vue Electron UI using Vue.js.
- vuex Multiple views of the same state using Vuex.
- vueui A larger Vue demo with example templates and coalescing updates into animation frames.
- spin Showing updates as fast as the screen can go without slowing down the I/O.
- repl In-window command line runs functions and shows state. 🤯 #experimental
- mark Simple text markup in the code becomes styled UI. 🤯 #experimental
Features
- instance Block a second instance, receive registered file extensions and custom URI protocols, and allow portable instances.
- settings Dock the dev tools to the bottom of the window, and they're still there the next time you run. Where is Electron keeping these settings? Exploration of best practices for settings, considering portable and cross-platform use cases.
- log Explore best practices for logging in Electron with debug, electron-log, or something else.
- kinesis Send logs to an Amazon bucket.
- pulse Detect harmful long-running events in the Node event loop. 🤯 #experimental
Web
- refresh Save your page and the browser automatically refreshes.
- vuepage Vue in a page from Vue's Getting Started. 🎂 #helloworld
- vuerouter Vue Router in a page from Vue Router's Getting Started. 🎂 #helloworld
- vuecli Vue in a project from Vue CLI. 🎂 #helloworld
- subtle Light encryption entirely in the page using SubtleCrypto. 🤯 #experimental
- zip Page zips and unzips archive. 🤯 #experimental
- deep Pages renders files from zip archive. 🤯 #experimental
- upload The best web upload experience, ever.
$ git clone https://github.com/zootella/tortuga
$ cd tortuga
$ git checkout branch1
$ npm run clean
$ npm run power-wash
$ npm install
$ npm run start
$ npm run build
$ APPLEID=yourid PASSWORD=yourpassword npm run build
$ alias graph="git log --all --decorate --oneline --graph"
$ graph
$ git branch branch1
$ git push -u origin branch1
$ git checkout branch1
$ git status
$ git add .
$ git commit -a -n -m "note"
$ git push
$ git status
$ git pull
$ git checkout branch1
TODO: as you complete this list, build out notes right here for manual QA to demonstrate and test these abilities
Basic stuff everybody needs:
- setup: installers for win/mac/linux, for individual local and non-admin users, know every path it deposits stuff, uninstall, and code signing instructions
- update: update from your website, not a server you or someone else needs to run
- tray: app shortcuts, start menu, taskbar/dock, system tray/mac menu
- minimize:
_[]X
/mac traffic light - html: windows show html, images, and fonts you brought yourself
- startup: run on startup, do this not as a service, run before login, get startup and shutdown events
- protocol: query and register custom:// and file extensions, test as admin and not
- send to: win ''Send To'' app shortcut, mac drag document onto dock icon
- drag: drag files, folders, and text into a div
- instance: single instance per running location, new launch from start/file extension/browser protocol forwards to running instance
- modes: nonmodal, modal, and disappearing modal windows to let a menu stick out beyond the edges of the window
- vue: change parts of a page with Vue.js and coalesce progress updates with requestAnimationFrame
The realm of the advanced, weird and experimental:
- icons: high-res and pixel-hinted icons
- tile: full-bleed win10 start menu tile with custom background
- portables: portable editions
- portable: carry a single stick between win/mac/linux
- portable asar: multiple different native modules in a single asar
- refresh: update app on electron browser refresh
- p2p: notify, distribute, and trust updates without a centralized anything
- tabs: tabs like a web browser but made of html and css
- repl: neo-repl ideas, a command-line style prompt in a page that can show form elements, and runs a command app in the same process with close and refresh
- markup: really simple markup becomes page ui
I love boilerplates (rather than CLIs). The Electron docs say:
Electron development is unopinionated - there is no "one true way" to develop, build, package, or release an Electron application.
but then also:
Especially for beginners, using a command line tool is likely to be helpful.
Totally disagree. Boilerplates are much better for learning: you can see the code rather than having a CLI deliver a huge amount of complexity right from step one. I've found CLI-generated projects and pipelines to be quite brittle. Encountering code a CLI generated a few months ago that no longer builds, it's often easiest to start over from scratch, running the CLI again, and then moving your code into the new fresh project. Growing your project from a simple boilerplate you can understand and from the start is much better.
In addition to these, check out Electron's list of awesome boilerplates.