12345678910111213141516171819202122232425262728293031323334353637383940414243444546 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { onMounted } from 'vue'
- import {
- useNotifications,
- NotificationTypes,
- } from '#shared/components/CommonNotifications/index.ts'
- import { usePushMessagesSubscription } from '#shared/graphql/subscriptions/pushMessages.api.ts'
- import type {
- PushMessagesSubscription,
- PushMessagesSubscriptionVariables,
- } from '#shared/graphql/types.ts'
- import { SubscriptionHandler } from '#shared/server/apollo/handler/index.ts'
- import testFlags from '#shared/utils/testFlags.ts'
- let subscription: SubscriptionHandler<
- PushMessagesSubscription,
- PushMessagesSubscriptionVariables
- >
- const usePushMessages = () => {
- const notify = (message: string) => {
- useNotifications().notify({
- message,
- type: NotificationTypes.Warn,
- persistent: true,
- })
- }
- onMounted(() => {
- if (subscription) return
- subscription = new SubscriptionHandler(usePushMessagesSubscription())
- subscription.onResult((result) => {
- const message = result.data?.pushMessages
- if (!message?.title && !message?.text) {
- testFlags.set('usePushMessagesSubscription.subscribed')
- return
- }
- notify(`${message.title}: ${message.text}`)
- })
- })
- }
- export default usePushMessages
|