kopia lustrzana https://github.com/miklobit/TiddlyWiki5
First pass at external image support
A bunch of little changes that together enable external image support. Try: ``` tiddlywiki editions/tw5.com --verbose --build externalimages ``` Then open `externalimages.html`, look for the images in the more/types tab of the sidebar, open them and verify that they are set with an external SRC attribute, not a data URI.print-window-tiddler
rodzic
f131c37893
commit
9547a1f01c
|
@ -1,5 +1,6 @@
|
||||||
title: $:/language/EditTemplate/
|
title: $:/language/EditTemplate/
|
||||||
|
|
||||||
|
Body/External/Hint: This is an external tiddler stored outside of the main TiddlyWiki file. You can edit the tags and fields but cannot directly edit the content itself
|
||||||
Body/Hint: Use [[wiki text|http://tiddlywiki.com/static/WikiText.html]] to add formatting, images, and dynamic features
|
Body/Hint: Use [[wiki text|http://tiddlywiki.com/static/WikiText.html]] to add formatting, images, and dynamic features
|
||||||
Body/Placeholder: Type the text for this tiddler
|
Body/Placeholder: Type the text for this tiddler
|
||||||
Body/Preview/Button/Hide: hide preview
|
Body/Preview/Button/Hide: hide preview
|
||||||
|
|
|
@ -19,7 +19,12 @@ var ImageParser = function(type,text,options) {
|
||||||
attributes: {}
|
attributes: {}
|
||||||
},
|
},
|
||||||
src;
|
src;
|
||||||
if(text) {
|
if(options._canonical_uri) {
|
||||||
|
element.attributes.src = {type: "string", value: options._canonical_uri};
|
||||||
|
if(type === "application/pdf" || type === ".pdf") {
|
||||||
|
element.tag = "embed";
|
||||||
|
}
|
||||||
|
} else if(text) {
|
||||||
if(type === "application/pdf" || type === ".pdf") {
|
if(type === "application/pdf" || type === ".pdf") {
|
||||||
element.attributes.src = {type: "string", value: "data:application/pdf;base64," + text};
|
element.attributes.src = {type: "string", value: "data:application/pdf;base64," + text};
|
||||||
element.tag = "embed";
|
element.tag = "embed";
|
||||||
|
|
|
@ -56,20 +56,37 @@ ImageWidget.prototype.render = function(parent,nextSibling) {
|
||||||
} else {
|
} else {
|
||||||
// Check if it is an image tiddler
|
// Check if it is an image tiddler
|
||||||
if(this.wiki.isImageTiddler(this.imageSource)) {
|
if(this.wiki.isImageTiddler(this.imageSource)) {
|
||||||
// Render the appropriate element for the image type
|
|
||||||
var type = tiddler.fields.type,
|
var type = tiddler.fields.type,
|
||||||
text = tiddler.fields.text;
|
text = tiddler.fields.text,
|
||||||
switch(type) {
|
_canonical_uri = tiddler.fields._canonical_uri;
|
||||||
case "application/pdf":
|
// If the tiddler has body text then it doesn't need to be lazily loaded
|
||||||
tag = "embed";
|
if(text) {
|
||||||
src = "data:application/pdf;base64," + text;
|
// Render the appropriate element for the image type
|
||||||
break;
|
switch(type) {
|
||||||
case "image/svg+xml":
|
case "application/pdf":
|
||||||
src = "data:image/svg+xml," + encodeURIComponent(text);
|
tag = "embed";
|
||||||
break;
|
src = "data:application/pdf;base64," + text;
|
||||||
default:
|
break;
|
||||||
src = "data:" + type + ";base64," + text;
|
case "image/svg+xml":
|
||||||
break;
|
src = "data:image/svg+xml," + encodeURIComponent(text);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
src = "data:" + type + ";base64," + text;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else if(_canonical_uri) {
|
||||||
|
switch(type) {
|
||||||
|
case "application/pdf":
|
||||||
|
tag = "embed";
|
||||||
|
src = _canonical_uri;
|
||||||
|
break;
|
||||||
|
case "image/svg+xml":
|
||||||
|
src = _canonical_uri;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
src = _canonical_uri;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -711,6 +711,7 @@ Parse a block of text of a specified MIME type
|
||||||
options: see below
|
options: see below
|
||||||
Options include:
|
Options include:
|
||||||
parseAsInline: if true, the text of the tiddler will be parsed as an inline run
|
parseAsInline: if true, the text of the tiddler will be parsed as an inline run
|
||||||
|
_canonical_uri: optional string of the canonical URI of this content
|
||||||
*/
|
*/
|
||||||
exports.old_parseText = function(type,text,options) {
|
exports.old_parseText = function(type,text,options) {
|
||||||
options = options || {};
|
options = options || {};
|
||||||
|
@ -728,7 +729,8 @@ exports.old_parseText = function(type,text,options) {
|
||||||
// Return the parser instance
|
// Return the parser instance
|
||||||
return new Parser(type,text,{
|
return new Parser(type,text,{
|
||||||
parseAsInline: options.parseAsInline,
|
parseAsInline: options.parseAsInline,
|
||||||
wiki: this
|
wiki: this,
|
||||||
|
_canonical_uri: options._canonical_uri
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -736,11 +738,14 @@ exports.old_parseText = function(type,text,options) {
|
||||||
Parse a tiddler according to its MIME type
|
Parse a tiddler according to its MIME type
|
||||||
*/
|
*/
|
||||||
exports.old_parseTiddler = function(title,options) {
|
exports.old_parseTiddler = function(title,options) {
|
||||||
options = options || {};
|
options = $tw.utils.extend({},options);
|
||||||
var cacheType = options.parseAsInline ? "newInlineParseTree" : "newBlockParseTree",
|
var cacheType = options.parseAsInline ? "newInlineParseTree" : "newBlockParseTree",
|
||||||
tiddler = this.getTiddler(title),
|
tiddler = this.getTiddler(title),
|
||||||
self = this;
|
self = this;
|
||||||
return tiddler ? this.getCacheForTiddler(title,cacheType,function() {
|
return tiddler ? this.getCacheForTiddler(title,cacheType,function() {
|
||||||
|
if(tiddler.hasField("_canonical_uri")) {
|
||||||
|
options._canonical_uri = tiddler.fields._canonical_uri;
|
||||||
|
}
|
||||||
return self.old_parseText(tiddler.fields.type,tiddler.fields.text,options);
|
return self.old_parseText(tiddler.fields.type,tiddler.fields.text,options);
|
||||||
}) : null;
|
}) : null;
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,10 +1,26 @@
|
||||||
title: $:/core/ui/EditTemplate/body
|
title: $:/core/ui/EditTemplate/body
|
||||||
tags: $:/tags/EditTemplate
|
tags: $:/tags/EditTemplate
|
||||||
|
|
||||||
\define lingo-base() $:/language/EditTemplate/
|
\define lingo-base() $:/language/EditTemplate/Body/
|
||||||
|
<$list filter="[is[current]has[_canonical_uri]]">
|
||||||
|
|
||||||
|
<div class="tw-message-box">
|
||||||
|
|
||||||
|
<<lingo External/Hint>>
|
||||||
|
|
||||||
|
<a href={{!!_canonical_uri}}><$text text={{!!_canonical_uri}}/></a>
|
||||||
|
|
||||||
|
<$edit-text field="_canonical_uri" class="tw-edit-fields"></$edit-text>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</$list>
|
||||||
|
|
||||||
|
<$list filter="[is[current]!has[_canonical_uri]]">
|
||||||
|
|
||||||
<$reveal state="$:/state/showeditpreview" type="match" text="yes">
|
<$reveal state="$:/state/showeditpreview" type="match" text="yes">
|
||||||
|
|
||||||
<em class="tw-edit"><<lingo Body/Hint>></em> <$button type="set" set="$:/state/showeditpreview" setTo="no"><<lingo Body/Preview/Button/Hide>></$button>
|
<em class="tw-edit"><<lingo Hint>></em> <$button type="set" set="$:/state/showeditpreview" setTo="no"><<lingo Preview/Button/Hide>></$button>
|
||||||
|
|
||||||
<div class="tw-tiddler-preview">
|
<div class="tw-tiddler-preview">
|
||||||
<div class="tw-tiddler-preview-preview">
|
<div class="tw-tiddler-preview-preview">
|
||||||
|
@ -24,7 +40,9 @@ tags: $:/tags/EditTemplate
|
||||||
|
|
||||||
<$reveal state="$:/state/showeditpreview" type="nomatch" text="yes">
|
<$reveal state="$:/state/showeditpreview" type="nomatch" text="yes">
|
||||||
|
|
||||||
<em class="tw-edit"><<lingo Body/Hint>></em> <$button type="set" set="$:/state/showeditpreview" setTo="yes"><<lingo Body/Preview/Button/Show>></$button>
|
<em class="tw-edit"><<lingo Hint>></em> <$button type="set" set="$:/state/showeditpreview" setTo="yes"><<lingo Preview/Button/Show>></$button>
|
||||||
<$edit field="text" class="tw-edit-texteditor" placeholder={{$:/language/EditTemplate/Body/Placeholder}}/>
|
<$edit field="text" class="tw-edit-texteditor" placeholder={{$:/language/EditTemplate/Body/Placeholder}}/>
|
||||||
|
|
||||||
</$reveal>
|
</$reveal>
|
||||||
|
|
||||||
|
</$list>
|
||||||
|
|
|
@ -0,0 +1,68 @@
|
||||||
|
created: 20140610213500000
|
||||||
|
modified: 20140610213936575
|
||||||
|
tags: concepts
|
||||||
|
title: ExternalImages
|
||||||
|
type: text/vnd.tiddlywiki
|
||||||
|
|
||||||
|
External images in TiddlyWiki are tiddlers that point to the URI of an image, rather than embedding the full image data. They can perform better than embedded images, particularly with large numbers or sizes of images. However, using them breaks the single file pattern of TiddlyWiki.
|
||||||
|
|
||||||
|
External images are used in the browser. They can be created by the Node.js configuration when it builds a TiddlyWiki, or they can be created manually within the browser.
|
||||||
|
|
||||||
|
! What is an External Image
|
||||||
|
|
||||||
|
An external image is an ordinary image tiddler that has a ''_canonical_uri'' field containing the URI of the image. The URI can be absoluate or relative to the HTML document. If the canonical URI is provided then the ''text'' field of the tiddler is ignored and so should be omitted.
|
||||||
|
|
||||||
|
! Manually Creating External Images
|
||||||
|
|
||||||
|
To manually create an external image just create the tiddler with the appropriate image content type, and add a ''_canonical_uri'' field with a URI pointing to the actual image location.
|
||||||
|
|
||||||
|
! Creating external images under Node.js
|
||||||
|
|
||||||
|
The following steps are used to create a static HTML file version of a wiki accompanied by an ''images'' folder containing the referenced external images:
|
||||||
|
|
||||||
|
# Create image tiddlers in your TiddlyWikiFolders in the usual way
|
||||||
|
# Save the images as separate files (by convention, in a subfolder named ''images'')
|
||||||
|
# Externalise the image tiddlers by giving them a ''_canonical_uri'' field
|
||||||
|
# Save the main HTML file
|
||||||
|
|
||||||
|
Note the image files must be saved before they are externalised. Externalising them destroys the ''text'' field within the in-memory copy of the wiki store, meaning that attempts to save them will fail.
|
||||||
|
|
||||||
|
For an example see the ''externalimages'' build target of the demo ''tw5.com'' wiki:
|
||||||
|
|
||||||
|
```
|
||||||
|
--savetiddlers [is[image]] images
|
||||||
|
--setfield [is[image]] _canonical_uri $:/core/templates/canonical-uri text/plain
|
||||||
|
--setfield [is[image]] text "" text/plain
|
||||||
|
--rendertiddler $:/core/save/all externalimages.html text/plain
|
||||||
|
```
|
||||||
|
|
||||||
|
!! Saving Separate Image Files
|
||||||
|
|
||||||
|
The following `--savetiddlers` command can be used to save the images of a wiki into an ''images'' subfolder:
|
||||||
|
|
||||||
|
```
|
||||||
|
--savetiddlers [is[image]] images
|
||||||
|
```
|
||||||
|
|
||||||
|
!! Externalising Image Tiddlers
|
||||||
|
|
||||||
|
Two `--setfield` commands are used: the first sets the ''_canonical_uri'' field to a URI derived from the title of the tiddler, and the second clears the text field.
|
||||||
|
|
||||||
|
```
|
||||||
|
--setfield [is[image]] _canonical_uri $:/core/templates/canonical-uri text/plain
|
||||||
|
--setfield [is[image]] text "" text/plain
|
||||||
|
```
|
||||||
|
|
||||||
|
The template tiddler [[$:/core/templates/canonical-uri]] contains:
|
||||||
|
|
||||||
|
<pre>
|
||||||
|
|
||||||
|
<$view tiddler="$:/core/templates/canonical-uri" field="text" format="text"/>
|
||||||
|
|
||||||
|
</pre>
|
||||||
|
|
||||||
|
Note that these operations modify the tiddlers in the wiki store and so may affect the operation of subsequent commands.
|
||||||
|
|
||||||
|
! Using External Images
|
||||||
|
|
||||||
|
You can't edit an external image directly in the browser except by changing the URI field to point to a different image.
|
|
@ -1,6 +1,6 @@
|
||||||
title: ImageWidget
|
title: ImageWidget
|
||||||
created: 20140416160234142
|
created: 20140416160234142
|
||||||
modified: 20140416160234142
|
modified: 20140611160234142
|
||||||
tags: widget
|
tags: widget
|
||||||
|
|
||||||
! Introduction
|
! Introduction
|
||||||
|
@ -18,3 +18,11 @@ Any content of the `<$image>` widget is ignored.
|
||||||
|tooltip |The tooltip to be displayed over the image |
|
|tooltip |The tooltip to be displayed over the image |
|
||||||
|class |CSS classes to be assigned to the `<img>` element |
|
|class |CSS classes to be assigned to the `<img>` element |
|
||||||
|
|
||||||
|
! External Images and the ''_canonical_uri'' field
|
||||||
|
|
||||||
|
When used to display tiddler-based images, the image widget operates in two distinct modes:
|
||||||
|
|
||||||
|
* If the ''_canonical_uri'' field is present then it is used as the ''src'' attribute of the generated `<img>` element and the ''text'' field is ignored
|
||||||
|
* Without the ''_canonical_uri'' field, the image widget generates an `<img>` element that embeds the image data directly using a `data:` URI.
|
||||||
|
|
||||||
|
See ExternalImages for more details.
|
||||||
|
|
|
@ -30,6 +30,11 @@
|
||||||
"build": {
|
"build": {
|
||||||
"index": [
|
"index": [
|
||||||
"--rendertiddler","$:/core/save/all","index.html","text/plain"],
|
"--rendertiddler","$:/core/save/all","index.html","text/plain"],
|
||||||
|
"externalimages": [
|
||||||
|
"--savetiddlers","[is[image]] [type[text/html]]","images",
|
||||||
|
"--setfield","[is[image]] [type[text/html]]","_canonical_uri","$:/core/templates/canonical-uri","text/plain",
|
||||||
|
"--setfield","[is[image]]","text","","text/plain",
|
||||||
|
"--rendertiddler","$:/core/save/all","externalimages.html","text/plain"],
|
||||||
"encrypted": [
|
"encrypted": [
|
||||||
"--password", "password",
|
"--password", "password",
|
||||||
"--rendertiddler", "$:/core/save/all", "encrypted.html", "text/plain",
|
"--rendertiddler", "$:/core/save/all", "encrypted.html", "text/plain",
|
||||||
|
|
Ładowanie…
Reference in New Issue