5
0
mirror of https://github.com/wailsapp/wails.git synced 2025-05-05 03:42:22 +08:00
wails/v3/examples/notifications/frontend/main.js
2025-03-18 22:46:44 -07:00

67 lines
2.2 KiB
JavaScript

import * as Notifications from "./bindings/github.com/wailsapp/wails/v3/pkg/services/notifications";
import { Events } from "@wailsio/runtime";
const notificationsElement = document.getElementById('notifications');
window.sendNotification = async () => {
const granted = await Notifications.Service.RequestNotificationAuthorization();
if (granted) {
await Notifications.Service.SendNotification({
id: crypto.randomUUID(),
title: "Title",
body: "Body!",
data: {
messageId: "msg-123",
senderId: "user-123",
timestamp: Date.now(),
}
});
}
}
window.sendComplexNotification = async () => {
const granted = await Notifications.Service.RequestNotificationAuthorization();
if (granted) {
await Notifications.Service.RegisterNotificationCategory({
id: "FRONTEND_NOTIF",
actions: [
{ id: "VIEW_ACTION", title: "View" },
{ id: "MARK_READ_ACTION", title: "Mark as Read" },
],
hasReplyField: true,
replyButtonTitle: "Reply",
replyPlaceholder: "Reply to frontend...",
});
await Notifications.Service.SendNotificationWithActions({
id: crypto.randomUUID(),
title: "Complex Frontend Notification",
subtitle: "From: Jane Doe",
body: "Is it rainging today where you are?",
categoryId: "FRONTEND_NOTIF",
data: {
messageId: "msg-456",
senderId: "user-456",
timestamp: Date.now(),
}
});
}
}
window.removeNotification = async (id) => {
const granted = await Notifications.Service.RequestNotificationAuthorization();
if (granted) {
await Notifications.Service.RemoveDeliveredNotification(id);
}
}
window.removeAllNotifications = async (id) => {
const granted = await Notifications.Service.RequestNotificationAuthorization();
if (granted) {
await Notifications.Service.RemoveAllDeliveredNotifications();
}
}
Events.On("notification:response", (response) => {
notificationsElement.innerText = JSON.stringify(response.data[0]);
});