1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { without } from 'lodash-es'
- import { defineStore } from 'pinia'
- import { computed, nextTick, ref, toValue } from 'vue'
- import { useMacrosUpdateSubscription } from '#shared/graphql/subscriptions/macrosUpdate.api.ts'
- import type {
- MacrosQuery,
- MacrosQueryVariables,
- } from '#shared/graphql/types.ts'
- import QueryHandler from '#shared/server/apollo/handler/QueryHandler.ts'
- import SubscriptionHandler from '#shared/server/apollo/handler/SubscriptionHandler.ts'
- export const useMacroStore = defineStore('macro', () => {
- const usageKeys = ref<string[]>([])
- const queryByUsageKey = new Map<
- string,
- QueryHandler<MacrosQuery, MacrosQueryVariables>
- >()
- const activate = (
- usageKey: string,
- query: QueryHandler<MacrosQuery, MacrosQueryVariables>,
- ) => {
- usageKeys.value.push(usageKey)
- queryByUsageKey.set(usageKey, query)
- }
- const enabled = computed(() => usageKeys.value.length > 0)
- const macroSubscription = new SubscriptionHandler(
- useMacrosUpdateSubscription(() => ({ enabled })),
- )
- macroSubscription.onResult((data) => {
- if (!data.data?.macrosUpdate.macroUpdated) return
- const refetchFor: Record<string, boolean> = {}
- queryByUsageKey.forEach((query) => {
- const { groupId } = toValue(query.operationResult.variables) ?? {}
- // Skip refetching of duplicate queries with the same group ID.
- if (!groupId || refetchFor[groupId]) return
- query.refetch()
- refetchFor[groupId] = true
- })
- })
- const deactivate = (usageKey: string) => {
- if (!usageKeys.value.includes(usageKey)) return
- nextTick(() => {
- usageKeys.value = without(usageKeys.value, usageKey)
- queryByUsageKey.delete(usageKey)
- })
- }
- return {
- usageKeys,
- activate,
- deactivate,
- }
- })
|