mirror of
https://github.com/S2-/gitlit
synced 2025-08-04 13:10:09 +02:00
274 lines
12 KiB
HTML
274 lines
12 KiB
HTML
<script>
|
|
import PNotify from './PNotify.html';
|
|
|
|
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);
|
|
};
|
|
|
|
export default {
|
|
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;
|
|
},
|
|
|
|
data () {
|
|
return Object.assign({
|
|
'_notice': null, // The PNotify notice.
|
|
'_options': {} // The options for the notice.
|
|
}, PNotify.modules.Desktop.defaults);
|
|
},
|
|
|
|
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();
|
|
};
|
|
}
|
|
}
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<style>
|
|
:global([ui-pnotify].ui-pnotify-desktop-hide.ui-pnotify) {
|
|
left: -10000px !important;
|
|
display: none !important;
|
|
}
|
|
</style>
|