// Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ import { defineStore } from 'pinia' import { effectScope, ref } from 'vue' import { useLocalesLazyQuery } from '#shared/graphql/queries/locales.api.ts' import type { LocalesQuery, LocalesQueryVariables, } from '#shared/graphql/types.ts' import localeForBrowserLanguage from '#shared/i18n/localeForBrowserLanguage.ts' import { QueryHandler } from '#shared/server/apollo/handler/index.ts' import log from '#shared/utils/log.ts' import { useTranslationsStore } from './translations.ts' import type { LastArrayElement } from 'type-fest' type Locale = LastArrayElement let localesQuery: QueryHandler const getLocalesQuery = () => { if (localesQuery) return localesQuery const scope = effectScope() scope.run(() => { localesQuery = new QueryHandler(useLocalesLazyQuery({ onlyActive: true })) }) return localesQuery } export const useLocaleStore = defineStore( 'locale', () => { const localeData = ref>(null) const locales = ref>(null) const loadLocales = async (): Promise => { if (locales.value) return const currentQuery = getLocalesQuery() const { data: result } = await currentQuery.query() locales.value = result?.locales || null } const setLocale = async (locale?: string): Promise => { await loadLocales() let newLocaleData if (locale) { newLocaleData = locales.value?.find((elem) => { return elem.locale === locale }) } if (!newLocaleData) newLocaleData = localeForBrowserLanguage(locales.value || []) log.debug('localeStore.setLocale()', newLocaleData) // Update the translation store, when the locale is different. if (localeData.value?.locale !== newLocaleData.locale) { await useTranslationsStore().load(newLocaleData.locale) localeData.value = newLocaleData document.documentElement.setAttribute('dir', newLocaleData.dir) document.documentElement.setAttribute('lang', newLocaleData.locale) } } return { locales, localeData, setLocale, loadLocales, } }, { requiresAuth: false, }, )