ant-design/components/divider/index.tsx
2018-12-07 18:27:30 +08:00

39 lines
978 B
TypeScript

import * as React from 'react';
import classNames from 'classnames';
export interface DividerProps {
prefixCls?: string;
type?: 'horizontal' | 'vertical';
orientation?: 'left' | 'right' | '';
className?: string;
children?: React.ReactNode;
dashed?: boolean;
style?: React.CSSProperties;
}
export default function Divider({
prefixCls = 'ant',
type = 'horizontal',
orientation = '',
className,
children,
dashed,
...restProps
}: DividerProps) {
const orientationPrefix = orientation.length > 0 ? '-' + orientation : orientation;
const classString = classNames(
className,
`${prefixCls}-divider`,
`${prefixCls}-divider-${type}`,
{
[`${prefixCls}-divider-with-text${orientationPrefix}`]: children,
[`${prefixCls}-divider-dashed`]: !!dashed,
},
);
return (
<div className={classString} {...restProps}>
{children && <span className={`${prefixCls}-divider-inner-text`}>{children}</span>}
</div>
);
}