import PropTypes from '../_util/vue-types'; import { getComponentFromProp } from '../_util/props-util'; import { ConfigConsumerProps } from '../config-provider'; import Icon from '../icon'; import Base from '../base'; import noFound from './noFound'; import serverError from './serverError'; import unauthorized from './unauthorized'; export const IconMap = { success: 'check-circle', error: 'close-circle', info: 'exclamation-circle', warning: 'warning', }; export const ExceptionMap = { '404': noFound, '500': serverError, '403': unauthorized, }; // ExceptionImageMap keys const ExceptionStatus = Object.keys(ExceptionMap); export const ResultProps = { prefixCls: PropTypes.string, icon: PropTypes.any, status: PropTypes.oneOf(['success', 'error', 'info', 'warning', '404', '403', '500']).def('info'), title: PropTypes.any, subTitle: PropTypes.any, extra: PropTypes.any, }; const renderIcon = (h, prefixCls, { status, icon }) => { if (ExceptionStatus.includes(`${status}`)) { const SVGComponent = ExceptionMap[status]; return (
); } // prop `icon` require slot or VNode const iconString = IconMap[status]; const iconNode = icon ||