at-ui
Version:
A UI Component Library with Vue.js
60 lines (48 loc) • 1.23 kB
JavaScript
/**
* Simplified version
* https://github.com/ElemeFE/element/blob/dev/src/locale/index.js
*/
import Vue from 'vue'
import deepmerge from 'deepmerge'
import defaultLang from './lang/en-US'
let lang = defaultLang
let merged = false
let i18nHandler = function (...args) {
const vuei18n = Object.getPrototypeOf(this || Vue).$t
if (typeof vuei18n === 'function' && !!Vue.locale) {
if (!merged) {
merged = true
Vue.locale(
Vue.config.lang,
deepmerge(lang, Vue.locale(Vue.config.lang) || {}, { clone: true })
)
}
return vuei18n.apply(this, args)
}
}
export const t = function (...args) {
let value = i18nHandler.apply(this, args)
if (value !== null && typeof value !== 'undefined') {
return value
}
const array = args[0].split('.')
let current = lang
for (let i = 0, len = array.length; i < len; i++) {
const property = array[i]
value = current[property]
if (i === len - 1) {
return value
} else if (!value) {
return ''
}
current = value
}
return ''
}
export const use = function (l) {
lang = l || lang
}
export const i18n = function (fn) {
i18nHandler = fn || i18nHandler
}
export default { use, t, i18n }