mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2025-01-13 02:40:26 +00:00
7c8c5cf745
We were parsing the boot tiddlers, making them into a widget and then refreshing the widget tree. The problem is that subsequent chances to the boot tiddlers themselves wouldn’t be picked up as part of the refresh. Now we indirectly parse those UI boot tiddlers through a transclusion, which does get refreshed in the desired way.
81 lines
2.3 KiB
JavaScript
81 lines
2.3 KiB
JavaScript
/*\
|
|
title: $:/core/modules/utils/dom/notifier.js
|
|
type: application/javascript
|
|
module-type: utils
|
|
|
|
Notifier mechanism
|
|
|
|
\*/
|
|
(function(){
|
|
|
|
/*jslint node: true, browser: true */
|
|
/*global $tw: false */
|
|
"use strict";
|
|
|
|
var widget = require("$:/core/modules/widgets/widget.js");
|
|
|
|
var Notifier = function(wiki) {
|
|
this.wiki = wiki;
|
|
};
|
|
|
|
/*
|
|
Display a notification
|
|
title: Title of tiddler containing the notification text
|
|
options: see below
|
|
Options include:
|
|
*/
|
|
Notifier.prototype.display = function(title,options) {
|
|
options = options || {};
|
|
// Create the wrapper divs
|
|
var notification = document.createElement("div"),
|
|
tiddler = this.wiki.getTiddler(title),
|
|
duration = $tw.utils.getAnimationDuration();
|
|
// Don't do anything if the tiddler doesn't exist
|
|
if(!tiddler) {
|
|
return;
|
|
}
|
|
// Add classes
|
|
$tw.utils.addClass(notification,"tw-notification");
|
|
// Render the body of the notification
|
|
var widgetNode = this.wiki.makeTranscludeWidget(title,{parentWidget: $tw.rootWidget, document: document});
|
|
widgetNode.render(notification,null);
|
|
this.wiki.addEventListener("change",function(changes) {
|
|
widgetNode.refresh(changes,notification,null);
|
|
});
|
|
// Set the initial styles for the notification
|
|
$tw.utils.setStyle(notification,[
|
|
{opacity: "0"},
|
|
{transformOrigin: "0% 0%"},
|
|
{transform: "translateY(" + (-window.innerHeight) + "px)"},
|
|
{transition: "opacity " + duration + "ms ease-out, " + $tw.utils.roundTripPropertyName("transform") + " " + duration + "ms ease-in-out"}
|
|
]);
|
|
// Add the notification to the DOM
|
|
document.body.appendChild(notification);
|
|
// Force layout
|
|
$tw.utils.forceLayout(notification);
|
|
// Set final animated styles
|
|
$tw.utils.setStyle(notification,[
|
|
{opacity: "1.0"},
|
|
{transform: "translateY(0px)"}
|
|
]);
|
|
// Set a timer to remove the notification
|
|
window.setTimeout(function() {
|
|
// Force layout and animate the notification away
|
|
$tw.utils.forceLayout(notification);
|
|
$tw.utils.setStyle(notification,[
|
|
{opacity: "0.0"},
|
|
{transform: "translateX(" + (notification.offsetWidth) + "px)"}
|
|
]);
|
|
// Remove the modal message from the DOM once the transition ends
|
|
setTimeout(function() {
|
|
if(notification.parentNode) {
|
|
document.body.removeChild(notification);
|
|
}
|
|
},duration);
|
|
},$tw.config.preferences.notificationDuration);
|
|
};
|
|
|
|
exports.Notifier = Notifier;
|
|
|
|
})();
|