123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192 |
- <template>
- <div class="login-wrap" @keydown.enter="login">
- <div class="login-con">
- <el-card class="box-card">
- <template #header>
- <span class="login--header">登录</span>
- </template>
- <el-form
- ref="loginForm"
- :model="form"
- :rules="rules"
- class="login-form"
- >
- <el-form-item prop="userName">
- <el-input
- v-model="form.userName"
- placeholder="请输入账号 admin or test"
- class="form--input"
- >
- <template #prefix>
- <span class="svg-container">
- <svg-icon icon-class="user" />
- </span>
- </template>
- </el-input>
- </el-form-item>
- <el-form-item prop="passWord">
- <el-input
- v-model="form.passWord"
- show-password
- :minlength="3"
- :maxlength="18"
- placeholder="请输入密码 admin or test"
- class="form--input"
- >
- <template #prefix>
- <span class="svg-container">
- <svg-icon icon-class="password" />
- </span>
- </template>
- </el-input>
- </el-form-item>
- <el-form-item>
- <el-button
- :loading="loading"
- type="primary"
- class="login--button"
- @click="login"
- >
- 登录
- </el-button>
- </el-form-item>
- </el-form>
- </el-card>
- </div>
- </div>
- </template>
- <script lang="ts">
- import { defineComponent, ref, unref, reactive, watch } from 'vue'
- import { useRouter } from 'vue-router'
- import type { RouteRecordRaw } from 'vue-router'
- import { permissionStore } from '_p/index/store/modules/permission'
- import { appStore } from '_p/index/store/modules/app'
- import wsCache from '@/cache'
- import { ElNotification } from 'element-plus'
- import { loginApi, getRoleDetApi } from './api'
- interface FormModule {
- userName: string,
- passWord: string
- }
- interface RulesModule {
- userName: any[],
- passWord: any[]
- }
- export default defineComponent({
- name: 'Login',
- setup() {
- const { push, addRoute, currentRoute } = useRouter()
- const loginForm = ref<HTMLElement | null>(null)
- const loading = ref<boolean>(false)
- const redirect = ref<string>('')
- watch(() => {
- return currentRoute.value
- }, (route) => {
- redirect.value = (route.query && route.query.redirect) as string
- }, {
- immediate: true
- })
- const form = reactive<FormModule>({
- userName: '',
- passWord: ''
- })
- const rules = reactive<RulesModule>({
- userName: [{ required: true, message: '请输入账号' }],
- passWord: [{ required: true, message: '请输入密码' }]
- })
- async function login(): Promise<void> {
- const formWrap = unref(loginForm) as any
- if (!formWrap) return
- loading.value = true
- try {
- formWrap.validate(async(valid: boolean) => {
- if (valid) {
- // 模拟登录接口之后返回角色信息
- const res = await loginApi({ data: form })
- if (res) {
- // 获取权限信息
- const role = await getRoleDetApi({
- params: {
- id: res.data.roleId
- }
- })
- if (role) {
- wsCache.set(appStore.userInfo, Object.assign(form, role.data))
- permissionStore.GenerateRoutes().then(() => {
- permissionStore.addRouters.forEach(async(route: RouteRecordRaw) => {
- await addRoute(route.name!, route) // 动态添加可访问路由表
- })
- permissionStore.SetIsAddRouters(true)
- push({ path: redirect.value || '/' })
- })
- }
- }
- } else {
- console.log('error submit!!')
- return false
- }
- })
- } catch (err) {
- console.log(err)
- } finally {
- loading.value = false
- }
- }
- ElNotification({
- title: '提示',
- message: '账号 admin 为 前端 控制路由权限,账号 test 为 后端 控制路由权限。密码与账号相同',
- duration: 60000
- })
- return {
- loginForm,
- loading, redirect, form, rules,
- login
- }
- }
- })
- </script>
- <style lang="less" scoped>
- .login-wrap {
- width: 100%;
- height: 100%;
- background-image: url('~@/assets/img/login-bg.jpg');
- background-size: cover;
- background-position: center;
- position: relative;
- .box-card {
- width: 400px;
- .login--header {
- font-size: 24px;
- font-weight: 600;
- }
- .svg-container {
- color: #889aa4;
- vertical-align: middle;
- width: 30px;
- display: inline-block;
- }
- .form--input {
- width: 100%;
- @{deep}(.el-input__inner) {
- padding-left: 40px;
- }
- }
- .login--button {
- width: 100%;
- }
- }
- .login-con {
- position: absolute;
- right: 160px;
- top: 50%;
- transform: translateY(-60%);
- }
- }
- </style>
|