!283 fix:vue3 bug

Merge pull request !283 from weikun/master
pull/2/head
芋道源码 2022-11-02 02:01:54 +00:00 committed by Gitee
commit ce33b5c219
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
11 changed files with 86 additions and 50 deletions

View File

@ -39,5 +39,6 @@
"i18n-ally.sourceLanguage": "en", "i18n-ally.sourceLanguage": "en",
"i18n-ally.displayLanguage": "zh-CN", "i18n-ally.displayLanguage": "zh-CN",
"i18n-ally.enabledFrameworks": ["vue", "react"], "i18n-ally.enabledFrameworks": ["vue", "react"],
"god.tsconfig": "./tsconfig.json" "god.tsconfig": "./tsconfig.json",
"vue-i18n.i18nPaths": "src/locales"
} }

View File

@ -38,6 +38,7 @@
"echarts-wordcloud": "^2.0.0", "echarts-wordcloud": "^2.0.0",
"element-plus": "2.2.18", "element-plus": "2.2.18",
"intro.js": "^6.0.0", "intro.js": "^6.0.0",
"js-cookie": "^3.0.1",
"jsencrypt": "^3.2.1", "jsencrypt": "^3.2.1",
"lodash-es": "^4.17.21", "lodash-es": "^4.17.21",
"mitt": "^3.0.0", "mitt": "^3.0.0",

View File

@ -4,7 +4,7 @@ import { useAppStore } from '@/store/modules/app'
import { ConfigGlobal } from '@/components/ConfigGlobal' import { ConfigGlobal } from '@/components/ConfigGlobal'
import { isDark } from '@/utils/is' import { isDark } from '@/utils/is'
import { useDesign } from '@/hooks/web/useDesign' import { useDesign } from '@/hooks/web/useDesign'
import { useCache } from '@/hooks/web/useCache' import Cookies from 'js-cookie'
const { getPrefixCls } = useDesign() const { getPrefixCls } = useDesign()
@ -16,18 +16,19 @@ const currentSize = computed(() => appStore.getCurrentSize)
const greyMode = computed(() => appStore.getGreyMode) const greyMode = computed(() => appStore.getGreyMode)
const { wsCache } = useCache()
// //
const setDefaultTheme = () => { const setDefaultTheme = () => {
if (wsCache.get('isDark')) { if (Cookies.get('isDark')) {
appStore.setIsDark(wsCache.get('isDark')) if (Cookies.get('isDark') === 'true') {
appStore.setIsDark(true)
} else {
appStore.setIsDark(false)
}
return return
} }
const isDarkTheme = isDark() const isDarkTheme = isDark()
appStore.setIsDark(isDarkTheme) appStore.setIsDark(isDarkTheme)
} }
setDefaultTheme() setDefaultTheme()
</script> </script>

View File

