index.js 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.resultProps = exports.default = exports.IconMap = exports.ExceptionMap = void 0;
  7. var _vue = require("vue");
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
  10. var _CheckCircleFilled = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CheckCircleFilled"));
  11. var _CloseCircleFilled = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CloseCircleFilled"));
  12. var _ExclamationCircleFilled = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/ExclamationCircleFilled"));
  13. var _WarningFilled = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/WarningFilled"));
  14. var _noFound = _interopRequireDefault(require("./noFound"));
  15. var _serverError = _interopRequireDefault(require("./serverError"));
  16. var _unauthorized = _interopRequireDefault(require("./unauthorized"));
  17. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  18. var _classNames = _interopRequireDefault(require("../_util/classNames"));
  19. var _style = _interopRequireDefault(require("./style"));
  20. const IconMap = exports.IconMap = {
  21. success: _CheckCircleFilled.default,
  22. error: _CloseCircleFilled.default,
  23. info: _ExclamationCircleFilled.default,
  24. warning: _WarningFilled.default
  25. };
  26. const ExceptionMap = exports.ExceptionMap = {
  27. '404': _noFound.default,
  28. '500': _serverError.default,
  29. '403': _unauthorized.default
  30. };
  31. // ExceptionImageMap keys
  32. const ExceptionStatus = Object.keys(ExceptionMap);
  33. const resultProps = () => ({
  34. prefixCls: String,
  35. icon: _vueTypes.default.any,
  36. status: {
  37. type: [Number, String],
  38. default: 'info'
  39. },
  40. title: _vueTypes.default.any,
  41. subTitle: _vueTypes.default.any,
  42. extra: _vueTypes.default.any
  43. });
  44. exports.resultProps = resultProps;
  45. const renderIcon = (prefixCls, _ref) => {
  46. let {
  47. status,
  48. icon
  49. } = _ref;
  50. if (ExceptionStatus.includes(`${status}`)) {
  51. const SVGComponent = ExceptionMap[status];
  52. return (0, _vue.createVNode)("div", {
  53. "class": `${prefixCls}-icon ${prefixCls}-image`
  54. }, [(0, _vue.createVNode)(SVGComponent, null, null)]);
  55. }
  56. const IconComponent = IconMap[status];
  57. const iconNode = icon || (0, _vue.createVNode)(IconComponent, null, null);
  58. return (0, _vue.createVNode)("div", {
  59. "class": `${prefixCls}-icon`
  60. }, [iconNode]);
  61. };
  62. const renderExtra = (prefixCls, extra) => extra && (0, _vue.createVNode)("div", {
  63. "class": `${prefixCls}-extra`
  64. }, [extra]);
  65. const Result = (0, _vue.defineComponent)({
  66. compatConfig: {
  67. MODE: 3
  68. },
  69. name: 'AResult',
  70. inheritAttrs: false,
  71. props: resultProps(),
  72. slots: Object,
  73. setup(props, _ref2) {
  74. let {
  75. slots,
  76. attrs
  77. } = _ref2;
  78. const {
  79. prefixCls,
  80. direction
  81. } = (0, _useConfigInject.default)('result', props);
  82. const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
  83. const className = (0, _vue.computed)(() => (0, _classNames.default)(prefixCls.value, hashId.value, `${prefixCls.value}-${props.status}`, {
  84. [`${prefixCls.value}-rtl`]: direction.value === 'rtl'
  85. }));
  86. return () => {
  87. var _a, _b, _c, _d, _e, _f, _g, _h;
  88. const title = (_a = props.title) !== null && _a !== void 0 ? _a : (_b = slots.title) === null || _b === void 0 ? void 0 : _b.call(slots);
  89. const subTitle = (_c = props.subTitle) !== null && _c !== void 0 ? _c : (_d = slots.subTitle) === null || _d === void 0 ? void 0 : _d.call(slots);
  90. const icon = (_e = props.icon) !== null && _e !== void 0 ? _e : (_f = slots.icon) === null || _f === void 0 ? void 0 : _f.call(slots);
  91. const extra = (_g = props.extra) !== null && _g !== void 0 ? _g : (_h = slots.extra) === null || _h === void 0 ? void 0 : _h.call(slots);
  92. const pre = prefixCls.value;
  93. return wrapSSR((0, _vue.createVNode)("div", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), {}, {
  94. "class": [className.value, attrs.class]
  95. }), [renderIcon(pre, {
  96. status: props.status,
  97. icon
  98. }), (0, _vue.createVNode)("div", {
  99. "class": `${pre}-title`
  100. }, [title]), subTitle && (0, _vue.createVNode)("div", {
  101. "class": `${pre}-subtitle`
  102. }, [subTitle]), renderExtra(pre, extra), slots.default && (0, _vue.createVNode)("div", {
  103. "class": `${pre}-content`
  104. }, [slots.default()])]));
  105. };
  106. }
  107. });
  108. /* add resource */
  109. Result.PRESENTED_IMAGE_403 = ExceptionMap[403];
  110. Result.PRESENTED_IMAGE_404 = ExceptionMap[404];
  111. Result.PRESENTED_IMAGE_500 = ExceptionMap[500];
  112. /* istanbul ignore next */
  113. Result.install = function (app) {
  114. app.component(Result.name, Result);
  115. return app;
  116. };
  117. var _default = exports.default = Result;