notion-enhancer/DOCUMENTATION.md
2020-07-14 00:23:21 +10:00

3.2 KiB

readme placeholder

ended up here? this is a wip version of the enhancer, and this file is yet to be completed. if you're interested in using the project, switch back to the master branch. for support, contact me on discord dragonwocky#8449 or open an issue here in the repo.

want to contribute? check the the contribution guidelines.

module creation

each directory in the mods folder is considered a module, with the entry point mod.js. this file must have its exports set to an object that defines metadata, configurable options for the menu, code to be run in both the back- and front- ends of the app, and styling.

module.exports =

key value required
id uuidv4 string ✔️
meta { meta: see below } ✔️
options [ array of { option: see below } ]
code { code: see below } ✔️

meta: { }

key value required
type 'extension', 'theme' ✔️
name string ✔️
version semver string (e.g. '0.3.7') ✔️
author github username string ✔️
thumb relative file string, url

{ option }

key value required
name string ✔️
type 'toggle', 'select', 'input', 'file' ✔️
value type.toggle = true, false. type.select = [array of strings]. type.input = string

code: {}

key value required
styles relative file string
main function
renderer function
hack function

styles should be a css file, which is automatically inserted into each app window via the enhancement:// protocol.

main code is executed on app launch in the "main" process (singular, shared between all apps - consider it a backend). renderer code is executed on window launch in the "renderer" process (per-window, the client-side js one might expect to run on a website).

note that as this code is inserted into notion's app, it may not work to require() modules that are not already installed for the app. in future a fix for this is planned.

hack code is executed on enhancement. this can be useful for things that require modding pre-existing parts of the app, and can't just be overruled (e.g. making the window frameless).

to make the best use of these, check out the electron docs and explore the contents of your local extracted app.asar.