<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <title>JSDoc: Source: entities/attribute.js</title> <script src="scripts/prettify/prettify.js"> </script> <script src="scripts/prettify/lang-css.js"> </script> <!--[if lt IE 9]> <script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script> <![endif]--> <link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css"> <link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css"> </head> <body> <div id="main"> <h1 class="page-title">Source: entities/attribute.js</h1> <section> <article> <pre class="prettyprint source linenums"><code>import promotedAttributeDefinitionParser from '../services/promoted_attribute_definition_parser.js'; /** * Attribute is an abstract concept which has two real uses - label (key - value pair) * and relation (representing named relationship between source and target note) */ class Attribute { constructor(froca, row) { this.froca = froca; this.update(row); } update(row) { /** @type {string} */ this.attributeId = row.attributeId; /** @type {string} */ this.noteId = row.noteId; /** @type {string} */ this.type = row.type; /** @type {string} */ this.name = row.name; /** @type {string} */ this.value = row.value; /** @type {int} */ this.position = row.position; /** @type {boolean} */ this.isInheritable = !!row.isInheritable; } /** @returns {NoteShort} */ getNote() { return this.froca.notes[this.noteId]; } get targetNoteId() { // alias return this.type === 'relation' ? this.value : undefined; } get isAutoLink() { return this.type === 'relation' && ['internalLink', 'imageLink', 'relationMapLink', 'includeNoteLink'].includes(this.name); } get toString() { return `Attribute(attributeId=${this.attributeId}, type=${this.type}, name=${this.name}, value=${this.value})`; } isDefinition() { return this.type === 'label' && (this.name.startsWith('label:') || this.name.startsWith('relation:')); } getDefinition() { return promotedAttributeDefinitionParser.parse(this.value); } isDefinitionFor(attr) { return this.type === 'label' && this.name === `${attr.type}:${attr.name}`; } get dto() { const dto = Object.assign({}, this); delete dto.froca; return dto; } } export default Attribute; </code></pre> </article> </section> </div> <nav> <h2><a href="index.html">Home</a></h2><h3>Classes</h3><ul><li><a href="Attribute.html">Attribute</a></li><li><a href="Branch.html">Branch</a></li><li><a href="FrontendScriptApi.html">FrontendScriptApi</a></li><li><a href="NoteComplement.html">NoteComplement</a></li><li><a href="NoteShort.html">NoteShort</a></li></ul><h3>Global</h3><ul><li><a href="global.html#doRenderBody">doRenderBody</a></li></ul> </nav> <br class="clear"> <footer> Documentation generated by <a href="https://github.com/jsdoc/jsdoc">JSDoc 3.6.10</a> </footer> <script> prettyPrint(); </script> <script src="scripts/linenumber.js"> </script> </body> </html>