@ant-design/pro-layout
Version:
119 lines (94 loc) • 4.57 kB
JavaScript
"use strict";
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
require("antd/es/config-provider/style");
var _configProvider = _interopRequireDefault(require("antd/es/config-provider"));
require("./index.less");
var _react = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _SiderMenu = require("../SiderMenu/SiderMenu");
var _TopNavHeader = _interopRequireDefault(require("../TopNavHeader"));
var _utils = require("../../utils/utils");
var renderLogo = function renderLogo(menuHeaderRender, logoDom) {
if (menuHeaderRender === false) {
return null;
}
if (menuHeaderRender) {
return menuHeaderRender(logoDom, null);
}
return logoDom;
};
var GlobalHeader = function GlobalHeader(props) {
var isMobile = props.isMobile,
logo = props.logo,
collapsed = props.collapsed,
onCollapse = props.onCollapse,
_props$collapsedButto = props.collapsedButtonRender,
collapsedButtonRender = _props$collapsedButto === void 0 ? _SiderMenu.defaultRenderCollapsedButton : _props$collapsedButto,
rightContentRender = props.rightContentRender,
menuHeaderRender = props.menuHeaderRender,
onMenuHeaderClick = props.onMenuHeaderClick,
propClassName = props.className,
style = props.style,
layout = props.layout,
children = props.children,
_props$headerTheme = props.headerTheme,
headerTheme = _props$headerTheme === void 0 ? 'dark' : _props$headerTheme,
splitMenus = props.splitMenus,
menuData = props.menuData,
prefixCls = props.prefixCls;
var _useContext = (0, _react.useContext)(_configProvider.default.ConfigContext),
direction = _useContext.direction;
var baseClassName = "".concat(prefixCls, "-global-header");
var className = (0, _classnames.default)(propClassName, baseClassName, (0, _defineProperty2.default)({}, "".concat(baseClassName, "-layout-").concat(layout), layout && headerTheme === 'dark'));
if (layout === 'mix' && !isMobile && splitMenus) {
var noChildrenMenuData = (menuData || []).map(function (item) {
return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, item), {}, {
children: undefined,
routes: undefined
});
});
var clearMenuData = (0, _utils.clearMenuItem)(noChildrenMenuData);
return /*#__PURE__*/_react.default.createElement(_TopNavHeader.default, (0, _extends2.default)({
mode: "horizontal"
}, props, {
splitMenus: false,
menuData: clearMenuData,
theme: headerTheme
}));
}
var logoClassNames = (0, _classnames.default)("".concat(baseClassName, "-logo"), (0, _defineProperty2.default)({}, "".concat(baseClassName, "-logo-rtl"), direction === 'rtl'));
var logoDom = /*#__PURE__*/_react.default.createElement("span", {
className: logoClassNames,
key: "logo"
}, /*#__PURE__*/_react.default.createElement("a", null, (0, _SiderMenu.defaultRenderLogo)(logo)));
return /*#__PURE__*/_react.default.createElement("div", {
className: className,
style: (0, _objectSpread2.default)({}, style)
}, isMobile && renderLogo(menuHeaderRender, logoDom), isMobile && collapsedButtonRender && /*#__PURE__*/_react.default.createElement("span", {
className: "".concat(baseClassName, "-collapsed-button"),
onClick: function onClick() {
if (onCollapse) {
onCollapse(!collapsed);
}
}
}, collapsedButtonRender(collapsed)), layout === 'mix' && !isMobile && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
className: logoClassNames,
onClick: onMenuHeaderClick
}, (0, _SiderMenu.defaultRenderLogoAndTitle)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, props), {}, {
collapsed: false
}), 'headerTitleRender'))), /*#__PURE__*/_react.default.createElement("div", {
style: {
flex: 1
}
}, children), rightContentRender && rightContentRender(props));
};
var _default = GlobalHeader;
exports.default = _default;