1
0
mirror of https://github.com/Jermolene/TiddlyWiki5 synced 2024-11-15 06:14:53 +00:00
TiddlyWiki5/core/modules/startup/rootwidget.js

86 lines
2.8 KiB
JavaScript
Raw Normal View History

2014-05-05 13:41:46 +00:00
/*\
title: $:/core/modules/startup/rootwidget.js
type: application/javascript
module-type: startup
2014-05-05 14:25:51 +00:00
Setup the root widget and the core root widget handlers
2014-05-05 13:41:46 +00:00
\*/
(function(){
/*jslint node: true, browser: true */
/*global $tw: false */
"use strict";
// Export name and synchronous status
exports.name = "rootwidget";
exports.platforms = ["browser"];
2014-08-13 19:20:58 +00:00
exports.after = ["startup"];
2014-05-05 14:25:51 +00:00
exports.before = ["story"];
2014-05-05 13:41:46 +00:00
exports.synchronous = true;
exports.startup = function() {
// Install the modal message mechanism
$tw.modal = new $tw.utils.Modal($tw.wiki);
2014-08-28 20:43:44 +00:00
$tw.rootWidget.addEventListener("tm-modal",function(event) {
$tw.modal.display(event.param,{variables: event.paramObject, event: event});
2014-05-05 13:41:46 +00:00
});
$tw.rootWidget.addEventListener("tm-show-switcher",function(event) {
$tw.modal.display("$:/core/ui/SwitcherModal",{variables: event.paramObject, event: event});
});
2014-05-05 13:41:46 +00:00
// Install the notification mechanism
$tw.notifier = new $tw.utils.Notifier($tw.wiki);
2014-08-28 20:43:44 +00:00
$tw.rootWidget.addEventListener("tm-notify",function(event) {
$tw.notifier.display(event.param,{variables: event.paramObject});
2014-05-05 13:41:46 +00:00
});
// Install the copy-to-clipboard mechanism
$tw.rootWidget.addEventListener("tm-copy-to-clipboard",function(event) {
$tw.utils.copyToClipboard(event.param);
});
2019-06-28 16:27:36 +00:00
// Install the tm-focus-selector message
$tw.rootWidget.addEventListener("tm-focus-selector",function(event) {
var selector = event.param || "",
element,
doc = event.event && event.event.target ? event.event.target.ownerDocument : document;
2019-06-28 16:27:36 +00:00
try {
element = doc.querySelector(selector);
2019-06-28 16:27:36 +00:00
} catch(e) {
console.log("Error in selector: ",selector)
}
if(element && element.focus) {
element.focus(event.paramObject);
2019-06-28 16:27:36 +00:00
}
});
2014-05-05 13:41:46 +00:00
// Install the scroller
$tw.pageScroller = new $tw.utils.PageScroller();
2014-08-28 20:43:44 +00:00
$tw.rootWidget.addEventListener("tm-scroll",function(event) {
2014-05-05 13:41:46 +00:00
$tw.pageScroller.handleEvent(event);
});
var fullscreen = $tw.utils.getFullScreenApis();
2014-08-03 11:35:53 +00:00
if(fullscreen) {
2014-08-28 20:43:44 +00:00
$tw.rootWidget.addEventListener("tm-full-screen",function(event) {
var fullScreenDocument = event.event ? event.event.target.ownerDocument : document;
if(event.param === "enter") {
fullScreenDocument.documentElement[fullscreen._requestFullscreen](Element.ALLOW_KEYBOARD_INPUT);
} else if(event.param === "exit") {
fullScreenDocument[fullscreen._exitFullscreen]();
2014-08-03 11:35:53 +00:00
} else {
if(fullScreenDocument[fullscreen._fullscreenElement]) {
fullScreenDocument[fullscreen._exitFullscreen]();
} else {
fullScreenDocument.documentElement[fullscreen._requestFullscreen](Element.ALLOW_KEYBOARD_INPUT);
}
2014-08-03 11:35:53 +00:00
}
});
}
2014-05-05 13:41:46 +00:00
// If we're being viewed on a data: URI then give instructions for how to save
if(document.location.protocol === "data:") {
$tw.rootWidget.dispatchEvent({
2014-08-28 20:43:44 +00:00
type: "tm-modal",
2014-05-05 13:41:46 +00:00
param: "$:/language/Modals/SaveInstructions"
});
}
};
})();