Files
ant-design/components/transfer/hooks/useSelection.ts
EmilyyyLiu a02c1d5595 refactor: Upgrade utils and replace useMergedState (#55047)
* refactor: Upgrade utils and replace useMergedState

* Update components/color-picker/components/ColorPresets.tsx

Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com>
Signed-off-by: EmilyyyLiu <100924403+EmilyyyLiu@users.noreply.github.com>

* fix: lint error useControlledState not use

* feat: change import util path

* feat: mergedSelectedKeys

* feat: Modify the import path of rc-util

* feat: Restore the 'useControlledState' modification of 'select'

---------

Signed-off-by: EmilyyyLiu <100924403+EmilyyyLiu@users.noreply.github.com>
Co-authored-by: 刘欢 <lh01217311@antgroup.com>
Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com>
2025-09-25 10:57:09 +08:00

78 lines
2.2 KiB
TypeScript

import * as React from 'react';
import { useControlledState, useEvent } from '@rc-component/util';
import type { TransferKey } from '../interface';
const EMPTY_KEYS: TransferKey[] = [];
function filterKeys(keys: TransferKey[], dataKeys: Set<TransferKey>) {
const filteredKeys = keys.filter((key) => dataKeys.has(key));
return keys.length === filteredKeys.length ? keys : filteredKeys;
}
function flattenKeys(keys: Set<TransferKey>) {
return Array.from(keys).join(';');
}
function useSelection<T extends { key: TransferKey }>(
leftDataSource: T[],
rightDataSource: T[],
selectedKeys?: TransferKey[],
): [
sourceSelectedKeys: TransferKey[],
targetSelectedKeys: TransferKey[],
setSourceSelectedKeys: (srcKeys: TransferKey[]) => void,
setTargetSelectedKeys: (srcKeys: TransferKey[]) => void,
] {
// Prepare `dataSource` keys
const [leftKeys, rightKeys] = React.useMemo(
() => [
new Set(leftDataSource.map<React.Key>((src) => src?.key)),
new Set(rightDataSource.map<React.Key>((src) => src?.key)),
],
[leftDataSource, rightDataSource],
);
// Selected Keys
const [mergedSelectedKeys, setMergedSelectedKeys] = useControlledState<React.Key[]>(
EMPTY_KEYS,
selectedKeys,
);
const sourceSelectedKeys = React.useMemo(
() => filterKeys(mergedSelectedKeys, leftKeys),
[mergedSelectedKeys, leftKeys],
);
const targetSelectedKeys = React.useMemo(
() => filterKeys(mergedSelectedKeys, rightKeys),
[mergedSelectedKeys, rightKeys],
);
// // Reset when data changed
React.useEffect(() => {
setMergedSelectedKeys([
...filterKeys(mergedSelectedKeys, leftKeys),
...filterKeys(mergedSelectedKeys, rightKeys),
]);
}, [flattenKeys(leftKeys), flattenKeys(rightKeys)]);
// Update keys
const setSourceSelectedKeys = useEvent((nextSrcKeys: TransferKey[]) => {
setMergedSelectedKeys([...nextSrcKeys, ...targetSelectedKeys]);
});
const setTargetSelectedKeys = useEvent((nextTargetKeys: TransferKey[]) => {
setMergedSelectedKeys([...sourceSelectedKeys, ...nextTargetKeys]);
});
return [
// Keys
sourceSelectedKeys,
targetSelectedKeys,
// Updater
setSourceSelectedKeys,
setTargetSelectedKeys,
];
}
export default useSelection;