plus-pro-components
Version:
Page level components developed based on Element Plus.
37 lines (33 loc) • 1.18 kB
JavaScript
;
var vue = require('vue');
var lodashEs = require('lodash-es');
var elementPlus = require('element-plus');
var en = require('../locale/lang/en.js');
const buildTranslator = (locale) => (path, option) => translate(path, option, vue.unref(locale));
const translate = (path, option, locale) => lodashEs.get(locale, path, path).replace(
/\{(\w+)\}/g,
(_, key) => {
var _a;
return `${(_a = option == null ? void 0 : option[key]) != null ? _a : `{${key}}`}`;
}
);
const buildLocaleContext = (locale) => {
const lang = vue.computed(() => vue.unref(locale).name);
const localeRef = vue.isRef(locale) ? locale : vue.ref(locale);
return {
lang,
locale: localeRef,
t: buildTranslator(locale)
};
};
const useLocale = (localeOverrides) => {
const locale = localeOverrides || vue.inject(elementPlus.localeContextKey, vue.ref());
return buildLocaleContext(vue.computed(() => {
var _a;
return ((_a = locale.value) == null ? void 0 : _a.plus) ? locale.value : en.default;
}));
};
exports.buildLocaleContext = buildLocaleContext;
exports.buildTranslator = buildTranslator;
exports.translate = translate;
exports.useLocale = useLocale;