mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-26 09:09:05 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			41 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Markdown
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Markdown
		
	
	
	
		
			Vendored
		
	
	
	
| # Scripting
 | ||
| Trilium supports creating <a class="reference-link" href="Note%20Types/Code.md">Code</a> notes, i.e. notes which allow you to store some programming code and highlight it. Special case is JavaScript code notes which can also be executed inside Trilium which can in conjunction with <a class="reference-link" href="Scripting/Script%20API.md">Script API</a> provide extra functionality.
 | ||
| 
 | ||
| ## Scripting
 | ||
| 
 | ||
| To go further I must explain basic architecture of Trilium - in its essence it is a classic web application - it has these two main components:
 | ||
| 
 | ||
| *   frontend running in the browser (using HTML, CSS, JavaScript) - this is mainly used to interact with the user, display notes etc.
 | ||
| *   backend running JavaScript code in node.js runtime - this is responsible for e.g. storing notes, encrypting them etc.
 | ||
| 
 | ||
| So we have frontend and backend, each with their own set of responsibilities, but their common feature is that they both run JavaScript code. Add to this the fact, that we're able to create JavaScript \[\[code notes\]\] and we're onto something.
 | ||
| 
 | ||
| ## Use cases
 | ||
| 
 | ||
| *   <a class="reference-link" href="Scripting/Examples/New%20Task%20launcher%20button.md">"New Task" launcher button</a>
 | ||
| 
 | ||
| ## Action handler
 | ||
| 
 | ||
| Saving the note to the database is backend's responsibility, so we immediately pass control to the backend and ask it to create a note. Once this is done, we show the newly created note so that the user can set the task title and maybe some attributes.
 | ||
| 
 | ||
| ## Script execution
 | ||
| 
 | ||
| So we have a script which will add the button to the toolbar. But how can we execute it? One possibility is to click on "play" icon (marked by red circle). The problem with this is that this UI change is time bound by Trilium runtime so when we restart Trilium, button won't be there.
 | ||
| 
 | ||
| We need to execute it every time Trilium starts up, but we probably don't want to have to manually click on play button on every start up.
 | ||
| 
 | ||
| The solution is marked by red circle at the bottom - this note has [label](Advanced%20Usage/Attributes.md) `#run=frontendStartup` - this is one of the "system" labels which Trilium understands. As you might guess, this will cause all such labeled script notes to be executed once Trilium frontend starts up.
 | ||
| 
 | ||
| (`#run=frontendStartup` does not work for [Mobile frontend](Installation%20%26%20Setup/Mobile%20Frontend.md) - if you want to have scripts running there, give the script `#run=mobileStartup` label)
 | ||
| 
 | ||
| ## More showcases
 | ||
| 
 | ||
| You can see more scripting with explanation in <a class="reference-link" href="Advanced%20Usage/Advanced%20Showcases.md">Advanced Showcases</a>.
 | ||
| 
 | ||
| ## Events
 | ||
| 
 | ||
| See <a class="reference-link" href="Scripting/Events.md">Events</a>.
 | ||
| 
 | ||
| ## Script API
 | ||
| 
 | ||
| See <a class="reference-link" href="Scripting/Script%20API.md">Script API</a>. | 
