import { CheckCircleFilled, ExclamationCircleFilled, LoadingOutlined, WarningOutlined } from '@ant-design/icons'; export const STATUS_RESET_TIMEOUT = 3000; export const STATUS_ERROR = 'error'; export const STATUS_INVALID = 'invalid'; export const STATUS_PROCESSING = 'proessing'; export const STATUS_SUCCESS = 'success'; export const STATUS_WARNING = 'warning'; export type InputStatusTypes = typeof STATUS_ERROR | typeof STATUS_INVALID | typeof STATUS_PROCESSING | typeof STATUS_SUCCESS | typeof STATUS_WARNING; export type StatusState = { icon: any; // Element type of sorts? message: string; }; export const INPUT_STATES = { [STATUS_SUCCESS]: { icon: , message: 'Success!', }, [STATUS_ERROR]: { icon: , message: 'An error occurred.', }, [STATUS_INVALID]: { icon: , message: 'An error occurred.', }, [STATUS_PROCESSING]: { icon: , message: '', }, [STATUS_WARNING]: { icon: , message: '', }, }; // Don't like any of the default messages in INPUT_STATES? Create a state with custom message by providing an icon style with your message. export function createInputStatus(type: InputStatusTypes, message: string): StatusState { if (!type || !INPUT_STATES[type]) { return null; } if (message === null) { return INPUT_STATES[type]; } return { icon: INPUT_STATES[type].icon, message, }; }