import React from 'react'; import CheckCircleFilled from '@ant-design/icons/CheckCircleFilled'; import ExclamationCircleFilled from '@ant-design/icons/ExclamationCircleFilled'; import CloseCircleFilled from '@ant-design/icons/CloseCircleFilled'; import LoadingOutlined from '@ant-design/icons/LoadingOutlined'; import classNames from 'classnames'; import { ValidateStatus } from '../form/FormItem'; import { tuple } from './type'; const InputStatuses = tuple('warning', 'error', ''); export type InputStatus = typeof InputStatuses[number]; const iconMap = { success: CheckCircleFilled, warning: ExclamationCircleFilled, error: CloseCircleFilled, validating: LoadingOutlined, }; export const getFeedbackIcon = (prefixCls: string, status?: ValidateStatus) => { const IconNode = status && iconMap[status]; return IconNode ? ( ) : null; }; export function getStatusClassNames( prefixCls: string, status?: ValidateStatus, hasFeedback?: boolean, ) { return classNames({ [`${prefixCls}-status-success`]: status === 'success', [`${prefixCls}-status-warning`]: status === 'warning', [`${prefixCls}-status-error`]: status === 'error', [`${prefixCls}-status-validating`]: status === 'validating', [`${prefixCls}-has-feedback`]: hasFeedback, }); }