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 ( <div class={`${prefixCls}-icon ${prefixCls}-image`}> <SVGComponent /> </div> ); } // prop `icon` require slot or VNode const iconString = IconMap[status]; const iconNode = icon || <Icon type={iconString} theme="filled" />; return <div class={`${prefixCls}-icon`}>{iconNode}</div>; }; const renderExtra = (h, prefixCls, extra) => extra && <div class={`${prefixCls}-extra`}>{extra}</div>; const Result = { name: 'AResult', props: ResultProps, inject: { configProvider: { default: () => ConfigConsumerProps }, }, render(h) { const { prefixCls: customizePrefixCls, status } = this; const getPrefixCls = this.configProvider.getPrefixCls; const prefixCls = getPrefixCls('result', customizePrefixCls); const title = getComponentFromProp(this, 'title'); const subTitle = getComponentFromProp(this, 'subTitle'); const icon = getComponentFromProp(this, 'icon'); const extra = getComponentFromProp(this, 'extra'); return ( <div class={`${prefixCls} ${prefixCls}-${status}`}> {renderIcon(h, prefixCls, { status, icon })} <div class={`${prefixCls}-title`}>{title}</div> {subTitle && <div class={`${prefixCls}-subtitle`}>{subTitle}</div>} {this.$slots.default && <div class={`${prefixCls}-content`}>{this.$slots.default}</div>} {renderExtra(h, prefixCls, extra)} </div> ); }, }; /* add resource */ Result.PRESENTED_IMAGE_403 = ExceptionMap[403]; Result.PRESENTED_IMAGE_404 = ExceptionMap[404]; Result.PRESENTED_IMAGE_500 = ExceptionMap[500]; /* istanbul ignore next */ Result.install = function(Vue) { Vue.use(Base); Vue.component(Result.name, Result); }; export default Result;