Class: BNote

BNote()

Trilium's main entity which can represent text note, image, code note, file attachment etc.

Constructor

new BNote()

Extends

Members

(protected) becca

Overrides:

dateCreated :string

Type:
  • string

dateModified :string

Type:
  • string

flatTextCache :string|null

Type:
  • string | null

isBeingDeleted :boolean

- set during the deletion operation, before it is completed (removed from becca completely)
Type:
  • boolean

isDecrypted :boolean

Type:
  • boolean

isProtected :boolean

Type:
  • boolean

mime :string

Type:
  • string

noteId :string

Type:
  • string

title :string

Type:
  • string

type :string

Type:
  • string

utcDateCreated :string

Type:
  • string

utcDateModified :string

Type:
  • string

Methods

addAttribute(type, name, valueopt, isInheritableopt, positionopt) → {Attribute}

Adds a new attribute to this note. The attribute is saved and returned. See addLabel, addRelation for more specific methods.
Parameters:
Name Type Attributes Default Description
type string attribute type (label / relation)
name string name of the attribute, not including the leading ~/#
value string <optional>
value of the attribute - text for labels, target note ID for relations; optional.
isInheritable boolean <optional>
false
position int <optional>
1000
Returns:
Type
Attribute

(protected) addEntityChange()

Overrides:

addLabel(name, valueopt, isInheritableopt) → {Attribute}

Adds a new label to this note. The label attribute is saved and returned.
Parameters:
Name Type Attributes Default Description
name string name of the label, not including the leading #
value string <optional>
text value of the label; optional
isInheritable boolean <optional>
false
Returns:
Type
Attribute

addRelation(name, targetNoteId, isInheritableopt) → {Attribute}

Adds a new relation to this note. The relation attribute is saved and returned.
Parameters:
Name Type Attributes Default Description
name string name of the relation, not including the leading ~
targetNoteId string
isInheritable boolean <optional>
false
Returns:
Type
Attribute

(protected) beforeSaving()

Overrides:

cloneTo(parentNoteId) → {Object}

Parameters:
Name Type Description
parentNoteId
Returns:
Type
Object

deleteNote(deleteIdopt, taskContextopt)

(Soft) delete a note and all its descendants.
Parameters:
Name Type Attributes Description
deleteId string <optional>
optional delete identified
taskContext TaskContext <optional>

(protected) generateHash()

Overrides:

(protected) generateIdIfNecessary()

Overrides:

getAllNotePaths() → {Array.<Array.<string>>}

Returns:
- array of notePaths (each represented by array of noteIds constituting the particular note path)
Type
Array.<Array.<string>>

getAncestors() → {Array.<BNote>}

Returns:
Type
Array.<BNote>

getAttribute(type, name) → {Attribute}

Parameters:
Name Type Description
type string attribute type (label, relation, etc.)
name string attribute name
Returns:
attribute of given type and name. If there's more such attributes, first is returned. Returns null if there's no such attribute belonging to this note.
Type
Attribute

getAttributeValue(type, name) → {string|null}

Parameters:
Name Type Description
type string attribute type (label, relation, etc.)
name string attribute name
Returns:
attribute value of given type and name or null if no such attribute exists.
Type
string | null

getAttributes(typeopt, nameopt) → {Array.<Attribute>}

Parameters:
Name Type Attributes Description
type string <optional>
(optional) attribute type to filter
name string <optional>
(optional) attribute name to filter
Returns:
all note's attributes, including inherited ones
Type
Array.<Attribute>

getBranches() → {Array.<BBranch>}

Deprecated:
  • use getParentBranches() instead
Returns:
Type
Array.<BBranch>

getChildBranches() → {Array.<BBranch>}

Returns:
Type
Array.<BBranch>

getChildNotes() → {Array.<BNote>}

Returns:
Type
Array.<BNote>

getContent() → {*}

Returns:
Type
*

getContentMetadata() → {Object}

Returns:
Type
Object

getDescendantNoteIds()

Deprecated:
  • use getSubtreeNoteIds() instead

getFlatText() → {string}

This is used for: - fast searching - note similarity evaluation
Returns:
- returns flattened textual representation of note, prefixes and attributes
Type
string

getJsonContent() → {*}

Returns:
Type
*

getLabel(name) → {Attribute|null}

Parameters:
Name Type Description
name string label name
Returns:
label if it exists, null otherwise
Type
Attribute | null

getLabelValue(name) → {string|null}

