mirror of
https://github.com/S2-/gitlit
synced 2025-08-04 13:10:09 +02:00
remove node_modules
This commit is contained in:
273
app/node_modules/pnotify/src/PNotifyDesktop.html
generated
vendored
273
app/node_modules/pnotify/src/PNotifyDesktop.html
generated
vendored
@@ -1,273 +0,0 @@
|
||||
<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>
|
Reference in New Issue
Block a user