perf: adjustment of form spelling errors, type adjustment, closer to actual development (#4694)

pull/48/MERGE
Vben 2024-10-20 21:44:25 +08:00 committed by GitHub
parent 646598afba
commit 860fc15ce6
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
32 changed files with 95 additions and 122 deletions

View File

@ -1,9 +1,9 @@
{ {
"auth": { "auth": {
"login": "登", "login": "登",
"register": "注册", "register": "注册",
"codeLogin": "验证码登", "codeLogin": "验证码登",
"qrcodeLogin": "二维码登", "qrcodeLogin": "二维码登",
"forgetPassword": "忘记密码" "forgetPassword": "忘记密码"
}, },
"dashboard": { "dashboard": {

View File

@ -1,5 +1,4 @@
import type { LoginAndRegisterParams } from '@vben/common-ui'; import type { Recordable, UserInfo } from '@vben/types';
import type { UserInfo } from '@vben/types';
import { ref } from 'vue'; import { ref } from 'vue';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
@ -26,7 +25,7 @@ export const useAuthStore = defineStore('auth', () => {
* @param params * @param params
*/ */
async function authLogin( async function authLogin(
params: LoginAndRegisterParams, params: Recordable<any>,
onSuccess?: () => Promise<void> | void, onSuccess?: () => Promise<void> | void,
) { ) {
// 异步处理用户登录操作并获取 accessToken // 异步处理用户登录操作并获取 accessToken
@ -84,7 +83,7 @@ export const useAuthStore = defineStore('auth', () => {
resetAllStores(); resetAllStores();
accessStore.setLoginExpired(false); accessStore.setLoginExpired(false);
// 回登页带上当前路由地址 // 回登页带上当前路由地址
await router.replace({ await router.replace({
path: LOGIN_PATH, path: LOGIN_PATH,
query: redirect query: redirect

View File

@ -1,5 +1,6 @@
<script lang="ts" setup> <script lang="ts" setup>
import type { LoginCodeParams, 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, ref } from 'vue';
@ -49,7 +50,7 @@ const formSchema = computed((): VbenFormSchema[] => {
* Asynchronously handle the login process * Asynchronously handle the login process
* @param values 登录表单数据 * @param values 登录表单数据
*/ */
async function handleLogin(values: LoginCodeParams) { async function handleLogin(values: Recordable<any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log(values); console.log(values);
} }

View File

@ -1,5 +1,6 @@
<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, ref } from 'vue';
@ -27,7 +28,7 @@ const formSchema = computed((): VbenFormSchema[] => {
]; ];
}); });
function handleSubmit(value: string) { function handleSubmit(value: Recordable<any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log('reset email:', value); console.log('reset email:', value);
} }

View File

@ -1,5 +1,6 @@
<script lang="ts" setup> <script lang="ts" setup>
import type { LoginAndRegisterParams, VbenFormSchema } from '@vben/common-ui'; import type { VbenFormSchema } from '@vben/common-ui';
import type { Recordable } from '@vben/types';
import { computed, h, ref } from 'vue'; import { computed, h, ref } from 'vue';
@ -86,7 +87,7 @@ const formSchema = computed((): VbenFormSchema[] => {
]; ];
}); });
function handleSubmit(value: LoginAndRegisterParams) { function handleSubmit(value: Recordable<any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log('register submit:', value); console.log('register submit:', value);
} }

View File

@ -1,9 +1,9 @@
{ {
"auth": { "auth": {
"login": "登", "login": "登",
"register": "注册", "register": "注册",
"codeLogin": "验证码登", "codeLogin": "验证码登",
"qrcodeLogin": "二维码登", "qrcodeLogin": "二维码登",
"forgetPassword": "忘记密码" "forgetPassword": "忘记密码"
}, },
"dashboard": { "dashboard": {

View File

@ -1,5 +1,4 @@
import type { LoginAndRegisterParams } from '@vben/common-ui'; import type { Recordable, UserInfo } from '@vben/types';
import type { UserInfo } from '@vben/types';
import { ref } from 'vue'; import { ref } from 'vue';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
@ -26,7 +25,7 @@ export const useAuthStore = defineStore('auth', () => {
* @param params * @param params
*/ */
async function authLogin( async function authLogin(
params: LoginAndRegisterParams, params: Recordable<any>,
onSuccess?: () => Promise<void> | void, onSuccess?: () => Promise<void> | void,
) { ) {
// 异步处理用户登录操作并获取 accessToken // 异步处理用户登录操作并获取 accessToken
@ -85,7 +84,7 @@ export const useAuthStore = defineStore('auth', () => {
resetAllStores(); resetAllStores();
accessStore.setLoginExpired(false); accessStore.setLoginExpired(false);
// 回登页带上当前路由地址 // 回登页带上当前路由地址
await router.replace({ await router.replace({
path: LOGIN_PATH, path: LOGIN_PATH,
query: redirect query: redirect

View File

@ -1,5 +1,6 @@
<script lang="ts" setup> <script lang="ts" setup>
import type { LoginCodeParams, 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, ref } from 'vue';
@ -49,7 +50,7 @@ const formSchema = computed((): VbenFormSchema[] => {
* Asynchronously handle the login process * Asynchronously handle the login process
* @param values 登录表单数据 * @param values 登录表单数据
*/ */
async function handleLogin(values: LoginCodeParams) { async function handleLogin(values: Recordable<any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log(values); console.log(values);
} }

View File

@ -1,5 +1,6 @@
<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, ref } from 'vue';
@ -27,7 +28,7 @@ const formSchema = computed((): VbenFormSchema[] => {
]; ];
}); });
function handleSubmit(value: string) { function handleSubmit(value: Recordable<any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log('reset email:', value); console.log('reset email:', value);
} }

View File

@ -1,5 +1,6 @@
<script lang="ts" setup> <script lang="ts" setup>
import type { LoginAndRegisterParams, VbenFormSchema } from '@vben/common-ui'; import type { VbenFormSchema } from '@vben/common-ui';
import type { Recordable } from '@vben/types';
import { computed, h, ref } from 'vue'; import { computed, h, ref } from 'vue';
@ -86,7 +87,7 @@ const formSchema = computed((): VbenFormSchema[] => {
]; ];
}); });
function handleSubmit(value: LoginAndRegisterParams) { function handleSubmit(value: Recordable<any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log('register submit:', value); console.log('register submit:', value);
} }

View File

@ -1,9 +1,9 @@
{ {
"auth": { "auth": {
"login": "登", "login": "登",
"register": "注册", "register": "注册",
"codeLogin": "验证码登", "codeLogin": "验证码登",
"qrcodeLogin": "二维码登", "qrcodeLogin": "二维码登",
"forgetPassword": "忘记密码" "forgetPassword": "忘记密码"
}, },
"dashboard": { "dashboard": {

View File

@ -1,5 +1,4 @@
import type { LoginAndRegisterParams } from '@vben/common-ui'; import type { Recordable, UserInfo } from '@vben/types';
import type { UserInfo } from '@vben/types';
import { ref } from 'vue'; import { ref } from 'vue';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
@ -26,7 +25,7 @@ export const useAuthStore = defineStore('auth', () => {
* @param params * @param params
*/ */
async function authLogin( async function authLogin(
params: LoginAndRegisterParams, params: Recordable<any>,
onSuccess?: () => Promise<void> | void, onSuccess?: () => Promise<void> | void,
) { ) {
// 异步处理用户登录操作并获取 accessToken // 异步处理用户登录操作并获取 accessToken
@ -85,7 +84,7 @@ export const useAuthStore = defineStore('auth', () => {
resetAllStores(); resetAllStores();
accessStore.setLoginExpired(false); accessStore.setLoginExpired(false);
// 回登页带上当前路由地址 // 回登页带上当前路由地址
await router.replace({ await router.replace({
path: LOGIN_PATH, path: LOGIN_PATH,
query: redirect query: redirect

View File

@ -1,5 +1,6 @@
<script lang="ts" setup> <script lang="ts" setup>
import type { LoginCodeParams, 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, ref } from 'vue';
@ -49,7 +50,7 @@ const formSchema = computed((): VbenFormSchema[] => {
* Asynchronously handle the login process * Asynchronously handle the login process
* @param values 登录表单数据 * @param values 登录表单数据
*/ */
async function handleLogin(values: LoginCodeParams) { async function handleLogin(values: Recordable<any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log(values); console.log(values);
} }

View File

@ -1,5 +1,6 @@
<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, ref } from 'vue';
@ -27,7 +28,7 @@ const formSchema = computed((): VbenFormSchema[] => {
]; ];
}); });
function handleSubmit(value: string) { function handleSubmit(value: Recordable<any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log('reset email:', value); console.log('reset email:', value);
} }

View File

@ -1,5 +1,6 @@
<script lang="ts" setup> <script lang="ts" setup>
import type { LoginAndRegisterParams, VbenFormSchema } from '@vben/common-ui'; import type { VbenFormSchema } from '@vben/common-ui';
import type { Recordable } from '@vben/types';
import { computed, h, ref } from 'vue'; import { computed, h, ref } from 'vue';
@ -86,7 +87,7 @@ const formSchema = computed((): VbenFormSchema[] => {
]; ];
}); });
function handleSubmit(value: LoginAndRegisterParams) { function handleSubmit(value: Recordable<any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log('register submit:', value); console.log('register submit:', value);
} }

View File

@ -11,7 +11,7 @@ outline: deep
## 前端访问控制 ## 前端访问控制
**实现原理**: 在前端固定写死路由的权限,指定路由有哪些权限可以查看。只初始化通用的路由,需要权限才能访问的路由没有被加入路由表内。在登后或者其他方式获取用户角色后,通过角色去遍历路由表,获取该角色可以访问的路由表,生成路由表,再通过 `router.addRoute` 添加到路由实例,实现权限的过滤。 **实现原理**: 在前端固定写死路由的权限,指定路由有哪些权限可以查看。只初始化通用的路由,需要权限才能访问的路由没有被加入路由表内。在登后或者其他方式获取用户角色后,通过角色去遍历路由表,获取该角色可以访问的路由表,生成路由表,再通过 `router.addRoute` 添加到路由实例,实现权限的过滤。
**缺点**: 权限相对不自由,如果后台改动角色,前台也需要跟着改动。适合角色较固定的系统 **缺点**: 权限相对不自由,如果后台改动角色,前台也需要跟着改动。适合角色较固定的系统

View File

@ -1,5 +1,5 @@
/** /**
* @zh_CN url * @zh_CN url
*/ */
export const LOGIN_PATH = '/auth/login'; export const LOGIN_PATH = '/auth/login';

View File

@ -1,8 +1,7 @@
<script setup lang="ts"> <script setup lang="ts">
import type { Recordable } from '@vben/types';
import type { VbenFormSchema } from '@vben-core/form-ui'; import type { VbenFormSchema } from '@vben-core/form-ui';
import type { LoginCodeEmits } from './types';
import { computed, reactive } from 'vue'; import { computed, reactive } from 'vue';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
@ -19,7 +18,7 @@ interface Props {
*/ */
loading?: boolean; loading?: boolean;
/** /**
* @zh_CN 路径 * @zh_CN 路径
*/ */
loginPath?: string; loginPath?: string;
/** /**
@ -49,12 +48,12 @@ const props = withDefaults(defineProps<Props>(), {
}); });
const emit = defineEmits<{ const emit = defineEmits<{
submit: LoginCodeEmits['submit']; submit: [Recordable<any>];
}>(); }>();
const router = useRouter(); const router = useRouter();
const [Form, { validate }] = useVbenForm( const [Form, { validate, getValues }] = useVbenForm(
reactive({ reactive({
commonConfig: { commonConfig: {
hideLabel: true, hideLabel: true,
@ -66,8 +65,8 @@ const [Form, { validate }] = useVbenForm(
); );
async function handleSubmit() { async function handleSubmit() {
const { valid, values } = await validate(); const { valid } = await validate();
const values = await getValues();
if (valid) { if (valid) {
emit('submit', { emit('submit', {
code: values?.code, code: values?.code,

View File

@ -17,7 +17,7 @@ interface Props {
*/ */
loading?: boolean; loading?: boolean;
/** /**
* @zh_CN 路径 * @zh_CN 路径
*/ */
loginPath?: string; loginPath?: string;
/** /**
@ -47,10 +47,10 @@ const props = withDefaults(defineProps<Props>(), {
}); });
const emit = defineEmits<{ const emit = defineEmits<{
submit: [string]; submit: [Record<string, any>];
}>(); }>();
const [Form, { validate }] = useVbenForm( const [Form, { validate, getValues }] = useVbenForm(
reactive({ reactive({
commonConfig: { commonConfig: {
hideLabel: true, hideLabel: true,
@ -64,10 +64,10 @@ const [Form, { validate }] = useVbenForm(
const router = useRouter(); const router = useRouter();
async function handleSubmit() { async function handleSubmit() {
const { valid, values } = await validate(); const { valid } = await validate();
const values = await getValues();
if (valid) { if (valid) {
emit('submit', values?.email); emit('submit', values);
} }
} }

View File

@ -4,8 +4,4 @@ export { default as AuthenticationLogin } from './login.vue';
export { default as AuthenticationLoginExpiredModal } from './login-expired-modal.vue'; export { default as AuthenticationLoginExpiredModal } from './login-expired-modal.vue';
export { default as AuthenticationQrCodeLogin } from './qrcode-login.vue'; export { default as AuthenticationQrCodeLogin } from './qrcode-login.vue';
export { default as AuthenticationRegister } from './register.vue'; export { default as AuthenticationRegister } from './register.vue';
export type { export type { AuthenticationProps } from './types';
AuthenticationProps,
LoginAndRegisterParams,
LoginCodeParams,
} from './types';

View File

@ -1,7 +1,8 @@
<script setup lang="ts"> <script setup lang="ts">
import type { Recordable } from '@vben/types';
import type { VbenFormSchema } from '@vben-core/form-ui'; import type { VbenFormSchema } from '@vben-core/form-ui';
import type { AuthenticationProps, LoginEmits } from './types'; import type { AuthenticationProps } from './types';
import { computed, onMounted, reactive, ref } from 'vue'; import { computed, onMounted, reactive, ref } from 'vue';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
@ -40,10 +41,10 @@ const props = withDefaults(defineProps<Props>(), {
}); });
const emit = defineEmits<{ const emit = defineEmits<{
submit: LoginEmits['submit']; submit: [Recordable<any>];
}>(); }>();
const [Form, { setFieldValue, validate }] = useVbenForm( const [Form, { setFieldValue, validate, getValues }] = useVbenForm(
reactive({ reactive({
commonConfig: { commonConfig: {
hideLabel: true, hideLabel: true,
@ -62,13 +63,14 @@ const localUsername = localStorage.getItem(REMEMBER_ME_KEY) || '';
const rememberMe = ref(!!localUsername); const rememberMe = ref(!!localUsername);
async function handleSubmit() { async function handleSubmit() {
const { valid, values } = await validate(); const { valid } = await validate();
const values = await getValues();
if (valid) { if (valid) {
localStorage.setItem( localStorage.setItem(
REMEMBER_ME_KEY, REMEMBER_ME_KEY,
rememberMe.value ? values?.username : '', rememberMe.value ? values?.username : '',
); );
emit('submit', values as { password: string; username: string }); emit('submit', values);
} }
} }

View File

@ -15,7 +15,7 @@ interface Props {
*/ */
loading?: boolean; loading?: boolean;
/** /**
* @zh_CN 路径 * @zh_CN 路径
*/ */
loginPath?: string; loginPath?: string;
/** /**

View File

@ -1,8 +1,7 @@
<script setup lang="ts"> <script setup lang="ts">
import type { Recordable } from '@vben/types';
import type { VbenFormSchema } from '@vben-core/form-ui'; import type { VbenFormSchema } from '@vben-core/form-ui';
import type { RegisterEmits } from './types';
import { computed, reactive } from 'vue'; import { computed, reactive } from 'vue';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
@ -19,7 +18,7 @@ interface Props {
*/ */
loading?: boolean; loading?: boolean;
/** /**
* @zh_CN 路径 * @zh_CN 路径
*/ */
loginPath?: string; loginPath?: string;
/** /**
@ -50,10 +49,10 @@ const props = withDefaults(defineProps<Props>(), {
}); });
const emit = defineEmits<{ const emit = defineEmits<{
submit: RegisterEmits['submit']; submit: [Recordable<any>];
}>(); }>();
const [Form, { validate }] = useVbenForm( const [Form, { validate, getValues }] = useVbenForm(
reactive({ reactive({
commonConfig: { commonConfig: {
hideLabel: true, hideLabel: true,
@ -67,7 +66,8 @@ const [Form, { validate }] = useVbenForm(
const router = useRouter(); const router = useRouter();
async function handleSubmit() { async function handleSubmit() {
const { valid, values } = await validate(); const { valid } = await validate();
const values = await getValues();
if (valid) { if (valid) {
emit('submit', values as { password: string; username: string }); emit('submit', values as { password: string; username: string });
} }

View File

@ -67,30 +67,4 @@ interface AuthenticationProps {
submitButtonText?: string; submitButtonText?: string;
} }
type LoginAndRegisterParams = Record<string, any>; export type { AuthenticationProps };
interface LoginCodeParams {
code: string;
phoneNumber: string;
}
interface LoginEmits {
submit: [LoginAndRegisterParams];
}
interface LoginCodeEmits {
submit: [LoginCodeParams];
}
interface RegisterEmits {
submit: [LoginAndRegisterParams];
}
export type {
AuthenticationProps,
LoginAndRegisterParams,
LoginCodeEmits,
LoginCodeParams,
LoginEmits,
RegisterEmits,
};

View File

@ -1,4 +1,6 @@
<script setup lang="ts"> <script setup lang="ts">
import type { Recordable } from '@vben/types';
import { computed, reactive } from 'vue'; import { computed, reactive } from 'vue';
import { $t } from '@vben/locales'; import { $t } from '@vben/locales';
@ -11,14 +13,6 @@ interface Props {
text?: string; text?: string;
} }
interface LockAndRegisterParams {
lockScreenPassword: string;
}
interface RegisterEmits {
submit: [LockAndRegisterParams];
}
defineOptions({ defineOptions({
name: 'LockScreenModal', name: 'LockScreenModal',
}); });
@ -29,10 +23,10 @@ withDefaults(defineProps<Props>(), {
}); });
const emit = defineEmits<{ const emit = defineEmits<{
submit: RegisterEmits['submit']; submit: [Recordable<any>];
}>(); }>();
const [Form, { resetForm, validate }] = useVbenForm( const [Form, { resetForm, validate, getValues }] = useVbenForm(
reactive({ reactive({
commonConfig: { commonConfig: {
hideLabel: true, hideLabel: true,
@ -68,7 +62,8 @@ const [Modal] = useVbenModal({
}); });
async function handleSubmit() { async function handleSubmit() {
const { valid, values } = await validate(); const { valid } = await validate();
const values = await getValues();
if (valid) { if (valid) {
emit('submit', values?.lockScreenPassword); emit('submit', values?.lockScreenPassword);
} }

View File

@ -1,9 +1,9 @@
{ {
"auth": { "auth": {
"login": "登", "login": "登",
"register": "注册", "register": "注册",
"codeLogin": "验证码登", "codeLogin": "验证码登",
"qrcodeLogin": "二维码登", "qrcodeLogin": "二维码登",
"forgetPassword": "忘记密码" "forgetPassword": "忘记密码"
}, },
"dashboard": { "dashboard": {

View File

@ -1,5 +1,4 @@
import type { LoginAndRegisterParams } from '@vben/common-ui'; import type { Recordable, UserInfo } from '@vben/types';
import type { UserInfo } from '@vben/types';
import { ref } from 'vue'; import { ref } from 'vue';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
@ -27,7 +26,7 @@ export const useAuthStore = defineStore('auth', () => {
* @param onSuccess * @param onSuccess
*/ */
async function authLogin( async function authLogin(
params: LoginAndRegisterParams, params: Recordable<any>,
onSuccess?: () => Promise<void> | void, onSuccess?: () => Promise<void> | void,
) { ) {
// 异步处理用户登录操作并获取 accessToken // 异步处理用户登录操作并获取 accessToken
@ -86,7 +85,7 @@ export const useAuthStore = defineStore('auth', () => {
resetAllStores(); resetAllStores();
accessStore.setLoginExpired(false); accessStore.setLoginExpired(false);
// 回登页带上当前路由地址 // 回登页带上当前路由地址
await router.replace({ await router.replace({
path: LOGIN_PATH, path: LOGIN_PATH,
query: redirect query: redirect

View File

@ -1,5 +1,6 @@
<script lang="ts" setup> <script lang="ts" setup>
import type { LoginCodeParams, 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, ref } from 'vue';
@ -49,7 +50,7 @@ const formSchema = computed((): VbenFormSchema[] => {
* Asynchronously handle the login process * Asynchronously handle the login process
* @param values 登录表单数据 * @param values 登录表单数据
*/ */
async function handleLogin(values: LoginCodeParams) { async function handleLogin(values: Recordable<any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log(values); console.log(values);
} }

View File

@ -27,7 +27,7 @@ const formSchema = computed((): VbenFormSchema[] => {
]; ];
}); });
function handleSubmit(value: string) { function handleSubmit(value: Record<string, any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log('reset email:', value); console.log('reset email:', value);
} }

View File

@ -1,5 +1,6 @@
<script lang="ts" setup> <script lang="ts" setup>
import type { LoginAndRegisterParams, VbenFormSchema } from '@vben/common-ui'; import type { VbenFormSchema } from '@vben/common-ui';
import type { Recordable } from '@vben/types';
import { computed, h, ref } from 'vue'; import { computed, h, ref } from 'vue';
@ -86,7 +87,7 @@ const formSchema = computed((): VbenFormSchema[] => {
]; ];
}); });
function handleSubmit(value: LoginAndRegisterParams) { function handleSubmit(value: Recordable<any>) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log('register submit:', value); console.log('register submit:', value);
} }

View File

@ -1,5 +1,5 @@
<script lang="ts" setup> <script lang="ts" setup>
import type { LoginAndRegisterParams } from '@vben/common-ui'; import type { Recordable } from '@vben/types';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
@ -11,7 +11,7 @@ import { Button, Card } from 'ant-design-vue';
import { useAuthStore } from '#/store'; import { useAuthStore } from '#/store';
const accounts: Record<string, LoginAndRegisterParams> = { const accounts: Record<string, Recordable<any>> = {
admin: { admin: {
password: '123456', password: '123456',
username: 'admin', username: 'admin',

View File

@ -1,5 +1,5 @@
<script lang="ts" setup> <script lang="ts" setup>
import type { LoginAndRegisterParams } from '@vben/common-ui'; import type { Recordable } from '@vben/types';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
@ -11,7 +11,7 @@ import { Button, Card } from 'ant-design-vue';
import { useAuthStore } from '#/store'; import { useAuthStore } from '#/store';
const accounts: Record<string, LoginAndRegisterParams> = { const accounts: Record<string, Recordable<any>> = {
admin: { admin: {
password: '123456', password: '123456',
username: 'admin', username: 'admin',