// 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([]) const queryByUsageKey = new Map< string, QueryHandler >() const activate = ( usageKey: string, query: QueryHandler, ) => { 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 = {} 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, } })