123456789101112131415161718192021222324252627282930313233343536373839 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { computed } from 'vue'
- import { useOnlineNotificationsQuery } from '#shared/entities/online-notification/graphql/queries/onlineNotifications.api.ts'
- import type { OnlineNotification } from '#shared/graphql/types.ts'
- import { QueryHandler } from '#shared/server/apollo/handler/index.ts'
- import { edgesToArray } from '#shared/utils/helpers.ts'
- export const useOnlineNotificationList = () => {
- const notificationsQuery = new QueryHandler(useOnlineNotificationsQuery())
- const loading = notificationsQuery.loading()
- const result = notificationsQuery.result()
- const notificationList = computed(
- () =>
- edgesToArray(result.value?.onlineNotifications) as OnlineNotification[],
- )
- const isLoading = computed(() => {
- if (result.value !== undefined) return false
- return loading.value
- })
- const hasUnseenNotification = computed(() =>
- notificationList.value.some((notification) => !notification.seen),
- )
- const refetch = () => notificationsQuery.refetch()
- return {
- notificationList,
- hasUnseenNotification,
- refetch,
- loading: isLoading,
- }
- }
|