kopia lustrzana https://github.com/miklobit/TiddlyWiki5
Beefed up <<slider>> macro to store state in a tiddler
Now the state of the slider is reflected in the text of a tiddlerprint-window-tiddler
rodzic
81219b1205
commit
8d4d168432
|
@ -8,32 +8,39 @@ title: js/macros/slider.js
|
||||||
"use strict";
|
"use strict";
|
||||||
|
|
||||||
var Renderer = require("../Renderer.js").Renderer,
|
var Renderer = require("../Renderer.js").Renderer,
|
||||||
|
Tiddler = require("../Tiddler.js").Tiddler,
|
||||||
utils = require("../Utils.js");
|
utils = require("../Utils.js");
|
||||||
|
|
||||||
exports.macro = {
|
exports.macro = {
|
||||||
name: "slider",
|
name: "slider",
|
||||||
types: ["text/html","text/plain"],
|
types: ["text/html","text/plain"],
|
||||||
params: {
|
params: {
|
||||||
name: {byPos: 0, type: "text", optional: false},
|
state: {byPos: 0, type: "text", optional: false},
|
||||||
targetTiddler: {byPos: 1, type: "tiddler", optional: false},
|
targetTiddler: {byPos: 1, type: "tiddler", optional: false},
|
||||||
label: {byPos: 2, type: "text", optional: false},
|
label: {byPos: 2, type: "text", optional: false},
|
||||||
tooltip: {byPos: 3, type: "text", optional: true}
|
tooltip: {byPos: 3, type: "text", optional: true}
|
||||||
},
|
},
|
||||||
events: {
|
events: {
|
||||||
click: function(event,macroNode) {
|
click: function(event,macroNode) {
|
||||||
var el = event.currentTarget.firstChild.firstChild.nextSibling;
|
var el = event.currentTarget.firstChild.firstChild.nextSibling,
|
||||||
el.style.display = el.style.display === "block" ? "none" : "block";
|
stateTiddler = macroNode.params.state ? macroNode.store.getTiddler(macroNode.params.state) : {text: ""},
|
||||||
|
isOpen = stateTiddler.text.trim() === "open";
|
||||||
|
macroNode.store.addTiddler(new Tiddler(stateTiddler,{text: isOpen ? "closed" : "open"}));
|
||||||
|
el.style.display = isOpen ? "none" : "block";
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
execute: function(macroNode,tiddler,store) {
|
execute: function(macroNode,tiddler,store) {
|
||||||
var target = macroNode.params.targetTiddler,
|
var stateTiddler = macroNode.params.state ? store.getTiddler(macroNode.params.state) : {text: ""},
|
||||||
|
isOpen = stateTiddler.text.trim() === "open",
|
||||||
|
target = macroNode.params.targetTiddler,
|
||||||
dependencies = {include: {}};
|
dependencies = {include: {}};
|
||||||
dependencies.include[target] = 1;
|
dependencies.include[target] = 1;
|
||||||
var content = Renderer.SliderNode(macroNode.params.name,
|
var content = Renderer.SliderNode(macroNode.params.state,
|
||||||
macroNode.params.label,
|
macroNode.params.label,
|
||||||
macroNode.params.tooltip,
|
macroNode.params.tooltip,
|
||||||
|
isOpen,
|
||||||
[
|
[
|
||||||
Renderer.MacroNode("tiddler",{target: target},null,dependencies,store)
|
Renderer.MacroNode("tiddler",{target: target},null,dependencies,store)
|
||||||
]);
|
]);
|
||||||
|
|
Ładowanie…
Reference in New Issue