feat: add verification login
parent
31315a7f76
commit
b1038c7bb8
|
@ -1,20 +1,27 @@
|
||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
import type { VbenFormSchema } from '@vben/common-ui';
|
import type { VbenFormSchema } from '@vben/common-ui';
|
||||||
import type { Recordable } from '@vben/types';
|
|
||||||
|
|
||||||
import { computed, ref } from 'vue';
|
import { computed, reactive, ref } from 'vue';
|
||||||
|
|
||||||
import { AuthenticationLogin, z } from '@vben/common-ui';
|
import { AuthenticationLogin, z } from '@vben/common-ui';
|
||||||
import { useAppConfig } from '@vben/hooks';
|
import { useAppConfig } from '@vben/hooks';
|
||||||
import { $t } from '@vben/locales';
|
import { $t } from '@vben/locales';
|
||||||
|
|
||||||
import { getTenantByWebsite, getTenantIdByName } from '#/api/core/auth';
|
import { getTenantByWebsite, getTenantIdByName } from '#/api/core/auth';
|
||||||
|
import { Verify } from '#/components/Verification';
|
||||||
import { useAuthStore } from '#/store';
|
import { useAuthStore } from '#/store';
|
||||||
import { setTenantId } from '#/utils';
|
import { setTenantId } from '#/utils';
|
||||||
|
|
||||||
defineOptions({ name: 'Login' });
|
defineOptions({ name: 'Login' });
|
||||||
|
|
||||||
const authStore = useAuthStore();
|
const authStore = useAuthStore();
|
||||||
|
/**
|
||||||
|
* 初始化验证码
|
||||||
|
* blockPuzzle 滑块
|
||||||
|
* clickWord 点击文字
|
||||||
|
*/
|
||||||
|
const verify = ref();
|
||||||
|
const captchaType = ref('blockPuzzle');
|
||||||
|
|
||||||
const { tenantEnable, captchaEnable } = useAppConfig(
|
const { tenantEnable, captchaEnable } = useAppConfig(
|
||||||
import.meta.env,
|
import.meta.env,
|
||||||
|
@ -26,84 +33,112 @@ const formSchema = computed((): VbenFormSchema[] => {
|
||||||
{
|
{
|
||||||
component: 'VbenInput',
|
component: 'VbenInput',
|
||||||
componentProps: {
|
componentProps: {
|
||||||
placeholder: $t('authentication.usernameTip'),
|
placeholder: $t('page.auth.tenantNameTip'),
|
||||||
},
|
},
|
||||||
fieldName: 'tenantName',
|
fieldName: 'tenantName',
|
||||||
label: $t('authentication.username'),
|
label: $t('page.auth.tenantname'),
|
||||||
rules: z.string().min(1, { message: $t('authentication.usernameTip') }),
|
rules: z.string().min(1, { message: $t('page.auth.tenantNameTip') }),
|
||||||
value: import.meta.env.VITE_APP_DEFAULT_LOGIN_TENANT || '',
|
defaultValue: import.meta.env.VITE_APP_DEFAULT_LOGIN_TENANT || '',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
component: 'VbenInput',
|
component: 'VbenInput',
|
||||||
componentProps: {
|
componentProps: {
|
||||||
placeholder: $t('authentication.usernameTip'),
|
placeholder: $t('page.auth.usernameTip'),
|
||||||
},
|
},
|
||||||
fieldName: 'username',
|
fieldName: 'username',
|
||||||
label: $t('authentication.username'),
|
label: $t('page.auth.username'),
|
||||||
rules: z.string().min(1, { message: $t('authentication.usernameTip') }),
|
rules: z.string().min(1, { message: $t('page.auth.usernameTip') }),
|
||||||
value: import.meta.env.VITE_APP_DEFAULT_LOGIN_USERNAME || '',
|
defaultValue: import.meta.env.VITE_APP_DEFAULT_LOGIN_USERNAME || '',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
component: 'VbenInputPassword',
|
component: 'VbenInputPassword',
|
||||||
componentProps: {
|
componentProps: {
|
||||||
placeholder: $t('authentication.password'),
|
placeholder: $t('page.auth.passwordTip'),
|
||||||
},
|
},
|
||||||
fieldName: 'password',
|
fieldName: 'password',
|
||||||
label: $t('authentication.password'),
|
label: $t('page.auth.password'),
|
||||||
rules: z.string().min(1, { message: $t('authentication.passwordTip') }),
|
rules: z.string().min(1, { message: $t('page.auth.passwordTip') }),
|
||||||
value: import.meta.env.VITE_APP_DEFAULT_LOGIN_PASSWORD || '',
|
defaultValue: import.meta.env.VITE_APP_DEFAULT_LOGIN_PASSWORD || '',
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
});
|
});
|
||||||
const loginData = ref({
|
const loginData = reactive({
|
||||||
captchaVerification: '',
|
loginForm: {
|
||||||
username: '',
|
username: '',
|
||||||
password: '',
|
password: '',
|
||||||
tenantName: '',
|
tenantName: '',
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
const captchaVerification = ref('');
|
||||||
// 获取验证码
|
// 获取验证码
|
||||||
async function getCode(params: Recordable<any>) {
|
async function getCode(params: any) {
|
||||||
if (params) {
|
if (params) {
|
||||||
loginData.value = params;
|
loginData.loginForm = params;
|
||||||
}
|
}
|
||||||
getTenant()
|
try {
|
||||||
.then()
|
await getTenant();
|
||||||
.finally(async () => {
|
if (captchaEnable) {
|
||||||
// 情况一,未开启:则直接登录
|
|
||||||
if (captchaEnable === 'false') {
|
|
||||||
await handleLogin();
|
|
||||||
} else {
|
|
||||||
// 情况二,已开启:则展示验证码;只有完成验证码的情况,才进行登录
|
// 情况二,已开启:则展示验证码;只有完成验证码的情况,才进行登录
|
||||||
// 弹出验证码
|
// 弹出验证码
|
||||||
verify.value.show();
|
verify.value.show();
|
||||||
|
} else {
|
||||||
|
// 情况一,未开启:则直接登录
|
||||||
|
await handleLogin({});
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Error in getCode:', error);
|
||||||
}
|
}
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 根据域名,获得租户信息 && 获取租户ID
|
// 根据域名,获得租户信息 && 获取租户ID
|
||||||
async function getTenant() {
|
async function getTenant() {
|
||||||
if (tenantEnable === 'true') {
|
if (tenantEnable) {
|
||||||
const website = location.host;
|
const website = location.host;
|
||||||
|
try {
|
||||||
const tenant = await getTenantByWebsite(website);
|
const tenant = await getTenantByWebsite(website);
|
||||||
if (tenant) {
|
if (tenant) {
|
||||||
loginData.value.tenantName = tenant.name;
|
loginData.loginForm.tenantName = tenant.name;
|
||||||
setTenantId(tenant.id);
|
setTenantId(tenant.id);
|
||||||
} else {
|
} else {
|
||||||
const res = await getTenantIdByName(loginData.value.tenantName);
|
const res = await getTenantIdByName(loginData.loginForm.tenantName);
|
||||||
setTenantId(res);
|
setTenantId(res);
|
||||||
}
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Error in getTenant:', error);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async function handleLogin() {
|
async function handleLogin(params: any) {
|
||||||
authStore.authLogin(loginData.value);
|
if (!params.captchaVerification && captchaEnable) {
|
||||||
|
console.error('Captcha verification is required');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
captchaVerification.value = params.captchaVerification;
|
||||||
|
try {
|
||||||
|
await authStore.authLogin({
|
||||||
|
...loginData.loginForm,
|
||||||
|
captchaVerification: captchaVerification.value,
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Error in handleLogin:', error);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
|
<div>
|
||||||
<AuthenticationLogin
|
<AuthenticationLogin
|
||||||
:form-schema="formSchema"
|
:form-schema="formSchema"
|
||||||
:loading="authStore.loginLoading"
|
:loading="authStore.loginLoading"
|
||||||
@submit="getCode"
|
@submit="getCode"
|
||||||
/>
|
/>
|
||||||
|
<Verify
|
||||||
|
ref="verify"
|
||||||
|
:captcha-type="captchaType"
|
||||||
|
:img-size="{ width: '400px', height: '200px' }"
|
||||||
|
mode="pop"
|
||||||
|
@success="handleLogin"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
Loading…
Reference in New Issue