1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { storeToRefs } from 'pinia'
- import { computed, ref } from 'vue'
- import {
- NotificationTypes,
- useNotifications,
- } from '#shared/components/CommonNotifications/index.ts'
- import { useUserCurrentLocaleMutation } from '#shared/entities/user/current/graphql/mutations/userCurrentLocale.api.ts'
- import { useLocaleStore } from '#shared/stores/locale.ts'
- import MutationHandler from '../server/apollo/handler/MutationHandler.ts'
- const ZAMMAD_TRANSLATION_LINK = 'https://translations.zammad.org/'
- export const useLocaleUpdate = () => {
- const isSavingLocale = ref(false)
- const localeMutation = new MutationHandler(useUserCurrentLocaleMutation({}), {
- errorNotificationMessage: __('The language could not be updated.'),
- })
- const { notify } = useNotifications()
- const localeStore = useLocaleStore()
- const { localeData, locales } = storeToRefs(localeStore)
- const { setLocale } = localeStore
- const modelCurrentLocale = computed({
- get: () => localeData.value?.locale ?? 'en',
- set: (locale) => {
- if (!locale || localeData.value?.locale === locale) return
- isSavingLocale.value = true
- Promise.all([setLocale(locale), localeMutation.send({ locale })])
- .then(() => {
- notify({
- id: 'locale-update',
- message: __('Profile language updated successfully.'),
- type: NotificationTypes.Success,
- })
- })
- .finally(() => {
- isSavingLocale.value = false
- })
- },
- })
- const localeOptions = computed(() => {
- return (
- locales?.value?.map((locale) => {
- return { label: locale.name, value: locale.locale }
- }) || []
- )
- })
- return {
- translation: {
- link: ZAMMAD_TRANSLATION_LINK,
- },
- isSavingLocale,
- modelCurrentLocale,
- localeOptions,
- }
- }
|