element-plus/docs/.vitepress/vitepress/composables/translation.ts
2022-03-25 15:35:56 +08:00

63 lines
1.7 KiB
TypeScript

import { computed } from 'vue'
import { useRoute, useRouter } from 'vitepress'
import { useStorage } from '@vueuse/core'
import { PREFERRED_LANG_KEY } from '../constant'
import langs from '../../i18n/lang.json'
import translationLocale from '../../i18n/component/translation.json'
import { useLang } from './lang'
export const useTranslation = () => {
const route = useRoute()
const router = useRouter()
const lang = useLang()
const languageMap = {
'en-US': 'English',
'zh-CN': '中文',
'es-ES': 'Español',
'fr-FR': 'Français',
'ja-JP': '日本語',
}
const helpTranslate = computed(() => translationLocale[lang.value].help)
const langsRef = computed(() => {
const currentLang = lang.value
// When there is no zh-CN in the list, meaning this is the PR preview
// so we simply return the current list which contains only en-US
if (!langs.includes('zh-CN')) return []
const langsCopy = langs.slice(0)
langsCopy.splice(langsCopy.indexOf(currentLang), 1)
// if current language is not zh-CN, then zh-CN needs to be moved to the head.
if (currentLang !== 'zh-CN') {
langsCopy.splice(langsCopy.indexOf('zh-CN'), 1)
}
return currentLang === 'zh-CN' ? langsCopy : ['zh-CN'].concat(langsCopy)
})
const language = useStorage(PREFERRED_LANG_KEY, 'en-US')
const switchLang = (targetLang: string) => {
if (lang.value === targetLang) return
language.value = targetLang
const firstSlash = route.path.indexOf('/', 1)
const goTo = `/${targetLang}/${route.path.slice(firstSlash + 1)}`
router.go(goTo)
}
return {
helpTranslate,
languageMap,
langs: langsRef,
lang,
switchLang,
}
}