Parameters:
Name Type Description
name string label name
Returns:
label value if label exists, null otherwise
Type
string | null

getLabelValues(nameopt) → {Array.<string>}

Parameters:
Name Type Attributes Description
name string <optional>
label name to filter
Returns:
all note's label values, including inherited ones
Type
Array.<string>

getLabels(nameopt) → {Array.<Attribute>}

Parameters:
Name Type Attributes Description
name string <optional>
label name to filter
Returns:
all note's labels (attributes with type label), including inherited ones
Type
Array.<Attribute>

getOwnedAttribute() → {Attribute}

Returns:
attribute belonging to this specific note (excludes inherited attributes) This method can be significantly faster than the getAttribute()
Type
Attribute

getOwnedAttributeValue(type, name) → {string|null}

Parameters:
Name Type Description
type string attribute type (label, relation, etc.)
name string attribute name
Returns:
attribute value of given type and name or null if no such attribute exists.
Type
string | null

getOwnedAttributes(typeopt, nameopt, valueopt) → {Array.<Attribute>}

Parameters:
Name Type Attributes Default Description
type string | null <optional>
null (optional) attribute type to filter
name string | null <optional>
null (optional) attribute name to filter
value string | null <optional>
null (optional) attribute value to filter
Returns:
note's "owned" attributes - excluding inherited ones
Type
Array.<Attribute>

getOwnedLabel(name) → {Attribute|null}

Parameters:
Name Type Description
name string label name
Returns:
label if it exists, null otherwise
Type
Attribute | null

getOwnedLabelValue(name) → {string|null}

Parameters:
Name Type Description
name string label name
Returns:
label value if label exists, null otherwise
Type
string | null

getOwnedLabelValues(nameopt) → {Array.<string>}

Parameters:
Name Type Attributes Description
name string <optional>
label name to filter
Returns:
all note's label values, excluding inherited ones
Type
Array.<string>

getOwnedLabels(nameopt) → {Array.<Attribute>}

Parameters:
Name Type Attributes Description
name string <optional>
label name to filter
Returns:
all note's labels (attributes with type label), excluding inherited ones
Type
Array.<Attribute>

getOwnedRelation(name) → {Attribute|null}

Parameters:
Name Type Description
name string relation name
Returns:
relation if it exists, null otherwise
Type
Attribute | null

getOwnedRelationValue(name) → {string|null}

Parameters:
Name Type Description
name string relation name
Returns:
relation value if relation exists, null otherwise
Type
string | null

getOwnedRelations(nameopt) → {Array.<Attribute>}

Parameters:
Name Type Attributes Description
name string <optional>
relation name to filter
Returns:
all note's relations (attributes with type relation), excluding inherited ones
Type
Array.<Attribute>

getParentBranches() → {Array.<BBranch>}

Returns:
Type
Array.<BBranch>

getParentNotes() → {Array.<BNote>}

Returns:
Type
Array.<BNote>

(protected) getPojoToSave()

Overrides:

getRelation(name) → {Attribute|null}

Parameters:
Name Type Description
name string relation name
Returns:
relation if it exists, null otherwise
Type
Attribute | null

getRelationValue(name) → {string|null}

Parameters:
Name Type Description
name string relation name
Returns:
relation value if relation exists, null otherwise
Type
string | null

getRelations(nameopt) → {Array.<Attribute>}

Parameters:
Name Type Attributes Description
name string <optional>
relation name to filter
Returns:
all note's relations (attributes with type relation), including inherited ones
Type
Array.<Attribute>

getScriptEnv() → {string|null}

Returns:
JS script environment - either "frontend" or "backend"
Type
string | null

getSearchResultNotes() → {Array.<BNote>}

Returns:
Type
Array.<BNote>

getStrongParentBranches() → {Array.<BBranch>}

Returns strong (as opposed to weak) parent branches. See isWeak for details.
Returns:
Type
Array.<BBranch>

getSubtree() → {Object}

Returns:
Type
Object

getSubtreeNoteIds() → {Array.<String>}

Returns:
- includes the subtree node as well
Type
Array.<String>

getSubtreeNotesIncludingTemplated() → {Array.<BNote>}

Returns:
Type
Array.<BNote>

getTemplatedNotes() → {Array.<BNote>}

Returns:
- returns only notes which are templated, does not include their subtrees in effect returns notes which are influenced by note's non-inheritable attributes
Type
Array.<BNote>

(protected) getUtcDateChanged()

Overrides:

hasAncestor() → {boolean}

