UNPKG

4.67 kBJavaScriptView Raw
1"use strict";
2
3function _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); }
4
5Object.defineProperty(exports, "__esModule", {
6 value: true
7});
8exports.default = MaybeChildMenu;
9
10var React = _interopRequireWildcard(require("react"));
11
12var _nestedMenus = require("./nested-menus.js");
13
14var _index = require("../popover/index.js");
15
16var _overrides = require("../helpers/overrides.js");
17
18function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
19
20function _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; }
21
22function _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); }
23
24function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }
25
26function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance"); }
27
28function _iterableToArrayLimit(arr, i) { if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === "[object Arguments]")) { 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; }
29
30function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
31
32function MaybeChildMenu(props) {
33 if (!props.getChildMenu) {
34 return props.children;
35 }
36
37 var ChildMenu = props.getChildMenu(props.item);
38
39 if (!ChildMenu) {
40 return props.children;
41 }
42
43 var _props$overrides = props.overrides,
44 overrides = _props$overrides === void 0 ? {} : _props$overrides;
45
46 var _getOverrides = (0, _overrides.getOverrides)(overrides.ChildMenuPopover, _index.Popover),
47 _getOverrides2 = _slicedToArray(_getOverrides, 2),
48 PopoverOverride = _getOverrides2[0],
49 popoverProps = _getOverrides2[1];
50
51 return React.createElement(_nestedMenus.NestedMenuContext.Consumer, null, function (ctx) {
52 return React.createElement(PopoverOverride, _extends({
53 focusLock: false,
54 isOpen: props.isOpen,
55 renderAll: props.renderAll,
56 content: ChildMenu,
57 ignoreBoundary: true,
58 mountNode: ctx.mountRef.current ? ctx.mountRef.current : undefined,
59 onMouseEnterDelay: 30,
60 onMouseLeaveDelay: 30,
61 onEsc: props.resetParentMenu,
62 placement: "rightTop"
63 }, popoverProps, {
64 overrides: (0, _overrides.mergeOverrides)({
65 Body: {
66 props: {
67 // Adds mouseleave to popover body so that child menu closes when user mouses out.
68 onMouseLeave: props.resetParentMenu,
69 // Trap tabbing when focused on a child menu. Popover mounts the element at the end of
70 // the html body by default. If a user was to tab to the next element it would navigate
71 // to elements not within the immediate area surrounding the menu.
72 onKeyDown: function onKeyDown(e) {
73 if (e.keyCode === 9) {
74 e.preventDefault();
75 }
76 }
77 }
78 }
79 }, // $FlowFixMe - getOverrides' return type for props is {}
80 popoverProps.overrides)
81 }), props.children);
82 });
83}
\No newline at end of file