vben
2020-12-01 962f90de445d7935ad76ea7b74a98f12ce9a7498
src/views/sys/login/Login.vue
@@ -1,41 +1,56 @@
<template>
  <div class="login h-screen relative">
    <div class="login-mask h-full hidden lg:block" />
    <div
      class="h-full absolute right-0 top-0 w-full lg:w-2/5 xl:w-1/3 flex justify-center items-center"
    >
      <div class="login-form bg-white w-full rounded-sm border-solid bg-clip-padding mx-6 xl:mx-14">
        <div class="w-full h-full border border-gray-600 px-2 py-10 rounded-sm">
          <header class="flex justify-center items-center">
            <img src="/@/assets/images/logo.png" class="w-12 mr-4 inline-block" />
            <h1 class="text-2xl text-center text-primary tracking-wide">Vben Admin 2.0</h1>
  <div class="login">
    <div class="login-mask" />
    <div class="login-form-wrap">
      <div class="login-form mx-6">
        <AppLocalePicker v-if="showLocale" class="login-form__locale" />
        <div class="login-form__content px-2 py-10">
          <header>
            <img :src="logo" class="mr-4" />
            <h1>{{ title }}</h1>
          </header>
          <a-form class="w-4/5 mx-auto mt-10" :model="formData" :rules="formRules" ref="formRef">
          <a-form class="mx-auto mt-10" :model="formData" :rules="formRules" ref="formRef">
            <a-form-item name="account">
              <a-input size="large" v-model:value="formData.account" placeholder="vben" />
              <a-input size="large" v-model:value="formData.account" placeholder="username: vben" />
            </a-form-item>
            <a-form-item name="password">
              <a-input-password
                autofocus="autofocus"
                size="large"
                visibilityToggle
                v-model:value="formData.password"
                placeholder="123456"
                placeholder="password: 123456"
              />
            </a-form-item>
            <a-form-item name="verify" v-if="openLoginVerify">
            <!-- <a-form-item name="verify" v-if="openLoginVerify">
              <BasicDragVerify v-model:value="formData.verify" ref="verifyRef" />
            </a-form-item>
            </a-form-item> -->
            <a-row>
              <a-col :span="12">
                <a-form-item>
                  <!-- No logic, you need to deal with it yourself -->
                  <a-checkbox v-model:checked="autoLogin" size="small">{{
                    t('sys.login.autoLogin')
                  }}</a-checkbox>
                </a-form-item>
              </a-col>
              <a-col :span="12">
                <a-form-item :style="{ 'text-align': 'right' }">
                  <!-- No logic, you need to deal with it yourself -->
                  <a-button type="link" size="small">{{ t('sys.login.forgetPassword') }}</a-button>
                </a-form-item>
              </a-col>
            </a-row>
            <a-form-item>
              <a-button
                type="primary"
                size="large"
                class="rounded-sm"
                block
                :block="true"
                @click="login"
                :loading="formState.loading"
                >登录</a-button
                >{{ t('sys.login.loginButton') }}</a-button
              >
            </a-form-item>
          </a-form>
@@ -45,41 +60,63 @@
  </div>
