fix
This commit is contained in:
12
src/App.vue
12
src/App.vue
@@ -1,6 +1,6 @@
|
|||||||
<template>
|
<template>
|
||||||
<!-- <RouteCache /> -->
|
<!-- <RouteCache /> -->
|
||||||
<router-view v-if="show"></router-view>
|
<router-view></router-view>
|
||||||
<div id="loading" v-if="loading" v-loading="true"></div>
|
<div id="loading" v-if="loading" v-loading="true"></div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@@ -22,19 +22,15 @@
|
|||||||
window['onClickRegister'] = () => {
|
window['onClickRegister'] = () => {
|
||||||
router.push({ name: 'register' })
|
router.push({ name: 'register' })
|
||||||
}
|
}
|
||||||
const show = ref(true)
|
|
||||||
provide('reload', () => {
|
|
||||||
show.value = false
|
|
||||||
nextTick(() => {
|
|
||||||
show.value = true
|
|
||||||
})
|
|
||||||
})
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="less">
|
<style lang="less">
|
||||||
#app {
|
#app {
|
||||||
font-size: 1.6rem;
|
font-size: 1.6rem;
|
||||||
}
|
}
|
||||||
|
.el-message{
|
||||||
|
font-size: 1.6rem;
|
||||||
|
}
|
||||||
#loading {
|
#loading {
|
||||||
position: fixed;
|
position: fixed;
|
||||||
z-index: 999999999;
|
z-index: 999999999;
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ export const SendVerificationCode = (params) => {
|
|||||||
return request({
|
return request({
|
||||||
url: '/api/user/send-verification-code',
|
url: '/api/user/send-verification-code',
|
||||||
method: 'post',
|
method: 'post',
|
||||||
|
loading: true,
|
||||||
params
|
params
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@@ -28,6 +29,7 @@ export const Register = (data) => {
|
|||||||
return request({
|
return request({
|
||||||
url: '/api/user/register',
|
url: '/api/user/register',
|
||||||
method: 'post',
|
method: 'post',
|
||||||
|
loading: true,
|
||||||
data
|
data
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@@ -43,6 +45,7 @@ export const Login = (data) => {
|
|||||||
return request({
|
return request({
|
||||||
url: '/api/user/login',
|
url: '/api/user/login',
|
||||||
method: 'post',
|
method: 'post',
|
||||||
|
loading: true,
|
||||||
data
|
data
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@@ -4,7 +4,7 @@ export default {
|
|||||||
login: 'Log in',
|
login: 'Log in',
|
||||||
register: 'Register',
|
register: 'Register',
|
||||||
loginTo: 'Log on to <span>FiDA</span>',
|
loginTo: 'Log on to <span>FiDA</span>',
|
||||||
LoginTitle: 'A multi-agent canvas for rapid, trend driven design iteration.',
|
loginTitle: 'A multi-agent canvas for rapid, trend driven design iteration.',
|
||||||
name: 'Name',
|
name: 'Name',
|
||||||
email: 'Email',
|
email: 'Email',
|
||||||
password: 'Password',
|
password: 'Password',
|
||||||
|
|||||||
@@ -27,7 +27,7 @@ const i18n = createI18n({
|
|||||||
warnHtmlMessage: false,
|
warnHtmlMessage: false,
|
||||||
legacy: false,
|
legacy: false,
|
||||||
globalInjection:true, // 全局模式,可以直接使用 $t
|
globalInjection:true, // 全局模式,可以直接使用 $t
|
||||||
locale: 'ENGLISH',
|
locale: localStorage.getItem('language') || 'ENGLISH',
|
||||||
messages: messages
|
messages: messages
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import axios from 'axios'
|
import axios from 'axios'
|
||||||
import router from '@/router/index'
|
import router from '@/router/index'
|
||||||
import { useGlobalStore, useUserInfoStore } from '@/stores'
|
import { useGlobalStore, useUserInfoStore } from '@/stores'
|
||||||
|
import { ElMessage } from 'element-plus'
|
||||||
|
|
||||||
// 扩展 AxiosRequestConfig 接口
|
// 扩展 AxiosRequestConfig 接口
|
||||||
declare module 'axios' {
|
declare module 'axios' {
|
||||||
@@ -80,13 +81,7 @@ service.interceptors.response.use(
|
|||||||
// 处理异常的情况
|
// 处理异常的情况
|
||||||
// console.log(res)
|
// console.log(res)
|
||||||
if (res.code != 200) {
|
if (res.code != 200) {
|
||||||
// showToast({
|
ElMessage.error(res.message)
|
||||||
// message: res.errMsg || res.message,
|
|
||||||
// // type: 'fail',
|
|
||||||
// duration: 5000,
|
|
||||||
// position: 'top',
|
|
||||||
// icon: 'none'
|
|
||||||
// })
|
|
||||||
return Promise.reject(new Error(res.errMsg || res.message || 'error'))
|
return Promise.reject(new Error(res.errMsg || res.message || 'error'))
|
||||||
} else {
|
} else {
|
||||||
// 默认只返回data,不返回状态码和message
|
// 默认只返回data,不返回状态码和message
|
||||||
@@ -123,11 +118,7 @@ service.interceptors.response.use(
|
|||||||
}
|
}
|
||||||
error.config && removePending(error.config)
|
error.config && removePending(error.config)
|
||||||
console.log('err' + error) // for debug
|
console.log('err' + error) // for debug
|
||||||
// showToast({
|
ElMessage.error(error.message)
|
||||||
// message: error.message,
|
|
||||||
// type: 'fail',
|
|
||||||
// duration: 5000
|
|
||||||
// })
|
|
||||||
}
|
}
|
||||||
return Promise.reject(error)
|
return Promise.reject(error)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,12 +18,13 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { computed, ref, onBeforeUnmount, inject } from 'vue'
|
import { computed, ref, nextTick, inject } from 'vue'
|
||||||
|
import { useRouter } from 'vue-router'
|
||||||
import dropdownMenu from '@/components/dropdown-menu.vue'
|
import dropdownMenu from '@/components/dropdown-menu.vue'
|
||||||
import { useUserInfoStore } from '@/stores'
|
import { useUserInfoStore } from '@/stores'
|
||||||
import { useI18n } from 'vue-i18n'
|
import { useI18n } from 'vue-i18n'
|
||||||
|
const router = useRouter()
|
||||||
const { locale } = useI18n()
|
const { locale } = useI18n()
|
||||||
const reload = inject('reload')
|
|
||||||
const userInfoStore = useUserInfoStore()
|
const userInfoStore = useUserInfoStore()
|
||||||
const langs = ref([
|
const langs = ref([
|
||||||
{ label: 'English', value: 'ENGLISH' },
|
{ label: 'English', value: 'ENGLISH' },
|
||||||
@@ -31,7 +32,10 @@
|
|||||||
])
|
])
|
||||||
const changeLang = (value: string) => {
|
const changeLang = (value: string) => {
|
||||||
locale.value = value
|
locale.value = value
|
||||||
reload()
|
localStorage.setItem('language', value)
|
||||||
|
nextTick(() => {
|
||||||
|
router.go(0)
|
||||||
|
})
|
||||||
}
|
}
|
||||||
const logout = () => {
|
const logout = () => {
|
||||||
userInfoStore.logOut()
|
userInfoStore.logOut()
|
||||||
|
|||||||
@@ -102,6 +102,7 @@
|
|||||||
verificationCode: code
|
verificationCode: code
|
||||||
})
|
})
|
||||||
.then((res) => {
|
.then((res) => {
|
||||||
|
console.log(res)
|
||||||
if (res) {
|
if (res) {
|
||||||
userInfoStore.setToken(res)
|
userInfoStore.setToken(res)
|
||||||
userInfoStore.setUserInfo({
|
userInfoStore.setUserInfo({
|
||||||
@@ -110,8 +111,8 @@
|
|||||||
router.push({ name: 'mainInput' })
|
router.push({ name: 'mainInput' })
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.catch(() => {
|
.catch((error) => {
|
||||||
console.warn('error verify code!')
|
console.warn(error)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
Reference in New Issue
Block a user