1
0
mirror of https://github.com/Jermolene/TiddlyWiki5 synced 2025-01-23 07:26:54 +00:00

Add warning notification when viewing a document on a data: uri

The intent is to handhold the user through their first save+verification
This commit is contained in:
Jeremy Ruston 2012-07-15 17:37:03 +01:00
parent c9c26794af
commit 507460eb4e
4 changed files with 88 additions and 26 deletions

View File

@ -0,0 +1,10 @@
title: $:/messages/SaveInstructions
type: text/x-tiddlywiki
subtitle: Save your work
Your changes to this TiddlyWiki document need to be saved for safe-keeping.
* On most browsers, choose "Save As" from the "File" menu and save this HTML file
** Some browsers such as Chrome, also require you to specify the format in which the page should be saved as "Webpage, HTML only"
* On Mobile Safari on iOS devices like the iPad and iPhone, it isn't possible to save the page directly. Instead, save a bookmark to this page. If you've got iCloud set up then the bookmark will automatically sync to your desktop where you can open it and save it as above
** If you open the bookmark again in Mobile Safari you will see this message again. If you want to go ahead and use the file, just click the close button on this message

View File

@ -14,29 +14,14 @@ This is the main application logic for both the client and server
exports.startup = function() {
var modules,n,m,f,commander;
// This should be somewhere else
if($tw.browser) {
$tw.browser.unHyphenateCss = document.body.style["background-color"] === undefined;
$tw.browser.prefix = document.body.style.webkitTransform !== undefined ? "webkit" :
document.body.style.MozTransform !== undefined ? "Moz" :
document.body.style.MSTransform !== undefined ? "MS" :
document.body.style.OTransform !== undefined ? "O" : "";
$tw.browser.transition = $tw.browser.prefix + "Transition";
$tw.browser.transform = $tw.browser.prefix + "Transform";
$tw.browser.transformorigin = $tw.browser.prefix + "TransformOrigin";
$tw.browser.transitionEnd = {
"": "transitionEnd",
"O": "oTransitionEnd",
"MS": "msTransitionEnd",
"Moz": "transitionend",
"webkit": "webkitTransitionEnd"
}[$tw.browser.prefix];
}
// Set up additional global objects
// Load modules
$tw.plugins.applyMethods("global",$tw);
// Wire up plugin modules
$tw.plugins.applyMethods("config",$tw.config);
$tw.plugins.applyMethods("utils",$tw.utils);
if($tw.browser) {
$tw.utils.getBrowserInfo($tw.browser);
}
$tw.version = $tw.utils.extractVersionInfo();
$tw.Tiddler.fieldPlugins = $tw.plugins.getPluginsByTypeAsHashmap("tiddlerfield");
$tw.plugins.applyMethods("tiddlermethod",$tw.Tiddler.prototype);
$tw.plugins.applyMethods("wikimethod",$tw.Wiki.prototype);
@ -45,8 +30,6 @@ exports.startup = function() {
$tw.plugins.applyMethods("tiddlerserializer",$tw.Wiki.tiddlerSerializerPlugins);
$tw.plugins.applyMethods("treeutils",$tw.Tree);
$tw.plugins.applyMethods("treenode",$tw.Tree);
// Get version information
$tw.version = $tw.utils.extractVersionInfo();
// Set up the wiki store
$tw.wiki.initMacros();
$tw.wiki.initEditors();
@ -56,11 +39,16 @@ exports.startup = function() {
$tw.Commander.initCommands();
// Host-specific startup
if($tw.browser) {
// Install the popup manage
// Install the popup manager
$tw.popup = new $tw.utils.Popup({
wiki: $tw.wiki,
rootElement: document.body
});
// Install the modal message mechanism
$tw.modal = new $tw.utils.Modal(this);
document.addEventListener("tw-modal",function(event) {
$tw.modal.display(event.param);
},false);
// Install the scroller
$tw.scroller = new $tw.utils.Scroller();
// Install the save action handler
@ -89,15 +77,22 @@ exports.startup = function() {
}
$tw.wiki.addTiddler(new $tw.Tiddler({title: storyTitle,text: JSON.stringify(story)}));
$tw.wiki.addTiddler(new $tw.Tiddler({title: historyTitle,text: JSON.stringify(history)}));
// If we're being viewed on a data: URI then give instructions for how to save
if(document.location.protocol === "data:") {
var event = document.createEvent("Event");
event.initEvent("tw-modal",true,true);
event.param = "$:/messages/SaveInstructions";
document.dispatchEvent(event);
}
// Display the PageTemplate
var template = "$:/templates/PageTemplate";
var template = "$:/templates/PageTemplate",
title = template;
$tw.renderer = $tw.wiki.parseTiddler(template);
$tw.renderer.execute([],template);
$tw.renderer.execute([],title);
$tw.renderer.renderInDom(document.body);
$tw.wiki.addEventListener("",function(changes) {
$tw.renderer.refreshInDom(changes);
});
console.log("$tw",$tw);
} else {
// Start a commander with the command line arguments
commander = new $tw.Commander(

View File

@ -0,0 +1,40 @@
/*\
title: $:/core/modules/utils/dom/modal.js
type: application/javascript
module-type: utils
Modal message mechanism
\*/
(function(){
/*jslint node: true, browser: true */
/*global $tw: false */
"use strict";
var Modal = function(wiki) {
this.wiki = wiki;
};
Modal.prototype.display = function(title) {
var wrapper = document.createElement("div"),
template,renderer;
template = "$:/templates/ModalMessage";
renderer = $tw.wiki.parseTiddler(template);
renderer.execute([],title);
renderer.renderInDom(wrapper);
$tw.wiki.addEventListener("",function(changes) {
renderer.refreshInDom(changes);
});
wrapper.addEventListener("tw-close",function(event) {
console.log("Got tw-close event");
document.body.removeChild(wrapper);
event.stopPropogation();
return false;
},false);
document.body.appendChild(wrapper);
};
exports.Modal = Modal;
})();

View File

@ -0,0 +1,17 @@
title: $:/templates/ModalMessage
type: text/x-tiddlywiki
<div class="modal-backdrop fade in"></div>
<div class="container">
<div class="modal">
<div class="modal-header">
!!! <<view subtitle text>>
</div>
<div class="modal-body">
<<view text wikified>>
</div>
<div class="modal-footer">
<<button close class:"btn btn-primary"><Close>>
</div>
</div>
</div>