mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2025-01-03 22:10:26 +00:00
b35544bf49
This solves the problem with extraneous double square brackets when using the filtered set widget.
97 lines
2.4 KiB
JavaScript
Executable File
97 lines
2.4 KiB
JavaScript
Executable File
/*\
|
|
title: $:/core/modules/widgets/set.js
|
|
type: application/javascript
|
|
module-type: widget
|
|
|
|
Set variable widget
|
|
|
|
\*/
|
|
(function(){
|
|
|
|
/*jslint node: true, browser: true */
|
|
/*global $tw: false */
|
|
"use strict";
|
|
|
|
var Widget = require("$:/core/modules/widgets/widget.js").widget;
|
|
|
|
var SetWidget = function(parseTreeNode,options) {
|
|
this.initialise(parseTreeNode,options);
|
|
};
|
|
|
|
/*
|
|
Inherit from the base widget class
|
|
*/
|
|
SetWidget.prototype = new Widget();
|
|
|
|
/*
|
|
Render this widget into the DOM
|
|
*/
|
|
SetWidget.prototype.render = function(parent,nextSibling) {
|
|
this.parentDomNode = parent;
|
|
this.computeAttributes();
|
|
this.execute();
|
|
this.renderChildren(parent,nextSibling);
|
|
};
|
|
|
|
/*
|
|
Compute the internal state of the widget
|
|
*/
|
|
SetWidget.prototype.execute = function() {
|
|
// Get our parameters
|
|
this.setName = this.getAttribute("name","currentTiddler");
|
|
this.setFilter = this.getAttribute("filter");
|
|
this.setSelect = this.getAttribute("select");
|
|
this.setValue = this.getAttribute("value");
|
|
this.setEmptyValue = this.getAttribute("emptyValue");
|
|
// Set context variable
|
|
this.setVariable(this.setName,this.getValue(),this.parseTreeNode.params);
|
|
// Construct the child widgets
|
|
this.makeChildWidgets();
|
|
};
|
|
|
|
/*
|
|
Get the value to be assigned
|
|
*/
|
|
SetWidget.prototype.getValue = function() {
|
|
var value = this.setValue;
|
|
if(this.setFilter) {
|
|
var results = this.wiki.filterTiddlers(this.setFilter,this);
|
|
if(!this.setValue) {
|
|
var select;
|
|
if(this.setSelect) {
|
|
select = parseInt(this.setSelect,10);
|
|
}
|
|
if(select !== undefined) {
|
|
value = results[select] || "";
|
|
} else {
|
|
value = $tw.utils.stringifyList(results);
|
|
}
|
|
}
|
|
if(results.length === 0 && this.setEmptyValue !== undefined) {
|
|
value = this.setEmptyValue;
|
|
}
|
|
} else if(!value && this.setEmptyValue) {
|
|
value = this.setEmptyValue;
|
|
}
|
|
return value;
|
|
};
|
|
|
|
/*
|
|
Selectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering
|
|
*/
|
|
SetWidget.prototype.refresh = function(changedTiddlers) {
|
|
var changedAttributes = this.computeAttributes();
|
|
if(changedAttributes.name || changedAttributes.filter || changedAttributes.select ||changedAttributes.value || changedAttributes.emptyValue ||
|
|
(this.setFilter && this.getValue() != this.variables[this.setName].value)) {
|
|
this.refreshSelf();
|
|
return true;
|
|
} else {
|
|
return this.refreshChildren(changedTiddlers);
|
|
}
|
|
};
|
|
|
|
exports.setvariable = SetWidget;
|
|
exports.set = SetWidget;
|
|
|
|
})();
|