mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2025-10-24 12:17:39 +00:00
Add support for macro modules
Now JavaScript macros can be defined in "macro" modules
This commit is contained in:
44
core/modules/macros/makedatauri.js
Normal file
44
core/modules/macros/makedatauri.js
Normal file
@@ -0,0 +1,44 @@
|
||||
/*\
|
||||
title: $:/core/modules/macros/makedatauri.js
|
||||
type: application/javascript
|
||||
module-type: macro
|
||||
|
||||
Macro to convert the content of a tiddler to a data URI
|
||||
|
||||
<<makedatauri text:"Text to be converted" type:"text/vnd.tiddlywiki">>
|
||||
|
||||
\*/
|
||||
(function(){
|
||||
|
||||
/*jslint node: true, browser: true */
|
||||
/*global $tw: false */
|
||||
"use strict";
|
||||
|
||||
/*
|
||||
Information about this macro
|
||||
*/
|
||||
|
||||
exports.name = "makedatauri";
|
||||
|
||||
exports.params = [
|
||||
{name: "text"},
|
||||
{name: "type"}
|
||||
];
|
||||
|
||||
/*
|
||||
Run the macro
|
||||
*/
|
||||
exports.run = function(text,type) {
|
||||
type = type || "text/vnd.tiddlywiki";
|
||||
var typeInfo = $tw.config.contentTypeInfo[type] || $tw.config.contentTypeInfo["text/plain"],
|
||||
isBase64 = typeInfo.encoding === "base64",
|
||||
parts = [];
|
||||
parts.push("data:");
|
||||
parts.push(type);
|
||||
parts.push(isBase64 ? ";base64" : "");
|
||||
parts.push(",");
|
||||
parts.push(isBase64 ? text : encodeURIComponent(text));
|
||||
return parts.join("");
|
||||
};
|
||||
|
||||
})();
|
30
core/modules/macros/version.js
Normal file
30
core/modules/macros/version.js
Normal file
@@ -0,0 +1,30 @@
|
||||
/*\
|
||||
title: $:/core/modules/macros/version.js
|
||||
type: application/javascript
|
||||
module-type: macro
|
||||
|
||||
Macro to return the TiddlyWiki core version number
|
||||
|
||||
\*/
|
||||
(function(){
|
||||
|
||||
/*jslint node: true, browser: true */
|
||||
/*global $tw: false */
|
||||
"use strict";
|
||||
|
||||
/*
|
||||
Information about this macro
|
||||
*/
|
||||
|
||||
exports.name = "version";
|
||||
|
||||
exports.params = [];
|
||||
|
||||
/*
|
||||
Run the macro
|
||||
*/
|
||||
exports.run = function() {
|
||||
return $tw.version;
|
||||
};
|
||||
|
||||
})();
|
@@ -81,8 +81,9 @@ Widget.prototype.getVariable = function(name,actualParams,defaultValue) {
|
||||
while(node && !$tw.utils.hop(node.variables,name)) {
|
||||
node = node.parentWidget;
|
||||
}
|
||||
// If we get to the root then look for a macro module
|
||||
if(!node) {
|
||||
return defaultValue;
|
||||
return this.evaluateMacroModule(name,actualParams,defaultValue);
|
||||
}
|
||||
// Get the value
|
||||
var value = node.variables[name].value;
|
||||
@@ -129,6 +130,40 @@ Widget.prototype.substituteVariableReferences = function(text) {
|
||||
});
|
||||
};
|
||||
|
||||
Widget.prototype.evaluateMacroModule = function(name,actualParams,defaultValue) {
|
||||
if($tw.utils.hop($tw.macros,name)) {
|
||||
var macro = $tw.macros[name],
|
||||
args = [];
|
||||
var nextAnonParameter = 0, // Next candidate anonymous parameter in macro call
|
||||
paramInfo, paramValue;
|
||||
// Step through each of the parameters in the macro definition
|
||||
for(var p=0; p<macro.params.length; p++) {
|
||||
// Check if we've got a macro call parameter with the same name
|
||||
paramInfo = macro.params[p];
|
||||
paramValue = undefined;
|
||||
for(var m=0; m<actualParams.length; m++) {
|
||||
if(actualParams[m].name === paramInfo.name) {
|
||||
paramValue = actualParams[m].value;
|
||||
}
|
||||
}
|
||||
// If not, use the next available anonymous macro call parameter
|
||||
while(nextAnonParameter < actualParams.length && actualParams[nextAnonParameter].name) {
|
||||
nextAnonParameter++;
|
||||
}
|
||||
if(paramValue === undefined && nextAnonParameter < actualParams.length) {
|
||||
paramValue = actualParams[nextAnonParameter++].value;
|
||||
}
|
||||
// If we've still not got a value, use the default, if any
|
||||
paramValue = paramValue || paramInfo["default"] || "";
|
||||
// Save the parameter
|
||||
args.push(paramValue);
|
||||
}
|
||||
return macro.run.apply(null,args)
|
||||
} else {
|
||||
return defaultValue;
|
||||
}
|
||||
};
|
||||
|
||||
/*
|
||||
Set the value of a context variable
|
||||
name: name of the variable
|
||||
|
@@ -28,6 +28,7 @@ exports.startup = function() {
|
||||
$tw.modules.applyMethods("tiddlermethod",$tw.Tiddler.prototype);
|
||||
$tw.modules.applyMethods("wikimethod",$tw.Wiki.prototype);
|
||||
$tw.modules.applyMethods("tiddlerdeserializer",$tw.Wiki.tiddlerDeserializerModules);
|
||||
$tw.macros = $tw.modules.getModulesByTypeAsHashmap("macro");
|
||||
// Set up the parsers
|
||||
$tw.wiki.initParsers();
|
||||
// Set up the syncer object
|
||||
|
@@ -282,6 +282,21 @@ describe("Widget module", function() {
|
||||
expect(wrapper.innerHTML).toBe("<p>\n<div class='My something something, or other thing'>\nContent</div></p>");
|
||||
});
|
||||
|
||||
it("should deal with built-in macros", function() {
|
||||
var wiki = new $tw.Wiki();
|
||||
// Add some tiddlers
|
||||
wiki.addTiddlers([
|
||||
{title: "TiddlerOne", text: "Jolly Old World", type: "text/vnd.tiddlywiki"}
|
||||
]);
|
||||
// Construct the widget node
|
||||
var text = "\\define makelink(text,type)\n<a href=<<makedatauri text:\"$text$\" type:\"$type$\">>>My linky link</a>\n\\end\n\n<$macrocall $name=\"makelink\" text={{TiddlerOne}} type={{TiddlerOne!!type}}/>";
|
||||
var widgetNode = createWidgetNode(parseText(text,wiki),wiki);
|
||||
// Render the widget node to the DOM
|
||||
var wrapper = renderWidgetNode(widgetNode);
|
||||
// Test the rendering
|
||||
expect(wrapper.innerHTML).toBe("<p>\n<a href='data:text/vnd.tiddlywiki,Jolly%20Old%20World'>\nMy linky link</a></p>");
|
||||
});
|
||||
|
||||
it("should deal with the list widget", function() {
|
||||
var wiki = new $tw.Wiki();
|
||||
// Add some tiddlers
|
||||
|
40
readme.md
40
readme.md
@@ -128,8 +128,7 @@ The following commands are available:</p><div class='tw-list-frame'>
|
||||
<h3 class=''>
|
||||
<span class='tw-view-link'>
|
||||
<a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/LoadCommand.html'>
|
||||
LoadCommand</a></span></h3><div>
|
||||
<div class='tw-transclude'>
|
||||
LoadCommand</a></span></h3><div class='tw-transclude'>
|
||||
<p>
|
||||
Load tiddlers from 2.x.x <a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/TiddlyWiki.html'>
|
||||
TiddlyWiki</a> files (<code>
|
||||
@@ -137,22 +136,20 @@ TiddlyWiki</a> files (<code>
|
||||
.tiddler</code>, <code>
|
||||
.tid</code>, <code>
|
||||
.json</code> or other files </p><pre>
|
||||
--load <filepath></pre></div></div></div></div><div class='tw-list-element'>
|
||||
--load <filepath></pre></div></div></div><div class='tw-list-element'>
|
||||
<div class='tw-tiddler'>
|
||||
<h3 class=''>
|
||||
<span class='tw-view-link'>
|
||||
<a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/PasswordCommand.html'>
|
||||
PasswordCommand</a></span></h3><div>
|
||||
<div class='tw-transclude'>
|
||||
PasswordCommand</a></span></h3><div class='tw-transclude'>
|
||||
<p>
|
||||
Set a password for subsequent crypto operations</p><pre>
|
||||
--password <password></pre></div></div></div></div><div class='tw-list-element'>
|
||||
--password <password></pre></div></div></div><div class='tw-list-element'>
|
||||
<div class='tw-tiddler'>
|
||||
<h3 class=''>
|
||||
<span class='tw-view-link'>
|
||||
<a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/PrintCommand.html'>
|
||||
PrintCommand</a></span></h3><div>
|
||||
<div class='tw-transclude'>
|
||||
PrintCommand</a></span></h3><div class='tw-transclude'>
|
||||
<p>
|
||||
The <code>
|
||||
print</code> command outputs specified information. </p><h3 class=''>
|
||||
@@ -167,24 +164,22 @@ Print the titles of the system tiddlers in the wiki store </p><pre>
|
||||
--print system</pre><h3 class=''>
|
||||
print config</h3><p>
|
||||
Print the current core configuration </p><pre>
|
||||
--print config</pre></div></div></div></div><div class='tw-list-element'>
|
||||
--print config</pre></div></div></div><div class='tw-list-element'>
|
||||
<div class='tw-tiddler'>
|
||||
<h3 class=''>
|
||||
<span class='tw-view-link'>
|
||||
<a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/RenderTiddlerCommand.html'>
|
||||
RenderTiddlerCommand</a></span></h3><div>
|
||||
<div class='tw-transclude'>
|
||||
RenderTiddlerCommand</a></span></h3><div class='tw-transclude'>
|
||||
<p>
|
||||
Render an individual tiddler as a specified <a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/ContentType.html'>
|
||||
ContentType</a>, defaults to <code>
|
||||
text/html</code> and save it to the specified filename </p><pre>
|
||||
--rendertiddler <title> <filename> [<type>]</pre></div></div></div></div><div class='tw-list-element'>
|
||||
--rendertiddler <title> <filename> [<type>]</pre></div></div></div><div class='tw-list-element'>
|
||||
<div class='tw-tiddler'>
|
||||
<h3 class=''>
|
||||
<span class='tw-view-link'>
|
||||
<a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/RenderTiddlersCommand.html'>
|
||||
RenderTiddlersCommand</a></span></h3><div>
|
||||
<div class='tw-transclude'>
|
||||
RenderTiddlersCommand</a></span></h3><div class='tw-transclude'>
|
||||
<p>
|
||||
Render a set of tiddlers matching a filter to separate files of a specified <a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/ContentType.html'>
|
||||
ContentType</a> (defaults to <code>
|
||||
@@ -192,13 +187,12 @@ text/html</code>) and extension (defaults to <code>
|
||||
.html</code>).</p><pre>
|
||||
--rendertiddlers <filter> <template> <pathname> [<type>] [<extension>]</pre><p>
|
||||
For example:</p><pre>
|
||||
--rendertiddlers [!is[system]] $:/core/templates/static.tiddler.html ./static text/plain</pre></div></div></div></div><div class='tw-list-element'>
|
||||
--rendertiddlers [!is[system]] $:/core/templates/static.tiddler.html ./static text/plain</pre></div></div></div><div class='tw-list-element'>
|
||||
<div class='tw-tiddler'>
|
||||
<h3 class=''>
|
||||
<span class='tw-view-link'>
|
||||
<a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/ServerCommand.html'>
|
||||
ServerCommand</a></span></h3><div>
|
||||
<div class='tw-transclude'>
|
||||
ServerCommand</a></span></h3><div class='tw-transclude'>
|
||||
<p>
|
||||
The server built in to <a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/TiddlyWiki5.html'>
|
||||
TiddlyWiki5</a> is very simple. Although compatible with <a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/TiddlyWeb.html'>
|
||||
@@ -222,26 +216,24 @@ servetype</strong> - the content type with which the root tiddler should be serv
|
||||
<strong>
|
||||
username</strong> - the default username for signing edits</li></ul><p>
|
||||
For example:</p><pre>
|
||||
--server 8080 $:/core/tiddlywiki5.template.html text/plain text/html MyUserName</pre></div></div></div></div><div class='tw-list-element'>
|
||||
--server 8080 $:/core/tiddlywiki5.template.html text/plain text/html MyUserName</pre></div></div></div><div class='tw-list-element'>
|
||||
<div class='tw-tiddler'>
|
||||
<h3 class=''>
|
||||
<span class='tw-view-link'>
|
||||
<a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/VerboseCommand.html'>
|
||||
VerboseCommand</a></span></h3><div>
|
||||
<div class='tw-transclude'>
|
||||
VerboseCommand</a></span></h3><div class='tw-transclude'>
|
||||
<p>
|
||||
Triggers verbose output, useful for debugging </p><pre>
|
||||
--verbose</pre></div></div></div></div><div class='tw-list-element'>
|
||||
--verbose</pre></div></div></div><div class='tw-list-element'>
|
||||
<div class='tw-tiddler'>
|
||||
<h3 class=''>
|
||||
<span class='tw-view-link'>
|
||||
<a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/VersionCommand.html'>
|
||||
VersionCommand</a></span></h3><div>
|
||||
<div class='tw-transclude'>
|
||||
VersionCommand</a></span></h3><div class='tw-transclude'>
|
||||
<p>
|
||||
Displays the version number of <a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/TiddlyWiki.html'>
|
||||
TiddlyWiki</a>.</p><pre>
|
||||
--version</pre></div></div></div></div></div></div></div><p>
|
||||
--version</pre></div></div></div></div></div></div><p>
|
||||
<em>
|
||||
This readme file was automatically generated by <a class='tw-tiddlylink tw-tiddlylink-internal tw-tiddlylink-resolves' href='http://five.tiddlywiki.com/static/TiddlyWiki5.html'>
|
||||
TiddlyWiki5</a></em>
|
||||
|
Reference in New Issue
Block a user