new BackendScriptApi()
This is the main backend API interface for scripts. All the properties and methods are published in the "api" object
available in the JS backend notes. You can use e.g. api.log(api.startNote.title);
- Source:
Members
__private
This object contains "at your risk" and "no BC guarantees" objects for advanced use cases.
Properties:
- Source:
axios
Properties:
- Deprecated:
- use native (browser compatible) fetch() instead
- Source:
currentNote
Properties:
Name |
Type |
Description |
note |
BNote
|
where script is currently executing. Don't mix this up with concept of active note |
- Source:
dayjs
Properties:
Name |
Type |
Description |
day.js |
dayjs
|
library for date manipulation. See https://day.js.org for documentation |
- Source:
originEntity
Properties:
- Source:
sql
Properties:
- Source:
startNote
Properties:
Name |
Type |
Description |
note |
BNote
|
where script started executing |
- Source:
xml2js
Properties:
- Source:
Methods
createDataNote(parentNoteId, title, content) → {Object}
Create data note - data in this context means object serializable to JSON. Created note will be of type 'code' and
JSON MIME type. See also createNewNote() for more options.
Parameters:
Name |
Type |
Description |
parentNoteId |
string
|
|
title |
string
|
|
content |
object
|
|
- Source:
Returns:
object having "note" and "branch" keys representing respective objects
-
Type
-
Object
createNewNote() → {Object}
Properties:
Name |
Type |
Description |
params |
object
|
Properties
Name |
Type |
Attributes |
Default |
Description |
parentNoteId |
string
|
|
|
|
title |
string
|
|
|
|
content |
string
|
buffer
|
|
|
|
type |
string
|
|
|
text, code, file, image, search, book, relationMap, canvas |
mime |
string
|
<optional>
|
|
value is derived from default mimes for type |
isProtected |
boolean
|
<optional>
|
false
|
|
isExpanded |
boolean
|
<optional>
|
false
|
|
prefix |
string
|
<optional>
|
''
|
|
notePosition |
int
|
<optional>
|
|
default is last existing notePosition in a parent + 10 |
|
- Source:
Returns:
object contains newly created entities note and branch
-
Type
-
Object
createNote(parentNoteId, title, contentopt, extraOptionsopt) → {Object}
Parameters:
Name |
Type |
Attributes |
Default |
Description |
parentNoteId |
string
|
|
|
create new note under this parent |
title |
string
|
|
|
|
content |
string
|
<optional>
|
""
|
|
extraOptions |
object
|
<optional>
|
{}
|
|
Properties:
Name |
Type |
Attributes |
Default |
Description |
extraOptions.json |
boolean
|
<optional>
|
false
|
should the note be JSON |
extraOptions.isProtected |
boolean
|
<optional>
|
false
|
should the note be protected |
extraOptions.type |
string
|
<optional>
|
'text'
|
note type |
extraOptions.mime |
string
|
<optional>
|
'text/html'
|
MIME type of the note |
extraOptions.attributes |
Array.<object>
|
<optional>
|
[]
|
attributes to be created for this note
Properties
Name |
Type |
Attributes |
Description |
type |
string
|
|
attribute type - label, relation etc. |
name |
string
|
|
attribute name |
value |
string
|
<optional>
|
attribute value |
|
- Deprecated:
- please use createTextNote() with similar API for simpler use cases or createNewNote() for more complex needs
- Source:
Returns:
object contains newly created entities note and branch
-
Type
-
Object
createOrUpdateLauncher(opts) → {Object}
Creates a new launcher to the launchbar. If the launcher (id) already exists, it will be updated.
Parameters:
Name |
Type |
Description |
opts |
object
|
|
Properties:
Name |
Type |
Attributes |
Default |
Description |
opts.id |
string
|
|
|
id of the launcher, only alphanumeric at least 6 characters long |
opts.type |
string
|
|
|
one of
* "note" - activating the launcher will navigate to the target note (specified in targetNoteId param)
* "script" - activating the launcher will execute the script (specified in scriptNoteId param)
* "customWidget" - the launcher will be rendered with a custom widget (specified in widgetNoteId param) |
opts.title |
string
|
|
|
|
opts.isVisible |
boolean
|
<optional>
|
false
|
if true, will be created in the "Visible launchers", otherwise in "Available launchers" |
opts.icon |
string
|
<optional>
|
|
name of the boxicon to be used (e.g. "bx-time") |
opts.keyboardShortcut |
string
|
<optional>
|
|
will activate the target note/script upon pressing, e.g. "ctrl+e" |
opts.targetNoteId |
string
|
<optional>
|
|
for type "note" |
opts.scriptNoteId |
string
|
<optional>
|
|
for type "script" |
opts.widgetNoteId |
string
|
<optional>
|
|
for type "customWidget" |
- Source:
Returns:
-
Type
-
Object
createTextNote(parentNoteId, title, content) → {Object}
Create text note. See also createNewNote() for more options.
Parameters:
Name |
Type |
Description |
parentNoteId |
string
|
|
title |
string
|
|
content |
string
|
|
- Source:
Returns:
- object having "note" and "branch" keys representing respective objects
-
Type
-
Object
ensureNoteIsAbsentFromParent(noteId, parentNoteId) → {void}
If there's a branch between note and parent note, remove it. Otherwise, do nothing.
Parameters:
Name |
Type |
Description |
noteId |
string
|
|
parentNoteId |
string
|
|
- Source:
Returns:
-
Type
-
void
ensureNoteIsPresentInParent(noteId, parentNoteId, prefix) → {Object}
If there's no branch between note and parent note, create one. Otherwise, do nothing. Returns the new or existing branch.
Parameters:
Name |
Type |
Description |
noteId |
string
|
|
parentNoteId |
string
|
|
prefix |
string
|
if branch will be created between note and parent note, set this prefix |
- Source:
Returns:
-
Type
-
Object
escapeHtml(string) → {string}
Parameters:
Name |
Type |
Description |
string |
string
|
to escape |
- Source:
Returns:
escaped string
-
Type
-
string
exportSubtreeToZipFile(noteId, format, zipFilePath) → {Promise.<void>}
Parameters:
Name |
Type |
Description |
noteId |
string
|
|
format |
string
|
either 'html' or 'markdown' |
zipFilePath |
string
|
|
- Source:
Returns:
-
Type
-
Promise.<void>
getAppInfo() → {Object|*}
- Source:
Returns:
- object representing basic info about running Trilium version
-
Type
-
Object
|
*
getAttribute(attributeId) → {BAttribute|null}
Parameters:
Name |
Type |
Description |
attributeId |
string
|
|
- Source:
Returns:
-
Type
-
BAttribute
|
null
getBranch(branchId) → {BBranch|null}
Parameters:
Name |
Type |
Description |
branchId |
string
|
|
- Source:
Returns:
-
Type
-
BBranch
|
null
getDayNote(date, rootNoteopt) → {BNote|null}
Returns day note for given date. If such note doesn't exist, it is created.
Parameters:
Name |
Type |
Attributes |
Description |
date |
string
|
|
in YYYY-MM-DD format |
rootNote |
BNote
|
<optional>
|
specify calendar root note, normally leave empty to use the default calendar |
- Source:
Returns:
-
Type
-
BNote
|
null
getInstanceName() → {string|null}
Instance name identifies particular Trilium instance. It can be useful for scripts
if some action needs to happen on only one specific instance.
- Source:
Returns:
-
Type
-
string
|
null
getMonthNote(date, rootNoteopt) → {BNote|null}
Returns month note for given date. If such note doesn't exist, it is created.
Parameters:
Name |
Type |
Attributes |
Description |
date |
string
|
|
in YYYY-MM format |
rootNote |
BNote
|
<optional>
|
specify calendar root note, normally leave empty to use the default calendar |
- Source:
Returns:
-
Type
-
BNote
|
null
getNote(noteId) → {BNote|null}
Parameters:
Name |
Type |
Description |
noteId |
string
|
|
- Source:
Returns:
-
Type
-
BNote
|
null
getNoteWithLabel(name, valueopt) → {BNote|null}
Retrieves first note with given label name & value
Parameters:
Name |
Type |
Attributes |
Description |
name |
string
|
|
attribute name |
value |
string
|
<optional>
|
attribute value |
- Source:
Returns:
-
Type
-
BNote
|
null
getNotesWithLabel(name, valueopt) → {Array.<BNote>}
Retrieves notes with given label name & value
Parameters:
Name |
Type |
Attributes |
Description |
name |
string
|
|
attribute name |
value |
string
|
<optional>
|
attribute value |
- Source:
Returns:
-
Type
-
Array.<BNote>
getRootCalendarNote() → {BNote|null}
Returns root note of the calendar.
- Source:
Returns:
-
Type
-
BNote
|
null
getTodayNote(rootNoteopt) → {BNote|null}
Returns today's day note. If such note doesn't exist, it is created.
Parameters:
Name |
Type |
Attributes |
Description |
rootNote |
BNote
|
<optional>
|
specify calendar root note, normally leave empty to use the default calendar |
- Source:
Returns:
-
Type
-
BNote
|
null
getWeekNote(date, optionsopt, rootNoteopt) → {BNote|null}
Returns note for the first date of the week of the given date.
Parameters:
Name |
Type |
Attributes |
Description |
date |
string
|
|
in YYYY-MM-DD format |
options |
object
|
<optional>
|
Properties
Name |
Type |
Attributes |
Default |
Description |
startOfTheWeek |
string
|
<optional>
|
monday
|
either "monday" (default) or "sunday" |
|
rootNote |
BNote
|
<optional>
|
specify calendar root note, normally leave empty to use the default calendar |
- Source:
Returns:
-
Type
-
BNote
|
null
getYearNote(year, rootNoteopt) → {BNote|null}
Returns year note for given year. If such note doesn't exist, it is created.
Parameters:
Name |
Type |
Attributes |
Description |
year |
string
|
|
in YYYY format |
rootNote |
BNote
|
<optional>
|
specify calendar root note, normally leave empty to use the default calendar |
- Source:
Returns:
-
Type
-
BNote
|
null
log(message) → {void}
Log given message to trilium logs and log pane in UI
Parameters:
Name |
Type |
Description |
message |
|
|
- Source:
Returns:
-
Type
-
void
randomString(length) → {string}
Return randomly generated string of given length. This random string generation is NOT cryptographically secure.
Parameters:
Name |
Type |
Description |
length |
number
|
of the string |
- Source:
Returns:
random string
-
Type
-
string
searchForNote(query, searchParamsopt) → {BNote|null}
Parameters:
Name |
Type |
Attributes |
Description |
query |
string
|
|
|
searchParams |
Object
|
<optional>
|
|
- Source:
Returns:
-
Type
-
BNote
|
null
searchForNotes(query, searchParamsopt) → {Array.<BNote>}
Parameters:
Name |
Type |
Attributes |
Description |
query |
string
|
|
|
searchParams |
Object
|
<optional>
|
|
- Source:
Returns:
-
Type
-
Array.<BNote>
setNoteToParent(noteId, prefix, parentNoteId) → {void}
This method finds note by its noteId and prefix and either sets it to the given parentNoteId
or removes the branch (if parentNoteId is not given).
This method looks similar to toggleNoteInParent() but differs because we're looking up branch by prefix.
Parameters:
Name |
Type |
Description |
noteId |
string
|
|
prefix |
string
|
|
parentNoteId |
string
|
null
|
|
- Deprecated:
- this method is pretty confusing and serves specialized purpose only
- Source:
Returns:
-
Type
-
void
sortNotes(parentNoteId, sortConfigopt) → {void}
Sort child notes of a given note.
Parameters:
Name |
Type |
Attributes |
Description |
parentNoteId |
string
|
|
this note's child notes will be sorted |
sortConfig |
object
|
<optional>
|
|
Properties:
Name |
Type |
Attributes |
Default |
Description |
sortConfig.sortBy |
string
|
<optional>
|
title
|
'title', 'dateCreated', 'dateModified' or a label name
See https://github.com/zadam/trilium/wiki/Sorting for details. |
sortConfig.reverse |
boolean
|
<optional>
|
false
|
|
sortConfig.foldersFirst |
boolean
|
<optional>
|
false
|
|
- Source:
Returns:
-
Type
-
void
toggleNoteInParent(present, noteId, parentNoteId, prefix) → {void}
Based on the value, either create or remove branch between note and parent note.
Parameters:
Name |
Type |
Description |
present |
boolean
|
true if we want the branch to exist, false if we want it gone |
noteId |
string
|
|
parentNoteId |
string
|
|
prefix |
string
|
if branch will be created between note and parent note, set this prefix |
- Source:
Returns:
-
Type
-
void
transactional(func) → {?}
This functions wraps code which is supposed to be running in transaction. If transaction already
exists, then we'll use that transaction.
Parameters:
Name |
Type |
Description |
func |
function
|
|
- Source:
Returns:
result of func callback
-
Type
-
?
unescapeHtml(string) → {string}
Parameters:
Name |
Type |
Description |
string |
string
|
to unescape |
- Source:
Returns:
unescaped string
-
Type
-
string