edu/admin/src/views/account/login.vue

131 lines
4.4 KiB
Vue
Raw Normal View History

2022-04-08 02:42:44 +00:00
<template>
<div class="login flex flex-col">
2022-08-12 10:44:09 +00:00
<div class="flex-1 flex items-center justify-center">
<div class="login-card flex rounded-md">
<div class="flex-1 h-full hidden md:inline-block">
<image-contain :src="config.webBackdrop" :width="400" height="100%" />
</div>
2022-04-08 02:42:44 +00:00
<div
2022-09-20 08:23:29 +00:00
class="login-form bg-body flex flex-col justify-center px-10 py-10 md:w-[400px] w-[375px] flex-none mx-auto"
2022-08-12 10:44:09 +00:00
>
<div class="text-center text-3xl font-medium mb-8">{{ config.webName }}</div>
<el-form ref="formRef" :model="formData" size="large" :rules="rules">
2022-04-08 02:42:44 +00:00
<el-form-item prop="account">
<el-input
2022-08-12 10:44:09 +00:00
v-model.trim="formData.account"
2022-04-08 02:42:44 +00:00
placeholder="请输入账号"
@keyup.enter="handleEnter"
>
<template #prepend>
2022-08-12 10:44:09 +00:00
<icon name="el-icon-Avatar" />
2022-04-08 02:42:44 +00:00
</template>
</el-input>
</el-form-item>
<el-form-item prop="password">
<el-input
2022-08-12 10:44:09 +00:00
ref="passwordRef"
v-model="formData.password"
2022-04-08 02:42:44 +00:00
show-password
placeholder="请输入密码"
@keyup.enter="handleLogin"
>
<template #prepend>
2022-08-12 10:44:09 +00:00
<icon name="el-icon-Lock" />
2022-04-08 02:42:44 +00:00
</template>
</el-input>
</el-form-item>
</el-form>
2022-08-12 10:44:09 +00:00
<div class="mb-5">
2022-04-08 02:42:44 +00:00
<el-checkbox v-model="remAccount" label="记住账号"></el-checkbox>
</div>
2022-08-12 10:44:09 +00:00
<el-button type="primary" size="large" :loading="isLock" @click="lockLogin">
登录
</el-button>
2022-04-08 02:42:44 +00:00
</div>
</div>
</div>
2022-08-12 10:44:09 +00:00
<layout-footer />
2022-04-08 02:42:44 +00:00
</div>
</template>
2022-08-12 10:44:09 +00:00
<script lang="ts" setup>
import { computed, onMounted, reactive, ref, shallowRef } from 'vue'
import type { InputInstance, FormInstance } from 'element-plus'
import LayoutFooter from '@/layout/components/footer.vue'
import useAppStore from '@/stores/modules/app'
import useUserStore from '@/stores/modules/user'
2022-04-08 02:42:44 +00:00
import cache from '@/utils/cache'
2022-08-12 10:44:09 +00:00
import { ACCOUNT_KEY } from '@/enums/cacheEnums'
import { PageEnum } from '@/enums/pageEnum'
import { useLockFn } from '@/hooks/useLockFn'
const passwordRef = shallowRef<InputInstance>()
const formRef = shallowRef<FormInstance>()
const appStore = useAppStore()
const userStore = useUserStore()
const route = useRoute()
const router = useRouter()
const remAccount = ref(false)
const config = computed(() => appStore.config)
const formData = reactive({
account: '',
password: ''
})
const rules = {
account: [
{
required: true,
message: '请输入账号',
trigger: ['blur']
2022-04-08 02:42:44 +00:00
}
2022-08-12 10:44:09 +00:00
],
password: [
{
required: true,
message: '请输入密码',
trigger: ['blur']
2022-04-08 02:42:44 +00:00
}
2022-08-12 10:44:09 +00:00
]
}
// 回车按键监听
const handleEnter = () => {
if (!formData.password) {
return passwordRef.value?.focus()
}
handleLogin()
}
// 登录处理
const handleLogin = async () => {
await formRef.value?.validate()
// 记住账号,缓存
cache.set(ACCOUNT_KEY, {
remember: remAccount.value,
account: formData.account
})
await userStore.login(formData)
const {
query: { redirect }
} = route
const path = typeof redirect === 'string' ? redirect : PageEnum.INDEX
router.push(path)
}
const { isLock, lockFn: lockLogin } = useLockFn(handleLogin)
2022-04-08 02:42:44 +00:00
2022-08-12 10:44:09 +00:00
onMounted(() => {
const value = cache.get(ACCOUNT_KEY)
if (value?.remember) {
remAccount.value = value.remember
formData.account = value.account
2022-04-08 02:42:44 +00:00
}
})
</script>
<style lang="scss" scoped>
.login {
background-image: url('./images/login_bg.png');
2022-08-12 10:44:09 +00:00
@apply min-h-screen bg-no-repeat bg-center bg-cover;
2022-04-08 02:42:44 +00:00
.login-card {
height: 400px;
}
}
</style>