index.vue 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. <template>
  2. <sign-layout class="user-login" :title="islogin ? '登录' : '重置密码'">
  3. <el-form ref="formRef" :model="formData" :rules="formRules" v-if="islogin">
  4. <el-form-item prop="userName">
  5. <el-input placeholder="用户名/账号/手机号" v-model="formData.userName">
  6. <!-- <template #append>
  7. <el-checkbox v-model="remember"></el-checkbox>
  8. </template> -->
  9. </el-input>
  10. </el-form-item>
  11. <el-form-item prop="password">
  12. <el-input type="password" placeholder="请输入您的登录密码" v-model="formData.password">
  13. </el-input>
  14. </el-form-item>
  15. <el-form-item>
  16. <SliderVerify @statu="slide" v-if="showSliderVerify" />
  17. </el-form-item>
  18. <el-form-item>
  19. <div class="text-link">
  20. <span @click="click" v-if="shwoRegister">立即注册</span>
  21. <span @click="islogin = false">忘记密码?</span>
  22. </div>
  23. </el-form-item>
  24. <el-form-item>
  25. <el-button class="submit" type="primary" :loading="loading" @click="formSubmit">
  26. <span v-if="loading">正在登录</span>
  27. <span v-else>登录</span>
  28. </el-button>
  29. </el-form-item>
  30. </el-form>
  31. <Forget @close="islogin = true" v-else></Forget>
  32. <el-dialog class="register" v-model="isRegister" title="扫码注册" :width="360" center align-center>
  33. <div v-loading="rloading" v-if="rloading"></div>
  34. <div style="text-align: center;" v-else>
  35. <app-qrcode class="app-register-code__qrcode" :width="240" :text="qrContent" />
  36. </div>
  37. <template #footer>
  38. <span class="dialog-footer">
  39. <el-button type="primary" @click="isRegister = false">关闭</el-button>
  40. </span>
  41. </template>
  42. </el-dialog>
  43. <PasswordMidify v-if="showPasswordMidify" @closed="onClosed" />
  44. </sign-layout>
  45. </template>
  46. <script lang="ts" setup>
  47. import { shallowRef } from 'vue'
  48. import { useRoute, useRouter } from 'vue-router'
  49. import { ElMessage } from 'element-plus'
  50. import type { FormInstance, FormRules } from 'element-plus'
  51. import { useLogin } from '@/business/login'
  52. import { useGlobalStore, useMenuStore } from '@/stores'
  53. import service from '@/services'
  54. import SignLayout from '../components/layout/index.vue'
  55. import Forget from "../forget/index.vue"
  56. import AppQrcode from '@/components/base/qrcode/index.vue'
  57. import PasswordMidify from '@pc/components/layouts/header/components/modify/index.vue' // 待优化
  58. import SliderVerify from '@/components/base/slider-verify/index.vue' // 临时调用,待优化
  59. const { formData, userLogin, userLogout } = useLogin()
  60. const route = useRoute()
  61. const router = useRouter()
  62. const globalStore = useGlobalStore()
  63. const menuStore = useMenuStore()
  64. const formRef = shallowRef<FormInstance>()
  65. const loading = shallowRef(false)
  66. const shwoRegister = shallowRef(false)
  67. const islogin = shallowRef(true)
  68. const isRegister = shallowRef(false)
  69. const qrContent = shallowRef('')
  70. const rloading = shallowRef(false)
  71. const showPasswordMidify = shallowRef(false) // 显示修改密码
  72. const showSliderVerify = shallowRef(true) // 验证滑块组件重载
  73. const sliderVerifyStatus = shallowRef(false) // 滑块验证状态
  74. const formRules: FormRules = {
  75. userName: [
  76. { required: true, max: 20, message: '请输入登录账号', trigger: 'blur' }
  77. ],
  78. password: [
  79. { required: true, max: 16, message: '请输入登录密码', trigger: 'blur' }
  80. ]
  81. }
  82. const click = () => {
  83. isRegister.value = true
  84. rloading.value = true
  85. service.onReady().then((res) => {
  86. qrContent.value = res.mobileOpenUrl
  87. }).finally(() => {
  88. rloading.value = false
  89. })
  90. }
  91. // 滑块验证
  92. const slide = (vfcStatu: { statu: string }) => {
  93. if (vfcStatu.statu === 'success') {
  94. sliderVerifyStatus.value = true
  95. } else {
  96. sliderVerifyStatus.value = false
  97. }
  98. }
  99. const onClosed = () => {
  100. userLogout()
  101. showPasswordMidify.value = false
  102. }
  103. const formSubmit = () => {
  104. const reset = () => {
  105. loading.value = false
  106. showSliderVerify.value = false
  107. sliderVerifyStatus.value = false
  108. formData.password = ''
  109. setTimeout(() => {
  110. showSliderVerify.value = true
  111. }, 0)
  112. }
  113. formRef.value?.validate(async (valid) => {
  114. if (valid && sliderVerifyStatus.value) {
  115. try {
  116. loading.value = true
  117. const forcedPasswordChange = await userLogin()
  118. if (forcedPasswordChange) {
  119. reset()
  120. showPasswordMidify.value = true
  121. } else {
  122. await menuStore.getUserRoutes()
  123. const redirect = route.query.redirect
  124. if (redirect) {
  125. router.replace(redirect.toString())
  126. } else {
  127. router.replace('/')
  128. }
  129. }
  130. } catch (err) {
  131. reset()
  132. ElMessage.error('登录失败:' + err as string)
  133. }
  134. }
  135. })
  136. }
  137. service.systemInfoAsync.then(() => {
  138. shwoRegister.value = globalStore.hasSystemModule('register')
  139. })
  140. </script>
  141. <style lang="less" scoped>
  142. @import './index.less';
  143. </style>