mirror of
https://github.com/vbenjs/vue-vben-admin.git
synced 2025-08-27 16:51:22 +08:00
feat: add naive app
This commit is contained in:
3
apps/web-naive/src/locales/README.md
Normal file
3
apps/web-naive/src/locales/README.md
Normal file
@@ -0,0 +1,3 @@
|
||||
# locale
|
||||
|
||||
每个app使用的国际化可能不同,这里用于扩展国际化的功能,例如扩展 dayjs、antd组件库的多语言切换,以及app本身的国际化文件。
|
31
apps/web-naive/src/locales/index.ts
Normal file
31
apps/web-naive/src/locales/index.ts
Normal file
@@ -0,0 +1,31 @@
|
||||
import type { LocaleSetupOptions, SupportedLanguagesType } from '@vben/locales';
|
||||
|
||||
import type { App } from 'vue';
|
||||
|
||||
import { $t, setupI18n as coreSetup, loadLocalesMap } from '@vben/locales';
|
||||
import { preferences } from '@vben/preferences';
|
||||
|
||||
const modules = import.meta.glob('./langs/*.json');
|
||||
|
||||
const localesMap = loadLocalesMap(modules);
|
||||
|
||||
/**
|
||||
* 加载应用特有的语言包
|
||||
* 这里也可以改造为从服务端获取翻译数据
|
||||
* @param lang
|
||||
*/
|
||||
async function loadMessages(lang: SupportedLanguagesType) {
|
||||
const appLocaleMessages = await localesMap[lang]();
|
||||
return appLocaleMessages.default;
|
||||
}
|
||||
|
||||
async function setupI18n(app: App, options: LocaleSetupOptions = {}) {
|
||||
await coreSetup(app, {
|
||||
defaultLocale: preferences.app.locale,
|
||||
loadMessages,
|
||||
missingWarn: !import.meta.env.PROD,
|
||||
...options,
|
||||
});
|
||||
}
|
||||
|
||||
export { $t, loadMessages, setupI18n };
|
8
apps/web-naive/src/locales/langs/en-US.json
Normal file
8
apps/web-naive/src/locales/langs/en-US.json
Normal file
@@ -0,0 +1,8 @@
|
||||
{
|
||||
"page": {
|
||||
"demos": {
|
||||
"title": "Demos",
|
||||
"naive": "Naive UI"
|
||||
}
|
||||
}
|
||||
}
|
8
apps/web-naive/src/locales/langs/zh-CN.json
Normal file
8
apps/web-naive/src/locales/langs/zh-CN.json
Normal file
@@ -0,0 +1,8 @@
|
||||
{
|
||||
"page": {
|
||||
"demos": {
|
||||
"title": "演示",
|
||||
"naive": "Naive UI"
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user