From 82893322149827f40598e6d9ddab478308a15f7e Mon Sep 17 00:00:00 2001 From: bowen <54492610+jiaowoxiaobala@users.noreply.github.com> Date: Mon, 9 Oct 2023 15:12:23 +0800 Subject: [PATCH] chore: Fix ts type error (#3112) --- src/components/Form/src/BasicForm.vue | 15 ++++++++++----- src/components/Form/src/hooks/useForm.ts | 8 ++++---- src/components/Scrollbar/src/util.ts | 4 ++-- src/logics/mitt/routeChange.ts | 6 ++++-- src/utils/bem.ts | 3 ++- 5 files changed, 22 insertions(+), 14 deletions(-) diff --git a/src/components/Form/src/BasicForm.vue b/src/components/Form/src/BasicForm.vue index a9ee8b7e..bcc11105 100644 --- a/src/components/Form/src/BasicForm.vue +++ b/src/components/Form/src/BasicForm.vue @@ -117,14 +117,19 @@ const getSchema = computed((): FormSchema[] => { const schemas: FormSchema[] = unref(schemaRef) || (unref(getProps).schemas as any); for (const schema of schemas) { - const { defaultValue, component, componentProps,isHandleDateDefaultValue = true } = schema; + const { + defaultValue, + component, + componentProps, + isHandleDateDefaultValue = true, + } = schema; // handle date type if (isHandleDateDefaultValue && defaultValue && dateItemType.includes(component)) { - const valueFormat =componentProps ? componentProps['valueFormat'] : null; + const valueFormat = componentProps ? componentProps['valueFormat'] : null; if (!Array.isArray(defaultValue)) { - schema.defaultValue = valueFormat - ? dateUtil(defaultValue).format(valueFormat) - : dateUtil(defaultValue); + schema.defaultValue = valueFormat + ? dateUtil(defaultValue).format(valueFormat) + : dateUtil(defaultValue); } else { const def: any[] = []; defaultValue.forEach((item) => { diff --git a/src/components/Form/src/hooks/useForm.ts b/src/components/Form/src/hooks/useForm.ts index 40f246da..9f6855f6 100644 --- a/src/components/Form/src/hooks/useForm.ts +++ b/src/components/Form/src/hooks/useForm.ts @@ -88,15 +88,15 @@ export function useForm(props?: Props): UseFormReturnType { return unref(formRef)?.getFieldsValue() as T; }, - setFieldsValue: async (values: T) => { + setFieldsValue: async >(values: T) => { const form = await getForm(); - form.setFieldsValue(values); + form.setFieldsValue(values); }, appendSchemaByField: async ( schema: FormSchema | FormSchema[], prefixField: string | undefined, - first: boolean, + first?: boolean, ) => { const form = await getForm(); form.appendSchemaByField(schema, prefixField, first); @@ -107,7 +107,7 @@ export function useForm(props?: Props): UseFormReturnType { return form.submit(); }, - validate: async (nameList?: NamePath[]): Promise => { + validate: async (nameList?: NamePath[] | false): Promise => { const form = await getForm(); return form.validate(nameList); }, diff --git a/src/components/Scrollbar/src/util.ts b/src/components/Scrollbar/src/util.ts index 77694a90..c98b0b8b 100644 --- a/src/components/Scrollbar/src/util.ts +++ b/src/components/Scrollbar/src/util.ts @@ -36,11 +36,11 @@ export function renderThumbStyle({ move, size, bar }) { return style; } -function extend(to: T, _from: K): T & K { +function extend(to: T, _from: K): T & K { return Object.assign(to, _from); } -export function toObject(arr: Array): Recordable { +export function toObject(arr: Array): Recordable { const res = {}; for (let i = 0; i < arr.length; i++) { if (arr[i]) { diff --git a/src/logics/mitt/routeChange.ts b/src/logics/mitt/routeChange.ts index a985fe2f..ccd777d3 100644 --- a/src/logics/mitt/routeChange.ts +++ b/src/logics/mitt/routeChange.ts @@ -6,10 +6,12 @@ import { mitt } from '/@/utils/mitt'; import type { RouteLocationNormalized } from 'vue-router'; import { getRawRoute } from '/@/utils'; -const emitter = mitt(); - const key = Symbol(); +const emitter = mitt<{ + [key]: RouteLocationNormalized; +}>(); + let lastChangeTab: RouteLocationNormalized; export function setRouteChange(lastChangeRoute: RouteLocationNormalized) { diff --git a/src/utils/bem.ts b/src/utils/bem.ts index 7dcadbc9..53fb0543 100644 --- a/src/utils/bem.ts +++ b/src/utils/bem.ts @@ -14,8 +14,9 @@ function genBem(name: string, mods?: Mods): string { return ` ${name}--${mods}`; } + // ArrayConstructor.isArray(arg: any): arg is any[] if (Array.isArray(mods)) { - return mods.reduce((ret, item) => ret + genBem(name, item), ''); + return (mods as Mod[]).reduce((ret, item) => ret + genBem(name, item), ''); } return Object.keys(mods).reduce((ret, key) => ret + (mods[key] ? genBem(name, key) : ''), '');