You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

184 lines
11 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

"use strict";
function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _umi = require("umi");
var _proLayout = _interopRequireDefault(require("@ant-design/pro-layout"));
require("./style.less");
var _ErrorBoundary = _interopRequireDefault(require("../component/ErrorBoundary"));
var _renderRightContent = _interopRequireDefault(require("./renderRightContent"));
var _Exception = require("../component/Exception");
var _routeUtils = require("@umijs/route-utils");
var _logo = _interopRequireDefault(require("../assets/logo.svg"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (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; }
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
var getLayoutRender = function getLayoutRender(currentPathConfig) {
var _currentPathConfig$la, _currentPathConfig$la2, _currentPathConfig$la3;
var layoutRender = {};
if (currentPathConfig === null || currentPathConfig === void 0 ? void 0 : currentPathConfig.hideFooter) {
layoutRender.footerRender = false;
}
if ((currentPathConfig === null || currentPathConfig === void 0 ? void 0 : currentPathConfig.layout) == false) {
layoutRender.pure = true;
return layoutRender;
}
if (currentPathConfig === null || currentPathConfig === void 0 ? void 0 : (_currentPathConfig$la = currentPathConfig.layout) === null || _currentPathConfig$la === void 0 ? void 0 : _currentPathConfig$la.hideMenu) {
layoutRender.menuRender = false;
}
if (currentPathConfig === null || currentPathConfig === void 0 ? void 0 : (_currentPathConfig$la2 = currentPathConfig.layout) === null || _currentPathConfig$la2 === void 0 ? void 0 : _currentPathConfig$la2.hideFooter) {
layoutRender.footerRender = false;
}
if (currentPathConfig === null || currentPathConfig === void 0 ? void 0 : (_currentPathConfig$la3 = currentPathConfig.layout) === null || _currentPathConfig$la3 === void 0 ? void 0 : _currentPathConfig$la3.hideNav) {
layoutRender.headerRender = false;
}
return layoutRender;
};
var BasicLayout = function BasicLayout(props) {
var children = props.children,
userConfig = props.userConfig,
location = props.location,
route = props.route,
restProps = _objectWithoutProperties(props, ["children", "userConfig", "location", "route"]);
var initialInfo = _umi.useModel && (0, _umi.useModel)('@@initialState') || {
initialState: undefined,
loading: false,
setInitialState: null
}; // plugin-initial-state 未开启
var initialState = initialInfo.initialState,
loading = initialInfo.loading,
setInitialState = initialInfo.setInitialState; // 国际化插件并非默认启动
var intl = _umi.useIntl && (0, _umi.useIntl)();
var _useState = (0, _react.useState)({}),
_useState2 = _slicedToArray(_useState, 2),
currentPathConfig = _useState2[0],
setCurrentPathConfig = _useState2[1];
(0, _react.useEffect)(function () {
var _props$route;
var _transformRoute = (0, _routeUtils.transformRoute)((props === null || props === void 0 ? void 0 : (_props$route = props.route) === null || _props$route === void 0 ? void 0 : _props$route.routes) || [], undefined, undefined, true),
menuData = _transformRoute.menuData; // 动态路由匹配
var currentPathConfig = (0, _routeUtils.getMatchMenu)(location.pathname, menuData).pop();
setCurrentPathConfig(currentPathConfig || {});
}, [location.pathname]); // layout 是否渲染相关
var layoutRestProps = _objectSpread({}, userConfig, {}, restProps, {}, getLayoutRender(currentPathConfig));
return /*#__PURE__*/_react.default.createElement(_proLayout.default, _extends({
route: route,
location: location,
title: userConfig.name || userConfig.title,
className: "umi-plugin-layout-main",
navTheme: "dark",
siderWidth: 256,
onMenuHeaderClick: function onMenuHeaderClick(e) {
e.stopPropagation();
e.preventDefault();
_umi.history.push('/');
},
menu: {
locale: userConfig.locale
} // 支持了一个 patchMenus其实应该用 menuDataRender
,
menuDataRender: userConfig.patchMenus ? function (menuData) {
return userConfig.patchMenus(menuData, initialInfo);
} : undefined,
formatMessage: intl && intl.formatMessage,
logo: _logo.default,
menuItemRender: function menuItemRender(menuItemProps, defaultDom) {
if (menuItemProps.isUrl || menuItemProps.children) {
return defaultDom;
}
if (menuItemProps.path) {
return /*#__PURE__*/_react.default.createElement(_umi.Link, {
to: menuItemProps.path
}, defaultDom);
}
return defaultDom;
},
disableContentMargin: true,
fixSiderbar: true,
fixedHeader: true
}, layoutRestProps, {
rightContentRender: // === false 应该关闭这个功能
(layoutRestProps === null || layoutRestProps === void 0 ? void 0 : layoutRestProps.rightContentRender) !== false && function (layoutProps) {
var dom = (0, _renderRightContent.default)(userConfig, loading, initialState, setInitialState);
if (layoutRestProps.rightContentRender) {
return layoutRestProps.rightContentRender(layoutProps, dom, {
userConfig: userConfig,
loading: loading,
initialState: initialState,
setInitialState: setInitialState
});
}
return dom;
}
}), /*#__PURE__*/_react.default.createElement(_ErrorBoundary.default, null, /*#__PURE__*/_react.default.createElement(_Exception.WithExceptionOpChildren, {
currentPathConfig: currentPathConfig
}, userConfig.childrenRender ? userConfig.childrenRender(children) : children)));
};
var _default = BasicLayout;
exports.default = _default;