1
0
mirror of https://github.com/Jermolene/TiddlyWiki5 synced 2025-10-26 05:07:39 +00:00

Refactoring more of startup.js into modules

This commit is contained in:
Jermolene
2014-05-05 10:17:50 +01:00
parent 519e1b4a44
commit a0022a1cd6
6 changed files with 102 additions and 42 deletions

View File

@@ -1783,27 +1783,40 @@ console.log(s.join(" "));
return false; return false;
}; };
$tw.boot.isStartupTaskEligible = function(taskModule) { /*
var t; Returns true if we are running on one platforms specified in a task modules `platforms` array
// Check that the platform is correct */
$tw.boot.doesTaskMatchPlatform = function(taskModule) {
var platforms = taskModule.platforms; var platforms = taskModule.platforms;
if(platforms) { if(platforms) {
for(t=0; t<platforms.length; t++) { for(var t=0; t<platforms.length; t++) {
if((platforms[t] === "browser" && !$tw.browser) || (platforms[t] === "node" && !$tw.node)) { if((platforms[t] === "browser" && !$tw.browser) || (platforms[t] === "node" && !$tw.node)) {
return false; return false;
} }
} }
} }
return true;
};
$tw.boot.isStartupTaskEligible = function(taskModule) {
var t;
// Check that the platform is correct
if(!$tw.boot.doesTaskMatchPlatform(taskModule)) {
return false;
}
// Check that no other outstanding tasks must be executed before this one // Check that no other outstanding tasks must be executed before this one
var name = taskModule.name, var name = taskModule.name,
remaining = $tw.boot.remainingStartupModules; remaining = $tw.boot.remainingStartupModules;
if(name) { if(name) {
for(t=0; t<remaining.length; t++) { for(t=0; t<remaining.length; t++) {
if(remaining[t].before && remaining[t].before.indexOf(name) !== -1) { var task = remaining[t];
if(task.before && task.before.indexOf(name) !== -1) {
if($tw.boot.doesTaskMatchPlatform(task)) {
return false; return false;
} }
} }
} }
}
// Check that all of the tasks that we must be performed after has been done // Check that all of the tasks that we must be performed after has been done
var after = taskModule.after; var after = taskModule.after;
if(after) { if(after) {

View File

@@ -119,40 +119,6 @@ exports.startup = function() {
downloadType: "text/plain" downloadType: "text/plain"
}); });
}); });
// Listen out for login/logout/refresh events in the browser
$tw.rootWidget.addEventListener("tw-login",function() {
$tw.syncer.handleLoginEvent();
});
$tw.rootWidget.addEventListener("tw-logout",function() {
$tw.syncer.handleLogoutEvent();
});
$tw.rootWidget.addEventListener("tw-server-refresh",function() {
$tw.syncer.handleRefreshEvent();
});
// Install the crypto event handlers
$tw.rootWidget.addEventListener("tw-set-password",function(event) {
$tw.passwordPrompt.createPrompt({
serviceName: "Set a new password for this TiddlyWiki",
noUserName: true,
submitText: "Set password",
canCancel: true,
callback: function(data) {
if(data) {
$tw.crypto.setPassword(data.password);
}
return true; // Get rid of the password prompt
}
});
});
$tw.rootWidget.addEventListener("tw-clear-password",function(event) {
$tw.crypto.setPassword(null);
});
// Ensure that $:/isEncrypted is maintained properly
$tw.wiki.addEventListener("change",function(changes) {
if($tw.utils.hop(changes,"$:/isEncrypted")) {
$tw.crypto.updateCryptoStateTiddler();
}
});
// If we're being viewed on a data: URI then give instructions for how to save // If we're being viewed on a data: URI then give instructions for how to save
if(document.location.protocol === "data:") { if(document.location.protocol === "data:") {
$tw.utils.dispatchCustomEvent(document,"tw-modal",{ $tw.utils.dispatchCustomEvent(document,"tw-modal",{

View File

@@ -3,7 +3,7 @@ title: $:/core/modules/startup/favicon.js
type: application/javascript type: application/javascript
module-type: startup module-type: startup
Load core modules Favicon handling
\*/ \*/
(function(){ (function(){

View File

@@ -0,0 +1,47 @@
/*\
title: $:/core/modules/startup/password.js
type: application/javascript
module-type: startup
Password handling
\*/
(function(){
/*jslint node: true, browser: true */
/*global $tw: false */
"use strict";
// Export name and synchronous status
exports.name = "password";
exports.platforms = ["browser"];
exports.after = ["startup"];
exports.synchronous = true;
exports.startup = function() {
$tw.rootWidget.addEventListener("tw-set-password",function(event) {
$tw.passwordPrompt.createPrompt({
serviceName: "Set a new password for this TiddlyWiki",
noUserName: true,
submitText: "Set password",
canCancel: true,
callback: function(data) {
if(data) {
$tw.crypto.setPassword(data.password);
}
return true; // Get rid of the password prompt
}
});
});
$tw.rootWidget.addEventListener("tw-clear-password",function(event) {
$tw.crypto.setPassword(null);
});
// Ensure that $:/isEncrypted is maintained properly
$tw.wiki.addEventListener("change",function(changes) {
if($tw.utils.hop(changes,"$:/isEncrypted")) {
$tw.crypto.updateCryptoStateTiddler();
}
});
};
})();

View File

@@ -0,0 +1,34 @@
/*\
title: $:/core/modules/startup/syncer-browser.js
type: application/javascript
module-type: startup
Startup handling
\*/
(function(){
/*jslint node: true, browser: true */
/*global $tw: false */
"use strict";
// Export name and synchronous status
exports.name = "syncer-browser";
exports.platforms = ["browser"];
exports.after = ["main-render"];
exports.synchronous = true;
exports.startup = function() {
// Listen out for login/logout/refresh events in the browser
$tw.rootWidget.addEventListener("tw-login",function() {
$tw.syncer.handleLoginEvent();
});
$tw.rootWidget.addEventListener("tw-logout",function() {
$tw.syncer.handleLogoutEvent();
});
$tw.rootWidget.addEventListener("tw-server-refresh",function() {
$tw.syncer.handleRefreshEvent();
});
};
})();

View File

@@ -13,7 +13,7 @@ Message handler for full screen mode
"use strict"; "use strict";
// Export name and synchronous status // Export name and synchronous status
exports.name = "full-screen-startup"; exports.name = "full-screen";
exports.platforms = ["browser"]; exports.platforms = ["browser"];
exports.after = ["startup"]; exports.after = ["startup"];
exports.synchronous = true; exports.synchronous = true;