liudong
2024-08-23 38e9abbd9e89ccf14389e90fa94b4b8ea36fa60d
src/views/login/components/login-form.vue
@@ -1,7 +1,7 @@
<template>
  <div class="login-form-wrapper">
    <div class="login-form-title">{{ $t('login.form.title') }}</div>
<!--    <div class="login-form-sub-title">{{ $t('login.form.title') }}</div>-->
    <!--    <div class="login-form-sub-title">{{ $t('login.form.title') }}</div>-->
    <div class="login-form-error-msg">{{ errorMessage }}</div>
    <a-form
      ref="loginForm"
@@ -12,14 +12,11 @@
    >
      <a-form-item
        field="email"
        :rules="[{ required: true, message: '请输入邮箱' }]"
        :rules="[{ required: true, message: '请输入用户名' }]"
        :validate-trigger="['change', 'blur']"
        hide-label
      >
        <a-input
          v-model="userInfo.email"
          placeholder="请输入邮箱"
        >
        <a-input v-model="userInfo.email" placeholder="请输入用户名">
          <template #prefix>
            <icon-user />
          </template>
@@ -43,34 +40,34 @@
      </a-form-item>
      <a-space :size="16" direction="vertical">
        <div class="login-form-password-actions">
          <a-checkbox
          <!-- <a-checkbox
            checked="rememberPassword"
            :model-value="loginConfig.rememberPassword"
            @change="setRememberPassword as any"
          >
            {{ $t('login.form.rememberPassword') }}
          </a-checkbox>
          <a-link>{{ $t('login.form.forgetPassword') }}</a-link>
          </a-checkbox> -->
          <!-- <a-link>{{ $t("login.form.forgetPassword") }}</a-link> -->
        </div>
        <a-button type="primary" html-type="submit" long :loading="loading">
          {{ $t('login.form.login') }}
        </a-button>
        <a-button type="text" long class="login-form-register-btn">
        <!-- <a-button type="text" long class="login-form-register-btn">
          {{ $t('login.form.register') }}
        </a-button>
        </a-button> -->
      </a-space>
    </a-form>
  </div>
</template>
<script lang="ts" setup>
  import { ref, reactive } from 'vue';
  import { reactive, ref } from 'vue';
  import { useRouter } from 'vue-router';
  import { Message } from '@arco-design/web-vue';
  import { ValidatedError } from '@arco-design/web-vue/es/form/interface';
  import { useI18n } from 'vue-i18n';
  import { useStorage } from '@vueuse/core';
  import { useUserStore } from '@/store';
  import { useUserStore, userModelState } from '@/store';
  import useLoading from '@/hooks/loading';
  import type { LoginData } from '@/api/user';
  import { rsaPsw } from '@/utils/ras';
@@ -80,15 +77,16 @@
  const errorMessage = ref('');
  const { loading, setLoading } = useLoading();
  const userStore = useUserStore();
  const modelStore = userModelState();
  const loginConfig = useStorage('login-config', {
    rememberPassword: true,
    email: '1750082535@qq.com', // 演示默认值
    password: 'basic2024', // demo default value
    email: '', // 演示默认值
    password: '', // demo default value
  });
  const userInfo = reactive({
    email: '1750082535@qq.com', // 演示默认值
    password: 'basic2024', // demo default value
    email: '', // 演示默认值
    password: '', // demo default value
  });
  const handleSubmit = async ({
@@ -102,28 +100,30 @@
    if (!errors) {
      setLoading(true);
      try {
        // const rsaPassWord = rsaPsw(values.password) as string;
        // console.log(values,'登录信息');
        // await userStore.login({
        //   email: values.email,
        //   password: rsaPassWord,
        // } as LoginData);
        // const { redirect, ...othersQuery } = router.currentRoute.value.query;
        const rsaPassWord = rsaPsw(values.password) as string;
        console.log(values, '登录信息');
        let goto = await userStore.login({
          email: values.email,
          password: rsaPassWord,
        } as LoginData);
        const { redirect, ...othersQuery } = router.currentRoute.value.query;
        router.push({
          name: 'knowledgeLib',
          // query: {
          //   ...othersQuery,
          // },
          name: goto,
          query: {
            ...othersQuery,
          },
        });
        Message.success(t('欢迎回来'));
        const url = window.location.origin;
        localStorage.setItem('httpUrl', url);
        modelStore.getHrefUrl(url);
        Message.success(t('登录成功'));
        const { rememberPassword } = loginConfig.value;
        const { email, password } = values;
        // 实际生产环境需要进行加密存储。
        // The actual production environment requires encrypted storage.
        loginConfig.value.email = rememberPassword ? email : '';
        loginConfig.value.password = rememberPassword ? password : '';
      } catch (err) {
        errorMessage.value = (err as Error).message;
      } finally {