index.js 8.1 KB

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