@ -16,7 +16,7 @@ export const updateUserProfileApi = (params) => {
export const updateUserPwdApi = (oldPassword: string, newPassword: string) => { export const updateUserPwdApi = (oldPassword: string, newPassword: string) => {
return request.put({ return request.put({
url: '/system/user/profile/update-password', url: '/system/user/profile/update-password',
params: { data: {
oldPassword: oldPassword, oldPassword: oldPassword,
newPassword: newPassword newPassword: newPassword
} }

View File

@ -96,6 +96,7 @@ service.interceptors.request.use(
service.interceptors.response.use( service.interceptors.response.use(
async (response: AxiosResponse<Recordable>) => { async (response: AxiosResponse<Recordable>) => {
const { data } = response const { data } = response
const config = response.config
if (!data) { if (!data) {
// 返回“[HTTP]请求没有返回值”; // 返回“[HTTP]请求没有返回值”;
throw new Error() throw new Error()
@ -127,13 +128,13 @@ service.interceptors.response.use(
try { try {
const refreshTokenRes = await refreshToken() const refreshTokenRes = await refreshToken()
// 2.1 刷新成功,则回放队列的请求 + 当前请求 // 2.1 刷新成功,则回放队列的请求 + 当前请求
setToken(refreshTokenRes.data) setToken(refreshTokenRes.data.data)
;(config as Recordable).headers.Authorization = 'Bearer ' + getAccessToken() config.headers!.Authorization = 'Bearer ' + getAccessToken()
requestList.forEach((cb: any) => { requestList.forEach((cb: any) => {
cb() cb()
}) })
requestList = [] requestList = []
return service(response.config) return service(config)
} catch (e) { } catch (e) {
// 为什么需要 catch 异常呢?刷新失败时,请求因为 Promise.reject 触发异常。 // 为什么需要 catch 异常呢?刷新失败时,请求因为 Promise.reject 触发异常。
// 2.2 刷新失败,只回放队列的请求 // 2.2 刷新失败,只回放队列的请求
@ -150,8 +151,8 @@ service.interceptors.response.use(
// 添加到队列,等待刷新获取到新的令牌 // 添加到队列,等待刷新获取到新的令牌
return new Promise((resolve) => { return new Promise((resolve) => {
requestList.push(() => { requestList.push(() => {
;(config as Recordable).headers.Authorization = 'Bearer ' + getAccessToken() // 让每个请求携带自定义token 请根据实际情况自行修改 config.headers!.Authorization = 'Bearer ' + getAccessToken() // 让每个请求携带自定义token 请根据实际情况自行修改
resolve(service(response.config)) resolve(service(config))
}) })
}) })
} }

View File

@ -65,3 +65,9 @@
--transition-time-02: 0.2s; --transition-time-02: 0.2s;
} }
html,
body {
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}

View File

@ -1,4 +1,4 @@
import { JSEncrypt } from 'jsencrypt/bin/jsencrypt.min' import { JSEncrypt } from 'jsencrypt'
// 密钥对生成 http://web.chacuo.net/netrsakeypair // 密钥对生成 http://web.chacuo.net/netrsakeypair

View File

@ -65,30 +65,49 @@ export const generateRoute = (routes: AppCustomRouteRecordRaw[]): AppRouteRecord
redirect: route.redirect, redirect: route.redirect,
meta: meta meta: meta
} }
// 目录 //处理顶级非目录路由
if (route.children) { if (!route.children && route.parentId == 0 && route.component) {
data.component = Layout data.component = Layout
data.redirect = getRedirect(route.path, route.children) data.meta = {}
// 外链 data.name = toCamelCase(route.path, true) + 'Parent'
} else if (isUrl(route.path)) { data.redirect = ''
data = { const childrenData: AppRouteRecordRaw = {
path: '/external-link', path: '',
component: Layout, name: toCamelCase(route.path, true),
meta: { redirect: route.redirect,
name: route.name meta: meta
}, }
children: [data]
} as AppRouteRecordRaw
// 菜单
} else {
// 对后端传component组件路径和不传做兼容如果后端传component组件路径那么path可以随便写如果不传component组件路径会根path保持一致
const index = route?.component const index = route?.component
? modulesRoutesKeys.findIndex((ev) => ev.includes(route.component)) ? modulesRoutesKeys.findIndex((ev) => ev.includes(route.component))
: modulesRoutesKeys.findIndex((ev) => ev.includes(route.path)) : modulesRoutesKeys.findIndex((ev) => ev.includes(route.path))
data.component = modules[modulesRoutesKeys[index]] childrenData.component = modules[modulesRoutesKeys[index]]
} data.children = [childrenData]
if (route.children) { } else {
data.children = generateRoute(route.children) // 目录
if (route.children) {
data.component = Layout
data.redirect = getRedirect(route.path, route.children)
// 外链
} else if (isUrl(route.path)) {
data = {
path: '/external-link',
component: Layout,
meta: {
name: route.name
},
children: [data]
} as AppRouteRecordRaw
// 菜单
} else {
// 对后端传component组件路径和不传做兼容如果后端传component组件路径那么path可以随便写如果不传component组件路径会根path保持一致
const index = route?.component
? modulesRoutesKeys.findIndex((ev) => ev.includes(route.component))
: modulesRoutesKeys.findIndex((ev) => ev.includes(route.path))
data.component = modules[modulesRoutesKeys[index]]
}
if (route.children) {
data.children = generateRoute(route.children)
}
} }
res.push(data) res.push(data)
} }

View File

@ -13,14 +13,7 @@ import {
} from 'element-plus' } from 'element-plus'
import { reactive, ref, unref, onMounted, computed, watch } from 'vue' import { reactive, ref, unref, onMounted, computed, watch } from 'vue'
import * as LoginApi from '@/api/login' import * as LoginApi from '@/api/login'
import { import { setToken, setTenantId } from '@/utils/auth'
setToken,
setTenantId,
getUsername,
getRememberMe,
getPassword,
getTenantName
} from '@/utils/auth'
import { usePermissionStore } from '@/store/modules/permission' import { usePermissionStore } from '@/store/modules/permission'
import { useRouter } from 'vue-router' import { useRouter } from 'vue-router'
import { useI18n } from '@/hooks/web/useI18n' import { useI18n } from '@/hooks/web/useI18n'
@ -29,6 +22,8 @@ import { Icon } from '@/components/Icon'
import { LoginStateEnum, useLoginState, useFormValid } from './useLogin' import { LoginStateEnum, useLoginState, useFormValid } from './useLogin'
import type { RouteLocationNormalizedLoaded } from 'vue-router' import type { RouteLocationNormalizedLoaded } from 'vue-router'
import { Verify } from '@/components/Verifition' import { Verify } from '@/components/Verifition'
import Cookies from 'js-cookie'
import { decrypt, encrypt } from '@/utils/jsencrypt'
const { currentRoute, push } = useRouter() const { currentRoute, push } = useRouter()
const permissionStore = usePermissionStore() const permissionStore = usePermissionStore()
@ -72,7 +67,7 @@ const captchaType = ref('blockPuzzle')
// //
const getCode = async () => { const getCode = async () => {
// //
if (!loginData.captchaEnable) { if (loginData.captchaEnable === 'false') {
await handleLogin({}) await handleLogin({})
return return
} }
@ -88,15 +83,15 @@ const getTenantId = async () => {
} }
// //
const getCookie = () => { const getCookie = () => {
const username = getUsername() const username = Cookies.get('username')
const password = getPassword() const password = Cookies.get('password') ? decrypt(Cookies.get('password')) : undefined
const rememberMe = getRememberMe() const rememberMe = Cookies.get('rememberMe')
const tenantName = getTenantName() const tenantName = Cookies.get('tenantName')
loginData.loginForm = { loginData.loginForm = {
...loginData.loginForm, ...loginData.loginForm,
username: username ? username : loginData.loginForm.username, username: username ? username : loginData.loginForm.username,
password: password ? password : loginData.loginForm.password, password: password ? password : loginData.loginForm.password,
rememberMe: rememberMe ? getRememberMe() : false, rememberMe: rememberMe ? true : false,
tenantName: tenantName ? tenantName : loginData.loginForm.tenantName tenantName: tenantName ? tenantName : loginData.loginForm.tenantName
} }
} }
@ -114,6 +109,17 @@ const handleLogin = async (params) => {
if (!res) { if (!res) {
return return
} }
if (loginData.loginForm.rememberMe) {
Cookies.set('username', loginData.loginForm.username, { expires: 30 })
Cookies.set('password', encrypt(loginData.loginForm.password), { expires: 30 })
Cookies.set('rememberMe', loginData.loginForm.rememberMe, { expires: 30 })
Cookies.set('tenantName', loginData.loginForm.tenantName, { expires: 30 })
} else {
Cookies.remove('username')
Cookies.remove('password')
Cookies.remove('rememberMe')
Cookies.remove('tenantName')
}
setToken(res) setToken(res)
if (!redirect.value) { if (!redirect.value) {
redirect.value = '/' redirect.value = '/'

View File

@ -11,8 +11,8 @@ interface ImportMetaEnv {
readonly VITE_APP_TITLE: string readonly VITE_APP_TITLE: string
readonly VITE_PORT: number readonly VITE_PORT: number
readonly VITE_OPEN: boolean readonly VITE_OPEN: boolean
readonly VITE_APP_CAPTCHA_ENABLE: boolean readonly VITE_APP_CAPTCHA_ENABLE: string
readonly VITE_APP_TENANT_ENABLE: boolean readonly VITE_APP_TENANT_ENABLE: string
readonly VITE_BASE_URL: string readonly VITE_BASE_URL: string
readonly VITE_UPLOAD_URL: string readonly VITE_UPLOAD_URL: string
readonly VITE_API_BASEPATH: string readonly VITE_API_BASEPATH: string

View File

@ -74,5 +74,6 @@ declare global {
children?: AppCustomRouteRecordRaw[] children?: AppCustomRouteRecordRaw[]
keepAlive?: boolean keepAlive?: boolean
visible?: boolean visible?: boolean
parentId?: number
} }
} }