Fable bindings for Electron.
If you are actively using Fable.Electron or otherwise interested in seeing these bindings being kept up to date, please consider taking over this project!
I am not actively using Fable.Electron and will not be able to prioritize keeping it up to date with new Electron releases. I am therefore seeking a new maintainer.
Work involved: The only thing I have been doing so far is using a website scanner (I use Wachete, but use whatever you want) to monitor https://www.electronjs.org/docs/all for changes, and update the bindings accordingly. Minor releases and relevant documentation updates occur at most once a week (often less) and usually involve 15m to an hour of work (including deployment), while major Electron releases may take a several hours.
This documentation-driven approach is slightly complicated by the fact that the docs may have bugs, i.e. something should be an array but is documented as a single value. Use your best judgement and search the Electron source code if you’re unsure whether the docs are correct.
Pull requests are more than welcome, whether it’s bindings for new APIs, new helpers, bugfixes, or just improving typos and formatting in the documentation. If you want to create a PR with non-trivial changes, consider opening an issue first so you don’t waste time and effort on something that might not be accepted or might already be underway.
Note that since Fable.Electron is mostly just bindings, the official Electron docs is the place to go for general Electron usage.
For an example app with complete boilerplate for Electron apps using Fable and Elmish with hot module reloading, time-travel debugging, etc., check out Fable-Elmish-Electron-Material-UI demo.
To get started with the bindings, simply:
- Install the
Fable.Electron
Nuget package as well as theelectron
npm package. Make sure theelectron
version is compatible with the bindings. Fable.Electron supports Femto. open Electron
. In addition to all the the type definitions, you now have access to two entry points for the Electron API:main
for everything that can be used from the main processrenderer
for everything that can be used from the renderer process
You can also use electron
to access everything, but consider using only main
or renderer
.
By convention, class constructors are accessible as static Create
members. For example, to instantiate a BrowserWindow
, you call main.BrowserWindow.Create()
.
In addition to the bindings, Fable.Electron also gives you access to some convenience helpers if you open Electron.Helpers
:
Accelerators in Electron are simply strings with a specific format. If you want, you can use createAccelerator
with the Modifier
and Key
helper types to create them in a strongly typed manner:
// Returns an accelerator string that can be used to register shortcuts
createAccelerator: Modifier list -> Key -> string
Example:
let accelerator = createAccelerator [Modifier.Ctrl; Modifier.Alt] Key.Tilde
main.globalShortcut.register(accelerator, fun () -> (* do stuff *))
// The above is identical to:
main.globalShortcut.register("Ctrl+Alt+~", fun () -> (* do stuff *))
If you need to use a key that is not in the Key type but that you know works, you can use a string with Fable's !!
operator, or just skip the helper altogether (also, please make a PR to add the key!):
let accelerator = createAccelerator [Modifier.Ctrl] !!"="
// The above is identical to:
let accelerator = "Ctrl+="
- Make necessary changes to the code
- Update the changelog
- Update the version and release notes in the package info, as well as the supported Electron versions in the
NpmPackage
node - Commit and tag the commit (this is what triggers deployment from AppVeyor). For consistency, the tag should be identical to the package version number.
- Push the changes and the tag to the repo. If AppVeyor build succeeds, the package is automatically published to NuGet.