Returns:
Type
boolean

hasAttribute(type, name, valueopt) → {boolean}

Parameters:
Name Type Attributes Default Description
type
name
value <optional>
null
Returns:
Type
boolean

hasChildren() → {boolean}

Returns:
Type
boolean

hasLabel(name, valueopt) → {boolean}

Parameters:
Name Type Attributes Description
name string label name
value string <optional>
label value
Returns:
true if label exists (including inherited)
Type
boolean

hasOwnedAttribute(type, name, valueopt) → {boolean}

Parameters:
Name Type Attributes Description
type string attribute type (label, relation, etc.)
name string attribute name
value string <optional>
attribute value
Returns:
true if note has an attribute with given type and name (excluding inherited)
Type
boolean

hasOwnedLabel(name, valueopt) → {boolean}

Parameters:
Name Type Attributes Description
name string label name
value string <optional>
label value
Returns:
true if label exists (excluding inherited)
Type
boolean

hasOwnedRelation(name, valueopt) → {boolean}

Parameters:
Name Type Attributes Description
name string relation name
value string <optional>
relation value
Returns:
true if relation exists (excluding inherited)
Type
boolean

hasRelation(name, valueopt) → {boolean}

Parameters:
Name Type Attributes Description
name string relation name
value string <optional>
relation value
Returns:
true if relation exists (including inherited)
Type
boolean

isDescendantOfNote(ancestorNoteId) → {boolean}

Parameters:
Name Type Description
ancestorNoteId
Returns:
- true if ancestorNoteId occurs in at least one of the note's paths
Type
boolean

isHtml() → {boolean}

Returns:
true if this note is HTML
Type
boolean

isJavaScript() → {boolean}

Returns:
true if this note is JavaScript (code or attachment)
Type
boolean

isJson() → {boolean}

Returns:
true if this note is of application/json content type
Type
boolean

isRoot() → {boolean}

Returns:
true if this note is the root of the note tree. Root note has "root" noteId
Type
boolean

isStringNote() → {boolean}

Returns:
true if the note has string content (not binary)
Type
boolean

markAsDeleted(deleteIdopt)

Mark the entity as (soft) deleted. It will be completely erased later. This is a low level method, for notes and branches use `note.deleteNote()` and 'branch.deleteBranch()` instead.
Parameters:
Name Type Attributes Default Description
deleteId <optional>
null
Overrides:

removeAttribute(type, name, valueopt)

Removes given attribute name-value pair if it exists.
Parameters:
Name Type Attributes Description
type string attribute type (label, relation, etc.)
name string attribute name
value string <optional>
attribute value (optional)

removeLabel(name, valueopt)

Remove label name-value pair, if it exists.
Parameters:
Name Type Attributes Description
name string label name
value string <optional>
label value

removeRelation(name, valueopt)

Remove relation name-value pair, if it exists.
Parameters:
Name Type Attributes Description
name string relation name
value string <optional>
relation value (noteId)

save() → {this}

Saves entity - executes SQL, but doesn't commit the transaction on its own
Overrides:
Returns:
Type
this

saveNoteRevision() → {BNoteRevision|null}

Returns:
Type
BNoteRevision | null

setAttribute(type, name, valueopt)

Update's given attribute's value or creates it if it doesn't exist
Parameters:
Name Type Attributes Description
type string attribute type (label, relation, etc.)
name string attribute name
value string <optional>
attribute value (optional)

setLabel(name, valueopt)

Update's given label's value or creates it if it doesn't exist
Parameters:
Name Type Attributes Description
name string label name
value string <optional>
label value

setRelation(name, value)

Update's given relation's value or creates it if it doesn't exist
Parameters:
Name Type Description
name string relation name
value string relation value (noteId)

toggleAttribute(type, enabled, name, valueopt)

Based on enabled, attribute is either set or removed.
Parameters:
Name Type Attributes Description
type string attribute type ('relation', 'label' etc.)
enabled boolean toggle On or Off
name string attribute name
value string <optional>
attribute value (optional)

toggleLabel(enabled, name, valueopt)

Based on enabled, label is either set or removed.
Parameters:
Name Type Attributes Description
enabled boolean toggle On or Off
name string label name
value string <optional>
label value (optional)

toggleRelation(enabled, name, valueopt)

Based on enabled, relation is either set or removed.
Parameters:
Name Type Attributes Description
enabled boolean toggle On or Off
name string relation name
value string <optional>
relation value (noteId)