12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- // 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<LocalesQuery['locales']>
- let localesQuery: QueryHandler<LocalesQuery, LocalesQueryVariables>
- 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<Maybe<Locale>>(null)
- const locales = ref<Maybe<LocalesQuery['locales']>>(null)
- const loadLocales = async (): Promise<void> => {
- if (locales.value) return
- const currentQuery = getLocalesQuery()
- const { data: result } = await currentQuery.query()
- locales.value = result?.locales || null
- }
- const setLocale = async (locale?: string): Promise<void> => {
- 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,
- },
- )
|