A simple way to pack addons as zip
files for Trilium Notes.
Note: This is still early in development and things may change rapidly. Use at your own discretion.
npm install trilium-pack
To use this via cli (or npm scripts
) you'll have to setup your config in either a tpack.json
or tpack.config.json
. In either case, trilium-pack will find the config and pack your addon.
If you installed the package globally, just run tpack
!
Just add tpack
to your npm scripts
!
{
"scripts": {
"dist": "tpack"
}
}
const packAddon = require("trilium-pack");
// Replace with your config
const config = {};
// __dirname is the default so this is optional
const opts = {basePath: __dirname};
packAddon(config, opts);
Currently, the configuration only has 2 top-level properties, output
and notes
, both are required.
Name | Type | Description |
---|---|---|
output |
string |
A path to the desired output relative to the configuration file. |
notes |
object |
A tree of notes to be created with the root being a singular note. |
Each note can have several different properties, some of them optional, and some of them have defaults.
Name | Type | Optional | Default | Description |
---|---|---|---|---|
file |
string |
❌* | Relative path string to the file to be included. *This may be omitted only for "render" notes. |
|
title |
string |
✅ | filename | Title to be displayed in Trilium (affects pseudo-import name for scripts). |
type |
string |
✅ | "code" |
Type of note to be created. Only "code" , "file" and "render" are currently supported due to the scope of this project. |
mime |
string |
✅ | auto |
Mime type to set for the note, this will be automatically determined from the file extension where possible. |
env |
string |
✅ | "frontend" |
Script environment for js notes. Should be either "frontend" or "backend" . |
attributes |
object |
✅ | {} |
Attributes to be set on the imported note. |
children |
Array<Note> |
✅ | filename | Title to be displayed in Trilium (affects pseudo-import name for scripts). |
Due to the scope of the project, this does not support the full set of attribute features from Trilium such as inheritence. This only accepts a simple Record<string, string>
set of attributes, where the key
is the name of the attribute and the value
is the value of the attribute. Every key
can start with #
or ~
to indicate label
or relation
type respectively. For relation
notes, the value should be set to the target note.file
string, abd it will be resolved automatically. For simple labels like #widget
you can simply use an empty string ""
as the value.
{
"#widget": "",
"#run": "frontendStartup",
"~renderNote": "static/page.html",
}
This example was tested with Trilium Heatmap.
tpack.config.js
module.exports = {
output: "dist/Trilium-Heatmap.zip",
notes: {
title: "Trilium Heatmap",
type: "render",
attributes: {
"~renderNote": "static/main.html"
},
children: [
{
file: "static/main.html",
title: "HTML",
children: [
{
file: "src/main.js",
env: "frontend",
children: [
{
title: "getDatas", // ensures import name
file: "scripts/getDatas.js",
attributes: {"#heatmapDatas": ""}
},
{
title: "setHistoryCount", // ensures import name
file: "scripts/setHistoryCount.js",
attributes: {"#run": "frontendStartup"}
},
{
file: "lib/d3.js",
title: "d3", // ensures import name
type: "file"
}
]
}
]
}
]
}
};
- Add more MIME types as needed
- Add more options (e.g. enable/disable logging)
- Attributes don't support all attributes
- Only 3 note types supported
- Only a subset of MIME types supported