5
0
mirror of https://github.com/wailsapp/wails.git synced 2025-05-05 04:00:32 +08:00
wails/v3/examples/notifications/frontend/main.js
Zach Botterman ab9c460088 quick fixes
2025-02-23 11:40:39 -08:00

52 lines
1.8 KiB
JavaScript

import * as Notifications from "./bindings/github.com/wailsapp/wails/v3/pkg/services/notifications/service";
import { Events } from "@wailsio/runtime";
const timeElement = document.getElementById('time');
const notificationsElement = document.getElementById('notifications');
window.sendNotification = async () => {
const granted = await Notifications.RequestUserNotificationAuthorization();
if (granted) {
const uuid = crypto.randomUUID();
await Notifications.SendNotification(uuid, "Frontend Notification", "", "Notification sent through JS!");
}
}
window.sendComplexNotification = async () => {
const granted = await Notifications.RequestUserNotificationAuthorization();
if (granted) {
await Notifications.RegisterNotificationCategory({
id: "FRONTEND_NOTIF",
actions: [
{ id: "VIEW_ACTION", title: "View" },
{ id: "MARK_READ_ACTION", title: "Mark as Read" },
{ id: "DELETE_ACTION", title: "Delete", destructive: true },
],
hasReplyField: true,
replyButtonTitle: "Reply",
replyPlaceholder: "Reply to frontend...",
});
const uuid = crypto.randomUUID();
await Notifications.SendNotificationWithActions({
id: uuid,
title: "Complex Frontend Notification",
subtitle: "From: Jane Doe",
body: "Is it raining today where you are?",
categoryId: "FRONTEND_NOTIF",
data: {
messageId: "msg-456",
senderId: "user-456",
timestamp: Date.now(),
}
});
}
}
Events.On('time', (time) => {
timeElement.innerText = time.data;
});
Events.On("notificationResponse", (response) => {
notificationsElement.innerText += JSON.stringify(response.data[0].data);
});