index.js 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.pageHeaderProps = exports.default = 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 _propsUtil = require("../_util/props-util");
  11. var _ArrowLeftOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/ArrowLeftOutlined"));
  12. var _ArrowRightOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/ArrowRightOutlined"));
  13. var _breadcrumb = _interopRequireDefault(require("../breadcrumb"));
  14. var _avatar = _interopRequireDefault(require("../avatar"));
  15. var _transButton = _interopRequireDefault(require("../_util/transButton"));
  16. var _LocaleReceiver = _interopRequireDefault(require("../locale-provider/LocaleReceiver"));
  17. var _type = require("../_util/type");
  18. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  19. var _classNames = _interopRequireDefault(require("../_util/classNames"));
  20. var _vcResizeObserver = _interopRequireDefault(require("../vc-resize-observer"));
  21. var _useDestroyed = _interopRequireDefault(require("../_util/hooks/useDestroyed"));
  22. var _space = _interopRequireDefault(require("../space"));
  23. var _style = _interopRequireDefault(require("./style"));
  24. // CSSINJS
  25. const pageHeaderProps = () => ({
  26. backIcon: (0, _type.vNodeType)(),
  27. prefixCls: String,
  28. title: (0, _type.vNodeType)(),
  29. subTitle: (0, _type.vNodeType)(),
  30. breadcrumb: _vueTypes.default.object,
  31. tags: (0, _type.vNodeType)(),
  32. footer: (0, _type.vNodeType)(),
  33. extra: (0, _type.vNodeType)(),
  34. avatar: (0, _type.objectType)(),
  35. ghost: {
  36. type: Boolean,
  37. default: undefined
  38. },
  39. onBack: Function
  40. });
  41. exports.pageHeaderProps = pageHeaderProps;
  42. const PageHeader = (0, _vue.defineComponent)({
  43. compatConfig: {
  44. MODE: 3
  45. },
  46. name: 'APageHeader',
  47. inheritAttrs: false,
  48. props: pageHeaderProps(),
  49. // emits: ['back'],
  50. slots: Object,
  51. setup(props, _ref) {
  52. let {
  53. emit,
  54. slots,
  55. attrs
  56. } = _ref;
  57. const {
  58. prefixCls,
  59. direction,
  60. pageHeader
  61. } = (0, _useConfigInject.default)('page-header', props);
  62. // style
  63. const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
  64. const compact = (0, _vue.shallowRef)(false);
  65. const isDestroyed = (0, _useDestroyed.default)();
  66. const onResize = _ref2 => {
  67. let {
  68. width
  69. } = _ref2;
  70. if (!isDestroyed.value) {
  71. compact.value = width < 768;
  72. }
  73. };
  74. const ghost = (0, _vue.computed)(() => {
  75. var _a, _b, _c;
  76. return (_c = (_a = props.ghost) !== null && _a !== void 0 ? _a : (_b = pageHeader === null || pageHeader === void 0 ? void 0 : pageHeader.value) === null || _b === void 0 ? void 0 : _b.ghost) !== null && _c !== void 0 ? _c : true;
  77. });
  78. const getBackIcon = () => {
  79. var _a, _b, _c;
  80. return (_c = (_a = props.backIcon) !== null && _a !== void 0 ? _a : (_b = slots.backIcon) === null || _b === void 0 ? void 0 : _b.call(slots)) !== null && _c !== void 0 ? _c : direction.value === 'rtl' ? (0, _vue.createVNode)(_ArrowRightOutlined.default, null, null) : (0, _vue.createVNode)(_ArrowLeftOutlined.default, null, null);
  81. };
  82. const renderBack = backIcon => {
  83. if (!backIcon || !props.onBack) {
  84. return null;
  85. }
  86. return (0, _vue.createVNode)(_LocaleReceiver.default, {
  87. "componentName": "PageHeader",
  88. "children": _ref3 => {
  89. let {
  90. back
  91. } = _ref3;
  92. return (0, _vue.createVNode)("div", {
  93. "class": `${prefixCls.value}-back`
  94. }, [(0, _vue.createVNode)(_transButton.default, {
  95. "onClick": e => {
  96. emit('back', e);
  97. },
  98. "class": `${prefixCls.value}-back-button`,
  99. "aria-label": back
  100. }, {
  101. default: () => [backIcon]
  102. })]);
  103. }
  104. }, null);
  105. };
  106. const renderBreadcrumb = () => {
  107. var _a;
  108. return props.breadcrumb ? (0, _vue.createVNode)(_breadcrumb.default, props.breadcrumb, null) : (_a = slots.breadcrumb) === null || _a === void 0 ? void 0 : _a.call(slots);
  109. };
  110. const renderTitle = () => {
  111. var _a, _b, _c, _d, _e, _f, _g, _h, _j;
  112. const {
  113. avatar
  114. } = props;
  115. const title = (_a = props.title) !== null && _a !== void 0 ? _a : (_b = slots.title) === null || _b === void 0 ? void 0 : _b.call(slots);
  116. const subTitle = (_c = props.subTitle) !== null && _c !== void 0 ? _c : (_d = slots.subTitle) === null || _d === void 0 ? void 0 : _d.call(slots);
  117. const tags = (_e = props.tags) !== null && _e !== void 0 ? _e : (_f = slots.tags) === null || _f === void 0 ? void 0 : _f.call(slots);
  118. const extra = (_g = props.extra) !== null && _g !== void 0 ? _g : (_h = slots.extra) === null || _h === void 0 ? void 0 : _h.call(slots);
  119. const headingPrefixCls = `${prefixCls.value}-heading`;
  120. const hasHeading = title || subTitle || tags || extra;
  121. // If there is nothing, return a null
  122. if (!hasHeading) {
  123. return null;
  124. }
  125. const backIcon = getBackIcon();
  126. const backIconDom = renderBack(backIcon);
  127. const hasTitle = backIconDom || avatar || hasHeading;
  128. return (0, _vue.createVNode)("div", {
  129. "class": headingPrefixCls
  130. }, [hasTitle && (0, _vue.createVNode)("div", {
  131. "class": `${headingPrefixCls}-left`
  132. }, [backIconDom, avatar ? (0, _vue.createVNode)(_avatar.default, avatar, null) : (_j = slots.avatar) === null || _j === void 0 ? void 0 : _j.call(slots), title && (0, _vue.createVNode)("span", {
  133. "class": `${headingPrefixCls}-title`,
  134. "title": typeof title === 'string' ? title : undefined
  135. }, [title]), subTitle && (0, _vue.createVNode)("span", {
  136. "class": `${headingPrefixCls}-sub-title`,
  137. "title": typeof subTitle === 'string' ? subTitle : undefined
  138. }, [subTitle]), tags && (0, _vue.createVNode)("span", {
  139. "class": `${headingPrefixCls}-tags`
  140. }, [tags])]), extra && (0, _vue.createVNode)("span", {
  141. "class": `${headingPrefixCls}-extra`
  142. }, [(0, _vue.createVNode)(_space.default, null, {
  143. default: () => [extra]
  144. })])]);
  145. };
  146. const renderFooter = () => {
  147. var _a, _b;
  148. const footer = (_a = props.footer) !== null && _a !== void 0 ? _a : (0, _propsUtil.filterEmpty)((_b = slots.footer) === null || _b === void 0 ? void 0 : _b.call(slots));
  149. return (0, _propsUtil.isEmptyContent)(footer) ? null : (0, _vue.createVNode)("div", {
  150. "class": `${prefixCls.value}-footer`
  151. }, [footer]);
  152. };
  153. const renderChildren = children => {
  154. return (0, _vue.createVNode)("div", {
  155. "class": `${prefixCls.value}-content`
  156. }, [children]);
  157. };
  158. return () => {
  159. var _a, _b;
  160. const hasBreadcrumb = ((_a = props.breadcrumb) === null || _a === void 0 ? void 0 : _a.routes) || slots.breadcrumb;
  161. const hasFooter = props.footer || slots.footer;
  162. const children = (0, _propsUtil.flattenChildren)((_b = slots.default) === null || _b === void 0 ? void 0 : _b.call(slots));
  163. const className = (0, _classNames.default)(prefixCls.value, {
  164. 'has-breadcrumb': hasBreadcrumb,
  165. 'has-footer': hasFooter,
  166. [`${prefixCls.value}-ghost`]: ghost.value,
  167. [`${prefixCls.value}-rtl`]: direction.value === 'rtl',
  168. [`${prefixCls.value}-compact`]: compact.value
  169. }, attrs.class, hashId.value);
  170. return wrapSSR((0, _vue.createVNode)(_vcResizeObserver.default, {
  171. "onResize": onResize
  172. }, {
  173. default: () => [(0, _vue.createVNode)("div", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), {}, {
  174. "class": className
  175. }), [renderBreadcrumb(), renderTitle(), children.length ? renderChildren(children) : null, renderFooter()])]
  176. }));
  177. };
  178. }
  179. });
  180. var _default = exports.default = (0, _type.withInstall)(PageHeader);