/* src/PNotifyDesktop.html generated by Svelte v2.6.3 */ import PNotify from "./PNotify.js"; let permission; const Notification = window.Notification; let notify = (title, options, onclick, onclose) => { // Memoize based on feature detection. if ('Notification' in window) { notify = (title, options, onclick, onclose) => { const notice = new Notification(title, options); if ('NotificationEvent' in window) { notice.addEventListener('notificationclick', onclick); notice.addEventListener('close', onclose); } else if ('addEventListener' in notice) { notice.addEventListener('click', onclick); notice.addEventListener('close', onclose); } else { notice.onclick = onclick; notice.onclose = onclose; } return notice; }; } else if ('mozNotification' in navigator) { notify = (title, options, onclick, onclose) => { // Gecko < 22 const notice = navigator.mozNotification .createNotification(title, options.body, options.icon) .show(); notice.onclick = onclick; notice.onclose = onclose; return notice; }; } else if ('webkitNotifications' in window) { notify = (title, options, onclick, onclose) => { const notice = window.webkitNotifications.createNotification( options.icon, title, options.body ); notice.onclick = onclick; notice.onclose = onclose; return notice; }; } else { notify = (title, options, onclick, onclose) => { return null; }; } return notify(title, options, onclick, onclose); }; function data() { return Object.assign({ '_notice': null, // The PNotify notice. '_options': {} // The options for the notice. }, PNotify.modules.Desktop.defaults); }; var methods = { initModule (options) { this.set(options); const {_notice} = this.get(); // Animation should always be 'none' for desktop notices, but remember // the old animation so it can be recovered. this.set({'_oldAnimation': _notice.get().animation}); _notice.on('state', ({changed, current, previous}) => { if (changed.animation) { if ( previous.animation === undefined || current.animation !== 'none' || ( previous.animation === 'none' && current.animation !== this.get()._oldAnimation ) ) { this.set({'_oldAnimation': current.animation}); } } // This is necessary so desktop notices don't cause spacing problems // when positioning. if (changed._animatingClass) { if (!(current._animatingClass === '' || (permission !== 0 && this.get().fallback) || !this.get().desktop)) { _notice.set({'_animatingClass': ''}); } } }); if (!this.get().desktop) { return; } permission = PNotify.modules.Desktop.checkPermission(); if (permission !== 0) { // Keep the notice from opening if fallback is false. if (!this.get().fallback) { _notice.set({'autoDisplay': false}); } return; } _notice.set({'animation': 'none'}); _notice.addModuleClass('ui-pnotify-desktop-hide'); this.genNotice(); }, update () { const {_notice} = this.get(); if ((permission !== 0 && this.get().fallback) || !this.get().desktop) { _notice.set({'animation': this.get()._oldAnimation}); _notice.removeModuleClass('ui-pnotify-desktop-hide'); return; } else { _notice.set({'animation': 'none'}); _notice.addModuleClass('ui-pnotify-desktop-hide'); } this.genNotice(); }, beforeOpen () { if (this.get().desktop && permission !== 0) { PNotify.modules.Desktop.permission(); } if ((permission !== 0 && this.get().fallback) || !this.get().desktop) { return; } const {_desktop} = this.get(); if (_desktop && 'show' in _desktop) { this.get()._notice.set({'_moduleIsNoticeOpen': true}); _desktop.show(); } }, beforeClose () { if ((permission !== 0 && this.get().fallback) || !this.get().desktop) { return; } const {_desktop} = this.get(); if (_desktop && 'close' in _desktop) { _desktop.close(); this.get()._notice.set({'_moduleIsNoticeOpen': false}); } }, genNotice () { const {_notice, icon} = this.get(); if (icon === null) { switch (_notice.get().type) { case 'error': this.set({'_icon': ''}); break; case 'success': this.set({'_icon': ''}); break; case 'info': this.set({'_icon': ''}); break; case 'notice': default: this.set({'_icon': ''}); break; } } else if (icon === false) { this.set({'_icon': null}); } else { this.set({'_icon': icon}); } let {tag} = this.get(); if (!this.get()._tag || tag !== null) { this.set({ '_tag': tag === null ? 'PNotify-' + Math.round(Math.random() * 1000000) : tag }); } const options = { body: this.get().text || _notice.get().text, tag: this.get()._tag }; if (!_notice.get().hide) { options.requireInteraction = true; } if (this.get()._icon !== null) { options.icon = this.get()._icon; } Object.apply(options, this.get().options); const _desktop = notify( this.get().title || _notice.get().title, options, () => { _notice.fire('click', {target: _desktop}); }, () => { _notice.close(); } ); _notice.set({'_moduleIsNoticeOpen': true}); this.set({_desktop}); if (!('close' in _desktop) && ('cancel' in _desktop)) { _desktop.close = () => { _desktop.cancel(); }; } } }; function setup(Component) { Component.key = 'Desktop'; Component.defaults = { // Display the notification as a desktop notification. desktop: false, // If desktop notifications are not supported or allowed, fall back to a regular notice. fallback: true, // The URL of the icon to display. If false, no icon will show. If null, a default icon will show. icon: null, // Using a tag lets you update an existing notice, or keep from duplicating notices between tabs. // If you leave tag null, one will be generated, facilitating the 'update' function. // see: http://www.w3.org/TR/notifications/#tags-example tag: null, // Optionally display a different title for the desktop. title: null, // Optionally display different text for the desktop. text: null, // Any additional options to be passed to the Notification constructor. options: {} }; Component.init = (notice) => { return new Component({target: document.body}); }; Component.permission = () => { if (typeof Notification !== 'undefined' && 'requestPermission' in Notification) { Notification.requestPermission(); } else if ('webkitNotifications' in window) { window.webkitNotifications.requestPermission(); } }; Component.checkPermission = () => { if (typeof Notification !== 'undefined' && 'permission' in Notification) { return (Notification.permission === 'granted' ? 0 : 1); } else if ('webkitNotifications' in window) { return window.webkitNotifications.checkPermission() == 0 ? 0 : 1; // eslint-disable-line eqeqeq } else { return 1; } }; permission = Component.checkPermission(); // Register the module with PNotify. PNotify.modules.Desktop = Component; }; function add_css() { var style = createElement("style"); style.id = 'svelte-xbgnx4-style'; style.textContent = "[ui-pnotify].ui-pnotify-desktop-hide.ui-pnotify{left:-10000px !important;display:none !important}"; appendNode(style, document.head); } function create_main_fragment(component, ctx) { return { c: noop, m: noop, p: noop, d: noop }; } function PNotifyDesktop(options) { init(this, options); this._state = assign(data(), options.data); this._intro = true; if (!document.getElementById("svelte-xbgnx4-style")) add_css(); this._fragment = create_main_fragment(this, this._state); if (options.target) { this._fragment.c(); this._mount(options.target, options.anchor); } } assign(PNotifyDesktop.prototype, { destroy: destroy, get: get, fire: fire, on: on, set: set, _set: _set, _mount: _mount, _differs: _differs }); assign(PNotifyDesktop.prototype, methods); PNotifyDesktop.prototype._recompute = noop; setup(PNotifyDesktop); function createElement(name) { return document.createElement(name); } function appendNode(node, target) { target.appendChild(node); } function noop() {} function init(component, options) { component._handlers = blankObject(); component._bind = options._bind; component.options = options; component.root = options.root || component; component.store = component.root.store || options.store; } function assign(tar, src) { for (var k in src) tar[k] = src[k]; return tar; } function destroy(detach) { this.destroy = noop; this.fire('destroy'); this.set = noop; this._fragment.d(detach !== false); this._fragment = null; this._state = {}; } function get() { return this._state; } function fire(eventName, data) { var handlers = eventName in this._handlers && this._handlers[eventName].slice(); if (!handlers) return; for (var i = 0; i < handlers.length; i += 1) { var handler = handlers[i]; if (!handler.__calling) { handler.__calling = true; handler.call(this, data); handler.__calling = false; } } } function on(eventName, handler) { var handlers = this._handlers[eventName] || (this._handlers[eventName] = []); handlers.push(handler); return { cancel: function() { var index = handlers.indexOf(handler); if (~index) handlers.splice(index, 1); } }; } function set(newState) { this._set(assign({}, newState)); if (this.root._lock) return; this.root._lock = true; callAll(this.root._beforecreate); callAll(this.root._oncreate); callAll(this.root._aftercreate); this.root._lock = false; } function _set(newState) { var oldState = this._state, changed = {}, dirty = false; for (var key in newState) { if (this._differs(newState[key], oldState[key])) changed[key] = dirty = true; } if (!dirty) return; this._state = assign(assign({}, oldState), newState); this._recompute(changed, this._state); if (this._bind) this._bind(changed, this._state); if (this._fragment) { this.fire("state", { changed: changed, current: this._state, previous: oldState }); this._fragment.p(changed, this._state); this.fire("update", { changed: changed, current: this._state, previous: oldState }); } } function _mount(target, anchor) { this._fragment[this._fragment.i ? 'i' : 'm'](target, anchor || null); } function _differs(a, b) { return a != a ? b == b : a !== b || ((a && typeof a === 'object') || typeof a === 'function'); } function blankObject() { return Object.create(null); } function callAll(fns) { while (fns && fns.length) fns.shift()(); } export default PNotifyDesktop;