mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2024-11-27 03:57:21 +00:00
BrowserStorage: A new plugin to save tiddlers to local storage
Experimental at this point.
This commit is contained in:
parent
70f5dff81e
commit
e31c5563ff
@ -14,7 +14,8 @@
|
||||
"tiddlywiki/external-attachments",
|
||||
"tiddlywiki/dynaview",
|
||||
"tiddlywiki/codemirror",
|
||||
"tiddlywiki/comments"
|
||||
"tiddlywiki/comments",
|
||||
"tiddlywiki/browser-storage"
|
||||
],
|
||||
"themes": [
|
||||
"tiddlywiki/vanilla",
|
||||
|
7
plugins/tiddlywiki/browser-storage/plugin.info
Normal file
7
plugins/tiddlywiki/browser-storage/plugin.info
Normal file
@ -0,0 +1,7 @@
|
||||
{
|
||||
"title": "$:/plugins/tiddlywiki/browser-storage",
|
||||
"description": "Local storage in the browser",
|
||||
"author": "Jeremy Ruston ",
|
||||
"core-version": ">=5.0.0",
|
||||
"list": "readme"
|
||||
}
|
63
plugins/tiddlywiki/browser-storage/rawmarkup.js
Normal file
63
plugins/tiddlywiki/browser-storage/rawmarkup.js
Normal file
@ -0,0 +1,63 @@
|
||||
/*\
|
||||
title: $:/plugins/tiddlywiki/browser-storage/rawmarkup.js
|
||||
type: application/javascript
|
||||
module-type: library
|
||||
|
||||
Startup code injected as raw markup
|
||||
|
||||
\*/
|
||||
|
||||
(function() {
|
||||
|
||||
// Need to initialise these because we run before bootprefix.js and boot.js
|
||||
$tw = window.$tw || Object.create(null);
|
||||
$tw.hooks = $tw.hooks || { names: {}};
|
||||
|
||||
// Hook the point in the startup process when the tiddlers have been loaded but plugins not unpacked
|
||||
var hookName = "th-boot-tiddlers-loaded";
|
||||
if(Object.prototype.hasOwnProperty.call($tw.hooks.names,hookName)) {
|
||||
$tw.hooks.names[hookName].push(hookBootTiddlersLoaded);
|
||||
} else {
|
||||
$tw.hooks.names[hookName] = [hookBootTiddlersLoaded];
|
||||
}
|
||||
|
||||
// Load tiddlers from browser storage
|
||||
function hookBootTiddlersLoaded() {
|
||||
var url = window.location.protocol === "file:" ? window.location.pathname : "";
|
||||
// Step through each browsder storage item
|
||||
for(var index=0; index<window.localStorage.length; index++) {
|
||||
var key = window.localStorage.key(index),
|
||||
parts = key.split("#");
|
||||
console.log("key",key)
|
||||
// If it's ours
|
||||
if(parts[0] === "tw5" && parts[1] === url) {
|
||||
// Read it as JSON
|
||||
var jsonString = window.localStorage.getItem(key),
|
||||
jsonData;
|
||||
if(jsonString) {
|
||||
try {
|
||||
jsonData = JSON.parse(jsonString);
|
||||
} catch(e) {}
|
||||
if(jsonData) {
|
||||
// Convert it to a tiddler
|
||||
var incomingTiddler = new $tw.Tiddler(jsonData);
|
||||
if(incomingTiddler) {
|
||||
// Get any existing tiddler
|
||||
var title = incomingTiddler.fields.title,
|
||||
existingTiddler = $tw.wiki.getTiddler(title);
|
||||
console.log("Existing",title,existingTiddler,existingTiddler && existingTiddler.isEqual(incomingTiddler))
|
||||
if(existingTiddler && existingTiddler.isEqual(incomingTiddler)) {
|
||||
// If the incoming tiddler is the same as the existing then we can delete the local storage version
|
||||
window.localStorage.removeItem(key);
|
||||
console.log("Removing from local storage",title)
|
||||
}
|
||||
$tw.wiki.addTiddler(incomingTiddler);
|
||||
console.log("Loading from local storage",title);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
})();
|
6
plugins/tiddlywiki/browser-storage/rawmarkup.tid
Normal file
6
plugins/tiddlywiki/browser-storage/rawmarkup.tid
Normal file
@ -0,0 +1,6 @@
|
||||
title: $:/plugins/tiddlywiki/browser-storage/rawmarkup
|
||||
tags: $:/tags/RawMarkupWikified
|
||||
|
||||
`<script>`
|
||||
{{$:/plugins/tiddlywiki/browser-storage/rawmarkup.js}}
|
||||
`</script>`
|
18
plugins/tiddlywiki/browser-storage/readme.tid
Normal file
18
plugins/tiddlywiki/browser-storage/readme.tid
Normal file
@ -0,0 +1,18 @@
|
||||
title: $:/plugins/tiddlywiki/browser-storage/readme
|
||||
|
||||
This plugin enables TiddlyWiki to save tiddlers in [[browser local storage|https://en.wikipedia.org/wiki/Web_storage#localStorage]]. This means that changes are stored within the browser, and automatically re-applied any time the base wiki is reloaded.
|
||||
|
||||
At startup, the plugin reads tiddlers from local storage. Any tiddlers that are identical to those built into the file are deleted from local storage. Once the wiki is up and running, any tiddler changes are written straight to local storage.
|
||||
|
||||
Browser local storage is not a panacea for TiddlyWiki:
|
||||
|
||||
* Browsers limit the amount of local storage available to a page, typically to 5 or 10MB
|
||||
* Keeping personal data in browser local storage can lead to unexpected privacy violations
|
||||
* Browsers reserve the right to without warning delete data stored in local storage at any time
|
||||
* Browsers tie local storage to a URL which can lead to problems if you move a wiki to a URL previously occupied by a different wiki
|
||||
|
||||
Please use this plugin with caution. There are a number of unresolved issues and open questions:
|
||||
|
||||
* An "red screen of embarrassment" error is raised when local storage is full
|
||||
* Innerwikis read the local storage of their parent wikis
|
||||
* This plugin does not interfere with the existing saver mechanism, so you'll still get warnings when refreshing the page, even if your changes are safely committed to local storage
|
41
plugins/tiddlywiki/browser-storage/startup.js
Normal file
41
plugins/tiddlywiki/browser-storage/startup.js
Normal file
@ -0,0 +1,41 @@
|
||||
/*\
|
||||
title: $:/plugins/tiddlywiki/browser-storage/startup.js
|
||||
type: application/javascript
|
||||
module-type: startup
|
||||
|
||||
Startup initialisation
|
||||
|
||||
\*/
|
||||
(function(){
|
||||
|
||||
/*jslint node: true, browser: true */
|
||||
/*global $tw: false */
|
||||
"use strict";
|
||||
|
||||
// Export name and synchronous status
|
||||
exports.name = "browser-storage";
|
||||
exports.platforms = ["browser"];
|
||||
exports.after = ["load-modules"];
|
||||
exports.synchronous = true;
|
||||
|
||||
exports.startup = function() {
|
||||
// Compute our prefix for local storage keys
|
||||
var url = window.location.protocol === "file:" ? window.location.pathname : "",
|
||||
prefix = "tw5#" + url + "#"
|
||||
// Track tiddler changes
|
||||
$tw.wiki.addEventListener("change",function(changes) {
|
||||
$tw.utils.each(changes,function(change,title) {
|
||||
var tiddler = $tw.wiki.getTiddler(title);
|
||||
if(tiddler) {
|
||||
var json = JSON.stringify(tiddler.getFieldStrings());
|
||||
window.localStorage.setItem(prefix + title,json);
|
||||
console.log("browser-storage: Saving",title);
|
||||
} else {
|
||||
window.localStorage.removeItem(prefix + title);
|
||||
console.log("browser-storage: Deleting",title);
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
})();
|
Loading…
Reference in New Issue
Block a user