From 251d2411f235e23209d57173857e05b637729ce8 Mon Sep 17 00:00:00 2001 From: LiuHao <liuhaoai545@gmail.com> Date: 星期日, 02 四月 2023 01:01:56 +0800 Subject: [PATCH] refactor ts --- src/views/login.vue | 265 +++++++++++++++++++++++++--------------------------- 1 files changed, 128 insertions(+), 137 deletions(-) diff --git a/src/views/login.vue b/src/views/login.vue index 4174090..8a29fda 100644 --- a/src/views/login.vue +++ b/src/views/login.vue @@ -1,185 +1,176 @@ -<template> - <div class="login"> - <el-form ref="loginRef" :model="loginForm" :rules="loginRules" class="login-form"> - <h3 class="title">RuoYi-Vue-Plus澶氱鎴风鐞嗙郴缁�</h3> - <el-form-item prop="tenantId"> - <el-select v-model="loginForm.tenantId" filterable placeholder="璇烽�夋嫨/杈撳叆鍏徃鍚嶇О" style="width: 100%"> - <el-option - v-for="item in tenantList" - :key="item.tenantId" - :label="item.companyName" - :value="item.tenantId"> - </el-option> - <template #prefix><svg-icon icon-class="company" class="el-input__icon input-icon" /></template> - </el-select> - </el-form-item> - <el-form-item prop="username"> - <el-input - v-model="loginForm.username" - type="text" - size="large" - auto-complete="off" - placeholder="璐﹀彿" - > - <template #prefix><svg-icon icon-class="user" class="el-input__icon input-icon" /></template> - </el-input> - </el-form-item> - <el-form-item prop="password"> - <el-input - v-model="loginForm.password" - type="password" - size="large" - auto-complete="off" - placeholder="瀵嗙爜" - @keyup.enter="handleLogin" - > - <template #prefix><svg-icon icon-class="password" class="el-input__icon input-icon" /></template> - </el-input> - </el-form-item> - <el-form-item prop="code" v-if="captchaEnabled"> - <el-input - v-model="loginForm.code" - size="large" - auto-complete="off" - placeholder="楠岃瘉鐮�" - style="width: 63%" - @keyup.enter="handleLogin" - > - <template #prefix><svg-icon icon-class="validCode" class="el-input__icon input-icon" /></template> - </el-input> - <div class="login-code"> - <img :src="codeUrl" @click="getCode" class="login-code-img"/> - </div> - </el-form-item> - <el-checkbox v-model="loginForm.rememberMe" style="margin:0px 0px 25px 0px;">璁颁綇瀵嗙爜</el-checkbox> - <el-form-item style="width:100%;"> - <el-button - :loading="loading" - size="large" - type="primary" - style="width:100%;" - @click.prevent="handleLogin" - > - <span v-if="!loading">鐧� 褰�</span> - <span v-else>鐧� 褰� 涓�...</span> - </el-button> - <div style="float: right;" v-if="register"> - <router-link class="link-type" :to="'/register'">绔嬪嵆娉ㄥ唽</router-link> - </div> - </el-form-item> - </el-form> - <!-- 搴曢儴 --> - <div class="el-login-footer"> - <span>Copyright 漏 2018-2023 ruoyi.vip All Rights Reserved.</span> - </div> - </div> -</template> +<script setup lang="ts"> +import { getCodeImg, getTenantList } from '@/api/login'; +import Cookies from 'js-cookie'; +import { encrypt, decrypt } from '@/utils/jsencrypt'; +import { useUserStore } from '@/store/modules/user'; +import { LoginData, TenantVO } from '@/api/types'; +import { FormRules } from 'element-plus'; +import { to } from 'await-to-js'; -<script setup> -import { getCodeImg, getTenantList } from "@/api/login"; -import Cookies from "js-cookie"; -import { encrypt, decrypt } from "@/utils/jsencrypt"; -import useUserStore from '@/store/modules/user' - -const userStore = useUserStore() +const userStore = useUserStore(); const router = useRouter(); -const { proxy } = getCurrentInstance(); -const loginForm = ref({ +const loginForm = ref<LoginData>({ tenantId: "000000", - username: "admin", - password: "admin123", + username: 'admin', + password: 'admin123', rememberMe: false, - code: "", - uuid: "" + code: '', + uuid: '' }); -const loginRules = { +const loginRules: FormRules = { tenantId: [{ required: true, trigger: "blur", message: "璇疯緭鍏ユ偍鐨勭鎴风紪鍙�" }], - username: [{ required: true, trigger: "blur", message: "璇疯緭鍏ユ偍鐨勮处鍙�" }], - password: [{ required: true, trigger: "blur", message: "璇疯緭鍏ユ偍鐨勫瘑鐮�" }], - code: [{ required: true, trigger: "change", message: "璇疯緭鍏ラ獙璇佺爜" }] + username: [{ required: true, trigger: 'blur', message: '璇疯緭鍏ユ偍鐨勮处鍙�' }], + password: [{ required: true, trigger: 'blur', message: '璇疯緭鍏ユ偍鐨勫瘑鐮�' }], + code: [{ required: true, trigger: 'change', message: '璇疯緭鍏ラ獙璇佺爜' }] }; -const codeUrl = ref(""); +const codeUrl = ref(''); const loading = ref(false); // 楠岃瘉鐮佸紑鍏� const captchaEnabled = ref(true); +// 绉熸埛寮�鍏� +const tenantEnabled = ref(true); + + // 娉ㄥ唽寮�鍏� const register = ref(false); const redirect = ref(undefined); +const loginRef = ref(ElForm); // 绉熸埛鍒楄〃 -const tenantList = ref([]); +const tenantList = ref<TenantVO[]>([]); -function handleLogin() { - proxy.$refs.loginRef.validate(valid => { +const handleLogin = () => { + loginRef.value.validate(async (valid:boolean, fields: any) => { if (valid) { loading.value = true; // 鍕鹃�変簡闇�瑕佽浣忓瘑鐮佽缃湪 cookie 涓缃浣忕敤鎴峰悕鍜屽瘑鐮� if (loginForm.value.rememberMe) { Cookies.set("tenantId", loginForm.value.tenantId, { expires: 30 }); - Cookies.set("username", loginForm.value.username, { expires: 30 }); - Cookies.set("password", encrypt(loginForm.value.password), { expires: 30 }); - Cookies.set("rememberMe", loginForm.value.rememberMe, { expires: 30 }); + Cookies.set('username', loginForm.value.username, { expires: 30 }); + Cookies.set('password', String(encrypt(loginForm.value.password)), { expires: 30 }); + Cookies.set('rememberMe', String(loginForm.value.rememberMe), { expires: 30 }); } else { // 鍚﹀垯绉婚櫎 Cookies.remove("tenantId"); - Cookies.remove("username"); - Cookies.remove("password"); - Cookies.remove("rememberMe"); + Cookies.remove('username'); + Cookies.remove('password'); + Cookies.remove('rememberMe'); } // 璋冪敤action鐨勭櫥褰曟柟娉� - userStore.login(loginForm.value).then(() => { - router.push({ path: redirect.value || "/" }); - }).catch(() => { + // prittier-ignore + const [err] = await to(userStore.login(loginForm.value)); + if (!err) { + await router.push({ path: redirect.value || '/' }); + } else { loading.value = false; // 閲嶆柊鑾峰彇楠岃瘉鐮� if (captchaEnabled.value) { - getCode(); + await getCode(); } - }); + } + } else { + console.log('error submit!', fields); } }); -} +}; -function getCode() { - getCodeImg().then(res => { - captchaEnabled.value = res.data.captchaEnabled === undefined ? true : res.data.captchaEnabled; - if (captchaEnabled.value) { - codeUrl.value = "data:image/gif;base64," + res.data.img; - loginForm.value.uuid = res.data.uuid; - } - }); -} +/** + * 鑾峰彇楠岃瘉鐮� + */ +const getCode = async () => { + const res = await getCodeImg(); + const { data } = res; + captchaEnabled.value = data.captchaEnabled === undefined ? true : data.captchaEnabled; + if (captchaEnabled.value) { + codeUrl.value = 'data:image/gif;base64,' + data.img; + loginForm.value.uuid = data.uuid; + } +}; -function initTenantList() { - getTenantList().then(res => { - tenantList.value = res.data; - if (tenantList.value != null && tenantList.value.length !== 0) { - loginForm.value.tenantId = tenantList.value[0].tenantId; - } - }); -} - -function getCookie() { +const getCookie = () => { const tenantId = Cookies.get("tenantId"); - const username = Cookies.get("username"); - const password = Cookies.get("password"); - const rememberMe = Cookies.get("rememberMe"); + const username = Cookies.get('username'); + const password = Cookies.get('password'); + const rememberMe = Cookies.get('rememberMe'); loginForm.value = { tenantId: tenantId === undefined ? loginForm.value.tenantId : tenantId, username: username === undefined ? loginForm.value.username : username, - password: password === undefined ? loginForm.value.password : decrypt(password), + password: password === undefined ? loginForm.value.password : (decrypt(password) as string), rememberMe: rememberMe === undefined ? false : Boolean(rememberMe) }; } -getCode(); -initTenantList(); -getCookie(); + +/** + * 鑾峰彇绉熸埛鍒楄〃 + */ +const initTenantList = async () => { + const { data } = await getTenantList(); + tenantEnabled.value = data.tenantEnabled === undefined ? true : data.tenantEnabled; + if (tenantEnabled.value) { + tenantList.value = data.voList; + if (tenantList.value != null && tenantList.value.length !== 0) { + loginForm.value.tenantId = tenantList.value[0].tenantId; + } + } +} + +onMounted(() => { + getCode(); + initTenantList(); + getCookie(); +}); </script> -<style lang='scss' scoped> +<template> + <div class="login"> + <el-form ref="loginRef" :model="loginForm" :rules="loginRules" class="login-form"> + <h3 class="title">RuoYi-Vue-Plus澶氱鎴风鐞嗙郴缁�</h3> + <el-form-item prop="tenantId" v-if="tenantEnabled"> + <el-select v-model="loginForm.tenantId" filterable placeholder="璇烽�夋嫨/杈撳叆鍏徃鍚嶇О" style="width: 100%"> + <el-option v-for="item in tenantList" :key="item.tenantId" :label="item.companyName" :value="item.tenantId"> </el-option> + <template #prefix><svg-icon icon-class="company" class="el-input__icon input-icon" /></template> + </el-select> + </el-form-item> + <el-form-item prop="username"> + <el-input v-model="loginForm.username" type="text" size="large" auto-complete="off" placeholder="璐﹀彿"> + <template #prefix><svg-icon icon-class="user" class="el-input__icon input-icon" /></template> + </el-input> + </el-form-item> + <el-form-item prop="password"> + <el-input v-model="loginForm.password" type="password" size="large" auto-complete="off" placeholder="瀵嗙爜" @keyup.enter="handleLogin"> + <template #prefix><svg-icon icon-class="password" class="el-input__icon input-icon" /></template> + </el-input> + </el-form-item> + <el-form-item prop="code" v-if="captchaEnabled"> + <el-input v-model="loginForm.code" size="large" auto-complete="off" placeholder="楠岃瘉鐮�" style="width: 63%" @keyup.enter="handleLogin"> + <template #prefix><svg-icon icon-class="validCode" class="el-input__icon input-icon" /></template> + </el-input> + <div class="login-code"> + <img :src="codeUrl" @click="getCode" class="login-code-img" /> + </div> + </el-form-item> + <el-checkbox v-model="loginForm.rememberMe" style="margin:0px 0px 25px 0px;">璁颁綇瀵嗙爜</el-checkbox> + <el-form-item style="width:100%;"> + <el-button :loading="loading" size="large" type="primary" style="width:100%;" @click.prevent="handleLogin"> + <span v-if="!loading">鐧� 褰�</span> + <span v-else>鐧� 褰� 涓�...</span> + </el-button> + <div style="float: right;" v-if="register"> + <router-link class="link-type" :to="'/register'">绔嬪嵆娉ㄥ唽</router-link> + </div> + </el-form-item> + </el-form> + <!-- 搴曢儴 --> + <div class="el-login-footer"> + <span>Copyright 漏 2018-2023 ruoyi.vip All Rights Reserved.</span> + </div> + </div> +</template> + +<style lang="scss" scoped> .login { display: flex; justify-content: center; @@ -233,7 +224,7 @@ width: 100%; text-align: center; color: #fff; - font-family: Arial; + font-family: Arial,serif; font-size: 12px; letter-spacing: 1px; } -- Gitblit v1.9.3