index.js 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
  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 _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
  19. var _classNames2 = _interopRequireDefault(require("../_util/classNames"));
  20. var _vcResizeObserver = _interopRequireDefault(require("../vc-resize-observer"));
  21. var _useDestroyed = _interopRequireDefault(require("../_util/hooks/useDestroyed"));
  22. var pageHeaderProps = function pageHeaderProps() {
  23. return {
  24. backIcon: _vueTypes.default.any,
  25. prefixCls: String,
  26. title: _vueTypes.default.any,
  27. subTitle: _vueTypes.default.any,
  28. breadcrumb: _vueTypes.default.object,
  29. tags: _vueTypes.default.any,
  30. footer: _vueTypes.default.any,
  31. extra: _vueTypes.default.any,
  32. avatar: _vueTypes.default.object,
  33. ghost: {
  34. type: Boolean,
  35. default: undefined
  36. },
  37. onBack: Function
  38. };
  39. };
  40. exports.pageHeaderProps = pageHeaderProps;
  41. var PageHeader = (0, _vue.defineComponent)({
  42. compatConfig: {
  43. MODE: 3
  44. },
  45. name: 'APageHeader',
  46. props: pageHeaderProps(),
  47. // emits: ['back'],
  48. slots: ['backIcon', 'avatar', 'breadcrumb', 'title', 'subTitle', 'tags', 'extra', 'footer'],
  49. setup: function setup(props, _ref) {
  50. var emit = _ref.emit,
  51. slots = _ref.slots;
  52. var _useConfigInject = (0, _useConfigInject2.default)('page-header', props),
  53. prefixCls = _useConfigInject.prefixCls,
  54. direction = _useConfigInject.direction,
  55. pageHeader = _useConfigInject.pageHeader;
  56. var compact = (0, _vue.ref)(false);
  57. var isDestroyed = (0, _useDestroyed.default)();
  58. var onResize = function onResize(_ref2) {
  59. var width = _ref2.width;
  60. if (!isDestroyed.value) {
  61. compact.value = width < 768;
  62. }
  63. };
  64. var ghost = (0, _vue.computed)(function () {
  65. var _ref3, _props$ghost, _pageHeader$value;
  66. return (_ref3 = (_props$ghost = props.ghost) !== null && _props$ghost !== void 0 ? _props$ghost : (_pageHeader$value = pageHeader.value) === null || _pageHeader$value === void 0 ? void 0 : _pageHeader$value.ghost) !== null && _ref3 !== void 0 ? _ref3 : true;
  67. });
  68. var getBackIcon = function getBackIcon() {
  69. var _ref4, _props$backIcon, _slots$backIcon;
  70. return (_ref4 = (_props$backIcon = props.backIcon) !== null && _props$backIcon !== void 0 ? _props$backIcon : (_slots$backIcon = slots.backIcon) === null || _slots$backIcon === void 0 ? void 0 : _slots$backIcon.call(slots)) !== null && _ref4 !== void 0 ? _ref4 : direction.value === 'rtl' ? (0, _vue.createVNode)(_ArrowRightOutlined.default, null, null) : (0, _vue.createVNode)(_ArrowLeftOutlined.default, null, null);
  71. };
  72. var renderBack = function renderBack(backIcon) {
  73. if (!backIcon || !props.onBack) {
  74. return null;
  75. }
  76. return (0, _vue.createVNode)(_LocaleReceiver.default, {
  77. "componentName": "PageHeader",
  78. "children": function children(_ref5) {
  79. var back = _ref5.back;
  80. return (0, _vue.createVNode)("div", {
  81. "class": "".concat(prefixCls.value, "-back")
  82. }, [(0, _vue.createVNode)(_transButton.default, {
  83. "onClick": function onClick(e) {
  84. emit('back', e);
  85. },
  86. "class": "".concat(prefixCls.value, "-back-button"),
  87. "aria-label": back
  88. }, {
  89. default: function _default() {
  90. return [backIcon];
  91. }
  92. })]);
  93. }
  94. }, null);
  95. };
  96. var renderBreadcrumb = function renderBreadcrumb() {
  97. var _slots$breadcrumb;
  98. return props.breadcrumb ? (0, _vue.createVNode)(_breadcrumb.default, props.breadcrumb, null) : (_slots$breadcrumb = slots.breadcrumb) === null || _slots$breadcrumb === void 0 ? void 0 : _slots$breadcrumb.call(slots);
  99. };
  100. var renderTitle = function renderTitle() {
  101. var _props$title, _slots$title, _props$subTitle, _slots$subTitle, _props$tags, _slots$tags, _props$extra, _slots$extra, _slots$avatar;
  102. var avatar = props.avatar;
  103. var title = (_props$title = props.title) !== null && _props$title !== void 0 ? _props$title : (_slots$title = slots.title) === null || _slots$title === void 0 ? void 0 : _slots$title.call(slots);
  104. var subTitle = (_props$subTitle = props.subTitle) !== null && _props$subTitle !== void 0 ? _props$subTitle : (_slots$subTitle = slots.subTitle) === null || _slots$subTitle === void 0 ? void 0 : _slots$subTitle.call(slots);
  105. var tags = (_props$tags = props.tags) !== null && _props$tags !== void 0 ? _props$tags : (_slots$tags = slots.tags) === null || _slots$tags === void 0 ? void 0 : _slots$tags.call(slots);
  106. var extra = (_props$extra = props.extra) !== null && _props$extra !== void 0 ? _props$extra : (_slots$extra = slots.extra) === null || _slots$extra === void 0 ? void 0 : _slots$extra.call(slots);
  107. var headingPrefixCls = "".concat(prefixCls.value, "-heading");
  108. var hasHeading = title || subTitle || tags || extra;
  109. // If there is nothing, return a null
  110. if (!hasHeading) {
  111. return null;
  112. }
  113. var backIcon = getBackIcon();
  114. var backIconDom = renderBack(backIcon);
  115. var hasTitle = backIconDom || avatar || hasHeading;
  116. return (0, _vue.createVNode)("div", {
  117. "class": headingPrefixCls
  118. }, [hasTitle && (0, _vue.createVNode)("div", {
  119. "class": "".concat(headingPrefixCls, "-left")
  120. }, [backIconDom, avatar ? (0, _vue.createVNode)(_avatar.default, avatar, null) : (_slots$avatar = slots.avatar) === null || _slots$avatar === void 0 ? void 0 : _slots$avatar.call(slots), title && (0, _vue.createVNode)("span", {
  121. "class": "".concat(headingPrefixCls, "-title"),
  122. "title": typeof title === 'string' ? title : undefined
  123. }, [title]), subTitle && (0, _vue.createVNode)("span", {
  124. "class": "".concat(headingPrefixCls, "-sub-title"),
  125. "title": typeof subTitle === 'string' ? subTitle : undefined
  126. }, [subTitle]), tags && (0, _vue.createVNode)("span", {
  127. "class": "".concat(headingPrefixCls, "-tags")
  128. }, [tags])]), extra && (0, _vue.createVNode)("span", {
  129. "class": "".concat(headingPrefixCls, "-extra")
  130. }, [extra])]);
  131. };
  132. var renderFooter = function renderFooter() {
  133. var _props$footer, _slots$footer;
  134. var footer = (_props$footer = props.footer) !== null && _props$footer !== void 0 ? _props$footer : (0, _propsUtil.filterEmpty)((_slots$footer = slots.footer) === null || _slots$footer === void 0 ? void 0 : _slots$footer.call(slots));
  135. return (0, _propsUtil.isEmptyContent)(footer) ? null : (0, _vue.createVNode)("div", {
  136. "class": "".concat(prefixCls.value, "-footer")
  137. }, [footer]);
  138. };
  139. var renderChildren = function renderChildren(children) {
  140. return (0, _vue.createVNode)("div", {
  141. "class": "".concat(prefixCls.value, "-content")
  142. }, [children]);
  143. };
  144. return function () {
  145. var _props$breadcrumb, _slots$default, _classNames;
  146. var hasBreadcrumb = ((_props$breadcrumb = props.breadcrumb) === null || _props$breadcrumb === void 0 ? void 0 : _props$breadcrumb.routes) || slots.breadcrumb;
  147. var hasFooter = props.footer || slots.footer;
  148. var children = (0, _propsUtil.flattenChildren)((_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots));
  149. var className = (0, _classNames2.default)(prefixCls.value, (_classNames = {
  150. 'has-breadcrumb': hasBreadcrumb,
  151. 'has-footer': hasFooter
  152. }, (0, _defineProperty2.default)(_classNames, "".concat(prefixCls.value, "-ghost"), ghost.value), (0, _defineProperty2.default)(_classNames, "".concat(prefixCls.value, "-rtl"), direction.value === 'rtl'), (0, _defineProperty2.default)(_classNames, "".concat(prefixCls.value, "-compact"), compact.value), _classNames));
  153. return (0, _vue.createVNode)(_vcResizeObserver.default, {
  154. "onResize": onResize
  155. }, {
  156. default: function _default() {
  157. return [(0, _vue.createVNode)("div", {
  158. "class": className
  159. }, [renderBreadcrumb(), renderTitle(), children.length ? renderChildren(children) : null, renderFooter()])];
  160. }
  161. });
  162. };
  163. }
  164. });
  165. var _default2 = (0, _type.withInstall)(PageHeader);
  166. exports.default = _default2;