import * as React from 'react'; import classnames from 'classnames'; import toArray from 'rc-util/lib/Children/toArray'; import { ConfigConsumerProps, ConfigContext } from '../config-provider'; import { SizeType } from '../config-provider/SizeContext'; export interface SpaceProps { prefixCls?: string; className?: string; style?: React.CSSProperties; size?: SizeType | number; direction?: 'horizontal' | 'vertical'; } const spaceSize = { small: 8, middle: 16, large: 24, }; const Space: React.FC = props => { const { getPrefixCls, space }: ConfigConsumerProps = React.useContext(ConfigContext); const { size = space?.size || 'small', className, children, direction = 'horizontal', prefixCls: customizePrefixCls, ...otherProps } = props; const items = toArray(children); const len = items.length; if (len === 0) { return null; } const prefixCls = getPrefixCls('space', customizePrefixCls); const cn = classnames(prefixCls, `${prefixCls}-${direction}`, className); const itemClassName = `${prefixCls}-item`; return (
{items.map((child, i) => (
{child}
))}
); }; export default Space;