mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-26 07:46:30 +01:00 
			
		
		
		
	Compare commits
	
		
			50 Commits
		
	
	
		
			v0.61.8-be
			...
			v0.61.11
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | d3a477b8f2 | ||
|  | 01093d05d7 | ||
|  | a9b63111ae | ||
|  | ed1a731950 | ||
|  | ef974ab1f5 | ||
|  | 1cd391a132 | ||
|  | 1c15527d95 | ||
|  | 7af79ec33b | ||
|  | 4294c043d8 | ||
|  | e5b925abf8 | ||
|  | 90c0a4a437 | ||
|  | 692f7868bc | ||
|  | 5282af55f6 | ||
|  | aefc4c6bd2 | ||
|  | b39ba76505 | ||
|  | 9d918e7a54 | ||
|  | 38db7f9db7 | ||
|  | 5163e50e7d | ||
|  | 5115b33446 | ||
|  | b01fe5ead9 | ||
|  | b1d4a258a1 | ||
|  | ca041bb658 | ||
|  | 87a60e325f | ||
|  | 0a172d8bc1 | ||
|  | 67a12d3c4d | ||
|  | 5b2ba3646d | ||
|  | 148bff9f77 | ||
|  | 2132cf3bdc | ||
|  | d5271c17e3 | ||
|  | b764761e58 | ||
|  | c666fc3b98 | ||
|  | ba34df2e15 | ||
|  | 840ac2d63e | ||
|  | 5dd4586ebe | ||
|  | d09d3f5a96 | ||
|  | 3d15aeae58 | ||
|  | 9765892d18 | ||
|  | 78f8a37587 | ||
|  | 86d62866f2 | ||
|  | 1dc3fafcbf | ||
|  | 7f06952d9e | ||
|  | 78b6614eea | ||
|  | 9665e872c2 | ||
|  | 9db0a062ed | ||
|  | 055bb39e4d | ||
|  | 1261a06a30 | ||
|  | 91eb3c45d5 | ||
|  | 3944235592 | ||
|  | 5be61e6142 | ||
|  | 62ccf798ee | 
| @@ -2,7 +2,7 @@ image: | |||||||
|   file: .gitpod.dockerfile |   file: .gitpod.dockerfile | ||||||
|  |  | ||||||
| tasks: | tasks: | ||||||
|     - before: nvm install 18.18.0 && nvm use 18.18.0 |     - before: nvm install 18.18.2 && nvm use 18.18.2 | ||||||
|       init: npm install |       init: npm install | ||||||
|       command: npm run start-server |       command: npm run start-server | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| # !!! Don't try to build this Dockerfile directly, run it through bin/build-docker.sh script !!! | # !!! Don't try to build this Dockerfile directly, run it through bin/build-docker.sh script !!! | ||||||
| FROM node:18.18.0-alpine | FROM node:18.18.2-alpine | ||||||
|  |  | ||||||
| # Create app directory | # Create app directory | ||||||
| WORKDIR /usr/src/app | WORKDIR /usr/src/app | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| #!/usr/bin/env bash | #!/usr/bin/env bash | ||||||
|  |  | ||||||
| PKG_DIR=dist/trilium-linux-x64-server | PKG_DIR=dist/trilium-linux-x64-server | ||||||
| NODE_VERSION=18.18.0 | NODE_VERSION=18.18.2 | ||||||
|  |  | ||||||
| if [ "$1" != "DONTCOPY" ] | if [ "$1" != "DONTCOPY" ] | ||||||
| then | then | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ if [[ $# -eq 0 ]] ; then | |||||||
|     exit 1 |     exit 1 | ||||||
| fi | fi | ||||||
|  |  | ||||||
| n exec 18.18.0 npm run webpack | n exec 18.18.2 npm run webpack | ||||||
|  |  | ||||||
| DIR=$1 | DIR=$1 | ||||||
|  |  | ||||||
| @@ -27,7 +27,7 @@ cp -r electron.js $DIR/ | |||||||
| cp webpack-* $DIR/ | cp webpack-* $DIR/ | ||||||
|  |  | ||||||
| # run in subshell (so we return to original dir) | # run in subshell (so we return to original dir) | ||||||
| (cd $DIR && n exec 18.18.0 npm install --only=prod) | (cd $DIR && n exec 18.18.2 npm install --only=prod) | ||||||
|  |  | ||||||
| # cleanup of useless files in dependencies | # cleanup of useless files in dependencies | ||||||
| rm -r $DIR/node_modules/image-q/demo | rm -r $DIR/node_modules/image-q/demo | ||||||
|   | |||||||
							
								
								
									
										0
									
								
								bin/create-anonymization-script.js
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								bin/create-anonymization-script.js
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -1,165 +1,47 @@ | |||||||
|  |  | ||||||
| UPDATE etapi_tokens SET tokenHash = 'API token hash value'; | UPDATE etapi_tokens SET tokenHash = 'API token hash value'; | ||||||
| UPDATE notes SET title = 'title' WHERE noteId != 'root' AND noteId NOT LIKE '\_%' ESCAPE '\'; | UPDATE notes SET title = 'title' WHERE title NOT IN ('root', '_hidden', '_share'); | ||||||
| UPDATE blobs SET content = 'text' WHERE content IS NOT NULL; | UPDATE blobs SET content = 'text' WHERE content IS NOT NULL; | ||||||
| UPDATE revisions SET title = 'title'; | UPDATE revisions SET title = 'title'; | ||||||
|  |  | ||||||
| UPDATE attributes SET name = 'name', value = 'value' | UPDATE attributes SET name  = 'name', value = 'value' WHERE type = 'label' | ||||||
|                   WHERE type = 'label' |   AND name NOT IN | ||||||
|                     AND name NOT IN ('inbox', |       ('inbox', 'disableVersioning', 'calendarRoot', 'archived', 'excludeFromExport', 'disableInclusion', 'appCss', | ||||||
|                                      'disableVersioning', |        'appTheme', 'hidePromotedAttributes', 'readOnly', 'autoReadOnlyDisabled', 'cssClass', 'iconClass', | ||||||
|                                      'calendarRoot', |        'keyboardShortcut', 'run', 'runOnInstance', 'runAtHour', 'customRequestHandler', 'customResourceProvider', | ||||||
|                                      'archived', |        'widget', 'noteInfoWidgetDisabled', 'linkMapWidgetDisabled', 'revisionsWidgetDisabled', | ||||||
|                                      'excludeFromExport', |        'whatLinksHereWidgetDisabled', 'similarNotesWidgetDisabled', 'workspace', 'workspaceIconClass', | ||||||
|                                      'disableInclusion', |        'workspaceTabBackgroundColor', 'workspaceCalendarRoot', 'workspaceTemplate', 'searchHome', 'workspaceInbox', | ||||||
|                                      'appCss', |        'workspaceSearchHome', 'sqlConsoleHome', 'datePattern', 'pageSize', 'viewType', 'mapRootNoteId', | ||||||
|                                      'appTheme', |        'bookmarkFolder', 'sorted', 'sortDirection', 'sortFoldersFirst', 'sortNatural', 'sortLocale', 'top', | ||||||
|                                      'hidePromotedAttributes', |        'fullContentWidth', 'shareHiddenFromTree', 'shareOmitDefaultCss', 'shareRoot', 'shareDescription', | ||||||
|                                      'readOnly', |        'shareRaw', 'shareDisallowRobotIndexing', 'shareIndex', 'displayRelations', 'hideRelations', 'titleTemplate', | ||||||
|                                      'autoReadOnlyDisabled', |        'template', 'toc', 'color', 'keepCurrentHoisting', 'executeButton', 'executeDescription', 'newNotesOnTop', | ||||||
|                                      'cssClass', |        'clipperInbox', 'internalLink', 'imageLink', 'relationMapLink', 'includeMapLink', 'runOnNoteCreation', | ||||||
|                                      'iconClass', |        'runOnNoteTitleChange', 'runOnNoteChange', 'runOnNoteContentChange', 'runOnNoteDeletion', 'runOnBranchCreation', | ||||||
|                                      'keyboardShortcut', |        'runOnBranchDeletion', 'runOnChildNoteCreation', 'runOnAttributeCreation', 'runOnAttributeChange', 'template', | ||||||
|                                      'run', |        'inherit', 'widget', 'renderNote', 'shareCss', 'shareJs', 'shareFavicon'); | ||||||
|                                      'runOnInstance', | UPDATE attributes SET name = 'name' WHERE type = 'relation' | ||||||
|                                      'runAtHour', |   AND name NOT IN | ||||||
|                                      'customRequestHandler', |       ('inbox', 'disableVersioning', 'calendarRoot', 'archived', 'excludeFromExport', 'disableInclusion', 'appCss', | ||||||
|                                      'customResourceProvider', |        'appTheme', 'hidePromotedAttributes', 'readOnly', 'autoReadOnlyDisabled', 'cssClass', 'iconClass', | ||||||
|                                      'widget', |        'keyboardShortcut', 'run', 'runOnInstance', 'runAtHour', 'customRequestHandler', 'customResourceProvider', | ||||||
|                                      'noteInfoWidgetDisabled', |        'widget', 'noteInfoWidgetDisabled', 'linkMapWidgetDisabled', 'revisionsWidgetDisabled', | ||||||
|                                      'linkMapWidgetDisabled', |        'whatLinksHereWidgetDisabled', 'similarNotesWidgetDisabled', 'workspace', 'workspaceIconClass', | ||||||
|                                      'revisionsWidgetDisabled', |        'workspaceTabBackgroundColor', 'workspaceCalendarRoot', 'workspaceTemplate', 'searchHome', 'workspaceInbox', | ||||||
|                                      'whatLinksHereWidgetDisabled', |        'workspaceSearchHome', 'sqlConsoleHome', 'datePattern', 'pageSize', 'viewType', 'mapRootNoteId', | ||||||
|                                      'similarNotesWidgetDisabled', |        'bookmarkFolder', 'sorted', 'sortDirection', 'sortFoldersFirst', 'sortNatural', 'sortLocale', 'top', | ||||||
|                                      'workspace', |        'fullContentWidth', 'shareHiddenFromTree', 'shareOmitDefaultCss', 'shareRoot', 'shareDescription', | ||||||
|                                      'workspaceIconClass', |        'shareRaw', 'shareDisallowRobotIndexing', 'shareIndex', 'displayRelations', 'hideRelations', 'titleTemplate', | ||||||
|                                      'workspaceTabBackgroundColor', |        'template', 'toc', 'color', 'keepCurrentHoisting', 'executeButton', 'executeDescription', 'newNotesOnTop', | ||||||
|                                      'searchHome', |        'clipperInbox', 'internalLink', 'imageLink', 'relationMapLink', 'includeMapLink', 'runOnNoteCreation', | ||||||
|                                      'workspaceInbox', |        'runOnNoteTitleChange', 'runOnNoteChange', 'runOnNoteContentChange', 'runOnNoteDeletion', 'runOnBranchCreation', | ||||||
|                                      'workspaceSearchHome', |        'runOnBranchDeletion', 'runOnChildNoteCreation', 'runOnAttributeCreation', 'runOnAttributeChange', 'template', | ||||||
|                                      'sqlConsoleHome', |        'inherit', 'widget', 'renderNote', 'shareCss', 'shareJs', 'shareFavicon'); | ||||||
|                                      'datePattern', |  | ||||||
|                                      'pageSize', |  | ||||||
|                                      'viewType', |  | ||||||
|                                      'mapRootNoteId', |  | ||||||
|                                      'bookmarkFolder', |  | ||||||
|                                      'sorted', |  | ||||||
|                                      'top', |  | ||||||
|                                      'fullContentWidth', |  | ||||||
|                                      'shareHiddenFromTree', |  | ||||||
|                                      'shareAlias', |  | ||||||
|                                      'shareOmitDefaultCss', |  | ||||||
|                                      'shareRoot', |  | ||||||
|                                      'internalLink', |  | ||||||
|                                      'imageLink', |  | ||||||
|                                      'relationMapLink', |  | ||||||
|                                      'includeMapLink', |  | ||||||
|                                      'runOnNoteCreation', |  | ||||||
|                                      'runOnNoteTitleChange', |  | ||||||
|                                      'runOnNoteContentChange', |  | ||||||
|                                      'runOnNoteChange', |  | ||||||
|                                      'runOnChildNoteCreation', |  | ||||||
|                                      'runOnAttributeCreation', |  | ||||||
|                                      'runOnAttributeChange', |  | ||||||
|                                      'template', |  | ||||||
|                                      'inherit', |  | ||||||
|                                      'widget', |  | ||||||
|                                      'renderNote', |  | ||||||
|                                      'shareCss', |  | ||||||
|                                      'shareJs', |  | ||||||
|                                      'shareFavicon', |  | ||||||
|                                      'executeButton', |  | ||||||
|                                      'keepCurrentHoisting', |  | ||||||
|                                      'color', |  | ||||||
|                                      'toc', |  | ||||||
|                                      'excludeFromNoteMap', |  | ||||||
|                                      'docName', |  | ||||||
|                                      'launcherType', |  | ||||||
|                                      'builtinWidget', |  | ||||||
|                                      'baseSize', |  | ||||||
|                                      'growthFactor' |  | ||||||
|                       ); |  | ||||||
|  |  | ||||||
| UPDATE attributes SET name = 'name' |  | ||||||
|                     AND name NOT IN ('inbox', |  | ||||||
|                                      'disableVersioning', |  | ||||||
|                                      'calendarRoot', |  | ||||||
|                                      'archived', |  | ||||||
|                                      'excludeFromExport', |  | ||||||
|                                      'disableInclusion', |  | ||||||
|                                      'appCss', |  | ||||||
|                                      'appTheme', |  | ||||||
|                                      'hidePromotedAttributes', |  | ||||||
|                                      'readOnly', |  | ||||||
|                                      'autoReadOnlyDisabled', |  | ||||||
|                                      'cssClass', |  | ||||||
|                                      'iconClass', |  | ||||||
|                                      'keyboardShortcut', |  | ||||||
|                                      'run', |  | ||||||
|                                      'runOnInstance', |  | ||||||
|                                      'runAtHour', |  | ||||||
|                                      'customRequestHandler', |  | ||||||
|                                      'customResourceProvider', |  | ||||||
|                                      'widget', |  | ||||||
|                                      'noteInfoWidgetDisabled', |  | ||||||
|                                      'linkMapWidgetDisabled', |  | ||||||
|                                      'revisionsWidgetDisabled', |  | ||||||
|                                      'whatLinksHereWidgetDisabled', |  | ||||||
|                                      'similarNotesWidgetDisabled', |  | ||||||
|                                      'workspace', |  | ||||||
|                                      'workspaceIconClass', |  | ||||||
|                                      'workspaceTabBackgroundColor', |  | ||||||
|                                      'searchHome', |  | ||||||
|                                      'workspaceInbox', |  | ||||||
|                                      'workspaceSearchHome', |  | ||||||
|                                      'sqlConsoleHome', |  | ||||||
|                                      'datePattern', |  | ||||||
|                                      'pageSize', |  | ||||||
|                                      'viewType', |  | ||||||
|                                      'mapRootNoteId', |  | ||||||
|                                      'bookmarkFolder', |  | ||||||
|                                      'sorted', |  | ||||||
|                                      'top', |  | ||||||
|                                      'fullContentWidth', |  | ||||||
|                                      'shareHiddenFromTree', |  | ||||||
|                                      'shareAlias', |  | ||||||
|                                      'shareOmitDefaultCss', |  | ||||||
|                                      'shareRoot', |  | ||||||
|                                      'internalLink', |  | ||||||
|                                      'imageLink', |  | ||||||
|                                      'relationMapLink', |  | ||||||
|                                      'includeMapLink', |  | ||||||
|                                      'runOnNoteCreation', |  | ||||||
|                                      'runOnNoteTitleChange', |  | ||||||
|                                      'runOnNoteContentChange', |  | ||||||
|                                      'runOnNoteChange', |  | ||||||
|                                      'runOnChildNoteCreation', |  | ||||||
|                                      'runOnAttributeCreation', |  | ||||||
|                                      'runOnAttributeChange', |  | ||||||
|                                      'template', |  | ||||||
|                                      'inherit', |  | ||||||
|                                      'widget', |  | ||||||
|                                      'renderNote', |  | ||||||
|                                      'shareCss', |  | ||||||
|                                      'shareJs', |  | ||||||
|                                      'shareFavicon', |  | ||||||
|                                      'executeButton', |  | ||||||
|                                      'keepCurrentHoisting', |  | ||||||
|                                      'color', |  | ||||||
|                                      'toc', |  | ||||||
|                                      'excludeFromNoteMap', |  | ||||||
|                                      'docName', |  | ||||||
|                                      'launcherType', |  | ||||||
|                                      'builtinWidget', |  | ||||||
|                                      'baseSize', |  | ||||||
|                                      'growthFactor' |  | ||||||
|                                     ); |  | ||||||
|  |  | ||||||
| UPDATE branches SET prefix = 'prefix' WHERE prefix IS NOT NULL AND prefix != 'recovered'; | UPDATE branches SET prefix = 'prefix' WHERE prefix IS NOT NULL AND prefix != 'recovered'; | ||||||
| UPDATE options SET value = 'anonymized' WHERE name IN | UPDATE options SET value = 'anonymized' WHERE name IN | ||||||
|                     ('documentId', 'documentSecret', 'encryptedDataKey', |       ('documentId', 'documentSecret', 'encryptedDataKey', | ||||||
|                      'passwordVerificationHash', 'passwordVerificationSalt', |        'passwordVerificationHash', 'passwordVerificationSalt', | ||||||
|                      'passwordDerivedKeySalt', 'username', 'syncServerHost', 'syncProxy') |        'passwordDerivedKeySalt', 'username', 'syncServerHost', 'syncProxy') | ||||||
|                       AND value != ''; |   AND value != ''; | ||||||
|  |  | ||||||
| VACUUM; | VACUUM; | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								db/demo.zip
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								db/demo.zip
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										1
									
								
								db/migrations/0226__rename_noteSize_label.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								db/migrations/0226__rename_noteSize_label.sql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | UPDATE attributes SET value = 'contentAndAttachmentsAndRevisionsSize' WHERE name = 'orderBy' AND value = 'noteSize'; | ||||||
| @@ -1,3 +1,5 @@ | |||||||
|  | # Running `docker-compose up` will create/use the "trilium-data" directory in the user home | ||||||
|  | # Run `TRILIUM_DATA_DIR=/path/of/your/choice docker-compose up` to set a different directory | ||||||
| version: '2.1' | version: '2.1' | ||||||
| services: | services: | ||||||
|   trilium: |   trilium: | ||||||
| @@ -8,7 +10,7 @@ services: | |||||||
|     ports: |     ports: | ||||||
|       - "8080:8080" |       - "8080:8080" | ||||||
|     volumes: |     volumes: | ||||||
|       - trilium:/home/node/trilium-data |       - ${TRILIUM_DATA_DIR:-~/trilium-data}:/home/node/trilium-data | ||||||
|  |  | ||||||
| volumes: | volumes: | ||||||
|   trilium: |   trilium: | ||||||
|   | |||||||
| @@ -183,7 +183,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line55">line 55</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line35">line 35</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -259,7 +259,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line246">line 246</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line250">line 250</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -364,7 +364,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line124">line 124</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line128">line 128</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -484,7 +484,7 @@ | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"> → {string}</span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -532,7 +532,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line32">line 32</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line59">line 59</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -557,6 +557,24 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">string</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -568,7 +586,7 @@ | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateIdIfNecessary"><span class="type-signature">(protected) </span>generateIdIfNecessary<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="getPojo"><span class="type-signature">(abstract, protected) </span>getPojo<span class="signature">()</span><span class="type-signature"></span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -616,7 +634,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line25">line 25</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line82">line 82</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -700,7 +718,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line76">line 76</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line74">line 74</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -784,7 +802,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line47">line 47</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line27">line 27</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -938,7 +956,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line263">line 263</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line267">line 267</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1022,7 +1040,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line64">line 64</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line44">line 44</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1110,7 +1128,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line85">line 85</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line91">line 91</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
|   | |||||||
| @@ -205,7 +205,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line40">line 40</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line39">line 39</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -268,7 +268,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line55">line 55</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line35">line 35</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -336,7 +336,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line52">line 52</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line51">line 51</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -408,7 +408,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line63">line 63</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line62">line 62</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -476,7 +476,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line56">line 56</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line55">line 55</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -544,7 +544,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line54">line 54</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line53">line 53</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -612,7 +612,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line46">line 46</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line45">line 45</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -684,7 +684,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line42">line 42</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line41">line 41</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -752,7 +752,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line50">line 50</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line49">line 49</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -820,7 +820,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line44">line 44</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line43">line 43</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -888,7 +888,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line48">line 48</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line47">line 47</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -956,7 +956,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line58">line 58</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line57">line 57</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1024,7 +1024,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line60">line 60</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line59">line 59</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1105,7 +1105,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line246">line 246</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line250">line 250</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1215,7 +1215,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line124">line 124</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line128">line 128</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1388,7 +1388,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line133">line 133</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line132">line 132</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1490,7 +1490,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line69">line 69</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line68">line 68</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1544,7 +1544,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"> → {string}</span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -1597,7 +1597,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line32">line 32</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line59">line 59</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1622,95 +1622,24 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|          |          | ||||||
|              |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <h4 class="name" id="generateIdIfNecessary"><span class="type-signature">(protected) </span>generateIdIfNecessary<span class="signature">()</span><span class="type-signature"></span></h4> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">string</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| <dl class="details"> |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <dt class="tag-overrides">Overrides:</dt> |  | ||||||
|     <dd class="tag-overrides"><ul class="dummy"><li> |  | ||||||
|         <a href="AbstractBeccaEntity.html#generateIdIfNecessary">AbstractBeccaEntity#generateIdIfNecessary</a> |  | ||||||
|     </li></ul></dd> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <dt class="tag-source">Source:</dt> |  | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |  | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line25">line 25</a> |  | ||||||
|     </li></ul></dd> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
| </dl> | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1770,7 +1699,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line118">line 118</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line117">line 117</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1875,7 +1804,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line81">line 81</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line80">line 80</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1923,6 +1852,95 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          | ||||||
|  |              | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <h4 class="name" id="getPojo"><span class="type-signature">(abstract, protected) </span>getPojo<span class="signature">()</span><span class="type-signature"></span></h4> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl class="details"> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-overrides">Overrides:</dt> | ||||||
|  |     <dd class="tag-overrides"><ul class="dummy"><li> | ||||||
|  |         <a href="AbstractBeccaEntity.html#getPojo">AbstractBeccaEntity#getPojo</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-source">Source:</dt> | ||||||
|  |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|  |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line82">line 82</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|          |          | ||||||
|              |              | ||||||
|  |  | ||||||
| @@ -1982,7 +2000,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line76">line 76</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line74">line 74</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2071,7 +2089,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line47">line 47</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line27">line 27</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2155,7 +2173,7 @@ larger amounts of data and generally not accessible to the user.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line86">line 86</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line85">line 85</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2336,7 +2354,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line263">line 263</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line267">line 267</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2425,7 +2443,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line64">line 64</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line44">line 44</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2518,7 +2536,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line85">line 85</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line91">line 91</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2815,7 +2833,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line128">line 128</a> |         <a href="becca_entities_battachment.js.html">becca/entities/battachment.js</a>, <a href="becca_entities_battachment.js.html#line127">line 127</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
|   | |||||||
| @@ -268,7 +268,7 @@ and relation (representing named relationship between source and target note)</d | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line55">line 55</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line35">line 35</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -825,7 +825,7 @@ and relation (representing named relationship between source and target note)</d | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line246">line 246</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line250">line 250</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -935,7 +935,7 @@ and relation (representing named relationship between source and target note)</d | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line124">line 124</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line128">line 128</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1060,7 +1060,7 @@ and relation (representing named relationship between source and target note)</d | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"> → {string}</span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -1113,7 +1113,7 @@ and relation (representing named relationship between source and target note)</d | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line32">line 32</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line59">line 59</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1138,95 +1138,24 @@ and relation (representing named relationship between source and target note)</d | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|          |          | ||||||
|              |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <h4 class="name" id="generateIdIfNecessary"><span class="type-signature">(protected) </span>generateIdIfNecessary<span class="signature">()</span><span class="type-signature"></span></h4> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">string</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| <dl class="details"> |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <dt class="tag-overrides">Overrides:</dt> |  | ||||||
|     <dd class="tag-overrides"><ul class="dummy"><li> |  | ||||||
|         <a href="AbstractBeccaEntity.html#generateIdIfNecessary">AbstractBeccaEntity#generateIdIfNecessary</a> |  | ||||||
|     </li></ul></dd> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <dt class="tag-source">Source:</dt> |  | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |  | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line25">line 25</a> |  | ||||||
|     </li></ul></dd> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
| </dl> | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1337,6 +1266,95 @@ and relation (representing named relationship between source and target note)</d | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          | ||||||
|  |              | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <h4 class="name" id="getPojo"><span class="type-signature">(abstract, protected) </span>getPojo<span class="signature">()</span><span class="type-signature"></span></h4> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl class="details"> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-overrides">Overrides:</dt> | ||||||
|  |     <dd class="tag-overrides"><ul class="dummy"><li> | ||||||
|  |         <a href="AbstractBeccaEntity.html#getPojo">AbstractBeccaEntity#getPojo</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-source">Source:</dt> | ||||||
|  |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|  |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line82">line 82</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|          |          | ||||||
|              |              | ||||||
|  |  | ||||||
| @@ -1396,7 +1414,7 @@ and relation (representing named relationship between source and target note)</d | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line76">line 76</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line74">line 74</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1590,7 +1608,7 @@ and relation (representing named relationship between source and target note)</d | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line47">line 47</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line27">line 27</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1851,7 +1869,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line263">line 263</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line267">line 267</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1940,7 +1958,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line64">line 64</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line44">line 44</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2033,7 +2051,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line85">line 85</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line91">line 91</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
|   | |||||||
| @@ -203,7 +203,7 @@ Always check noteId instead.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line55">line 55</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line35">line 35</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -945,7 +945,7 @@ of deletion should not act as a clone. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line246">line 246</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line250">line 250</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1055,7 +1055,7 @@ of deletion should not act as a clone. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line124">line 124</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line128">line 128</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1384,7 +1384,7 @@ of deletion should not act as a clone. | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"> → {string}</span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -1437,7 +1437,7 @@ of deletion should not act as a clone. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line32">line 32</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line59">line 59</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1462,95 +1462,24 @@ of deletion should not act as a clone. | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|          |          | ||||||
|              |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <h4 class="name" id="generateIdIfNecessary"><span class="type-signature">(protected) </span>generateIdIfNecessary<span class="signature">()</span><span class="type-signature"></span></h4> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">string</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| <dl class="details"> |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <dt class="tag-overrides">Overrides:</dt> |  | ||||||
|     <dd class="tag-overrides"><ul class="dummy"><li> |  | ||||||
|         <a href="AbstractBeccaEntity.html#generateIdIfNecessary">AbstractBeccaEntity#generateIdIfNecessary</a> |  | ||||||
|     </li></ul></dd> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <dt class="tag-source">Source:</dt> |  | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |  | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line25">line 25</a> |  | ||||||
|     </li></ul></dd> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
| </dl> | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1658,6 +1587,95 @@ of deletion should not act as a clone. | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          | ||||||
|  |              | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <h4 class="name" id="getPojo"><span class="type-signature">(abstract, protected) </span>getPojo<span class="signature">()</span><span class="type-signature"></span></h4> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl class="details"> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-overrides">Overrides:</dt> | ||||||
|  |     <dd class="tag-overrides"><ul class="dummy"><li> | ||||||
|  |         <a href="AbstractBeccaEntity.html#getPojo">AbstractBeccaEntity#getPojo</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-source">Source:</dt> | ||||||
|  |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|  |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line82">line 82</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|          |          | ||||||
|              |              | ||||||
|  |  | ||||||
| @@ -1717,7 +1735,7 @@ of deletion should not act as a clone. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line76">line 76</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line74">line 74</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1806,7 +1824,7 @@ of deletion should not act as a clone. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line47">line 47</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line27">line 27</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1965,7 +1983,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line263">line 263</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line267">line 267</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2054,7 +2072,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line64">line 64</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line44">line 44</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2147,7 +2165,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line85">line 85</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line91">line 91</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
|   | |||||||
| @@ -205,7 +205,7 @@ from tokenHash and token.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line55">line 55</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line35">line 35</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -694,7 +694,7 @@ from tokenHash and token.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line246">line 246</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line250">line 250</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -804,7 +804,7 @@ from tokenHash and token.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line124">line 124</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line128">line 128</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -929,7 +929,7 @@ from tokenHash and token.</div> | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"> → {string}</span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -982,7 +982,7 @@ from tokenHash and token.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line32">line 32</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line59">line 59</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1007,6 +1007,24 @@ from tokenHash and token.</div> | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">string</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1018,7 +1036,7 @@ from tokenHash and token.</div> | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateIdIfNecessary"><span class="type-signature">(protected) </span>generateIdIfNecessary<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="getPojo"><span class="type-signature">(abstract, protected) </span>getPojo<span class="signature">()</span><span class="type-signature"></span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -1048,7 +1066,7 @@ from tokenHash and token.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-overrides">Overrides:</dt> |     <dt class="tag-overrides">Overrides:</dt> | ||||||
|     <dd class="tag-overrides"><ul class="dummy"><li> |     <dd class="tag-overrides"><ul class="dummy"><li> | ||||||
|         <a href="AbstractBeccaEntity.html#generateIdIfNecessary">AbstractBeccaEntity#generateIdIfNecessary</a> |         <a href="AbstractBeccaEntity.html#getPojo">AbstractBeccaEntity#getPojo</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1071,7 +1089,7 @@ from tokenHash and token.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line25">line 25</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line82">line 82</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1160,7 +1178,7 @@ from tokenHash and token.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line76">line 76</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line74">line 74</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1249,7 +1267,7 @@ from tokenHash and token.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line47">line 47</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line27">line 27</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1408,7 +1426,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line263">line 263</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line267">line 267</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1497,7 +1515,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line64">line 64</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line44">line 44</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1590,7 +1608,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line85">line 85</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line91">line 91</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
|   | |||||||
| @@ -270,7 +270,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line55">line 55</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line35">line 35</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1171,7 +1171,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line246">line 246</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line250">line 250</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1281,7 +1281,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line124">line 124</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line128">line 128</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1588,7 +1588,7 @@ See addLabel, addRelation for more specific methods. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1327">line 1327</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1333">line 1333</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1835,7 +1835,7 @@ See addLabel, addRelation for more specific methods. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1348">line 1348</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1354">line 1354</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2081,7 +2081,7 @@ returned. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1361">line 1361</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1367">line 1367</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2316,7 +2316,7 @@ returned. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1446">line 1446</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1452">line 1452</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2432,7 +2432,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1498">line 1498</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1504">line 1504</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2653,7 +2653,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1536">line 1536</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1542">line 1542</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2689,7 +2689,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"> → {string}</span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -2742,7 +2742,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line32">line 32</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line59">line 59</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2767,95 +2767,24 @@ In the future, this functionality might get more generic and some of the require | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|          |          | ||||||
|              |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <h4 class="name" id="generateIdIfNecessary"><span class="type-signature">(protected) </span>generateIdIfNecessary<span class="signature">()</span><span class="type-signature"></span></h4> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">string</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| <dl class="details"> |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <dt class="tag-overrides">Overrides:</dt> |  | ||||||
|     <dd class="tag-overrides"><ul class="dummy"><li> |  | ||||||
|         <a href="AbstractBeccaEntity.html#generateIdIfNecessary">AbstractBeccaEntity#generateIdIfNecessary</a> |  | ||||||
|     </li></ul></dd> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <dt class="tag-source">Source:</dt> |  | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |  | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line25">line 25</a> |  | ||||||
|     </li></ul></dd> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |  | ||||||
| </dl> | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -2919,7 +2848,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1168">line 1168</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1174">line 1174</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3025,7 +2954,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1044">line 1044</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1050">line 1050</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3127,7 +3056,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1018">line 1018</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1024">line 1024</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3229,7 +3158,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1125">line 1125</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1131">line 1131</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3334,7 +3263,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1152">line 1152</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1158">line 1158</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3436,7 +3365,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1107">line 1107</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1113">line 1113</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3538,7 +3467,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1140">line 1140</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1146">line 1146</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3712,7 +3641,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line581">line 581</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line587">line 587</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3891,7 +3820,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line592">line 592</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line598">line 598</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4099,7 +4028,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line334">line 334</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line340">line 340</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4278,7 +4207,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1221">line 1221</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1227">line 1227</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4457,7 +4386,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1231">line 1231</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1237">line 1237</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4565,7 +4494,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line176">line 176</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line182">line 182</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4667,7 +4596,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line196">line 196</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line202">line 202</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4769,7 +4698,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line186">line 186</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line192">line 192</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4871,7 +4800,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line210">line 210</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line216">line 216</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4978,7 +4907,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line965">line 965</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line971">line 971</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5068,7 +4997,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line766">line 766</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line772">line 772</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5174,7 +5103,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1070">line 1070</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1076">line 1076</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5281,7 +5210,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line217">line 217</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line223">line 223</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5395,7 +5324,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line228">line 228</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line234">line 234</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5553,7 +5482,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line521">line 521</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line527">line 527</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5711,7 +5640,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line545">line 545</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line551">line 551</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5881,7 +5810,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line621">line 621</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line627">line 627</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6048,7 +5977,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line613">line 613</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line619">line 619</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6154,7 +6083,7 @@ In the future, this functionality might get more generic and some of the require | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line691">line 691</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line697">line 697</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6334,7 +6263,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line603">line 603</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line609">line 609</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6604,7 +6533,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line666">line 666</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line672">line 672</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6759,7 +6688,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line527">line 527</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line533">line 533</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6917,7 +6846,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line551">line 551</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line557">line 557</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7087,7 +7016,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line637">line 637</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line643">line 643</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7254,7 +7183,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line629">line 629</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line635">line 635</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7409,7 +7338,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line539">line 539</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line545">line 545</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7567,7 +7496,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line563">line 563</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line569">line 569</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7737,7 +7666,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line653">line 653</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line659">line 659</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7843,7 +7772,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line159">line 159</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line165">line 165</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7945,7 +7874,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line181">line 181</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line187">line 187</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7993,6 +7922,95 @@ This method can be significantly faster than the getAttribute() | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          | ||||||
|  |              | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <h4 class="name" id="getPojo"><span class="type-signature">(abstract, protected) </span>getPojo<span class="signature">()</span><span class="type-signature"></span></h4> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl class="details"> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-overrides">Overrides:</dt> | ||||||
|  |     <dd class="tag-overrides"><ul class="dummy"><li> | ||||||
|  |         <a href="AbstractBeccaEntity.html#getPojo">AbstractBeccaEntity#getPojo</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-source">Source:</dt> | ||||||
|  |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|  |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line82">line 82</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|          |          | ||||||
|              |              | ||||||
|  |  | ||||||
| @@ -8052,7 +8070,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line76">line 76</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line74">line 74</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -8185,7 +8203,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line533">line 533</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line539">line 539</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -8343,7 +8361,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line557">line 557</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line563">line 563</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -8513,7 +8531,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line645">line 645</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line651">line 651</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -8619,7 +8637,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1101">line 1101</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1107">line 1107</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -8721,7 +8739,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line310">line 310</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line316">line 316</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -8830,7 +8848,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line876">line 876</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line882">line 882</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -9001,7 +9019,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1190">line 1190</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1196">line 1196</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -9107,7 +9125,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line168">line 168</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line174">line 174</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -9209,7 +9227,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line899">line 899</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line905">line 905</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -9311,7 +9329,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line958">line 958</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line964">line 964</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -9417,7 +9435,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line844">line 844</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line850">line 850</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -9519,7 +9537,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1064">line 1064</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1070">line 1070</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -9626,7 +9644,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line47">line 47</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line27">line 27</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -9710,7 +9728,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1049">line 1049</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1055">line 1055</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -9936,7 +9954,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line451">line 451</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line457">line 457</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -10038,7 +10056,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line191">line 191</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line197">line 197</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -10232,7 +10250,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line480">line 480</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line486">line 486</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -10461,7 +10479,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line571">line 571</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line577">line 577</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -10659,7 +10677,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line501">line 501</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line507">line 507</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -10857,7 +10875,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line515">line 515</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line521">line 521</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -11055,7 +11073,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line508">line 508</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line514">line 514</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -11161,7 +11179,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line305">line 305</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line311">line 311</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -11311,7 +11329,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1262">line 1262</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1268">line 1268</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -11417,7 +11435,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1240">line 1240</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1246">line 1246</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -11511,7 +11529,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line288">line 288</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line294">line 294</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -11617,7 +11635,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line294">line 294</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line300">line 300</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -11723,7 +11741,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line280">line 280</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line286">line 286</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -11829,7 +11847,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line275">line 275</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line281">line 281</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -11984,7 +12002,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line486">line 486</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line492">line 492</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -12090,7 +12108,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line270">line 270</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line276">line 276</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -12198,7 +12216,7 @@ This method can be significantly faster than the getAttribute() | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line300">line 300</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line306">line 306</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -12357,7 +12375,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line263">line 263</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line267">line 267</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -12446,7 +12464,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line64">line 64</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line44">line 44</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -12657,7 +12675,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1306">line 1306</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1312">line 1312</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -12837,7 +12855,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1422">line 1422</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1428">line 1428</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -13017,7 +13035,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1430">line 1430</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1436">line 1436</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -13110,7 +13128,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line85">line 85</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line91">line 91</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -13212,7 +13230,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1638">line 1638</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1640">line 1640</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -13314,7 +13332,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1590">line 1590</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1596">line 1596</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -13546,7 +13564,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1275">line 1275</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1281">line 1281</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -13825,7 +13843,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line243">line 243</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line249">line 249</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -14005,7 +14023,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1406">line 1406</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1412">line 1412</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -14165,7 +14183,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1414">line 1414</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1420">line 1420</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -14407,7 +14425,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1373">line 1373</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1379">line 1379</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -14618,7 +14636,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1389">line 1389</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1395">line 1395</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -14829,7 +14847,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1398">line 1398</a> |         <a href="becca_entities_bnote.js.html">becca/entities/bnote.js</a>, <a href="becca_entities_bnote.js.html#line1404">line 1404</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
|   | |||||||
| @@ -199,7 +199,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line55">line 55</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line35">line 35</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -552,7 +552,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line246">line 246</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line250">line 250</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -662,7 +662,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line124">line 124</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line128">line 128</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -787,7 +787,7 @@ | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"> → {string}</span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -840,7 +840,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line32">line 32</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line59">line 59</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -865,6 +865,24 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">string</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -876,7 +894,7 @@ | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateIdIfNecessary"><span class="type-signature">(protected) </span>generateIdIfNecessary<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="getPojo"><span class="type-signature">(abstract, protected) </span>getPojo<span class="signature">()</span><span class="type-signature"></span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -906,7 +924,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-overrides">Overrides:</dt> |     <dt class="tag-overrides">Overrides:</dt> | ||||||
|     <dd class="tag-overrides"><ul class="dummy"><li> |     <dd class="tag-overrides"><ul class="dummy"><li> | ||||||
|         <a href="AbstractBeccaEntity.html#generateIdIfNecessary">AbstractBeccaEntity#generateIdIfNecessary</a> |         <a href="AbstractBeccaEntity.html#getPojo">AbstractBeccaEntity#getPojo</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -929,7 +947,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line25">line 25</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line82">line 82</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1018,7 +1036,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line76">line 76</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line74">line 74</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1107,7 +1125,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line47">line 47</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line27">line 27</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1266,7 +1284,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line263">line 263</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line267">line 267</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1355,7 +1373,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line64">line 64</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line44">line 44</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1448,7 +1466,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line85">line 85</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line91">line 91</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
|   | |||||||
| @@ -199,7 +199,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line55">line 55</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line35">line 35</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -484,7 +484,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line246">line 246</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line250">line 250</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -594,7 +594,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line124">line 124</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line128">line 128</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -719,7 +719,7 @@ | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"> → {string}</span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -772,7 +772,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line32">line 32</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line59">line 59</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -797,6 +797,24 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">string</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -808,7 +826,7 @@ | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateIdIfNecessary"><span class="type-signature">(protected) </span>generateIdIfNecessary<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="getPojo"><span class="type-signature">(abstract, protected) </span>getPojo<span class="signature">()</span><span class="type-signature"></span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -838,7 +856,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-overrides">Overrides:</dt> |     <dt class="tag-overrides">Overrides:</dt> | ||||||
|     <dd class="tag-overrides"><ul class="dummy"><li> |     <dd class="tag-overrides"><ul class="dummy"><li> | ||||||
|         <a href="AbstractBeccaEntity.html#generateIdIfNecessary">AbstractBeccaEntity#generateIdIfNecessary</a> |         <a href="AbstractBeccaEntity.html#getPojo">AbstractBeccaEntity#getPojo</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -861,7 +879,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line25">line 25</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line82">line 82</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -950,7 +968,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line76">line 76</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line74">line 74</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1039,7 +1057,7 @@ | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line47">line 47</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line27">line 27</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1198,7 +1216,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line263">line 263</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line267">line 267</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1287,7 +1305,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line64">line 64</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line44">line 44</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1380,7 +1398,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line85">line 85</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line91">line 91</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
|   | |||||||
| @@ -200,7 +200,7 @@ It's used for seamless note versioning.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line55">line 55</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line35">line 35</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1165,7 +1165,7 @@ It's used for seamless note versioning.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line246">line 246</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line250">line 250</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1275,7 +1275,7 @@ It's used for seamless note versioning.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line124">line 124</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line128">line 128</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1400,7 +1400,7 @@ It's used for seamless note versioning.</div> | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="generateHash"><span class="type-signature">(protected) </span>generateHash<span class="signature">()</span><span class="type-signature"> → {string}</span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -1453,7 +1453,7 @@ It's used for seamless note versioning.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line32">line 32</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line59">line 59</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1478,6 +1478,24 @@ It's used for seamless note versioning.</div> | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">string</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1489,7 +1507,7 @@ It's used for seamless note versioning.</div> | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <h4 class="name" id="generateIdIfNecessary"><span class="type-signature">(protected) </span>generateIdIfNecessary<span class="signature">()</span><span class="type-signature"></span></h4> |     <h4 class="name" id="getAttachmentById"><span class="type-signature"></span>getAttachmentById<span class="signature">()</span><span class="type-signature"> → {<a href="BAttachment.html">BAttachment</a>|null}</span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
| @@ -1517,11 +1535,6 @@ It's used for seamless note versioning.</div> | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|     <dt class="tag-overrides">Overrides:</dt> |  | ||||||
|     <dd class="tag-overrides"><ul class="dummy"><li> |  | ||||||
|         <a href="AbstractBeccaEntity.html#generateIdIfNecessary">AbstractBeccaEntity#generateIdIfNecessary</a> |  | ||||||
|     </li></ul></dd> |  | ||||||
|      |  | ||||||
|  |  | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1542,7 +1555,7 @@ It's used for seamless note versioning.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line25">line 25</a> |         <a href="becca_entities_brevision.js.html">becca/entities/brevision.js</a>, <a href="becca_entities_brevision.js.html#line132">line 132</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1567,6 +1580,129 @@ It's used for seamless note versioning.</div> | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type"><a href="BAttachment.html">BAttachment</a></span> | ||||||
|  | | | ||||||
|  |  | ||||||
|  | <span class="param-type">null</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          | ||||||
|  |              | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <h4 class="name" id="getAttachmentByTitle"><span class="type-signature"></span>getAttachmentByTitle<span class="signature">()</span><span class="type-signature"> → {<a href="BAttachment.html">BAttachment</a>}</span></h4> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl class="details"> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-source">Source:</dt> | ||||||
|  |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|  |         <a href="becca_entities_brevision.js.html">becca/entities/brevision.js</a>, <a href="becca_entities_brevision.js.html#line159">line 159</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type"><a href="BAttachment.html">BAttachment</a></span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1626,7 +1762,109 @@ It's used for seamless note versioning.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_brevision.js.html">becca/entities/brevision.js</a>, <a href="becca_entities_brevision.js.html#line99">line 99</a> |         <a href="becca_entities_brevision.js.html">becca/entities/brevision.js</a>, <a href="becca_entities_brevision.js.html#line122">line 122</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">Array.<<a href="BAttachment.html">BAttachment</a>></span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          | ||||||
|  |              | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <h4 class="name" id="getAttachmentsByRole"><span class="type-signature"></span>getAttachmentsByRole<span class="signature">()</span><span class="type-signature"> → {Array.<<a href="BAttachment.html">BAttachment</a>>}</span></h4> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl class="details"> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-source">Source:</dt> | ||||||
|  |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|  |         <a href="becca_entities_brevision.js.html">becca/entities/brevision.js</a>, <a href="becca_entities_brevision.js.html#line147">line 147</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1779,6 +2017,318 @@ It's used for seamless note versioning.</div> | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          | ||||||
|  |              | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <h4 class="name" id="getJsonContent"><span class="type-signature"></span>getJsonContent<span class="signature">()</span><span class="type-signature"> → {*}</span></h4> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl class="details"> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-source">Source:</dt> | ||||||
|  |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|  |         <a href="becca_entities_brevision.js.html">becca/entities/brevision.js</a>, <a href="becca_entities_brevision.js.html#line92">line 92</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Throws:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |     <div class="param-desc"> | ||||||
|  |      | ||||||
|  |         Error in case of invalid JSON | ||||||
|  |      | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">*</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          | ||||||
|  |              | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <h4 class="name" id="getJsonContentSafely"><span class="type-signature"></span>getJsonContentSafely<span class="signature">()</span><span class="type-signature"> → {*|null}</span></h4> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl class="details"> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-source">Source:</dt> | ||||||
|  |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|  |         <a href="becca_entities_brevision.js.html">becca/entities/brevision.js</a>, <a href="becca_entities_brevision.js.html#line103">line 103</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  | <div class="param-desc"> | ||||||
|  |     valid object or null if the content cannot be parsed as JSON | ||||||
|  | </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">*</span> | ||||||
|  | | | ||||||
|  |  | ||||||
|  | <span class="param-type">null</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          | ||||||
|  |              | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <h4 class="name" id="getPojo"><span class="type-signature">(abstract, protected) </span>getPojo<span class="signature">()</span><span class="type-signature"></span></h4> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl class="details"> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-overrides">Overrides:</dt> | ||||||
|  |     <dd class="tag-overrides"><ul class="dummy"><li> | ||||||
|  |         <a href="AbstractBeccaEntity.html#getPojo">AbstractBeccaEntity#getPojo</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-source">Source:</dt> | ||||||
|  |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|  |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line82">line 82</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|          |          | ||||||
|              |              | ||||||
|  |  | ||||||
| @@ -1838,7 +2388,7 @@ It's used for seamless note versioning.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line76">line 76</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line74">line 74</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1927,7 +2477,7 @@ It's used for seamless note versioning.</div> | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line47">line 47</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line27">line 27</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2192,7 +2742,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line263">line 263</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line267">line 267</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2281,7 +2831,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line64">line 64</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line44">line 44</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2374,7 +2924,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line85">line 85</a> |         <a href="becca_entities_abstract_becca_entity.js.html">becca/entities/abstract_becca_entity.js</a>, <a href="becca_entities_abstract_becca_entity.js.html#line91">line 91</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2632,7 +3182,7 @@ This is a low-level method, for notes and branches use `note.deleteNote()` and ' | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="becca_entities_brevision.js.html">becca/entities/brevision.js</a>, <a href="becca_entities_brevision.js.html#line94">line 94</a> |         <a href="becca_entities_brevision.js.html">becca/entities/brevision.js</a>, <a href="becca_entities_brevision.js.html#line117">line 117</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
|   | |||||||
| @@ -94,7 +94,7 @@ available in the JS backend notes. You can use e.g. <code>api.log(api.startNote. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line29">line 29</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line30">line 30</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -240,7 +240,7 @@ available in the JS backend notes. You can use e.g. <code>api.log(api.startNote. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line579">line 579</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line594">line 594</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -352,7 +352,7 @@ available in the JS backend notes. You can use e.g. <code>api.log(api.startNote. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line45">line 45</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line46">line 46</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -462,7 +462,7 @@ available in the JS backend notes. You can use e.g. <code>api.log(api.startNote. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line33">line 33</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line34">line 34</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -572,7 +572,7 @@ available in the JS backend notes. You can use e.g. <code>api.log(api.startNote. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line47">line 47</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line48">line 48</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -682,7 +682,7 @@ available in the JS backend notes. You can use e.g. <code>api.log(api.startNote. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line35">line 35</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line36">line 36</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -792,7 +792,7 @@ available in the JS backend notes. You can use e.g. <code>api.log(api.startNote. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line437">line 437</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line438">line 438</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -902,7 +902,7 @@ available in the JS backend notes. You can use e.g. <code>api.log(api.startNote. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line31">line 31</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line32">line 32</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1012,7 +1012,7 @@ available in the JS backend notes. You can use e.g. <code>api.log(api.startNote. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line49">line 49</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line50">line 50</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1188,7 +1188,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line198">line 198</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line199">line 199</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -1691,7 +1691,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line221">line 221</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line222">line 222</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2311,7 +2311,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line241">line 241</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line242">line 242</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -2817,7 +2817,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line464">line 464</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line465">line 465</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3018,7 +3018,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line181">line 181</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line182">line 182</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3200,7 +3200,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line158">line 158</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line159">line 159</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3401,7 +3401,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line148">line 148</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line149">line 149</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3552,7 +3552,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line425">line 425</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line426">line 426</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3753,7 +3753,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line530">line 530</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line531">line 531</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -3855,7 +3855,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line443">line 443</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line444">line 444</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4013,7 +4013,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line78">line 78</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line79">line 79</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4167,7 +4167,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line71">line 71</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line72">line 72</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4368,7 +4368,7 @@ JSON MIME type. See also createNewNote() for more options. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line324">line 324</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line325">line 325</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4478,7 +4478,7 @@ if some action needs to happen on only one specific instance. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line57">line 57</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line58">line 58</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4679,7 +4679,7 @@ if some action needs to happen on only one specific instance. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line355">line 355</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line356">line 356</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -4833,7 +4833,7 @@ if some action needs to happen on only one specific instance. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line64">line 64</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line65">line 65</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5034,7 +5034,7 @@ if some action needs to happen on only one specific instance. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line137">line 137</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line138">line 138</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5235,7 +5235,7 @@ if some action needs to happen on only one specific instance. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line127">line 127</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line128">line 128</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5341,7 +5341,7 @@ if some action needs to happen on only one specific instance. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line314">line 314</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line315">line 315</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5511,7 +5511,7 @@ if some action needs to happen on only one specific instance. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line333">line 333</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line334">line 334</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -5814,7 +5814,7 @@ if some action needs to happen on only one specific instance. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line345">line 345</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line346">line 346</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6015,7 +6015,7 @@ if some action needs to happen on only one specific instance. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line365">line 365</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line366">line 366</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6168,7 +6168,7 @@ if some action needs to happen on only one specific instance. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line287">line 287</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line288">line 288</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6323,7 +6323,7 @@ if some action needs to happen on only one specific instance. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line418">line 418</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line419">line 419</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6508,7 +6508,7 @@ instances execute the given function. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line543">line 543</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line544">line 544</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6566,6 +6566,170 @@ instances execute the given function. | |||||||
|      |      | ||||||
|  |  | ||||||
|      |      | ||||||
|  |     <h4 class="name" id="runOutsideOfSync"><span class="type-signature"></span>runOutsideOfSync<span class="signature">(callback)</span><span class="type-signature"> → {Promise}</span></h4> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <div class="description"> | ||||||
|  |     Sync process can make data intermittently inconsistent. Scripts which require strong data consistency | ||||||
|  | can use this function to wait for a possible sync process to finish and prevent new sync process from starting | ||||||
|  | while it is running. | ||||||
|  |  | ||||||
|  | Because this is an async process, the inner callback doesn't have automatic transaction handling, so in case | ||||||
|  | you need to make some DB changes, you need to surround your call with api.transactional(...) | ||||||
|  | </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     <h5>Parameters:</h5> | ||||||
|  |      | ||||||
|  |  | ||||||
|  | <table class="params"> | ||||||
|  |     <thead> | ||||||
|  |     <tr> | ||||||
|  |          | ||||||
|  |         <th>Name</th> | ||||||
|  |          | ||||||
|  |  | ||||||
|  |         <th>Type</th> | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |          | ||||||
|  |  | ||||||
|  |         <th class="last">Description</th> | ||||||
|  |     </tr> | ||||||
|  |     </thead> | ||||||
|  |  | ||||||
|  |     <tbody> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |         <tr> | ||||||
|  |              | ||||||
|  |                 <td class="name"><code>callback</code></td> | ||||||
|  |              | ||||||
|  |  | ||||||
|  |             <td class="type"> | ||||||
|  |              | ||||||
|  |                  | ||||||
|  | <span class="param-type">function</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |              | ||||||
|  |             </td> | ||||||
|  |  | ||||||
|  |              | ||||||
|  |  | ||||||
|  |              | ||||||
|  |  | ||||||
|  |             <td class="description last">function to be executed while sync process is not running</td> | ||||||
|  |         </tr> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     </tbody> | ||||||
|  | </table> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl class="details"> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <dt class="tag-source">Source:</dt> | ||||||
|  |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|  |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line587">line 587</a> | ||||||
|  |     </li></ul></dd> | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h5>Returns:</h5> | ||||||
|  |  | ||||||
|  |          | ||||||
|  | <div class="param-desc"> | ||||||
|  |     - resolves once the callback is finished (callback is awaited) | ||||||
|  | </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <dl> | ||||||
|  |     <dt> | ||||||
|  |         Type | ||||||
|  |     </dt> | ||||||
|  |     <dd> | ||||||
|  |          | ||||||
|  | <span class="param-type">Promise</span> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </dd> | ||||||
|  | </dl> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          | ||||||
|  |              | ||||||
|  |  | ||||||
|  |      | ||||||
|  |  | ||||||
|  |      | ||||||
|     <h4 class="name" id="searchForNote"><span class="type-signature"></span>searchForNote<span class="signature">(query, searchParams<span class="signature-attributes">opt</span>)</span><span class="type-signature"> → {<a href="BNote.html">BNote</a>|null}</span></h4> |     <h4 class="name" id="searchForNote"><span class="type-signature"></span>searchForNote<span class="signature">(query, searchParams<span class="signature-attributes">opt</span>)</span><span class="type-signature"> → {<a href="BNote.html">BNote</a>|null}</span></h4> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6711,7 +6875,7 @@ instances execute the given function. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line113">line 113</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line114">line 114</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -6913,7 +7077,7 @@ instances execute the given function. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line89">line 89</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line90">line 90</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7122,7 +7286,7 @@ This method looks similar to toggleNoteInParent() but differs because we're look | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line399">line 399</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line400">line 400</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7465,7 +7629,7 @@ This method looks similar to toggleNoteInParent() but differs because we're look | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line379">line 379</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line380">line 380</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7689,7 +7853,7 @@ This method looks similar to toggleNoteInParent() but differs because we're look | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line170">line 170</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line171">line 171</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -7845,7 +8009,7 @@ exists, then we'll use that transaction. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line409">line 409</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line410">line 410</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
| @@ -8000,7 +8164,7 @@ exists, then we'll use that transaction. | |||||||
|      |      | ||||||
|     <dt class="tag-source">Source:</dt> |     <dt class="tag-source">Source:</dt> | ||||||
|     <dd class="tag-source"><ul class="dummy"><li> |     <dd class="tag-source"><ul class="dummy"><li> | ||||||
|         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line432">line 432</a> |         <a href="services_backend_script_api.js.html">services/backend_script_api.js</a>, <a href="services_backend_script_api.js.html#line433">line 433</a> | ||||||
|     </li></ul></dd> |     </li></ul></dd> | ||||||
|      |      | ||||||
|  |  | ||||||
|   | |||||||
| @@ -46,31 +46,11 @@ let becca = null; | |||||||
| class AbstractBeccaEntity { | class AbstractBeccaEntity { | ||||||
|     /** @protected */ |     /** @protected */ | ||||||
|     beforeSaving() { |     beforeSaving() { | ||||||
|         this.generateIdIfNecessary(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** @protected */ |  | ||||||
|     generateIdIfNecessary() { |  | ||||||
|         if (!this[this.constructor.primaryKeyName]) { |         if (!this[this.constructor.primaryKeyName]) { | ||||||
|             this[this.constructor.primaryKeyName] = utils.newEntityId(); |             this[this.constructor.primaryKeyName] = utils.newEntityId(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** @protected */ |  | ||||||
|     generateHash(isDeleted = false) { |  | ||||||
|         let contentToHash = ""; |  | ||||||
|  |  | ||||||
|         for (const propertyName of this.constructor.hashedProperties) { |  | ||||||
|             contentToHash += `|${this[propertyName]}`; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         if (isDeleted) { |  | ||||||
|             contentToHash += "|deleted"; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         return utils.hash(contentToHash).substr(0, 10); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** @protected */ |     /** @protected */ | ||||||
|     getUtcDateChanged() { |     getUtcDateChanged() { | ||||||
|         return this.utcDateModified || this.utcDateCreated; |         return this.utcDateModified || this.utcDateCreated; | ||||||
| @@ -89,7 +69,7 @@ class AbstractBeccaEntity { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** @protected */ |     /** @protected */ | ||||||
|     putEntityChange(isDeleted = false) { |     putEntityChange(isDeleted) { | ||||||
|         entityChangesService.putEntityChange({ |         entityChangesService.putEntityChange({ | ||||||
|             entityName: this.constructor.entityName, |             entityName: this.constructor.entityName, | ||||||
|             entityId: this[this.constructor.primaryKeyName], |             entityId: this[this.constructor.primaryKeyName], | ||||||
| @@ -100,11 +80,37 @@ class AbstractBeccaEntity { | |||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @protected | ||||||
|  |      * @returns {string} | ||||||
|  |      */ | ||||||
|  |     generateHash(isDeleted) { | ||||||
|  |         let contentToHash = ""; | ||||||
|  |  | ||||||
|  |         for (const propertyName of this.constructor.hashedProperties) { | ||||||
|  |             contentToHash += `|${this[propertyName]}`; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (isDeleted) { | ||||||
|  |             contentToHash += "|deleted"; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return utils.hash(contentToHash).substr(0, 10); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** @protected */ |     /** @protected */ | ||||||
|     getPojoToSave() { |     getPojoToSave() { | ||||||
|         return this.getPojo(); |         return this.getPojo(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @protected | ||||||
|  |      * @abstract | ||||||
|  |      */ | ||||||
|  |     getPojo() { | ||||||
|  |         throw new Error(`Unimplemented getPojo() for entity '${this.constructor.name}'`) | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Saves entity - executes SQL, but doesn't commit the transaction on its own |      * Saves entity - executes SQL, but doesn't commit the transaction on its own | ||||||
|      * |      * | ||||||
| @@ -116,9 +122,7 @@ class AbstractBeccaEntity { | |||||||
|  |  | ||||||
|         const isNewEntity = !this[primaryKeyName]; |         const isNewEntity = !this[primaryKeyName]; | ||||||
|  |  | ||||||
|         if (this.beforeSaving) { |         this.beforeSaving(opts); | ||||||
|             this.beforeSaving(opts); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         const pojo = this.getPojoToSave(); |         const pojo = this.getPojoToSave(); | ||||||
|  |  | ||||||
| @@ -129,7 +133,7 @@ class AbstractBeccaEntity { | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             this.putEntityChange(false); |             this.putEntityChange(!!this.isDeleted); | ||||||
|  |  | ||||||
|             if (!cls.isEntityEventsDisabled()) { |             if (!cls.isEntityEventsDisabled()) { | ||||||
|                 const eventPayload = { |                 const eventPayload = { | ||||||
|   | |||||||
| @@ -48,8 +48,7 @@ const attachmentRoleToNoteTypeMapping = { | |||||||
| class BAttachment extends AbstractBeccaEntity { | class BAttachment extends AbstractBeccaEntity { | ||||||
|     static get entityName() { return "attachments"; } |     static get entityName() { return "attachments"; } | ||||||
|     static get primaryKeyName() { return "attachmentId"; } |     static get primaryKeyName() { return "attachmentId"; } | ||||||
|     static get hashedProperties() { return ["attachmentId", "ownerId", "role", "mime", "title", "blobId", |     static get hashedProperties() { return ["attachmentId", "ownerId", "role", "mime", "title", "blobId", "utcDateScheduledForErasureSince"]; } | ||||||
|                                             "utcDateScheduledForErasureSince", "utcDateModified"]; } |  | ||||||
|  |  | ||||||
|     constructor(row) { |     constructor(row) { | ||||||
|         super(); |         super(); | ||||||
|   | |||||||
| @@ -160,11 +160,17 @@ class BNote extends AbstractBeccaEntity { | |||||||
|          */ |          */ | ||||||
|         this.contentSize = null; |         this.contentSize = null; | ||||||
|         /** |         /** | ||||||
|          * size of the content and note revision contents in bytes |          * size of the note content, attachment contents in bytes | ||||||
|          * @type {int|null} |          * @type {int|null} | ||||||
|          * @private |          * @private | ||||||
|          */ |          */ | ||||||
|         this.noteSize = null; |         this.contentAndAttachmentsSize = null; | ||||||
|  |         /** | ||||||
|  |          * size of the note content, attachment contents and revision contents in bytes | ||||||
|  |          * @type {int|null} | ||||||
|  |          * @private | ||||||
|  |          */ | ||||||
|  |         this.contentAndAttachmentsAndRevisionsSize = null; | ||||||
|         /** |         /** | ||||||
|          * number of note revisions for this note |          * number of note revisions for this note | ||||||
|          * @type {int|null} |          * @type {int|null} | ||||||
| @@ -1635,16 +1641,12 @@ class BNote extends AbstractBeccaEntity { | |||||||
|  |  | ||||||
|             revision.save(); // to generate revisionId, which is then used to save attachments |             revision.save(); // to generate revisionId, which is then used to save attachments | ||||||
|  |  | ||||||
|             if (this.type === 'text') { |             for (const noteAttachment of this.getAttachments()) { | ||||||
|                 for (const noteAttachment of this.getAttachments()) { |                 const revisionAttachment = noteAttachment.copy(); | ||||||
|                     if (noteAttachment.utcDateScheduledForErasureSince) { |                 revisionAttachment.ownerId = revision.revisionId; | ||||||
|                         continue; |                 revisionAttachment.setContent(noteAttachment.getContent(), {forceSave: true}); | ||||||
|                     } |  | ||||||
|  |  | ||||||
|                     const revisionAttachment = noteAttachment.copy(); |  | ||||||
|                     revisionAttachment.ownerId = revision.revisionId; |  | ||||||
|                     revisionAttachment.setContent(noteAttachment.getContent(), {forceSave: true}); |  | ||||||
|  |  | ||||||
|  |                 if (this.type === 'text') { | ||||||
|                     // content is rewritten to point to the revision attachments |                     // content is rewritten to point to the revision attachments | ||||||
|                     noteContent = noteContent.replaceAll(`attachments/${noteAttachment.attachmentId}`, |                     noteContent = noteContent.replaceAll(`attachments/${noteAttachment.attachmentId}`, | ||||||
|                         `attachments/${revisionAttachment.attachmentId}`); |                         `attachments/${revisionAttachment.attachmentId}`); | ||||||
|   | |||||||
| @@ -114,6 +114,29 @@ class BRevision extends AbstractBeccaEntity { | |||||||
|         return this._getContent(); |         return this._getContent(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @returns {*} | ||||||
|  |      * @throws Error in case of invalid JSON */ | ||||||
|  |     getJsonContent() { | ||||||
|  |         const content = this.getContent(); | ||||||
|  |  | ||||||
|  |         if (!content || !content.trim()) { | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return JSON.parse(content); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** @returns {*|null} valid object or null if the content cannot be parsed as JSON */ | ||||||
|  |     getJsonContentSafely() { | ||||||
|  |         try { | ||||||
|  |             return this.getJsonContent(); | ||||||
|  |         } | ||||||
|  |         catch (e) { | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @param content |      * @param content | ||||||
|      * @param {object} [opts] |      * @param {object} [opts] | ||||||
| @@ -133,6 +156,45 @@ class BRevision extends AbstractBeccaEntity { | |||||||
|             .map(row => new BAttachment(row)); |             .map(row => new BAttachment(row)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** @returns {BAttachment|null} */ | ||||||
|  |     getAttachmentById(attachmentId, opts = {}) { | ||||||
|  |         opts.includeContentLength = !!opts.includeContentLength; | ||||||
|  |  | ||||||
|  |         const query = opts.includeContentLength | ||||||
|  |             ? `SELECT attachments.*, LENGTH(blobs.content) AS contentLength | ||||||
|  |                FROM attachments  | ||||||
|  |                JOIN blobs USING (blobId)  | ||||||
|  |                WHERE ownerId = ? AND attachmentId = ? AND isDeleted = 0` | ||||||
|  |             : `SELECT * FROM attachments WHERE ownerId = ? AND attachmentId = ? AND isDeleted = 0`; | ||||||
|  |  | ||||||
|  |         return sql.getRows(query, [this.revisionId, attachmentId]) | ||||||
|  |             .map(row => new BAttachment(row))[0]; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** @returns {BAttachment[]} */ | ||||||
|  |     getAttachmentsByRole(role) { | ||||||
|  |         return sql.getRows(` | ||||||
|  |                 SELECT attachments.* | ||||||
|  |                 FROM attachments  | ||||||
|  |                 WHERE ownerId = ?  | ||||||
|  |                   AND role = ? | ||||||
|  |                   AND isDeleted = 0 | ||||||
|  |                 ORDER BY position`, [this.revisionId, role]) | ||||||
|  |             .map(row => new BAttachment(row)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** @returns {BAttachment} */ | ||||||
|  |     getAttachmentByTitle(title) { | ||||||
|  |         return sql.getRows(` | ||||||
|  |                 SELECT attachments.* | ||||||
|  |                 FROM attachments  | ||||||
|  |                 WHERE ownerId = ?  | ||||||
|  |                   AND title = ? | ||||||
|  |                   AND isDeleted = 0 | ||||||
|  |                 ORDER BY position`, [this.revisionId, title]) | ||||||
|  |             .map(row => new BAttachment(row))[0]; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     beforeSaving() { |     beforeSaving() { | ||||||
|         super.beforeSaving(); |         super.beforeSaving(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -47,6 +47,7 @@ const SpacedUpdate = require("./spaced_update"); | |||||||
| const specialNotesService = require("./special_notes"); | const specialNotesService = require("./special_notes"); | ||||||
| const branchService = require("./branches"); | const branchService = require("./branches"); | ||||||
| const exportService = require("./export/zip"); | const exportService = require("./export/zip"); | ||||||
|  | const syncMutex = require("./sync_mutex.js"); | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * <p>This is the main backend API interface for scripts. All the properties and methods are published in the "api" object |  * <p>This is the main backend API interface for scripts. All the properties and methods are published in the "api" object | ||||||
| @@ -599,6 +600,20 @@ function BackendScriptApi(currentNote, apiParams) { | |||||||
|         } |         } | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Sync process can make data intermittently inconsistent. Scripts which require strong data consistency | ||||||
|  |      * can use this function to wait for a possible sync process to finish and prevent new sync process from starting | ||||||
|  |      * while it is running. | ||||||
|  |      * | ||||||
|  |      * Because this is an async process, the inner callback doesn't have automatic transaction handling, so in case | ||||||
|  |      * you need to make some DB changes, you need to surround your call with api.transactional(...) | ||||||
|  |      * | ||||||
|  |      * @method | ||||||
|  |      * @param {function} callback - function to be executed while sync process is not running | ||||||
|  |      * @returns {Promise} - resolves once the callback is finished (callback is awaited) | ||||||
|  |      */ | ||||||
|  |     this.runOutsideOfSync = syncMutex.doExclusively; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * This object contains "at your risk" and "no BC guarantees" objects for advanced use cases. |      * This object contains "at your risk" and "no BC guarantees" objects for advanced use cases. | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -5,8 +5,8 @@ | |||||||
| } | } | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * CKEditor 5 (v39.0.2) content styles. |  * CKEditor 5 (v40.0.0) content styles. | ||||||
|  * Generated on Wed, 06 Sep 2023 07:32:15 GMT. |  * Generated on Thu, 19 Oct 2023 13:45:23 GMT. | ||||||
|  * For more information, check out https://ckeditor.com/docs/ckeditor5/latest/installation/advanced/content-styles.html |  * For more information, check out https://ckeditor.com/docs/ckeditor5/latest/installation/advanced/content-styles.html | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| @@ -42,6 +42,18 @@ | |||||||
|     overflow-wrap: break-word; |     overflow-wrap: break-word; | ||||||
|     position: relative; |     position: relative; | ||||||
| } | } | ||||||
|  | /* @ckeditor/ckeditor5-table/theme/tablecaption.css */ | ||||||
|  | .ck-content .table > figcaption { | ||||||
|  |     display: table-caption; | ||||||
|  |     caption-side: top; | ||||||
|  |     word-break: break-word; | ||||||
|  |     text-align: center; | ||||||
|  |     color: var(--ck-color-selector-caption-text); | ||||||
|  |     background-color: var(--ck-color-selector-caption-background); | ||||||
|  |     padding: .6em; | ||||||
|  |     font-size: .75em; | ||||||
|  |     outline-offset: -1px; | ||||||
|  | } | ||||||
| /* @ckeditor/ckeditor5-table/theme/table.css */ | /* @ckeditor/ckeditor5-table/theme/table.css */ | ||||||
| .ck-content .table { | .ck-content .table { | ||||||
|     margin: 0.9em auto; |     margin: 0.9em auto; | ||||||
| @@ -75,18 +87,6 @@ | |||||||
| .ck-content[dir="ltr"] .table th { | .ck-content[dir="ltr"] .table th { | ||||||
|     text-align: left; |     text-align: left; | ||||||
| } | } | ||||||
| /* @ckeditor/ckeditor5-table/theme/tablecaption.css */ |  | ||||||
| .ck-content .table > figcaption { |  | ||||||
|     display: table-caption; |  | ||||||
|     caption-side: top; |  | ||||||
|     word-break: break-word; |  | ||||||
|     text-align: center; |  | ||||||
|     color: var(--ck-color-selector-caption-text); |  | ||||||
|     background-color: var(--ck-color-selector-caption-background); |  | ||||||
|     padding: .6em; |  | ||||||
|     font-size: .75em; |  | ||||||
|     outline-offset: -1px; |  | ||||||
| } |  | ||||||
| /* @ckeditor/ckeditor5-page-break/theme/pagebreak.css */ | /* @ckeditor/ckeditor5-page-break/theme/pagebreak.css */ | ||||||
| .ck-content .page-break { | .ck-content .page-break { | ||||||
|     position: relative; |     position: relative; | ||||||
| @@ -136,6 +136,7 @@ | |||||||
| } | } | ||||||
| /* @ckeditor/ckeditor5-list/theme/todolist.css */ | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
| .ck-content .todo-list li { | .ck-content .todo-list li { | ||||||
|  |     position: relative; | ||||||
|     margin-bottom: 5px; |     margin-bottom: 5px; | ||||||
| } | } | ||||||
| /* @ckeditor/ckeditor5-list/theme/todolist.css */ | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
| @@ -157,6 +158,13 @@ | |||||||
|     margin-left: 0; |     margin-left: 0; | ||||||
| } | } | ||||||
| /* @ckeditor/ckeditor5-list/theme/todolist.css */ | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
|  | .ck-content[dir=rtl] .todo-list .todo-list__label > input { | ||||||
|  |     left: 0; | ||||||
|  |     margin-right: 0; | ||||||
|  |     right: -25px; | ||||||
|  |     margin-left: -15px; | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
| .ck-content .todo-list .todo-list__label > input::before { | .ck-content .todo-list .todo-list__label > input::before { | ||||||
|     display: block; |     display: block; | ||||||
|     position: absolute; |     position: absolute; | ||||||
| @@ -166,7 +174,7 @@ | |||||||
|     height: 100%; |     height: 100%; | ||||||
|     border: 1px solid hsl(0, 0%, 20%); |     border: 1px solid hsl(0, 0%, 20%); | ||||||
|     border-radius: 2px; |     border-radius: 2px; | ||||||
|     transition: 250ms ease-in-out box-shadow, 250ms ease-in-out background, 250ms ease-in-out border; |     transition: 250ms ease-in-out box-shadow; | ||||||
| } | } | ||||||
| /* @ckeditor/ckeditor5-list/theme/todolist.css */ | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
| .ck-content .todo-list .todo-list__label > input::after { | .ck-content .todo-list .todo-list__label > input::after { | ||||||
| @@ -197,19 +205,80 @@ | |||||||
| .ck-content .todo-list .todo-list__label .todo-list__label__description { | .ck-content .todo-list .todo-list__label .todo-list__label__description { | ||||||
|     vertical-align: middle; |     vertical-align: middle; | ||||||
| } | } | ||||||
| /* @ckeditor/ckeditor5-image/theme/imageresize.css */ | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
| .ck-content .image.image_resized { | .ck-content .todo-list .todo-list__label.todo-list__label_without-description input[type=checkbox] { | ||||||
|     max-width: 100%; |     position: absolute; | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
|  | .ck-editor__editable.ck-content .todo-list .todo-list__label > input, | ||||||
|  | .ck-editor__editable.ck-content .todo-list .todo-list__label > span[contenteditable=false] > input { | ||||||
|  |     cursor: pointer; | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
|  | .ck-editor__editable.ck-content .todo-list .todo-list__label > input:hover::before, .ck-editor__editable.ck-content .todo-list .todo-list__label > span[contenteditable=false] > input:hover::before { | ||||||
|  |     box-shadow: 0 0 0 5px hsla(0, 0%, 0%, 0.1); | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
|  | .ck-editor__editable.ck-content .todo-list .todo-list__label > span[contenteditable=false] > input { | ||||||
|  |     -webkit-appearance: none; | ||||||
|  |     display: inline-block; | ||||||
|  |     position: relative; | ||||||
|  |     width: var(--ck-todo-list-checkmark-size); | ||||||
|  |     height: var(--ck-todo-list-checkmark-size); | ||||||
|  |     vertical-align: middle; | ||||||
|  |     border: 0; | ||||||
|  |     left: -25px; | ||||||
|  |     margin-right: -15px; | ||||||
|  |     right: 0; | ||||||
|  |     margin-left: 0; | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
|  | .ck-editor__editable.ck-content[dir=rtl] .todo-list .todo-list__label > span[contenteditable=false] > input { | ||||||
|  |     left: 0; | ||||||
|  |     margin-right: 0; | ||||||
|  |     right: -25px; | ||||||
|  |     margin-left: -15px; | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
|  | .ck-editor__editable.ck-content .todo-list .todo-list__label > span[contenteditable=false] > input::before { | ||||||
|     display: block; |     display: block; | ||||||
|  |     position: absolute; | ||||||
|     box-sizing: border-box; |     box-sizing: border-box; | ||||||
| } |     content: ''; | ||||||
| /* @ckeditor/ckeditor5-image/theme/imageresize.css */ |  | ||||||
| .ck-content .image.image_resized img { |  | ||||||
|     width: 100%; |     width: 100%; | ||||||
|  |     height: 100%; | ||||||
|  |     border: 1px solid hsl(0, 0%, 20%); | ||||||
|  |     border-radius: 2px; | ||||||
|  |     transition: 250ms ease-in-out box-shadow; | ||||||
| } | } | ||||||
| /* @ckeditor/ckeditor5-image/theme/imageresize.css */ | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
| .ck-content .image.image_resized > figcaption { | .ck-editor__editable.ck-content .todo-list .todo-list__label > span[contenteditable=false] > input::after { | ||||||
|     display: block; |     display: block; | ||||||
|  |     position: absolute; | ||||||
|  |     box-sizing: content-box; | ||||||
|  |     pointer-events: none; | ||||||
|  |     content: ''; | ||||||
|  |     left: calc( var(--ck-todo-list-checkmark-size) / 3 ); | ||||||
|  |     top: calc( var(--ck-todo-list-checkmark-size) / 5.3 ); | ||||||
|  |     width: calc( var(--ck-todo-list-checkmark-size) / 5.3 ); | ||||||
|  |     height: calc( var(--ck-todo-list-checkmark-size) / 2.6 ); | ||||||
|  |     border-style: solid; | ||||||
|  |     border-color: transparent; | ||||||
|  |     border-width: 0 calc( var(--ck-todo-list-checkmark-size) / 8 ) calc( var(--ck-todo-list-checkmark-size) / 8 ) 0; | ||||||
|  |     transform: rotate(45deg); | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
|  | .ck-editor__editable.ck-content .todo-list .todo-list__label > span[contenteditable=false] > input[checked]::before { | ||||||
|  |     background: hsl(126, 64%, 41%); | ||||||
|  |     border-color: hsl(126, 64%, 41%); | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
|  | .ck-editor__editable.ck-content .todo-list .todo-list__label > span[contenteditable=false] > input[checked]::after { | ||||||
|  |     border-color: hsl(0, 0%, 100%); | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-list/theme/todolist.css */ | ||||||
|  | .ck-editor__editable.ck-content .todo-list .todo-list__label.todo-list__label_without-description input[type=checkbox] { | ||||||
|  |     position: absolute; | ||||||
| } | } | ||||||
| /* @ckeditor/ckeditor5-image/theme/image.css */ | /* @ckeditor/ckeditor5-image/theme/image.css */ | ||||||
| .ck-content .image { | .ck-content .image { | ||||||
| @@ -225,6 +294,7 @@ | |||||||
|     margin: 0 auto; |     margin: 0 auto; | ||||||
|     max-width: 100%; |     max-width: 100%; | ||||||
|     min-width: 100%; |     min-width: 100%; | ||||||
|  |     height: auto; | ||||||
| } | } | ||||||
| /* @ckeditor/ckeditor5-image/theme/image.css */ | /* @ckeditor/ckeditor5-image/theme/image.css */ | ||||||
| .ck-content .image-inline { | .ck-content .image-inline { | ||||||
| @@ -259,6 +329,50 @@ | |||||||
|     font-size: .75em; |     font-size: .75em; | ||||||
|     outline-offset: -1px; |     outline-offset: -1px; | ||||||
| } | } | ||||||
|  | /* @ckeditor/ckeditor5-image/theme/imageresize.css */ | ||||||
|  | .ck-content img.image_resized { | ||||||
|  |     height: auto; | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-image/theme/imageresize.css */ | ||||||
|  | .ck-content .image.image_resized { | ||||||
|  |     max-width: 100%; | ||||||
|  |     display: block; | ||||||
|  |     box-sizing: border-box; | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-image/theme/imageresize.css */ | ||||||
|  | .ck-content .image.image_resized img { | ||||||
|  |     width: 100%; | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-image/theme/imageresize.css */ | ||||||
|  | .ck-content .image.image_resized > figcaption { | ||||||
|  |     display: block; | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ | ||||||
|  | .ck-content .marker-yellow { | ||||||
|  |     background-color: var(--ck-highlight-marker-yellow); | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ | ||||||
|  | .ck-content .marker-green { | ||||||
|  |     background-color: var(--ck-highlight-marker-green); | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ | ||||||
|  | .ck-content .marker-pink { | ||||||
|  |     background-color: var(--ck-highlight-marker-pink); | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ | ||||||
|  | .ck-content .marker-blue { | ||||||
|  |     background-color: var(--ck-highlight-marker-blue); | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ | ||||||
|  | .ck-content .pen-red { | ||||||
|  |     color: var(--ck-highlight-pen-red); | ||||||
|  |     background-color: transparent; | ||||||
|  | } | ||||||
|  | /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ | ||||||
|  | .ck-content .pen-green { | ||||||
|  |     color: var(--ck-highlight-pen-green); | ||||||
|  |     background-color: transparent; | ||||||
|  | } | ||||||
| /* @ckeditor/ckeditor5-list/theme/list.css */ | /* @ckeditor/ckeditor5-list/theme/list.css */ | ||||||
| .ck-content ol { | .ck-content ol { | ||||||
|     list-style-type: decimal; |     list-style-type: decimal; | ||||||
| @@ -295,32 +409,6 @@ | |||||||
| .ck-content ul ul ul ul { | .ck-content ul ul ul ul { | ||||||
|     list-style-type: square; |     list-style-type: square; | ||||||
| } | } | ||||||
| /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ |  | ||||||
| .ck-content .marker-yellow { |  | ||||||
|     background-color: var(--ck-highlight-marker-yellow); |  | ||||||
| } |  | ||||||
| /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ |  | ||||||
| .ck-content .marker-green { |  | ||||||
|     background-color: var(--ck-highlight-marker-green); |  | ||||||
| } |  | ||||||
| /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ |  | ||||||
| .ck-content .marker-pink { |  | ||||||
|     background-color: var(--ck-highlight-marker-pink); |  | ||||||
| } |  | ||||||
| /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ |  | ||||||
| .ck-content .marker-blue { |  | ||||||
|     background-color: var(--ck-highlight-marker-blue); |  | ||||||
| } |  | ||||||
| /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ |  | ||||||
| .ck-content .pen-red { |  | ||||||
|     color: var(--ck-highlight-pen-red); |  | ||||||
|     background-color: transparent; |  | ||||||
| } |  | ||||||
| /* @ckeditor/ckeditor5-highlight/theme/highlight.css */ |  | ||||||
| .ck-content .pen-green { |  | ||||||
|     color: var(--ck-highlight-pen-green); |  | ||||||
|     background-color: transparent; |  | ||||||
| } |  | ||||||
| /* @ckeditor/ckeditor5-image/theme/imagestyle.css */ | /* @ckeditor/ckeditor5-image/theme/imagestyle.css */ | ||||||
| .ck-content .image-style-block-align-left, | .ck-content .image-style-block-align-left, | ||||||
| .ck-content .image-style-block-align-right { | .ck-content .image-style-block-align-right { | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								libraries/ckeditor/ckeditor.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								libraries/ckeditor/ckeditor.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										395
									
								
								libraries/mermaid.min.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										395
									
								
								libraries/mermaid.min.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										495
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										495
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -1,17 +1,17 @@ | |||||||
| { | { | ||||||
|   "name": "trilium", |   "name": "trilium", | ||||||
|   "version": "0.61.7-beta", |   "version": "0.61.10-beta", | ||||||
|   "lockfileVersion": 2, |   "lockfileVersion": 2, | ||||||
|   "requires": true, |   "requires": true, | ||||||
|   "packages": { |   "packages": { | ||||||
|     "": { |     "": { | ||||||
|       "name": "trilium", |       "name": "trilium", | ||||||
|       "version": "0.61.7-beta", |       "version": "0.61.10-beta", | ||||||
|       "hasInstallScript": true, |       "hasInstallScript": true, | ||||||
|       "license": "AGPL-3.0-only", |       "license": "AGPL-3.0-only", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@braintree/sanitize-url": "6.0.4", |         "@braintree/sanitize-url": "6.0.4", | ||||||
|         "@electron/remote": "2.0.11", |         "@electron/remote": "2.0.12", | ||||||
|         "@excalidraw/excalidraw": "0.16.1", |         "@excalidraw/excalidraw": "0.16.1", | ||||||
|         "archiver": "5.3.1", |         "archiver": "5.3.1", | ||||||
|         "async-mutex": "0.4.0", |         "async-mutex": "0.4.0", | ||||||
| @@ -27,7 +27,7 @@ | |||||||
|         "debounce": "1.2.1", |         "debounce": "1.2.1", | ||||||
|         "ejs": "3.1.9", |         "ejs": "3.1.9", | ||||||
|         "electron-debug": "3.2.0", |         "electron-debug": "3.2.0", | ||||||
|         "electron-dl": "3.5.0", |         "electron-dl": "3.5.1", | ||||||
|         "electron-window-state": "5.0.3", |         "electron-window-state": "5.0.3", | ||||||
|         "escape-html": "1.0.3", |         "escape-html": "1.0.3", | ||||||
|         "express": "4.18.2", |         "express": "4.18.2", | ||||||
| @@ -47,21 +47,21 @@ | |||||||
|         "jimp": "0.22.10", |         "jimp": "0.22.10", | ||||||
|         "joplin-turndown-plugin-gfm": "1.0.12", |         "joplin-turndown-plugin-gfm": "1.0.12", | ||||||
|         "jsdom": "22.1.0", |         "jsdom": "22.1.0", | ||||||
|         "marked": "9.0.3", |         "marked": "9.1.2", | ||||||
|         "mime-types": "2.1.35", |         "mime-types": "2.1.35", | ||||||
|         "multer": "1.4.5-lts.1", |         "multer": "1.4.5-lts.1", | ||||||
|         "node-abi": "3.47.0", |         "node-abi": "3.50.0", | ||||||
|         "normalize-strings": "1.1.1", |         "normalize-strings": "1.1.1", | ||||||
|         "open": "8.4.1", |         "open": "8.4.1", | ||||||
|         "rand-token": "1.0.1", |         "rand-token": "1.0.1", | ||||||
|         "react": "18.2.0", |         "react": "18.2.0", | ||||||
|         "react-dom": "18.2.0", |         "react-dom": "18.2.0", | ||||||
|         "request": "2.88.2", |         "request": "2.88.2", | ||||||
|         "rimraf": "5.0.1", |         "rimraf": "5.0.5", | ||||||
|         "safe-compare": "1.1.4", |         "safe-compare": "1.1.4", | ||||||
|         "sanitize-filename": "1.6.3", |         "sanitize-filename": "1.6.3", | ||||||
|         "sanitize-html": "2.11.0", |         "sanitize-html": "2.11.0", | ||||||
|         "sax": "1.2.4", |         "sax": "1.3.0", | ||||||
|         "semver": "7.5.4", |         "semver": "7.5.4", | ||||||
|         "serve-favicon": "2.5.0", |         "serve-favicon": "2.5.0", | ||||||
|         "session-file-store": "1.5.0", |         "session-file-store": "1.5.0", | ||||||
| @@ -79,27 +79,27 @@ | |||||||
|       }, |       }, | ||||||
|       "devDependencies": { |       "devDependencies": { | ||||||
|         "cross-env": "7.0.3", |         "cross-env": "7.0.3", | ||||||
|         "electron": "25.8.3", |         "electron": "25.9.2", | ||||||
|         "electron-builder": "24.6.4", |         "electron-builder": "24.6.4", | ||||||
|         "electron-packager": "17.1.2", |         "electron-packager": "17.1.2", | ||||||
|         "electron-rebuild": "3.2.9", |         "electron-rebuild": "3.2.9", | ||||||
|         "eslint": "8.50.0", |         "eslint": "8.51.0", | ||||||
|         "eslint-config-airbnb-base": "15.0.0", |         "eslint-config-airbnb-base": "15.0.0", | ||||||
|         "eslint-config-prettier": "9.0.0", |         "eslint-config-prettier": "9.0.0", | ||||||
|         "eslint-plugin-import": "2.28.1", |         "eslint-plugin-import": "2.28.1", | ||||||
|         "eslint-plugin-jsonc": "2.9.0", |         "eslint-plugin-jsonc": "2.10.0", | ||||||
|         "eslint-plugin-prettier": "5.0.0", |         "eslint-plugin-prettier": "5.0.1", | ||||||
|         "esm": "3.2.25", |         "esm": "3.2.25", | ||||||
|         "husky": "8.0.3", |         "husky": "8.0.3", | ||||||
|         "jasmine": "5.1.0", |         "jasmine": "5.1.0", | ||||||
|         "jsdoc": "4.0.2", |         "jsdoc": "4.0.2", | ||||||
|         "jsonc-eslint-parser": "2.3.0", |         "jsonc-eslint-parser": "2.3.0", | ||||||
|         "lint-staged": "14.0.1", |         "lint-staged": "15.0.0", | ||||||
|         "lorem-ipsum": "2.0.8", |         "lorem-ipsum": "2.0.8", | ||||||
|         "nodemon": "3.0.1", |         "nodemon": "3.0.1", | ||||||
|         "prettier": "3.0.3", |         "prettier": "3.0.3", | ||||||
|         "rcedit": "3.1.0", |         "rcedit": "3.1.0", | ||||||
|         "webpack": "5.88.2", |         "webpack": "5.89.0", | ||||||
|         "webpack-cli": "5.1.4" |         "webpack-cli": "5.1.4" | ||||||
|       }, |       }, | ||||||
|       "optionalDependencies": { |       "optionalDependencies": { | ||||||
| @@ -326,9 +326,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@electron/remote": { |     "node_modules/@electron/remote": { | ||||||
|       "version": "2.0.11", |       "version": "2.0.12", | ||||||
|       "resolved": "https://registry.npmjs.org/@electron/remote/-/remote-2.0.11.tgz", |       "resolved": "https://registry.npmjs.org/@electron/remote/-/remote-2.0.12.tgz", | ||||||
|       "integrity": "sha512-PYEs7W3GrQNuhgiMHjFEvL5MbAL6C7m1AwSAHGqC+xc33IdP7rcGtJSdTP2eg1ssyB3oI00KwTsiSlsQbAoXpA==", |       "integrity": "sha512-IJN6xLAxptq5MCvXNCU6+pdQyz0DjpPtX6g2TPJftu3Z9pU6BTdnos9ZMN8nK471LkASqiA6C+Hzjv5SS8PAQw==", | ||||||
|       "peerDependencies": { |       "peerDependencies": { | ||||||
|         "electron": ">= 13.0.0" |         "electron": ">= 13.0.0" | ||||||
|       } |       } | ||||||
| @@ -447,9 +447,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@eslint/js": { |     "node_modules/@eslint/js": { | ||||||
|       "version": "8.50.0", |       "version": "8.51.0", | ||||||
|       "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.50.0.tgz", |       "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.51.0.tgz", | ||||||
|       "integrity": "sha512-NCC3zz2+nvYd+Ckfh87rA47zfu2QsQpvc6k1yzTk+b9KzRj0wkGa8LSoGOXN6Zv4lRf/EIoZ80biDh9HOI+RNQ==", |       "integrity": "sha512-HxjQ8Qn+4SI3/AFv6sOrDB+g6PpUTDwSJiQqOrnneEk8L71161srI9gjzzZvYVbzHiVg/BvcH95+cK/zfIt4pg==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": "^12.22.0 || ^14.17.0 || >=16.0.0" |         "node": "^12.22.0 || ^14.17.0 || >=16.0.0" | ||||||
| @@ -4276,9 +4276,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/electron": { |     "node_modules/electron": { | ||||||
|       "version": "25.8.3", |       "version": "25.9.2", | ||||||
|       "resolved": "https://registry.npmjs.org/electron/-/electron-25.8.3.tgz", |       "resolved": "https://registry.npmjs.org/electron/-/electron-25.9.2.tgz", | ||||||
|       "integrity": "sha512-BdcTIrhQIf6YgsihCXYh3DgKobtLaNcFb1B5C/5euepxxXQ7qmTWC6WgNUm+IntLOFEDQO926rvm2nhRdSN+Nw==", |       "integrity": "sha512-hVBN5rsrL99BKNHvzMeYy2PkAmewuIobu4U3o3EzVz4MDoLmMfW4yTH5GZ4RbJrpokoEky5IzGtRR/ggPzL6Fw==", | ||||||
|       "hasInstallScript": true, |       "hasInstallScript": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@electron/get": "^2.0.0", |         "@electron/get": "^2.0.0", | ||||||
| @@ -4366,14 +4366,17 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/electron-dl": { |     "node_modules/electron-dl": { | ||||||
|       "version": "3.5.0", |       "version": "3.5.1", | ||||||
|       "resolved": "https://registry.npmjs.org/electron-dl/-/electron-dl-3.5.0.tgz", |       "resolved": "https://registry.npmjs.org/electron-dl/-/electron-dl-3.5.1.tgz", | ||||||
|       "integrity": "sha512-Oj+VSuScVx8hEKM2HEvTQswTX6G3MLh7UoAz/oZuvKyNDfudNi1zY6PK/UnFoK1nCl9DF6k+3PFwElKbtZlDig==", |       "integrity": "sha512-5Yb9s/iPVJ5mW5x3j6XkKxt7WEqREr/AhYxZmtEfW1ffQHs1+aGoiQ2fXCAU6UIXMnWog2MXK82vrxJsjA3nbQ==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "ext-name": "^5.0.0", |         "ext-name": "^5.0.0", | ||||||
|         "pupa": "^2.0.1", |         "pupa": "^2.0.1", | ||||||
|         "unused-filename": "^2.1.0" |         "unused-filename": "^2.1.0" | ||||||
|       }, |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=12" | ||||||
|  |       }, | ||||||
|       "funding": { |       "funding": { | ||||||
|         "url": "https://github.com/sponsors/sindresorhus" |         "url": "https://github.com/sponsors/sindresorhus" | ||||||
|       } |       } | ||||||
| @@ -5001,15 +5004,15 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/eslint": { |     "node_modules/eslint": { | ||||||
|       "version": "8.50.0", |       "version": "8.51.0", | ||||||
|       "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.50.0.tgz", |       "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.51.0.tgz", | ||||||
|       "integrity": "sha512-FOnOGSuFuFLv/Sa+FDVRZl4GGVAAFFi8LecRsI5a1tMO5HIE8nCm4ivAlzt4dT3ol/PaaGC0rJEEXQmHJBGoOg==", |       "integrity": "sha512-2WuxRZBrlwnXi+/vFSJyjMqrNjtJqiasMzehF0shoLaW7DzS3/9Yvrmq5JiT66+pNjiX4UBnLDiKHcWAr/OInA==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@eslint-community/eslint-utils": "^4.2.0", |         "@eslint-community/eslint-utils": "^4.2.0", | ||||||
|         "@eslint-community/regexpp": "^4.6.1", |         "@eslint-community/regexpp": "^4.6.1", | ||||||
|         "@eslint/eslintrc": "^2.1.2", |         "@eslint/eslintrc": "^2.1.2", | ||||||
|         "@eslint/js": "8.50.0", |         "@eslint/js": "8.51.0", | ||||||
|         "@humanwhocodes/config-array": "^0.11.11", |         "@humanwhocodes/config-array": "^0.11.11", | ||||||
|         "@humanwhocodes/module-importer": "^1.0.1", |         "@humanwhocodes/module-importer": "^1.0.1", | ||||||
|         "@nodelib/fs.walk": "^1.2.8", |         "@nodelib/fs.walk": "^1.2.8", | ||||||
| @@ -5054,6 +5057,18 @@ | |||||||
|         "url": "https://opencollective.com/eslint" |         "url": "https://opencollective.com/eslint" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     "node_modules/eslint-compat-utils": { | ||||||
|  |       "version": "0.1.2", | ||||||
|  |       "resolved": "https://registry.npmjs.org/eslint-compat-utils/-/eslint-compat-utils-0.1.2.tgz", | ||||||
|  |       "integrity": "sha512-Jia4JDldWnFNIru1Ehx1H5s9/yxiRHY/TimCuUc0jNexew3cF1gI6CYZil1ociakfWO3rRqFjl1mskBblB3RYg==", | ||||||
|  |       "dev": true, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=12" | ||||||
|  |       }, | ||||||
|  |       "peerDependencies": { | ||||||
|  |         "eslint": ">=6.0.0" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     "node_modules/eslint-config-airbnb-base": { |     "node_modules/eslint-config-airbnb-base": { | ||||||
|       "version": "15.0.0", |       "version": "15.0.0", | ||||||
|       "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-15.0.0.tgz", |       "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-15.0.0.tgz", | ||||||
| @@ -5220,12 +5235,13 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/eslint-plugin-jsonc": { |     "node_modules/eslint-plugin-jsonc": { | ||||||
|       "version": "2.9.0", |       "version": "2.10.0", | ||||||
|       "resolved": "https://registry.npmjs.org/eslint-plugin-jsonc/-/eslint-plugin-jsonc-2.9.0.tgz", |       "resolved": "https://registry.npmjs.org/eslint-plugin-jsonc/-/eslint-plugin-jsonc-2.10.0.tgz", | ||||||
|       "integrity": "sha512-RK+LeONVukbLwT2+t7/OY54NJRccTXh/QbnXzPuTLpFMVZhPuq1C9E07+qWenGx7rrQl0kAalAWl7EmB+RjpGA==", |       "integrity": "sha512-9d//o6Jyh4s1RxC9fNSt1+MMaFN2ruFdXPG9XZcb/mR2KkfjADYiNL/hbU6W0Cyxfg3tS/XSFuhl5LgtMD8hmw==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@eslint-community/eslint-utils": "^4.2.0", |         "@eslint-community/eslint-utils": "^4.2.0", | ||||||
|  |         "eslint-compat-utils": "^0.1.2", | ||||||
|         "jsonc-eslint-parser": "^2.0.4", |         "jsonc-eslint-parser": "^2.0.4", | ||||||
|         "natural-compare": "^1.4.0" |         "natural-compare": "^1.4.0" | ||||||
|       }, |       }, | ||||||
| @@ -5240,9 +5256,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/eslint-plugin-prettier": { |     "node_modules/eslint-plugin-prettier": { | ||||||
|       "version": "5.0.0", |       "version": "5.0.1", | ||||||
|       "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.0.0.tgz", |       "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.0.1.tgz", | ||||||
|       "integrity": "sha512-AgaZCVuYDXHUGxj/ZGu1u8H8CYgDY3iG6w5kUFw4AzMVXzB7VvbKgYR4nATIN+OvUrghMbiDLeimVjVY5ilq3w==", |       "integrity": "sha512-m3u5RnR56asrwV/lDC4GHorlW75DsFfmUcjfCYylTUs85dBRnB7VM6xG8eCMJdeDRnppzmxZVf1GEPJvl1JmNg==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "prettier-linter-helpers": "^1.0.0", |         "prettier-linter-helpers": "^1.0.0", | ||||||
| @@ -7697,9 +7713,9 @@ | |||||||
|       "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" |       "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" | ||||||
|     }, |     }, | ||||||
|     "node_modules/jackspeak": { |     "node_modules/jackspeak": { | ||||||
|       "version": "2.2.1", |       "version": "2.3.6", | ||||||
|       "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.2.1.tgz", |       "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.3.6.tgz", | ||||||
|       "integrity": "sha512-MXbxovZ/Pm42f6cDIDkl3xpwv1AGwObKwfmjs2nQePiy85tP3fatofl3FC1aBsOtP/6fq5SbtgHwWcMsLP+bDw==", |       "integrity": "sha512-N3yCS/NegsOBokc8GAdM8UcmfsKiSS8cipheD/nivzr700H+nsMOxJjQnvwOcRYVuFkdH0wGUvW2WbXGmrZGbQ==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@isaacs/cliui": "^8.0.2" |         "@isaacs/cliui": "^8.0.2" | ||||||
|       }, |       }, | ||||||
| @@ -8265,27 +8281,27 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/lint-staged": { |     "node_modules/lint-staged": { | ||||||
|       "version": "14.0.1", |       "version": "15.0.0", | ||||||
|       "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-14.0.1.tgz", |       "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-15.0.0.tgz", | ||||||
|       "integrity": "sha512-Mw0cL6HXnHN1ag0mN/Dg4g6sr8uf8sn98w2Oc1ECtFto9tvRF7nkXGJRbx8gPlHyoR0pLyBr2lQHbWwmUHe1Sw==", |       "integrity": "sha512-OdrAd/qZhO4MnPyNRehI1Fh6j8kcfQoGpjQ1Vw8dSkDkNONdqe/HpKXqtKpFIPCAYeF4/tfnE11MnjLYuLKjqA==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "chalk": "5.3.0", |         "chalk": "5.3.0", | ||||||
|         "commander": "11.0.0", |         "commander": "11.1.0", | ||||||
|         "debug": "4.3.4", |         "debug": "4.3.4", | ||||||
|         "execa": "7.2.0", |         "execa": "8.0.1", | ||||||
|         "lilconfig": "2.1.0", |         "lilconfig": "2.1.0", | ||||||
|         "listr2": "6.6.1", |         "listr2": "7.0.1", | ||||||
|         "micromatch": "4.0.5", |         "micromatch": "4.0.5", | ||||||
|         "pidtree": "0.6.0", |         "pidtree": "0.6.0", | ||||||
|         "string-argv": "0.3.2", |         "string-argv": "0.3.2", | ||||||
|         "yaml": "2.3.1" |         "yaml": "2.3.2" | ||||||
|       }, |       }, | ||||||
|       "bin": { |       "bin": { | ||||||
|         "lint-staged": "bin/lint-staged.js" |         "lint-staged": "bin/lint-staged.js" | ||||||
|       }, |       }, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": "^16.14.0 || >=18.0.0" |         "node": ">=18.12.0" | ||||||
|       }, |       }, | ||||||
|       "funding": { |       "funding": { | ||||||
|         "url": "https://opencollective.com/lint-staged" |         "url": "https://opencollective.com/lint-staged" | ||||||
| @@ -8304,18 +8320,101 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/lint-staged/node_modules/commander": { |     "node_modules/lint-staged/node_modules/commander": { | ||||||
|       "version": "11.0.0", |       "version": "11.1.0", | ||||||
|       "resolved": "https://registry.npmjs.org/commander/-/commander-11.0.0.tgz", |       "resolved": "https://registry.npmjs.org/commander/-/commander-11.1.0.tgz", | ||||||
|       "integrity": "sha512-9HMlXtt/BNoYr8ooyjjNRdIilOTkVJXB+GhxMTtOKwk0R4j4lS4NpjuqmRxroBfnfTSHQIHQB7wryHhXarNjmQ==", |       "integrity": "sha512-yPVavfyCcRhmorC7rWlkHn15b4wDVgVmBA7kV4QVBsF7kv/9TKJAbAXVTxvTnwP8HHKjRCJDClKbciiYS7p0DQ==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": ">=16" |         "node": ">=16" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     "node_modules/lint-staged/node_modules/execa": { | ||||||
|  |       "version": "8.0.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/execa/-/execa-8.0.1.tgz", | ||||||
|  |       "integrity": "sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==", | ||||||
|  |       "dev": true, | ||||||
|  |       "dependencies": { | ||||||
|  |         "cross-spawn": "^7.0.3", | ||||||
|  |         "get-stream": "^8.0.1", | ||||||
|  |         "human-signals": "^5.0.0", | ||||||
|  |         "is-stream": "^3.0.0", | ||||||
|  |         "merge-stream": "^2.0.0", | ||||||
|  |         "npm-run-path": "^5.1.0", | ||||||
|  |         "onetime": "^6.0.0", | ||||||
|  |         "signal-exit": "^4.1.0", | ||||||
|  |         "strip-final-newline": "^3.0.0" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=16.17" | ||||||
|  |       }, | ||||||
|  |       "funding": { | ||||||
|  |         "url": "https://github.com/sindresorhus/execa?sponsor=1" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/lint-staged/node_modules/get-stream": { | ||||||
|  |       "version": "8.0.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-8.0.1.tgz", | ||||||
|  |       "integrity": "sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==", | ||||||
|  |       "dev": true, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=16" | ||||||
|  |       }, | ||||||
|  |       "funding": { | ||||||
|  |         "url": "https://github.com/sponsors/sindresorhus" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/lint-staged/node_modules/human-signals": { | ||||||
|  |       "version": "5.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-5.0.0.tgz", | ||||||
|  |       "integrity": "sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ==", | ||||||
|  |       "dev": true, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=16.17.0" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/lint-staged/node_modules/mimic-fn": { | ||||||
|  |       "version": "4.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", | ||||||
|  |       "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", | ||||||
|  |       "dev": true, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=12" | ||||||
|  |       }, | ||||||
|  |       "funding": { | ||||||
|  |         "url": "https://github.com/sponsors/sindresorhus" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/lint-staged/node_modules/onetime": { | ||||||
|  |       "version": "6.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", | ||||||
|  |       "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", | ||||||
|  |       "dev": true, | ||||||
|  |       "dependencies": { | ||||||
|  |         "mimic-fn": "^4.0.0" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=12" | ||||||
|  |       }, | ||||||
|  |       "funding": { | ||||||
|  |         "url": "https://github.com/sponsors/sindresorhus" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/lint-staged/node_modules/signal-exit": { | ||||||
|  |       "version": "4.1.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", | ||||||
|  |       "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", | ||||||
|  |       "dev": true, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=14" | ||||||
|  |       }, | ||||||
|  |       "funding": { | ||||||
|  |         "url": "https://github.com/sponsors/isaacs" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     "node_modules/listr2": { |     "node_modules/listr2": { | ||||||
|       "version": "6.6.1", |       "version": "7.0.1", | ||||||
|       "resolved": "https://registry.npmjs.org/listr2/-/listr2-6.6.1.tgz", |       "resolved": "https://registry.npmjs.org/listr2/-/listr2-7.0.1.tgz", | ||||||
|       "integrity": "sha512-+rAXGHh0fkEWdXBmX+L6mmfmXmXvDGEKzkjxO+8mP3+nI/r/CWznVBvsibXdxda9Zz0OW2e2ikphN3OwCT/jSg==", |       "integrity": "sha512-nz+7hwgbDp8eWNoDgzdl4hA/xDSLrNRzPu1TLgOYs6l5Y+Ma6zVWWy9Oyt9TQFONwKoSPoka3H50D3vD5EuNwg==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "cli-truncate": "^3.1.0", |         "cli-truncate": "^3.1.0", | ||||||
| @@ -8327,14 +8426,6 @@ | |||||||
|       }, |       }, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": ">=16.0.0" |         "node": ">=16.0.0" | ||||||
|       }, |  | ||||||
|       "peerDependencies": { |  | ||||||
|         "enquirer": ">= 2.3.0 < 3" |  | ||||||
|       }, |  | ||||||
|       "peerDependenciesMeta": { |  | ||||||
|         "enquirer": { |  | ||||||
|           "optional": true |  | ||||||
|         } |  | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/listr2/node_modules/ansi-regex": { |     "node_modules/listr2/node_modules/ansi-regex": { | ||||||
| @@ -8946,9 +9037,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/marked": { |     "node_modules/marked": { | ||||||
|       "version": "9.0.3", |       "version": "9.1.2", | ||||||
|       "resolved": "https://registry.npmjs.org/marked/-/marked-9.0.3.tgz", |       "resolved": "https://registry.npmjs.org/marked/-/marked-9.1.2.tgz", | ||||||
|       "integrity": "sha512-pI/k4nzBG1PEq1J3XFEHxVvjicfjl8rgaMaqclouGSMPhk7Q3Ejb2ZRxx/ZQOcQ1909HzVoWCFYq6oLgtL4BpQ==", |       "integrity": "sha512-qoKMJqK0w6vkLk8+KnKZAH6neUZSNaQqVZ/h2yZ9S7CbLuFHyS2viB0jnqcWF9UKjwsAbMrQtnQhdmdvOVOw9w==", | ||||||
|       "bin": { |       "bin": { | ||||||
|         "marked": "bin/marked.js" |         "marked": "bin/marked.js" | ||||||
|       }, |       }, | ||||||
| @@ -9294,9 +9385,9 @@ | |||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "node_modules/node-abi": { |     "node_modules/node-abi": { | ||||||
|       "version": "3.47.0", |       "version": "3.50.0", | ||||||
|       "resolved": "https://registry.npmjs.org/node-abi/-/node-abi-3.47.0.tgz", |       "resolved": "https://registry.npmjs.org/node-abi/-/node-abi-3.50.0.tgz", | ||||||
|       "integrity": "sha512-2s6B2CWZM//kPgwnuI0KrYwNjfdByE25zvAaEpq9IH4zcNsarH8Ihu/UuX6XMPEogDAxkuUFeZn60pXNHAqn3A==", |       "integrity": "sha512-2Gxu7Eq7vnBIRfYSmqPruEllMM14FjOQFJSoqdGWthVn+tmwEXzmdPpya6cvvwf0uZA3F5N1fMFr9mijZBplFA==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "semver": "^7.3.5" |         "semver": "^7.3.5" | ||||||
|       }, |       }, | ||||||
| @@ -10106,12 +10197,12 @@ | |||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "node_modules/path-scurry": { |     "node_modules/path-scurry": { | ||||||
|       "version": "1.9.2", |       "version": "1.10.1", | ||||||
|       "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.9.2.tgz", |       "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.10.1.tgz", | ||||||
|       "integrity": "sha512-qSDLy2aGFPm8i4rsbHd4MNyTcrzHFsLQykrtbuGRknZZCBBVXSv2tSCDN2Cg6Rt/GFRw8GoW9y9Ecw5rIPG1sg==", |       "integrity": "sha512-MkhCqzzBEpPvxxQ71Md0b1Kk51W01lrYvlMzSUaIzNsODdd7mqhiimSZlr+VegAz5Z6Vzt9Xg2ttE//XBhH3EQ==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "lru-cache": "^9.1.1", |         "lru-cache": "^9.1.1 || ^10.0.0", | ||||||
|         "minipass": "^5.0.0 || ^6.0.2" |         "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" | ||||||
|       }, |       }, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": ">=16 || 14 >=14.17" |         "node": ">=16 || 14 >=14.17" | ||||||
| @@ -10947,14 +11038,14 @@ | |||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "node_modules/rimraf": { |     "node_modules/rimraf": { | ||||||
|       "version": "5.0.1", |       "version": "5.0.5", | ||||||
|       "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-5.0.1.tgz", |       "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-5.0.5.tgz", | ||||||
|       "integrity": "sha512-OfFZdwtd3lZ+XZzYP/6gTACubwFcHdLRqS9UX3UwpU2dnGQYkPFISRwvM3w9IiB2w7bW5qGo/uAwE4SmXXSKvg==", |       "integrity": "sha512-CqDakW+hMe/Bz202FPEymy68P+G50RfMQK+Qo5YUqc9SPipvbGjCGKd0RSKEelbsfQuw3g5NZDSrlZZAJurH1A==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "glob": "^10.2.5" |         "glob": "^10.3.7" | ||||||
|       }, |       }, | ||||||
|       "bin": { |       "bin": { | ||||||
|         "rimraf": "dist/cjs/src/bin.js" |         "rimraf": "dist/esm/bin.mjs" | ||||||
|       }, |       }, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": ">=14" |         "node": ">=14" | ||||||
| @@ -10972,18 +11063,18 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/rimraf/node_modules/glob": { |     "node_modules/rimraf/node_modules/glob": { | ||||||
|       "version": "10.2.6", |       "version": "10.3.10", | ||||||
|       "resolved": "https://registry.npmjs.org/glob/-/glob-10.2.6.tgz", |       "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.10.tgz", | ||||||
|       "integrity": "sha512-U/rnDpXJGF414QQQZv5uVsabTVxMSwzS5CH0p3DRCIV6ownl4f7PzGnkGmvlum2wB+9RlJWJZ6ACU1INnBqiPA==", |       "integrity": "sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "foreground-child": "^3.1.0", |         "foreground-child": "^3.1.0", | ||||||
|         "jackspeak": "^2.0.3", |         "jackspeak": "^2.3.5", | ||||||
|         "minimatch": "^9.0.1", |         "minimatch": "^9.0.1", | ||||||
|         "minipass": "^5.0.0 || ^6.0.2", |         "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0", | ||||||
|         "path-scurry": "^1.7.0" |         "path-scurry": "^1.10.1" | ||||||
|       }, |       }, | ||||||
|       "bin": { |       "bin": { | ||||||
|         "glob": "dist/cjs/src/bin.js" |         "glob": "dist/esm/bin.mjs" | ||||||
|       }, |       }, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": ">=16 || 14 >=14.17" |         "node": ">=16 || 14 >=14.17" | ||||||
| @@ -10993,9 +11084,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/rimraf/node_modules/minimatch": { |     "node_modules/rimraf/node_modules/minimatch": { | ||||||
|       "version": "9.0.1", |       "version": "9.0.3", | ||||||
|       "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.1.tgz", |       "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", | ||||||
|       "integrity": "sha512-0jWhJpD/MdhPXwPuiRkCbfYfSKp2qnn2eOc279qI7f+osl/l+prKSrvhg157zSYvx/1nmgn2NqdT6k2Z7zSH9w==", |       "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "brace-expansion": "^2.0.1" |         "brace-expansion": "^2.0.1" | ||||||
|       }, |       }, | ||||||
| @@ -11007,9 +11098,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/rimraf/node_modules/minipass": { |     "node_modules/rimraf/node_modules/minipass": { | ||||||
|       "version": "6.0.2", |       "version": "7.0.4", | ||||||
|       "resolved": "https://registry.npmjs.org/minipass/-/minipass-6.0.2.tgz", |       "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.0.4.tgz", | ||||||
|       "integrity": "sha512-MzWSV5nYVT7mVyWCwn2o7JH13w2TBRmmSqSRCKzTw+lmft9X4z+3wjvs06Tzijo5z4W/kahUCDpRXTF+ZrmF/w==", |       "integrity": "sha512-jYofLM5Dam9279rdkWzqHozUo4ybjdZmCsDHePy5V/PbBcVMiSZR97gmAy45aqi8CK1lG2ECd356FU86avfwUQ==", | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": ">=16 || 14 >=14.17" |         "node": ">=16 || 14 >=14.17" | ||||||
|       } |       } | ||||||
| @@ -11290,9 +11381,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/sax": { |     "node_modules/sax": { | ||||||
|       "version": "1.2.4", |       "version": "1.3.0", | ||||||
|       "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", |       "resolved": "https://registry.npmjs.org/sax/-/sax-1.3.0.tgz", | ||||||
|       "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" |       "integrity": "sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA==" | ||||||
|     }, |     }, | ||||||
|     "node_modules/saxes": { |     "node_modules/saxes": { | ||||||
|       "version": "6.0.0", |       "version": "6.0.0", | ||||||
| @@ -12841,9 +12932,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/webpack": { |     "node_modules/webpack": { | ||||||
|       "version": "5.88.2", |       "version": "5.89.0", | ||||||
|       "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.88.2.tgz", |       "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.89.0.tgz", | ||||||
|       "integrity": "sha512-JmcgNZ1iKj+aiR0OvTYtWQqJwq37Pf683dY9bVORwVbUrDhLhdn/PlO2sHsFHPkj7sHNQF3JwaAkp49V+Sq1tQ==", |       "integrity": "sha512-qyfIC10pOr70V+jkmud8tMfajraGCZMBWJtrmuBymQKCrLTRejBI8STDp1MCyZu/QTdZSeacCQYpYNQVOzX5kw==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@types/eslint-scope": "^3.7.3", |         "@types/eslint-scope": "^3.7.3", | ||||||
| @@ -13221,9 +13312,9 @@ | |||||||
|       "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" |       "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" | ||||||
|     }, |     }, | ||||||
|     "node_modules/yaml": { |     "node_modules/yaml": { | ||||||
|       "version": "2.3.1", |       "version": "2.3.2", | ||||||
|       "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.3.1.tgz", |       "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.3.2.tgz", | ||||||
|       "integrity": "sha512-2eHWfjaoXgTBC2jNM1LRef62VQa0umtvRiDSk6HSzW7RvS5YtkabJrwYLLEKWBc8a5U2PTSCs+dJjUTJdlHsWQ==", |       "integrity": "sha512-N/lyzTPaJasoDmfV7YTrYCI0G/3ivm/9wdG0aHuheKowWQwGTsK0Eoiw6utmzAnI6pkJa0DUVygvp3spqqEKXg==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": ">= 14" |         "node": ">= 14" | ||||||
| @@ -13481,9 +13572,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "@electron/remote": { |     "@electron/remote": { | ||||||
|       "version": "2.0.11", |       "version": "2.0.12", | ||||||
|       "resolved": "https://registry.npmjs.org/@electron/remote/-/remote-2.0.11.tgz", |       "resolved": "https://registry.npmjs.org/@electron/remote/-/remote-2.0.12.tgz", | ||||||
|       "integrity": "sha512-PYEs7W3GrQNuhgiMHjFEvL5MbAL6C7m1AwSAHGqC+xc33IdP7rcGtJSdTP2eg1ssyB3oI00KwTsiSlsQbAoXpA==", |       "integrity": "sha512-IJN6xLAxptq5MCvXNCU6+pdQyz0DjpPtX6g2TPJftu3Z9pU6BTdnos9ZMN8nK471LkASqiA6C+Hzjv5SS8PAQw==", | ||||||
|       "requires": {} |       "requires": {} | ||||||
|     }, |     }, | ||||||
|     "@electron/universal": { |     "@electron/universal": { | ||||||
| @@ -13572,9 +13663,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "@eslint/js": { |     "@eslint/js": { | ||||||
|       "version": "8.50.0", |       "version": "8.51.0", | ||||||
|       "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.50.0.tgz", |       "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.51.0.tgz", | ||||||
|       "integrity": "sha512-NCC3zz2+nvYd+Ckfh87rA47zfu2QsQpvc6k1yzTk+b9KzRj0wkGa8LSoGOXN6Zv4lRf/EIoZ80biDh9HOI+RNQ==", |       "integrity": "sha512-HxjQ8Qn+4SI3/AFv6sOrDB+g6PpUTDwSJiQqOrnneEk8L71161srI9gjzzZvYVbzHiVg/BvcH95+cK/zfIt4pg==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "@excalidraw/excalidraw": { |     "@excalidraw/excalidraw": { | ||||||
| @@ -16542,9 +16633,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "electron": { |     "electron": { | ||||||
|       "version": "25.8.3", |       "version": "25.9.2", | ||||||
|       "resolved": "https://registry.npmjs.org/electron/-/electron-25.8.3.tgz", |       "resolved": "https://registry.npmjs.org/electron/-/electron-25.9.2.tgz", | ||||||
|       "integrity": "sha512-BdcTIrhQIf6YgsihCXYh3DgKobtLaNcFb1B5C/5euepxxXQ7qmTWC6WgNUm+IntLOFEDQO926rvm2nhRdSN+Nw==", |       "integrity": "sha512-hVBN5rsrL99BKNHvzMeYy2PkAmewuIobu4U3o3EzVz4MDoLmMfW4yTH5GZ4RbJrpokoEky5IzGtRR/ggPzL6Fw==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "@electron/get": "^2.0.0", |         "@electron/get": "^2.0.0", | ||||||
|         "@types/node": "^18.11.18", |         "@types/node": "^18.11.18", | ||||||
| @@ -16609,9 +16700,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "electron-dl": { |     "electron-dl": { | ||||||
|       "version": "3.5.0", |       "version": "3.5.1", | ||||||
|       "resolved": "https://registry.npmjs.org/electron-dl/-/electron-dl-3.5.0.tgz", |       "resolved": "https://registry.npmjs.org/electron-dl/-/electron-dl-3.5.1.tgz", | ||||||
|       "integrity": "sha512-Oj+VSuScVx8hEKM2HEvTQswTX6G3MLh7UoAz/oZuvKyNDfudNi1zY6PK/UnFoK1nCl9DF6k+3PFwElKbtZlDig==", |       "integrity": "sha512-5Yb9s/iPVJ5mW5x3j6XkKxt7WEqREr/AhYxZmtEfW1ffQHs1+aGoiQ2fXCAU6UIXMnWog2MXK82vrxJsjA3nbQ==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "ext-name": "^5.0.0", |         "ext-name": "^5.0.0", | ||||||
|         "pupa": "^2.0.1", |         "pupa": "^2.0.1", | ||||||
| @@ -17103,15 +17194,15 @@ | |||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "eslint": { |     "eslint": { | ||||||
|       "version": "8.50.0", |       "version": "8.51.0", | ||||||
|       "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.50.0.tgz", |       "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.51.0.tgz", | ||||||
|       "integrity": "sha512-FOnOGSuFuFLv/Sa+FDVRZl4GGVAAFFi8LecRsI5a1tMO5HIE8nCm4ivAlzt4dT3ol/PaaGC0rJEEXQmHJBGoOg==", |       "integrity": "sha512-2WuxRZBrlwnXi+/vFSJyjMqrNjtJqiasMzehF0shoLaW7DzS3/9Yvrmq5JiT66+pNjiX4UBnLDiKHcWAr/OInA==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "requires": { |       "requires": { | ||||||
|         "@eslint-community/eslint-utils": "^4.2.0", |         "@eslint-community/eslint-utils": "^4.2.0", | ||||||
|         "@eslint-community/regexpp": "^4.6.1", |         "@eslint-community/regexpp": "^4.6.1", | ||||||
|         "@eslint/eslintrc": "^2.1.2", |         "@eslint/eslintrc": "^2.1.2", | ||||||
|         "@eslint/js": "8.50.0", |         "@eslint/js": "8.51.0", | ||||||
|         "@humanwhocodes/config-array": "^0.11.11", |         "@humanwhocodes/config-array": "^0.11.11", | ||||||
|         "@humanwhocodes/module-importer": "^1.0.1", |         "@humanwhocodes/module-importer": "^1.0.1", | ||||||
|         "@nodelib/fs.walk": "^1.2.8", |         "@nodelib/fs.walk": "^1.2.8", | ||||||
| @@ -17217,6 +17308,13 @@ | |||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     "eslint-compat-utils": { | ||||||
|  |       "version": "0.1.2", | ||||||
|  |       "resolved": "https://registry.npmjs.org/eslint-compat-utils/-/eslint-compat-utils-0.1.2.tgz", | ||||||
|  |       "integrity": "sha512-Jia4JDldWnFNIru1Ehx1H5s9/yxiRHY/TimCuUc0jNexew3cF1gI6CYZil1ociakfWO3rRqFjl1mskBblB3RYg==", | ||||||
|  |       "dev": true, | ||||||
|  |       "requires": {} | ||||||
|  |     }, | ||||||
|     "eslint-config-airbnb-base": { |     "eslint-config-airbnb-base": { | ||||||
|       "version": "15.0.0", |       "version": "15.0.0", | ||||||
|       "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-15.0.0.tgz", |       "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-15.0.0.tgz", | ||||||
| @@ -17356,20 +17454,21 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "eslint-plugin-jsonc": { |     "eslint-plugin-jsonc": { | ||||||
|       "version": "2.9.0", |       "version": "2.10.0", | ||||||
|       "resolved": "https://registry.npmjs.org/eslint-plugin-jsonc/-/eslint-plugin-jsonc-2.9.0.tgz", |       "resolved": "https://registry.npmjs.org/eslint-plugin-jsonc/-/eslint-plugin-jsonc-2.10.0.tgz", | ||||||
|       "integrity": "sha512-RK+LeONVukbLwT2+t7/OY54NJRccTXh/QbnXzPuTLpFMVZhPuq1C9E07+qWenGx7rrQl0kAalAWl7EmB+RjpGA==", |       "integrity": "sha512-9d//o6Jyh4s1RxC9fNSt1+MMaFN2ruFdXPG9XZcb/mR2KkfjADYiNL/hbU6W0Cyxfg3tS/XSFuhl5LgtMD8hmw==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "requires": { |       "requires": { | ||||||
|         "@eslint-community/eslint-utils": "^4.2.0", |         "@eslint-community/eslint-utils": "^4.2.0", | ||||||
|  |         "eslint-compat-utils": "^0.1.2", | ||||||
|         "jsonc-eslint-parser": "^2.0.4", |         "jsonc-eslint-parser": "^2.0.4", | ||||||
|         "natural-compare": "^1.4.0" |         "natural-compare": "^1.4.0" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "eslint-plugin-prettier": { |     "eslint-plugin-prettier": { | ||||||
|       "version": "5.0.0", |       "version": "5.0.1", | ||||||
|       "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.0.0.tgz", |       "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.0.1.tgz", | ||||||
|       "integrity": "sha512-AgaZCVuYDXHUGxj/ZGu1u8H8CYgDY3iG6w5kUFw4AzMVXzB7VvbKgYR4nATIN+OvUrghMbiDLeimVjVY5ilq3w==", |       "integrity": "sha512-m3u5RnR56asrwV/lDC4GHorlW75DsFfmUcjfCYylTUs85dBRnB7VM6xG8eCMJdeDRnppzmxZVf1GEPJvl1JmNg==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "requires": { |       "requires": { | ||||||
|         "prettier-linter-helpers": "^1.0.0", |         "prettier-linter-helpers": "^1.0.0", | ||||||
| @@ -19062,9 +19161,9 @@ | |||||||
|       "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" |       "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" | ||||||
|     }, |     }, | ||||||
|     "jackspeak": { |     "jackspeak": { | ||||||
|       "version": "2.2.1", |       "version": "2.3.6", | ||||||
|       "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.2.1.tgz", |       "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.3.6.tgz", | ||||||
|       "integrity": "sha512-MXbxovZ/Pm42f6cDIDkl3xpwv1AGwObKwfmjs2nQePiy85tP3fatofl3FC1aBsOtP/6fq5SbtgHwWcMsLP+bDw==", |       "integrity": "sha512-N3yCS/NegsOBokc8GAdM8UcmfsKiSS8cipheD/nivzr700H+nsMOxJjQnvwOcRYVuFkdH0wGUvW2WbXGmrZGbQ==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "@isaacs/cliui": "^8.0.2", |         "@isaacs/cliui": "^8.0.2", | ||||||
|         "@pkgjs/parseargs": "^0.11.0" |         "@pkgjs/parseargs": "^0.11.0" | ||||||
| @@ -19504,21 +19603,21 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "lint-staged": { |     "lint-staged": { | ||||||
|       "version": "14.0.1", |       "version": "15.0.0", | ||||||
|       "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-14.0.1.tgz", |       "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-15.0.0.tgz", | ||||||
|       "integrity": "sha512-Mw0cL6HXnHN1ag0mN/Dg4g6sr8uf8sn98w2Oc1ECtFto9tvRF7nkXGJRbx8gPlHyoR0pLyBr2lQHbWwmUHe1Sw==", |       "integrity": "sha512-OdrAd/qZhO4MnPyNRehI1Fh6j8kcfQoGpjQ1Vw8dSkDkNONdqe/HpKXqtKpFIPCAYeF4/tfnE11MnjLYuLKjqA==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "requires": { |       "requires": { | ||||||
|         "chalk": "5.3.0", |         "chalk": "5.3.0", | ||||||
|         "commander": "11.0.0", |         "commander": "11.1.0", | ||||||
|         "debug": "4.3.4", |         "debug": "4.3.4", | ||||||
|         "execa": "7.2.0", |         "execa": "8.0.1", | ||||||
|         "lilconfig": "2.1.0", |         "lilconfig": "2.1.0", | ||||||
|         "listr2": "6.6.1", |         "listr2": "7.0.1", | ||||||
|         "micromatch": "4.0.5", |         "micromatch": "4.0.5", | ||||||
|         "pidtree": "0.6.0", |         "pidtree": "0.6.0", | ||||||
|         "string-argv": "0.3.2", |         "string-argv": "0.3.2", | ||||||
|         "yaml": "2.3.1" |         "yaml": "2.3.2" | ||||||
|       }, |       }, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "chalk": { |         "chalk": { | ||||||
| @@ -19528,17 +19627,67 @@ | |||||||
|           "dev": true |           "dev": true | ||||||
|         }, |         }, | ||||||
|         "commander": { |         "commander": { | ||||||
|           "version": "11.0.0", |           "version": "11.1.0", | ||||||
|           "resolved": "https://registry.npmjs.org/commander/-/commander-11.0.0.tgz", |           "resolved": "https://registry.npmjs.org/commander/-/commander-11.1.0.tgz", | ||||||
|           "integrity": "sha512-9HMlXtt/BNoYr8ooyjjNRdIilOTkVJXB+GhxMTtOKwk0R4j4lS4NpjuqmRxroBfnfTSHQIHQB7wryHhXarNjmQ==", |           "integrity": "sha512-yPVavfyCcRhmorC7rWlkHn15b4wDVgVmBA7kV4QVBsF7kv/9TKJAbAXVTxvTnwP8HHKjRCJDClKbciiYS7p0DQ==", | ||||||
|  |           "dev": true | ||||||
|  |         }, | ||||||
|  |         "execa": { | ||||||
|  |           "version": "8.0.1", | ||||||
|  |           "resolved": "https://registry.npmjs.org/execa/-/execa-8.0.1.tgz", | ||||||
|  |           "integrity": "sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==", | ||||||
|  |           "dev": true, | ||||||
|  |           "requires": { | ||||||
|  |             "cross-spawn": "^7.0.3", | ||||||
|  |             "get-stream": "^8.0.1", | ||||||
|  |             "human-signals": "^5.0.0", | ||||||
|  |             "is-stream": "^3.0.0", | ||||||
|  |             "merge-stream": "^2.0.0", | ||||||
|  |             "npm-run-path": "^5.1.0", | ||||||
|  |             "onetime": "^6.0.0", | ||||||
|  |             "signal-exit": "^4.1.0", | ||||||
|  |             "strip-final-newline": "^3.0.0" | ||||||
|  |           } | ||||||
|  |         }, | ||||||
|  |         "get-stream": { | ||||||
|  |           "version": "8.0.1", | ||||||
|  |           "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-8.0.1.tgz", | ||||||
|  |           "integrity": "sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==", | ||||||
|  |           "dev": true | ||||||
|  |         }, | ||||||
|  |         "human-signals": { | ||||||
|  |           "version": "5.0.0", | ||||||
|  |           "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-5.0.0.tgz", | ||||||
|  |           "integrity": "sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ==", | ||||||
|  |           "dev": true | ||||||
|  |         }, | ||||||
|  |         "mimic-fn": { | ||||||
|  |           "version": "4.0.0", | ||||||
|  |           "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", | ||||||
|  |           "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", | ||||||
|  |           "dev": true | ||||||
|  |         }, | ||||||
|  |         "onetime": { | ||||||
|  |           "version": "6.0.0", | ||||||
|  |           "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", | ||||||
|  |           "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", | ||||||
|  |           "dev": true, | ||||||
|  |           "requires": { | ||||||
|  |             "mimic-fn": "^4.0.0" | ||||||
|  |           } | ||||||
|  |         }, | ||||||
|  |         "signal-exit": { | ||||||
|  |           "version": "4.1.0", | ||||||
|  |           "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", | ||||||
|  |           "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", | ||||||
|           "dev": true |           "dev": true | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "listr2": { |     "listr2": { | ||||||
|       "version": "6.6.1", |       "version": "7.0.1", | ||||||
|       "resolved": "https://registry.npmjs.org/listr2/-/listr2-6.6.1.tgz", |       "resolved": "https://registry.npmjs.org/listr2/-/listr2-7.0.1.tgz", | ||||||
|       "integrity": "sha512-+rAXGHh0fkEWdXBmX+L6mmfmXmXvDGEKzkjxO+8mP3+nI/r/CWznVBvsibXdxda9Zz0OW2e2ikphN3OwCT/jSg==", |       "integrity": "sha512-nz+7hwgbDp8eWNoDgzdl4hA/xDSLrNRzPu1TLgOYs6l5Y+Ma6zVWWy9Oyt9TQFONwKoSPoka3H50D3vD5EuNwg==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "requires": { |       "requires": { | ||||||
|         "cli-truncate": "^3.1.0", |         "cli-truncate": "^3.1.0", | ||||||
| @@ -19990,9 +20139,9 @@ | |||||||
|       "requires": {} |       "requires": {} | ||||||
|     }, |     }, | ||||||
|     "marked": { |     "marked": { | ||||||
|       "version": "9.0.3", |       "version": "9.1.2", | ||||||
|       "resolved": "https://registry.npmjs.org/marked/-/marked-9.0.3.tgz", |       "resolved": "https://registry.npmjs.org/marked/-/marked-9.1.2.tgz", | ||||||
|       "integrity": "sha512-pI/k4nzBG1PEq1J3XFEHxVvjicfjl8rgaMaqclouGSMPhk7Q3Ejb2ZRxx/ZQOcQ1909HzVoWCFYq6oLgtL4BpQ==" |       "integrity": "sha512-qoKMJqK0w6vkLk8+KnKZAH6neUZSNaQqVZ/h2yZ9S7CbLuFHyS2viB0jnqcWF9UKjwsAbMrQtnQhdmdvOVOw9w==" | ||||||
|     }, |     }, | ||||||
|     "matcher": { |     "matcher": { | ||||||
|       "version": "3.0.0", |       "version": "3.0.0", | ||||||
| @@ -20248,9 +20397,9 @@ | |||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "node-abi": { |     "node-abi": { | ||||||
|       "version": "3.47.0", |       "version": "3.50.0", | ||||||
|       "resolved": "https://registry.npmjs.org/node-abi/-/node-abi-3.47.0.tgz", |       "resolved": "https://registry.npmjs.org/node-abi/-/node-abi-3.50.0.tgz", | ||||||
|       "integrity": "sha512-2s6B2CWZM//kPgwnuI0KrYwNjfdByE25zvAaEpq9IH4zcNsarH8Ihu/UuX6XMPEogDAxkuUFeZn60pXNHAqn3A==", |       "integrity": "sha512-2Gxu7Eq7vnBIRfYSmqPruEllMM14FjOQFJSoqdGWthVn+tmwEXzmdPpya6cvvwf0uZA3F5N1fMFr9mijZBplFA==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "semver": "^7.3.5" |         "semver": "^7.3.5" | ||||||
|       } |       } | ||||||
| @@ -20873,12 +21022,12 @@ | |||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "path-scurry": { |     "path-scurry": { | ||||||
|       "version": "1.9.2", |       "version": "1.10.1", | ||||||
|       "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.9.2.tgz", |       "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.10.1.tgz", | ||||||
|       "integrity": "sha512-qSDLy2aGFPm8i4rsbHd4MNyTcrzHFsLQykrtbuGRknZZCBBVXSv2tSCDN2Cg6Rt/GFRw8GoW9y9Ecw5rIPG1sg==", |       "integrity": "sha512-MkhCqzzBEpPvxxQ71Md0b1Kk51W01lrYvlMzSUaIzNsODdd7mqhiimSZlr+VegAz5Z6Vzt9Xg2ttE//XBhH3EQ==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "lru-cache": "^9.1.1", |         "lru-cache": "^9.1.1 || ^10.0.0", | ||||||
|         "minipass": "^5.0.0 || ^6.0.2" |         "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" | ||||||
|       }, |       }, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "lru-cache": { |         "lru-cache": { | ||||||
| @@ -21498,11 +21647,11 @@ | |||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "rimraf": { |     "rimraf": { | ||||||
|       "version": "5.0.1", |       "version": "5.0.5", | ||||||
|       "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-5.0.1.tgz", |       "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-5.0.5.tgz", | ||||||
|       "integrity": "sha512-OfFZdwtd3lZ+XZzYP/6gTACubwFcHdLRqS9UX3UwpU2dnGQYkPFISRwvM3w9IiB2w7bW5qGo/uAwE4SmXXSKvg==", |       "integrity": "sha512-CqDakW+hMe/Bz202FPEymy68P+G50RfMQK+Qo5YUqc9SPipvbGjCGKd0RSKEelbsfQuw3g5NZDSrlZZAJurH1A==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "glob": "^10.2.5" |         "glob": "^10.3.7" | ||||||
|       }, |       }, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "brace-expansion": { |         "brace-expansion": { | ||||||
| @@ -21514,29 +21663,29 @@ | |||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "glob": { |         "glob": { | ||||||
|           "version": "10.2.6", |           "version": "10.3.10", | ||||||
|           "resolved": "https://registry.npmjs.org/glob/-/glob-10.2.6.tgz", |           "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.10.tgz", | ||||||
|           "integrity": "sha512-U/rnDpXJGF414QQQZv5uVsabTVxMSwzS5CH0p3DRCIV6ownl4f7PzGnkGmvlum2wB+9RlJWJZ6ACU1INnBqiPA==", |           "integrity": "sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g==", | ||||||
|           "requires": { |           "requires": { | ||||||
|             "foreground-child": "^3.1.0", |             "foreground-child": "^3.1.0", | ||||||
|             "jackspeak": "^2.0.3", |             "jackspeak": "^2.3.5", | ||||||
|             "minimatch": "^9.0.1", |             "minimatch": "^9.0.1", | ||||||
|             "minipass": "^5.0.0 || ^6.0.2", |             "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0", | ||||||
|             "path-scurry": "^1.7.0" |             "path-scurry": "^1.10.1" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "minimatch": { |         "minimatch": { | ||||||
|           "version": "9.0.1", |           "version": "9.0.3", | ||||||
|           "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.1.tgz", |           "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", | ||||||
|           "integrity": "sha512-0jWhJpD/MdhPXwPuiRkCbfYfSKp2qnn2eOc279qI7f+osl/l+prKSrvhg157zSYvx/1nmgn2NqdT6k2Z7zSH9w==", |           "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", | ||||||
|           "requires": { |           "requires": { | ||||||
|             "brace-expansion": "^2.0.1" |             "brace-expansion": "^2.0.1" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "minipass": { |         "minipass": { | ||||||
|           "version": "6.0.2", |           "version": "7.0.4", | ||||||
|           "resolved": "https://registry.npmjs.org/minipass/-/minipass-6.0.2.tgz", |           "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.0.4.tgz", | ||||||
|           "integrity": "sha512-MzWSV5nYVT7mVyWCwn2o7JH13w2TBRmmSqSRCKzTw+lmft9X4z+3wjvs06Tzijo5z4W/kahUCDpRXTF+ZrmF/w==" |           "integrity": "sha512-jYofLM5Dam9279rdkWzqHozUo4ybjdZmCsDHePy5V/PbBcVMiSZR97gmAy45aqi8CK1lG2ECd356FU86avfwUQ==" | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
| @@ -21736,9 +21885,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "sax": { |     "sax": { | ||||||
|       "version": "1.2.4", |       "version": "1.3.0", | ||||||
|       "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", |       "resolved": "https://registry.npmjs.org/sax/-/sax-1.3.0.tgz", | ||||||
|       "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" |       "integrity": "sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA==" | ||||||
|     }, |     }, | ||||||
|     "saxes": { |     "saxes": { | ||||||
|       "version": "6.0.0", |       "version": "6.0.0", | ||||||
| @@ -22923,9 +23072,9 @@ | |||||||
|       "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==" |       "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==" | ||||||
|     }, |     }, | ||||||
|     "webpack": { |     "webpack": { | ||||||
|       "version": "5.88.2", |       "version": "5.89.0", | ||||||
|       "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.88.2.tgz", |       "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.89.0.tgz", | ||||||
|       "integrity": "sha512-JmcgNZ1iKj+aiR0OvTYtWQqJwq37Pf683dY9bVORwVbUrDhLhdn/PlO2sHsFHPkj7sHNQF3JwaAkp49V+Sq1tQ==", |       "integrity": "sha512-qyfIC10pOr70V+jkmud8tMfajraGCZMBWJtrmuBymQKCrLTRejBI8STDp1MCyZu/QTdZSeacCQYpYNQVOzX5kw==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "requires": { |       "requires": { | ||||||
|         "@types/eslint-scope": "^3.7.3", |         "@types/eslint-scope": "^3.7.3", | ||||||
| @@ -23188,9 +23337,9 @@ | |||||||
|       "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" |       "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" | ||||||
|     }, |     }, | ||||||
|     "yaml": { |     "yaml": { | ||||||
|       "version": "2.3.1", |       "version": "2.3.2", | ||||||
|       "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.3.1.tgz", |       "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.3.2.tgz", | ||||||
|       "integrity": "sha512-2eHWfjaoXgTBC2jNM1LRef62VQa0umtvRiDSk6HSzW7RvS5YtkabJrwYLLEKWBc8a5U2PTSCs+dJjUTJdlHsWQ==", |       "integrity": "sha512-N/lyzTPaJasoDmfV7YTrYCI0G/3ivm/9wdG0aHuheKowWQwGTsK0Eoiw6utmzAnI6pkJa0DUVygvp3spqqEKXg==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "yargs": { |     "yargs": { | ||||||
|   | |||||||
							
								
								
									
										40
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										40
									
								
								package.json
									
									
									
									
									
								
							| @@ -2,7 +2,7 @@ | |||||||
|   "name": "trilium", |   "name": "trilium", | ||||||
|   "productName": "Trilium Notes", |   "productName": "Trilium Notes", | ||||||
|   "description": "Trilium Notes", |   "description": "Trilium Notes", | ||||||
|   "version": "0.61.8-beta", |   "version": "0.61.11", | ||||||
|   "license": "AGPL-3.0-only", |   "license": "AGPL-3.0-only", | ||||||
|   "main": "electron.js", |   "main": "electron.js", | ||||||
|   "bin": { |   "bin": { | ||||||
| @@ -13,14 +13,18 @@ | |||||||
|     "url": "https://github.com/zadam/trilium.git" |     "url": "https://github.com/zadam/trilium.git" | ||||||
|   }, |   }, | ||||||
|   "scripts": { |   "scripts": { | ||||||
|     "start-server": "cross-env TRILIUM_DATA_DIR=./data TRILIUM_ENV=dev TRILIUM_SYNC_SERVER_HOST=http://tsyncserver:4000 nodemon ./src/www", |     "start-server": "cross-env TRILIUM_SAFE_MODE=1 TRILIUM_DATA_DIR=./data TRILIUM_ENV=dev TRILIUM_SYNC_SERVER_HOST=http://tsyncserver:4000 nodemon ./src/www", | ||||||
|     "start-server-no-dir": "cross-env TRILIUM_ENV=dev TRILIUM_SYNC_SERVER_HOST=http://tsyncserver:4000 nodemon ./src/www", |     "start-server-no-dir": "cross-env TRILIUM_SAFE_MODE=1 TRILIUM_ENV=dev TRILIUM_SYNC_SERVER_HOST=http://tsyncserver:4000 nodemon ./src/www", | ||||||
|     "start-electron": "cross-env TRILIUM_DATA_DIR=./data TRILIUM_SYNC_SERVER_HOST=http://tsyncserver:4000 TRILIUM_ENV=dev electron --inspect=5858 .", |     "qstart-server": "npm run qswitch-server && TRILIUM_SAFE_MODE=1 TRILIUM_DATA_DIR=./data TRILIUM_ENV=dev TRILIUM_SYNC_SERVER_HOST=http://tsyncserver:4000 nodemon ./src/www", | ||||||
|     "start-electron-no-dir": "cross-env TRILIUM_ENV=dev TRILIUM_SYNC_SERVER_HOST=http://tsyncserver:4000 electron --inspect=5858 .", |     "start-electron": "cross-env TRILIUM_SAFE_MODE=1 TRILIUM_DATA_DIR=./data TRILIUM_SYNC_SERVER_HOST=http://tsyncserver:4000 TRILIUM_ENV=dev electron --inspect=5858 .", | ||||||
|  |     "start-electron-no-dir": "cross-env TRILIUM_SAFE_MODE=1 TRILIUM_ENV=dev TRILIUM_SYNC_SERVER_HOST=http://tsyncserver:4000 electron --inspect=5858 .", | ||||||
|  |     "qstart-electron": "npm run qswitch-electron && TRILIUM_SAFE_MODE=1 TRILIUM_DATA_DIR=./data TRILIUM_SYNC_SERVER_HOST=http://tsyncserver:4000 TRILIUM_ENV=dev electron --inspect=5858 .", | ||||||
|     "switch-server": "rm -rf ./node_modules/better-sqlite3 && npm install", |     "switch-server": "rm -rf ./node_modules/better-sqlite3 && npm install", | ||||||
|     "switch-electron": "./node_modules/.bin/electron-rebuild", |     "switch-electron": "./node_modules/.bin/electron-rebuild", | ||||||
|  |     "qswitch-server": "rm -rf ./node_modules/better-sqlite3/bin ; mkdir -p ./node_modules/better-sqlite3/build ; cp ./bin/better-sqlite3/linux-server-better_sqlite3.node ./node_modules/better-sqlite3/build/better_sqlite3.node", | ||||||
|  |     "qswitch-electron": "rm -rf ./node_modules/better-sqlite3/bin ; mkdir -p ./node_modules/better-sqlite3/build ; cp ./bin/better-sqlite3/linux-desktop-better_sqlite3.node ./node_modules/better-sqlite3/build/better_sqlite3.node", | ||||||
|     "build-backend-docs": "rm -rf ./docs/backend_api && ./node_modules/.bin/jsdoc -c jsdoc-conf.json -d ./docs/backend_api src/becca/entities/*.js src/services/backend_script_api.js src/services/sql.js", |     "build-backend-docs": "rm -rf ./docs/backend_api && ./node_modules/.bin/jsdoc -c jsdoc-conf.json -d ./docs/backend_api src/becca/entities/*.js src/services/backend_script_api.js src/services/sql.js", | ||||||
|     "build-frontend-docs": "rm -rf ./docs/frontend_api && ./node_modules/.bin/jsdoc -c jsdoc-conf.json -d ./docs/frontend_api src/public/app/entities/*.js src/public/app/services/frontend_script_api.js src/public/app/widgets/right_panel_widget.js", |     "build-frontend-docs": "rm -rf ./docs/frontend_api && ./node_modules/.bin/jsdoc -c jsdoc-conf.json -d ./docs/frontend_api src/public/app/entities/*.js src/public/app/services/frontend_script_api.js src/public/app/widgets/basic_widget.js src/public/app/widgets/note_context_aware_widget.js src/public/app/widgets/right_panel_widget.js", | ||||||
|     "build-docs": "npm run build-backend-docs && npm run build-frontend-docs", |     "build-docs": "npm run build-backend-docs && npm run build-frontend-docs", | ||||||
|     "webpack": "webpack -c webpack.config.js", |     "webpack": "webpack -c webpack.config.js", | ||||||
|     "test-jasmine": "jasmine", |     "test-jasmine": "jasmine", | ||||||
| @@ -32,7 +36,7 @@ | |||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@braintree/sanitize-url": "6.0.4", |     "@braintree/sanitize-url": "6.0.4", | ||||||
|     "@electron/remote": "2.0.11", |     "@electron/remote": "2.0.12", | ||||||
|     "@excalidraw/excalidraw": "0.16.1", |     "@excalidraw/excalidraw": "0.16.1", | ||||||
|     "archiver": "5.3.1", |     "archiver": "5.3.1", | ||||||
|     "async-mutex": "0.4.0", |     "async-mutex": "0.4.0", | ||||||
| @@ -48,7 +52,7 @@ | |||||||
|     "debounce": "1.2.1", |     "debounce": "1.2.1", | ||||||
|     "ejs": "3.1.9", |     "ejs": "3.1.9", | ||||||
|     "electron-debug": "3.2.0", |     "electron-debug": "3.2.0", | ||||||
|     "electron-dl": "3.5.0", |     "electron-dl": "3.5.1", | ||||||
|     "electron-window-state": "5.0.3", |     "electron-window-state": "5.0.3", | ||||||
|     "escape-html": "1.0.3", |     "escape-html": "1.0.3", | ||||||
|     "express": "4.18.2", |     "express": "4.18.2", | ||||||
| @@ -68,21 +72,21 @@ | |||||||
|     "jimp": "0.22.10", |     "jimp": "0.22.10", | ||||||
|     "joplin-turndown-plugin-gfm": "1.0.12", |     "joplin-turndown-plugin-gfm": "1.0.12", | ||||||
|     "jsdom": "22.1.0", |     "jsdom": "22.1.0", | ||||||
|     "marked": "9.0.3", |     "marked": "9.1.2", | ||||||
|     "mime-types": "2.1.35", |     "mime-types": "2.1.35", | ||||||
|     "multer": "1.4.5-lts.1", |     "multer": "1.4.5-lts.1", | ||||||
|     "node-abi": "3.47.0", |     "node-abi": "3.50.0", | ||||||
|     "normalize-strings": "1.1.1", |     "normalize-strings": "1.1.1", | ||||||
|     "open": "8.4.1", |     "open": "8.4.1", | ||||||
|     "rand-token": "1.0.1", |     "rand-token": "1.0.1", | ||||||
|     "react": "18.2.0", |     "react": "18.2.0", | ||||||
|     "react-dom": "18.2.0", |     "react-dom": "18.2.0", | ||||||
|     "request": "2.88.2", |     "request": "2.88.2", | ||||||
|     "rimraf": "5.0.1", |     "rimraf": "5.0.5", | ||||||
|     "safe-compare": "1.1.4", |     "safe-compare": "1.1.4", | ||||||
|     "sanitize-filename": "1.6.3", |     "sanitize-filename": "1.6.3", | ||||||
|     "sanitize-html": "2.11.0", |     "sanitize-html": "2.11.0", | ||||||
|     "sax": "1.2.4", |     "sax": "1.3.0", | ||||||
|     "semver": "7.5.4", |     "semver": "7.5.4", | ||||||
|     "serve-favicon": "2.5.0", |     "serve-favicon": "2.5.0", | ||||||
|     "session-file-store": "1.5.0", |     "session-file-store": "1.5.0", | ||||||
| @@ -97,27 +101,27 @@ | |||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "cross-env": "7.0.3", |     "cross-env": "7.0.3", | ||||||
|     "electron": "25.8.3", |     "electron": "25.9.2", | ||||||
|     "electron-builder": "24.6.4", |     "electron-builder": "24.6.4", | ||||||
|     "electron-packager": "17.1.2", |     "electron-packager": "17.1.2", | ||||||
|     "electron-rebuild": "3.2.9", |     "electron-rebuild": "3.2.9", | ||||||
|     "eslint": "8.50.0", |     "eslint": "8.51.0", | ||||||
|     "eslint-config-airbnb-base": "15.0.0", |     "eslint-config-airbnb-base": "15.0.0", | ||||||
|     "eslint-config-prettier": "9.0.0", |     "eslint-config-prettier": "9.0.0", | ||||||
|     "eslint-plugin-import": "2.28.1", |     "eslint-plugin-import": "2.28.1", | ||||||
|     "eslint-plugin-jsonc": "2.9.0", |     "eslint-plugin-jsonc": "2.10.0", | ||||||
|     "eslint-plugin-prettier": "5.0.0", |     "eslint-plugin-prettier": "5.0.1", | ||||||
|     "esm": "3.2.25", |     "esm": "3.2.25", | ||||||
|     "husky": "8.0.3", |     "husky": "8.0.3", | ||||||
|     "jasmine": "5.1.0", |     "jasmine": "5.1.0", | ||||||
|     "jsdoc": "4.0.2", |     "jsdoc": "4.0.2", | ||||||
|     "jsonc-eslint-parser": "2.3.0", |     "jsonc-eslint-parser": "2.3.0", | ||||||
|     "lint-staged": "14.0.1", |     "lint-staged": "15.0.0", | ||||||
|     "lorem-ipsum": "2.0.8", |     "lorem-ipsum": "2.0.8", | ||||||
|     "nodemon": "3.0.1", |     "nodemon": "3.0.1", | ||||||
|     "prettier": "3.0.3", |     "prettier": "3.0.3", | ||||||
|     "rcedit": "3.1.0", |     "rcedit": "3.1.0", | ||||||
|     "webpack": "5.88.2", |     "webpack": "5.89.0", | ||||||
|     "webpack-cli": "5.1.4" |     "webpack-cli": "5.1.4" | ||||||
|   }, |   }, | ||||||
|   "optionalDependencies": { |   "optionalDependencies": { | ||||||
|   | |||||||
							
								
								
									
										5
									
								
								spec/etapi/notes.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								spec/etapi/notes.spec.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | describe("Notes", () => { | ||||||
|  |     it("zzz", () => { | ||||||
|  |  | ||||||
|  |     }); | ||||||
|  | }); | ||||||
| @@ -132,11 +132,17 @@ class BNote extends AbstractBeccaEntity { | |||||||
|          */ |          */ | ||||||
|         this.contentSize = null; |         this.contentSize = null; | ||||||
|         /** |         /** | ||||||
|          * size of the content and note revision contents in bytes |          * size of the note content, attachment contents in bytes | ||||||
|          * @type {int|null} |          * @type {int|null} | ||||||
|          * @private |          * @private | ||||||
|          */ |          */ | ||||||
|         this.noteSize = null; |         this.contentAndAttachmentsSize = null; | ||||||
|  |         /** | ||||||
|  |          * size of the note content, attachment contents and revision contents in bytes | ||||||
|  |          * @type {int|null} | ||||||
|  |          * @private | ||||||
|  |          */ | ||||||
|  |         this.contentAndAttachmentsAndRevisionsSize = null; | ||||||
|         /** |         /** | ||||||
|          * number of note revisions for this note |          * number of note revisions for this note | ||||||
|          * @type {int|null} |          * @type {int|null} | ||||||
| @@ -1607,16 +1613,12 @@ class BNote extends AbstractBeccaEntity { | |||||||
|  |  | ||||||
|             revision.save(); // to generate revisionId, which is then used to save attachments |             revision.save(); // to generate revisionId, which is then used to save attachments | ||||||
|  |  | ||||||
|             if (this.type === 'text') { |             for (const noteAttachment of this.getAttachments()) { | ||||||
|                 for (const noteAttachment of this.getAttachments()) { |                 const revisionAttachment = noteAttachment.copy(); | ||||||
|                     if (noteAttachment.utcDateScheduledForErasureSince) { |                 revisionAttachment.ownerId = revision.revisionId; | ||||||
|                         continue; |                 revisionAttachment.setContent(noteAttachment.getContent(), {forceSave: true}); | ||||||
|                     } |  | ||||||
|  |  | ||||||
|                     const revisionAttachment = noteAttachment.copy(); |  | ||||||
|                     revisionAttachment.ownerId = revision.revisionId; |  | ||||||
|                     revisionAttachment.setContent(noteAttachment.getContent(), {forceSave: true}); |  | ||||||
|  |  | ||||||
|  |                 if (this.type === 'text') { | ||||||
|                     // content is rewritten to point to the revision attachments |                     // content is rewritten to point to the revision attachments | ||||||
|                     noteContent = noteContent.replaceAll(`attachments/${noteAttachment.attachmentId}`, |                     noteContent = noteContent.replaceAll(`attachments/${noteAttachment.attachmentId}`, | ||||||
|                         `attachments/${revisionAttachment.attachmentId}`); |                         `attachments/${revisionAttachment.attachmentId}`); | ||||||
| @@ -1633,24 +1635,32 @@ class BNote extends AbstractBeccaEntity { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|  |      * @param {string} matchBy - choose by which property we detect if to update an existing attachment. | ||||||
|  |  *                               Supported values are either 'attachmentId' (default) or 'title' | ||||||
|      * @returns {BAttachment} |      * @returns {BAttachment} | ||||||
|      */ |      */ | ||||||
|     saveAttachment({attachmentId, role, mime, title, content, position}) { |     saveAttachment({attachmentId, role, mime, title, content, position}, matchBy = 'attachmentId') { | ||||||
|  |         if (!['attachmentId', 'title'].includes(matchBy)) { | ||||||
|  |             throw new Error(`Unsupported value '${matchBy}' for matchBy param, has to be either 'attachmentId' or 'title'.`); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         let attachment; |         let attachment; | ||||||
|  |  | ||||||
|         if (attachmentId) { |         if (matchBy === 'title') { | ||||||
|  |             attachment = this.getAttachmentByTitle(title); | ||||||
|  |         } else if (matchBy === 'attachmentId' && attachmentId) { | ||||||
|             attachment = this.becca.getAttachmentOrThrow(attachmentId); |             attachment = this.becca.getAttachmentOrThrow(attachmentId); | ||||||
|         } else { |  | ||||||
|             attachment = new BAttachment({ |  | ||||||
|                 ownerId: this.noteId, |  | ||||||
|                 title, |  | ||||||
|                 role, |  | ||||||
|                 mime, |  | ||||||
|                 isProtected: this.isProtected, |  | ||||||
|                 position |  | ||||||
|             }); |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         attachment = attachment || new BAttachment({ | ||||||
|  |             ownerId: this.noteId, | ||||||
|  |             title, | ||||||
|  |             role, | ||||||
|  |             mime, | ||||||
|  |             isProtected: this.isProtected, | ||||||
|  |             position | ||||||
|  |         }); | ||||||
|  |  | ||||||
|         content = content || ""; |         content = content || ""; | ||||||
|         attachment.setContent(content, {forceSave: true}); |         attachment.setContent(content, {forceSave: true}); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -86,6 +86,29 @@ class BRevision extends AbstractBeccaEntity { | |||||||
|         return this._getContent(); |         return this._getContent(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @returns {*} | ||||||
|  |      * @throws Error in case of invalid JSON */ | ||||||
|  |     getJsonContent() { | ||||||
|  |         const content = this.getContent(); | ||||||
|  |  | ||||||
|  |         if (!content || !content.trim()) { | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return JSON.parse(content); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** @returns {*|null} valid object or null if the content cannot be parsed as JSON */ | ||||||
|  |     getJsonContentSafely() { | ||||||
|  |         try { | ||||||
|  |             return this.getJsonContent(); | ||||||
|  |         } | ||||||
|  |         catch (e) { | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @param content |      * @param content | ||||||
|      * @param {object} [opts] |      * @param {object} [opts] | ||||||
| @@ -105,6 +128,45 @@ class BRevision extends AbstractBeccaEntity { | |||||||
|             .map(row => new BAttachment(row)); |             .map(row => new BAttachment(row)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** @returns {BAttachment|null} */ | ||||||
|  |     getAttachmentById(attachmentId, opts = {}) { | ||||||
|  |         opts.includeContentLength = !!opts.includeContentLength; | ||||||
|  |  | ||||||
|  |         const query = opts.includeContentLength | ||||||
|  |             ? `SELECT attachments.*, LENGTH(blobs.content) AS contentLength | ||||||
|  |                FROM attachments  | ||||||
|  |                JOIN blobs USING (blobId)  | ||||||
|  |                WHERE ownerId = ? AND attachmentId = ? AND isDeleted = 0` | ||||||
|  |             : `SELECT * FROM attachments WHERE ownerId = ? AND attachmentId = ? AND isDeleted = 0`; | ||||||
|  |  | ||||||
|  |         return sql.getRows(query, [this.revisionId, attachmentId]) | ||||||
|  |             .map(row => new BAttachment(row))[0]; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** @returns {BAttachment[]} */ | ||||||
|  |     getAttachmentsByRole(role) { | ||||||
|  |         return sql.getRows(` | ||||||
|  |                 SELECT attachments.* | ||||||
|  |                 FROM attachments  | ||||||
|  |                 WHERE ownerId = ?  | ||||||
|  |                   AND role = ? | ||||||
|  |                   AND isDeleted = 0 | ||||||
|  |                 ORDER BY position`, [this.revisionId, role]) | ||||||
|  |             .map(row => new BAttachment(row)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** @returns {BAttachment} */ | ||||||
|  |     getAttachmentByTitle(title) { | ||||||
|  |         return sql.getRows(` | ||||||
|  |                 SELECT attachments.* | ||||||
|  |                 FROM attachments  | ||||||
|  |                 WHERE ownerId = ?  | ||||||
|  |                   AND title = ? | ||||||
|  |                   AND isDeleted = 0 | ||||||
|  |                 ORDER BY position`, [this.revisionId, title]) | ||||||
|  |             .map(row => new BAttachment(row))[0]; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     beforeSaving() { |     beforeSaving() { | ||||||
|         super.beforeSaving(); |         super.beforeSaving(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -127,7 +127,8 @@ paths: | |||||||
|             - targetRelationCount |             - targetRelationCount | ||||||
|             - targetRelationCountIncludingLinks |             - targetRelationCountIncludingLinks | ||||||
|             - contentSize |             - contentSize | ||||||
|             - noteSize |             - contentAndAttachmentsSize | ||||||
|  |             - contentAndAttachmentsAndRevisionsSize | ||||||
|             - revisionCount |             - revisionCount | ||||||
|         - name: orderDirection |         - name: orderDirection | ||||||
|           in: query |           in: query | ||||||
|   | |||||||
| @@ -78,6 +78,7 @@ import HideFloatingButtonsButton from "../widgets/floating_buttons/hide_floating | |||||||
| import ScriptExecutorWidget from "../widgets/ribbon_widgets/script_executor.js"; | import ScriptExecutorWidget from "../widgets/ribbon_widgets/script_executor.js"; | ||||||
| import MovePaneButton from "../widgets/buttons/move_pane_button.js"; | import MovePaneButton from "../widgets/buttons/move_pane_button.js"; | ||||||
| import UploadAttachmentsDialog from "../widgets/dialogs/upload_attachments.js"; | import UploadAttachmentsDialog from "../widgets/dialogs/upload_attachments.js"; | ||||||
|  | import CopyImageReferenceButton from "../widgets/floating_buttons/copy_image_reference_button.js"; | ||||||
|  |  | ||||||
| export default class DesktopLayout { | export default class DesktopLayout { | ||||||
|     constructor(customWidgets) { |     constructor(customWidgets) { | ||||||
| @@ -160,6 +161,7 @@ export default class DesktopLayout { | |||||||
|                                         .child(new EditButton()) |                                         .child(new EditButton()) | ||||||
|                                         .child(new CodeButtonsWidget()) |                                         .child(new CodeButtonsWidget()) | ||||||
|                                         .child(new RelationMapButtons()) |                                         .child(new RelationMapButtons()) | ||||||
|  |                                         .child(new CopyImageReferenceButton()) | ||||||
|                                         .child(new MermaidExportButton()) |                                         .child(new MermaidExportButton()) | ||||||
|                                         .child(new BacklinksWidget()) |                                         .child(new BacklinksWidget()) | ||||||
|                                         .child(new HideFloatingButtonsButton()) |                                         .child(new HideFloatingButtonsButton()) | ||||||
|   | |||||||
| @@ -32,8 +32,8 @@ export default class LauncherContextMenu { | |||||||
|         const isVisibleItem = parentNoteId === '_lbVisibleLaunchers'; |         const isVisibleItem = parentNoteId === '_lbVisibleLaunchers'; | ||||||
|         const isAvailableItem = parentNoteId === '_lbAvailableLaunchers'; |         const isAvailableItem = parentNoteId === '_lbAvailableLaunchers'; | ||||||
|         const isItem = isVisibleItem || isAvailableItem; |         const isItem = isVisibleItem || isAvailableItem; | ||||||
|         const canBeDeleted = !note.isLaunchBarConfig(); |         const canBeDeleted = !note.noteId.startsWith("_"); // fixed notes can't be deleted | ||||||
|         const canBeReset = note.isLaunchBarConfig(); |         const canBeReset = !canBeDeleted && note.isLaunchBarConfig();; | ||||||
|  |  | ||||||
|         return [ |         return [ | ||||||
|             (isVisibleRoot || isAvailableRoot) ? { title: 'Add a note launcher', command: 'addNoteLauncher', uiIcon: "bx bx-plus" } : null, |             (isVisibleRoot || isAvailableRoot) ? { title: 'Add a note launcher', command: 'addNoteLauncher', uiIcon: "bx bx-plus" } : null, | ||||||
|   | |||||||
| @@ -252,11 +252,15 @@ class NoteListRenderer { | |||||||
|             if (pageCount < 20 || i <= 5 || pageCount - i <= 5 || Math.abs(this.page - i) <= 2) { |             if (pageCount < 20 || i <= 5 || pageCount - i <= 5 || Math.abs(this.page - i) <= 2) { | ||||||
|                 lastPrinted = true; |                 lastPrinted = true; | ||||||
|  |  | ||||||
|  |                 const startIndex = (i - 1) * this.pageSize + 1; | ||||||
|  |                 const endIndex = Math.min(this.noteIds.length, i * this.pageSize); | ||||||
|  |  | ||||||
|                 $pager.append( |                 $pager.append( | ||||||
|                     i === this.page |                     i === this.page | ||||||
|                         ? $('<span>').text(i).css('text-decoration', 'underline').css('font-weight', "bold") |                         ? $('<span>').text(i).css('text-decoration', 'underline').css('font-weight', "bold") | ||||||
|                         : $('<a href="javascript:">') |                         : $('<a href="javascript:">') | ||||||
|                             .text(i) |                             .text(i) | ||||||
|  |                             .attr("title", `Page of ${startIndex} - ${endIndex}`) | ||||||
|                             .on('click', () => { |                             .on('click', () => { | ||||||
|                                 this.page = i; |                                 this.page = i; | ||||||
|                                 this.renderList(); |                                 this.renderList(); | ||||||
| @@ -270,6 +274,9 @@ class NoteListRenderer { | |||||||
|                 lastPrinted = false; |                 lastPrinted = false; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         // no need to distinguish "note" vs "notes" since in case of one result, there's no paging at all | ||||||
|  |         $pager.append(`<span class="note-list-pager-total-count">(${this.noteIds.length} notes)</span>`); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     async renderNote(note, expand = false) { |     async renderNote(note, expand = false) { | ||||||
|   | |||||||
| @@ -495,6 +495,14 @@ function copyHtmlToClipboard(content) { | |||||||
|     navigator.clipboard.write([clipboardItem]); |     navigator.clipboard.write([clipboardItem]); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param {FNote} note | ||||||
|  |  * @return {string} | ||||||
|  |  */ | ||||||
|  | function createImageSrcUrl(note) { | ||||||
|  |     return `api/images/${note.noteId}/${encodeURIComponent(note.title)}?timestamp=${Date.now()}`; | ||||||
|  | } | ||||||
|  |  | ||||||
| export default { | export default { | ||||||
|     reloadFrontendApp, |     reloadFrontendApp, | ||||||
|     parseDate, |     parseDate, | ||||||
| @@ -533,5 +541,6 @@ export default { | |||||||
|     sleep, |     sleep, | ||||||
|     escapeRegExp, |     escapeRegExp, | ||||||
|     areObjectsEqual, |     areObjectsEqual, | ||||||
|     copyHtmlToClipboard |     copyHtmlToClipboard, | ||||||
|  |     createImageSrcUrl | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ const TPL = ` | |||||||
|     .global-menu-button { |     .global-menu-button { | ||||||
|         background-image: url("${window.glob.assetPath}/images/icon-black.svg"); |         background-image: url("${window.glob.assetPath}/images/icon-black.svg"); | ||||||
|         background-repeat: no-repeat; |         background-repeat: no-repeat; | ||||||
|         background-position: 50% 80%; |         background-position: 40% 50%; | ||||||
|         background-size: 45px; |         background-size: 45px; | ||||||
|         width: 100%; |         width: 100%; | ||||||
|         height: 100%; |         height: 100%; | ||||||
|   | |||||||
| @@ -45,6 +45,7 @@ const TPL = ` | |||||||
|         <a class="dropdown-item export-note-button">Export note</a> |         <a class="dropdown-item export-note-button">Export note</a> | ||||||
|         <a class="dropdown-item delete-note-button">Delete note</a> |         <a class="dropdown-item delete-note-button">Delete note</a> | ||||||
|         <a data-trigger-command="printActiveNote" class="dropdown-item print-active-note-button"><kbd data-command="printActiveNote"></kbd> Print note</a> |         <a data-trigger-command="printActiveNote" class="dropdown-item print-active-note-button"><kbd data-command="printActiveNote"></kbd> Print note</a> | ||||||
|  |         <a data-trigger-command="forceSaveRevision" class="dropdown-item save-revision-button"><kbd data-command="forceSaveRevision"></kbd> Save revision</a> | ||||||
|     </div> |     </div> | ||||||
| </div>`; | </div>`; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -88,7 +88,7 @@ const TPL = ` | |||||||
|         display: none; |         display: none; | ||||||
|         border-bottom: 1px solid var(--main-border-color); |         border-bottom: 1px solid var(--main-border-color); | ||||||
|         margin-left: 10px; |         margin-left: 10px; | ||||||
|         margin-right: 10px; |         margin-right: 5px; /* needs to have this value so that the bottom border is the same width as the top one */ | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     .ribbon-body.active { |     .ribbon-body.active { | ||||||
|   | |||||||
| @@ -242,7 +242,7 @@ export default class RevisionsDialog extends BasicWidget { | |||||||
|  |  | ||||||
|                 renderMathInElement(this.$content[0], {trust: true}); |                 renderMathInElement(this.$content[0], {trust: true}); | ||||||
|             } |             } | ||||||
|         } else if (revisionItem.type === 'code' || revisionItem.type === 'mermaid') { |         } else if (revisionItem.type === 'code') { | ||||||
|             this.$content.html($("<pre>").text(fullRevision.content)); |             this.$content.html($("<pre>").text(fullRevision.content)); | ||||||
|         } else if (revisionItem.type === 'image') { |         } else if (revisionItem.type === 'image') { | ||||||
|             this.$content.html($("<img>") |             this.$content.html($("<img>") | ||||||
| @@ -274,26 +274,19 @@ export default class RevisionsDialog extends BasicWidget { | |||||||
|  |  | ||||||
|             this.$content.html($table); |             this.$content.html($table); | ||||||
|         } else if (revisionItem.type === 'canvas') { |         } else if (revisionItem.type === 'canvas') { | ||||||
|             /** |             const sanitizedTitle = revisionItem.title.replace(/[^a-z0-9-.]/gi, ""); | ||||||
|              * FIXME: We load a font called Virgil.wof2, which originates from excalidraw.com |  | ||||||
|              *        REMOVE external dependency!!!! This is defined in the svg in defs.style |  | ||||||
|              */ |  | ||||||
|             const content = fullRevision.content; |  | ||||||
|  |  | ||||||
|             try { |             this.$content.html($("<img>") | ||||||
|                 const data = JSON.parse(content) |                 .attr("src", `api/revisions/${revisionItem.revisionId}/image/${sanitizedTitle}?${Math.random()}`) | ||||||
|                 const svg = data.svg || "no svg present." |                 .css("max-width", "100%")); | ||||||
|  |         } else if (revisionItem.type === 'mermaid') { | ||||||
|  |             const sanitizedTitle = revisionItem.title.replace(/[^a-z0-9-.]/gi, ""); | ||||||
|  |  | ||||||
|                 /** |             this.$content.html($("<img>") | ||||||
|                  * maxWidth: 100% use full width of container but do not enlarge! |                 .attr("src", `api/revisions/${revisionItem.revisionId}/image/${sanitizedTitle}?${Math.random()}`) | ||||||
|                  * height:auto to ensure that height scales with width |                 .css("max-width", "100%")); | ||||||
|                  */ |  | ||||||
|                 const $svgHtml = $(svg).css({maxWidth: "100%", height: "auto"}); |             this.$content.append($("<pre>").text(fullRevision.content)); | ||||||
|                 this.$content.html($('<div>').append($svgHtml)); |  | ||||||
|             } catch (err) { |  | ||||||
|                 console.error("error parsing fullRevision.content as JSON", fullRevision.content, err); |  | ||||||
|                 this.$content.html($("<div>").text("Error parsing content. Please check console.error() for more details.")); |  | ||||||
|             } |  | ||||||
|         } else { |         } else { | ||||||
|             this.$content.text("Preview isn't available for this note type."); |             this.$content.text("Preview isn't available for this note type."); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -0,0 +1,40 @@ | |||||||
|  | import NoteContextAwareWidget from "../note_context_aware_widget.js"; | ||||||
|  | import utils from "../../services/utils.js"; | ||||||
|  | import imageService from "../../services/image.js"; | ||||||
|  |  | ||||||
|  | const TPL = ` | ||||||
|  | <button type="button" | ||||||
|  |         class="copy-image-reference-button" | ||||||
|  |         title="Copy image reference to the clipboard, can be pasted into a text note."> | ||||||
|  |         <span class="bx bx-copy"></span> | ||||||
|  |          | ||||||
|  |         <div class="hidden-image-copy"></div> | ||||||
|  | </button>`; | ||||||
|  |  | ||||||
|  | export default class CopyImageReferenceButton extends NoteContextAwareWidget { | ||||||
|  |     isEnabled() { | ||||||
|  |         return super.isEnabled() | ||||||
|  |             && ['mermaid', 'canvas'].includes(this.note?.type) | ||||||
|  |             && this.note.isContentAvailable() | ||||||
|  |             && this.noteContext?.viewScope.viewMode === 'default'; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     doRender() { | ||||||
|  |         super.doRender(); | ||||||
|  |  | ||||||
|  |         this.$widget = $(TPL); | ||||||
|  |         this.$hiddenImageCopy = this.$widget.find(".hidden-image-copy"); | ||||||
|  |  | ||||||
|  |         this.$widget.on('click', () => { | ||||||
|  |             this.$hiddenImageCopy.empty().append( | ||||||
|  |                 $("<img>") | ||||||
|  |                     .attr("src", utils.createImageSrcUrl(this.note)) | ||||||
|  |             ); | ||||||
|  |  | ||||||
|  |             imageService.copyImageReferenceToClipboard(this.$hiddenImageCopy); | ||||||
|  |  | ||||||
|  |             this.$hiddenImageCopy.empty(); | ||||||
|  |         }); | ||||||
|  |         this.contentSized(); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -16,6 +16,10 @@ const TPL = ` | |||||||
|             z-index: 100; |             z-index: 100; | ||||||
|         } |         } | ||||||
|          |          | ||||||
|  |         .type-canvas .floating-buttons-children { | ||||||
|  |             top: 70px;  | ||||||
|  |         } | ||||||
|  |          | ||||||
|         .floating-buttons-children > *:not(.hidden-int):not(.no-content-hidden) { |         .floating-buttons-children > *:not(.hidden-int):not(.no-content-hidden) { | ||||||
|             margin-left: 10px; |             margin-left: 10px; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| import libraryLoader from "../services/library_loader.js"; | import libraryLoader from "../services/library_loader.js"; | ||||||
| import NoteContextAwareWidget from "./note_context_aware_widget.js"; | import NoteContextAwareWidget from "./note_context_aware_widget.js"; | ||||||
|  | import server from "../services/server.js"; | ||||||
|  |  | ||||||
| const TPL = `<div class="mermaid-widget"> | const TPL = `<div class="mermaid-widget"> | ||||||
|     <style> |     <style> | ||||||
| @@ -18,6 +19,10 @@ const TPL = `<div class="mermaid-widget"> | |||||||
|             height: 100%; |             height: 100%; | ||||||
|             text-align: center; |             text-align: center; | ||||||
|         } |         } | ||||||
|  |          | ||||||
|  |         .mermaid-render svg { | ||||||
|  |             width: 95%; /* https://github.com/zadam/trilium/issues/4340 */ | ||||||
|  |         } | ||||||
|     </style> |     </style> | ||||||
|  |  | ||||||
|     <div class="mermaid-error alert alert-warning"> |     <div class="mermaid-error alert alert-warning"> | ||||||
| @@ -77,6 +82,20 @@ export default class MermaidWidget extends NoteContextAwareWidget { | |||||||
|         try { |         try { | ||||||
|             const svg = await this.renderSvg(); |             const svg = await this.renderSvg(); | ||||||
|  |  | ||||||
|  |             if (this.dirtyAttachment) { | ||||||
|  |                 const payload = { | ||||||
|  |                     role: 'image', | ||||||
|  |                     title: 'mermaid-export.svg', | ||||||
|  |                     mime: 'image/svg+xml', | ||||||
|  |                     content: svg, | ||||||
|  |                     position: 0 | ||||||
|  |                 }; | ||||||
|  |  | ||||||
|  |                 server.post(`notes/${this.noteId}/attachments?matchBy=title`, payload).then(() => { | ||||||
|  |                     this.dirtyAttachment = false; | ||||||
|  |                 }); | ||||||
|  |             } | ||||||
|  |  | ||||||
|             this.$display.html(svg); |             this.$display.html(svg); | ||||||
|  |  | ||||||
|             await wheelZoomLoaded; |             await wheelZoomLoaded; | ||||||
| @@ -85,8 +104,8 @@ export default class MermaidWidget extends NoteContextAwareWidget { | |||||||
|  |  | ||||||
|             WZoom.create(`#mermaid-render-${idCounter}`, { |             WZoom.create(`#mermaid-render-${idCounter}`, { | ||||||
|                 type: 'html', |                 type: 'html', | ||||||
|                 maxScale: 10, |                 maxScale: 50, | ||||||
|                 speed: 20, |                 speed: 1.3, | ||||||
|                 zoomOnClick: false |                 zoomOnClick: false | ||||||
|             }); |             }); | ||||||
|         } catch (e) { |         } catch (e) { | ||||||
| @@ -107,6 +126,8 @@ export default class MermaidWidget extends NoteContextAwareWidget { | |||||||
|  |  | ||||||
|     async entitiesReloadedEvent({loadResults}) { |     async entitiesReloadedEvent({loadResults}) { | ||||||
|         if (loadResults.isNoteContentReloaded(this.noteId)) { |         if (loadResults.isNoteContentReloaded(this.noteId)) { | ||||||
|  |             this.dirtyAttachment = true; | ||||||
|  |  | ||||||
|             await this.refresh(); |             await this.refresh(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1147,6 +1147,7 @@ export default class NoteTreeWidget extends NoteContextAwareWidget { | |||||||
|         let parentsOfAddedNodes = []; |         let parentsOfAddedNodes = []; | ||||||
|  |  | ||||||
|         const allBranchRows = loadResults.getBranchRows(); |         const allBranchRows = loadResults.getBranchRows(); | ||||||
|  |         // TODO: this flag is suspicious - why does it matter that all branches in a particular update are deleted? | ||||||
|         const allBranchesDeleted = allBranchRows.every(branchRow => !!branchRow.isDeleted); |         const allBranchesDeleted = allBranchRows.every(branchRow => !!branchRow.isDeleted); | ||||||
|  |  | ||||||
|         for (const branchRow of allBranchRows) { |         for (const branchRow of allBranchRows) { | ||||||
| @@ -1159,8 +1160,8 @@ export default class NoteTreeWidget extends NoteContextAwareWidget { | |||||||
|                 noteIdsToUpdate.add(branchRow.noteId); |                 noteIdsToUpdate.add(branchRow.noteId); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             for (const node of this.getNodesByBranch(branchRow)) { |             if (branchRow.isDeleted) { | ||||||
|                 if (branchRow.isDeleted) { |                 for (const node of this.getNodesByBranch(branchRow)) { | ||||||
|                     if (node.isActive()) { |                     if (node.isActive()) { | ||||||
|                         if (allBranchesDeleted) { |                         if (allBranchesDeleted) { | ||||||
|                             const newActiveNode = node.getNextSibling() |                             const newActiveNode = node.getNextSibling() | ||||||
| @@ -1181,9 +1182,7 @@ export default class NoteTreeWidget extends NoteContextAwareWidget { | |||||||
|  |  | ||||||
|                     noteIdsToUpdate.add(branchRow.parentNoteId); |                     noteIdsToUpdate.add(branchRow.parentNoteId); | ||||||
|                 } |                 } | ||||||
|             } |             } else { | ||||||
|  |  | ||||||
|             if (!branchRow.isDeleted) { |  | ||||||
|                 for (const parentNode of this.getNodesByNoteId(branchRow.parentNoteId)) { |                 for (const parentNode of this.getNodesByNoteId(branchRow.parentNoteId)) { | ||||||
|                     parentsOfAddedNodes.push(parentNode) |                     parentsOfAddedNodes.push(parentNode) | ||||||
|  |  | ||||||
| @@ -1194,12 +1193,16 @@ export default class NoteTreeWidget extends NoteContextAwareWidget { | |||||||
|                     const found = (parentNode.getChildren() || []).find(child => child.data.noteId === branchRow.noteId); |                     const found = (parentNode.getChildren() || []).find(child => child.data.noteId === branchRow.noteId); | ||||||
|                     if (!found) { |                     if (!found) { | ||||||
|                         // make sure it's loaded |                         // make sure it's loaded | ||||||
|                         await froca.getNote(branchRow.noteId); |                         const note = await froca.getNote(branchRow.noteId); | ||||||
|                         const frocaBranch = froca.getBranch(branchRow.branchId); |                         const frocaBranch = froca.getBranch(branchRow.branchId); | ||||||
|  |  | ||||||
|                         // we're forcing lazy since it's not clear if the whole required subtree is in froca |                         // we're forcing lazy since it's not clear if the whole required subtree is in froca | ||||||
|                         parentNode.addChildren([this.prepareNode(frocaBranch, true)]); |                         parentNode.addChildren([this.prepareNode(frocaBranch, true)]); | ||||||
|  |  | ||||||
|  |                         if (frocaBranch.isExpanded && note.hasChildren()) { | ||||||
|  |                             noteIdsToReload.add(frocaBranch.noteId); | ||||||
|  |                         } | ||||||
|  |  | ||||||
|                         this.sortChildren(parentNode); |                         this.sortChildren(parentNode); | ||||||
|  |  | ||||||
|                         // this might be a first child which would force an icon change |                         // this might be a first child which would force an icon change | ||||||
|   | |||||||
| @@ -17,7 +17,8 @@ const TPL = ` | |||||||
|          |          | ||||||
|         .basic-properties-widget > * { |         .basic-properties-widget > * { | ||||||
|             margin-right: 30px; |             margin-right: 30px; | ||||||
|             margin-top: 12px; |             margin-top: 9px; | ||||||
|  |             margin-bottom: 2px; | ||||||
|         } |         } | ||||||
|          |          | ||||||
|         .note-type-container, .editability-select-container { |         .note-type-container, .editability-select-container { | ||||||
|   | |||||||
| @@ -61,9 +61,13 @@ export default class ImagePropertiesWidget extends NoteContextAwareWidget { | |||||||
|     doRender() { |     doRender() { | ||||||
|         this.$widget = $(TPL); |         this.$widget = $(TPL); | ||||||
|         this.contentSized(); |         this.contentSized(); | ||||||
|  |  | ||||||
|         this.$copyReferenceToClipboardButton = this.$widget.find(".image-copy-reference-to-clipboard"); |         this.$copyReferenceToClipboardButton = this.$widget.find(".image-copy-reference-to-clipboard"); | ||||||
|  |         this.$copyReferenceToClipboardButton.on('click', () => this.triggerEvent(`copyImageReferenceToClipboard`, {ntxId: this.noteContext.ntxId})); | ||||||
|  |  | ||||||
|         this.$uploadNewRevisionButton = this.$widget.find(".image-upload-new-revision"); |         this.$uploadNewRevisionButton = this.$widget.find(".image-upload-new-revision"); | ||||||
|         this.$uploadNewRevisionInput = this.$widget.find(".image-upload-new-revision-input"); |         this.$uploadNewRevisionInput = this.$widget.find(".image-upload-new-revision-input"); | ||||||
|  |  | ||||||
|         this.$fileName = this.$widget.find(".image-filename"); |         this.$fileName = this.$widget.find(".image-filename"); | ||||||
|         this.$fileType = this.$widget.find(".image-filetype"); |         this.$fileType = this.$widget.find(".image-filetype"); | ||||||
|         this.$fileSize = this.$widget.find(".image-filesize"); |         this.$fileSize = this.$widget.find(".image-filesize"); | ||||||
| @@ -74,8 +78,6 @@ export default class ImagePropertiesWidget extends NoteContextAwareWidget { | |||||||
|         this.$imageDownloadButton = this.$widget.find(".image-download"); |         this.$imageDownloadButton = this.$widget.find(".image-download"); | ||||||
|         this.$imageDownloadButton.on('click', () => openService.downloadFileNote(this.noteId)); |         this.$imageDownloadButton.on('click', () => openService.downloadFileNote(this.noteId)); | ||||||
|  |  | ||||||
|         this.$copyReferenceToClipboardButton.on('click', () => this.triggerEvent(`copyImageReferenceToClipboard`, {ntxId: this.noteContext.ntxId})); |  | ||||||
|  |  | ||||||
|         this.$uploadNewRevisionButton.on("click", () => { |         this.$uploadNewRevisionButton.on("click", () => { | ||||||
|             this.$uploadNewRevisionInput.trigger("click"); |             this.$uploadNewRevisionInput.trigger("click"); | ||||||
|         }); |         }); | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ const TPL = ` | |||||||
|         color: var(--muted-text-color); |         color: var(--muted-text-color); | ||||||
|         max-height: 200px; |         max-height: 200px; | ||||||
|         overflow: auto; |         overflow: auto; | ||||||
|         padding: 12px 12px 11px 12px; |         padding: 14px 12px 13px 12px; | ||||||
|     } |     } | ||||||
|     </style> |     </style> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,7 +8,8 @@ const TPL = ` | |||||||
|         .attribute-list { |         .attribute-list { | ||||||
|             margin-left: 7px; |             margin-left: 7px; | ||||||
|             margin-right: 7px; |             margin-right: 7px; | ||||||
|             margin-top: 3px; |             margin-top: 5px; | ||||||
|  |             margin-bottom: 2px; | ||||||
|             position: relative; |             position: relative; | ||||||
|         } |         } | ||||||
|          |          | ||||||
|   | |||||||
| @@ -23,6 +23,7 @@ const TPL = ` | |||||||
|                 <option value="eq7">is exactly 7</option> |                 <option value="eq7">is exactly 7</option> | ||||||
|                 <option value="eq8">is exactly 8</option> |                 <option value="eq8">is exactly 8</option> | ||||||
|                 <option value="eq9">is exactly 9</option> |                 <option value="eq9">is exactly 9</option> | ||||||
|  |                 <option value="gt0">is greater than 0</option> | ||||||
|                 <option value="gt1">is greater than 1</option> |                 <option value="gt1">is greater than 1</option> | ||||||
|                 <option value="gt2">is greater than 2</option> |                 <option value="gt2">is greater than 2</option> | ||||||
|                 <option value="gt3">is greater than 3</option> |                 <option value="gt3">is greater than 3</option> | ||||||
| @@ -32,6 +33,7 @@ const TPL = ` | |||||||
|                 <option value="gt7">is greater than 7</option> |                 <option value="gt7">is greater than 7</option> | ||||||
|                 <option value="gt8">is greater than 8</option> |                 <option value="gt8">is greater than 8</option> | ||||||
|                 <option value="gt9">is greater than 9</option> |                 <option value="gt9">is greater than 9</option> | ||||||
|  |                 <option value="lt2">is less than 2</option> | ||||||
|                 <option value="lt3">is less than 3</option> |                 <option value="lt3">is less than 3</option> | ||||||
|                 <option value="lt4">is less than 4</option> |                 <option value="lt4">is less than 4</option> | ||||||
|                 <option value="lt5">is less than 5</option> |                 <option value="lt5">is less than 5</option> | ||||||
|   | |||||||
| @@ -14,7 +14,8 @@ const TPL = ` | |||||||
|             <option value="dateCreated">Date created</option> |             <option value="dateCreated">Date created</option> | ||||||
|             <option value="dateModified">Date of last modification</option> |             <option value="dateModified">Date of last modification</option> | ||||||
|             <option value="contentSize">Note content size</option> |             <option value="contentSize">Note content size</option> | ||||||
|             <option value="noteSize">Note content size including revisions</option> |             <option value="contentAndAttachmentsSize">Note content size including attachments</option> | ||||||
|  |             <option value="contentAndAttachmentsAndRevisionsSize">Note content size including attachments and revisions</option> | ||||||
|             <option value="revisionCount">Number of revisions</option> |             <option value="revisionCount">Number of revisions</option> | ||||||
|             <option value="childrenCount">Number of children notes</option> |             <option value="childrenCount">Number of children notes</option> | ||||||
|             <option value="parentCount">Number of clones</option> |             <option value="parentCount">Number of clones</option> | ||||||
|   | |||||||
| @@ -22,6 +22,7 @@ const Draggabilly = window.Draggabilly; | |||||||
|  |  | ||||||
| const TAB_CONTAINER_MIN_WIDTH = 24; | const TAB_CONTAINER_MIN_WIDTH = 24; | ||||||
| const TAB_CONTAINER_MAX_WIDTH = 240; | const TAB_CONTAINER_MAX_WIDTH = 240; | ||||||
|  | const TAB_CONTAINER_LEFT_PADDING = 5; | ||||||
| const NEW_TAB_WIDTH = 32; | const NEW_TAB_WIDTH = 32; | ||||||
| const MIN_FILLER_WIDTH = 50; | const MIN_FILLER_WIDTH = 50; | ||||||
| const MARGIN_WIDTH = 5; | const MARGIN_WIDTH = 5; | ||||||
| @@ -330,7 +331,7 @@ export default class TabRowWidget extends BasicWidget { | |||||||
|     getTabPositions() { |     getTabPositions() { | ||||||
|         const tabPositions = []; |         const tabPositions = []; | ||||||
|  |  | ||||||
|         let position = 0; |         let position = TAB_CONTAINER_LEFT_PADDING; | ||||||
|         this.tabWidths.forEach(width => { |         this.tabWidths.forEach(width => { | ||||||
|             tabPositions.push(position); |             tabPositions.push(position); | ||||||
|             position += width + MARGIN_WIDTH; |             position += width + MARGIN_WIDTH; | ||||||
| @@ -617,7 +618,7 @@ export default class TabRowWidget extends BasicWidget { | |||||||
|  |  | ||||||
|         // update tab id for the new main context |         // update tab id for the new main context | ||||||
|         this.getTabById(oldMainNtxId).attr("data-ntx-id", newMainNtxId); |         this.getTabById(oldMainNtxId).attr("data-ntx-id", newMainNtxId); | ||||||
|         this.updateTabById(newMainNtxId);         |         this.updateTabById(newMainNtxId); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     contextsReopenedEvent({mainNtxId, tabPosition}) { |     contextsReopenedEvent({mainNtxId, tabPosition}) { | ||||||
|   | |||||||
| @@ -209,7 +209,7 @@ export default class ExcalidrawTypeWidget extends TypeWidget { | |||||||
|                 }; |                 }; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             const {elements, files, appState} = content; |             const {elements, files, appState = {}} = content; | ||||||
|  |  | ||||||
|             appState.theme = this.themeStyle; |             appState.theme = this.themeStyle; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -49,8 +49,8 @@ class ImageTypeWidget extends TypeWidget { | |||||||
|  |  | ||||||
|         libraryLoader.requireLibrary(libraryLoader.WHEEL_ZOOM).then(() => { |         libraryLoader.requireLibrary(libraryLoader.WHEEL_ZOOM).then(() => { | ||||||
|             WZoom.create(`#${this.$imageView.attr("id")}`, { |             WZoom.create(`#${this.$imageView.attr("id")}`, { | ||||||
|                 maxScale: 10, |                 maxScale: 50, | ||||||
|                 speed: 20, |                 speed: 1.3, | ||||||
|                 zoomOnClick: false |                 zoomOnClick: false | ||||||
|             }); |             }); | ||||||
|         }); |         }); | ||||||
| @@ -90,7 +90,7 @@ class ImageTypeWidget extends TypeWidget { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     async doRefresh(note) { |     async doRefresh(note) { | ||||||
|         this.$imageView.prop("src", `api/images/${note.noteId}/${encodeURIComponent(note.title)}?timestamp=${Date.now()}`); |         this.$imageView.prop("src", utils.createImageSrcUrl(note)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     copyImageReferenceToClipboardEvent({ntxId}) { |     copyImageReferenceToClipboardEvent({ntxId}) { | ||||||
|   | |||||||
| @@ -20,6 +20,10 @@ const TPL = ` | |||||||
|     <p>You can decide yourself if you want to provide a fully or lightly anonymized database. Even fully anonymized DB is very useful, however in some cases lightly anonymized database can speed up the process of bug identification and fixing.</p> |     <p>You can decide yourself if you want to provide a fully or lightly anonymized database. Even fully anonymized DB is very useful, however in some cases lightly anonymized database can speed up the process of bug identification and fixing.</p> | ||||||
|      |      | ||||||
|     <button class="anonymize-light-button btn">Save lightly anonymized database</button> |     <button class="anonymize-light-button btn">Save lightly anonymized database</button> | ||||||
|  |      | ||||||
|  |     <h5>Existing anonymized databases</h5> | ||||||
|  |      | ||||||
|  |     <ul class="existing-anonymized-databases"></ul> | ||||||
| </div>`; | </div>`; | ||||||
|  |  | ||||||
| export default class DatabaseAnonymizationOptions extends OptionsWidget { | export default class DatabaseAnonymizationOptions extends OptionsWidget { | ||||||
| @@ -38,6 +42,8 @@ export default class DatabaseAnonymizationOptions extends OptionsWidget { | |||||||
|             else { |             else { | ||||||
|                 toastService.showMessage(`Created fully anonymized database in ${resp.anonymizedFilePath}`, 10000); |                 toastService.showMessage(`Created fully anonymized database in ${resp.anonymizedFilePath}`, 10000); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             this.refresh(); | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
|         this.$anonymizeLightButton.on('click', async () => { |         this.$anonymizeLightButton.on('click', async () => { | ||||||
| @@ -51,6 +57,24 @@ export default class DatabaseAnonymizationOptions extends OptionsWidget { | |||||||
|             else { |             else { | ||||||
|                 toastService.showMessage(`Created lightly anonymized database in ${resp.anonymizedFilePath}`, 10000); |                 toastService.showMessage(`Created lightly anonymized database in ${resp.anonymizedFilePath}`, 10000); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             this.refresh(); | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         this.$existingAnonymizedDatabases = this.$widget.find(".existing-anonymized-databases"); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     optionsLoaded(options) { | ||||||
|  |         server.get("database/anonymized-databases").then(anonymizedDatabases => { | ||||||
|  |             this.$existingAnonymizedDatabases.empty(); | ||||||
|  |  | ||||||
|  |             if (!anonymizedDatabases.length) { | ||||||
|  |                 anonymizedDatabases = [{filePath: "no anonymized database yet"}]; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             for (const {filePath} of anonymizedDatabases) { | ||||||
|  |                 this.$existingAnonymizedDatabases.append($("<li>").text(filePath)); | ||||||
|  |             } | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -37,6 +37,12 @@ const TPL = ` | |||||||
|      |      | ||||||
|     <button class="backup-database-button btn">Backup database now</button> |     <button class="backup-database-button btn">Backup database now</button> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  | <div class="options-section"> | ||||||
|  |     <h4>Existing backups</h4> | ||||||
|  |      | ||||||
|  |     <ul class="existing-backup-list"></ul> | ||||||
|  | </div> | ||||||
| `; | `; | ||||||
|  |  | ||||||
| export default class BackupOptions extends OptionsWidget { | export default class BackupOptions extends OptionsWidget { | ||||||
| @@ -49,6 +55,8 @@ export default class BackupOptions extends OptionsWidget { | |||||||
|             const {backupFile} = await server.post('database/backup-database'); |             const {backupFile} = await server.post('database/backup-database'); | ||||||
|  |  | ||||||
|             toastService.showMessage(`Database has been backed up to ${backupFile}`, 10000); |             toastService.showMessage(`Database has been backed up to ${backupFile}`, 10000); | ||||||
|  |  | ||||||
|  |             this.refresh(); | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
|         this.$dailyBackupEnabled = this.$widget.find(".daily-backup-enabled"); |         this.$dailyBackupEnabled = this.$widget.find(".daily-backup-enabled"); | ||||||
| @@ -63,11 +71,25 @@ export default class BackupOptions extends OptionsWidget { | |||||||
|  |  | ||||||
|         this.$monthlyBackupEnabled.on('change', () => |         this.$monthlyBackupEnabled.on('change', () => | ||||||
|             this.updateCheckboxOption('monthlyBackupEnabled', this.$monthlyBackupEnabled)); |             this.updateCheckboxOption('monthlyBackupEnabled', this.$monthlyBackupEnabled)); | ||||||
|  |  | ||||||
|  |         this.$existingBackupList = this.$widget.find(".existing-backup-list"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     optionsLoaded(options) { |     optionsLoaded(options) { | ||||||
|         this.setCheckboxState(this.$dailyBackupEnabled, options.dailyBackupEnabled); |         this.setCheckboxState(this.$dailyBackupEnabled, options.dailyBackupEnabled); | ||||||
|         this.setCheckboxState(this.$weeklyBackupEnabled, options.weeklyBackupEnabled); |         this.setCheckboxState(this.$weeklyBackupEnabled, options.weeklyBackupEnabled); | ||||||
|         this.setCheckboxState(this.$monthlyBackupEnabled, options.monthlyBackupEnabled); |         this.setCheckboxState(this.$monthlyBackupEnabled, options.monthlyBackupEnabled); | ||||||
|  |  | ||||||
|  |         server.get("database/backups").then(backupFiles => { | ||||||
|  |             this.$existingBackupList.empty(); | ||||||
|  |  | ||||||
|  |             if (!backupFiles.length) { | ||||||
|  |                 backupFiles = [{filePath: "no backup yet", mtime: ''}]; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             for (const {filePath, mtime} of backupFiles) { | ||||||
|  |                 this.$existingBackupList.append($("<li>").text(`${filePath} ${mtime ? ` - ${mtime}` : ''}`)); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -21,7 +21,8 @@ const TPL = ` | |||||||
|             <label>Sync proxy server (optional)</label> |             <label>Sync proxy server (optional)</label> | ||||||
|             <input class="sync-proxy form-control" placeholder="https://<host>:<port>"> |             <input class="sync-proxy form-control" placeholder="https://<host>:<port>"> | ||||||
|      |      | ||||||
|             <p><strong>Note:</strong> If you leave the proxy setting blank, the system proxy will be used (applies to desktop/electron build only)</p> |             <p><strong>Note:</strong> If you leave the proxy setting blank, the system proxy will be used (applies to desktop/electron build only).</p> | ||||||
|  |             <p>Another special value is <code>noproxy</code> which forces ignoring even the system proxy and respectes <code>NODE_TLS_REJECT_UNAUTHORIZED</code>.</p> | ||||||
|         </div> |         </div> | ||||||
|      |      | ||||||
|         <div style="display: flex; justify-content: space-between;"> |         <div style="display: flex; justify-content: space-between;"> | ||||||
|   | |||||||
| @@ -32,9 +32,10 @@ function getAllAttachments(req) { | |||||||
| function saveAttachment(req) { | function saveAttachment(req) { | ||||||
|     const {noteId} = req.params; |     const {noteId} = req.params; | ||||||
|     const {attachmentId, role, mime, title, content} = req.body; |     const {attachmentId, role, mime, title, content} = req.body; | ||||||
|  |     const {matchBy} = req.query; | ||||||
|  |  | ||||||
|     const note = becca.getNoteOrThrow(noteId); |     const note = becca.getNoteOrThrow(noteId); | ||||||
|     note.saveAttachment({attachmentId, role, mime, title, content}); |     note.saveAttachment({attachmentId, role, mime, title, content}, matchBy); | ||||||
| } | } | ||||||
|  |  | ||||||
| function uploadAttachment(req) { | function uploadAttachment(req) { | ||||||
|   | |||||||
| @@ -6,8 +6,8 @@ const backupService = require('../../services/backup'); | |||||||
| const anonymizationService = require('../../services/anonymization'); | const anonymizationService = require('../../services/anonymization'); | ||||||
| const consistencyChecksService = require('../../services/consistency_checks'); | const consistencyChecksService = require('../../services/consistency_checks'); | ||||||
|  |  | ||||||
| async function anonymize(req) { | function getExistingBackups() { | ||||||
|     return await anonymizationService.createAnonymizedCopy(req.params.type); |     return backupService.getExistingBackups(); | ||||||
| } | } | ||||||
|  |  | ||||||
| async function backupDatabase() { | async function backupDatabase() { | ||||||
| @@ -22,6 +22,18 @@ function vacuumDatabase() { | |||||||
|     log.info("Database has been vacuumed."); |     log.info("Database has been vacuumed."); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | function findAndFixConsistencyIssues() { | ||||||
|  |     consistencyChecksService.runOnDemandChecks(true); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getExistingAnonymizedDatabases() { | ||||||
|  |     return anonymizationService.getExistingAnonymizedDatabases(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function anonymize(req) { | ||||||
|  |     return await anonymizationService.createAnonymizedCopy(req.params.type); | ||||||
|  | } | ||||||
|  |  | ||||||
| function checkIntegrity() { | function checkIntegrity() { | ||||||
|     const results = sql.getRows("PRAGMA integrity_check"); |     const results = sql.getRows("PRAGMA integrity_check"); | ||||||
|  |  | ||||||
| @@ -32,14 +44,12 @@ function checkIntegrity() { | |||||||
|     }; |     }; | ||||||
| } | } | ||||||
|  |  | ||||||
| function findAndFixConsistencyIssues() { |  | ||||||
|     consistencyChecksService.runOnDemandChecks(true); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| module.exports = { | module.exports = { | ||||||
|  |     getExistingBackups, | ||||||
|     backupDatabase, |     backupDatabase, | ||||||
|     vacuumDatabase, |     vacuumDatabase, | ||||||
|     findAndFixConsistencyIssues, |     findAndFixConsistencyIssues, | ||||||
|  |     getExistingAnonymizedDatabases, | ||||||
|     anonymize, |     anonymize, | ||||||
|     checkIntegrity |     checkIntegrity | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -5,40 +5,34 @@ const becca = require('../../becca/becca'); | |||||||
| const RESOURCE_DIR = require('../../services/resource_dir').RESOURCE_DIR; | const RESOURCE_DIR = require('../../services/resource_dir').RESOURCE_DIR; | ||||||
| const fs = require('fs'); | const fs = require('fs'); | ||||||
|  |  | ||||||
| function returnImage(req, res) { | function returnImageFromNote(req, res) { | ||||||
|     const image = becca.getNote(req.params.noteId); |     const image = becca.getNote(req.params.noteId); | ||||||
|  |  | ||||||
|  |     return returnImageInt(image, res); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function returnImageFromRevision(req, res) { | ||||||
|  |     const image = becca.getRevision(req.params.revisionId); | ||||||
|  |  | ||||||
|  |     return returnImageInt(image, res); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param {BNote|BRevision} image | ||||||
|  |  * @param res | ||||||
|  |  */ | ||||||
|  | function returnImageInt(image, res) { | ||||||
|     if (!image) { |     if (!image) { | ||||||
|         res.set('Content-Type', 'image/png'); |         res.set('Content-Type', 'image/png'); | ||||||
|         return res.send(fs.readFileSync(`${RESOURCE_DIR}/db/image-deleted.png`)); |         return res.send(fs.readFileSync(`${RESOURCE_DIR}/db/image-deleted.png`)); | ||||||
|     } |     } else if (!["image", "canvas", "mermaid"].includes(image.type)) { | ||||||
|     else if (!["image", "canvas"].includes(image.type)){ |  | ||||||
|         return res.sendStatus(400); |         return res.sendStatus(400); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * special "image" type. the canvas is actually type application/json |  | ||||||
|      * to avoid bitrot and enable usage as referenced image the svg is included. |  | ||||||
|      */ |  | ||||||
|     if (image.type === 'canvas') { |     if (image.type === 'canvas') { | ||||||
|         let svgString = '<svg/>' |         renderSvgAttachment(image, res, 'canvas-export.svg'); | ||||||
|         const attachment = image.getAttachmentByTitle('canvas-export.svg'); |     } else if (image.type === 'mermaid') { | ||||||
|  |         renderSvgAttachment(image, res, 'mermaid-export.svg'); | ||||||
|         if (attachment) { |  | ||||||
|             svgString = attachment.getContent(); |  | ||||||
|         } else { |  | ||||||
|             // backwards compatibility, before attachments, the SVG was stored in the main note content as a separate key |  | ||||||
|             const contentSvg = image.getJsonContentSafely()?.svg; |  | ||||||
|  |  | ||||||
|             if (contentSvg) { |  | ||||||
|                 svgString = contentSvg; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         const svg = svgString |  | ||||||
|         res.set('Content-Type', "image/svg+xml"); |  | ||||||
|         res.set("Cache-Control", "no-cache, no-store, must-revalidate"); |  | ||||||
|         res.send(svg); |  | ||||||
|     } else { |     } else { | ||||||
|         res.set('Content-Type', image.mime); |         res.set('Content-Type', image.mime); | ||||||
|         res.set("Cache-Control", "no-cache, no-store, must-revalidate"); |         res.set("Cache-Control", "no-cache, no-store, must-revalidate"); | ||||||
| @@ -46,6 +40,28 @@ function returnImage(req, res) { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | function renderSvgAttachment(image, res, attachmentName) { | ||||||
|  |     let svgString = '<svg/>' | ||||||
|  |     const attachment = image.getAttachmentByTitle(attachmentName); | ||||||
|  |  | ||||||
|  |     if (attachment) { | ||||||
|  |         svgString = attachment.getContent(); | ||||||
|  |     } else { | ||||||
|  |         // backwards compatibility, before attachments, the SVG was stored in the main note content as a separate key | ||||||
|  |         const contentSvg = image.getJsonContentSafely()?.svg; | ||||||
|  |  | ||||||
|  |         if (contentSvg) { | ||||||
|  |             svgString = contentSvg; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     const svg = svgString | ||||||
|  |     res.set('Content-Type', "image/svg+xml"); | ||||||
|  |     res.set("Cache-Control", "no-cache, no-store, must-revalidate"); | ||||||
|  |     res.send(svg); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| function returnAttachedImage(req, res) { | function returnAttachedImage(req, res) { | ||||||
|     const attachment = becca.getAttachment(req.params.attachmentId); |     const attachment = becca.getAttachment(req.params.attachmentId); | ||||||
|  |  | ||||||
| @@ -84,7 +100,8 @@ function updateImage(req) { | |||||||
| } | } | ||||||
|  |  | ||||||
| module.exports = { | module.exports = { | ||||||
|     returnImage, |     returnImageFromNote, | ||||||
|  |     returnImageFromRevision, | ||||||
|     returnAttachedImage, |     returnAttachedImage, | ||||||
|     updateImage |     updateImage | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -181,6 +181,8 @@ function register(app) { | |||||||
|     apiRoute(GET, '/api/revisions/:revisionId/blob', revisionsApiRoute.getRevisionBlob); |     apiRoute(GET, '/api/revisions/:revisionId/blob', revisionsApiRoute.getRevisionBlob); | ||||||
|     apiRoute(DEL, '/api/revisions/:revisionId', revisionsApiRoute.eraseRevision); |     apiRoute(DEL, '/api/revisions/:revisionId', revisionsApiRoute.eraseRevision); | ||||||
|     apiRoute(PST, '/api/revisions/:revisionId/restore', revisionsApiRoute.restoreRevision); |     apiRoute(PST, '/api/revisions/:revisionId/restore', revisionsApiRoute.restoreRevision); | ||||||
|  |     route(GET, '/api/revisions/:revisionId/image/:filename', [auth.checkApiAuthOrElectron], imageRoute.returnImageFromRevision); | ||||||
|  |  | ||||||
|     route(GET, '/api/revisions/:revisionId/download', [auth.checkApiAuthOrElectron], revisionsApiRoute.downloadRevision); |     route(GET, '/api/revisions/:revisionId/download', [auth.checkApiAuthOrElectron], revisionsApiRoute.downloadRevision); | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -200,7 +202,7 @@ function register(app) { | |||||||
|     apiRoute(GET, '/api/attribute-values/:attributeName', attributesRoute.getValuesForAttribute); |     apiRoute(GET, '/api/attribute-values/:attributeName', attributesRoute.getValuesForAttribute); | ||||||
|  |  | ||||||
|     // :filename is not used by trilium, but instead used for "save as" to assign a human-readable filename |     // :filename is not used by trilium, but instead used for "save as" to assign a human-readable filename | ||||||
|     route(GET, '/api/images/:noteId/:filename', [auth.checkApiAuthOrElectron], imageRoute.returnImage); |     route(GET, '/api/images/:noteId/:filename', [auth.checkApiAuthOrElectron], imageRoute.returnImageFromNote); | ||||||
|     route(PUT, '/api/images/:noteId', [auth.checkApiAuthOrElectron, uploadMiddlewareWithErrorHandling, csrfMiddleware], imageRoute.updateImage, apiResultHandler); |     route(PUT, '/api/images/:noteId', [auth.checkApiAuthOrElectron, uploadMiddlewareWithErrorHandling, csrfMiddleware], imageRoute.updateImage, apiResultHandler); | ||||||
|  |  | ||||||
|     apiRoute(GET, '/api/options', optionsApiRoute.getOptions); |     apiRoute(GET, '/api/options', optionsApiRoute.getOptions); | ||||||
| @@ -287,9 +289,11 @@ function register(app) { | |||||||
|     apiRoute(GET, '/api/sql/schema', sqlRoute.getSchema); |     apiRoute(GET, '/api/sql/schema', sqlRoute.getSchema); | ||||||
|     apiRoute(PST, '/api/sql/execute/:noteId', sqlRoute.execute); |     apiRoute(PST, '/api/sql/execute/:noteId', sqlRoute.execute); | ||||||
|     route(PST, '/api/database/anonymize/:type', [auth.checkApiAuthOrElectron, csrfMiddleware], databaseRoute.anonymize, apiResultHandler, false); |     route(PST, '/api/database/anonymize/:type', [auth.checkApiAuthOrElectron, csrfMiddleware], databaseRoute.anonymize, apiResultHandler, false); | ||||||
|  |     apiRoute(GET, '/api/database/anonymized-databases', databaseRoute.getExistingAnonymizedDatabases); | ||||||
|  |  | ||||||
|     // backup requires execution outside of transaction |     // backup requires execution outside of transaction | ||||||
|     route(PST, '/api/database/backup-database', [auth.checkApiAuthOrElectron, csrfMiddleware], databaseRoute.backupDatabase, apiResultHandler, false); |     route(PST, '/api/database/backup-database', [auth.checkApiAuthOrElectron, csrfMiddleware], databaseRoute.backupDatabase, apiResultHandler, false); | ||||||
|  |     apiRoute(GET, '/api/database/backups', databaseRoute.getExistingBackups); | ||||||
|  |  | ||||||
|     // VACUUM requires execution outside of transaction |     // VACUUM requires execution outside of transaction | ||||||
|     route(PST, '/api/database/vacuum-database', [auth.checkApiAuthOrElectron, csrfMiddleware], databaseRoute.vacuumDatabase, apiResultHandler, false); |     route(PST, '/api/database/vacuum-database', [auth.checkApiAuthOrElectron, csrfMiddleware], databaseRoute.vacuumDatabase, apiResultHandler, false); | ||||||
|   | |||||||
| @@ -4,11 +4,13 @@ const dataDir = require("./data_dir"); | |||||||
| const dateUtils = require("./date_utils"); | const dateUtils = require("./date_utils"); | ||||||
| const Database = require("better-sqlite3"); | const Database = require("better-sqlite3"); | ||||||
| const sql = require("./sql"); | const sql = require("./sql"); | ||||||
|  | const path = require("path"); | ||||||
|  |  | ||||||
| function getFullAnonymizationScript() { | function getFullAnonymizationScript() { | ||||||
|     // we want to delete all non-builtin attributes because they can contain sensitive names and values |     // we want to delete all non-builtin attributes because they can contain sensitive names and values | ||||||
| // on the other hand builtin/system attrs should not contain any sensitive info |     // on the other hand builtin/system attrs should not contain any sensitive info | ||||||
|     const builtinAttrNames = BUILTIN_ATTRIBUTES |     const builtinAttrNames = BUILTIN_ATTRIBUTES | ||||||
|  |         .filter(attr => !["shareCredentials", "shareAlias"].includes(attr.name)) | ||||||
|         .map(attr => `'${attr.name}'`).join(', '); |         .map(attr => `'${attr.name}'`).join(', '); | ||||||
|  |  | ||||||
|     const anonymizeScript = ` |     const anonymizeScript = ` | ||||||
| @@ -69,7 +71,21 @@ async function createAnonymizedCopy(type) { | |||||||
|     }; |     }; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | function getExistingAnonymizedDatabases() { | ||||||
|  |     if (!fs.existsSync(dataDir.ANONYMIZED_DB_DIR)) { | ||||||
|  |         return []; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return fs.readdirSync(dataDir.ANONYMIZED_DB_DIR) | ||||||
|  |         .filter(fileName => fileName.includes("anonymized")) | ||||||
|  |         .map(fileName => ({ | ||||||
|  |             fileName: fileName, | ||||||
|  |             filePath: path.resolve(dataDir.ANONYMIZED_DB_DIR, fileName) | ||||||
|  |         })); | ||||||
|  | } | ||||||
|  |  | ||||||
| module.exports = { | module.exports = { | ||||||
|     getFullAnonymizationScript, |     getFullAnonymizationScript, | ||||||
|     createAnonymizedCopy |     createAnonymizedCopy, | ||||||
|  |     getExistingAnonymizedDatabases | ||||||
| } | } | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ const build = require('./build'); | |||||||
| const packageJson = require('../../package'); | const packageJson = require('../../package'); | ||||||
| const {TRILIUM_DATA_DIR} = require('./data_dir'); | const {TRILIUM_DATA_DIR} = require('./data_dir'); | ||||||
|  |  | ||||||
| const APP_DB_VERSION = 225; | const APP_DB_VERSION = 226; | ||||||
| const SYNC_VERSION = 31; | const SYNC_VERSION = 31; | ||||||
| const CLIPPER_PROTOCOL_VERSION = "1.0"; | const CLIPPER_PROTOCOL_VERSION = "1.0"; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ const SpacedUpdate = require("./spaced_update"); | |||||||
| const specialNotesService = require("./special_notes"); | const specialNotesService = require("./special_notes"); | ||||||
| const branchService = require("./branches"); | const branchService = require("./branches"); | ||||||
| const exportService = require("./export/zip"); | const exportService = require("./export/zip"); | ||||||
|  | const syncMutex = require("./sync_mutex.js"); | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * <p>This is the main backend API interface for scripts. All the properties and methods are published in the "api" object |  * <p>This is the main backend API interface for scripts. All the properties and methods are published in the "api" object | ||||||
| @@ -571,6 +572,20 @@ function BackendScriptApi(currentNote, apiParams) { | |||||||
|         } |         } | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Sync process can make data intermittently inconsistent. Scripts which require strong data consistency | ||||||
|  |      * can use this function to wait for a possible sync process to finish and prevent new sync process from starting | ||||||
|  |      * while it is running. | ||||||
|  |      * | ||||||
|  |      * Because this is an async process, the inner callback doesn't have automatic transaction handling, so in case | ||||||
|  |      * you need to make some DB changes, you need to surround your call with api.transactional(...) | ||||||
|  |      * | ||||||
|  |      * @method | ||||||
|  |      * @param {function} callback - function to be executed while sync process is not running | ||||||
|  |      * @returns {Promise} - resolves once the callback is finished (callback is awaited) | ||||||
|  |      */ | ||||||
|  |     this.runOutsideOfSync = syncMutex.doExclusively; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * This object contains "at your risk" and "no BC guarantees" objects for advanced use cases. |      * This object contains "at your risk" and "no BC guarantees" objects for advanced use cases. | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -8,6 +8,22 @@ const log = require('./log'); | |||||||
| const syncMutexService = require('./sync_mutex'); | const syncMutexService = require('./sync_mutex'); | ||||||
| const cls = require('./cls'); | const cls = require('./cls'); | ||||||
| const sql = require('./sql'); | const sql = require('./sql'); | ||||||
|  | const path = require('path'); | ||||||
|  |  | ||||||
|  | function getExistingBackups() { | ||||||
|  |     if (!fs.existsSync(dataDir.BACKUP_DIR)) { | ||||||
|  |         return []; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return fs.readdirSync(dataDir.BACKUP_DIR) | ||||||
|  |         .filter(fileName => fileName.includes("backup")) | ||||||
|  |         .map(fileName => { | ||||||
|  |             const filePath = path.resolve(dataDir.BACKUP_DIR, fileName); | ||||||
|  |             const stat = fs.statSync(filePath) | ||||||
|  |  | ||||||
|  |             return {fileName, filePath, mtime: stat.mtime}; | ||||||
|  |         }); | ||||||
|  | } | ||||||
|  |  | ||||||
| function regularBackup() { | function regularBackup() { | ||||||
|     cls.init(() => { |     cls.init(() => { | ||||||
| @@ -58,6 +74,7 @@ if (!fs.existsSync(dataDir.BACKUP_DIR)) { | |||||||
| } | } | ||||||
|  |  | ||||||
| module.exports = { | module.exports = { | ||||||
|  |     getExistingBackups, | ||||||
|     backupNow, |     backupNow, | ||||||
|     regularBackup |     regularBackup | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| module.exports = { buildDate:"2023-09-29T00:54:45+02:00", buildRevision: "e5555beea9a1638fefa218118e0596f4cfc1f4d0" }; | module.exports = { buildDate:"2023-11-03T11:46:53+01:00", buildRevision: "01093d05d7ca1ede0c9af3fe2f5b04969ade816d" }; | ||||||
|   | |||||||
| @@ -66,6 +66,7 @@ module.exports = [ | |||||||
|     { type: 'label', name: 'executeDescription'}, |     { type: 'label', name: 'executeDescription'}, | ||||||
|     { type: 'label', name: 'newNotesOnTop'}, |     { type: 'label', name: 'newNotesOnTop'}, | ||||||
|     { type: 'label', name: 'clipperInbox'}, |     { type: 'label', name: 'clipperInbox'}, | ||||||
|  |     { type: 'label', name: 'webViewSrc', isDangerous: true }, | ||||||
|  |  | ||||||
|     // relation names |     // relation names | ||||||
|     { type: 'relation', name: 'internalLink' }, |     { type: 'relation', name: 'internalLink' }, | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ const BBranch = require('../becca/entities/bbranch'); | |||||||
| const becca = require("../becca/becca"); | const becca = require("../becca/becca"); | ||||||
| const log = require("./log"); | const log = require("./log"); | ||||||
|  |  | ||||||
| function cloneNoteToParentNote(noteId, parentNoteId, prefix) { | function cloneNoteToParentNote(noteId, parentNoteId, prefix = null) { | ||||||
|     if (!(noteId in becca.notes) || !(parentNoteId in becca.notes)) { |     if (!(noteId in becca.notes) || !(parentNoteId in becca.notes)) { | ||||||
|         return { success: false, message: 'Note cannot be cloned because either the cloned note or the intended parent is deleted.' }; |         return { success: false, message: 'Note cannot be cloned because either the cloned note or the intended parent is deleted.' }; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -28,22 +28,14 @@ function sanitize(dirtyHtml) { | |||||||
|         allowedTags: [ |         allowedTags: [ | ||||||
|             'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'blockquote', 'p', 'a', 'ul', 'ol', |             'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'blockquote', 'p', 'a', 'ul', 'ol', | ||||||
|             'li', 'b', 'i', 'strong', 'em', 'strike', 's', 'del', 'abbr', 'code', 'hr', 'br', 'div', |             'li', 'b', 'i', 'strong', 'em', 'strike', 's', 'del', 'abbr', 'code', 'hr', 'br', 'div', | ||||||
|             'table', 'thead', 'caption', 'tbody', 'tr', 'th', 'td', 'pre', 'section', 'img', |             'table', 'thead', 'caption', 'tbody', 'tfoot', 'tr', 'th', 'td', 'pre', 'section', 'img', | ||||||
|             'figure', 'figcaption', 'span', 'label', 'input', |             'figure', 'figcaption', 'span', 'label', 'input', 'details', 'summary', 'address', 'aside', 'footer', | ||||||
|  |             'header', 'hgroup', 'main', 'nav', 'dl', 'dt', 'menu', 'bdi', 'bdo', 'dfn', 'kbd', 'mark', 'q', 'time', | ||||||
|  |             'var', 'wbr', 'area', 'map', 'track', 'video', 'audio', 'picture', 'del', 'ins', | ||||||
|             'en-media' // for ENEX import |             'en-media' // for ENEX import | ||||||
|         ], |         ], | ||||||
|         allowedAttributes: { |         allowedAttributes: { | ||||||
|             'a': [ 'href', 'class' ], |             '*': [ 'class', 'style', 'title', 'src', 'href', 'hash', 'disabled', 'align', 'alt', 'center', 'data-*' ] | ||||||
|             'img': [ 'src' ], |  | ||||||
|             'section': [ 'class', 'data-note-id' ], |  | ||||||
|             'figure': [ 'class' ], |  | ||||||
|             'span': [ 'class', 'style' ], |  | ||||||
|             'label': [ 'class' ], |  | ||||||
|             'input': [ 'class', 'type', 'disabled' ], |  | ||||||
|             'code': [ 'class' ], |  | ||||||
|             'ul': [ 'class' ], |  | ||||||
|             'table': [ 'class' ], |  | ||||||
|             'en-media': [ 'hash' ] |  | ||||||
|         }, |         }, | ||||||
|         allowedSchemes: [ |         allowedSchemes: [ | ||||||
|             'http', 'https', 'ftp', 'ftps', 'mailto', 'data', 'evernote', 'file', 'facetime', 'irc', 'gemini', 'git', |             'http', 'https', 'ftp', 'ftps', 'mailto', 'data', 'evernote', 'file', 'facetime', 'irc', 'gemini', 'git', | ||||||
|   | |||||||
| @@ -121,7 +121,11 @@ function importMarkdown(taskContext, file, parentNote) { | |||||||
|     const title = utils.getNoteTitle(file.originalname, taskContext.data.replaceUnderscoresWithSpaces); |     const title = utils.getNoteTitle(file.originalname, taskContext.data.replaceUnderscoresWithSpaces); | ||||||
|  |  | ||||||
|     const markdownContent = file.buffer.toString("utf-8"); |     const markdownContent = file.buffer.toString("utf-8"); | ||||||
|     const htmlContent = markdownService.renderToHtml(markdownContent, title); |     let htmlContent = markdownService.renderToHtml(markdownContent, title); | ||||||
|  |  | ||||||
|  |     if (taskContext.data.safeImport) { | ||||||
|  |         htmlContent = htmlSanitizer.sanitize(htmlContent); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     const {note} = noteService.createNewNote({ |     const {note} = noteService.createNewNote({ | ||||||
|         parentNoteId: parentNote.noteId, |         parentNoteId: parentNote.noteId, | ||||||
| @@ -141,7 +145,10 @@ function importHtml(taskContext, file, parentNote) { | |||||||
|     const title = utils.getNoteTitle(file.originalname, taskContext.data.replaceUnderscoresWithSpaces); |     const title = utils.getNoteTitle(file.originalname, taskContext.data.replaceUnderscoresWithSpaces); | ||||||
|     let content = file.buffer.toString("utf-8"); |     let content = file.buffer.toString("utf-8"); | ||||||
|  |  | ||||||
|     content = htmlSanitizer.sanitize(content); |     if (taskContext.data.safeImport) { | ||||||
|  |         content = htmlSanitizer.sanitize(content); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     content = importUtils.handleH1(content, title); |     content = importUtils.handleH1(content, title); | ||||||
|  |  | ||||||
|     const {note} = noteService.createNewNote({ |     const {note} = noteService.createNewNote({ | ||||||
|   | |||||||
| @@ -311,7 +311,7 @@ async function importZip(taskContext, fileBuffer, importRootNote) { | |||||||
|             return /^(?:[a-z]+:)?\/\//i.test(url); |             return /^(?:[a-z]+:)?\/\//i.test(url); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         content = removeTrilumTags(content); |         content = removeTriliumTags(content); | ||||||
|  |  | ||||||
|         content = content.replace(/<h1>([^<]*)<\/h1>/gi, (match, text) => { |         content = content.replace(/<h1>([^<]*)<\/h1>/gi, (match, text) => { | ||||||
|             if (noteTitle.trim() === text.trim()) { |             if (noteTitle.trim() === text.trim()) { | ||||||
| @@ -321,12 +321,19 @@ async function importZip(taskContext, fileBuffer, importRootNote) { | |||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
|         content = htmlSanitizer.sanitize(content); |         if (taskContext.data.safeImport) { | ||||||
|  |             content = htmlSanitizer.sanitize(content); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         content = content.replace(/<html.*<body[^>]*>/gis, ""); |         content = content.replace(/<html.*<body[^>]*>/gis, ""); | ||||||
|         content = content.replace(/<\/body>.*<\/html>/gis, ""); |         content = content.replace(/<\/body>.*<\/html>/gis, ""); | ||||||
|  |  | ||||||
|         content = content.replace(/src="([^"]*)"/g, (match, url) => { |         content = content.replace(/src="([^"]*)"/g, (match, url) => { | ||||||
|  |             if (url.startsWith("data:image")) { | ||||||
|  |                 // inline images are parsed and saved into attachments in the note service | ||||||
|  |                 return match; | ||||||
|  |             } | ||||||
|  |  | ||||||
|             try { |             try { | ||||||
|                 url = decodeURIComponent(url).trim(); |                 url = decodeURIComponent(url).trim(); | ||||||
|             } catch (e) { |             } catch (e) { | ||||||
| @@ -388,7 +395,7 @@ async function importZip(taskContext, fileBuffer, importRootNote) { | |||||||
|         return content; |         return content; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     function removeTrilumTags(content) { |     function removeTriliumTags(content) { | ||||||
|         const tagsToRemove = [ |         const tagsToRemove = [ | ||||||
|             '<h1 data-trilium-h1>([^<]*)<\/h1>', |             '<h1 data-trilium-h1>([^<]*)<\/h1>', | ||||||
|             '<title data-trilium-title>([^<]*)<\/title>' |             '<title data-trilium-title>([^<]*)<\/title>' | ||||||
|   | |||||||
| @@ -63,7 +63,7 @@ const defaultOptions = [ | |||||||
|     { name: 'autoFixConsistencyIssues', value: 'true', isSynced: false }, |     { name: 'autoFixConsistencyIssues', value: 'true', isSynced: false }, | ||||||
|     { name: 'vimKeymapEnabled', value: 'false', isSynced: false }, |     { name: 'vimKeymapEnabled', value: 'false', isSynced: false }, | ||||||
|     { name: 'codeLineWrapEnabled', value: 'true', isSynced: false }, |     { name: 'codeLineWrapEnabled', value: 'true', isSynced: false }, | ||||||
|     { name: 'codeNotesMimeTypes', value: '["text/x-csrc","text/x-c++src","text/x-csharp","text/css","text/x-go","text/x-groovy","text/x-haskell","text/html","message/http","text/x-java","application/javascript;env=frontend","application/javascript;env=backend","application/json","text/x-kotlin","text/x-markdown","text/x-perl","text/x-php","text/x-python","text/x-ruby",null,"text/x-sql","text/x-sqlite;schema=trilium","text/x-swift","text/xml","text/x-yaml"]', isSynced: true }, |     { name: 'codeNotesMimeTypes', value: '["text/x-csrc","text/x-c++src","text/x-csharp","text/css","text/x-go","text/x-groovy","text/x-haskell","text/html","message/http","text/x-java","application/javascript;env=frontend","application/javascript;env=backend","application/json","text/x-kotlin","text/x-markdown","text/x-perl","text/x-php","text/x-python","text/x-ruby",null,"text/x-sql","text/x-sqlite;schema=trilium","text/x-swift","text/xml","text/x-yaml","text/x-sh"]', isSynced: true }, | ||||||
|     { name: 'leftPaneWidth', value: '25', isSynced: false }, |     { name: 'leftPaneWidth', value: '25', isSynced: false }, | ||||||
|     { name: 'leftPaneVisible', value: 'true', isSynced: false }, |     { name: 'leftPaneVisible', value: 'true', isSynced: false }, | ||||||
|     { name: 'rightPaneWidth', value: '25', isSynced: false }, |     { name: 'rightPaneWidth', value: '25', isSynced: false }, | ||||||
|   | |||||||
| @@ -58,10 +58,6 @@ function exec(opts) { | |||||||
|             request.on('error', err => reject(generateError(opts, err))); |             request.on('error', err => reject(generateError(opts, err))); | ||||||
|  |  | ||||||
|             request.on('response', response => { |             request.on('response', response => { | ||||||
|                 if (![200, 201, 204].includes(response.statusCode)) { |  | ||||||
|                     reject(generateError(opts, `${response.statusCode} ${response.statusMessage}`)); |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 if (opts.cookieJar && response.headers['set-cookie']) { |                 if (opts.cookieJar && response.headers['set-cookie']) { | ||||||
|                     opts.cookieJar.header = response.headers['set-cookie']; |                     opts.cookieJar.header = response.headers['set-cookie']; | ||||||
|                 } |                 } | ||||||
| @@ -71,15 +67,28 @@ function exec(opts) { | |||||||
|                 response.on('data', chunk => responseStr += chunk); |                 response.on('data', chunk => responseStr += chunk); | ||||||
|  |  | ||||||
|                 response.on('end', () => { |                 response.on('end', () => { | ||||||
|                     try { |                     if ([200, 201, 204].includes(response.statusCode)) { | ||||||
|                         const jsonObj = responseStr.trim() ? JSON.parse(responseStr) : null; |                         try { | ||||||
|  |                             const jsonObj = responseStr.trim() ? JSON.parse(responseStr) : null; | ||||||
|  |  | ||||||
|                         resolve(jsonObj); |                             resolve(jsonObj); | ||||||
|                     } |                         } catch (e) { | ||||||
|                     catch (e) { |                             log.error(`Failed to deserialize sync response: ${responseStr}`); | ||||||
|                         log.error(`Failed to deserialize sync response: ${responseStr}`); |  | ||||||
|  |  | ||||||
|                         reject(generateError(opts, e.message)); |                             reject(generateError(opts, e.message)); | ||||||
|  |                         } | ||||||
|  |                     } else { | ||||||
|  |                         let errorMessage; | ||||||
|  |  | ||||||
|  |                         try { | ||||||
|  |                             const jsonObj = JSON.parse(responseStr); | ||||||
|  |  | ||||||
|  |                             errorMessage = jsonObj?.message || ''; | ||||||
|  |                         } catch (e) { | ||||||
|  |                             errorMessage = responseStr.substr(0, Math.min(responseStr.length, 100)); | ||||||
|  |                         } | ||||||
|  |  | ||||||
|  |                         reject(generateError(opts, `${response.statusCode} ${response.statusMessage} ${errorMessage}`)); | ||||||
|                     } |                     } | ||||||
|                 }); |                 }); | ||||||
|             }); |             }); | ||||||
|   | |||||||
| @@ -56,9 +56,9 @@ class OrderByAndLimitExp extends Expression { | |||||||
|                 if (!valA && !valB) { |                 if (!valA && !valB) { | ||||||
|                     // the attribute value is empty/zero in both notes so continue to the next order definition |                     // the attribute value is empty/zero in both notes so continue to the next order definition | ||||||
|                     continue; |                     continue; | ||||||
|                 } else if (!valB || valA < valB) { |                 } else if (valA < valB) { | ||||||
|                     return smaller; |                     return smaller; | ||||||
|                 } else if (!valA || valA > valB) { |                 } else if (valA > valB) { | ||||||
|                     return larger; |                     return larger; | ||||||
|                 } |                 } | ||||||
|                 // else the values are equal and continue to next order definition |                 // else the values are equal and continue to next order definition | ||||||
|   | |||||||
| @@ -31,7 +31,8 @@ const PROP_MAPPING = { | |||||||
|     "targetrelationcount": "targetRelationCount", |     "targetrelationcount": "targetRelationCount", | ||||||
|     "targetrelationcountincludinglinks": "targetRelationCountIncludingLinks", |     "targetrelationcountincludinglinks": "targetRelationCountIncludingLinks", | ||||||
|     "contentsize": "contentSize", |     "contentsize": "contentSize", | ||||||
|     "notesize": "noteSize", |     "contentandattachmentssize": "contentAndAttachmentsSize", | ||||||
|  |     "contentandattachmentsandrevisionssize": "contentAndAttachmentsAndRevisionsSize", | ||||||
|     "revisioncount": "revisionCount" |     "revisioncount": "revisionCount" | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -48,7 +49,7 @@ class PropertyComparisonExp extends Expression { | |||||||
|         this.comparedValue = comparedValue; // for DEBUG mode |         this.comparedValue = comparedValue; // for DEBUG mode | ||||||
|         this.comparator = buildComparator(operator, comparedValue); |         this.comparator = buildComparator(operator, comparedValue); | ||||||
|  |  | ||||||
|         if (['contentsize', 'notesize', 'revisioncount'].includes(this.propertyName)) { |         if (['contentsize', 'contentandattachmentssize', 'contentandattachmentsandrevisionssize', 'revisioncount'].includes(this.propertyName)) { | ||||||
|             searchContext.dbLoadNeeded = true; |             searchContext.dbLoadNeeded = true; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -22,6 +22,10 @@ class SearchResult { | |||||||
|  |  | ||||||
|         const note = becca.notes[this.noteId]; |         const note = becca.notes[this.noteId]; | ||||||
|  |  | ||||||
|  |         if (note.noteId.toLowerCase() === fulltextQuery) { | ||||||
|  |             this.score += 100; | ||||||
|  |         } | ||||||
|  |  | ||||||
|         if (note.title.toLowerCase() === fulltextQuery) { |         if (note.title.toLowerCase() === fulltextQuery) { | ||||||
|             this.score += 100; // high reward for exact match #3470 |             this.score += 100; // high reward for exact match #3470 | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -92,47 +92,107 @@ function searchFromRelation(note, relationName) { | |||||||
| function loadNeededInfoFromDatabase() { | function loadNeededInfoFromDatabase() { | ||||||
|     const sql = require('../../sql'); |     const sql = require('../../sql'); | ||||||
|  |  | ||||||
|     for (const noteId in becca.notes) { |     /** | ||||||
|         becca.notes[noteId].contentSize = 0; |      * This complex structure is needed to calculate total occupied space by a note. Several object instances | ||||||
|         becca.notes[noteId].noteSize = 0; |      * (note, revisions, attachments) can point to a single blobId, and thus the blob size should count towards the total | ||||||
|         becca.notes[noteId].revisionCount = 0; |      * only once. | ||||||
|     } |      * | ||||||
|  |      * @var {Object.<string, Object.<string, int>>} - noteId => { blobId => blobSize } | ||||||
|  |      */ | ||||||
|  |     const noteBlobs = {}; | ||||||
|  |  | ||||||
|     const noteContentLengths = sql.getRows(` |     const noteContentLengths = sql.getRows(` | ||||||
|         SELECT  |         SELECT  | ||||||
|             noteId,  |             noteId,  | ||||||
|  |             blobId, | ||||||
|             LENGTH(content) AS length  |             LENGTH(content) AS length  | ||||||
|         FROM notes |         FROM notes | ||||||
|              JOIN blobs USING(blobId)  |              JOIN blobs USING(blobId)  | ||||||
|         WHERE notes.isDeleted = 0`); |         WHERE notes.isDeleted = 0`); | ||||||
|  |  | ||||||
|     for (const {noteId, length} of noteContentLengths) { |     for (const {noteId, blobId, length} of noteContentLengths) { | ||||||
|         if (!(noteId in becca.notes)) { |         if (!(noteId in becca.notes)) { | ||||||
|             log.error(`Note ${noteId} not found in becca.`); |             log.error(`Note '${noteId}' not found in becca.`); | ||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         becca.notes[noteId].contentSize = length; |         becca.notes[noteId].contentSize = length; | ||||||
|         becca.notes[noteId].noteSize = length; |         becca.notes[noteId].revisionCount = 0; | ||||||
|  |  | ||||||
|  |         noteBlobs[noteId] = { [blobId]: length }; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     const revisionContentLengths = sql.getRows(` |     const attachmentContentLengths = sql.getRows(` | ||||||
|         SELECT  |         SELECT | ||||||
|             noteId,  |             ownerId AS noteId, | ||||||
|             LENGTH(content) AS length  |             attachments.blobId, | ||||||
|         FROM notes |             LENGTH(content) AS length | ||||||
|              JOIN revisions USING(noteId)  |         FROM attachments | ||||||
|              JOIN blobs USING(blobId)  |             JOIN notes ON attachments.ownerId = notes.noteId | ||||||
|         WHERE notes.isDeleted = 0`); |             JOIN blobs ON attachments.blobId = blobs.blobId | ||||||
|  |         WHERE attachments.isDeleted = 0  | ||||||
|  |             AND notes.isDeleted = 0`); | ||||||
|  |  | ||||||
|     for (const {noteId, length} of revisionContentLengths) { |     for (const {noteId, blobId, length} of attachmentContentLengths) { | ||||||
|         if (!(noteId in becca.notes)) { |         if (!(noteId in becca.notes)) { | ||||||
|             log.error(`Note ${noteId} not found in becca.`); |             log.error(`Note '${noteId}' not found in becca.`); | ||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         becca.notes[noteId].noteSize += length; |         if (!(noteId in noteBlobs)) { | ||||||
|         becca.notes[noteId].revisionCount++; |             log.error(`Did not find a '${noteId}' in the noteBlobs.`); | ||||||
|  |             continue; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         noteBlobs[noteId][blobId] = length; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     for (const noteId in noteBlobs) { | ||||||
|  |         becca.notes[noteId].contentAndAttachmentsSize = Object.values(noteBlobs[noteId]).reduce((acc, size) => acc + size, 0); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     const revisionContentLengths = sql.getRows(` | ||||||
|  |             SELECT  | ||||||
|  |                 noteId,  | ||||||
|  |                 revisions.blobId, | ||||||
|  |                 LENGTH(content) AS length, | ||||||
|  |                 1 AS isNoteRevision | ||||||
|  |             FROM notes | ||||||
|  |                 JOIN revisions USING(noteId)  | ||||||
|  |                 JOIN blobs ON revisions.blobId = blobs.blobId | ||||||
|  |             WHERE notes.isDeleted = 0 | ||||||
|  |         UNION ALL | ||||||
|  |             SELECT | ||||||
|  |                 noteId, | ||||||
|  |                 revisions.blobId, | ||||||
|  |                 LENGTH(content) AS length, | ||||||
|  |                 0 AS isNoteRevision -- it's attachment not counting towards revision count | ||||||
|  |             FROM notes | ||||||
|  |                 JOIN revisions USING(noteId) | ||||||
|  |                 JOIN attachments ON attachments.ownerId = revisions.revisionId | ||||||
|  |                 JOIN blobs ON attachments.blobId = blobs.blobId | ||||||
|  |             WHERE notes.isDeleted = 0`); | ||||||
|  |  | ||||||
|  |     for (const {noteId, blobId, length, isNoteRevision} of revisionContentLengths) { | ||||||
|  |         if (!(noteId in becca.notes)) { | ||||||
|  |             log.error(`Note '${noteId}' not found in becca.`); | ||||||
|  |             continue; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (!(noteId in noteBlobs)) { | ||||||
|  |             log.error(`Did not find a '${noteId}' in the noteBlobs.`); | ||||||
|  |             continue; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         noteBlobs[noteId][blobId] = length; | ||||||
|  |  | ||||||
|  |         if (isNoteRevision) { | ||||||
|  |             becca.notes[noteId].revisionCount++; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     for (const noteId in noteBlobs) { | ||||||
|  |         becca.notes[noteId].contentAndAttachmentsAndRevisionsSize = Object.values(noteBlobs[noteId]).reduce((acc, size) => acc + size, 0); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -27,7 +27,8 @@ const PROP_MAPPING = { | |||||||
|     "targetrelationcount": "targetRelationCount", |     "targetrelationcount": "targetRelationCount", | ||||||
|     "targetrelationcountincludinglinks": "targetRelationCountIncludingLinks", |     "targetrelationcountincludinglinks": "targetRelationCountIncludingLinks", | ||||||
|     "contentsize": "contentSize", |     "contentsize": "contentSize", | ||||||
|     "notesize": "noteSize", |     "contentandattachmentssize": "contentAndAttachmentsSize", | ||||||
|  |     "contentandattachmentsandrevisionssize": "contentAndAttachmentsAndRevisionsSize", | ||||||
|     "revisioncount": "revisionCount" |     "revisioncount": "revisionCount" | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -42,7 +43,7 @@ class ValueExtractor { | |||||||
|             this.propertyPath = ['note', 'relations', this.propertyPath[0].substr(1), ...this.propertyPath.slice(1, this.propertyPath.length)]; |             this.propertyPath = ['note', 'relations', this.propertyPath[0].substr(1), ...this.propertyPath.slice(1, this.propertyPath.length)]; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (['contentsize', 'notesize', 'revisioncount'].includes(this.propertyPath[this.propertyPath.length - 1])) { |         if (['contentsize', 'contentandattachmentssize', 'contentandattachmentsandrevisionssize', 'revisioncount'].includes(this.propertyPath[this.propertyPath.length - 1])) { | ||||||
|             searchContext.dbLoadNeeded = true; |             searchContext.dbLoadNeeded = true; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -151,9 +151,14 @@ async function pullChanges(syncContext) { | |||||||
|         if (entityChanges.length === 0) { |         if (entityChanges.length === 0) { | ||||||
|             break; |             break; | ||||||
|         } else { |         } else { | ||||||
|             const sizeInKb = Math.round(JSON.stringify(resp).length / 1024); |             try { // https://github.com/zadam/trilium/issues/4310 | ||||||
|  |                 const sizeInKb = Math.round(JSON.stringify(resp).length / 1024); | ||||||
|  |  | ||||||
|             log.info(`Sync ${logMarkerId}: Pulled ${entityChanges.length} changes in ${sizeInKb} KB, starting at entityChangeId=${lastSyncedPull} in ${pulledDate - startDate}ms and applied them in ${Date.now() - pulledDate}ms, ${outstandingPullCount} outstanding pulls`); |                 log.info(`Sync ${logMarkerId}: Pulled ${entityChanges.length} changes in ${sizeInKb} KB, starting at entityChangeId=${lastSyncedPull} in ${pulledDate - startDate}ms and applied them in ${Date.now() - pulledDate}ms, ${outstandingPullCount} outstanding pulls`); | ||||||
|  |             } | ||||||
|  |             catch (e) { | ||||||
|  |                 log.error(`Error occurred ${e.message} ${e.stack}`); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| /** | /** | ||||||
|  * Sync makes process can make data intermittently inconsistent. Processes which require strong data consistency |  * Sync process can make data intermittently inconsistent. Processes which require strong data consistency | ||||||
|  * (like consistency checks) can use this mutex to make sure sync isn't currently running. |  * (like consistency checks) can use this mutex to make sure sync isn't currently running. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -68,44 +68,29 @@ function updateEntity(remoteEC, remoteEntityRow, instanceId, updateContext) { | |||||||
| function updateNormalEntity(remoteEC, remoteEntityRow, instanceId, updateContext) { | function updateNormalEntity(remoteEC, remoteEntityRow, instanceId, updateContext) { | ||||||
|     const localEC = sql.getRow(`SELECT * FROM entity_changes WHERE entityName = ? AND entityId = ?`, [remoteEC.entityName, remoteEC.entityId]); |     const localEC = sql.getRow(`SELECT * FROM entity_changes WHERE entityName = ? AND entityId = ?`, [remoteEC.entityName, remoteEC.entityId]); | ||||||
|  |  | ||||||
|     if (!localEC?.isErased && remoteEC.isErased) { |  | ||||||
|         eraseEntity(remoteEC, instanceId); |  | ||||||
|         updateContext.erased++; |  | ||||||
|  |  | ||||||
|         return true; |  | ||||||
|     } else if (localEC?.isErased && !remoteEC.isErased) { |  | ||||||
|         // on this side, we can't unerase the entity, so force the entity to be erased on the other side. |  | ||||||
|         entityChangesService.putEntityChangeForOtherInstances(localEC); |  | ||||||
|  |  | ||||||
|         return false; |  | ||||||
|     } else if (localEC?.isErased && remoteEC.isErased) { |  | ||||||
|         updateContext.alreadyErased++; |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (!localEC || localEC.utcDateChanged <= remoteEC.utcDateChanged) { |     if (!localEC || localEC.utcDateChanged <= remoteEC.utcDateChanged) { | ||||||
|         if (!remoteEntityRow) { |         if (remoteEC.isErased) { | ||||||
|             throw new Error(`Empty entity row for: ${JSON.stringify(remoteEC)}`); |             if (localEC?.isErased) { | ||||||
|         } |                 eraseEntity(remoteEC); // make sure it's erased anyway | ||||||
|  |                 updateContext.alreadyErased++; | ||||||
|         if (remoteEC.entityName === 'blobs' && remoteEntityRow.content !== null) { |                 return false; // we won't save entitychange in this case | ||||||
|             // we always use a Buffer object which is different from normal saving - there we use a simple string type for |             } else { | ||||||
|             // "string notes". The problem is that in general, it's not possible to detect whether a blob content |                 eraseEntity(remoteEC); | ||||||
|             // is string note or note (syncs can arrive out of order) |                 updateContext.erased++; | ||||||
|             remoteEntityRow.content = Buffer.from(remoteEntityRow.content, 'base64'); |  | ||||||
|  |  | ||||||
|             if (remoteEntityRow.content.byteLength === 0) { |  | ||||||
|                 // there seems to be a bug which causes empty buffer to be stored as NULL which is then picked up as inconsistency |  | ||||||
|                 // (possibly not a problem anymore with the newer better-sqlite3) |  | ||||||
|                 remoteEntityRow.content = ""; |  | ||||||
|             } |             } | ||||||
|  |         } else { | ||||||
|  |             if (!remoteEntityRow) { | ||||||
|  |                 throw new Error(`Empty entity row for: ${JSON.stringify(remoteEC)}`); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             preProcessContent(remoteEC, remoteEntityRow); | ||||||
|  |  | ||||||
|  |             sql.replace(remoteEC.entityName, remoteEntityRow); | ||||||
|  |  | ||||||
|  |             updateContext.updated[remoteEC.entityName] = updateContext.updated[remoteEC.entityName] || []; | ||||||
|  |             updateContext.updated[remoteEC.entityName].push(remoteEC.entityId); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         sql.replace(remoteEC.entityName, remoteEntityRow); |  | ||||||
|  |  | ||||||
|         updateContext.updated[remoteEC.entityName] = updateContext.updated[remoteEC.entityName] || []; |  | ||||||
|         updateContext.updated[remoteEC.entityName].push(remoteEC.entityId); |  | ||||||
|  |  | ||||||
|         if (!localEC || localEC.utcDateChanged < remoteEC.utcDateChanged || localEC.hash !== remoteEC.hash) { |         if (!localEC || localEC.utcDateChanged < remoteEC.utcDateChanged || localEC.hash !== remoteEC.hash) { | ||||||
|             entityChangesService.putEntityChangeWithInstanceId(remoteEC, instanceId); |             entityChangesService.putEntityChangeWithInstanceId(remoteEC, instanceId); | ||||||
|         } |         } | ||||||
| @@ -121,6 +106,21 @@ function updateNormalEntity(remoteEC, remoteEntityRow, instanceId, updateContext | |||||||
|     return false; |     return false; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | function preProcessContent(remoteEC, remoteEntityRow) { | ||||||
|  |     if (remoteEC.entityName === 'blobs' && remoteEntityRow.content !== null) { | ||||||
|  |         // we always use a Buffer object which is different from normal saving - there we use a simple string type for | ||||||
|  |         // "string notes". The problem is that in general, it's not possible to detect whether a blob content | ||||||
|  |         // is string note or note (syncs can arrive out of order) | ||||||
|  |         remoteEntityRow.content = Buffer.from(remoteEntityRow.content, 'base64'); | ||||||
|  |  | ||||||
|  |         if (remoteEntityRow.content.byteLength === 0) { | ||||||
|  |             // there seems to be a bug which causes empty buffer to be stored as NULL which is then picked up as inconsistency | ||||||
|  |             // (possibly not a problem anymore with the newer better-sqlite3) | ||||||
|  |             remoteEntityRow.content = ""; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| function updateNoteReordering(remoteEC, remoteEntityRow, instanceId) { | function updateNoteReordering(remoteEC, remoteEntityRow, instanceId) { | ||||||
|     if (!remoteEntityRow) { |     if (!remoteEntityRow) { | ||||||
|         throw new Error(`Empty note_reordering body for: ${JSON.stringify(remoteEC)}`); |         throw new Error(`Empty note_reordering body for: ${JSON.stringify(remoteEC)}`); | ||||||
| @@ -135,7 +135,7 @@ function updateNoteReordering(remoteEC, remoteEntityRow, instanceId) { | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
|  |  | ||||||
| function eraseEntity(entityChange, instanceId) { | function eraseEntity(entityChange) { | ||||||
|     const {entityName, entityId} = entityChange; |     const {entityName, entityId} = entityChange; | ||||||
|  |  | ||||||
|     const entityNames = [ |     const entityNames = [ | ||||||
| @@ -155,8 +155,6 @@ function eraseEntity(entityChange, instanceId) { | |||||||
|     const primaryKeyName = entityConstructor.getEntityFromEntityName(entityName).primaryKeyName; |     const primaryKeyName = entityConstructor.getEntityFromEntityName(entityName).primaryKeyName; | ||||||
|  |  | ||||||
|     sql.execute(`DELETE FROM ${entityName} WHERE ${primaryKeyName} = ?`, [entityId]); |     sql.execute(`DELETE FROM ${entityName} WHERE ${primaryKeyName} = ?`, [entityId]); | ||||||
|  |  | ||||||
|     entityChangesService.putEntityChangeWithInstanceId(entityChange, instanceId); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| function logUpdateContext(updateContext) { | function logUpdateContext(updateContext) { | ||||||
|   | |||||||
| @@ -24,7 +24,7 @@ function getContent(note) { | |||||||
|     } else if (note.type === 'code') { |     } else if (note.type === 'code') { | ||||||
|         renderCode(result); |         renderCode(result); | ||||||
|     } else if (note.type === 'mermaid') { |     } else if (note.type === 'mermaid') { | ||||||
|         renderMermaid(result); |         renderMermaid(result, note); | ||||||
|     } else if (note.type === 'image' || note.type === 'canvas') { |     } else if (note.type === 'image' || note.type === 'canvas') { | ||||||
|         renderImage(result, note); |         renderImage(result, note); | ||||||
|     } else if (note.type === 'file') { |     } else if (note.type === 'file') { | ||||||
| @@ -126,15 +126,14 @@ function renderCode(result) { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| function renderMermaid(result) { | function renderMermaid(result, note) { | ||||||
|     result.content = ` |     result.content = ` | ||||||
| <div class="mermaid">${escapeHtml(result.content)}</div> | <img src="api/images/${note.noteId}/${note.escapedTitle}?${note.utcDateModified}"> | ||||||
| <hr> | <hr> | ||||||
| <details> | <details> | ||||||
|     <summary>Chart source</summary> |     <summary>Chart source</summary> | ||||||
|     <pre>${escapeHtml(result.content)}</pre> |     <pre>${escapeHtml(result.content)}</pre> | ||||||
| </details>` | </details>` | ||||||
|     result.header += `<script src="../../${assetPath}/libraries/mermaid.min.js"></script>`; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| function renderImage(result, note) { | function renderImage(result, note) { | ||||||
|   | |||||||
| @@ -105,6 +105,27 @@ function checkNoteAccess(noteId, req, res) { | |||||||
|     return false; |     return false; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | function renderImageAttachment(image, res, attachmentName) { | ||||||
|  |     let svgString = '<svg/>' | ||||||
|  |     const attachment = image.getAttachmentByTitle(attachmentName); | ||||||
|  |  | ||||||
|  |     if (attachment) { | ||||||
|  |         svgString = attachment.getContent(); | ||||||
|  |     } else { | ||||||
|  |         // backwards compatibility, before attachments, the SVG was stored in the main note content as a separate key | ||||||
|  |         const contentSvg = image.getJsonContentSafely()?.svg; | ||||||
|  |  | ||||||
|  |         if (contentSvg) { | ||||||
|  |             svgString = contentSvg; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     const svg = svgString | ||||||
|  |     res.set('Content-Type', "image/svg+xml"); | ||||||
|  |     res.set("Cache-Control", "no-cache, no-store, must-revalidate"); | ||||||
|  |     res.send(svg); | ||||||
|  | } | ||||||
|  |  | ||||||
| function register(router) { | function register(router) { | ||||||
|     function renderNote(note, req, res) { |     function renderNote(note, req, res) { | ||||||
|         if (!note) { |         if (!note) { | ||||||
| @@ -209,37 +230,18 @@ function register(router) { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (!["image", "canvas"].includes(image.type)) { |         if (image.type === 'image') { | ||||||
|             return res.status(400) |  | ||||||
|                 .json({ message: "Requested note is not a shareable image" }); |  | ||||||
|         } else if (image.type === "canvas") { |  | ||||||
|             /** |  | ||||||
|              * special "image" type. the canvas is actually type application/json |  | ||||||
|              * to avoid bitrot and enable usage as referenced image the svg is included. |  | ||||||
|              */ |  | ||||||
|             let svgString = '<svg/>' |  | ||||||
|             const attachment = image.getAttachmentByTitle('canvas-export.svg'); |  | ||||||
|  |  | ||||||
|             if (attachment) { |  | ||||||
|                 svgString = attachment.getContent(); |  | ||||||
|             } else { |  | ||||||
|                 // backwards compatibility, before attachments, the SVG was stored in the main note content as a separate key |  | ||||||
|                 const contentSvg = image.getJsonContentSafely()?.svg; |  | ||||||
|  |  | ||||||
|                 if (contentSvg) { |  | ||||||
|                     svgString = contentSvg; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             const svg = svgString |  | ||||||
|             res.set('Content-Type', "image/svg+xml"); |  | ||||||
|             res.set("Cache-Control", "no-cache, no-store, must-revalidate"); |  | ||||||
|             res.send(svg); |  | ||||||
|         } else { |  | ||||||
|             // normal image |             // normal image | ||||||
|             res.set('Content-Type', image.mime); |             res.set('Content-Type', image.mime); | ||||||
|             addNoIndexHeader(image, res); |             addNoIndexHeader(image, res); | ||||||
|             res.send(image.getContent()); |             res.send(image.getContent()); | ||||||
|  |         } else if (image.type === "canvas") { | ||||||
|  |             renderImageAttachment(image, res, 'canvas-export.svg'); | ||||||
|  |         } else if (image.type === 'mermaid') { | ||||||
|  |             renderImageAttachment(image, res, 'mermaid-export.svg'); | ||||||
|  |         } else { | ||||||
|  |             return res.status(400) | ||||||
|  |                 .json({ message: "Requested note is not a shareable image" }); | ||||||
|         } |         } | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -68,8 +68,6 @@ | |||||||
|  |  | ||||||
|     // https://stackoverflow.com/a/73731646/944162 |     // https://stackoverflow.com/a/73731646/944162 | ||||||
|     function isMobile() { |     function isMobile() { | ||||||
|         if ('maxTouchPoints' in navigator) return navigator.maxTouchPoints > 0; |  | ||||||
|  |  | ||||||
|         const mQ = matchMedia?.('(pointer:coarse)'); |         const mQ = matchMedia?.('(pointer:coarse)'); | ||||||
|         if (mQ?.media === '(pointer:coarse)') return !!mQ.matches; |         if (mQ?.media === '(pointer:coarse)') return !!mQ.matches; | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user