| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 | import React from 'react';import { isFunction } from 'lodash';import PropTypes from 'prop-types';import classnames from 'classnames';import { stepsClasses as css } from '@douyinfe/semi-foundation/steps/constants';import { IconTickCircle, IconAlertCircle, IconAlertTriangle } from '@douyinfe/semi-icons';export type Status = 'wait' | 'process' | 'finish' | 'error' | 'warning';export interface FillStepProps {    description?: React.ReactNode;    icon?: React.ReactNode;    status?: Status;    title?: React.ReactNode;    className?: string;    style?: React.CSSProperties;    prefixCls?: string;    stepNumber?: string;    onChange?: () => void;    onClick?: React.MouseEventHandler<HTMLDivElement>;    onKeyDown?: React.KeyboardEventHandler<HTMLDivElement>;    "role"?: React.AriaRole;    "aria-label"?: React.AriaAttributes["aria-label"];}const FillStep = (props: FillStepProps) => {    const { prefixCls, className, title, description, status, style, onClick, icon, onChange, stepNumber, onKeyDown } = props;    const renderIcon = () => {        let inner, progress;        if ('icon' in props) {            inner = icon;        } else if ('status' in props) {            switch (status) {                case 'error':                    inner = <IconAlertCircle size="extra-large" />;                    break;                case 'wait':                    inner = stepNumber;                    break;                case 'process':                    inner = stepNumber;                    progress = true;                    break;                case 'finish':                    inner = <IconTickCircle size="extra-large" />;                    break;                case 'warning':                    inner = <IconAlertTriangle size="extra-large" />;                    break;                default:                    inner = null;                    break;            }        }        const cls = classnames({            [`${prefixCls}-left`]: true,            [`${prefixCls}-icon`]: 'icon' in props,            [`${prefixCls}-plain`]: !('icon' in props),            [`${prefixCls}-icon-process`]: progress,        });        return inner ? <div className={cls}>{inner}</div> : null;    };    const handleClick = (e: React.MouseEvent) => {        if (isFunction(onClick)) {            onClick(e);        }        onChange();    };    const handleKeyDown = (e) => {        if (e.key === 'Enter') {            if (isFunction(onKeyDown)) {                onKeyDown(e);            }            onChange();        }    };    return (        <div            role={props["role"]}            aria-label={props["aria-label"]}            aria-current="step"            tabIndex={0}             className={classnames({                [prefixCls]: true,                [`${prefixCls}-${status}`]: Boolean(status),                [`${prefixCls}-clickable`]: onClick,            }, className)}            style={style}            onClick={e => {                handleClick(e);            }}            onKeyDown={handleKeyDown}        >            {renderIcon()}            <div className={`${prefixCls}-content`}>                <div className={`${prefixCls}-title`} title={typeof title === 'string' ? title : null}>                    <span className={`${prefixCls}-title-text`}>{title}</span>                </div>                <div                    className={`${prefixCls}-description`}                    title={typeof description === 'string' ? description : null}                >                    {description}                </div>            </div>        </div>    );};FillStep.propTypes = {    prefixCls: PropTypes.string,    description: PropTypes.node,    icon: PropTypes.node,    status: PropTypes.oneOf(['wait', 'process', 'finish', 'error', 'warning']),    title: PropTypes.node,    className: PropTypes.string,    style: PropTypes.object,    onClick: PropTypes.func,};FillStep.defaultProps = {    prefixCls: css.ITEM,    status: 'wait',    className: '',};export default FillStep;
 |