perf: loginform code

pull/2/head
xingyu 2022-07-20 00:07:16 +08:00
parent 6d27ba4375
commit c8823752d0
3 changed files with 56 additions and 31 deletions

View File

@ -124,7 +124,15 @@ service.interceptors.response.use(
}, },
(error: AxiosError) => { (error: AxiosError) => {
console.log('err' + error) // for debug console.log('err' + error) // for debug
ElMessage.error(error.message) let { message } = error
if (message === 'Network Error') {
message = '后端接口连接异常'
} else if (message.includes('timeout')) {
message = '系统接口请求超时'
} else if (message.includes('Request failed with status code')) {
message = '系统接口' + message.substr(message.length - 3) + '异常'
}
ElMessage.error(message)
return Promise.reject(error) return Promise.reject(error)
} }
) )

View File

@ -13,7 +13,14 @@ 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 { setToken, setTenantId } from '@/utils/auth' import {
setToken,
setTenantId,
getUsername,
getRememberMe,
getPassword,
getTenantName
} from '@/utils/auth'
import { useUserStoreWithOut } from '@/store/modules/user' import { useUserStoreWithOut } from '@/store/modules/user'
import { useCache } from '@/hooks/web/useCache' import { useCache } from '@/hooks/web/useCache'
import { usePermissionStore } from '@/store/modules/permission' import { usePermissionStore } from '@/store/modules/permission'
@ -40,7 +47,6 @@ const iconHouse = useIcon({ icon: 'ep:house' })
const iconAvatar = useIcon({ icon: 'ep:avatar' }) const iconAvatar = useIcon({ icon: 'ep:avatar' })
const iconLock = useIcon({ icon: 'ep:lock' }) const iconLock = useIcon({ icon: 'ep:lock' })
const iconCircleCheck = useIcon({ icon: 'ep:circle-check' }) const iconCircleCheck = useIcon({ icon: 'ep:circle-check' })
const remember = ref(false)
const LoginRules = { const LoginRules = {
tenantName: [required], tenantName: [required],
username: [required], username: [required],
@ -61,6 +67,7 @@ const loginData = reactive({
tenantName: '芋道源码', tenantName: '芋道源码',
username: 'admin', username: 'admin',
password: 'admin123', password: 'admin123',
rememberMe: false,
code: '', code: '',
uuid: '' uuid: ''
} }
@ -77,6 +84,20 @@ const getTenantId = async () => {
const res = await LoginApi.getTenantIdByNameApi(loginData.loginForm.tenantName) const res = await LoginApi.getTenantIdByNameApi(loginData.loginForm.tenantName)
setTenantId(res) setTenantId(res)
} }
//
const getCookie = () => {
const username = getUsername()
const password = getPassword()
const rememberMe = getRememberMe()
const tenantName = getTenantName()
loginData.loginForm = {
...loginData.loginForm,
username: username ? username : loginData.loginForm.username,
password: password ? password : loginData.loginForm.password,
rememberMe: rememberMe ? getRememberMe() : false,
tenantName: tenantName ? tenantName : loginData.loginForm.tenantName
}
}
// //
const handleLogin = async () => { const handleLogin = async () => {
await getTenantId() await getTenantId()
@ -103,7 +124,7 @@ const getRoutes = async () => {
// //
const res = await LoginApi.getAsyncRoutesApi() const res = await LoginApi.getAsyncRoutesApi()
wsCache.set('roleRouters', res) wsCache.set('roleRouters', res)
await permissionStore.generateRoutes(res).catch(() => {}) await permissionStore.generateRoutes(res)
permissionStore.getAddRouters.forEach((route) => { permissionStore.getAddRouters.forEach((route) => {
addRoute(route as RouteRecordRaw) // 访 addRoute(route as RouteRecordRaw) // 访
}) })
@ -120,8 +141,9 @@ watch(
immediate: true immediate: true
} }
) )
onMounted(() => { onMounted(async () => {
getCode() await getCode()
getCookie()
}) })
</script> </script>
<template> <template>
@ -165,7 +187,7 @@ onMounted(() => {
<el-input <el-input
v-model="loginData.loginForm.password" v-model="loginData.loginForm.password"
type="password" type="password"
:placeholder="t('login.password')" :placeholder="t('login.passwordPlaceholder')"
show-password show-password
@keyup.enter="handleLogin" @keyup.enter="handleLogin"
:prefix-icon="iconLock" :prefix-icon="iconLock"
@ -178,7 +200,7 @@ onMounted(() => {
<el-col :span="14"> <el-col :span="14">
<el-input <el-input
v-model="loginData.loginForm.code" v-model="loginData.loginForm.code"
:placeholder="t('login.code')" :placeholder="t('login.codePlaceholder')"
@keyup.enter="handleLogin" @keyup.enter="handleLogin"
:prefix-icon="iconCircleCheck" :prefix-icon="iconCircleCheck"
style="width: 90%" style="width: 90%"
@ -199,7 +221,9 @@ onMounted(() => {
<el-form-item> <el-form-item>
<el-row justify="space-between" style="width: 100%"> <el-row justify="space-between" style="width: 100%">
<el-col :span="6"> <el-col :span="6">
<el-checkbox v-model="remember">{{ t('login.remember') }}</el-checkbox> <el-checkbox v-model="loginData.loginForm.rememberMe">
{{ t('login.remember') }}
</el-checkbox>
</el-col> </el-col>
<el-col :span="12" :offset="6"> <el-col :span="12" :offset="6">
<el-link type="primary" style="float: right">{{ t('login.forgetPassword') }}</el-link> <el-link type="primary" style="float: right">{{ t('login.forgetPassword') }}</el-link>
@ -254,7 +278,7 @@ onMounted(() => {
class="cursor-pointer anticon" class="cursor-pointer anticon"
/> />
<Icon <Icon
icon="ant-design:weibo-circle-filled" icon="ant-design:dingtalk-circle-filled"
:size="iconSize" :size="iconSize"
:color="iconColor" :color="iconColor"
class="cursor-pointer anticon" class="cursor-pointer anticon"

View File

@ -67,27 +67,21 @@ const redirect = ref<string>('')
const getSmsCode = async () => { const getSmsCode = async () => {
await getTenantId() await getTenantId()
smsVO.smsCode.mobile = loginData.loginForm.mobileNumber smsVO.smsCode.mobile = loginData.loginForm.mobileNumber
console.log('getSmsCode begin:', smsVO.smsCode) await sendSmsCodeApi(smsVO.smsCode).then(async () => {
await sendSmsCodeApi(smsVO.smsCode) //
.then(async (res) => { ElMessage({
// type: 'success',
ElMessage({ message: t('login.SmsSendMsg')
type: 'success',
message: t('login.SmsSendMsg')
})
console.log('res', res)
//
mobileCodeTimer.value = 60
let msgTimer = setInterval(() => {
mobileCodeTimer.value = mobileCodeTimer.value - 1
if (mobileCodeTimer.value <= 0) {
clearInterval(msgTimer)
}
}, 1000)
})
.catch(() => {
console.log('error')
}) })
//
mobileCodeTimer.value = 60
let msgTimer = setInterval(() => {
mobileCodeTimer.value = mobileCodeTimer.value - 1
if (mobileCodeTimer.value <= 0) {
clearInterval(msgTimer)
}
}, 1000)
})
} }
watch( watch(
() => currentRoute.value, () => currentRoute.value,
@ -126,7 +120,6 @@ const signIn = async () => {
// //
const getRoutes = async () => { const getRoutes = async () => {
// //
// TODO @jinz getRoutes store ruoyi-vue
const routers = await getAsyncRoutesApi() const routers = await getAsyncRoutesApi()
wsCache.set('roleRouters', routers) wsCache.set('roleRouters', routers)
await permissionStore.generateRoutes(routers).catch(() => {}) await permissionStore.generateRoutes(routers).catch(() => {})