diff --git a/packages/ui/transfer/src/Transfer.tsx b/packages/ui/transfer/src/Transfer.tsx index 66d2187fd..ba35f6d8b 100644 --- a/packages/ui/transfer/src/Transfer.tsx +++ b/packages/ui/transfer/src/Transfer.tsx @@ -9,6 +9,7 @@ import { TransferProvider } from './context' import { useCheck } from '@hi-ui/use-check' import { useUncontrolledState } from '@hi-ui/use-uncontrolled-state' import { HiBaseHTMLProps, useLocaleContext } from '@hi-ui/core' +import { transformData } from './utils' const _role = 'transfer' const _prefix = getPrefixCls(_role) @@ -32,6 +33,7 @@ export const Transfer = forwardRef( targetSortType = 'default', pagination = false, data = NOOP_ARRAY, + fieldNames, defaultTargetIds = NOOP_ARRAY, targetIds: targetIdsProp, targetLimit, @@ -56,6 +58,11 @@ export const Transfer = forwardRef( onChange ) + data = useMemo(() => { + if(data) return transformData(data, fieldNames) + else return data + }, [data,fieldNames]) + const pageSize = useMemo(() => { if (pagination === true) return 10 if (typeof pagination === 'object' && 'pageSize' in pagination) { @@ -376,6 +383,10 @@ export interface TransferProps * 穿梭框数据源 */ data: TransferDataItem[] + /** + * 设置data中各项值对应的key + **/ + fieldNames?: Record /** * 最大可穿梭上限 */ diff --git a/packages/ui/transfer/src/utils.ts b/packages/ui/transfer/src/utils.ts new file mode 100644 index 000000000..6f32edefc --- /dev/null +++ b/packages/ui/transfer/src/utils.ts @@ -0,0 +1,26 @@ +import { TransferDataItem } from "./types"; + + +export const transformData = (data: TransferDataItem[], + fieldNames: Record | undefined + ): TransferDataItem[] => { + const getKeyFields = (node: any, key: any) => { + if(fieldNames ){ + return node[(fieldNames as any)[key] || key] + } + return node[key] + } + + const traverseNode = (node: TransferDataItem): TransferDataItem => { + const newNode = { ...node } + + newNode.id = getKeyFields(newNode, 'id') + newNode.title = getKeyFields(newNode, 'title') + newNode.disabled = getKeyFields(newNode, 'disabled')?? false + + return newNode + } + + return data.map(traverseNode) as TransferDataItem[] + + }