mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-15 08:59:15 +08:00
1b2362a425
* type: rm useless type" * update size-limit
42 lines
1.3 KiB
TypeScript
42 lines
1.3 KiB
TypeScript
import type { ReactNode } from 'react';
|
|
import React from 'react';
|
|
import CloseOutlined from '@ant-design/icons/CloseOutlined';
|
|
|
|
function useInnerClosable(closable?: boolean, closeIcon?: ReactNode, defaultClosable?: boolean) {
|
|
if (typeof closable === 'boolean') {
|
|
return closable;
|
|
}
|
|
if (closeIcon === undefined) {
|
|
return !!defaultClosable;
|
|
}
|
|
return closeIcon !== false && closeIcon !== null;
|
|
}
|
|
|
|
export type UseClosableParams = {
|
|
closable?: boolean;
|
|
closeIcon?: ReactNode;
|
|
defaultClosable?: boolean;
|
|
defaultCloseIcon?: ReactNode;
|
|
customCloseIconRender?: (closeIcon: ReactNode) => ReactNode;
|
|
};
|
|
|
|
function useClosable(
|
|
closable?: boolean,
|
|
closeIcon?: ReactNode,
|
|
customCloseIconRender?: (closeIcon: ReactNode) => ReactNode,
|
|
defaultCloseIcon: ReactNode = <CloseOutlined />,
|
|
defaultClosable = false,
|
|
): [closable: boolean, closeIcon: React.ReactNode | null] {
|
|
const mergedClosable = useInnerClosable(closable, closeIcon, defaultClosable);
|
|
if (!mergedClosable) {
|
|
return [false, null];
|
|
}
|
|
const mergedCloseIcon =
|
|
typeof closeIcon === 'boolean' || closeIcon === undefined || closeIcon === null
|
|
? defaultCloseIcon
|
|
: closeIcon;
|
|
return [true, customCloseIconRender ? customCloseIconRender(mergedCloseIcon) : mergedCloseIcon];
|
|
}
|
|
|
|
export default useClosable;
|