!226 update src/hooks/web/useCrudSchemas.ts.

Merge pull request !226 from AKING/N/A
pull/232/head
芋道源码 2023-09-03 10:56:36 +00:00 committed by Gitee
commit 067f89f1d4
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
1 changed files with 26 additions and 18 deletions

View File

@ -9,7 +9,7 @@ import { TableColumn } from '@/types/table'
import { DescriptionsSchema } from '@/types/descriptions' import { DescriptionsSchema } from '@/types/descriptions'
import { ComponentOptions, ComponentProps } from '@/types/components' import { ComponentOptions, ComponentProps } from '@/types/components'
import { DictTag } from '@/components/DictTag' import { DictTag } from '@/components/DictTag'
import { cloneDeep } from 'lodash-es' import { cloneDeep, merge } from 'lodash-es'
export type CrudSchema = Omit<TableColumn, 'children'> & { export type CrudSchema = Omit<TableColumn, 'children'> & {
isSearch?: boolean // 是否在查询显示 isSearch?: boolean // 是否在查询显示
@ -117,14 +117,18 @@ const filterSearchSchema = (crudSchema: CrudSchema[], allSchemas: AllSchemas): F
} }
if (!schemaItem.search?.component) component = 'Select' if (!schemaItem.search?.component) component = 'Select'
} }
const searchSchemaItem = {
// 默认为 input // updated by AKing: 解决了当使用默认的dict选项时form中事件不能触发的问题
component: component, const searchSchemaItem = merge(
componentProps: comonentProps, {
...schemaItem.search, // 默认为 input
field: schemaItem.field, component,
label: schemaItem.search?.label || schemaItem.label ...schemaItem.search,
} field: schemaItem.field,
label: schemaItem.search?.label || schemaItem.label
},
{ componentProps: comonentProps }
)
if (searchSchemaItem.api) { if (searchSchemaItem.api) {
searchRequestTask.push(async () => { searchRequestTask.push(async () => {
const res = await (searchSchemaItem.api as () => AxiosPromise)() const res = await (searchSchemaItem.api as () => AxiosPromise)()
@ -224,15 +228,19 @@ const filterFormSchema = (crudSchema: CrudSchema[], allSchemas: AllSchemas): For
} }
if (!(schemaItem.form && schemaItem.form.component)) component = 'Select' if (!(schemaItem.form && schemaItem.form.component)) component = 'Select'
} }
const formSchemaItem = {
// 默认为 input // updated by AKing: 解决了当使用默认的dict选项时form中事件不能触发的问题
component: component, const formSchemaItem = merge(
componentProps: comonentProps, {
value: defaultValue, // 默认为 input
...schemaItem.form, component,
field: schemaItem.field, value: defaultValue,
label: schemaItem.form?.label || schemaItem.label ...schemaItem.form,
} field: schemaItem.field,
label: schemaItem.form?.label || schemaItem.label
},
{ componentProps: comonentProps }
)
if (formSchemaItem.api) { if (formSchemaItem.api) {
formRequestTask.push(async () => { formRequestTask.push(async () => {