From 6af68085ff6615e1ec3a5dd18c761250800d6fca Mon Sep 17 00:00:00 2001 From: LiuHao <liuhaoai545@gmail.com> Date: 星期二, 06 六月 2023 22:23:43 +0800 Subject: [PATCH] update 修改页面代码 去除ele的引入以及vue的类型声明 --- src/views/login.vue | 228 +++++++++++++++++++++++++++----------------------------- 1 files changed, 109 insertions(+), 119 deletions(-) diff --git a/src/views/login.vue b/src/views/login.vue index 4174090..8e3c014 100644 --- a/src/views/login.vue +++ b/src/views/login.vue @@ -2,64 +2,33 @@ <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-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> + <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="璐﹀彿" - > + <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" - > + <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" - > + <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"/> + <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" - > + <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> @@ -70,116 +39,137 @@ </el-form> <!-- 搴曢儴 --> <div class="el-login-footer"> - <span>Copyright 漏 2018-2023 ruoyi.vip All Rights Reserved.</span> + <span>Copyright 漏 2018-2023 鐤媯鐨勭嫯瀛怢i All Rights Reserved.</span> </div> </div> </template> -<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' +<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 { to } from 'await-to-js'; -const userStore = useUserStore() +const userStore = useUserStore(); const router = useRouter(); -const { proxy } = getCurrentInstance(); -const loginForm = ref({ - tenantId: "000000", - username: "admin", - password: "admin123", - rememberMe: false, - code: "", - uuid: "" +const loginForm = ref<LoginData>({ + tenantId: "000000", + username: 'admin', + password: 'admin123', + rememberMe: false, + code: '', + uuid: '' }); -const loginRules = { - tenantId: [{ required: true, trigger: "blur", message: "璇疯緭鍏ユ偍鐨勭鎴风紪鍙�" }], - username: [{ required: true, trigger: "blur", message: "璇疯緭鍏ユ偍鐨勮处鍙�" }], - password: [{ required: true, trigger: "blur", message: "璇疯緭鍏ユ偍鐨勫瘑鐮�" }], - code: [{ required: true, trigger: "change", message: "璇疯緭鍏ラ獙璇佺爜" }] +const loginRules: ElFormRules = { + tenantId: [{ required: true, trigger: "blur", 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 => { - 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 }); - } else { - // 鍚﹀垯绉婚櫎 - Cookies.remove("tenantId"); - Cookies.remove("username"); - Cookies.remove("password"); - Cookies.remove("rememberMe"); - } - // 璋冪敤action鐨勭櫥褰曟柟娉� - userStore.login(loginForm.value).then(() => { - router.push({ path: redirect.value || "/" }); - }).catch(() => { - loading.value = false; - // 閲嶆柊鑾峰彇楠岃瘉鐮� - if (captchaEnabled.value) { - getCode(); +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', 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'); + } + // 璋冪敤action鐨勭櫥褰曟柟娉� + // 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) { + await getCode(); + } + } + } else { + console.log('error submit!', fields); } - }); - } - }); -} + }); +}; -function getCode() { - getCodeImg().then(res => { - captchaEnabled.value = res.data.captchaEnabled === undefined ? true : res.data.captchaEnabled; +/** + * 鑾峰彇楠岃瘉鐮� + */ +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," + res.data.img; - loginForm.value.uuid = res.data.uuid; + codeUrl.value = 'data:image/gif;base64,' + data.img; + loginForm.value.uuid = data.uuid; } - }); +}; + +const getCookie = () => { + const tenantId = Cookies.get("tenantId"); + 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) as string), + rememberMe: rememberMe === undefined ? false : Boolean(rememberMe) + }; } -function initTenantList() { - getTenantList().then(res => { - tenantList.value = res.data; - if (tenantList.value != null && tenantList.value.length !== 0) { - loginForm.value.tenantId = tenantList.value[0].tenantId; + +/** + * 鑾峰彇绉熸埛鍒楄〃 + */ +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; + } } - }); } -function getCookie() { - const tenantId = Cookies.get("tenantId"); - 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), - rememberMe: rememberMe === undefined ? false : Boolean(rememberMe) - }; -} - -getCode(); -initTenantList(); -getCookie(); +onMounted(() => { + getCode(); + initTenantList(); + getCookie(); +}); </script> -<style lang='scss' scoped> +<style lang="scss" scoped> .login { display: flex; justify-content: center; @@ -233,7 +223,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