1 | "use strict";
|
2 |
|
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4 |
|
5 | var _typeof = require("@babel/runtime/helpers/typeof");
|
6 |
|
7 | Object.defineProperty(exports, "__esModule", {
|
8 | value: true
|
9 | });
|
10 | exports["default"] = void 0;
|
11 |
|
12 | var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
13 |
|
14 | var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
15 |
|
16 | var React = _interopRequireWildcard(require("react"));
|
17 |
|
18 | var _classnames = _interopRequireDefault(require("classnames"));
|
19 |
|
20 | var _ArrowLeftOutlined = _interopRequireDefault(require("@ant-design/icons/ArrowLeftOutlined"));
|
21 |
|
22 | var _ArrowRightOutlined = _interopRequireDefault(require("@ant-design/icons/ArrowRightOutlined"));
|
23 |
|
24 | var _rcResizeObserver = _interopRequireDefault(require("rc-resize-observer"));
|
25 |
|
26 | var _configProvider = require("../config-provider");
|
27 |
|
28 | var _breadcrumb = _interopRequireDefault(require("../breadcrumb"));
|
29 |
|
30 | var _avatar = _interopRequireDefault(require("../avatar"));
|
31 |
|
32 | var _transButton = _interopRequireDefault(require("../_util/transButton"));
|
33 |
|
34 | var _LocaleReceiver = _interopRequireDefault(require("../locale-provider/LocaleReceiver"));
|
35 |
|
36 | function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
37 |
|
38 | function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
39 |
|
40 | var renderBack = function renderBack(prefixCls, backIcon, onBack) {
|
41 | if (!backIcon || !onBack) {
|
42 | return null;
|
43 | }
|
44 |
|
45 | return React.createElement(_LocaleReceiver["default"], {
|
46 | componentName: "PageHeader"
|
47 | }, function (_ref) {
|
48 | var back = _ref.back;
|
49 | return React.createElement("div", {
|
50 | className: "".concat(prefixCls, "-back")
|
51 | }, React.createElement(_transButton["default"], {
|
52 | onClick: function onClick(e) {
|
53 | onBack === null || onBack === void 0 ? void 0 : onBack(e);
|
54 | },
|
55 | className: "".concat(prefixCls, "-back-button"),
|
56 | "aria-label": back
|
57 | }, backIcon));
|
58 | });
|
59 | };
|
60 |
|
61 | var renderBreadcrumb = function renderBreadcrumb(breadcrumb) {
|
62 | return React.createElement(_breadcrumb["default"], breadcrumb);
|
63 | };
|
64 |
|
65 | var getBackIcon = function getBackIcon(props) {
|
66 | var direction = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'ltr';
|
67 |
|
68 | if (props.backIcon !== undefined) {
|
69 | return props.backIcon;
|
70 | }
|
71 |
|
72 | return direction === 'rtl' ? React.createElement(_ArrowRightOutlined["default"], null) : React.createElement(_ArrowLeftOutlined["default"], null);
|
73 | };
|
74 |
|
75 | var renderTitle = function renderTitle(prefixCls, props) {
|
76 | var direction = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'ltr';
|
77 | var title = props.title,
|
78 | avatar = props.avatar,
|
79 | subTitle = props.subTitle,
|
80 | tags = props.tags,
|
81 | extra = props.extra,
|
82 | onBack = props.onBack;
|
83 | var headingPrefixCls = "".concat(prefixCls, "-heading");
|
84 | var hasHeading = title || subTitle || tags || extra;
|
85 |
|
86 | if (!hasHeading) {
|
87 | return null;
|
88 | }
|
89 |
|
90 | var backIcon = getBackIcon(props, direction);
|
91 | var backIconDom = renderBack(prefixCls, backIcon, onBack);
|
92 | var hasTitle = backIconDom || avatar || hasHeading;
|
93 | return React.createElement("div", {
|
94 | className: headingPrefixCls
|
95 | }, hasTitle && React.createElement("div", {
|
96 | className: "".concat(headingPrefixCls, "-left")
|
97 | }, backIconDom, avatar && React.createElement(_avatar["default"], avatar), title && React.createElement("span", {
|
98 | className: "".concat(headingPrefixCls, "-title"),
|
99 | title: typeof title === 'string' ? title : undefined
|
100 | }, title), subTitle && React.createElement("span", {
|
101 | className: "".concat(headingPrefixCls, "-sub-title"),
|
102 | title: typeof subTitle === 'string' ? subTitle : undefined
|
103 | }, subTitle), tags && React.createElement("span", {
|
104 | className: "".concat(headingPrefixCls, "-tags")
|
105 | }, tags)), extra && React.createElement("span", {
|
106 | className: "".concat(headingPrefixCls, "-extra")
|
107 | }, extra));
|
108 | };
|
109 |
|
110 | var renderFooter = function renderFooter(prefixCls, footer) {
|
111 | if (footer) {
|
112 | return React.createElement("div", {
|
113 | className: "".concat(prefixCls, "-footer")
|
114 | }, footer);
|
115 | }
|
116 |
|
117 | return null;
|
118 | };
|
119 |
|
120 | var renderChildren = function renderChildren(prefixCls, children) {
|
121 | return React.createElement("div", {
|
122 | className: "".concat(prefixCls, "-content")
|
123 | }, children);
|
124 | };
|
125 |
|
126 | var PageHeader = function PageHeader(props) {
|
127 | var _React$useState = React.useState(false),
|
128 | _React$useState2 = (0, _slicedToArray2["default"])(_React$useState, 2),
|
129 | compact = _React$useState2[0],
|
130 | updateCompact = _React$useState2[1];
|
131 |
|
132 | var onResize = function onResize(_ref2) {
|
133 | var width = _ref2.width;
|
134 | updateCompact(width < 768);
|
135 | };
|
136 |
|
137 | return React.createElement(_configProvider.ConfigConsumer, null, function (_ref3) {
|
138 | var _classNames;
|
139 |
|
140 | var getPrefixCls = _ref3.getPrefixCls,
|
141 | pageHeader = _ref3.pageHeader,
|
142 | direction = _ref3.direction;
|
143 | var customizePrefixCls = props.prefixCls,
|
144 | style = props.style,
|
145 | footer = props.footer,
|
146 | children = props.children,
|
147 | breadcrumb = props.breadcrumb,
|
148 | breadcrumbRender = props.breadcrumbRender,
|
149 | customizeClassName = props.className;
|
150 | var ghost = true;
|
151 |
|
152 | if ('ghost' in props) {
|
153 | ghost = props.ghost;
|
154 | } else if (pageHeader && 'ghost' in pageHeader) {
|
155 | ghost = pageHeader.ghost;
|
156 | }
|
157 |
|
158 | var prefixCls = getPrefixCls('page-header', customizePrefixCls);
|
159 |
|
160 | var getDefaultBreadcrumbDom = function getDefaultBreadcrumbDom() {
|
161 | var _a;
|
162 |
|
163 | if ((_a = breadcrumb) === null || _a === void 0 ? void 0 : _a.routes) {
|
164 | return renderBreadcrumb(breadcrumb);
|
165 | }
|
166 |
|
167 | return null;
|
168 | };
|
169 |
|
170 | var defaultBreadcrumbDom = getDefaultBreadcrumbDom();
|
171 | var isBreadcrumbComponent = breadcrumb && 'props' in breadcrumb;
|
172 |
|
173 | var breadcrumbRenderDomFromProps = (breadcrumbRender === null || breadcrumbRender === void 0 ? void 0 : breadcrumbRender(props, defaultBreadcrumbDom)) || defaultBreadcrumbDom;
|
174 | var breadcrumbDom = isBreadcrumbComponent ? breadcrumb : breadcrumbRenderDomFromProps;
|
175 | var className = (0, _classnames["default"])(prefixCls, customizeClassName, (_classNames = {
|
176 | 'has-breadcrumb': !!breadcrumbDom,
|
177 | 'has-footer': !!footer
|
178 | }, (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-ghost"), ghost), (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-rtl"), direction === 'rtl'), (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-compact"), compact), _classNames));
|
179 | return React.createElement(_rcResizeObserver["default"], {
|
180 | onResize: onResize
|
181 | }, React.createElement("div", {
|
182 | className: className,
|
183 | style: style
|
184 | }, breadcrumbDom, renderTitle(prefixCls, props, direction), children && renderChildren(prefixCls, children), renderFooter(prefixCls, footer)));
|
185 | });
|
186 | };
|
187 |
|
188 | var _default = PageHeader;
|
189 | exports["default"] = _default; |
\ | No newline at end of file |