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
.