2022-09-18 21:41:57 -04:00
|
|
|
// Monitors the gallery and sends a browser notification when the leading image is new.
|
|
|
|
|
|
|
|
let lastHeadImg = null;
|
|
|
|
|
2023-04-30 22:08:52 +03:00
|
|
|
let notificationButton = null;
|
2022-09-22 13:15:33 +03:00
|
|
|
|
2023-05-17 15:46:58 +03:00
|
|
|
onUiUpdate(function() {
|
|
|
|
if (notificationButton == null) {
|
|
|
|
notificationButton = gradioApp().getElementById('request_notifications');
|
2022-09-22 13:15:33 +03:00
|
|
|
|
2023-05-17 15:46:58 +03:00
|
|
|
if (notificationButton != null) {
|
2023-04-30 22:12:24 +03:00
|
|
|
notificationButton.addEventListener('click', () => {
|
2023-04-30 22:14:51 +03:00
|
|
|
void Notification.requestPermission();
|
2023-05-17 15:46:58 +03:00
|
|
|
}, true);
|
2022-09-22 13:15:33 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-03-25 14:28:20 -04:00
|
|
|
const galleryPreviews = gradioApp().querySelectorAll('div[id^="tab_"][style*="display: block"] div[id$="_results"] .thumbnail-item > img');
|
2022-09-18 21:41:57 -04:00
|
|
|
|
|
|
|
if (galleryPreviews == null) return;
|
|
|
|
|
|
|
|
const headImg = galleryPreviews[0]?.src;
|
|
|
|
|
|
|
|
if (headImg == null || headImg == lastHeadImg) return;
|
|
|
|
|
|
|
|
lastHeadImg = headImg;
|
|
|
|
|
2022-09-26 22:57:31 +02:00
|
|
|
// play notification sound if available
|
|
|
|
gradioApp().querySelector('#audio_notification audio')?.play();
|
|
|
|
|
2022-09-18 21:41:57 -04:00
|
|
|
if (document.hasFocus()) return;
|
|
|
|
|
|
|
|
// Multiple copies of the images are in the DOM when one is selected. Dedup with a Set to get the real number generated.
|
|
|
|
const imgs = new Set(Array.from(galleryPreviews).map(img => img.src));
|
|
|
|
|
|
|
|
const notification = new Notification(
|
|
|
|
'Stable Diffusion',
|
|
|
|
{
|
2022-10-13 00:12:20 +03:00
|
|
|
body: `Generated ${imgs.size > 1 ? imgs.size - opts.return_grid : 1} image${imgs.size > 1 ? 's' : ''}`,
|
2022-09-18 21:41:57 -04:00
|
|
|
icon: headImg,
|
|
|
|
image: headImg,
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2023-05-17 15:46:58 +03:00
|
|
|
notification.onclick = function(_) {
|
2022-09-18 21:41:57 -04:00
|
|
|
parent.focus();
|
|
|
|
this.close();
|
|
|
|
};
|
|
|
|
});
|