mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2026-01-28 22:01:26 +00:00
Compare commits
4 Commits
barcode-re
...
google-ana
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
b187819a34 | ||
|
|
2b19bbac47 | ||
|
|
c0720d8fae | ||
|
|
f195bfa9f2 |
@@ -5,7 +5,7 @@
|
|||||||
# Default to the current version number for building the plugin library
|
# Default to the current version number for building the plugin library
|
||||||
|
|
||||||
if [ -z "$TW5_BUILD_VERSION" ]; then
|
if [ -z "$TW5_BUILD_VERSION" ]; then
|
||||||
TW5_BUILD_VERSION=v5.3.2
|
TW5_BUILD_VERSION=v5.3.0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Using TW5_BUILD_VERSION as [$TW5_BUILD_VERSION]"
|
echo "Using TW5_BUILD_VERSION as [$TW5_BUILD_VERSION]"
|
||||||
@@ -104,15 +104,13 @@ node $TW5_BUILD_TIDDLYWIKI \
|
|||||||
--build favicon static index \
|
--build favicon static index \
|
||||||
|| exit 1
|
|| exit 1
|
||||||
|
|
||||||
# /empty.html Empty
|
# /empty.html Empty
|
||||||
# /empty.hta For Internet Explorer
|
# /empty.hta For Internet Explorer
|
||||||
# /empty-external-core.html External core empty
|
|
||||||
# /tiddlywikicore-<version>.js Core plugin javascript
|
|
||||||
node $TW5_BUILD_TIDDLYWIKI \
|
node $TW5_BUILD_TIDDLYWIKI \
|
||||||
./editions/empty \
|
$TW5_BUILD_MAIN_EDITION \
|
||||||
--verbose \
|
--verbose \
|
||||||
--output $TW5_BUILD_OUTPUT \
|
--output $TW5_BUILD_OUTPUT \
|
||||||
--build empty emptyexternalcore \
|
--build empty \
|
||||||
|| exit 1
|
|| exit 1
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
13
boot/boot.js
13
boot/boot.js
@@ -575,8 +575,9 @@ var globalCheck =[
|
|||||||
" configurable: true",
|
" configurable: true",
|
||||||
" });",
|
" });",
|
||||||
" if(Object.keys(__temp__).length){",
|
" if(Object.keys(__temp__).length){",
|
||||||
" console.log(\"Warning: Global assignment detected\",Object.keys(__temp__));",
|
" console.log(Object.keys(__temp__));",
|
||||||
" delete Object.prototype.__temp__;",
|
" delete Object.prototype.__temp__;",
|
||||||
|
" throw \"Global assignment is not allowed within modules on node.\";",
|
||||||
" }",
|
" }",
|
||||||
" delete Object.prototype.__temp__;",
|
" delete Object.prototype.__temp__;",
|
||||||
].join('\n');
|
].join('\n');
|
||||||
@@ -595,11 +596,11 @@ $tw.utils.evalGlobal = function(code,context,filename,sandbox,allowGlobals) {
|
|||||||
// Add the code prologue and epilogue
|
// Add the code prologue and epilogue
|
||||||
code = [
|
code = [
|
||||||
"(function(" + contextNames.join(",") + ") {",
|
"(function(" + contextNames.join(",") + ") {",
|
||||||
" (function(){" + code + "\n;})();\n",
|
" (function(){\n" + code + "\n;})();",
|
||||||
(!$tw.browser && sandbox && !allowGlobals) ? globalCheck : "",
|
(!$tw.browser && sandbox && !allowGlobals) ? globalCheck : "",
|
||||||
"\nreturn exports;\n",
|
" return exports;\n",
|
||||||
"})"
|
"})"
|
||||||
].join("");
|
].join("\n");
|
||||||
|
|
||||||
// Compile the code into a function
|
// Compile the code into a function
|
||||||
var fn;
|
var fn;
|
||||||
@@ -925,7 +926,7 @@ $tw.modules.execute = function(moduleName,moduleRoot) {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// line number should be included in e.stack for runtime errors
|
// line number should be included in e.stack for runtime errors
|
||||||
$tw.utils.error("Error executing boot module " + name + ": " + String(e) + "\n\n" + e.stack);
|
$tw.utils.error("Error executing boot module " + name + ": " + JSON.stringify(e) + "\n\n" + e.stack);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1149,7 +1150,7 @@ $tw.Wiki = function(options) {
|
|||||||
shadowTiddlerTitles = null,
|
shadowTiddlerTitles = null,
|
||||||
getShadowTiddlerTitles = function() {
|
getShadowTiddlerTitles = function() {
|
||||||
if(!shadowTiddlerTitles) {
|
if(!shadowTiddlerTitles) {
|
||||||
shadowTiddlerTitles = Object.keys(shadowTiddlers).sort(function(a,b) {return a.localeCompare(b);});
|
shadowTiddlerTitles = Object.keys(shadowTiddlers);
|
||||||
}
|
}
|
||||||
return shadowTiddlerTitles;
|
return shadowTiddlerTitles;
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -1,4 +1,6 @@
|
|||||||
title: $:/core/images/new-journal-button
|
title: $:/core/images/new-journal-button
|
||||||
tags: $:/tags/Image
|
tags: $:/tags/Image
|
||||||
|
|
||||||
<$parameters size="22pt" day=<<now "DD">>><svg width=<<size>> height=<<size>> class="tc-image-new-journal-button tc-image-button" viewBox="0 0 128 128"><g fill-rule="evenodd"><path d="M102.545 112.818v11.818c0 1.306 1.086 2.364 2.425 2.364h6.06c1.34 0 2.425-1.058 2.425-2.364v-11.818h12.12c1.34 0 2.425-1.058 2.425-2.363v-5.91c0-1.305-1.085-2.363-2.424-2.363h-12.121V90.364c0-1.306-1.086-2.364-2.425-2.364h-6.06c-1.34 0-2.425 1.058-2.425 2.364v11.818h-12.12c-1.34 0-2.425 1.058-2.425 2.363v5.91c0 1.305 1.085 2.363 2.424 2.363h12.121zM60.016 4.965c-4.781-2.76-10.897-1.118-13.656 3.66L5.553 79.305A9.993 9.993 0 009.21 92.963l51.04 29.468c4.78 2.76 10.897 1.118 13.655-3.66l40.808-70.681a9.993 9.993 0 00-3.658-13.656L60.016 4.965zm-3.567 27.963a6 6 0 106-10.393 6 6 0 00-6 10.393zm31.697 17.928a6 6 0 106-10.392 6 6 0 00-6 10.392z"/><text class="tc-fill-background" font-family="Helvetica" font-size="47.172" font-weight="bold" transform="rotate(30 25.742 95.82)"><tspan x="42" y="77.485" text-anchor="middle"><$text text=<<day>>/></tspan></text></g></svg></$parameters>
|
<$parameters size="22pt" day=<<now "DD">>>
|
||||||
|
<svg width=<<size>> height=<<size>> class="tc-image-new-journal-button tc-image-button" viewBox="0 0 128 128"><g fill-rule="evenodd"><path d="M102.545 112.818v11.818c0 1.306 1.086 2.364 2.425 2.364h6.06c1.34 0 2.425-1.058 2.425-2.364v-11.818h12.12c1.34 0 2.425-1.058 2.425-2.363v-5.91c0-1.305-1.085-2.363-2.424-2.363h-12.121V90.364c0-1.306-1.086-2.364-2.425-2.364h-6.06c-1.34 0-2.425 1.058-2.425 2.364v11.818h-12.12c-1.34 0-2.425 1.058-2.425 2.363v5.91c0 1.305 1.085 2.363 2.424 2.363h12.121zM60.016 4.965c-4.781-2.76-10.897-1.118-13.656 3.66L5.553 79.305A9.993 9.993 0 009.21 92.963l51.04 29.468c4.78 2.76 10.897 1.118 13.655-3.66l40.808-70.681a9.993 9.993 0 00-3.658-13.656L60.016 4.965zm-3.567 27.963a6 6 0 106-10.393 6 6 0 00-6 10.393zm31.697 17.928a6 6 0 106-10.392 6 6 0 00-6 10.392z"/><text class="tc-fill-background" font-family="Helvetica" font-size="47.172" font-weight="bold" transform="rotate(30 25.742 95.82)"><tspan x="42" y="77.485" text-anchor="middle"><$text text=<<day>>/></tspan></text></g></svg>
|
||||||
|
</$parameters>
|
||||||
@@ -4,7 +4,7 @@ description: Saves a wiki to a new wiki folder
|
|||||||
<<.from-version "5.1.20">> Saves the current wiki as a wiki folder, including tiddlers, plugins and configuration:
|
<<.from-version "5.1.20">> Saves the current wiki as a wiki folder, including tiddlers, plugins and configuration:
|
||||||
|
|
||||||
```
|
```
|
||||||
--savewikifolder <wikifolderpath> [<filter>] [ [<name>=<value>] ]*
|
--savewikifolder <wikifolderpath> [<filter>]
|
||||||
```
|
```
|
||||||
|
|
||||||
* The target wiki folder must be empty or non-existent
|
* The target wiki folder must be empty or non-existent
|
||||||
@@ -12,23 +12,8 @@ description: Saves a wiki to a new wiki folder
|
|||||||
* Plugins from the official plugin library are replaced with references to those plugins in the `tiddlywiki.info` file
|
* Plugins from the official plugin library are replaced with references to those plugins in the `tiddlywiki.info` file
|
||||||
* Custom plugins are unpacked into their own folder
|
* Custom plugins are unpacked into their own folder
|
||||||
|
|
||||||
The following options are supported:
|
|
||||||
|
|
||||||
* ''filter'': a filter expression that defines the tiddlers to include in the output.
|
|
||||||
* ''explodePlugins'': defaults to "yes"
|
|
||||||
** ''yes'' will "explode" plugins into separate tiddler files and save them to the plugin directory within the wiki folder
|
|
||||||
** ''no'' will suppress exploding plugins into their constituent tiddler files. It will save the plugin as a single JSON tiddler in the tiddlers folder
|
|
||||||
|
|
||||||
Note that both ''explodePlugins'' options will produce wiki folders that build the same exact same original wiki. The difference lies in how plugins are represented in the wiki folder.
|
|
||||||
|
|
||||||
A common usage is to convert a TiddlyWiki HTML file into a wiki folder:
|
A common usage is to convert a TiddlyWiki HTML file into a wiki folder:
|
||||||
|
|
||||||
```
|
```
|
||||||
tiddlywiki --load ./mywiki.html --savewikifolder ./mywikifolder
|
tiddlywiki --load ./mywiki.html --savewikifolder ./mywikifolder
|
||||||
```
|
```
|
||||||
|
|
||||||
Save the plugin to the tiddlers directory of the target wiki folder:
|
|
||||||
|
|
||||||
```
|
|
||||||
tiddlywiki --load ./mywiki.html --savewikifolder ./mywikifolder explodePlugins=no
|
|
||||||
```
|
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
title: $:/language/Help/server
|
title: $:/language/Help/server
|
||||||
description: (deprecated: see 'listen' command) Provides an HTTP server interface to TiddlyWiki
|
description: Provides an HTTP server interface to TiddlyWiki (deprecated in favour of the new listen command)
|
||||||
|
|
||||||
Legacy command to serve a wiki over HTTP.
|
Legacy command to serve a wiki over HTTP.
|
||||||
|
|
||||||
|
|||||||
@@ -5,14 +5,7 @@ module-type: command
|
|||||||
|
|
||||||
Command to save the current wiki as a wiki folder
|
Command to save the current wiki as a wiki folder
|
||||||
|
|
||||||
--savewikifolder <wikifolderpath> [ [<name>=<value>] ]*
|
--savewikifolder <wikifolderpath> [<filter>]
|
||||||
|
|
||||||
The following options are supported:
|
|
||||||
|
|
||||||
* ''filter'': a filter expression defining the tiddlers to be included in the output
|
|
||||||
* ''explodePlugins'': set to "no" to suppress exploding plugins into their constituent shadow tiddlers (defaults to "yes")
|
|
||||||
|
|
||||||
Supports backward compatibility with --savewikifolder <wikifolderpath> [<filter>] [ [<name>=<value>] ]*
|
|
||||||
|
|
||||||
\*/
|
\*/
|
||||||
(function(){
|
(function(){
|
||||||
@@ -42,28 +35,14 @@ Command.prototype.execute = function() {
|
|||||||
if(this.params.length < 1) {
|
if(this.params.length < 1) {
|
||||||
return "Missing wiki folder path";
|
return "Missing wiki folder path";
|
||||||
}
|
}
|
||||||
var regFilter = /^[a-zA-Z0-9\.\-_]+=/g, // dynamic parameters
|
var wikifoldermaker = new WikiFolderMaker(this.params[0],this.params[1],this.commander);
|
||||||
namedParames,
|
|
||||||
tiddlerFilter,
|
|
||||||
options = {};
|
|
||||||
if (regFilter.test(this.params[1])) {
|
|
||||||
namedParames = this.commander.extractNamedParameters(this.params.slice(1));
|
|
||||||
tiddlerFilter = namedParames.filter || "[all[tiddlers]]";
|
|
||||||
} else {
|
|
||||||
namedParames = this.commander.extractNamedParameters(this.params.slice(2));
|
|
||||||
tiddlerFilter = this.params[1];
|
|
||||||
}
|
|
||||||
tiddlerFilter = tiddlerFilter || "[all[tiddlers]]";
|
|
||||||
options.explodePlugins = namedParames.explodePlugins || "yes";
|
|
||||||
var wikifoldermaker = new WikiFolderMaker(this.params[0],tiddlerFilter,this.commander,options);
|
|
||||||
return wikifoldermaker.save();
|
return wikifoldermaker.save();
|
||||||
};
|
};
|
||||||
|
|
||||||
function WikiFolderMaker(wikiFolderPath,wikiFilter,commander,options) {
|
function WikiFolderMaker(wikiFolderPath,wikiFilter,commander) {
|
||||||
this.wikiFolderPath = wikiFolderPath;
|
this.wikiFolderPath = wikiFolderPath;
|
||||||
this.wikiFilter = wikiFilter;
|
this.wikiFilter = wikiFilter || "[all[tiddlers]]";
|
||||||
this.commander = commander;
|
this.commander = commander;
|
||||||
this.explodePlugins = options.explodePlugins;
|
|
||||||
this.wiki = commander.wiki;
|
this.wiki = commander.wiki;
|
||||||
this.savedPaths = []; // So that we can detect filename clashes
|
this.savedPaths = []; // So that we can detect filename clashes
|
||||||
}
|
}
|
||||||
@@ -114,13 +93,10 @@ WikiFolderMaker.prototype.save = function() {
|
|||||||
self.log("Adding built-in plugin: " + libraryDetails.name);
|
self.log("Adding built-in plugin: " + libraryDetails.name);
|
||||||
newWikiInfo[libraryDetails.type] = newWikiInfo[libraryDetails.type] || [];
|
newWikiInfo[libraryDetails.type] = newWikiInfo[libraryDetails.type] || [];
|
||||||
$tw.utils.pushTop(newWikiInfo[libraryDetails.type],libraryDetails.name);
|
$tw.utils.pushTop(newWikiInfo[libraryDetails.type],libraryDetails.name);
|
||||||
} else if(self.explodePlugins !== "no") {
|
} else {
|
||||||
// A custom plugin
|
// A custom plugin
|
||||||
self.log("Processing custom plugin: " + title);
|
self.log("Processing custom plugin: " + title);
|
||||||
self.saveCustomPlugin(tiddler);
|
self.saveCustomPlugin(tiddler);
|
||||||
} else if(self.explodePlugins === "no") {
|
|
||||||
self.log("Processing custom plugin to tiddlders folder: " + title);
|
|
||||||
self.saveTiddler("tiddlers", tiddler);
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Ordinary tiddler
|
// Ordinary tiddler
|
||||||
|
|||||||
@@ -60,7 +60,7 @@ function FramedEngine(options) {
|
|||||||
this.domNode.value = this.value;
|
this.domNode.value = this.value;
|
||||||
}
|
}
|
||||||
// Set the attributes
|
// Set the attributes
|
||||||
if(this.widget.editType && this.widget.editTag !== "textarea") {
|
if(this.widget.editType) {
|
||||||
this.domNode.setAttribute("type",this.widget.editType);
|
this.domNode.setAttribute("type",this.widget.editType);
|
||||||
}
|
}
|
||||||
if(this.widget.editPlaceholder) {
|
if(this.widget.editPlaceholder) {
|
||||||
@@ -72,6 +72,9 @@ function FramedEngine(options) {
|
|||||||
if(this.widget.editRows) {
|
if(this.widget.editRows) {
|
||||||
this.domNode.setAttribute("rows",this.widget.editRows);
|
this.domNode.setAttribute("rows",this.widget.editRows);
|
||||||
}
|
}
|
||||||
|
if(this.widget.editDir) {
|
||||||
|
this.domNode.setAttribute("dir",this.widget.editDir);
|
||||||
|
}
|
||||||
if(this.widget.editTabIndex) {
|
if(this.widget.editTabIndex) {
|
||||||
this.iframeNode.setAttribute("tabindex",this.widget.editTabIndex);
|
this.iframeNode.setAttribute("tabindex",this.widget.editTabIndex);
|
||||||
}
|
}
|
||||||
@@ -120,6 +123,7 @@ FramedEngine.prototype.copyStyles = function() {
|
|||||||
this.domNode.style["-webkit-text-fill-color"] = "currentcolor";
|
this.domNode.style["-webkit-text-fill-color"] = "currentcolor";
|
||||||
// Ensure we don't force text direction to LTR
|
// Ensure we don't force text direction to LTR
|
||||||
this.domNode.style.removeProperty("direction");
|
this.domNode.style.removeProperty("direction");
|
||||||
|
this.domNode.style.removeProperty("unicodeBidi");
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|||||||
@@ -34,7 +34,7 @@ function SimpleEngine(options) {
|
|||||||
this.domNode.value = this.value;
|
this.domNode.value = this.value;
|
||||||
}
|
}
|
||||||
// Set the attributes
|
// Set the attributes
|
||||||
if(this.widget.editType && this.widget.editTag !== "textarea") {
|
if(this.widget.editType) {
|
||||||
this.domNode.setAttribute("type",this.widget.editType);
|
this.domNode.setAttribute("type",this.widget.editType);
|
||||||
}
|
}
|
||||||
if(this.widget.editPlaceholder) {
|
if(this.widget.editPlaceholder) {
|
||||||
@@ -52,6 +52,9 @@ function SimpleEngine(options) {
|
|||||||
if(this.widget.editTabIndex) {
|
if(this.widget.editTabIndex) {
|
||||||
this.domNode.setAttribute("tabindex",this.widget.editTabIndex);
|
this.domNode.setAttribute("tabindex",this.widget.editTabIndex);
|
||||||
}
|
}
|
||||||
|
if(this.widget.editDir) {
|
||||||
|
this.domNode.setAttribute("dir",this.widget.editDir);
|
||||||
|
}
|
||||||
if(this.widget.editAutoComplete) {
|
if(this.widget.editAutoComplete) {
|
||||||
this.domNode.setAttribute("autocomplete",this.widget.editAutoComplete);
|
this.domNode.setAttribute("autocomplete",this.widget.editAutoComplete);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -183,6 +183,7 @@ function editTextWidgetFactory(toolbarEngine,nonToolbarEngine) {
|
|||||||
this.editFocusSelectFromStart = $tw.utils.parseNumber(this.getAttribute("focusSelectFromStart","0"));
|
this.editFocusSelectFromStart = $tw.utils.parseNumber(this.getAttribute("focusSelectFromStart","0"));
|
||||||
this.editFocusSelectFromEnd = $tw.utils.parseNumber(this.getAttribute("focusSelectFromEnd","0"));
|
this.editFocusSelectFromEnd = $tw.utils.parseNumber(this.getAttribute("focusSelectFromEnd","0"));
|
||||||
this.editTabIndex = this.getAttribute("tabindex");
|
this.editTabIndex = this.getAttribute("tabindex");
|
||||||
|
this.editDir = this.getAttribute("dir");
|
||||||
this.editCancelPopups = this.getAttribute("cancelPopups","") === "yes";
|
this.editCancelPopups = this.getAttribute("cancelPopups","") === "yes";
|
||||||
this.editInputActions = this.getAttribute("inputActions");
|
this.editInputActions = this.getAttribute("inputActions");
|
||||||
this.editRefreshTitle = this.getAttribute("refreshTitle");
|
this.editRefreshTitle = this.getAttribute("refreshTitle");
|
||||||
@@ -220,7 +221,7 @@ function editTextWidgetFactory(toolbarEngine,nonToolbarEngine) {
|
|||||||
EditTextWidget.prototype.refresh = function(changedTiddlers) {
|
EditTextWidget.prototype.refresh = function(changedTiddlers) {
|
||||||
var changedAttributes = this.computeAttributes();
|
var changedAttributes = this.computeAttributes();
|
||||||
// Completely rerender if any of our attributes have changed
|
// Completely rerender if any of our attributes have changed
|
||||||
if(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || changedAttributes["default"] || changedAttributes["class"] || changedAttributes.placeholder || changedAttributes.size || changedAttributes.autoHeight || changedAttributes.minHeight || changedAttributes.focusPopup || changedAttributes.rows || changedAttributes.tabindex || changedAttributes.cancelPopups || changedAttributes.inputActions || changedAttributes.refreshTitle || changedAttributes.autocomplete || changedTiddlers[HEIGHT_MODE_TITLE] || changedTiddlers[ENABLE_TOOLBAR_TITLE] || changedTiddlers["$:/palette"] || changedAttributes.disabled || changedAttributes.fileDrop) {
|
if(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || changedAttributes["default"] || changedAttributes["class"] || changedAttributes.placeholder || changedAttributes.size || changedAttributes.autoHeight || changedAttributes.minHeight || changedAttributes.focusPopup || changedAttributes.rows || changedAttributes.tabindex || changedAttributes.dir || changedAttributes.cancelPopups || changedAttributes.inputActions || changedAttributes.refreshTitle || changedAttributes.autocomplete || changedTiddlers[HEIGHT_MODE_TITLE] || changedTiddlers[ENABLE_TOOLBAR_TITLE] || changedTiddlers["$:/palette"] || changedAttributes.disabled || changedAttributes.fileDrop) {
|
||||||
this.refreshSelf();
|
this.refreshSelf();
|
||||||
return true;
|
return true;
|
||||||
} else if (changedTiddlers[this.editRefreshTitle]) {
|
} else if (changedTiddlers[this.editRefreshTitle]) {
|
||||||
|
|||||||
@@ -1,32 +0,0 @@
|
|||||||
/*\
|
|
||||||
title: $:/core/modules/filterrunprefixes/then.js
|
|
||||||
type: application/javascript
|
|
||||||
module-type: filterrunprefix
|
|
||||||
|
|
||||||
Replace results of previous runs unless empty
|
|
||||||
|
|
||||||
\*/
|
|
||||||
(function(){
|
|
||||||
|
|
||||||
/*jslint node: true, browser: true */
|
|
||||||
/*global $tw: false */
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
/*
|
|
||||||
Export our filter prefix function
|
|
||||||
*/
|
|
||||||
exports.then = function(operationSubFunction) {
|
|
||||||
return function(results,source,widget) {
|
|
||||||
if(results.length !== 0) {
|
|
||||||
// Only run if previous run(s) produced results
|
|
||||||
var thisRunResult = operationSubFunction(source,widget);
|
|
||||||
if(thisRunResult.length !== 0) {
|
|
||||||
// Replace results only if this run actually produces a result
|
|
||||||
results.clear();
|
|
||||||
results.pushTop(thisRunResult);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
})();
|
|
||||||
@@ -1,36 +0,0 @@
|
|||||||
/*\
|
|
||||||
title: $:/core/modules/filters/substitute.js
|
|
||||||
type: application/javascript
|
|
||||||
module-type: filteroperator
|
|
||||||
|
|
||||||
Filter operator for substituting variables and embedded filter expressions with their corresponding values
|
|
||||||
|
|
||||||
\*/
|
|
||||||
(function(){
|
|
||||||
|
|
||||||
/*jslint node: true, browser: true */
|
|
||||||
/*global $tw: false */
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
/*
|
|
||||||
Export our filter function
|
|
||||||
*/
|
|
||||||
exports.substitute = function(source,operator,options) {
|
|
||||||
var results = [],
|
|
||||||
operands = [];
|
|
||||||
$tw.utils.each(operator.operands,function(operand,index){
|
|
||||||
operands.push({
|
|
||||||
name: (index + 1).toString(),
|
|
||||||
value: operand
|
|
||||||
});
|
|
||||||
});
|
|
||||||
source(function(tiddler,title) {
|
|
||||||
if(title) {
|
|
||||||
results.push(options.wiki.getSubstitutedText(title,options.widget,{substitutions:operands}));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return results;
|
|
||||||
};
|
|
||||||
|
|
||||||
})();
|
|
||||||
|
|
||||||
@@ -305,11 +305,10 @@ exports.parseAttribute = function(source,pos) {
|
|||||||
start: pos
|
start: pos
|
||||||
};
|
};
|
||||||
// Define our regexps
|
// Define our regexps
|
||||||
var reAttributeName = /([^\/\s>"'`=]+)/g,
|
var reAttributeName = /([^\/\s>"'=]+)/g,
|
||||||
reUnquotedAttribute = /([^\/\s<>"'`=]+)/g,
|
reUnquotedAttribute = /([^\/\s<>"'=]+)/g,
|
||||||
reFilteredValue = /\{\{\{([\S\s]+?)\}\}\}/g,
|
reFilteredValue = /\{\{\{([\S\s]+?)\}\}\}/g,
|
||||||
reIndirectValue = /\{\{([^\}]+)\}\}/g,
|
reIndirectValue = /\{\{([^\}]+)\}\}/g;
|
||||||
reSubstitutedValue = /(?:```([\s\S]*?)```|`([^`]|[\S\s]*?)`)/g;
|
|
||||||
// Skip whitespace
|
// Skip whitespace
|
||||||
pos = $tw.utils.skipWhiteSpace(source,pos);
|
pos = $tw.utils.skipWhiteSpace(source,pos);
|
||||||
// Get the attribute name
|
// Get the attribute name
|
||||||
@@ -362,15 +361,8 @@ exports.parseAttribute = function(source,pos) {
|
|||||||
node.type = "macro";
|
node.type = "macro";
|
||||||
node.value = macroInvocation;
|
node.value = macroInvocation;
|
||||||
} else {
|
} else {
|
||||||
var substitutedValue = $tw.utils.parseTokenRegExp(source,pos,reSubstitutedValue);
|
node.type = "string";
|
||||||
if(substitutedValue) {
|
node.value = "true";
|
||||||
pos = substitutedValue.end;
|
|
||||||
node.type = "substituted";
|
|
||||||
node.rawValue = substitutedValue.match[1] || substitutedValue.match[2];
|
|
||||||
} else {
|
|
||||||
node.type = "string";
|
|
||||||
node.value = "true";
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
51
core/modules/parsers/wikiparser/rules/dir.js
Normal file
51
core/modules/parsers/wikiparser/rules/dir.js
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
/*\
|
||||||
|
title: $:/core/modules/parsers/wikiparser/rules/dir.js
|
||||||
|
type: application/javascript
|
||||||
|
module-type: wikirule
|
||||||
|
|
||||||
|
Wiki pragma rule for specifying text direction
|
||||||
|
|
||||||
|
```
|
||||||
|
\dir rtl
|
||||||
|
\dir ltr
|
||||||
|
\dir auto
|
||||||
|
```
|
||||||
|
|
||||||
|
\*/
|
||||||
|
(function(){
|
||||||
|
|
||||||
|
/*jslint node: true, browser: true */
|
||||||
|
/*global $tw: false */
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
exports.name = "dir";
|
||||||
|
exports.types = {pragma: true};
|
||||||
|
|
||||||
|
/*
|
||||||
|
Instantiate parse rule
|
||||||
|
*/
|
||||||
|
exports.init = function(parser) {
|
||||||
|
this.parser = parser;
|
||||||
|
// Regexp to match
|
||||||
|
this.matchRegExp = /^\\dir[^\S\n]*(\S+)\r?\n/mg;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
Parse the most recent match
|
||||||
|
*/
|
||||||
|
exports.parse = function() {
|
||||||
|
var self = this;
|
||||||
|
// Move past the pragma invocation
|
||||||
|
this.parser.pos = this.matchRegExp.lastIndex;
|
||||||
|
// Parse tree nodes to return
|
||||||
|
return [{
|
||||||
|
type: "element",
|
||||||
|
tag: this.parser.parseAsInline ? "span" : "div",
|
||||||
|
attributes: {
|
||||||
|
dir: {type: "string", value: this.match[1]}
|
||||||
|
},
|
||||||
|
children: []
|
||||||
|
}];
|
||||||
|
};
|
||||||
|
|
||||||
|
})();
|
||||||
@@ -35,7 +35,7 @@ Instantiate parse rule
|
|||||||
exports.init = function(parser) {
|
exports.init = function(parser) {
|
||||||
this.parser = parser;
|
this.parser = parser;
|
||||||
// Regexp to match
|
// Regexp to match
|
||||||
this.matchRegExp = /\\(function|procedure|widget)\s+([^(\s]+)\((\s*([^)]*))?\)(\s*\r?\n)?/mg;
|
this.matchRegExp = /^\\(function|procedure|widget)\s+([^(\s]+)\((\s*([^)]*))?\)(\s*\r?\n)?/mg;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -53,7 +53,7 @@ exports.parse = function() {
|
|||||||
var reEnd;
|
var reEnd;
|
||||||
if(this.match[5]) {
|
if(this.match[5]) {
|
||||||
// If so, the end of the body is marked with \end
|
// If so, the end of the body is marked with \end
|
||||||
reEnd = new RegExp("(\\r?\\n[^\\S\\n\\r]*\\\\end[^\\S\\n\\r]*(?:" + $tw.utils.escapeRegExp(this.match[2]) + ")?(?:$|\\r?\\n))","mg");
|
reEnd = new RegExp("(\\r?\\n\\\\end[^\\S\\n\\r]*(?:" + $tw.utils.escapeRegExp(this.match[2]) + ")?(?:$|\\r?\\n))","mg");
|
||||||
} else {
|
} else {
|
||||||
// Otherwise, the end of the definition is marked by the end of the line
|
// Otherwise, the end of the definition is marked by the end of the line
|
||||||
reEnd = /($|\r?\n)/mg;
|
reEnd = /($|\r?\n)/mg;
|
||||||
|
|||||||
@@ -26,7 +26,7 @@ Instantiate parse rule
|
|||||||
exports.init = function(parser) {
|
exports.init = function(parser) {
|
||||||
this.parser = parser;
|
this.parser = parser;
|
||||||
// Regexp to match
|
// Regexp to match
|
||||||
this.matchRegExp = /\\parameters\s*\(([^)]*)\)(\s*\r?\n)?/mg;
|
this.matchRegExp = /^\\parameters\s*\(([^)]*)\)(\s*\r?\n)?/mg;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|||||||
@@ -36,6 +36,7 @@ options: see below:
|
|||||||
*/
|
*/
|
||||||
var WikiParser = function(type,text,options) {
|
var WikiParser = function(type,text,options) {
|
||||||
this.wiki = options.wiki;
|
this.wiki = options.wiki;
|
||||||
|
this.parseAsInline = options.parseAsInline;
|
||||||
var self = this;
|
var self = this;
|
||||||
// Check for an externally linked tiddler
|
// Check for an externally linked tiddler
|
||||||
if($tw.browser && (text || "") === "" && options._canonical_uri) {
|
if($tw.browser && (text || "") === "" && options._canonical_uri) {
|
||||||
|
|||||||
@@ -15,7 +15,6 @@ Startup logic concerned with managing plugins
|
|||||||
// Export name and synchronous status
|
// Export name and synchronous status
|
||||||
exports.name = "plugins";
|
exports.name = "plugins";
|
||||||
exports.after = ["load-modules"];
|
exports.after = ["load-modules"];
|
||||||
exports.before = ["startup"];
|
|
||||||
exports.synchronous = true;
|
exports.synchronous = true;
|
||||||
|
|
||||||
var TITLE_REQUIRE_RELOAD_DUE_TO_PLUGIN_CHANGE = "$:/status/RequireReloadDueToPluginChange";
|
var TITLE_REQUIRE_RELOAD_DUE_TO_PLUGIN_CHANGE = "$:/status/RequireReloadDueToPluginChange";
|
||||||
|
|||||||
@@ -38,7 +38,6 @@ exports.startup = function() {
|
|||||||
url: params.url,
|
url: params.url,
|
||||||
method: params.method,
|
method: params.method,
|
||||||
body: params.body,
|
body: params.body,
|
||||||
binary: params.binary,
|
|
||||||
oncompletion: params.oncompletion,
|
oncompletion: params.oncompletion,
|
||||||
onprogress: params.onprogress,
|
onprogress: params.onprogress,
|
||||||
bindStatus: params["bind-status"],
|
bindStatus: params["bind-status"],
|
||||||
|
|||||||
@@ -27,11 +27,6 @@ exports.startup = function() {
|
|||||||
if($tw.browser) {
|
if($tw.browser) {
|
||||||
$tw.browser.isIE = (/msie|trident/i.test(navigator.userAgent));
|
$tw.browser.isIE = (/msie|trident/i.test(navigator.userAgent));
|
||||||
$tw.browser.isFirefox = !!document.mozFullScreenEnabled;
|
$tw.browser.isFirefox = !!document.mozFullScreenEnabled;
|
||||||
// 2023-07-21 Edge returns UA below. So we use "isChromeLike"
|
|
||||||
//'mozilla/5.0 (windows nt 10.0; win64; x64) applewebkit/537.36 (khtml, like gecko) chrome/114.0.0.0 safari/537.36 edg/114.0.1823.82'
|
|
||||||
$tw.browser.isChromeLike = navigator.userAgent.toLowerCase().indexOf("chrome") > -1;
|
|
||||||
$tw.browser.hasTouch = !!window.matchMedia && window.matchMedia("(pointer: coarse)").matches;
|
|
||||||
$tw.browser.isMobileChrome = $tw.browser.isChromeLike && $tw.browser.hasTouch;
|
|
||||||
}
|
}
|
||||||
// Platform detection
|
// Platform detection
|
||||||
$tw.platform = {};
|
$tw.platform = {};
|
||||||
|
|||||||
@@ -80,7 +80,7 @@ exports.makeDraggable = function(options) {
|
|||||||
if(dataTransfer.setDragImage) {
|
if(dataTransfer.setDragImage) {
|
||||||
if(dragImageType === "pill") {
|
if(dragImageType === "pill") {
|
||||||
dataTransfer.setDragImage(dragImage.firstChild,-16,-16);
|
dataTransfer.setDragImage(dragImage.firstChild,-16,-16);
|
||||||
} else if(dragImageType === "blank") {
|
} else if (dragImageType === "blank") {
|
||||||
dragImage.removeChild(dragImage.firstChild);
|
dragImage.removeChild(dragImage.firstChild);
|
||||||
dataTransfer.setDragImage(dragImage,0,0);
|
dataTransfer.setDragImage(dragImage,0,0);
|
||||||
} else {
|
} else {
|
||||||
@@ -106,9 +106,7 @@ exports.makeDraggable = function(options) {
|
|||||||
dataTransfer.setData("text/vnd.tiddler",jsonData);
|
dataTransfer.setData("text/vnd.tiddler",jsonData);
|
||||||
dataTransfer.setData("text/plain",titleString);
|
dataTransfer.setData("text/plain",titleString);
|
||||||
dataTransfer.setData("text/x-moz-url","data:text/vnd.tiddler," + encodeURIComponent(jsonData));
|
dataTransfer.setData("text/x-moz-url","data:text/vnd.tiddler," + encodeURIComponent(jsonData));
|
||||||
}
|
} else {
|
||||||
// If browser is Chrome-like and has a touch-input device do NOT .setData
|
|
||||||
if(!($tw.browser.isMobileChrome)) {
|
|
||||||
dataTransfer.setData("URL","data:text/vnd.tiddler," + encodeURIComponent(jsonData));
|
dataTransfer.setData("URL","data:text/vnd.tiddler," + encodeURIComponent(jsonData));
|
||||||
}
|
}
|
||||||
dataTransfer.setData("Text",titleString);
|
dataTransfer.setData("Text",titleString);
|
||||||
|
|||||||
@@ -90,7 +90,6 @@ wiki: wiki to be used for executing action strings
|
|||||||
url: URL for request
|
url: URL for request
|
||||||
method: method eg GET, POST
|
method: method eg GET, POST
|
||||||
body: text of request body
|
body: text of request body
|
||||||
binary: set to "yes" to force binary processing of response payload
|
|
||||||
oncompletion: action string to be invoked on completion
|
oncompletion: action string to be invoked on completion
|
||||||
onprogress: action string to be invoked on progress updates
|
onprogress: action string to be invoked on progress updates
|
||||||
bindStatus: optional title of tiddler to which status ("pending", "complete", "error") should be written
|
bindStatus: optional title of tiddler to which status ("pending", "complete", "error") should be written
|
||||||
@@ -107,11 +106,10 @@ function HttpClientRequest(options) {
|
|||||||
this.wiki = options.wiki;
|
this.wiki = options.wiki;
|
||||||
this.completionActions = options.oncompletion;
|
this.completionActions = options.oncompletion;
|
||||||
this.progressActions = options.onprogress;
|
this.progressActions = options.onprogress;
|
||||||
this.bindStatus = options["bindStatus"];
|
this.bindStatus = options["bind-status"];
|
||||||
this.bindProgress = options["bindProgress"];
|
this.bindProgress = options["bind-progress"];
|
||||||
this.method = options.method || "GET";
|
this.method = options.method || "GET";
|
||||||
this.body = options.body || "";
|
this.body = options.body || "";
|
||||||
this.binary = options.binary || "";
|
|
||||||
this.variables = options.variables;
|
this.variables = options.variables;
|
||||||
var url = options.url;
|
var url = options.url;
|
||||||
$tw.utils.each(options.queryStrings,function(value,name) {
|
$tw.utils.each(options.queryStrings,function(value,name) {
|
||||||
@@ -134,7 +132,7 @@ HttpClientRequest.prototype.send = function(callback) {
|
|||||||
var self = this,
|
var self = this,
|
||||||
setBinding = function(title,text) {
|
setBinding = function(title,text) {
|
||||||
if(title) {
|
if(title) {
|
||||||
self.wiki.addTiddler(new $tw.Tiddler({title: title, text: text}));
|
this.wiki.addTiddler(new $tw.Tiddler({title: title, text: text}));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
if(this.url) {
|
if(this.url) {
|
||||||
@@ -158,8 +156,6 @@ HttpClientRequest.prototype.send = function(callback) {
|
|||||||
type: this.method,
|
type: this.method,
|
||||||
headers: this.requestHeaders,
|
headers: this.requestHeaders,
|
||||||
data: this.body,
|
data: this.body,
|
||||||
returnProp: this.binary === "" ? "responseText" : "response",
|
|
||||||
responseType: this.binary === "" ? "text" : "arraybuffer",
|
|
||||||
callback: function(err,data,xhr) {
|
callback: function(err,data,xhr) {
|
||||||
var hasSucceeded = xhr.status >= 200 && xhr.status < 300,
|
var hasSucceeded = xhr.status >= 200 && xhr.status < 300,
|
||||||
completionCode = hasSucceeded ? "complete" : "error",
|
completionCode = hasSucceeded ? "complete" : "error",
|
||||||
@@ -179,16 +175,6 @@ HttpClientRequest.prototype.send = function(callback) {
|
|||||||
data: (data || "").toString(),
|
data: (data || "").toString(),
|
||||||
headers: JSON.stringify(headers)
|
headers: JSON.stringify(headers)
|
||||||
};
|
};
|
||||||
/* Convert data from binary to base64 */
|
|
||||||
if (xhr.responseType === "arraybuffer") {
|
|
||||||
var binary = "",
|
|
||||||
bytes = new Uint8Array(data),
|
|
||||||
len = bytes.byteLength;
|
|
||||||
for (var i=0; i<len; i++) {
|
|
||||||
binary += String.fromCharCode(bytes[i]);
|
|
||||||
}
|
|
||||||
resultVariables.data = window.btoa(binary);
|
|
||||||
}
|
|
||||||
self.wiki.addTiddler(new $tw.Tiddler(self.wiki.getTiddler(requestTrackerTitle),{
|
self.wiki.addTiddler(new $tw.Tiddler(self.wiki.getTiddler(requestTrackerTitle),{
|
||||||
status: completionCode,
|
status: completionCode,
|
||||||
}));
|
}));
|
||||||
@@ -226,7 +212,6 @@ Make an HTTP request. Options are:
|
|||||||
callback: function invoked with (err,data,xhr)
|
callback: function invoked with (err,data,xhr)
|
||||||
progress: optional function invoked with (lengthComputable,loaded,total)
|
progress: optional function invoked with (lengthComputable,loaded,total)
|
||||||
returnProp: string name of the property to return as first argument of callback
|
returnProp: string name of the property to return as first argument of callback
|
||||||
responseType: "text" or "arraybuffer"
|
|
||||||
*/
|
*/
|
||||||
exports.httpRequest = function(options) {
|
exports.httpRequest = function(options) {
|
||||||
var type = options.type || "GET",
|
var type = options.type || "GET",
|
||||||
@@ -279,7 +264,6 @@ exports.httpRequest = function(options) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
request.responseType = options.responseType || "text";
|
|
||||||
// Set up the state change handler
|
// Set up the state change handler
|
||||||
request.onreadystatechange = function() {
|
request.onreadystatechange = function() {
|
||||||
if(this.readyState === 4) {
|
if(this.readyState === 4) {
|
||||||
|
|||||||
@@ -116,7 +116,7 @@ CheckboxWidget.prototype.getValue = function() {
|
|||||||
} else {
|
} else {
|
||||||
list = $tw.utils.parseStringArray(this.checkboxDefault || "") || [];
|
list = $tw.utils.parseStringArray(this.checkboxDefault || "") || [];
|
||||||
}
|
}
|
||||||
} else if(this.checkboxListIndex) {
|
} else if (this.checkboxListIndex) {
|
||||||
list = $tw.utils.parseStringArray(this.wiki.extractTiddlerDataItem(tiddler,this.checkboxListIndex,this.checkboxDefault || "")) || [];
|
list = $tw.utils.parseStringArray(this.wiki.extractTiddlerDataItem(tiddler,this.checkboxListIndex,this.checkboxDefault || "")) || [];
|
||||||
} else {
|
} else {
|
||||||
list = this.wiki.filterTiddlers(this.checkboxFilter,this) || [];
|
list = this.wiki.filterTiddlers(this.checkboxFilter,this) || [];
|
||||||
@@ -215,8 +215,6 @@ CheckboxWidget.prototype.handleChangeEvent = function(event) {
|
|||||||
if($tw.utils.isArray(fieldContents)) {
|
if($tw.utils.isArray(fieldContents)) {
|
||||||
// Make a copy so we can modify it without changing original that's refrenced elsewhere
|
// Make a copy so we can modify it without changing original that's refrenced elsewhere
|
||||||
listContents = fieldContents.slice(0);
|
listContents = fieldContents.slice(0);
|
||||||
} else if(fieldContents === undefined) {
|
|
||||||
listContents = [];
|
|
||||||
} else if(typeof fieldContents === "string") {
|
} else if(typeof fieldContents === "string") {
|
||||||
listContents = $tw.utils.parseStringArray(fieldContents);
|
listContents = $tw.utils.parseStringArray(fieldContents);
|
||||||
// No need to copy since parseStringArray returns a fresh array, not refrenced elsewhere
|
// No need to copy since parseStringArray returns a fresh array, not refrenced elsewhere
|
||||||
|
|||||||
@@ -48,6 +48,7 @@ EditWidget.prototype.execute = function() {
|
|||||||
this.editPlaceholder = this.getAttribute("placeholder");
|
this.editPlaceholder = this.getAttribute("placeholder");
|
||||||
this.editTabIndex = this.getAttribute("tabindex");
|
this.editTabIndex = this.getAttribute("tabindex");
|
||||||
this.editFocus = this.getAttribute("focus","");
|
this.editFocus = this.getAttribute("focus","");
|
||||||
|
this.editDir = this.getAttribute("dir");
|
||||||
this.editCancelPopups = this.getAttribute("cancelPopups","");
|
this.editCancelPopups = this.getAttribute("cancelPopups","");
|
||||||
this.editInputActions = this.getAttribute("inputActions");
|
this.editInputActions = this.getAttribute("inputActions");
|
||||||
this.editRefreshTitle = this.getAttribute("refreshTitle");
|
this.editRefreshTitle = this.getAttribute("refreshTitle");
|
||||||
@@ -90,7 +91,7 @@ Selectively refreshes the widget if needed. Returns true if the widget or any of
|
|||||||
EditWidget.prototype.refresh = function(changedTiddlers) {
|
EditWidget.prototype.refresh = function(changedTiddlers) {
|
||||||
var changedAttributes = this.computeAttributes();
|
var changedAttributes = this.computeAttributes();
|
||||||
// Refresh if an attribute has changed, or the type associated with the target tiddler has changed
|
// Refresh if an attribute has changed, or the type associated with the target tiddler has changed
|
||||||
if(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || changedAttributes.tabindex || changedAttributes.cancelPopups || changedAttributes.inputActions || changedAttributes.refreshTitle || changedAttributes.autocomplete || (changedTiddlers[this.editTitle] && this.getEditorType() !== this.editorType)) {
|
if(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || changedAttributes.tabindex || changedAttributes.dir || changedAttributes.cancelPopups || changedAttributes.inputActions || changedAttributes.refreshTitle || changedAttributes.autocomplete || (changedTiddlers[this.editTitle] && this.getEditorType() !== this.editorType)) {
|
||||||
this.refreshSelf();
|
this.refreshSelf();
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -49,7 +49,7 @@ ImportVariablesWidget.prototype.execute = function(tiddlerList) {
|
|||||||
this.tiddlerList = tiddlerList || this.wiki.filterTiddlers(this.filter,this);
|
this.tiddlerList = tiddlerList || this.wiki.filterTiddlers(this.filter,this);
|
||||||
// Accumulate the <$set> widgets from each tiddler
|
// Accumulate the <$set> widgets from each tiddler
|
||||||
$tw.utils.each(this.tiddlerList,function(title) {
|
$tw.utils.each(this.tiddlerList,function(title) {
|
||||||
var parser = widgetPointer.wiki.parseTiddler(title,{parseAsInline:true, configTrimWhiteSpace:true});
|
var parser = widgetPointer.wiki.parseTiddler(title,{parseAsInline:true});
|
||||||
if(parser) {
|
if(parser) {
|
||||||
var parseTreeNode = parser.tree[0];
|
var parseTreeNode = parser.tree[0];
|
||||||
while(parseTreeNode && ["setvariable","set","parameters"].indexOf(parseTreeNode.type) !== -1) {
|
while(parseTreeNode && ["setvariable","set","parameters"].indexOf(parseTreeNode.type) !== -1) {
|
||||||
|
|||||||
@@ -42,6 +42,9 @@ RevealWidget.prototype.render = function(parent,nextSibling) {
|
|||||||
if(this.style) {
|
if(this.style) {
|
||||||
domNode.setAttribute("style",this.style);
|
domNode.setAttribute("style",this.style);
|
||||||
}
|
}
|
||||||
|
if(this.direction) {
|
||||||
|
domNode.setAttribute("dir",this.direction);
|
||||||
|
}
|
||||||
parent.insertBefore(domNode,nextSibling);
|
parent.insertBefore(domNode,nextSibling);
|
||||||
this.renderChildren(domNode,null);
|
this.renderChildren(domNode,null);
|
||||||
if(!domNode.isTiddlyWikiFakeDom && this.type === "popup" && this.isOpen) {
|
if(!domNode.isTiddlyWikiFakeDom && this.type === "popup" && this.isOpen) {
|
||||||
@@ -123,6 +126,7 @@ RevealWidget.prototype.execute = function() {
|
|||||||
this["default"] = this.getAttribute("default","");
|
this["default"] = this.getAttribute("default","");
|
||||||
this.animate = this.getAttribute("animate","no");
|
this.animate = this.getAttribute("animate","no");
|
||||||
this.retain = this.getAttribute("retain","no");
|
this.retain = this.getAttribute("retain","no");
|
||||||
|
this.direction = this.getAttribute("dir");
|
||||||
this.openAnimation = this.animate === "no" ? undefined : "open";
|
this.openAnimation = this.animate === "no" ? undefined : "open";
|
||||||
this.closeAnimation = this.animate === "no" ? undefined : "close";
|
this.closeAnimation = this.animate === "no" ? undefined : "close";
|
||||||
this.updatePopupPosition = this.getAttribute("updatePopupPosition","no") === "yes";
|
this.updatePopupPosition = this.getAttribute("updatePopupPosition","no") === "yes";
|
||||||
@@ -214,7 +218,7 @@ Selectively refreshes the widget if needed. Returns true if the widget or any of
|
|||||||
*/
|
*/
|
||||||
RevealWidget.prototype.refresh = function(changedTiddlers) {
|
RevealWidget.prototype.refresh = function(changedTiddlers) {
|
||||||
var changedAttributes = this.computeAttributes();
|
var changedAttributes = this.computeAttributes();
|
||||||
if(changedAttributes.state || changedAttributes.type || changedAttributes.text || changedAttributes.position || changedAttributes.positionAllowNegative || changedAttributes["default"] || changedAttributes.animate || changedAttributes.stateTitle || changedAttributes.stateField || changedAttributes.stateIndex) {
|
if(changedAttributes.state || changedAttributes.type || changedAttributes.text || changedAttributes.position || changedAttributes.positionAllowNegative || changedAttributes["default"] || changedAttributes.animate || changedAttributes.stateTitle || changedAttributes.stateField || changedAttributes.stateIndex || changedAttributes.dir) {
|
||||||
this.refreshSelf();
|
this.refreshSelf();
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -145,7 +145,6 @@ SelectWidget.prototype.execute = function() {
|
|||||||
this.selectDefault = this.getAttribute("default");
|
this.selectDefault = this.getAttribute("default");
|
||||||
this.selectMultiple = this.getAttribute("multiple", false);
|
this.selectMultiple = this.getAttribute("multiple", false);
|
||||||
this.selectSize = this.getAttribute("size");
|
this.selectSize = this.getAttribute("size");
|
||||||
this.selectTabindex = this.getAttribute("tabindex");
|
|
||||||
this.selectTooltip = this.getAttribute("tooltip");
|
this.selectTooltip = this.getAttribute("tooltip");
|
||||||
this.selectFocus = this.getAttribute("focus");
|
this.selectFocus = this.getAttribute("focus");
|
||||||
// Make the child widgets
|
// Make the child widgets
|
||||||
@@ -163,9 +162,6 @@ SelectWidget.prototype.execute = function() {
|
|||||||
if(this.selectSize) {
|
if(this.selectSize) {
|
||||||
$tw.utils.addAttributeToParseTreeNode(selectNode,"size",this.selectSize);
|
$tw.utils.addAttributeToParseTreeNode(selectNode,"size",this.selectSize);
|
||||||
}
|
}
|
||||||
if(this.selectTabindex) {
|
|
||||||
$tw.utils.addAttributeToParseTreeNode(selectNode,"tabindex",this.selectTabindex);
|
|
||||||
}
|
|
||||||
if(this.selectTooltip) {
|
if(this.selectTooltip) {
|
||||||
$tw.utils.addAttributeToParseTreeNode(selectNode,"title",this.selectTooltip);
|
$tw.utils.addAttributeToParseTreeNode(selectNode,"title",this.selectTooltip);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -41,43 +41,27 @@ TranscludeWidget.prototype.execute = function() {
|
|||||||
this.collectAttributes();
|
this.collectAttributes();
|
||||||
this.collectStringParameters();
|
this.collectStringParameters();
|
||||||
this.collectSlotFillParameters();
|
this.collectSlotFillParameters();
|
||||||
// Determine whether we're being used in inline or block mode
|
// Get the parse tree nodes that we are transcluding
|
||||||
var parseAsInline = !this.parseTreeNode.isBlock;
|
var target = this.getTransclusionTarget(),
|
||||||
if(this.transcludeMode === "inline") {
|
parseTreeNodes = target.parseTreeNodes;
|
||||||
parseAsInline = true;
|
this.sourceText = target.text;
|
||||||
} else if(this.transcludeMode === "block") {
|
this.parserType = target.type;
|
||||||
parseAsInline = false;
|
this.parseAsInline = target.parseAsInline;
|
||||||
}
|
|
||||||
// Set 'thisTiddler'
|
|
||||||
this.setVariable("thisTiddler",this.transcludeTitle);
|
|
||||||
var parseTreeNodes, target;
|
|
||||||
// Process the transclusion according to the output type
|
// Process the transclusion according to the output type
|
||||||
switch(this.transcludeOutput || "text/html") {
|
switch(this.transcludeOutput || "text/html") {
|
||||||
case "text/html":
|
case "text/html":
|
||||||
// Return the parse tree nodes of the target
|
// No further processing required
|
||||||
target = this.parseTransclusionTarget(parseAsInline);
|
|
||||||
this.parseAsInline = target.parseAsInline;
|
|
||||||
parseTreeNodes = target.parseTreeNodes;
|
|
||||||
break;
|
break;
|
||||||
case "text/raw":
|
case "text/raw":
|
||||||
// Just return the raw text
|
// Just return the raw text
|
||||||
target = this.getTransclusionTarget();
|
parseTreeNodes = [{type: "text", text: this.sourceText}];
|
||||||
parseTreeNodes = [{type: "text", text: target.text}];
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
// "text/plain" is the plain text result of wikifying the text
|
// text/plain
|
||||||
target = this.parseTransclusionTarget(parseAsInline);
|
var plainText = this.wiki.renderText("text/plain",this.parserType,this.sourceText,{parentWidget: this});
|
||||||
var widgetNode = this.wiki.makeWidget(target.parser,{
|
parseTreeNodes = [{type: "text", text: plainText}];
|
||||||
parentWidget: this,
|
|
||||||
document: $tw.fakeDocument
|
|
||||||
});
|
|
||||||
var container = $tw.fakeDocument.createElement("div");
|
|
||||||
widgetNode.render(container,null);
|
|
||||||
parseTreeNodes = [{type: "text", text: container.textContent}];
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
this.sourceText = target.text;
|
|
||||||
this.parserType = target.type;
|
|
||||||
// Set the legacy transclusion context variables only if we're not transcluding a variable
|
// Set the legacy transclusion context variables only if we're not transcluding a variable
|
||||||
if(!this.transcludeVariable) {
|
if(!this.transcludeVariable) {
|
||||||
var recursionMarker = this.makeRecursionMarker();
|
var recursionMarker = this.makeRecursionMarker();
|
||||||
@@ -174,44 +158,17 @@ TranscludeWidget.prototype.collectSlotFillParameters = function() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Get transcluded details as an object {text:,type:}
|
Get transcluded parse tree nodes as an object {parser:,text:,type:}
|
||||||
*/
|
*/
|
||||||
TranscludeWidget.prototype.getTransclusionTarget = function() {
|
TranscludeWidget.prototype.getTransclusionTarget = function() {
|
||||||
var self = this;
|
var self = this;
|
||||||
var text;
|
// Determine whether we're being used in inline or block mode
|
||||||
// Return the text and type of the target
|
var parseAsInline = !this.parseTreeNode.isBlock;
|
||||||
if(this.hasAttribute("$variable")) {
|
if(this.transcludeMode === "inline") {
|
||||||
if(this.transcludeVariable) {
|
parseAsInline = true;
|
||||||
// Transcluding a variable
|
} else if(this.transcludeMode === "block") {
|
||||||
var variableInfo = this.getVariableInfo(this.transcludeVariable,{params: this.getOrderedTransclusionParameters()});
|
parseAsInline = false;
|
||||||
text = variableInfo.text;
|
|
||||||
return {
|
|
||||||
text: variableInfo.text,
|
|
||||||
type: this.transcludeType
|
|
||||||
};
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// Transcluding a text reference
|
|
||||||
var parserInfo = this.wiki.getTextReferenceParserInfo(
|
|
||||||
this.transcludeTitle,
|
|
||||||
this.transcludeField,
|
|
||||||
this.transcludeIndex,
|
|
||||||
{
|
|
||||||
subTiddler: this.transcludeSubTiddler,
|
|
||||||
defaultType: this.transcludeType
|
|
||||||
});
|
|
||||||
return {
|
|
||||||
text: parserInfo.text,
|
|
||||||
type: parserInfo.type
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
Get transcluded parse tree nodes as an object {text:,type:,parseTreeNodes:,parseAsInline:}
|
|
||||||
*/
|
|
||||||
TranscludeWidget.prototype.parseTransclusionTarget = function(parseAsInline) {
|
|
||||||
var self = this;
|
|
||||||
var parser;
|
var parser;
|
||||||
// Get the parse tree
|
// Get the parse tree
|
||||||
if(this.hasAttribute("$variable")) {
|
if(this.hasAttribute("$variable")) {
|
||||||
@@ -220,7 +177,7 @@ TranscludeWidget.prototype.parseTransclusionTarget = function(parseAsInline) {
|
|||||||
var variableInfo = this.getVariableInfo(this.transcludeVariable,{params: this.getOrderedTransclusionParameters()}),
|
var variableInfo = this.getVariableInfo(this.transcludeVariable,{params: this.getOrderedTransclusionParameters()}),
|
||||||
srcVariable = variableInfo && variableInfo.srcVariable;
|
srcVariable = variableInfo && variableInfo.srcVariable;
|
||||||
if(variableInfo.text) {
|
if(variableInfo.text) {
|
||||||
if(srcVariable && srcVariable.isFunctionDefinition) {
|
if(srcVariable.isFunctionDefinition) {
|
||||||
var result = (variableInfo.resultList ? variableInfo.resultList[0] : variableInfo.text) || "";
|
var result = (variableInfo.resultList ? variableInfo.resultList[0] : variableInfo.text) || "";
|
||||||
parser = {
|
parser = {
|
||||||
tree: [{
|
tree: [{
|
||||||
@@ -250,7 +207,7 @@ TranscludeWidget.prototype.parseTransclusionTarget = function(parseAsInline) {
|
|||||||
if(variableInfo.isCacheable && srcVariable[cacheKey]) {
|
if(variableInfo.isCacheable && srcVariable[cacheKey]) {
|
||||||
parser = srcVariable[cacheKey];
|
parser = srcVariable[cacheKey];
|
||||||
} else {
|
} else {
|
||||||
parser = this.wiki.parseText(this.transcludeType,variableInfo.text || "",{parseAsInline: parseAsInline, configTrimWhiteSpace: srcVariable && srcVariable.configTrimWhiteSpace});
|
parser = this.wiki.parseText(this.transcludeType,variableInfo.text || "",{parseAsInline: parseAsInline, configTrimWhiteSpace: srcVariable.configTrimWhiteSpace});
|
||||||
if(variableInfo.isCacheable) {
|
if(variableInfo.isCacheable) {
|
||||||
srcVariable[cacheKey] = parser;
|
srcVariable[cacheKey] = parser;
|
||||||
}
|
}
|
||||||
@@ -258,7 +215,7 @@ TranscludeWidget.prototype.parseTransclusionTarget = function(parseAsInline) {
|
|||||||
}
|
}
|
||||||
if(parser) {
|
if(parser) {
|
||||||
// Add parameters widget for procedures and custom widgets
|
// Add parameters widget for procedures and custom widgets
|
||||||
if(srcVariable && (srcVariable.isProcedureDefinition || srcVariable.isWidgetDefinition)) {
|
if(srcVariable.isProcedureDefinition || srcVariable.isWidgetDefinition) {
|
||||||
parser = {
|
parser = {
|
||||||
tree: [
|
tree: [
|
||||||
{
|
{
|
||||||
@@ -277,7 +234,7 @@ TranscludeWidget.prototype.parseTransclusionTarget = function(parseAsInline) {
|
|||||||
}
|
}
|
||||||
$tw.utils.addAttributeToParseTreeNode(parser.tree[0],name,param["default"])
|
$tw.utils.addAttributeToParseTreeNode(parser.tree[0],name,param["default"])
|
||||||
});
|
});
|
||||||
} else if(srcVariable && !srcVariable.isFunctionDefinition) {
|
} else if(srcVariable.isMacroDefinition || !srcVariable.isFunctionDefinition) {
|
||||||
// For macros and ordinary variables, wrap the parse tree in a vars widget assigning the parameters to variables named "__paramname__"
|
// For macros and ordinary variables, wrap the parse tree in a vars widget assigning the parameters to variables named "__paramname__"
|
||||||
parser = {
|
parser = {
|
||||||
tree: [
|
tree: [
|
||||||
@@ -308,14 +265,27 @@ TranscludeWidget.prototype.parseTransclusionTarget = function(parseAsInline) {
|
|||||||
defaultType: this.transcludeType
|
defaultType: this.transcludeType
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
// Set 'thisTiddler'
|
||||||
|
this.setVariable("thisTiddler",this.transcludeTitle);
|
||||||
// Return the parse tree
|
// Return the parse tree
|
||||||
return {
|
if(parser) {
|
||||||
parser: parser,
|
return {
|
||||||
parseTreeNodes: parser ? parser.tree : (this.slotFillParseTrees["ts-missing"] || []),
|
parser: parser,
|
||||||
parseAsInline: parseAsInline,
|
parseTreeNodes: parser.tree,
|
||||||
text: parser && parser.source,
|
parseAsInline: parseAsInline,
|
||||||
type: parser && parser.type
|
text: parser.source,
|
||||||
};
|
type: parser.type
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
// If there's no parse tree then return the missing slot value
|
||||||
|
return {
|
||||||
|
parser: null,
|
||||||
|
parseTreeNodes: (this.slotFillParseTrees["ts-missing"] || []),
|
||||||
|
parseAsInline: parseAsInline,
|
||||||
|
text: null,
|
||||||
|
type: null
|
||||||
|
};
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|||||||
@@ -182,7 +182,8 @@ Widget.prototype.getVariableInfo = function(name,options) {
|
|||||||
}
|
}
|
||||||
return {
|
return {
|
||||||
text: text,
|
text: text,
|
||||||
resultList: [text]
|
resultList: [text],
|
||||||
|
srcVariable: {}
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -379,8 +380,6 @@ Widget.prototype.computeAttribute = function(attribute) {
|
|||||||
} else if(attribute.type === "macro") {
|
} else if(attribute.type === "macro") {
|
||||||
var variableInfo = this.getVariableInfo(attribute.value.name,{params: attribute.value.params});
|
var variableInfo = this.getVariableInfo(attribute.value.name,{params: attribute.value.params});
|
||||||
value = variableInfo.text;
|
value = variableInfo.text;
|
||||||
} else if(attribute.type === "substituted") {
|
|
||||||
value = this.wiki.getSubstitutedText(attribute.rawValue,this) || "";
|
|
||||||
} else { // String attribute
|
} else { // String attribute
|
||||||
value = attribute.value;
|
value = attribute.value;
|
||||||
}
|
}
|
||||||
@@ -719,23 +718,44 @@ Widget.prototype.findFirstDomNode = function() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Remove any DOM nodes created by this widget or its children
|
Entry into destroy procedure
|
||||||
|
*/
|
||||||
|
Widget.prototype.destroyChildren = function() {
|
||||||
|
$tw.utils.each(this.children,function(childWidget) {
|
||||||
|
childWidget.destroy();
|
||||||
|
});
|
||||||
|
};
|
||||||
|
/*
|
||||||
|
Legacy entry into destroy procedure
|
||||||
*/
|
*/
|
||||||
Widget.prototype.removeChildDomNodes = function() {
|
Widget.prototype.removeChildDomNodes = function() {
|
||||||
// If this widget has directly created DOM nodes, delete them and exit. This assumes that any child widgets are contained within the created DOM nodes, which would normally be the case
|
this.destroy();
|
||||||
|
};
|
||||||
|
/*
|
||||||
|
Default destroy
|
||||||
|
*/
|
||||||
|
Widget.prototype.destroy = function() {
|
||||||
|
// call children to remove their resources
|
||||||
|
this.destroyChildren();
|
||||||
|
// remove our resources
|
||||||
|
this.children = [];
|
||||||
|
this.removeLocalDomNodes();
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
Remove any DOM nodes created by this widget
|
||||||
|
*/
|
||||||
|
Widget.prototype.removeLocalDomNodes = function() {
|
||||||
|
// If this widget has directly created DOM nodes, delete them and exit.
|
||||||
if(this.domNodes.length > 0) {
|
if(this.domNodes.length > 0) {
|
||||||
$tw.utils.each(this.domNodes,function(domNode) {
|
$tw.utils.each(this.domNodes,function(domNode) {
|
||||||
domNode.parentNode.removeChild(domNode);
|
domNode.parentNode.removeChild(domNode);
|
||||||
});
|
});
|
||||||
this.domNodes = [];
|
this.domNodes = [];
|
||||||
} else {
|
|
||||||
// Otherwise, ask the child widgets to delete their DOM nodes
|
|
||||||
$tw.utils.each(this.children,function(childWidget) {
|
|
||||||
childWidget.removeChildDomNodes();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Invoke the action widgets that are descendents of the current widget.
|
Invoke the action widgets that are descendents of the current widget.
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -1063,34 +1063,6 @@ exports.getTextReferenceParserInfo = function(title,field,index,options) {
|
|||||||
return parserInfo;
|
return parserInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
Parse a block of text of a specified MIME type
|
|
||||||
text: text on which to perform substitutions
|
|
||||||
widget
|
|
||||||
options: see below
|
|
||||||
Options include:
|
|
||||||
substitutions: an optional array of substitutions
|
|
||||||
*/
|
|
||||||
exports.getSubstitutedText = function(text,widget,options) {
|
|
||||||
options = options || {};
|
|
||||||
text = text || "";
|
|
||||||
var self = this,
|
|
||||||
substitutions = options.substitutions || [],
|
|
||||||
output;
|
|
||||||
// Evaluate embedded filters and substitute with first result
|
|
||||||
output = text.replace(/\$\{([\S\s]+?)\}\$/g, function(match,filter) {
|
|
||||||
return self.filterTiddlers(filter,widget)[0] || "";
|
|
||||||
});
|
|
||||||
// Process any substitutions provided in options
|
|
||||||
$tw.utils.each(substitutions,function(substitute) {
|
|
||||||
output = $tw.utils.replaceString(output,new RegExp("\\$" + $tw.utils.escapeRegExp(substitute.name) + "\\$","mg"),substitute.value);
|
|
||||||
});
|
|
||||||
// Substitute any variable references with their values
|
|
||||||
return output.replace(/\$\(([^\)\$]+)\)\$/g, function(match,varname) {
|
|
||||||
return widget.getVariable(varname,{defaultValue: ""})
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Make a widget tree for a parse tree
|
Make a widget tree for a parse tree
|
||||||
parser: parser object
|
parser: parser object
|
||||||
|
|||||||
@@ -12,7 +12,8 @@ tc-page-container tc-page-view-$(storyviewTitle)$ tc-language-$(languageTitle)$
|
|||||||
tv-config-toolbar-class={{$:/config/Toolbar/ButtonClass}}
|
tv-config-toolbar-class={{$:/config/Toolbar/ButtonClass}}
|
||||||
tv-show-missing-links={{$:/config/MissingLinks}}
|
tv-show-missing-links={{$:/config/MissingLinks}}
|
||||||
storyviewTitle={{$:/view}}
|
storyviewTitle={{$:/view}}
|
||||||
languageTitle={{{ [{$:/language}get[name]] }}}>
|
languageTitle={{{ [{$:/language}get[name]] }}}
|
||||||
|
tv-text-direction={{$:/config/DefaultTextDirection}}>
|
||||||
|
|
||||||
<div class=<<containerClasses>>>
|
<div class=<<containerClasses>>>
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
code-body: yes
|
|
||||||
title: $:/core/ui/AlertTemplate
|
title: $:/core/ui/AlertTemplate
|
||||||
|
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
code-body: yes
|
|
||||||
title: $:/core/ui/EditTemplate
|
title: $:/core/ui/EditTemplate
|
||||||
|
|
||||||
\define delete-edittemplate-state-tiddlers()
|
\define delete-edittemplate-state-tiddlers()
|
||||||
@@ -30,6 +29,7 @@ title: $:/core/ui/EditTemplate
|
|||||||
data-tiddler-title=<<currentTiddler>>
|
data-tiddler-title=<<currentTiddler>>
|
||||||
data-tags={{!!tags}}
|
data-tags={{!!tags}}
|
||||||
class={{{ [all[shadows+tiddlers]tag[$:/tags/ClassFilters/TiddlerTemplate]!is[draft]] :map:flat[subfilter{!!text}] tc-tiddler-frame tc-tiddler-edit-frame [<currentTiddler>is[tiddler]then[tc-tiddler-exists]] [<currentTiddler>is[missing]!is[shadow]then[tc-tiddler-missing]] [<currentTiddler>is[shadow]then[tc-tiddler-exists tc-tiddler-shadow]] [<currentTiddler>is[system]then[tc-tiddler-system]] [{!!class}] [<currentTiddler>tags[]encodeuricomponent[]addprefix[tc-tagged-]] +[join[ ]] }}}
|
class={{{ [all[shadows+tiddlers]tag[$:/tags/ClassFilters/TiddlerTemplate]!is[draft]] :map:flat[subfilter{!!text}] tc-tiddler-frame tc-tiddler-edit-frame [<currentTiddler>is[tiddler]then[tc-tiddler-exists]] [<currentTiddler>is[missing]!is[shadow]then[tc-tiddler-missing]] [<currentTiddler>is[shadow]then[tc-tiddler-exists tc-tiddler-shadow]] [<currentTiddler>is[system]then[tc-tiddler-system]] [{!!class}] [<currentTiddler>tags[]encodeuricomponent[]addprefix[tc-tagged-]] +[join[ ]] }}}
|
||||||
|
dir=<<tv-text-direction>>
|
||||||
role="region"
|
role="region"
|
||||||
aria-label={{$:/language/EditTemplate/Caption}}>
|
aria-label={{$:/language/EditTemplate/Caption}}>
|
||||||
<$fieldmangler>
|
<$fieldmangler>
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ title: $:/core/ui/EditTemplate/body/editor
|
|||||||
placeholder={{$:/language/EditTemplate/Body/Placeholder}}
|
placeholder={{$:/language/EditTemplate/Body/Placeholder}}
|
||||||
tabindex={{$:/config/EditTabIndex}}
|
tabindex={{$:/config/EditTabIndex}}
|
||||||
focus={{{ [{$:/config/AutoFocus}match[text]then[true]] ~[[false]] }}}
|
focus={{{ [{$:/config/AutoFocus}match[text]then[true]] ~[[false]] }}}
|
||||||
|
dir=<<tv-text-direction>>
|
||||||
cancelPopups="yes"
|
cancelPopups="yes"
|
||||||
fileDrop={{{ [{$:/config/DragAndDrop/Enable}match[no]] :else[subfilter{$:/config/Editor/EnableImportFilter}then[yes]else[no]] }}}
|
fileDrop={{{ [{$:/config/DragAndDrop/Enable}match[no]] :else[subfilter{$:/config/Editor/EnableImportFilter}then[yes]else[no]] }}}
|
||||||
|
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ $:/config/EditorToolbarButtons/Visibility/$(currentTiddler)$
|
|||||||
importState=<<qualify $:/state/ImportImage>> >
|
importState=<<qualify $:/state/ImportImage>> >
|
||||||
<$dropzone importTitle=<<importTitle>> autoOpenOnImport="no" contentTypesFilter={{$:/config/Editor/ImportContentTypesFilter}} class="tc-dropzone-editor" enable={{{ [{$:/config/DragAndDrop/Enable}match[no]] :else[subfilter{$:/config/Editor/EnableImportFilter}then[yes]else[no]] }}} filesOnly="yes" actions=<<importFileActions>> >
|
<$dropzone importTitle=<<importTitle>> autoOpenOnImport="no" contentTypesFilter={{$:/config/Editor/ImportContentTypesFilter}} class="tc-dropzone-editor" enable={{{ [{$:/config/DragAndDrop/Enable}match[no]] :else[subfilter{$:/config/Editor/EnableImportFilter}then[yes]else[no]] }}} filesOnly="yes" actions=<<importFileActions>> >
|
||||||
<$reveal stateTitle=<<edit-preview-state>> type="match" text="yes" tag="div">
|
<$reveal stateTitle=<<edit-preview-state>> type="match" text="yes" tag="div">
|
||||||
<div class="tc-tiddler-preview">
|
<div class="tc-tiddler-preview" dir=<<tv-text-direction>>>
|
||||||
|
|
||||||
<$transclude tiddler="$:/core/ui/EditTemplate/body/editor" mode="inline"/>
|
<$transclude tiddler="$:/core/ui/EditTemplate/body/editor" mode="inline"/>
|
||||||
|
|
||||||
@@ -32,7 +32,7 @@ $:/config/EditorToolbarButtons/Visibility/$(currentTiddler)$
|
|||||||
</div>
|
</div>
|
||||||
</$reveal>
|
</$reveal>
|
||||||
|
|
||||||
<$reveal stateTitle=<<edit-preview-state>> type="nomatch" text="yes" tag="div">
|
<$reveal stateTitle=<<edit-preview-state>> type="nomatch" text="yes" tag="div" dir=<<tv-text-direction>>>
|
||||||
|
|
||||||
<$transclude tiddler="$:/core/ui/EditTemplate/body/editor" mode="inline"/>
|
<$transclude tiddler="$:/core/ui/EditTemplate/body/editor" mode="inline"/>
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ tags: $:/tags/EditTemplate
|
|||||||
$:/config/EditToolbarButtons/Visibility/$(listItem)$
|
$:/config/EditToolbarButtons/Visibility/$(listItem)$
|
||||||
\end
|
\end
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
<div class="tc-tiddler-title tc-tiddler-edit-title">
|
<div class="tc-tiddler-title tc-tiddler-edit-title" dir=<<tv-text-direction>>>
|
||||||
<$view field="title"/>
|
<$view field="title"/>
|
||||||
<span class="tc-tiddler-controls tc-titlebar"><$list filter="[all[shadows+tiddlers]tag[$:/tags/EditToolbar]!has[draft.of]]" variable="listItem"><$let tv-config-toolbar-class={{{ [enlist<tv-config-toolbar-class>] [<listItem>encodeuricomponent[]addprefix[tc-btn-]] +[join[ ]]}}}><$reveal type="nomatch" state=<<config-title>> text="hide"><$transclude tiddler=<<listItem>>/></$reveal></$let></$list></span>
|
<span class="tc-tiddler-controls tc-titlebar"><$list filter="[all[shadows+tiddlers]tag[$:/tags/EditToolbar]!has[draft.of]]" variable="listItem"><$let tv-config-toolbar-class={{{ [enlist<tv-config-toolbar-class>] [<listItem>encodeuricomponent[]addprefix[tc-btn-]] +[join[ ]]}}}><$reveal type="nomatch" state=<<config-title>> text="hide"><$transclude tiddler=<<listItem>>/></$reveal></$let></$list></span>
|
||||||
<div style="clear: both;"></div>
|
<div style="clear: both;"></div>
|
||||||
|
|||||||
@@ -74,7 +74,7 @@ $value={{{ [subfilter<get-field-value-tiddler-filter>get[text]] }}}/>
|
|||||||
\whitespace trim
|
\whitespace trim
|
||||||
|
|
||||||
<$set name="newFieldValueTiddlerPrefix" value=<<newFieldValueTiddlerPrefix>> emptyValue=<<qualify "$:/temp/NewFieldValue">> >
|
<$set name="newFieldValueTiddlerPrefix" value=<<newFieldValueTiddlerPrefix>> emptyValue=<<qualify "$:/temp/NewFieldValue">> >
|
||||||
<div class="tc-edit-fields">
|
<div class="tc-edit-fields" dir=<<tv-text-direction>>>
|
||||||
<table class={{{ [all[current]fields[]] :filter[lookup[$:/config/EditTemplateFields/Visibility/]!match[hide]] +[count[]!match[0]] +[then[tc-edit-fields]] ~[[tc-edit-fields tc-edit-fields-small]] }}}>
|
<table class={{{ [all[current]fields[]] :filter[lookup[$:/config/EditTemplateFields/Visibility/]!match[hide]] +[count[]!match[0]] +[then[tc-edit-fields]] ~[[tc-edit-fields tc-edit-fields-small]] }}}>
|
||||||
<tbody>
|
<tbody>
|
||||||
<$list filter="[all[current]fields[]] +[sort[title]]" variable="currentField" storyview="pop">
|
<$list filter="[all[current]fields[]] +[sort[title]]" variable="currentField" storyview="pop">
|
||||||
@@ -101,7 +101,7 @@ $value={{{ [subfilter<get-field-value-tiddler-filter>get[text]] }}}/>
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<$fieldmangler>
|
<$fieldmangler>
|
||||||
<div class="tc-edit-field-add">
|
<div class="tc-edit-field-add" dir=<<tv-text-direction>>>
|
||||||
<em class="tc-edit tc-small-gap-right">
|
<em class="tc-edit tc-small-gap-right">
|
||||||
<<lingo Fields/Add/Prompt>>
|
<<lingo Fields/Add/Prompt>>
|
||||||
</em>
|
</em>
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ tags: $:/tags/EditTemplate
|
|||||||
<$list filter="[all[current]shadowsource[]]" variable="pluginTitle">
|
<$list filter="[all[current]shadowsource[]]" variable="pluginTitle">
|
||||||
|
|
||||||
<$set name="pluginLink" value=<<pluginLinkBody>>>
|
<$set name="pluginLink" value=<<pluginLinkBody>>>
|
||||||
<div class="tc-message-box">
|
<div class="tc-message-box" dir=<<tv-text-direction>>>
|
||||||
|
|
||||||
<<lingo Warning>>
|
<<lingo Warning>>
|
||||||
|
|
||||||
@@ -29,7 +29,7 @@ tags: $:/tags/EditTemplate
|
|||||||
<$list filter="[all[current]shadowsource[]]" variable="pluginTitle">
|
<$list filter="[all[current]shadowsource[]]" variable="pluginTitle">
|
||||||
|
|
||||||
<$set name="pluginLink" value=<<pluginLinkBody>>>
|
<$set name="pluginLink" value=<<pluginLinkBody>>>
|
||||||
<div class="tc-message-box">
|
<div class="tc-message-box" dir=<<tv-text-direction>>>
|
||||||
|
|
||||||
<<lingo OverriddenWarning>>
|
<<lingo OverriddenWarning>>
|
||||||
|
|
||||||
|
|||||||
@@ -27,7 +27,7 @@ color:$(foregroundColor)$;
|
|||||||
|
|
||||||
\define edit-tags-template(tagField:"tags")
|
\define edit-tags-template(tagField:"tags")
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
<div class="tc-edit-tags">
|
<div class="tc-edit-tags" dir=<<tv-text-direction>>>
|
||||||
<$list filter="[list[!!$tagField$]sort[title]]" storyview="pop">
|
<$list filter="[list[!!$tagField$]sort[title]]" storyview="pop">
|
||||||
<$macrocall $name="tag-body" colour={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerColourFilter]!is[draft]get[text]] }}} palette={{$:/palette}} icon={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerIconFilter]!is[draft]get[text]] }}} tagField=<<__tagField__>>/>
|
<$macrocall $name="tag-body" colour={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerColourFilter]!is[draft]get[text]] }}} palette={{$:/palette}} icon={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerIconFilter]!is[draft]get[text]] }}} tagField=<<__tagField__>>/>
|
||||||
</$list>
|
</$list>
|
||||||
|
|||||||
@@ -2,13 +2,13 @@ title: $:/core/ui/EditTemplate/title
|
|||||||
tags: $:/tags/EditTemplate
|
tags: $:/tags/EditTemplate
|
||||||
|
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
<$edit-text field="draft.title" class="tc-titlebar tc-edit-texteditor" focus={{{ [{$:/config/AutoFocus}match[title]then[true]] ~[[false]] }}} tabindex={{$:/config/EditTabIndex}} cancelPopups="yes"/>
|
<$edit-text field="draft.title" class="tc-titlebar tc-edit-texteditor" focus={{{ [{$:/config/AutoFocus}match[title]then[true]] ~[[false]] }}} tabindex={{$:/config/EditTabIndex}} cancelPopups="yes" dir=<<tv-text-direction>>/>
|
||||||
|
|
||||||
<$vars pattern="""[\|\[\]{}]""" bad-chars="""`| [ ] { }`""">
|
<$vars pattern="""[\|\[\]{}]""" bad-chars="""`| [ ] { }`""">
|
||||||
|
|
||||||
<$list filter="[all[current]regexp:draft.title<pattern>]" variable="listItem">
|
<$list filter="[all[current]regexp:draft.title<pattern>]" variable="listItem">
|
||||||
|
|
||||||
<div class="tc-message-box">
|
<div class="tc-message-box" dir=<<tv-text-direction>>>
|
||||||
|
|
||||||
{{$:/core/images/warning}} {{$:/language/EditTemplate/Title/BadCharacterWarning}}
|
{{$:/core/images/warning}} {{$:/language/EditTemplate/Title/BadCharacterWarning}}
|
||||||
|
|
||||||
@@ -18,7 +18,7 @@ tags: $:/tags/EditTemplate
|
|||||||
|
|
||||||
</$vars>
|
</$vars>
|
||||||
|
|
||||||
<$reveal state="!!draft.title" type="nomatch" text={{!!draft.of}} tag="div">
|
<$reveal state="!!draft.title" type="nomatch" text={{!!draft.of}} tag="div" dir=<<tv-text-direction>>>
|
||||||
|
|
||||||
<$list filter="[{!!draft.title}!is[missing]]" variable="listItem">
|
<$list filter="[{!!draft.title}!is[missing]]" variable="listItem">
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ first-search-filter: [all[shadows+tiddlers]prefix[$:/language/Docs/Types/]sort[d
|
|||||||
<div class="tc-edit-type-selector-wrapper">
|
<div class="tc-edit-type-selector-wrapper">
|
||||||
<em class="tc-edit tc-small-gap-right"><<lingo Type/Prompt>></em>
|
<em class="tc-edit tc-small-gap-right"><<lingo Type/Prompt>></em>
|
||||||
<div class="tc-type-selector-dropdown-wrapper">
|
<div class="tc-type-selector-dropdown-wrapper">
|
||||||
<div class="tc-type-selector"><$fieldmangler>
|
<div class="tc-type-selector" dir=<<tv-text-direction>>}><$fieldmangler>
|
||||||
<$macrocall $name="keyboard-driven-input" tiddler=<<currentTiddler>> storeTitle=<<typeInputTiddler>> refreshTitle=<<refreshTitle>> selectionStateTitle=<<typeSelectionTiddler>> field="type" tag="input" default="" placeholder={{$:/language/EditTemplate/Type/Placeholder}} focusPopup=<<qualify "$:/state/popup/type-dropdown">> class="tc-edit-typeeditor tc-edit-texteditor tc-popup-handle" tabindex={{$:/config/EditTabIndex}} focus={{{ [{$:/config/AutoFocus}match[type]then[true]] ~[[false]] }}} cancelPopups="yes" configTiddlerFilter="[[$:/core/ui/EditTemplate/type]]" inputCancelActions=<<input-cancel-actions>>/><$button popup=<<qualify "$:/state/popup/type-dropdown">> class="tc-btn-invisible tc-btn-dropdown tc-small-gap" tooltip={{$:/language/EditTemplate/Type/Dropdown/Hint}} aria-label={{$:/language/EditTemplate/Type/Dropdown/Caption}}>{{$:/core/images/down-arrow}}</$button><$button message="tm-remove-field" param="type" class="tc-btn-invisible tc-btn-icon" tooltip={{$:/language/EditTemplate/Type/Delete/Hint}} aria-label={{$:/language/EditTemplate/Type/Delete/Caption}}>{{$:/core/images/delete-button}}<$action-deletetiddler $filter="[<storeTitle>] [<refreshTitle>] [<selectionStateTitle>]"/></$button>
|
<$macrocall $name="keyboard-driven-input" tiddler=<<currentTiddler>> storeTitle=<<typeInputTiddler>> refreshTitle=<<refreshTitle>> selectionStateTitle=<<typeSelectionTiddler>> field="type" tag="input" default="" placeholder={{$:/language/EditTemplate/Type/Placeholder}} focusPopup=<<qualify "$:/state/popup/type-dropdown">> class="tc-edit-typeeditor tc-edit-texteditor tc-popup-handle" tabindex={{$:/config/EditTabIndex}} focus={{{ [{$:/config/AutoFocus}match[type]then[true]] ~[[false]] }}} cancelPopups="yes" configTiddlerFilter="[[$:/core/ui/EditTemplate/type]]" inputCancelActions=<<input-cancel-actions>>/><$button popup=<<qualify "$:/state/popup/type-dropdown">> class="tc-btn-invisible tc-btn-dropdown tc-small-gap" tooltip={{$:/language/EditTemplate/Type/Dropdown/Hint}} aria-label={{$:/language/EditTemplate/Type/Dropdown/Caption}}>{{$:/core/images/down-arrow}}</$button><$button message="tm-remove-field" param="type" class="tc-btn-invisible tc-btn-icon" tooltip={{$:/language/EditTemplate/Type/Delete/Hint}} aria-label={{$:/language/EditTemplate/Type/Delete/Caption}}>{{$:/core/images/delete-button}}<$action-deletetiddler $filter="[<storeTitle>] [<refreshTitle>] [<selectionStateTitle>]"/></$button>
|
||||||
</$fieldmangler></div>
|
</$fieldmangler></div>
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
title: $:/core/ui/ImportPreviews/Text
|
title: $:/core/ui/ImportPreviews/Text
|
||||||
tags: $:/tags/ImportPreview
|
tags: $:/tags/ImportPreview
|
||||||
caption: {{$:/language/Import/Listing/Preview/Text}}
|
caption: {{$:/language/Import/Listing/Preview/Text}}
|
||||||
code-body: yes
|
|
||||||
|
|
||||||
<$transclude tiddler=<<currentTiddler>> subtiddler=<<payloadTiddler>> mode="block"/>
|
<$transclude tiddler=<<currentTiddler>> subtiddler=<<payloadTiddler>> mode="block"/>
|
||||||
|
|||||||
@@ -3,14 +3,15 @@ tags: $:/tags/MoreSideBar
|
|||||||
caption: {{$:/language/SideBar/Tags/Caption}}
|
caption: {{$:/language/SideBar/Tags/Caption}}
|
||||||
|
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
|
|
||||||
<$let tv-config-toolbar-icons="yes" tv-config-toolbar-text="yes" tv-config-toolbar-class="">
|
<$let tv-config-toolbar-icons="yes" tv-config-toolbar-text="yes" tv-config-toolbar-class="">
|
||||||
<div class="tc-tiny-v-gap-bottom">
|
<div class="tc-tiny-v-gap-bottom">
|
||||||
{{$:/core/ui/Buttons/tag-manager}}
|
{{$:/core/ui/Buttons/tag-manager}}
|
||||||
</div>
|
</div>
|
||||||
</$let>
|
</$let>
|
||||||
<$list filter={{$:/core/Filters/AllTags!!filter}}>
|
<$list filter={{$:/core/Filters/AllTags!!filter}}>
|
||||||
<div class="tc-tiny-v-gap-bottom">
|
<div class="tc-tiny-v-gap-bottom">
|
||||||
<$transclude tiddler="$:/core/ui/TagTemplate"/>
|
<$transclude tiddler="$:/core/ui/TagTemplate"/>
|
||||||
</div>
|
</div>
|
||||||
</$list>
|
</$list>
|
||||||
<hr class="tc-untagged-separator">
|
<hr class="tc-untagged-separator">
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
title: $:/core/ui/PageStylesheet
|
title: $:/core/ui/PageStylesheet
|
||||||
code-body: yes
|
|
||||||
|
|
||||||
\import [subfilter{$:/core/config/GlobalImportFilter}]
|
\import [subfilter{$:/core/config/GlobalImportFilter}]
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
|
|||||||
@@ -2,7 +2,6 @@ title: $:/core/ui/PageTemplate
|
|||||||
name: {{$:/language/PageTemplate/Name}}
|
name: {{$:/language/PageTemplate/Name}}
|
||||||
description: {{$:/language/PageTemplate/Description}}
|
description: {{$:/language/PageTemplate/Description}}
|
||||||
icon: $:/core/images/layout-button
|
icon: $:/core/images/layout-button
|
||||||
code-body: yes
|
|
||||||
|
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
\import [subfilter{$:/core/config/GlobalImportFilter}]
|
\import [subfilter{$:/core/config/GlobalImportFilter}]
|
||||||
@@ -14,7 +13,8 @@ code-body: yes
|
|||||||
tv-enable-drag-and-drop={{$:/config/DragAndDrop/Enable}}
|
tv-enable-drag-and-drop={{$:/config/DragAndDrop/Enable}}
|
||||||
tv-show-missing-links={{$:/config/MissingLinks}}
|
tv-show-missing-links={{$:/config/MissingLinks}}
|
||||||
storyviewTitle={{$:/view}}
|
storyviewTitle={{$:/view}}
|
||||||
languageTitle={{{ [{$:/language}get[name]] }}}>
|
languageTitle={{{ [{$:/language}get[name]] }}}
|
||||||
|
tv-text-direction={{$:/config/DefaultTextDirection}}>
|
||||||
|
|
||||||
<div class={{{ [all[shadows+tiddlers]tag[$:/tags/ClassFilters/PageTemplate]!is[draft]] :map:flat[subfilter{!!text}] tc-page-container [[tc-page-view-]addsuffix<storyviewTitle>] [[tc-language-]addsuffix<languageTitle>] :and[unique[]join[ ]] }}} >
|
<div class={{{ [all[shadows+tiddlers]tag[$:/tags/ClassFilters/PageTemplate]!is[draft]] :map:flat[subfilter{!!text}] tc-page-container [[tc-page-view-]addsuffix<storyviewTitle>] [[tc-language-]addsuffix<languageTitle>] :and[unique[]join[ ]] }}} >
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
title: $:/core/ui/RootTemplate
|
title: $:/core/ui/RootTemplate
|
||||||
code-body: yes
|
|
||||||
|
|
||||||
<$transclude tiddler={{{ [{$:/layout}has[text]] ~[[$:/core/ui/PageTemplate]] }}} mode="inline"/>
|
<$transclude tiddler={{{ [{$:/layout}has[text]] ~[[$:/core/ui/PageTemplate]] }}} mode="inline"/>
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
title: $:/core/ui/StoryTiddlerTemplate
|
title: $:/core/ui/StoryTiddlerTemplate
|
||||||
code-body: yes
|
|
||||||
|
|
||||||
<$transclude tiddler={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/StoryTiddlerTemplateFilter]!is[draft]get[text]] :and[has[title]else[$:/core/ui/ViewTemplate]] }}} />
|
<$transclude tiddler={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/StoryTiddlerTemplateFilter]!is[draft]get[text]] :and[has[title]else[$:/core/ui/ViewTemplate]] }}} />
|
||||||
|
|||||||
@@ -2,29 +2,22 @@ title: $:/core/ui/TagPickerTagTemplate
|
|||||||
|
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
<$button class=<<button-classes>> tag="a" tooltip={{$:/language/EditTemplate/Tags/Add/Button/Hint}}>
|
<$button class=<<button-classes>> tag="a" tooltip={{$:/language/EditTemplate/Tags/Add/Button/Hint}}>
|
||||||
<$list filter="[<saveTiddler>minlength[1]]">
|
<$list filter="[<saveTiddler>minlength[1]]">
|
||||||
<$action-listops $tiddler=<<saveTiddler>> $field=<<tagField>> $subfilter="[<tag>]"/>
|
<$action-listops $tiddler=<<saveTiddler>> $field=<<tagField>> $subfilter="[<tag>]"/>
|
||||||
</$list>
|
</$list>
|
||||||
<$set name="currentTiddlerCSSEscaped" value={{{ [<saveTiddler>escapecss[]] }}}>
|
<$set name="currentTiddlerCSSEscaped" value={{{ [<saveTiddler>escapecss[]] }}}>
|
||||||
<$action-sendmessage $message="tm-focus-selector" $param=<<get-tagpicker-focus-selector>> preventScroll="true"/>
|
<$action-sendmessage $message="tm-focus-selector" $param=<<get-tagpicker-focus-selector>> preventScroll="true"/>
|
||||||
</$set>
|
</$set>
|
||||||
<<delete-tag-state-tiddlers>>
|
<<delete-tag-state-tiddlers>>
|
||||||
<$list filter="[<refreshTitle>minlength[1]]">
|
<$list filter="[<refreshTitle>minlength[1]]">
|
||||||
<$action-setfield $tiddler=<<refreshTitle>> text="yes"/>
|
<$action-setfield $tiddler=<<refreshTitle>> text="yes"/>
|
||||||
</$list>
|
</$list>
|
||||||
<<actions>>
|
<<actions>>
|
||||||
<$set name="backgroundColor"
|
<$set name="backgroundColor" value={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerColourFilter]!is[draft]get[text]] }}}>
|
||||||
value={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerColourFilter]!is[draft]get[text]] }}}
|
<$wikify name="foregroundColor" text="""<$macrocall $name="contrastcolour" target=<<backgroundColor>> fallbackTarget=<<fallbackTarget>> colourA=<<colourA>> colourB=<<colourB>>/>""">
|
||||||
>
|
<span class="tc-tag-label tc-btn-invisible" style=<<tag-pill-styles>> data-tag-title=<<currentTiddler>> >
|
||||||
<$wikify name="foregroundColor"
|
{{||$:/core/ui/TiddlerIcon}}<$view field="title" format="text"/>
|
||||||
text="""<$macrocall $name="contrastcolour" target=<<backgroundColor>> fallbackTarget=<<fallbackTarget>> colourA=<<colourA>> colourB=<<colourB>>/>"""
|
</span>
|
||||||
>
|
</$wikify>
|
||||||
<span class="tc-tag-label tc-btn-invisible"
|
</$set>
|
||||||
style=<<tag-pill-styles>>
|
|
||||||
data-tag-title=<<currentTiddler>>
|
|
||||||
>
|
|
||||||
{{||$:/core/ui/TiddlerIcon}}<$view field="title" format="text"/>
|
|
||||||
</span>
|
|
||||||
</$wikify>
|
|
||||||
</$set>
|
|
||||||
</$button>
|
</$button>
|
||||||
|
|||||||
@@ -3,23 +3,16 @@ title: $:/core/ui/TagTemplate
|
|||||||
\whitespace trim
|
\whitespace trim
|
||||||
<span class="tc-tag-list-item" data-tag-title=<<currentTiddler>>>
|
<span class="tc-tag-list-item" data-tag-title=<<currentTiddler>>>
|
||||||
<$set name="transclusion" value=<<currentTiddler>>>
|
<$set name="transclusion" value=<<currentTiddler>>>
|
||||||
<$macrocall $name="tag-pill-body"
|
<$macrocall $name="tag-pill-body" tag=<<currentTiddler>> icon={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerIconFilter]!is[draft]get[text]] }}} colour={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerColourFilter]!is[draft]get[text]] }}} palette={{$:/palette}} element-tag="""$button""" element-attributes="""popup=<<qualify "$:/state/popup/tag">> dragFilter='[all[current]tagging[]]' tag='span'"""/>
|
||||||
tag=<<currentTiddler>>
|
<$reveal state=<<qualify "$:/state/popup/tag">> type="popup" position="below" animate="yes" class="tc-drop-down">
|
||||||
icon={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerIconFilter]!is[draft]get[text]] }}}
|
<$set name="tv-show-missing-links" value="yes">
|
||||||
colour={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerColourFilter]!is[draft]get[text]] }}}
|
<$transclude tiddler="$:/core/ui/ListItemTemplate"/>
|
||||||
palette={{$:/palette}}
|
</$set>
|
||||||
element-tag="$button"
|
<$list filter="[all[shadows+tiddlers]tag[$:/tags/TagDropdown]!has[draft.of]]" variable="listItem">
|
||||||
element-attributes="""popup=<<qualify "$:/state/popup/tag">> dragFilter="[all[current]tagging[]]" tag='span'"""
|
<$transclude tiddler=<<listItem>>/>
|
||||||
/>
|
</$list>
|
||||||
<$reveal state=<<qualify "$:/state/popup/tag">> type="popup" position="below" animate="yes" class="tc-drop-down">
|
<hr>
|
||||||
<$set name="tv-show-missing-links" value="yes">
|
<$macrocall $name="list-tagged-draggable" tag=<<currentTiddler>>/>
|
||||||
<$transclude tiddler="$:/core/ui/ListItemTemplate"/>
|
</$reveal>
|
||||||
</$set>
|
|
||||||
<$list filter="[all[shadows+tiddlers]tag[$:/tags/TagDropdown]!has[draft.of]]" variable="listItem">
|
|
||||||
<$transclude tiddler=<<listItem>>/>
|
|
||||||
</$list>
|
|
||||||
<hr>
|
|
||||||
<$macrocall $name="list-tagged-draggable" tag=<<currentTiddler>>/>
|
|
||||||
</$reveal>
|
|
||||||
</$set>
|
</$set>
|
||||||
</span>
|
</span>
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
title: $:/core/ui/ViewTemplate
|
title: $:/core/ui/ViewTemplate
|
||||||
code-body: yes
|
|
||||||
|
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
\define folded-state()
|
\define folded-state()
|
||||||
@@ -8,7 +7,7 @@ $:/state/folded/$(currentTiddler)$
|
|||||||
\define cancel-delete-tiddler-actions(message) <$action-sendmessage $message="tm-$message$-tiddler"/>
|
\define cancel-delete-tiddler-actions(message) <$action-sendmessage $message="tm-$message$-tiddler"/>
|
||||||
\import [all[shadows+tiddlers]tag[$:/tags/Macro/View]!is[draft]] [all[shadows+tiddlers]tag[$:/tags/Global/View]!is[draft]]
|
\import [all[shadows+tiddlers]tag[$:/tags/Macro/View]!is[draft]] [all[shadows+tiddlers]tag[$:/tags/Global/View]!is[draft]]
|
||||||
<$vars storyTiddler=<<currentTiddler>> tiddlerInfoState=<<qualify "$:/state/popup/tiddler-info">>>
|
<$vars storyTiddler=<<currentTiddler>> tiddlerInfoState=<<qualify "$:/state/popup/tiddler-info">>>
|
||||||
<div data-tiddler-title=<<currentTiddler>> data-tags={{!!tags}} class={{{ [all[shadows+tiddlers]tag[$:/tags/ClassFilters/TiddlerTemplate]!is[draft]] :map:flat[subfilter{!!text}] tc-tiddler-frame tc-tiddler-view-frame [<currentTiddler>is[tiddler]then[tc-tiddler-exists]] [<currentTiddler>is[missing]!is[shadow]then[tc-tiddler-missing]] [<currentTiddler>is[shadow]then[tc-tiddler-exists tc-tiddler-shadow]] [<currentTiddler>is[shadow]is[tiddler]then[tc-tiddler-overridden-shadow]] [<currentTiddler>is[system]then[tc-tiddler-system]] [{!!class}] [<currentTiddler>tags[]encodeuricomponent[]addprefix[tc-tagged-]] +[join[ ]] }}} role="article">
|
<div dir=<<tv-text-direction>> data-tiddler-title=<<currentTiddler>> data-tags={{!!tags}} class={{{ [all[shadows+tiddlers]tag[$:/tags/ClassFilters/TiddlerTemplate]!is[draft]] :map:flat[subfilter{!!text}] tc-tiddler-frame tc-tiddler-view-frame [<currentTiddler>is[tiddler]then[tc-tiddler-exists]] [<currentTiddler>is[missing]!is[shadow]then[tc-tiddler-missing]] [<currentTiddler>is[shadow]then[tc-tiddler-exists tc-tiddler-shadow]] [<currentTiddler>is[shadow]is[tiddler]then[tc-tiddler-overridden-shadow]] [<currentTiddler>is[system]then[tc-tiddler-system]] [{!!class}] [<currentTiddler>tags[]encodeuricomponent[]addprefix[tc-tagged-]] +[join[ ]] }}} role="article">
|
||||||
<$list filter="[all[shadows+tiddlers]tag[$:/tags/ViewTemplate]!is[draft]]" variable="listItem">
|
<$list filter="[all[shadows+tiddlers]tag[$:/tags/ViewTemplate]!is[draft]]" variable="listItem">
|
||||||
<$transclude tiddler=<<listItem>>/>
|
<$transclude tiddler=<<listItem>>/>
|
||||||
</$list>
|
</$list>
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ tags: $:/tags/ViewTemplate
|
|||||||
|
|
||||||
\import [all[shadows+tiddlers]tag[$:/tags/Macro/View/Body]!is[draft]] [all[shadows+tiddlers]tag[$:/tags/Global/View/Body]!is[draft]]
|
\import [all[shadows+tiddlers]tag[$:/tags/Macro/View/Body]!is[draft]] [all[shadows+tiddlers]tag[$:/tags/Global/View/Body]!is[draft]]
|
||||||
|
|
||||||
<$reveal tag="div" class="tc-tiddler-body" type="nomatch" stateTitle=<<folded-state>> text="hide" retain="yes" animate="yes">
|
<$reveal tag="div" class="tc-tiddler-body" type="nomatch" stateTitle=<<folded-state>> text="hide" retain="yes" animate="yes" dir=<<tv-text-direction>>>
|
||||||
|
|
||||||
<$transclude tiddler={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/ViewTemplateBodyFilter]!is[draft]get[text]] :and[!is[blank]else[$:/core/ui/ViewTemplate/body/default]] }}} />
|
<$transclude tiddler={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/ViewTemplateBodyFilter]!is[draft]get[text]] :and[!is[blank]else[$:/core/ui/ViewTemplate/body/default]] }}} />
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
title: $:/core/ui/ViewTemplate/body/default
|
title: $:/core/ui/ViewTemplate/body/default
|
||||||
code-body: yes
|
|
||||||
|
|
||||||
<$transclude>
|
<$transclude>
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ tags: $:/tags/ViewTemplate
|
|||||||
|
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
<$reveal type="nomatch" stateTitle=<<folded-state>> text="hide" tag="div" retain="yes" animate="yes">
|
<$reveal type="nomatch" stateTitle=<<folded-state>> text="hide" tag="div" retain="yes" animate="yes">
|
||||||
<div class="tc-subtitle">
|
<div class="tc-subtitle" dir=<<tv-text-direction>>>
|
||||||
<$list filter="[all[shadows+tiddlers]tag[$:/tags/ViewTemplate/Subtitle]!has[draft.of]]" variable="subtitleTiddler" counter="indexSubtitleTiddler">
|
<$list filter="[all[shadows+tiddlers]tag[$:/tags/ViewTemplate/Subtitle]!has[draft.of]]" variable="subtitleTiddler" counter="indexSubtitleTiddler">
|
||||||
<$list filter="[<indexSubtitleTiddler-first>match[no]]" variable="ignore">
|
<$list filter="[<indexSubtitleTiddler-first>match[no]]" variable="ignore">
|
||||||
|
|
||||||
|
|||||||
@@ -3,5 +3,5 @@ tags: $:/tags/ViewTemplate
|
|||||||
|
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
<$reveal type="nomatch" stateTitle=<<folded-state>> text="hide" tag="div" retain="yes" animate="yes">
|
<$reveal type="nomatch" stateTitle=<<folded-state>> text="hide" tag="div" retain="yes" animate="yes">
|
||||||
<div class="tc-tags-wrapper"><$list filter="[all[current]tags[]sort[title]]" template="$:/core/ui/TagTemplate" storyview="pop"/></div>
|
<div class="tc-tags-wrapper" dir=<<tv-text-direction>>><$list filter="[all[current]tags[]sort[title]]" template="$:/core/ui/TagTemplate" storyview="pop"/></div>
|
||||||
</$reveal>
|
</$reveal>
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ tags: $:/tags/ViewTemplate
|
|||||||
fill:$(foregroundColor)$;
|
fill:$(foregroundColor)$;
|
||||||
\end
|
\end
|
||||||
<div class="tc-tiddler-title">
|
<div class="tc-tiddler-title">
|
||||||
<div class="tc-titlebar">
|
<div class="tc-titlebar" dir=<<tv-text-direction>>>
|
||||||
<span class="tc-tiddler-controls">
|
<span class="tc-tiddler-controls">
|
||||||
<$list filter="[all[shadows+tiddlers]tag[$:/tags/ViewToolbar]!has[draft.of]] :filter[lookup[$:/config/ViewToolbarButtons/Visibility/]!match[hide]]" storyview="pop" variable="listItem"><$set name="tv-config-toolbar-class" filter="[<tv-config-toolbar-class>] [<listItem>encodeuricomponent[]addprefix[tc-btn-]]"><$transclude tiddler=<<listItem>>/></$set></$list>
|
<$list filter="[all[shadows+tiddlers]tag[$:/tags/ViewToolbar]!has[draft.of]] :filter[lookup[$:/config/ViewToolbarButtons/Visibility/]!match[hide]]" storyview="pop" variable="listItem"><$set name="tv-config-toolbar-class" filter="[<tv-config-toolbar-class>] [<listItem>encodeuricomponent[]addprefix[tc-btn-]]"><$transclude tiddler=<<listItem>>/></$set></$list>
|
||||||
</span>
|
</span>
|
||||||
|
|||||||
2
core/wiki/config/DefaultTextDirection.tid
Normal file
2
core/wiki/config/DefaultTextDirection.tid
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
title: $:/config/DefaultTextDirection
|
||||||
|
text: auto
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
title: $:/config/OfficialPluginLibrary
|
title: $:/config/OfficialPluginLibrary
|
||||||
tags: $:/tags/PluginLibrary
|
tags: $:/tags/PluginLibrary
|
||||||
url: https://tiddlywiki.com/library/v5.3.2/index.html
|
url: https://tiddlywiki.com/library/v5.2.8/index.html
|
||||||
caption: {{$:/language/OfficialPluginLibrary}}
|
caption: {{$:/language/OfficialPluginLibrary}}
|
||||||
|
|
||||||
{{$:/language/OfficialPluginLibrary/Hint}}
|
{{$:/language/OfficialPluginLibrary/Hint}}
|
||||||
|
|||||||
@@ -2,8 +2,7 @@ title: $:/config/ViewTemplateBodyFilters/
|
|||||||
tags: $:/tags/ViewTemplateBodyFilter
|
tags: $:/tags/ViewTemplateBodyFilter
|
||||||
|
|
||||||
stylesheet: [tag[$:/tags/Stylesheet]then[$:/core/ui/ViewTemplate/body/rendered-plain-text]]
|
stylesheet: [tag[$:/tags/Stylesheet]then[$:/core/ui/ViewTemplate/body/rendered-plain-text]]
|
||||||
core-ui-tags: [tag[$:/tags/PageTemplate]] [tag[$:/tags/EditTemplate]] [tag[$:/tags/ViewTemplate]] [tag[$:/tags/KeyboardShortcut]] [tag[$:/tags/ImportPreview]] [tag[$:/tags/EditPreview]][tag[$:/tags/EditorToolbar]] [tag[$:/tags/Actions]] :then[[$:/core/ui/ViewTemplate/body/code]]
|
system: [prefix[$:/boot/]] [prefix[$:/config/]] [prefix[$:/core/macros]] [prefix[$:/core/save/]] [prefix[$:/core/templates/]] [prefix[$:/core/ui/]split[/]count[]compare:number:eq[4]] [prefix[$:/info/]] [prefix[$:/language/]] [prefix[$:/languages/]] [prefix[$:/snippets/]] [prefix[$:/state/]] [prefix[$:/status/]] [prefix[$:/info/]] [prefix[$:/temp/]] +[!is[image]limit[1]then[$:/core/ui/ViewTemplate/body/code]]
|
||||||
system: [prefix[$:/boot/]] [prefix[$:/config/]] [prefix[$:/core/macros]] [prefix[$:/core/save/]] [prefix[$:/core/templates/]] [prefix[$:/info/]] [prefix[$:/language/]] [prefix[$:/languages/]] [prefix[$:/snippets/]] [prefix[$:/state/]] [prefix[$:/status/]] [prefix[$:/info/]] [prefix[$:/temp/]] +[!is[image]limit[1]then[$:/core/ui/ViewTemplate/body/code]]
|
|
||||||
code-body: [field:code-body[yes]then[$:/core/ui/ViewTemplate/body/code]]
|
code-body: [field:code-body[yes]then[$:/core/ui/ViewTemplate/body/code]]
|
||||||
import: [field:plugin-type[import]then[$:/core/ui/ViewTemplate/body/import]]
|
import: [field:plugin-type[import]then[$:/core/ui/ViewTemplate/body/import]]
|
||||||
plugin: [has[plugin-type]then[$:/core/ui/ViewTemplate/body/plugin]]
|
plugin: [has[plugin-type]then[$:/core/ui/ViewTemplate/body/plugin]]
|
||||||
|
|||||||
@@ -9,51 +9,26 @@ color:$(foregroundColor)$;
|
|||||||
|
|
||||||
<!-- This has no whitespace trim to avoid modifying $actions$. Closing tags omitted for brevity. -->
|
<!-- This has no whitespace trim to avoid modifying $actions$. Closing tags omitted for brevity. -->
|
||||||
\define tag-pill-inner(tag,icon,colour,fallbackTarget,colourA,colourB,element-tag,element-attributes,actions)
|
\define tag-pill-inner(tag,icon,colour,fallbackTarget,colourA,colourB,element-tag,element-attributes,actions)
|
||||||
\whitespace trim
|
<$vars
|
||||||
<$let
|
|
||||||
foregroundColor=<<contrastcolour target:"""$colour$""" fallbackTarget:"""$fallbackTarget$""" colourA:"""$colourA$""" colourB:"""$colourB$""">>
|
foregroundColor=<<contrastcolour target:"""$colour$""" fallbackTarget:"""$fallbackTarget$""" colourA:"""$colourA$""" colourB:"""$colourB$""">>
|
||||||
backgroundColor=<<__colour__>>
|
backgroundColor="""$colour$"""
|
||||||
>
|
><$element-tag$
|
||||||
<$element-tag$
|
|
||||||
$element-attributes$
|
$element-attributes$
|
||||||
class="tc-tag-label tc-btn-invisible"
|
class="tc-tag-label tc-btn-invisible"
|
||||||
style=<<tag-pill-styles>>
|
style=<<tag-pill-styles>>
|
||||||
>
|
>$actions$<$transclude tiddler="""$icon$"""/><$view tiddler=<<__tag__>> field="title" format="text" /></$element-tag$>
|
||||||
<<__actions__>>
|
|
||||||
<$transclude tiddler=<<__icon__>>/>
|
|
||||||
<$view tiddler=<<__tag__>> field="title" format="text" />
|
|
||||||
</$element-tag$>
|
|
||||||
</$let>
|
|
||||||
\end
|
\end
|
||||||
|
|
||||||
\define tag-pill-body(tag,icon,colour,palette,element-tag,element-attributes,actions)
|
\define tag-pill-body(tag,icon,colour,palette,element-tag,element-attributes,actions)
|
||||||
\whitespace trim
|
<$macrocall $name="tag-pill-inner" tag=<<__tag__>> icon="""$icon$""" colour="""$colour$""" fallbackTarget={{$palette$##tag-background}} colourA={{$palette$##foreground}} colourB={{$palette$##background}} element-tag="""$element-tag$""" element-attributes="""$element-attributes$""" actions="""$actions$"""/>
|
||||||
<$macrocall $name="tag-pill-inner"
|
|
||||||
tag=<<__tag__>>
|
|
||||||
icon=<<__icon__>>
|
|
||||||
colour=<<__colour__>>
|
|
||||||
fallbackTarget={{$palette$##tag-background}}
|
|
||||||
colourA={{$palette$##foreground}}
|
|
||||||
colourB={{$palette$##background}}
|
|
||||||
element-tag=<<__element-tag__>>
|
|
||||||
element-attributes=<<__element-attributes__>>
|
|
||||||
actions=<<__actions__>>
|
|
||||||
/>
|
|
||||||
\end
|
\end
|
||||||
|
|
||||||
\define tag-pill(tag,element-tag:"span",element-attributes:"",actions:"")
|
\define tag-pill(tag,element-tag:"span",element-attributes:"",actions:"")
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
<span class="tc-tag-list-item" data-tag-title=<<__tag__>>>
|
<span class="tc-tag-list-item" data-tag-title=<<__tag__>>>
|
||||||
<$let currentTiddler=<<__tag__>>>
|
<$let currentTiddler=<<__tag__>>>
|
||||||
<$macrocall $name="tag-pill-body"
|
<$macrocall $name="tag-pill-body" tag=<<__tag__>> icon={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerIconFilter]!is[draft]get[text]] }}} colour={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerColourFilter]!is[draft]get[text]] }}} palette={{$:/palette}} element-tag="""$element-tag$""" element-attributes="""$element-attributes$""" actions="""$actions$"""/>
|
||||||
tag=<<__tag__>>
|
</$let>
|
||||||
icon={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerIconFilter]!is[draft]get[text]] }}}
|
|
||||||
colour={{{ [<currentTiddler>] :cascade[all[shadows+tiddlers]tag[$:/tags/TiddlerColourFilter]!is[draft]get[text]] }}}
|
|
||||||
palette={{$:/palette}}
|
|
||||||
element-tag=<<__element-tag__>>
|
|
||||||
element-attributes=<<__element-attributes__>>
|
|
||||||
actions=<<__actions__>>/>
|
|
||||||
</$let>
|
|
||||||
</span>
|
</span>
|
||||||
\end
|
\end
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ tags: $:/tags/Macro
|
|||||||
|
|
||||||
\define toc-caption()
|
\define toc-caption()
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
<span class="tc-toc-caption tc-tiny-gap-left">
|
<span class="tc-toc-caption">
|
||||||
<$set name="tv-wikilinks" value="no">
|
<$set name="tv-wikilinks" value="no">
|
||||||
<$transclude field="caption">
|
<$transclude field="caption">
|
||||||
<$view field="title"/>
|
<$view field="title"/>
|
||||||
@@ -145,7 +145,7 @@ tags: $:/tags/Macro
|
|||||||
<$qualify name="toc-state" title={{{ [[$:/state/toc]addsuffix<__path__>addsuffix[-]addsuffix<currentTiddler>] }}}>
|
<$qualify name="toc-state" title={{{ [[$:/state/toc]addsuffix<__path__>addsuffix[-]addsuffix<currentTiddler>] }}}>
|
||||||
<$set name="toc-item-class" filter=<<__itemClassFilter__>> emptyValue="toc-item-selected" value="toc-item">
|
<$set name="toc-item-class" filter=<<__itemClassFilter__>> emptyValue="toc-item-selected" value="toc-item">
|
||||||
<li class=<<toc-item-class>>>
|
<li class=<<toc-item-class>>>
|
||||||
<$list filter="[all[current]tagging[]$sort$limit[1]]" variable="ignore" emptyMessage="""<$button class="tc-btn-invisible">{{$:/core/images/blank}}</$button><span class="toc-item-muted"><<toc-caption>></span>""">
|
<$list filter="[all[current]tagging[]$sort$limit[1]]" variable="ignore" emptyMessage="<$button class='tc-btn-invisible'>{{$:/core/images/blank}}</$button> <$view field='caption'><$view field='title'/></$view>">
|
||||||
<$reveal type="nomatch" stateTitle=<<toc-state>> text="open">
|
<$reveal type="nomatch" stateTitle=<<toc-state>> text="open">
|
||||||
<$button setTitle=<<toc-state>> setTo="open" class="tc-btn-invisible tc-popup-keep">
|
<$button setTitle=<<toc-state>> setTo="open" class="tc-btn-invisible tc-popup-keep">
|
||||||
<$transclude tiddler=<<toc-closed-icon>> />
|
<$transclude tiddler=<<toc-closed-icon>> />
|
||||||
|
|||||||
@@ -1,2 +1,3 @@
|
|||||||
title: $:/tags/ViewTemplateBodyFilter
|
title: $:/tags/ViewTemplateBodyFilter
|
||||||
list: $:/config/ViewTemplateBodyFilters/hide-body $:/config/ViewTemplateBodyFilters/code-body $:/config/ViewTemplateBodyFilters/stylesheet $:/config/ViewTemplateBodyFilters/core-ui-advanced-search $:/config/ViewTemplateBodyFilters/core-ui-tags $:/config/ViewTemplateBodyFilters/system $:/config/ViewTemplateBodyFilters/import $:/config/ViewTemplateBodyFilters/plugin $:/config/ViewTemplateBodyFilters/default
|
list: $:/config/ViewTemplateBodyFilters/hide-body $:/config/ViewTemplateBodyFilters/code-body $:/config/ViewTemplateBodyFilters/stylesheet $:/config/ViewTemplateBodyFilters/system $:/config/ViewTemplateBodyFilters/import $:/config/ViewTemplateBodyFilters/plugin $:/config/ViewTemplateBodyFilters/default
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
{
|
{
|
||||||
"file": "../../../tw5.com/tiddlers/images/New Release Banner.png",
|
"file": "../../../tw5.com/tiddlers/images/New Release Banner.png",
|
||||||
"fields": {
|
"fields": {
|
||||||
"type": "image/jpeg",
|
"type": "image/jpg",
|
||||||
"title": "New Release Banner",
|
"title": "New Release Banner",
|
||||||
"tags": "picture"
|
"tags": "picture"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,9 +12,6 @@
|
|||||||
"empty": [
|
"empty": [
|
||||||
"--render","$:/core/save/all","empty.html","text/plain",
|
"--render","$:/core/save/all","empty.html","text/plain",
|
||||||
"--render","$:/core/save/all","empty.hta","text/plain"],
|
"--render","$:/core/save/all","empty.hta","text/plain"],
|
||||||
"emptyexternalcore": [
|
|
||||||
"--render","$:/core/save/offline-external-js","empty-external-core.html","text/plain",
|
|
||||||
"--render","$:/core/templates/tiddlywiki5.js","[[tiddlywikicore-]addsuffix<version>addsuffix[.js]]","text/plain"],
|
|
||||||
"externalimages": [
|
"externalimages": [
|
||||||
"--savetiddlers","[is[image]]","images",
|
"--savetiddlers","[is[image]]","images",
|
||||||
"--setfield","[is[image]]","_canonical_uri","$:/core/templates/canonical-uri-external-image","text/plain",
|
"--setfield","[is[image]]","_canonical_uri","$:/core/templates/canonical-uri-external-image","text/plain",
|
||||||
@@ -23,7 +20,7 @@
|
|||||||
"static": [
|
"static": [
|
||||||
"--render","$:/core/templates/static.template.html","static.html","text/plain",
|
"--render","$:/core/templates/static.template.html","static.html","text/plain",
|
||||||
"--render","$:/core/templates/alltiddlers.template.html","alltiddlers.html","text/plain",
|
"--render","$:/core/templates/alltiddlers.template.html","alltiddlers.html","text/plain",
|
||||||
"--render","[!is[system]]","[encodeuricomponent[]addprefix[static/]addsuffix[.html]]","text/plain",
|
"--render","[!is[system]]","[encodeuricomponent[]addprefix[static/]addsuffix[.html]]","text/plain",
|
||||||
"--render","$:/core/templates/static.template.css","static/static.css","text/plain"]
|
"--render","$:/core/templates/static.template.css","static/static.css","text/plain"]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -17,8 +17,8 @@
|
|||||||
],
|
],
|
||||||
"library": [
|
"library": [
|
||||||
"--makelibrary","$:/UpgradeLibrary",
|
"--makelibrary","$:/UpgradeLibrary",
|
||||||
"--savelibrarytiddlers","$:/UpgradeLibrary","[prefix[$:/]] -[[$:/plugins/tiddlywiki/upgrade]] -[[$:/plugins/tiddlywiki/translators]] -[[$:/plugins/tiddlywiki/pluginlibrary]] -[[$:/plugins/tiddlywiki/jasmine]]","recipes/library/tiddlers/","$:/UpgradeLibrary/List",
|
"--savelibrarytiddlers","$:/UpgradeLibrary","[prefix[$:/]] -[[$:/plugins/tiddlywiki/upgrade]] -[[$:/plugins/tiddlywiki/translators]] -[[$:/plugins/tiddlywiki/pluginlibrary]] -[[$:/plugins/tiddlywiki/jasmine]]","recipes/library/tiddlers/","$:/UpgradeLibrary/List",
|
||||||
"--savetiddler","$:/UpgradeLibrary/List","recipes/library/tiddlers.json",
|
"--savetiddler","$:/UpgradeLibrary/List","recipes/library/tiddlers.json",
|
||||||
"--rendertiddler","$:/plugins/tiddlywiki/pluginlibrary/library.template.html","index.html","text/plain"]
|
"--rendertiddler","$:/plugins/tiddlywiki/pluginlibrary/library.template.html","index.html","text/plain"]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,18 +1,11 @@
|
|||||||
caption: 5.3.0
|
caption: 5.3.0
|
||||||
created: 20230701123439630
|
created: 20230506164543446
|
||||||
modified: 20230701123439630
|
modified: 20230506164543446
|
||||||
released: 20230701123439630
|
|
||||||
tags: ReleaseNotes
|
tags: ReleaseNotes
|
||||||
title: Release 5.3.0
|
title: Release 5.3.0
|
||||||
type: text/vnd.tiddlywiki
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
//[[See GitHub for detailed change history of this release|https://github.com/Jermolene/TiddlyWiki5/compare/v5.2.7...v5.3.0]]//
|
//[[See GitHub for detailed change history of this release|https://github.com/Jermolene/TiddlyWiki5/compare/v5.2.7...master]]//
|
||||||
|
|
||||||
<<.banner-credits
|
|
||||||
credit:"""Congratulations to [[vilc|https://talk.tiddlywiki.org/u/vilc]] for their winning design for the banner for this release (here is the [[competition thread|https://talk.tiddlywiki.org/t/banner-image-competition-for-v5-3-0/7406/10]]).
|
|
||||||
"""
|
|
||||||
url:"https://raw.githubusercontent.com/Jermolene/TiddlyWiki5/04950452fab7d5cb86f893020355611c4711d361/editions/tw5.com/tiddlers/images/New%20Release%20Banner.jpg"
|
|
||||||
>>
|
|
||||||
|
|
||||||
! Overview of v5.3.0
|
! Overview of v5.3.0
|
||||||
|
|
||||||
@@ -35,76 +28,49 @@ The approach taken by this release is to add new functionality by extending and
|
|||||||
|
|
||||||
These changes lay the groundwork for macros and related features to be deprecated (which is the point at which users are advised not to use old features, and instead given clear pointers to the equivalent modern functionality).
|
These changes lay the groundwork for macros and related features to be deprecated (which is the point at which users are advised not to use old features, and instead given clear pointers to the equivalent modern functionality).
|
||||||
|
|
||||||
! Text Substitution Improvements
|
The new transclusion architecture is not by itself sufficient to enable us to fully deprecate macros yet. To handle the remaining use cases we propose a new backtick quoted attribute format that allows for the substitution of variable values. See https://github.com/Jermolene/TiddlyWiki5/issues/6663 for details.
|
||||||
|
|
||||||
<<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/pull/7526">> The new transclusion architecture is not by itself sufficient to enable us to fully deprecate macros yet. To handle most of the remaining use cases this release adds convenient new ways of using textual substitution without having to create a macro:
|
|
||||||
|
|
||||||
Firstly, the new [[text substitution syntax for widget attributes|Substituted Attribute Values]] allows widget attributes to be assigned the value of a string with certain placeholders being replaced by their processed contents. For example:
|
|
||||||
|
|
||||||
* Substitute variable names with the value: <$codeblock code="attr=`Current tiddler is $(currentTiddler)$`"/>
|
|
||||||
* Substitute filter expressions with the first value they return: <$codeblock code="attr=```There are ${ [tag[Done]count[]] }$ completed tasks```"/>
|
|
||||||
|
|
||||||
Secondly, the new [[substitute operator|substitute Operator]] allows the same textual substitutions to be performed via a filter operator with the addition of positional parameters that use placeholders of the form `$1$`, `$2$`, `$3$` etc.
|
|
||||||
|
|
||||||
```
|
|
||||||
[[https://$1$/$(currentTiddler)$]substitute<domain-name>]
|
|
||||||
```
|
|
||||||
|
|
||||||
! HTTP Requests in WikiText
|
|
||||||
|
|
||||||
<<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/pull/7422">> new [[WidgetMessage: tm-http-request]] for performing HTTP requests in WikiText. This opens up some exciting new opportunities:
|
|
||||||
|
|
||||||
* Integration with Web-based APIs. The documentation includes an [[example of using the Zotero API|WidgetMessage: tm-http-request Example - Zotero]] to retrieve academic citation data
|
|
||||||
* Dynamic content loading: additional tiddlers can be imported dynamically after the main wiki has loaded
|
|
||||||
|
|
||||||
! Defaulting to Disabling CamelCase Links
|
! Defaulting to Disabling CamelCase Links
|
||||||
|
|
||||||
<<.link-badge-updated "https://github.com/Jermolene/TiddlyWiki5/pull/7513">> CamelCase linking is now disabled by default for new wikis. (Note that this documentation wiki has CamelCase linking explicitly enabled because much of the old content was written relying on them).
|
<<.link-badge-updated "https://github.com/Jermolene/TiddlyWiki5/pull/7513">> CamelCase linking is now disabled by default. (Note that this wiki has CamelCase linking explicitly enabled)
|
||||||
|
|
||||||
! Plugin Improvements
|
! Plugin Improvements
|
||||||
|
|
||||||
* <<.link-badge-updated "https://github.com/Jermolene/TiddlyWiki5/pull/7554">> Google Analytics plugin to use new GA4 code. Note that the update requires manual configuration to use the new "measurement ID" instead of the old "account ID"
|
|
||||||
* <<.link-badge-extended "https://github.com/Jermolene/TiddlyWiki5/pull/7260">> Dynannotate pugin to support three additional search modes
|
* <<.link-badge-extended "https://github.com/Jermolene/TiddlyWiki5/pull/7260">> Dynannotate pugin to support three additional search modes
|
||||||
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7365">> problem with [[BrowserStorage Plugin]] unnecessarily saving shadow tiddlers
|
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7365">> problem with [[BrowserStorage Plugin]] unnecessarily saving shadow tiddlers
|
||||||
|
|
||||||
* <<.link-badge-improved "https://github.com/Jermolene/TiddlyWiki5/pull/7398">> [[BrowserStorage Plugin]] to request that browser storage be persisted without eviction
|
|
||||||
* <<.link-badge-improved "https://github.com/Jermolene/TiddlyWiki5/pull/7493">> [[CodeMirror Plugin]] to add an option to make trailing spaces visible
|
* <<.link-badge-improved "https://github.com/Jermolene/TiddlyWiki5/pull/7493">> [[CodeMirror Plugin]] to add an option to make trailing spaces visible
|
||||||
|
|
||||||
! Translation improvement
|
! Translation improvement
|
||||||
|
|
||||||
Improvements to the following translations:
|
Improvements to the following translations:
|
||||||
|
|
||||||
* French
|
*
|
||||||
* German
|
|
||||||
* Polish
|
! Accessibility Improvements
|
||||||
* Chinese
|
|
||||||
|
*
|
||||||
|
|
||||||
! Usability Improvements
|
! Usability Improvements
|
||||||
|
|
||||||
* <<.link-badge-improved "https://github.com/Jermolene/TiddlyWiki5/pull/7524">> consistency of layout of "Settings" tab in $:/ControlPanel
|
*
|
||||||
|
|
||||||
<!--
|
|
||||||
|
|
||||||
! Widget Improvements
|
! Widget Improvements
|
||||||
|
|
||||||
-->
|
*
|
||||||
|
|
||||||
! Filter improvements
|
! Filter improvements
|
||||||
|
|
||||||
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/pull/7511"> new [[deserialize Operator]] for converting various textual representations of tiddlers into JSON data
|
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/pull/7511"> new [[deserialize Operator]] for converting various textual representations of tiddlers into JSON data
|
||||||
* <<.link-badge-extended "https://github.com/Jermolene/TiddlyWiki5/pull/7292">> [[format Operator]] to support converting Unix timestamps to TiddlyWiki's native date format
|
* <<.link-badge-extended "https://github.com/Jermolene/TiddlyWiki5/pull/7292">> [[format Operator]] to support converting Unix timestamps to TiddlyWiki's native date format
|
||||||
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/pull/7392">> new [[':then' filter run prefix|Then Filter Run Prefix]]
|
|
||||||
|
|
||||||
! Hackability Improvements
|
! Hackability Improvements
|
||||||
|
|
||||||
* <<.link-badge-extended "https://github.com/Jermolene/TiddlyWiki5/pull/7413">> [[Core Icons]] to allow the size to be controlled with a parameter
|
* <<.link-badge-extended "https://github.com/Jermolene/TiddlyWiki5/pull/7413">> [[Core Icons]] to allow the size to be controlled with a parameter
|
||||||
** <<.warning """This change can cause problems with non-standard usage of the core icons where the text is directly rendered instead of being transcluded""">>
|
** <<.warning """This change can cause problems with non-standard usage of the core icons where the text is directly rendered instead of being transcluded""">>
|
||||||
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/pull/7182">> new [[thisTiddler Variable]] that refers to the tiddler currently being rendered
|
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/pull/7182">> new [[thisTiddler Variable]] that refers to the tiddler currently being rendered
|
||||||
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/pull/7530">> `data-tag-title` attribute to all tag pills, allowing easier [[Custom tag pill styles]]
|
|
||||||
* <<.link-badge-improved "https://github.com/Jermolene/TiddlyWiki5/pull/7332">> [[Story Tiddler Template Cascade]] handling to fall back to the default template if the output of the cascade is not valid
|
* <<.link-badge-improved "https://github.com/Jermolene/TiddlyWiki5/pull/7332">> [[Story Tiddler Template Cascade]] handling to fall back to the default template if the output of the cascade is not valid
|
||||||
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7378">> missing file extensions for "audio/mpeg" files
|
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7378">> missing file extensions for "audio/mpeg" files
|
||||||
* <<.link-badge-extended "https://github.com/Jermolene/TiddlyWiki5/pull/7417">> [[Table-of-Contents Macros]] to add consistent support for an ''exclude'' parameter
|
|
||||||
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/commit/190613ad2989f70526f86eef17f524087f60eb72">> [[tv-config-static Variable]] for indicating static rendering
|
|
||||||
|
|
||||||
! Bug Fixes
|
! Bug Fixes
|
||||||
|
|
||||||
@@ -113,17 +79,20 @@ Improvements to the following translations:
|
|||||||
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7380">> crashes when using an invalid CSS selector for [[WidgetMessage: tm-focus-selector]] and [[WidgetMessage: tm-scroll]]
|
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7380">> crashes when using an invalid CSS selector for [[WidgetMessage: tm-focus-selector]] and [[WidgetMessage: tm-scroll]]
|
||||||
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7401">> bug whereby scrolling occurs if the linkcatcher widget triggers an action-navigate and the $scroll attribute is set to "no"
|
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7401">> bug whereby scrolling occurs if the linkcatcher widget triggers an action-navigate and the $scroll attribute is set to "no"
|
||||||
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7409">> problem switching between LTR and RTL text
|
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7409">> problem switching between LTR and RTL text
|
||||||
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7448">> bug when the listField attribute of the CheckboxWidget was given the name of a date field (like <<.field created>> or <<.field modified>>)
|
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/pull/7448">> bug when checkbox widget's listField attribute was given the name of a date field (like <<.field created>> or <<.field modified>>)
|
||||||
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/issues/7529">> size of buttons in dropdown for editor "link" toolbar button
|
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/issues/7529">> size of buttons in dropdown for editor "link" toolbar button
|
||||||
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/commit/8e132948b6bec623d81d300fbe6dc3a0307bcc6d">> crash when transcluding a lazily loaded tiddler as an attribute value
|
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/commit/8e132948b6bec623d81d300fbe6dc3a0307bcc6d">> crash when transcluding a lazily loaded tiddler as an attribute value
|
||||||
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/issues/7462">> DiffTextWidget crash with missing or empty attributes
|
* <<.link-badge-fixed "https://github.com/Jermolene/TiddlyWiki5/issues/7462">> DiffTextWidget crash with missing or empty attributes
|
||||||
|
|
||||||
|
! Developer Improvements
|
||||||
|
|
||||||
|
*
|
||||||
|
|
||||||
! Node.js Improvements
|
! Node.js Improvements
|
||||||
|
|
||||||
* <<.link-badge-extended "https://github.com/Jermolene/TiddlyWiki5/pull/7471">> [[WebServer Parameter: authenticated-user-header]] to require URI encoding of authenticated username header, permitting non-ASCII characters in usernames
|
* <<.link-badge-extended "https://github.com/Jermolene/TiddlyWiki5/pull/7471">> [[WebServer Parameter: authenticated-user-header]] to require URI encoding of authenticated username header, permitting non-ASCII characters in usernames
|
||||||
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/pull/7253">> support for `filepath` source attribute to [[tiddlywiki.files Files]]
|
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/pull/7253">> support for `filepath` source attribute to [[tiddlywiki.files Files]]
|
||||||
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/commit/48b22abdaab62c281c207127c66883b50898f9dd">> a warning message for JSON errors in [[tiddlywiki.info Files]] or [[plugin.info Files|PluginFolders]]
|
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/commit/48b22abdaab62c281c207127c66883b50898f9dd">> a warning message for JSON errors in [[tiddlywiki.info Files]] or [[plugin.info Files|PluginFolders]]
|
||||||
* <<.link-badge-added "https://github.com/Jermolene/TiddlyWiki5/pull/7490">> new "explodePlugins" option to SaveWikiFolderCommand
|
|
||||||
|
|
||||||
! Performance Improvements
|
! Performance Improvements
|
||||||
|
|
||||||
@@ -134,15 +103,10 @@ Improvements to the following translations:
|
|||||||
[[@Jermolene|https://github.com/Jermolene]] would like to thank the contributors to this release who have generously given their time to help improve TiddlyWiki:
|
[[@Jermolene|https://github.com/Jermolene]] would like to thank the contributors to this release who have generously given their time to help improve TiddlyWiki:
|
||||||
|
|
||||||
<<.contributors """
|
<<.contributors """
|
||||||
AnthonyMuscio
|
|
||||||
Arlen22
|
Arlen22
|
||||||
BramChen
|
BramChen
|
||||||
btheado
|
btheado
|
||||||
buggyj
|
|
||||||
carlo-colombo
|
|
||||||
cdruan
|
|
||||||
donmor
|
donmor
|
||||||
EvidentlyCube
|
|
||||||
flibbles
|
flibbles
|
||||||
GameDungeon
|
GameDungeon
|
||||||
JoshuaFontany
|
JoshuaFontany
|
||||||
@@ -152,13 +116,10 @@ Marxsal
|
|||||||
mateuszwilczek
|
mateuszwilczek
|
||||||
michsa
|
michsa
|
||||||
muzimuzhi
|
muzimuzhi
|
||||||
oeyoews
|
|
||||||
pmario
|
pmario
|
||||||
rmunn
|
rmunn
|
||||||
saqimtiaz
|
saqimtiaz
|
||||||
tavin
|
tavin
|
||||||
twMat
|
twMat
|
||||||
xcazin
|
|
||||||
yaisog
|
yaisog
|
||||||
Zacharia2
|
|
||||||
""">>
|
""">>
|
||||||
@@ -1,60 +0,0 @@
|
|||||||
caption: 5.3.2
|
|
||||||
created: 20230820114855583
|
|
||||||
modified: 20230820114855583
|
|
||||||
tags: ReleaseNotes
|
|
||||||
title: Release 5.3.2
|
|
||||||
type: text/vnd.tiddlywiki
|
|
||||||
|
|
||||||
//[[See GitHub for detailed change history of this release|https://github.com/Jermolene/TiddlyWiki5/compare/v5.3.1...master]]//
|
|
||||||
|
|
||||||
! Translation improvement
|
|
||||||
|
|
||||||
Improvements to the following translations:
|
|
||||||
|
|
||||||
*
|
|
||||||
|
|
||||||
! Widget Improvements
|
|
||||||
|
|
||||||
*
|
|
||||||
|
|
||||||
! Hackability Improvements
|
|
||||||
|
|
||||||
*
|
|
||||||
|
|
||||||
! Bug Fixes
|
|
||||||
|
|
||||||
*
|
|
||||||
|
|
||||||
! Node.js Improvements
|
|
||||||
|
|
||||||
*
|
|
||||||
|
|
||||||
! Developer Improvements
|
|
||||||
|
|
||||||
*
|
|
||||||
|
|
||||||
! Acknowledgements
|
|
||||||
|
|
||||||
[[@Jermolene|https://github.com/Jermolene]] would like to thank the contributors to this release who have generously given their time to help improve TiddlyWiki:
|
|
||||||
|
|
||||||
<<.contributors """
|
|
||||||
AnthonyMuscio
|
|
||||||
btheado
|
|
||||||
catter-fly
|
|
||||||
cmo-pomerium
|
|
||||||
CrossEye
|
|
||||||
flibbles
|
|
||||||
hffqyd
|
|
||||||
lilscribby
|
|
||||||
linonetwo
|
|
||||||
Marxsal
|
|
||||||
mateuszwilczek
|
|
||||||
pille1842
|
|
||||||
pmario
|
|
||||||
rmunn
|
|
||||||
saqimtiaz
|
|
||||||
stevesunypoly
|
|
||||||
TiddlyTweeter
|
|
||||||
twMat
|
|
||||||
yaisog
|
|
||||||
""">>
|
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
title: $:/config/LocalPluginLibrary
|
title: $:/config/LocalPluginLibrary
|
||||||
tags: $:/tags/PluginLibrary
|
tags: $:/tags/PluginLibrary
|
||||||
url: http://127.0.0.1:8080/prerelease/library/v5.3.2/index.html
|
url: http://127.0.0.1:8080/prerelease/library/v5.2.2/index.html
|
||||||
caption: {{$:/language/OfficialPluginLibrary}} (Prerelease Local)
|
caption: {{$:/language/OfficialPluginLibrary}} (Prerelease Local)
|
||||||
|
|
||||||
A locally installed version of the official ~TiddlyWiki plugin library at tiddlywiki.com for testing and debugging. //Requires a local web server to share the library//
|
A locally installed version of the official ~TiddlyWiki plugin library at tiddlywiki.com for testing and debugging. //Requires a local web server to share the library//
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
title: $:/config/OfficialPluginLibrary
|
title: $:/config/OfficialPluginLibrary
|
||||||
tags: $:/tags/PluginLibrary
|
tags: $:/tags/PluginLibrary
|
||||||
url: https://tiddlywiki.com/prerelease/library/v5.3.2/index.html
|
url: https://tiddlywiki.com/prerelease/library/v5.2.8/index.html
|
||||||
caption: {{$:/language/OfficialPluginLibrary}} (Prerelease)
|
caption: {{$:/language/OfficialPluginLibrary}} (Prerelease)
|
||||||
|
|
||||||
The prerelease version of the official ~TiddlyWiki plugin library at tiddlywiki.com. Plugins, themes and language packs are maintained by the core team.
|
The prerelease version of the official ~TiddlyWiki plugin library at tiddlywiki.com. Plugins, themes and language packs are maintained by the core team.
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
title: TiddlyWiki Pre-release
|
title: TiddlyWiki Pre-release
|
||||||
modified: 20230731122156493
|
modified: 20150428204930183
|
||||||
|
|
||||||
This is a pre-release build of TiddlyWiki provided for testing and review purposes. ''Please don't try to depend on the pre-release for anything important'' -- you should use the latest official release from https://tiddlywiki.com.
|
This is a pre-release build of TiddlyWiki provided for testing and review purposes. ''Please don't try to depend on the pre-release for anything important'' -- you should use the latest official release from https://tiddlywiki.com.
|
||||||
|
|
||||||
|
|||||||
@@ -20,4 +20,4 @@
|
|||||||
"favicon": [
|
"favicon": [
|
||||||
"--savetiddler","$:/favicon.ico","favicon.ico"]
|
"--savetiddler","$:/favicon.ico","favicon.ico"]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -17,7 +17,7 @@
|
|||||||
"static": [
|
"static": [
|
||||||
"--render","$:/core/templates/static.template.html","static.html","text/plain",
|
"--render","$:/core/templates/static.template.html","static.html","text/plain",
|
||||||
"--render","$:/core/templates/alltiddlers.template.html","alltiddlers.html","text/plain",
|
"--render","$:/core/templates/alltiddlers.template.html","alltiddlers.html","text/plain",
|
||||||
"--render","[!is[system]]","[encodeuricomponent[]addprefix[static/]addsuffix[.html]]","text/plain",
|
"--render","[!is[system]]","[encodeuricomponent[]addprefix[static/]addsuffix[.html]]","text/plain",
|
||||||
"--render","$:/core/templates/static.template.css","static/static.css","text/plain"],
|
"--render","$:/core/templates/static.template.css","static/static.css","text/plain"],
|
||||||
"tiddlywikicore": [
|
"tiddlywikicore": [
|
||||||
"--render","$:/core/templates/tiddlywiki5.js","[[tiddlywikicore-]addsuffix<version>addsuffix[.js]]","text/plain"]
|
"--render","$:/core/templates/tiddlywiki5.js","[[tiddlywikicore-]addsuffix<version>addsuffix[.js]]","text/plain"]
|
||||||
|
|||||||
@@ -1,40 +0,0 @@
|
|||||||
title: Filters/substitute
|
|
||||||
description: Test substitute operator
|
|
||||||
type: text/vnd.tiddlywiki-multiple
|
|
||||||
tags: [[$:/tags/wiki-test-spec]]
|
|
||||||
|
|
||||||
title: substitute filter data 1
|
|
||||||
tags: Hello There [[Welcome to TiddlyWiki]] GettingStarted
|
|
||||||
|
|
||||||
TiddlyWiki
|
|
||||||
+
|
|
||||||
title: substitute filter data 2
|
|
||||||
|
|
||||||
The output of the filter `[[substitute filter data 1]tags[]]` is ${[[substitute filter data 1]tags[]]}$.
|
|
||||||
+
|
|
||||||
title: substitute filter data 3
|
|
||||||
|
|
||||||
Welcome to $(projectname)$ $1$ $2$ $3$. Tiddlers starting with `substitute`: ${[prefix[substitute]format:titlelist[]join[ ]]}$.
|
|
||||||
+
|
|
||||||
title: Output
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
<$let projectname="TiddlyWiki">
|
|
||||||
(<$text text={{{ [[]substitute[]] }}}/>)
|
|
||||||
(<$text text={{{ [[Hello There, welcome to $TiddlyWiki$]substitute[]] }}}/>)
|
|
||||||
(<$text text={{{ [[Welcome to $(projectname)$]substitute[]] }}}/>)
|
|
||||||
(<$text text={{{ [[Welcome to $(projectname)$ $1$]substitute[today]] }}}/>)
|
|
||||||
(<$text text={{{ [[This is not a valid embedded filter ${ hello )$]substitute[]] }}}/>)
|
|
||||||
(<$text text={{{ [{substitute filter data 2}substitute[]] }}}/>)
|
|
||||||
(<$text text={{{ [{substitute filter data 3}substitute[every],[day]] }}}/>)
|
|
||||||
</$let>
|
|
||||||
+
|
|
||||||
title: ExpectedResult
|
|
||||||
|
|
||||||
<p>()
|
|
||||||
(Hello There, welcome to $TiddlyWiki$)
|
|
||||||
(Welcome to TiddlyWiki)
|
|
||||||
(Welcome to TiddlyWiki today)
|
|
||||||
(This is not a valid embedded filter ${ hello )$)
|
|
||||||
(The output of the filter `[[substitute filter data 1]tags[]]` is Hello.)
|
|
||||||
(Welcome to TiddlyWiki every day $3$. Tiddlers starting with `substitute`: [[substitute filter data 1]] [[substitute filter data 2]] [[substitute filter data 3]].)</p>
|
|
||||||
@@ -1,24 +0,0 @@
|
|||||||
title: Functions/Function/Indented
|
|
||||||
description: Indented function definition
|
|
||||||
type: text/vnd.tiddlywiki-multiple
|
|
||||||
tags: [[$:/tags/wiki-test-spec]]
|
|
||||||
|
|
||||||
title: Output
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
\function .dividebysomething(factor:0.5)
|
|
||||||
[divide<factor>]
|
|
||||||
\end
|
|
||||||
|
|
||||||
\function multiplebysomething(first:ignored,factor:2)
|
|
||||||
[multiply<factor>multiply[2].dividebysomething[0.25]]
|
|
||||||
\end
|
|
||||||
|
|
||||||
<$text text={{{ [[4]function[multiplebysomething]] }}}/>
|
|
||||||
|
|
|
||||||
<$text text={{{ [[6]function[multiplebysomething],[ignored],[4]] }}}/>
|
|
||||||
|
|
||||||
+
|
|
||||||
title: ExpectedResult
|
|
||||||
|
|
||||||
<p>64|192</p>
|
|
||||||
@@ -33,4 +33,4 @@ $param$ with a ''buffalo''
|
|||||||
+
|
+
|
||||||
title: ExpectedResult
|
title: ExpectedResult
|
||||||
|
|
||||||
<p>Going to lunch with a ''buffalo''</p><p>Going to breakfastwith a<strong>buffalo</strong></p><p>Going to dinner with a <strong>buffalo</strong></p>Going to lunch with a ''buffalo''Going to breakfastwith abuffaloGoing to dinner with a buffalo
|
<p>Going to lunch with a ''buffalo''</p><p>Going to breakfastwith a<strong>buffalo</strong></p><p>Going to dinner with a <strong>buffalo</strong></p>Going to lunch with a buffalo with a buffaloGoing to dinner with a buffalo
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
title: ImportVariables/WithSetWidgets
|
|
||||||
description: Import variables defined with a set widget
|
|
||||||
type: text/vnd.tiddlywiki-multiple
|
|
||||||
tags: [[$:/tags/wiki-test-spec]]
|
|
||||||
|
|
||||||
title: Output
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
\import Definitions
|
|
||||||
<$text text=<<one>>/>,
|
|
||||||
<$text text=<<two>>/>
|
|
||||||
+
|
|
||||||
title: Definitions
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
<$set name="one" value="elephant">
|
|
||||||
<$set name="two" value="giraffe">
|
|
||||||
</$set>
|
|
||||||
</$set>
|
|
||||||
+
|
|
||||||
title: ExpectedResult
|
|
||||||
|
|
||||||
<p>elephant,giraffe</p>
|
|
||||||
@@ -1,22 +0,0 @@
|
|||||||
title: ImportVariables/WithSetWidgets2
|
|
||||||
description: Import variables defined with a set widget without whitespace pragma
|
|
||||||
type: text/vnd.tiddlywiki-multiple
|
|
||||||
tags: [[$:/tags/wiki-test-spec]]
|
|
||||||
|
|
||||||
title: Output
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
\import Definitions
|
|
||||||
<$text text=<<one>>/>,
|
|
||||||
<$text text=<<two>>/>
|
|
||||||
+
|
|
||||||
title: Definitions
|
|
||||||
|
|
||||||
<$set name="one" value="elephant">
|
|
||||||
<$set name="two" value="giraffe">
|
|
||||||
</$set>
|
|
||||||
</$set>
|
|
||||||
+
|
|
||||||
title: ExpectedResult
|
|
||||||
|
|
||||||
<p>elephant,giraffe</p>
|
|
||||||
@@ -1,29 +0,0 @@
|
|||||||
title: ImportVariables/WithSetWidgetsAndMacros
|
|
||||||
description: Import variables defined with a set widget without whitespace pragma
|
|
||||||
type: text/vnd.tiddlywiki-multiple
|
|
||||||
tags: [[$:/tags/wiki-test-spec]]
|
|
||||||
|
|
||||||
title: Output
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
\import Definitions
|
|
||||||
<$text text=<<name>>/>,
|
|
||||||
<$text text=<<address>>/>,
|
|
||||||
<$text text=<<one>>/>,
|
|
||||||
<$text text=<<two>>/>
|
|
||||||
+
|
|
||||||
title: Definitions
|
|
||||||
|
|
||||||
\define name() Bugs Bunny
|
|
||||||
\procedure address()
|
|
||||||
Bunny Hill
|
|
||||||
\end
|
|
||||||
|
|
||||||
<$set name="one" value="elephant">
|
|
||||||
<$set name="two" value="giraffe">
|
|
||||||
</$set>
|
|
||||||
</$set>
|
|
||||||
+
|
|
||||||
title: ExpectedResult
|
|
||||||
|
|
||||||
<p>Bugs Bunny,Bunny Hill,elephant,giraffe</p>
|
|
||||||
@@ -1,20 +0,0 @@
|
|||||||
title: Procedures/Nested/Indented
|
|
||||||
description: Nested Procedures that are indented
|
|
||||||
type: text/vnd.tiddlywiki-multiple
|
|
||||||
tags: [[$:/tags/wiki-test-spec]]
|
|
||||||
|
|
||||||
title: Output
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
\procedure alpha(x)
|
|
||||||
\procedure beta(y)
|
|
||||||
<$text text=<<y>>/>
|
|
||||||
\end beta
|
|
||||||
<$transclude $variable="beta" y={{{ [<x>addprefix<x>] }}}/>
|
|
||||||
\end alpha
|
|
||||||
|
|
||||||
<<alpha "Elephant">>
|
|
||||||
+
|
|
||||||
title: ExpectedResult
|
|
||||||
|
|
||||||
<p>ElephantElephant</p>
|
|
||||||
@@ -1,22 +0,0 @@
|
|||||||
title: Procedures/TrailingNewlines
|
|
||||||
description: Trailing newlines in procedures must not be dropped
|
|
||||||
type: text/vnd.tiddlywiki-multiple
|
|
||||||
tags: [[$:/tags/wiki-test-spec]]
|
|
||||||
|
|
||||||
title: Output
|
|
||||||
|
|
||||||
\procedure inner()
|
|
||||||
Paragraph 1
|
|
||||||
|
|
||||||
Paragraph 2
|
|
||||||
\end
|
|
||||||
\procedure outer()
|
|
||||||
<$macrocall $name=inner />
|
|
||||||
|
|
||||||
\end
|
|
||||||
<<outer>>
|
|
||||||
|
|
||||||
+
|
|
||||||
title: ExpectedResult
|
|
||||||
|
|
||||||
<p>Paragraph 1</p><p>Paragraph 2</p>
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
title: Transclude/CustomWidget/Simple/Indented
|
|
||||||
description: Custom widget definition indented
|
|
||||||
type: text/vnd.tiddlywiki-multiple
|
|
||||||
tags: [[$:/tags/wiki-test-spec]]
|
|
||||||
|
|
||||||
title: Output
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
<$transclude $tiddler='TiddlerOne' one='Ferret'>
|
|
||||||
</$transclude>
|
|
||||||
+
|
|
||||||
title: TiddlerOne
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
<!-- Define the <$my.widget> widget by defining a transcludable variable with that name -->
|
|
||||||
\widget $my.widget(one:'Jaguar')
|
|
||||||
\whitespace trim
|
|
||||||
<$text text=<<one>>/>
|
|
||||||
<$slot $name="ts-raw">
|
|
||||||
Whale
|
|
||||||
</$slot>
|
|
||||||
\end
|
|
||||||
<$my.widget one="Dingo">
|
|
||||||
Crocodile
|
|
||||||
</$my.widget>
|
|
||||||
<$my.widget one="BumbleBee">
|
|
||||||
Squirrel
|
|
||||||
</$my.widget>
|
|
||||||
<$my.widget/>
|
|
||||||
+
|
|
||||||
title: ExpectedResult
|
|
||||||
|
|
||||||
<p>DingoCrocodileBumbleBeeSquirrelJaguarWhale</p>
|
|
||||||
@@ -1,20 +0,0 @@
|
|||||||
title: Transclude/Parameterised/Shortcut/ParametersIndented
|
|
||||||
description: Simple parameterised transclusion using the parameters pragma (indented)
|
|
||||||
type: text/vnd.tiddlywiki-multiple
|
|
||||||
tags: [[$:/tags/wiki-test-spec]]
|
|
||||||
|
|
||||||
title: Output
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
<$transclude $tiddler='TiddlerOne' one='Ferret'/>
|
|
||||||
<$transclude $tiddler='TiddlerOne'/>
|
|
||||||
+
|
|
||||||
title: TiddlerOne
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
\parameters(one:'Jaguar')
|
|
||||||
<$text text=<<one>>/>
|
|
||||||
+
|
|
||||||
title: ExpectedResult
|
|
||||||
|
|
||||||
<p>FerretJaguar</p>
|
|
||||||
@@ -1,26 +0,0 @@
|
|||||||
title: Procedures/Double/Underscore
|
|
||||||
description: Checking that procedures don't expose parameters as variables wrapped in double underscores
|
|
||||||
type: text/vnd.tiddlywiki-multiple
|
|
||||||
tags: [[$:/tags/wiki-test-spec]]
|
|
||||||
|
|
||||||
title: Output
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
\procedure mamacro(one:"red",two:"green")
|
|
||||||
It is $one$ and $two$<<__one__>><<__two__>>.
|
|
||||||
\end
|
|
||||||
|
|
||||||
<$macrocall $name="mamacro"/>
|
|
||||||
|
|
||||||
<$transclude $variable="mamacro"/>
|
|
||||||
|
|
||||||
<$transclude $variable="mamacro" one="orange"/>
|
|
||||||
|
|
||||||
<$transclude $variable="mamacro" 0="pink"/>
|
|
||||||
|
|
||||||
<$transclude $variable="mamacro" one="purple" 1="pink"/>
|
|
||||||
|
|
||||||
+
|
|
||||||
title: ExpectedResult
|
|
||||||
|
|
||||||
<p>It is $one$ and $two$.</p><p>It is $one$ and $two$.</p><p>It is $one$ and $two$.</p><p>It is $one$ and $two$.</p><p>It is $one$ and $two$.</p>
|
|
||||||
@@ -1,21 +0,0 @@
|
|||||||
title: Widgets/SubstitutedAttributes
|
|
||||||
description: Attributes specified as string that should have substitution performed.
|
|
||||||
type: text/vnd.tiddlywiki-multiple
|
|
||||||
tags: [[$:/tags/wiki-test-spec]]
|
|
||||||
|
|
||||||
title: Output
|
|
||||||
|
|
||||||
\whitespace trim
|
|
||||||
<$set name="var with spaces" value="spaces">
|
|
||||||
<$let project="TiddlyWiki" disabled="true" var-with-dashes="dashes">
|
|
||||||
<div class=`$(project)$
|
|
||||||
${ [[Hello]addsuffix[There]] }$` attrib=`myvalue` otherattrib=`$(1)$` blankattrib=`` quoted="here" disabled=```$(disabled)$``` dashes=`$(var-with-dashes)$` spaces=`$(var with spaces)$`>
|
|
||||||
</div>
|
|
||||||
</$let>
|
|
||||||
</$set>
|
|
||||||
|
|
||||||
+
|
|
||||||
title: ExpectedResult
|
|
||||||
|
|
||||||
<p><div attrib="myvalue" blankattrib="" class="TiddlyWiki
|
|
||||||
HelloThere" dashes="dashes" disabled="true" otherattrib="" quoted="here" spaces="spaces"></div></p>
|
|
||||||
@@ -397,8 +397,8 @@ Tests the filtering mechanism.
|
|||||||
expect(wiki.filterTiddlers("[all[shadows]tag[two]]").join(",")).toBe("$:/TiddlerFive");
|
expect(wiki.filterTiddlers("[all[shadows]tag[two]]").join(",")).toBe("$:/TiddlerFive");
|
||||||
expect(wiki.filterTiddlers("[all[shadows+tiddlers]tag[two]]").join(",")).toBe("$:/TiddlerFive,$:/TiddlerTwo,Tiddler Three");
|
expect(wiki.filterTiddlers("[all[shadows+tiddlers]tag[two]]").join(",")).toBe("$:/TiddlerFive,$:/TiddlerTwo,Tiddler Three");
|
||||||
expect(wiki.filterTiddlers("[all[tiddlers+shadows]tag[two]]").join(",")).toBe("$:/TiddlerTwo,Tiddler Three,$:/TiddlerFive");
|
expect(wiki.filterTiddlers("[all[tiddlers+shadows]tag[two]]").join(",")).toBe("$:/TiddlerTwo,Tiddler Three,$:/TiddlerFive");
|
||||||
expect(wiki.filterTiddlers("[all[shadows+tiddlers]]").join(",")).toBe("$:/TiddlerFive,Tiddler8,TiddlerSeventh,TiddlerSix,$:/ShadowPlugin,$:/TiddlerTwo,a fourth tiddler,filter regexp test,has filter,hasList,one,Tiddler Three,TiddlerOne");
|
expect(wiki.filterTiddlers("[all[shadows+tiddlers]]").join(",")).toBe("$:/TiddlerFive,TiddlerSix,TiddlerSeventh,Tiddler8,$:/ShadowPlugin,$:/TiddlerTwo,a fourth tiddler,filter regexp test,has filter,hasList,one,Tiddler Three,TiddlerOne");
|
||||||
expect(wiki.filterTiddlers("[all[tiddlers+shadows]]").join(",")).toBe("$:/ShadowPlugin,$:/TiddlerTwo,a fourth tiddler,filter regexp test,has filter,hasList,one,Tiddler Three,TiddlerOne,$:/TiddlerFive,Tiddler8,TiddlerSeventh,TiddlerSix");
|
expect(wiki.filterTiddlers("[all[tiddlers+shadows]]").join(",")).toBe("$:/ShadowPlugin,$:/TiddlerTwo,a fourth tiddler,filter regexp test,has filter,hasList,one,Tiddler Three,TiddlerOne,$:/TiddlerFive,TiddlerSix,TiddlerSeventh,Tiddler8");
|
||||||
expect(wiki.filterTiddlers("[all[tiddlers]tag[two]]").join(",")).toBe("$:/TiddlerTwo,Tiddler Three");
|
expect(wiki.filterTiddlers("[all[tiddlers]tag[two]]").join(",")).toBe("$:/TiddlerTwo,Tiddler Three");
|
||||||
expect(wiki.filterTiddlers("[all[orphans+tiddlers+tags]]").join(",")).toBe("$:/ShadowPlugin,$:/TiddlerTwo,a fourth tiddler,filter regexp test,has filter,hasList,Tiddler Three,TiddlerOne,two,one");
|
expect(wiki.filterTiddlers("[all[orphans+tiddlers+tags]]").join(",")).toBe("$:/ShadowPlugin,$:/TiddlerTwo,a fourth tiddler,filter regexp test,has filter,hasList,Tiddler Three,TiddlerOne,two,one");
|
||||||
});
|
});
|
||||||
@@ -420,10 +420,10 @@ Tests the filtering mechanism.
|
|||||||
|
|
||||||
it("should handle the tagging operator", function() {
|
it("should handle the tagging operator", function() {
|
||||||
expect(wiki.filterTiddlers("[[one]tagging[]sort[title]]").join(",")).toBe("Tiddler Three,Tiddler8,TiddlerOne,TiddlerSeventh");
|
expect(wiki.filterTiddlers("[[one]tagging[]sort[title]]").join(",")).toBe("Tiddler Three,Tiddler8,TiddlerOne,TiddlerSeventh");
|
||||||
expect(wiki.filterTiddlers("[[one]tagging[]]").join(",")).toBe("Tiddler Three,TiddlerOne,Tiddler8,TiddlerSeventh");
|
expect(wiki.filterTiddlers("[[one]tagging[]]").join(",")).toBe("Tiddler Three,TiddlerOne,TiddlerSeventh,Tiddler8");
|
||||||
expect(wiki.filterTiddlers("[[two]tagging[]sort[title]]").join(",")).toBe("$:/TiddlerFive,$:/TiddlerTwo,Tiddler Three");
|
expect(wiki.filterTiddlers("[[two]tagging[]sort[title]]").join(",")).toBe("$:/TiddlerFive,$:/TiddlerTwo,Tiddler Three");
|
||||||
var fakeWidget = {wiki: wiki, getVariable: function(name) {return name === "currentTiddler" ? "one": undefined;}};
|
var fakeWidget = {wiki: wiki, getVariable: function(name) {return name === "currentTiddler" ? "one": undefined;}};
|
||||||
expect(wiki.filterTiddlers("[all[current]tagging[]]",fakeWidget).join(",")).toBe("Tiddler Three,TiddlerOne,Tiddler8,TiddlerSeventh");
|
expect(wiki.filterTiddlers("[all[current]tagging[]]",fakeWidget).join(",")).toBe("Tiddler Three,TiddlerOne,TiddlerSeventh,Tiddler8");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should handle the untagged operator", function() {
|
it("should handle the untagged operator", function() {
|
||||||
|
|||||||
@@ -161,16 +161,6 @@ describe("HTML tag new parser tests", function() {
|
|||||||
expect($tw.utils.parseAttribute(" attrib1>",0)).toEqual(
|
expect($tw.utils.parseAttribute(" attrib1>",0)).toEqual(
|
||||||
{ type : 'string', value : 'true', start : 0, name : 'attrib1', end : 8 }
|
{ type : 'string', value : 'true', start : 0, name : 'attrib1', end : 8 }
|
||||||
);
|
);
|
||||||
expect($tw.utils.parseAttribute("p=`blah` ",1)).toEqual(null);
|
|
||||||
expect($tw.utils.parseAttribute("p=`blah` ",0)).toEqual(
|
|
||||||
{ start: 0, name: 'p', type: 'substituted', rawValue: 'blah', end: 8 }
|
|
||||||
);
|
|
||||||
expect($tw.utils.parseAttribute("p=```blah``` ",0)).toEqual(
|
|
||||||
{ start: 0, name: 'p', type: 'substituted', rawValue: 'blah', end: 12 }
|
|
||||||
);
|
|
||||||
expect($tw.utils.parseAttribute("p=`Hello \"There\"`",0)).toEqual(
|
|
||||||
{ start: 0, name: 'p', type: 'substituted', rawValue: 'Hello "There"', end: 17 }
|
|
||||||
);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should parse HTML tags", function() {
|
it("should parse HTML tags", function() {
|
||||||
|
|||||||
@@ -434,15 +434,6 @@ describe("'reduce' and 'intersection' filter prefix tests", function() {
|
|||||||
expect(wiki.filterTiddlers("[tag[shopping]] :map[get[title]addprefix[-]addprefix<length>addprefix[of]addprefix<index>]").join(",")).toBe("0of4-Brownies,1of4-Chick Peas,2of4-Milk,3of4-Rice Pudding");
|
expect(wiki.filterTiddlers("[tag[shopping]] :map[get[title]addprefix[-]addprefix<length>addprefix[of]addprefix<index>]").join(",")).toBe("0of4-Brownies,1of4-Chick Peas,2of4-Milk,3of4-Rice Pudding");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should handle the :then prefix", function() {
|
|
||||||
expect(wiki.filterTiddlers("[[one]] :then[[two]]").join(",")).toBe("two");
|
|
||||||
expect(wiki.filterTiddlers("[[one]] :then[tag[shopping]]").join(",")).toBe("Brownies,Chick Peas,Milk,Rice Pudding");
|
|
||||||
expect(wiki.filterTiddlers("[[one]] [[two]] [[three]] :then[[four]]").join(",")).toBe("four");
|
|
||||||
expect(wiki.filterTiddlers("[[one]] :then[tag[nonexistent]]").join(",")).toBe("one");
|
|
||||||
expect(wiki.filterTiddlers(":then[[two]]").length).toBe(0);
|
|
||||||
expect(wiki.filterTiddlers("[[notatiddler]is[tiddler]] :then[[two]]").length).toBe(0);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should handle macro parameters for filter run prefixes",function() {
|
it("should handle macro parameters for filter run prefixes",function() {
|
||||||
var widget = require("$:/core/modules/widgets/widget.js");
|
var widget = require("$:/core/modules/widgets/widget.js");
|
||||||
var rootWidget = new widget.widget({ type:"widget", children:[ {type:"widget", children:[]} ] },
|
var rootWidget = new widget.widget({ type:"widget", children:[ {type:"widget", children:[]} ] },
|
||||||
|
|||||||
@@ -21,7 +21,7 @@
|
|||||||
"static": [
|
"static": [
|
||||||
"--render","$:/core/templates/static.template.html","static.html","text/plain",
|
"--render","$:/core/templates/static.template.html","static.html","text/plain",
|
||||||
"--render","$:/core/templates/alltiddlers.template.html","alltiddlers.html","text/plain",
|
"--render","$:/core/templates/alltiddlers.template.html","alltiddlers.html","text/plain",
|
||||||
"--render","[!is[system]]","[encodeuricomponent[]addprefix[static/]addsuffix[.html]]","text/plain","$:/core/templates/static.tiddler.html",
|
"--render","[!is[system]]","[encodeuricomponent[]addprefix[static/]addsuffix[.html]]","text/plain","$:/core/templates/static.tiddler.html",
|
||||||
"--render","$:/core/templates/static.template.css","static/static.css","text/plain"]
|
"--render","$:/core/templates/static.template.css","static/static.css","text/plain"]
|
||||||
},
|
},
|
||||||
"config": {
|
"config": {
|
||||||
|
|||||||
11
editions/tw5.com/tiddlers/Right-To-Left Languages.tid
Normal file
11
editions/tw5.com/tiddlers/Right-To-Left Languages.tid
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
created: 20230613162508509
|
||||||
|
modified: 20230613162508509
|
||||||
|
title: Right-To-Left Languages
|
||||||
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
|
<<.from-version "5.3.0">> The [[language plugins|Languages]] in TiddlyWiki's plugin library apply the appropriate [["right-to-left" setting|https://www.w3.org/International/questions/qa-html-dir]] to the entire document. To set the right to left setting independently for an individual tiddler, use the `\dir` [[pragma|Pragma]] at the top of the tiddler:
|
||||||
|
|
||||||
|
```
|
||||||
|
\dir rtl
|
||||||
|
This text will be displayed with right-to-left formatting
|
||||||
|
```
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
caption: ~TiddlyStow (experimental)
|
caption: TiddlyStow (experimental)
|
||||||
color: #FF8A65
|
color: #FF8A65
|
||||||
created: 20230403170650008
|
created: 20230403170650008
|
||||||
delivery: Saver
|
delivery: Saver
|
||||||
@@ -13,4 +13,4 @@ url: https://github.com/btheado/tiddlystow
|
|||||||
''Link:'' {{!!url}}
|
''Link:'' {{!!url}}
|
||||||
|
|
||||||
Tiddlystow saves TiddlyWiki files locally using the browser file system API (Chrome-based browsers currently).
|
Tiddlystow saves TiddlyWiki files locally using the browser file system API (Chrome-based browsers currently).
|
||||||
This is a simple web page for loading a local TiddlyWiki file and storing it back to the same local file requiring no plugins or extensions.
|
This is a simple web page for loading a local TiddlyWiki file and storing it back to the same local file requiring no plugins or extensions.
|
||||||
@@ -1,11 +1,11 @@
|
|||||||
created: 20140129085406905
|
created: 20140129085406905
|
||||||
modified: 20230805140720289
|
modified: 20210106151027268
|
||||||
tags: [[Other Resources]] Articles
|
tags: [[Other Resources]] Articles
|
||||||
title: "TiddlyWiki Posts" by Jeffrey Kishner
|
title: "TiddlyWiki Posts" by Jeffrey Kishner
|
||||||
type: text/vnd.tiddlywiki
|
type: text/vnd.tiddlywiki
|
||||||
url: https://web.archive.org/web/20221015011644/http://blog.jeffreykishner.com/tiddlywiki/
|
url: http://blog.jeffreykishner.com/tiddlywiki/
|
||||||
|
|
||||||
A collection of articles covering integration with Fargo, Font Awesome and Google Calendar, and tips for managing task lists. The original site is missing, but a link to an archive is provided.
|
A collection of articles covering integration with Fargo, Font Awesome and Google Calendar, and tips for managing task lists.
|
||||||
|
|
||||||
{{!!url}}
|
{{!!url}}
|
||||||
|
|
||||||
|
|||||||
@@ -13,8 +13,6 @@ url: https://ibnishak.github.io/Timimi/
|
|||||||
|
|
||||||
Timimi is a web-extension accompanied by a native host that allows you to save and backup your standalone HTML tiddlywiki files ''anywhere in your hard-drive''. Once installed, you can save the tiddlywiki files without any extra steps, like the original Tiddlyfox addon.
|
Timimi is a web-extension accompanied by a native host that allows you to save and backup your standalone HTML tiddlywiki files ''anywhere in your hard-drive''. Once installed, you can save the tiddlywiki files without any extra steps, like the original Tiddlyfox addon.
|
||||||
|
|
||||||
* The native host requires a component installed on the host computer, outside the browser.
|
|
||||||
|
|
||||||
{{!!url}}
|
{{!!url}}
|
||||||
|
|
||||||
As of version 2.1, Timimi supports the following browsers
|
As of version 2.1, Timimi supports the following browsers
|
||||||
@@ -31,4 +29,4 @@ Timimi also provides users with 4 backup strategies, viz:
|
|||||||
* Create a backup Every n^^th^^ save
|
* Create a backup Every n^^th^^ save
|
||||||
* Create a backup every n^^th^^ minute
|
* Create a backup every n^^th^^ minute
|
||||||
* Customised Tower of Hanoi
|
* Customised Tower of Hanoi
|
||||||
* First in First Out
|
* First in First Out
|
||||||
@@ -1,11 +1,11 @@
|
|||||||
created: 20201117163027900
|
created: 20201117163027900
|
||||||
modified: 20230723074506632
|
modified: 20210106151027459
|
||||||
tags: Tutorials
|
tags: Tutorials
|
||||||
title: GitHub Saver Tutorial by Mohammad
|
title: GitHub Saver Tutorial by Mohammad
|
||||||
type: text/vnd.tiddlywiki
|
type: text/vnd.tiddlywiki
|
||||||
url: https://kookma.github.io/TW5-GitHub-Saver/
|
url: https://kookma.github.io/TW5-GitHub-Saver/
|
||||||
|
|
||||||
GitHub Saver is a step by step tutorial that shows how to integrate Tiddlywiki 5 and ~GitHub Pages to create websites hosted on https://github.com/.
|
GitHub Saver is a step by step tutorial shows how to integrate Tiddlywiki 5 and GitHub Pages to create websites hosted on https://github.com/.
|
||||||
|
|
||||||
{{!!url}}
|
{{!!url}}
|
||||||
|
|
||||||
@@ -13,11 +13,11 @@ This instruction is based on Tiddlywiki single html file model, while it can use
|
|||||||
|
|
||||||
!! Other tutorials
|
!! Other tutorials
|
||||||
|
|
||||||
;Tiddlywiki, Travis-CI and ~GitHub Pages
|
;Tiddlywiki, Travis-CI and GitHub Pages
|
||||||
:https://kookma.github.io/Tiddlywiki-Travis-CI/
|
:https://kookma.github.io/Tiddlywiki-Travis-CI/
|
||||||
:This wiki shows how to set up websites hosted on [[GitHub Pages|https://pages.github.com/]] using [[Travis-CI|https://travis-ci.org]] and [[Tiddlywiki 5|https://tiddlywiki.com]] on Node.js.
|
:This wiki shows how to set up websites hosted on [[GitHub Pages|https://pages.github.com/]] using [[Travis-CI|https://travis-ci.org]] and [[Tiddlywiki 5|https://tiddlywiki.com]] on Node.js.
|
||||||
|
|
||||||
|
|
||||||
;Tiddlywiki and ~GitHub Pages
|
;Tiddlywiki and GitHub Pages
|
||||||
:https://kookma.github.io/Tiddlywiki-and-GitHub-Pages/
|
:https://kookma.github.io/Tiddlywiki-and-GitHub-Pages/
|
||||||
:This instruction is based on local edit, save and push to ~GitHub. It does NOT use the new ~GitHub Saver mechanism (requires TW 5.1.20+) which lets edit and save directly from Tiddlywiki!
|
:This instruction is based on local edit, save and push to GitHub. It does NOT use the new GitHub Saver mechanism (requires TW 5.1.20+) which lets edit and save directly from Tiddlywiki!
|
||||||
@@ -0,0 +1,16 @@
|
|||||||
|
created: 20140312085406905
|
||||||
|
modified: 20140312084543862
|
||||||
|
tags: Tutorials
|
||||||
|
title: "Install and run TiddlyWiki on a CentOS 6 VPS using Nginx" from RoseHosting
|
||||||
|
type: text/vnd.tiddlywiki
|
||||||
|
url: http://www.rosehosting.com/blog/install-and-run-tiddlywiki-on-a-centoos-6-vps-using-nginx/
|
||||||
|
|
||||||
|
A step by step guide to running TiddlyWiki on a ~CentOS Virtual Private Server.
|
||||||
|
|
||||||
|
{{!!url}}
|
||||||
|
|
||||||
|
<<<
|
||||||
|
In this tutorial we will guide you through the steps of installing and running TiddlyWiki on a ~CentOS 6 VPS.
|
||||||
|
|
||||||
|
We will also install and configure Nginx as a reverse proxy, so you can run TiddlyWiki behind Nginx.
|
||||||
|
<<<
|
||||||
@@ -9,13 +9,9 @@ tags: Concepts
|
|||||||
<$button actions=<<actions>>>$text$</$button>
|
<$button actions=<<actions>>>$text$</$button>
|
||||||
\end
|
\end
|
||||||
|
|
||||||
ShadowTiddlers are tiddlers that are loaded from [[Plugins]] at the wiki startup. Unlike ordinary tiddlers, they don't appear in most lists.
|
ShadowTiddlers are tiddlers that are loaded from within [[Plugins]]. Unlike ordinary tiddlers, they don't appear in most lists.
|
||||||
|
|
||||||
!! Overriding Shadow Tiddlers to modify plugins
|
ShadowTiddlers can be overridden with an ordinary tiddler of the same name. If that tiddler is subsequently deleted then the original shadow tiddler is automatically restored.
|
||||||
|
|
||||||
A ShadowTiddler can be overridden with an ordinary tiddler of the same name. This leaves the shadow tiddler intact but the plugin will use the overriding tiddler in its place, effectively allowing users to modify the behaviour of plugins.
|
|
||||||
|
|
||||||
Users are cautioned against overriding shadow tiddlers because if the shadow tiddler is changed in a plugin update, the overriding tiddler may no longer perform as intended. To remedy this, the overriding tiddler may be modified or deleted. If the overriding tiddler is deleted, then the plugin falls back to using the original shadow tiddler.
|
|
||||||
|
|
||||||
!! Overridden Shadow Tiddlers
|
!! Overridden Shadow Tiddlers
|
||||||
|
|
||||||
|
|||||||
@@ -1,9 +0,0 @@
|
|||||||
created: 20230723073000469
|
|
||||||
modified: 20230723073046462
|
|
||||||
tags: Definitions
|
|
||||||
title: Git
|
|
||||||
type: text/vnd.tiddlywiki
|
|
||||||
|
|
||||||
>Git (/ɡɪt/) is a distributed version control system that tracks changes in any set of computer files, usually used for coordinating work among programmers collaboratively developing source code during software development. Its goals include speed, data integrity, and support for distributed, non-linear workflows (thousands of parallel branches running on different computers).
|
|
||||||
>
|
|
||||||
>https://en.wikipedia.org/wiki/Git
|
|
||||||
@@ -1,15 +1,13 @@
|
|||||||
created: 20140910212609354
|
created: 20140910212609354
|
||||||
modified: 20230723074351846
|
modified: 20190408173002622
|
||||||
tags: Definitions
|
tags: Definitions
|
||||||
title: GitHub
|
title: GitHub
|
||||||
type: text/vnd.tiddlywiki
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
GitHub is a hosting service for distributed projects that use git as their version-control system. It allows free hosting and management of open-source projects and facilitates collaborative development on the source code. Using ~GitHub for non-open-source endeavours requires additional fees.
|
GitHub is a hosting service for distributed projects that use git as their version-control system. It allows free hosting and management of open-source projects and facilitates collaborative development on the source code. Using GitHub for non-open-source endeavours requires additional fees.
|
||||||
|
|
||||||
The code and documentation of TiddlyWiki is hosted on ~GitHub at:
|
The code and documentation of TiddlyWiki is hosted on GitHub at:
|
||||||
|
|
||||||
https://github.com/Jermolene/TiddlyWiki5
|
https://github.com/Jermolene/TiddlyWiki5
|
||||||
|
|
||||||
~GitHub also offer a free web hosting service called [[GitHub Pages|https://pages.github.com/]] that can be used directly from the single file configuration. See [[Saving to a Git service]].
|
GitHub also offer a free web hosting service called [[GitHub Pages|https://pages.github.com/]] that can be used directly from the single file configuration. See [[Saving to a Git service]].
|
||||||
|
|
||||||
An alternative to ~GitHub is GitLab
|
|
||||||
|
|||||||
@@ -1,13 +0,0 @@
|
|||||||
created: 20230723072527781
|
|
||||||
modified: 20230723073955715
|
|
||||||
tags: Definitions
|
|
||||||
title: GitLab
|
|
||||||
type: text/vnd.tiddlywiki
|
|
||||||
|
|
||||||
>GitLab Inc. is an open-core company that operates ~GitLab, a ~DevOps software package which can develop, secure, and operate software. The open source software project was created by Ukrainian developer Dmytro Zaporozhets and Dutch developer Sytse Sijbrandij
|
|
||||||
>
|
|
||||||
>https://en.wikipedia.org/wiki/GitLab
|
|
||||||
|
|
||||||
Both GitLab and GitHub use [[Git]] a distributed version control system, that can be used to store, view and edit TiddlyWiki wikis using [[GitLab Pages|https://docs.gitlab.com/ee/user/project/pages/]]
|
|
||||||
|
|
||||||
Learn more at: [[Saving to a Git service]]
|
|
||||||
@@ -1,8 +1,6 @@
|
|||||||
caption: Fourth-Caption
|
|
||||||
created: 20150221194405000
|
created: 20150221194405000
|
||||||
modified: 20211114013601188
|
modified: 20211114013601188
|
||||||
tags: Contents [[Table-of-Contents Demonstrations]]
|
tags: Contents [[Table-of-Contents Demonstrations]]
|
||||||
title: Fourth
|
title: Fourth
|
||||||
type: text/vnd.tiddlywiki
|
|
||||||
|
|
||||||
<<.toc-lorem>>
|
<<.toc-lorem>>
|
||||||
|
|||||||
@@ -2,15 +2,5 @@ created: 20150221194423000
|
|||||||
modified: 20211114013601189
|
modified: 20211114013601189
|
||||||
tags: SecondThree [[Table-of-Contents Demonstrations]]
|
tags: SecondThree [[Table-of-Contents Demonstrations]]
|
||||||
title: SecondThreeThree
|
title: SecondThreeThree
|
||||||
toc-link: no
|
|
||||||
type: text/vnd.tiddlywiki
|
|
||||||
|
|
||||||
''Important''
|
|
||||||
|
|
||||||
It's important that this tiddler has no "child" to be able to visually test every possible toc code-path.
|
|
||||||
|
|
||||||
* This tiddler has a field ''toc-link: no''
|
|
||||||
* Do not tag any other tiddler with the title of this one
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<<.toc-lorem>>
|
||||||
|
|||||||
@@ -1,9 +1,7 @@
|
|||||||
caption: Third-Caption
|
|
||||||
created: 20150221194436000
|
created: 20150221194436000
|
||||||
list: ThirdOne ThirdTwo ThirdThree
|
list: ThirdOne ThirdTwo ThirdThree
|
||||||
modified: 20211114013601191
|
modified: 20211114013601191
|
||||||
tags: Contents [[Table-of-Contents Demonstrations]]
|
tags: Contents [[Table-of-Contents Demonstrations]]
|
||||||
title: Third
|
title: Third
|
||||||
type: text/vnd.tiddlywiki
|
|
||||||
|
|
||||||
<<.toc-lorem>>
|
<<.toc-lorem>>
|
||||||
|
|||||||
@@ -1,20 +0,0 @@
|
|||||||
created: 20230627093650105
|
|
||||||
modified: 20230627094356394
|
|
||||||
tags: Features
|
|
||||||
title: Deserializers
|
|
||||||
type: text/vnd.tiddlywiki
|
|
||||||
|
|
||||||
Deserializer [[modules|Modules]] parse text in various formats into their JSON representation as tiddlers. The deserializer modules available in a wiki can be seen using the [[deserializers operator|deserializers Operator]] and can be used with the [[deserialize Operator]].
|
|
||||||
|
|
||||||
The TiddlyWiki core provides the following deserializers:
|
|
||||||
|
|
||||||
|!Deserializer |!Description |
|
|
||||||
|(DOM)|Extracts tiddlers from a DOM node, should not be used with the <<.op deserialize[]>> operator |
|
|
||||||
|application/javascript|Parses a JavaScript module as a tiddler extracting fields from the header comment|
|
|
||||||
|application/json|Parses [[JSON|JSON in TiddlyWiki]] into tiddlers|
|
|
||||||
|application/x-tiddler|Parses the [[.tid file format|TiddlerFiles]] as a tiddler|
|
|
||||||
|application/x-tiddler-html-div|Parses the [[<DIV>.tiddler file format|TiddlerFiles]] as a tiddler|
|
|
||||||
|application/x-tiddlers|Parses the [[MultiTiddlerFile format|MultiTiddlerFiles]] as tiddlers|
|
|
||||||
|text/css|Parses CSS as a tiddler extracting fields from the header comment|
|
|
||||||
|text/html|Parses an HTML file into tiddlers. Supports ~TiddlyWiki Classic HTML files, ~TiddlyWiki5 HTML files and ordinary HTML files|
|
|
||||||
|text/plain|Parses plain text as a tiddler|
|
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user