</template>
<script lang="ts">
  import { defineComponent, reactive, ref, unref, toRaw, computed } from 'vue';
  import { BasicDragVerify, DragVerifyActionType } from '/@/components/Verify/index';
  import { userStore } from '/@/store/modules/user';
  import { appStore } from '/@/store/modules/app';
  import { useMessage } from '/@/hooks/web/useMessage';
  export default defineComponent({
    components: { BasicDragVerify },
    setup() {
      const { notification } = useMessage();
      const formRef = ref<any>(null);
      const verifyRef = ref<RefInstanceType<DragVerifyActionType>>(null);
  import { defineComponent, reactive, ref, unref, toRaw } from 'vue';
  import { Checkbox } from 'ant-design-vue';
      const openLoginVerifyRef = computed(() => appStore.getProjectConfig.openLoginVerify);
  import { Button } from '/@/components/Button';
  import { AppLocalePicker } from '/@/components/Application';
  // import { BasicDragVerify, DragVerifyActionType } from '/@/components/Verify/index';
  import { userStore } from '/@/store/modules/user';
  // import { appStore } from '/@/store/modules/app';
  import { useMessage } from '/@/hooks/web/useMessage';
  import { useGlobSetting, useProjectSetting } from '/@/hooks/setting';
  import logo from '/@/assets/images/logo.png';
  import { useI18n } from '/@/hooks/web/useI18n';
  export default defineComponent({
    components: {
      //  BasicDragVerify,
      AButton: Button,
      ACheckbox: Checkbox,
      AppLocalePicker,
    },
    setup() {
      const formRef = ref<any>(null);
      const autoLoginRef = ref(false);
      // const verifyRef = ref<RefInstanceType<DragVerifyActionType>>(null);
      const globSetting = useGlobSetting();
      const { locale } = useProjectSetting();
      const { notification } = useMessage();
      const { t } = useI18n();
      // const openLoginVerifyRef = computed(() => appStore.getProjectConfig.openLoginVerify);
      const formData = reactive({
        account: '',
        password: '',
        verify: undefined,
        account: 'vben',
        password: '123456',
        // verify: undefined,
      });
      const formState = reactive({
        loading: false,
      });
      const formRules = reactive({
        account: [{ required: true, message: '请输入账号', trigger: 'blur' }],
        password: [{ required: true, message: '请输入密码', trigger: 'blur' }],
        verify: unref(openLoginVerifyRef) ? [{ required: true, message: '请通过验证码校验' }] : [],
        account: [{ required: true, message: t('sys.login.accountPlaceholder'), trigger: 'blur' }],
        password: [
          { required: true, message: t('sys.login.passwordPlaceholder'), trigger: 'blur' },
        ],
        // verify: unref(openLoginVerifyRef) ? [{ required: true, message: '请通过验证码校验' }] : [],
      });
      function resetVerify() {
        const verify = unref(verifyRef);
        if (!verify) return;
        formData.verify && verify.$.resume();
        formData.verify = undefined;
      }
      // function resetVerify() {
      //   const verify = unref(verifyRef);
      //   if (!verify) return;
      //   formData.verify && verify.$.resume();
      //   formData.verify = undefined;
      // }
      async function handleLogin() {
        const form = unref(formRef);
@@ -95,43 +132,115 @@
          );
          if (userInfo) {
            notification.success({
              message: '登录成功',
              description: `欢迎回来: ${userInfo.realName}`,
              message: t('sys.login.loginSuccessTitle'),
              description: `${t('sys.login.loginSuccessDesc')}: ${userInfo.realName}`,
              duration: 3,
            });
          }
        } catch (error) {
        } finally {
          resetVerify();
          // resetVerify();
          formState.loading = false;
        }
      }
      return {
        formRef,
        verifyRef,
        // verifyRef,
        formData,
        formState,
        formRules,
        login: handleLogin,
        openLoginVerify: openLoginVerifyRef,
        autoLogin: autoLoginRef,
        // openLoginVerify: openLoginVerifyRef,
        title: globSetting && globSetting.title,
        logo,
        t,
        showLocale: locale.show,
      };
    },
  });
</script>
<style lang="less" scoped>
<style lang="less">
  @import (reference) '../../../design/index.less';
  .login-form__locale {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 1;
  }
  .login {
    position: relative;
    height: 100vh;
    background: url(../../../assets/images/login/login-bg.png) no-repeat;
    background-size: 100% 100%;
    &-mask {
      display: none;
      height: 100%;
      background: url(../../../assets/images/login/login-in.png) no-repeat;
      background-size: 100% 100%;
      background-position: 30% 30%;
      background-size: 80% 80%;
      .respond-to(xlarge, { display: block;});
    }
    &-form {
      border-color: rgba(255, 255, 255, 0.5);
      border-width: 10px;
      position: relative;
      bottom: 60px;
      width: 400px;
      background: @white;
      border: 10px solid rgba(255, 255, 255, 0.5);
      border-width: 8px;
      border-radius: 4px;
      background-clip: padding-box;
      .respond-to(xlarge, { margin: 0 120px 0 50px});
      &-wrap {
        position: absolute;
        top: 0;
        right: 0;
        display: flex;
        width: 100%;
        height: 100%;
        // height: 90%;
        justify-content: center;
        align-items: center;
        .respond-to(xlarge, {
        justify-content: flex-end;
          });
      }
      &__content {
        position: relative;
        width: 100%;
        height: 100%;
        padding: 60px 0 40px 0;
        border: 1px solid #999;
        border-radius: 2px;
        header {
          display: flex;
          justify-content: center;
          align-items: center;
          img {
            display: inline-block;
            width: 48px;
          }
          h1 {
            margin-bottom: 0;
            font-size: 24px;
            text-align: center;
          }
        }
        form {
          width: 80%;
        }
      }
    }
  }
</style>