trilium/docs/frontend_api/entities_attribute.js.html

120 lines
3.3 KiB
HTML
Raw Normal View History

2018-12-23 05:28:49 +08:00
<!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>
2020-10-01 04:48:30 +08:00
<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)
*/
2020-10-01 04:48:30 +08:00
class Attribute {
2021-04-17 04:57:37 +08:00
constructor(froca, row) {
this.froca = froca;
2020-02-02 18:44:08 +08:00
this.update(row);
}
update(row) {
/** @type {string} */
2018-12-23 05:28:49 +08:00
this.attributeId = row.attributeId;
/** @type {string} */
2018-12-23 05:28:49 +08:00
this.noteId = row.noteId;
/** @type {string} */
2018-12-23 05:28:49 +08:00
this.type = row.type;
/** @type {string} */
2018-12-23 05:28:49 +08:00
this.name = row.name;
/** @type {string} */
2018-12-23 05:28:49 +08:00
this.value = row.value;
/** @type {int} */
2018-12-23 05:28:49 +08:00
this.position = row.position;
/** @type {boolean} */
2020-10-01 04:48:30 +08:00
this.isInheritable = !!row.isInheritable;
2018-12-23 05:28:49 +08:00
}
/** @returns {NoteShort} */
2020-10-01 04:48:30 +08:00
getNote() {
2021-04-17 04:57:37 +08:00
return this.froca.notes[this.noteId];
2018-12-23 05:28:49 +08:00
}
2020-10-01 04:48:30 +08:00
get targetNoteId() { // alias
return this.type === 'relation' ? this.value : undefined;
}
get isAutoLink() {
return this.type === 'relation' &amp;&amp; ['internalLink', 'imageLink', 'relationMapLink', 'includeNoteLink'].includes(this.name);
2020-04-08 01:19:20 +08:00
}
2018-12-23 05:28:49 +08:00
get toString() {
2020-02-02 18:44:08 +08:00
return `Attribute(attributeId=${this.attributeId}, type=${this.type}, name=${this.name}, value=${this.value})`;
2018-12-23 05:28:49 +08:00
}
2020-10-01 04:48:30 +08:00
isDefinition() {
return this.type === 'label' &amp;&amp; (this.name.startsWith('label:') || this.name.startsWith('relation:'));
}
getDefinition() {
return promotedAttributeDefinitionParser.parse(this.value);
}
isDefinitionFor(attr) {
return this.type === 'label' &amp;&amp; this.name === `${attr.type}:${attr.name}`;
}
get dto() {
const dto = Object.assign({}, this);
2021-04-17 04:57:37 +08:00
delete dto.froca;
return dto;
}
2019-02-21 05:24:51 +08:00
}
2020-10-01 04:48:30 +08:00
export default Attribute;
</code></pre>
2018-12-23 05:28:49 +08:00
</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>
2018-12-23 05:28:49 +08:00
</nav>
<br class="clear">
<footer>
2022-04-16 06:17:32 +08:00
Documentation generated by <a href="https://github.com/jsdoc/jsdoc">JSDoc 3.6.10</a>
2018-12-23 05:28:49 +08:00
</footer>
<script> prettyPrint(); </script>
<script src="scripts/linenumber.js"> </script>
</body>
</html>