mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-31 18:36:30 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			115 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| 
 | |
| const Entity = require('./entity');
 | |
| const repository = require('../services/repository');
 | |
| const dateUtils = require('../services/date_utils');
 | |
| const sql = require('../services/sql');
 | |
| 
 | |
| /**
 | |
|  * Attribute is key value pair owned by a note.
 | |
|  *
 | |
|  * @param {string} attributeId
 | |
|  * @param {string} noteId
 | |
|  * @param {string} type
 | |
|  * @param {string} name
 | |
|  * @param {string} value
 | |
|  * @param {int} position
 | |
|  * @param {boolean} isInheritable
 | |
|  * @param {boolean} isDeleted
 | |
|  * @param {string} dateCreated
 | |
|  * @param {string} dateModified
 | |
|  *
 | |
|  * @extends Entity
 | |
|  */
 | |
| class Attribute extends Entity {
 | |
|     static get entityName() { return "attributes"; }
 | |
|     static get primaryKeyName() { return "attributeId"; }
 | |
|     static get hashedProperties() { return ["attributeId", "noteId", "type", "name", "value", "isInheritable", "isDeleted", "dateCreated"]; }
 | |
| 
 | |
|     constructor(row) {
 | |
|         super(row);
 | |
| 
 | |
|         this.isInheritable = !!this.isInheritable;
 | |
| 
 | |
|         if (this.isDefinition()) {
 | |
|             try {
 | |
|                 this.value = JSON.parse(this.value);
 | |
|             }
 | |
|             catch (e) {
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @returns {Promise<Note|null>}
 | |
|      */
 | |
|     async getNote() {
 | |
|         if (!this.__note) {
 | |
|             this.__note = await repository.getEntity("SELECT * FROM notes WHERE noteId = ?", [this.noteId]);
 | |
|         }
 | |
| 
 | |
|         return this.__note;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @returns {Promise<Note|null>}
 | |
|      */
 | |
|     async getTargetNote() {
 | |
|         if (this.type !== 'relation') {
 | |
|             throw new Error(`Attribute ${this.attributeId} is not relation`);
 | |
|         }
 | |
| 
 | |
|         if (!this.value) {
 | |
|             return null;
 | |
|         }
 | |
| 
 | |
|         if (!this.__targetNote) {
 | |
|             this.__targetNote = await repository.getEntity("SELECT * FROM notes WHERE noteId = ?", [this.value]);
 | |
|         }
 | |
| 
 | |
|         return this.__targetNote;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @return {boolean}
 | |
|      */
 | |
|     isDefinition() {
 | |
|         return this.type === 'label-definition' || this.type === 'relation-definition';
 | |
|     }
 | |
| 
 | |
|     async beforeSaving() {
 | |
|         if (!this.value) {
 | |
|             // null value isn't allowed
 | |
|             this.value = "";
 | |
|         }
 | |
| 
 | |
|         if (this.position === undefined) {
 | |
|             this.position = 1 + await sql.getValue(`SELECT COALESCE(MAX(position), 0) FROM attributes WHERE noteId = ?`, [this.noteId]);
 | |
|         }
 | |
| 
 | |
|         if (!this.isInheritable) {
 | |
|             this.isInheritable = false;
 | |
|         }
 | |
| 
 | |
|         if (!this.isDeleted) {
 | |
|             this.isDeleted = false;
 | |
|         }
 | |
| 
 | |
|         if (!this.dateCreated) {
 | |
|             this.dateCreated = dateUtils.nowDate();
 | |
|         }
 | |
| 
 | |
|         super.beforeSaving();
 | |
| 
 | |
|         if (this.isChanged) {
 | |
|             this.dateModified = dateUtils.nowDate();
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     // cannot be static!
 | |
|     updatePojo(pojo) {
 | |
|         delete pojo.isOwned;
 | |
|     }
 | |
| }
 | |
| 
 | |
| module.exports = Attribute; |