import { CSSProperties, ReactNode, Children, cloneElement } from 'react' import classNames from 'classnames' import { CommonComponentProps } from '../../utils/types' import './Steps.scss' import { StepsStep, StepsStepProps } from './StepsStep' export * from './StepsStep' export type StepsStatus = 'wait' | 'process' | 'error' | 'finish' export interface StepsProps extends CommonComponentProps { className?: string style?: CSSProperties children?: ReactNode center?: boolean direction?: 'horizontal' | 'vertical' active?: number status?: StepsStatus lineColor?: string clickable?: boolean disabled?: boolean onChange?: (active: number) => void } export function Steps(props: StepsProps) { const { className, children, center = false, direction = 'horizontal', active = 0, status, lineColor, clickable, disabled = false, onChange, ...restProps } = props const stepsClass = classNames( 's-steps', `s-steps-${direction}`, { 's-steps-center': center, 's-steps-clickable': clickable, }, className ) return (