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, direction: directionConfig }: 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}`, { [`${prefixCls}-rtl`]: directionConfig === 'rtl' }, className, ); const itemClassName = `${prefixCls}-item`; const marginDirection = directionConfig === 'rtl' ? 'marginLeft' : 'marginRight'; return (
{items.map((child, i) => (
{child}
))}
); }; export default Space;