element-plus/docs/.vitepress/vitepress/composables/translation.ts

58 lines
1.6 KiB
TypeScript

import { computed } from 'vue'
import { useRouter, useRoute } from 'vitepress'
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 switchLang = (targetLang: string) => {
if (lang.value === targetLang) return
localStorage.setItem(PREFERRED_LANG_KEY, 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,
}
}