3.1.0版本发布,支持模块化语言包,升级vite版本为4.0

This commit is contained in:
ray_wuhao 2023-03-01 14:45:52 +08:00
parent fc0c2f353e
commit 13db02c6c3
14 changed files with 315 additions and 133 deletions

View File

@ -1,6 +1,9 @@
# `Ray Template`
<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section -->
[![All Contributors](https://img.shields.io/badge/all_contributors-1-orange.svg?style=flat-square)](#contributors-)
<!-- ALL-CONTRIBUTORS-BADGE:END -->
## 感谢
@ -14,7 +17,7 @@
## 前言
> 该项目模板采用 `vue3.x` `vite3.2` `tsx` 进行开发,使用 `naive ui` 作为组件库。意在提供一个简洁、快速上手的模板。
> 该项目模板采用 `vue3.x` `vite4.0` `tsx` 进行开发,使用 `naive ui` 作为组件库。意在提供一个简洁、快速上手的模板。
## 版本说明
@ -169,7 +172,6 @@ npm run preview
<!-- ALL-CONTRIBUTORS-LIST:END -->
## Contributors ✨
Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):
@ -179,6 +181,7 @@ Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/d
<!-- markdownlint-disable -->
<!-- markdownlint-restore -->
<!-- prettier-ignore-end -->
<!-- ALL-CONTRIBUTORS-LIST:END -->
This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!
This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!

View File

@ -0,0 +1,40 @@
{
"GlobalMenuOptions": {
"Dashboard": "Home",
"Rely": "Rely",
"RelyAbout": "Rely About",
"Error": "Error Page",
"Echart": "Chart",
"scrollReveal": "Scroll Reveal",
"Axios": "Axios Request",
"Table": "Table",
"Doc": "Doc",
"DocLocal": "Doc (China)"
},
"LayoutHeaderTooltipOptions": {
"Reload": "Reload Current Page",
"Lock": "Lock",
"Setting": "Setting",
"Github": "Github",
"FullScreen": "Full Screen",
"CancelFullScreen": "Cancel Full Screen"
},
"LayoutHeaderSettingOptions": {
"Title": "Configuration",
"ThemeOptions": {
"Title": "Theme",
"Dark": "Dark",
"Light": "Light",
"PrimaryColorConfig": "Primary Color"
}
},
"LoginModule": {
"Register": "Register",
"Signin": "Signin",
"NamePlaceholder": "please enter user name",
"PasswordPlaceholder": "please enter password",
"Login": "Login",
"Name": "User Name",
"Password": "User Password"
}
}

View File

@ -0,0 +1,40 @@
{
"GlobalMenuOptions": {
"Dashboard": "首页",
"Rely": "依赖项",
"RelyAbout": "关于",
"Error": "错误页",
"Echart": "可视化",
"scrollReveal": "滚动动画",
"Axios": "请求",
"Table": "表格",
"Doc": "文档",
"DocLocal": "文档 (国内地址)"
},
"LayoutHeaderTooltipOptions": {
"Reload": "刷新当前页面",
"Lock": "锁屏",
"Setting": "设置",
"Github": "Github",
"FullScreen": "全屏",
"CancelFullScreen": "退出全屏"
},
"LayoutHeaderSettingOptions": {
"Title": "项目配置",
"ThemeOptions": {
"Title": "主题",
"Dark": "暗色",
"Light": "明亮",
"PrimaryColorConfig": "主题色"
}
},
"LoginModule": {
"Register": "注册",
"Signin": "登陆",
"NamePlaceholder": "请输入用户名",
"PasswordPlaceholder": "请输入密码",
"Login": "登 陆",
"Name": "用户名",
"Password": "密码"
}
}

View File

@ -0,0 +1,40 @@
{
"GlobalMenuOptions": {
"Dashboard": "Home",
"Rely": "Rely",
"RelyAbout": "Rely About",
"Error": "Error Page",
"Echart": "Chart",
"scrollReveal": "Scroll Reveal",
"Axios": "Axios Request",
"Table": "Table",
"Doc": "Doc",
"DocLocal": "Doc (China)"
},
"LayoutHeaderTooltipOptions": {
"Reload": "Reload Current Page",
"Lock": "Lock",
"Setting": "Setting",
"Github": "Github",
"FullScreen": "Full Screen",
"CancelFullScreen": "Cancel Full Screen"
},
"LayoutHeaderSettingOptions": {
"Title": "Configuration",
"ThemeOptions": {
"Title": "Theme",
"Dark": "Dark",
"Light": "Light",
"PrimaryColorConfig": "Primary Color"
}
},
"LoginModule": {
"Register": "Register",
"Signin": "Signin",
"NamePlaceholder": "please enter user name",
"PasswordPlaceholder": "please enter password",
"Login": "Login",
"Name": "User Name",
"Password": "User Password"
}
}

View File

@ -0,0 +1,40 @@
{
"GlobalMenuOptions": {
"Dashboard": "首页",
"Rely": "依赖项",
"RelyAbout": "关于",
"Error": "错误页",
"Echart": "可视化",
"scrollReveal": "滚动动画",
"Axios": "请求",
"Table": "表格",
"Doc": "文档",
"DocLocal": "文档 (国内地址)"
},
"LayoutHeaderTooltipOptions": {
"Reload": "刷新当前页面",
"Lock": "锁屏",
"Setting": "设置",
"Github": "Github",
"FullScreen": "全屏",
"CancelFullScreen": "退出全屏"
},
"LayoutHeaderSettingOptions": {
"Title": "项目配置",
"ThemeOptions": {
"Title": "主题",
"Dark": "暗色",
"Light": "明亮",
"PrimaryColorConfig": "主题色"
}
},
"LoginModule": {
"Register": "注册",
"Signin": "登陆",
"NamePlaceholder": "请输入用户名",
"PasswordPlaceholder": "请输入密码",
"Login": "登 陆",
"Name": "用户名",
"Password": "密码"
}
}

View File

@ -1,11 +1,11 @@
{
"name": "ray-template",
"private": true,
"version": "3.0.8",
"version": "3.1.0",
"type": "module",
"scripts": {
"dev": "vite",
"build": "vue-tsc --noEmit && vite build",
"build": "vue-tsc --noEmit && vite build --mode production",
"preview": "vite preview",
"test": "vue-tsc --noEmit && vite build --mode test",
"dev-build": "vue-tsc --noEmit && vite build --mode development",
@ -72,7 +72,7 @@
"typescript": "*",
"unplugin-auto-import": "^0.11.0",
"unplugin-vue-components": "^0.22.0",
"vite": "^3.2.4",
"vite": "^4.1.4",
"vite-plugin-compression": "^0.5.1",
"vite-plugin-eslint": "^1.8.1",
"vite-plugin-imp": "^2.3.1",

View File

@ -9,15 +9,60 @@
* @remark
*/
import { createI18n } from 'vue-i18n'
import messages from '@intlify/unplugin-vue-i18n/messages' // 导入所有语言包
import { zhCN, dateZhCN } from 'naive-ui' // 导入 `naive ui` 中文包
import { enUS, dateEnUS } from 'naive-ui' // 导入 `naive ui` 英文包
/**
*
* `vue-i18n`
*
* `localeLanguage` `key`
*
*
*
* `naive ui`
*
* :
* - 使 `i18n` , `locales` ,
* -
*/
import { createI18n } from 'vue-i18n'
import { naiveLocales } from './language'
import { getCache } from '@use-utils/cache'
export { naiveLocales, localOptions } from './language'
import type { App } from 'vue'
/**
*
* @returns
*
* @remark locales json , ()
* @remark key , , key ,
*/
export const getMatchLanguageModule = () => {
const msg = {}
const reg = /([^\\/]+)\.json$/i
try {
const modules = import.meta.glob('../../locales/**', {
eager: true,
as: 'raw',
})
const moduleKeys = Object.keys(modules)
moduleKeys.forEach((curr) => {
const k = curr.match(reg)?.[1] as string
msg[k] = Object.assign({}, JSON.parse(modules[curr]))
})
} catch (e) {
console.error(e)
}
return msg
}
/**
*
* @returns
@ -25,10 +70,9 @@ import type { App } from 'vue'
* @remak , `main.ts` , `i18n`
*/
export const getDefaultLocal = () => {
const locale: string =
getCache('localeLanguage', 'localStorage') !== 'no'
? getCache('localeLanguage', 'localStorage')
: 'zh-CN'
const catchLanguage = getCache('localeLanguage', 'localStorage')
const locale: string = catchLanguage !== 'no' ? catchLanguage : 'zh-CN'
return locale
}
@ -39,52 +83,12 @@ export const setupI18n = (app: App<Element>) => {
const i18n = createI18n({
locale,
allowComposition: true,
messages,
messages: getMatchLanguageModule(),
})
app.use(i18n)
}
export const useLanguageOptions = () => [
{
key: 'zh-CN',
label: '中文(简体)',
},
{
key: 'en-US',
label: 'English(US)',
},
]
/**
*
* @param key
* @returns
*
* @remark . , (https://www.naiveui.com/zh-CN/dark/docs/i18n)
*/
export const getNaiveLocal = (key: string) => {
switch (key) {
case 'zh-CN':
return {
local: zhCN,
dateLocal: dateZhCN,
}
case 'en-US':
return {
local: enUS,
dateLocal: dateEnUS,
}
default:
return {
local: zhCN,
dateLocal: dateZhCN,
}
}
}
/**
*
* @returns
@ -94,18 +98,5 @@ export const getNaiveLocal = (key: string) => {
export const getDefaultNaiveLocal = () => {
const local = getDefaultLocal()
return getNaiveLocal(local)
return naiveLocales(local)
}
/**
*
* `vue-i18n`
*
* 注意: 因使用 `i18n` , `locales` ,
*
* `localeLanguage` `key`
*
*
*
* `naive ui`
*/

54
src/language/language.ts Normal file
View File

@ -0,0 +1,54 @@
/**
*
* @author Ray <https://github.com/XiaoDaiGua-Ray>
*
* @date 2023-03-01
*
* @workspace ray-template
*
* @remark
*/
import { zhCN, dateZhCN } from 'naive-ui' // 导入 `naive ui` 中文包
import { enUS, dateEnUS } from 'naive-ui' // 导入 `naive ui` 英文包
/** 语言包语种添加后, 需要在此文件配置语言包 */
export const localOptions = [
{
key: 'zh-CN',
label: '中文(简体)',
},
{
key: 'en-US',
label: 'English(US)',
},
]
/**
*
* @param key
* @returns
*
* @remark . , (https://www.naiveui.com/zh-CN/dark/docs/i18n)
*/
export const naiveLocales = (key: string) => {
switch (key) {
case 'zh-CN':
return {
local: zhCN,
dateLocal: dateZhCN,
}
case 'en-US':
return {
local: enUS,
dateLocal: dateEnUS,
}
default:
return {
local: zhCN,
dateLocal: dateZhCN,
}
}
}

View File

@ -17,7 +17,7 @@ import RayTooltipIcon from '@/components/RayTooltipIcon/index'
import SettingDrawer from './components/SettingDrawer/index'
import { useSetting } from '@/store'
import { useLanguageOptions } from '@/language/index'
import { localOptions } from '@/language/index'
import { useAvatarOptions } from './hook'
import { getCache } from '@/utils/cache'
import screenfull from 'screenfull'
@ -169,7 +169,7 @@ const SiderBar = defineComponent({
/>
))}
<NDropdown
options={useLanguageOptions()}
options={localOptions}
onSelect={(key: string | number) =>
this.updateLocale(String(key))
}

View File

@ -1,4 +1,4 @@
import { getNaiveLocal, getDefaultNaiveLocal } from '@/language/index'
import { naiveLocales, getDefaultNaiveLocal } from '@/language/index'
export const useSetting = defineStore(
'setting',
@ -21,7 +21,7 @@ export const useSetting = defineStore(
const updateLocale = (key: string) => {
// TODO: 修改语言
locale.value = key
settingState.naiveLocal = getNaiveLocal(key)
settingState.naiveLocal = naiveLocales(key)
}
const changePrimaryColor = (value: string) => {

View File

@ -12,7 +12,7 @@ import Signin from './components/Signin/index'
import Register from './components/Register/index'
import { useSetting } from '@/store'
import RayIcon from '@/components/RayIcon'
import { useLanguageOptions } from '@/language/index'
import { localOptions } from '@/language/index'
import RayLink from '@/components/RayLink/index'
const Login = defineComponent({
@ -41,7 +41,7 @@ const Login = defineComponent({
Ray Template
</NGradientText>
<NDropdown
options={useLanguageOptions()}
options={localOptions}
onSelect={(key) => this.updateLocale(key)}
>
<RayIcon customClassName="login-icon" name="language" size="18" />

View File

@ -12,6 +12,7 @@
"vite-plugin/type.ts",
"cfg.ts",
"src/types/cfg.ts",
"package.json"
"package.json",
"vite-env.d.ts"
]
}

View File

@ -98,66 +98,36 @@ export const HTMLTitlePlugin = (title: string) => {
* @remark
*/
export const buildOptions = (mode: string): BuildOptions => {
switch (mode) {
case 'test':
return {
outDir: 'dist/test-dist',
sourcemap: true,
terserOptions: {
compress: {
drop_console: false,
drop_debugger: false,
},
},
}
const outDirMap = {
test: 'dist/test-dist',
development: 'dist/development-dist',
production: 'dist/production-dist',
report: 'dist/report-dist',
}
const dirPath = outDirMap[mode] || 'dist/test-dist'
case 'development':
return {
outDir: 'dist/development-dist',
sourcemap: true,
terserOptions: {
compress: {
drop_console: false,
drop_debugger: false,
},
if (mode === 'production') {
return {
outDir: dirPath,
sourcemap: false,
terserOptions: {
compress: {
drop_console: true,
drop_debugger: true,
},
}
case 'production':
return {
outDir: 'dist/production-dist',
sourcemap: false,
terserOptions: {
compress: {
drop_console: true,
drop_debugger: true,
},
},
}
} else {
return {
outDir: dirPath,
sourcemap: true,
terserOptions: {
compress: {
drop_console: false,
drop_debugger: false,
},
}
case 'report':
return {
outDir: 'dist/report-dist',
sourcemap: true,
terserOptions: {
compress: {
drop_console: false,
drop_debugger: false,
},
},
}
default:
return {
outDir: 'dist/test-dist',
sourcemap: false,
terserOptions: {
compress: {
drop_console: true, // 打包后移除 `console`
drop_debugger: true, // 打包后移除 `debugger`
},
},
}
},
}
}
}

View File

@ -118,6 +118,9 @@ export default defineConfig(async ({ mode }) => {
optimizeDeps: {
include: ['vue', 'vue-router', 'pinia', 'vue-i18n', '@vueuse/core'],
},
esbuild: {
pure: ['console.log'],
},
build: {
...buildOptions(mode),
rollupOptions: {