@elliemae/ds-menu 2.2.1 → 2.3.0-alpha.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/cjs/DSMenu.js +127 -0
  2. package/cjs/DSMenu.js.map +7 -0
  3. package/cjs/Menu.js +58 -193
  4. package/cjs/Menu.js.map +7 -0
  5. package/cjs/MenuCombobox.js +67 -53
  6. package/cjs/MenuCombobox.js.map +7 -0
  7. package/cjs/MenuContext.js +38 -11
  8. package/cjs/MenuContext.js.map +7 -0
  9. package/cjs/MenuExports.js +36 -0
  10. package/cjs/MenuExports.js.map +7 -0
  11. package/cjs/MenuItems/CheckboxGroup.js +49 -42
  12. package/cjs/MenuItems/CheckboxGroup.js.map +7 -0
  13. package/cjs/MenuItems/MenuItem.js +116 -163
  14. package/cjs/MenuItems/MenuItem.js.map +7 -0
  15. package/cjs/MenuItems/MenuItemCheckable.js +77 -108
  16. package/cjs/MenuItems/MenuItemCheckable.js.map +7 -0
  17. package/cjs/MenuItems/MenuItemCheckbox.js +47 -41
  18. package/cjs/MenuItems/MenuItemCheckbox.js.map +7 -0
  19. package/cjs/MenuItems/MenuItemRadio.js +50 -38
  20. package/cjs/MenuItems/MenuItemRadio.js.map +7 -0
  21. package/cjs/MenuItems/RadioGroup.js +48 -39
  22. package/cjs/MenuItems/RadioGroup.js.map +7 -0
  23. package/cjs/MenuItems/SearchableGroup.js +88 -92
  24. package/cjs/MenuItems/SearchableGroup.js.map +7 -0
  25. package/cjs/MenuItems/SearchableList.js +92 -95
  26. package/cjs/MenuItems/SearchableList.js.map +7 -0
  27. package/cjs/MenuItems/SelectionGroup.js +85 -90
  28. package/cjs/MenuItems/SelectionGroup.js.map +7 -0
  29. package/cjs/MenuItems/Separator.js +55 -40
  30. package/cjs/MenuItems/Separator.js.map +7 -0
  31. package/cjs/MenuItems/SubMenu.js +143 -160
  32. package/cjs/MenuItems/SubMenu.js.map +7 -0
  33. package/cjs/MenuItems/menuItemFactory.js +39 -71
  34. package/cjs/MenuItems/menuItemFactory.js.map +7 -0
  35. package/cjs/MenuItems/renderMenuItems.js +53 -0
  36. package/cjs/MenuItems/renderMenuItems.js.map +7 -0
  37. package/cjs/VirtualMenuList.js +69 -39
  38. package/cjs/VirtualMenuList.js.map +7 -0
  39. package/cjs/index.js +63 -36
  40. package/cjs/index.js.map +7 -0
  41. package/cjs/utils/useHeightByAmountOfItems.js +43 -14
  42. package/cjs/utils/useHeightByAmountOfItems.js.map +7 -0
  43. package/esm/DSMenu.js +98 -0
  44. package/esm/DSMenu.js.map +7 -0
  45. package/esm/Menu.js +22 -171
  46. package/esm/Menu.js.map +7 -0
  47. package/esm/MenuCombobox.js +38 -45
  48. package/esm/MenuCombobox.js.map +7 -0
  49. package/esm/MenuContext.js +9 -5
  50. package/esm/MenuContext.js.map +7 -0
  51. package/esm/MenuExports.js +7 -0
  52. package/esm/MenuExports.js.map +7 -0
  53. package/esm/MenuItems/CheckboxGroup.js +19 -31
  54. package/esm/MenuItems/CheckboxGroup.js.map +7 -0
  55. package/esm/MenuItems/MenuItem.js +84 -148
  56. package/esm/MenuItems/MenuItem.js.map +7 -0
  57. package/esm/MenuItems/MenuItemCheckable.js +47 -96
  58. package/esm/MenuItems/MenuItemCheckable.js.map +7 -0
  59. package/esm/MenuItems/MenuItemCheckbox.js +18 -33
  60. package/esm/MenuItems/MenuItemCheckbox.js.map +7 -0
  61. package/esm/MenuItems/MenuItemRadio.js +20 -28
  62. package/esm/MenuItems/MenuItemRadio.js.map +7 -0
  63. package/esm/MenuItems/RadioGroup.js +18 -28
  64. package/esm/MenuItems/RadioGroup.js.map +7 -0
  65. package/esm/MenuItems/SearchableGroup.js +53 -76
  66. package/esm/MenuItems/SearchableGroup.js.map +7 -0
  67. package/esm/MenuItems/SearchableList.js +59 -82
  68. package/esm/MenuItems/SearchableList.js.map +7 -0
  69. package/esm/MenuItems/SelectionGroup.js +54 -78
  70. package/esm/MenuItems/SelectionGroup.js.map +7 -0
  71. package/esm/MenuItems/Separator.js +26 -29
  72. package/esm/MenuItems/Separator.js.map +7 -0
  73. package/esm/MenuItems/SubMenu.js +107 -140
  74. package/esm/MenuItems/SubMenu.js.map +7 -0
  75. package/esm/MenuItems/menuItemFactory.js +11 -63
  76. package/esm/MenuItems/menuItemFactory.js.map +7 -0
  77. package/esm/MenuItems/renderMenuItems.js +24 -0
  78. package/esm/MenuItems/renderMenuItems.js.map +7 -0
  79. package/esm/VirtualMenuList.js +39 -32
  80. package/esm/VirtualMenuList.js.map +7 -0
  81. package/esm/index.js +34 -13
  82. package/esm/index.js.map +7 -0
  83. package/esm/utils/useHeightByAmountOfItems.js +13 -11
  84. package/esm/utils/useHeightByAmountOfItems.js.map +7 -0
  85. package/package.json +23 -11
  86. package/types/DSMenu.d.ts +9 -0
  87. package/types/Menu.d.ts +4 -10
  88. package/types/MenuContext.d.ts +3 -2
  89. package/types/MenuExports.d.ts +1 -0
  90. package/types/MenuItems/CheckboxGroup.d.ts +5 -5
  91. package/types/MenuItems/MenuItem.d.ts +5 -5
  92. package/types/MenuItems/MenuItemCheckable.d.ts +15 -14
  93. package/types/MenuItems/MenuItemCheckbox.d.ts +3 -2
  94. package/types/MenuItems/MenuItemRadio.d.ts +5 -5
  95. package/types/MenuItems/RadioGroup.d.ts +5 -5
  96. package/types/MenuItems/SearchableGroup.d.ts +3 -3
  97. package/types/MenuItems/SearchableList.d.ts +16 -16
  98. package/types/MenuItems/SelectionGroup.d.ts +16 -16
  99. package/types/MenuItems/Separator.d.ts +2 -1
  100. package/types/MenuItems/SubMenu.d.ts +18 -18
  101. package/types/MenuItems/menuItemFactory.d.ts +2 -3
  102. package/types/MenuItems/renderMenuItems.d.ts +1 -0
  103. package/types/VirtualMenuList.d.ts +3 -1
  104. package/types/index.d.ts +3 -2
  105. package/types/utils/useHeightByAmountOfItems.d.ts +3 -1
@@ -1,203 +1,186 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- var _defineProperty = require('@babel/runtime/helpers/defineProperty');
6
- var _jsx = require('@babel/runtime/helpers/jsx');
7
- require('core-js/modules/web.dom-collections.iterator.js');
8
- require('core-js/modules/esnext.async-iterator.filter.js');
9
- require('core-js/modules/esnext.iterator.constructor.js');
10
- require('core-js/modules/esnext.iterator.filter.js');
11
- require('core-js/modules/esnext.async-iterator.for-each.js');
12
- require('core-js/modules/esnext.iterator.for-each.js');
13
- var React = require('react');
14
- var reactDesc = require('react-desc');
15
- var dsIcons = require('@elliemae/ds-icons');
16
- var FocusGroup = require('@elliemae/ds-shared/FocusGroup');
17
- var dsHidden = require('@elliemae/ds-hidden');
18
- var DSButton = require('@elliemae/ds-button');
19
- var DSPopper = require('@elliemae/ds-popper');
20
- var styled = require('styled-components');
21
- var Menu = require('../Menu.js');
22
- var MenuItem = require('./MenuItem.js');
23
- var jsxRuntime = require('react/jsx-runtime');
24
-
25
- function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
26
-
27
- var _defineProperty__default = /*#__PURE__*/_interopDefaultLegacy(_defineProperty);
28
- var _jsx__default = /*#__PURE__*/_interopDefaultLegacy(_jsx);
29
- var DSButton__default = /*#__PURE__*/_interopDefaultLegacy(DSButton);
30
- var DSPopper__default = /*#__PURE__*/_interopDefaultLegacy(DSPopper);
31
- var styled__default = /*#__PURE__*/_interopDefaultLegacy(styled);
32
-
33
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
34
-
35
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty__default["default"](target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
36
- const ChevronRightComp = /*#__PURE__*/styled__default["default"].div.withConfig({
37
- componentId: "sc-1qhp1z-0"
38
- })(["display:flex;justify-content:center;align-items:center;width:28px;"]);
39
-
40
- function SubMenu(_ref) {
41
- let {
42
- noAddon,
43
- leftAddon = undefined,
44
- label = undefined,
45
- interactionType = 'hover',
46
- children: subitems,
47
- rightAddonType,
48
- disabledAddonInactive,
49
- checkableProps = {},
50
- customRenderer,
51
- onClick,
52
- closeMenu,
53
- id
54
- } = _ref;
55
- const itemRef = React.useRef(null);
56
- const focusOnOpen = React.useRef(false);
57
- const [isAddonHovered, setIsAddonHovered] = React.useState(false);
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __reExport = (target, module2, copyDefault, desc) => {
13
+ if (module2 && typeof module2 === "object" || typeof module2 === "function") {
14
+ for (let key of __getOwnPropNames(module2))
15
+ if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
16
+ __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
17
+ }
18
+ return target;
19
+ };
20
+ var __toESM = (module2, isNodeMode) => {
21
+ return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
22
+ };
23
+ var __toCommonJS = /* @__PURE__ */ ((cache) => {
24
+ return (module2, temp) => {
25
+ return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
26
+ };
27
+ })(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
28
+ var SubMenu_exports = {};
29
+ __export(SubMenu_exports, {
30
+ DSSubMenuWithSchema: () => DSSubMenuWithSchema,
31
+ SubMenu: () => SubMenu,
32
+ default: () => SubMenu_default
33
+ });
34
+ var React = __toESM(require("react"));
35
+ var import_react = __toESM(require("react"));
36
+ var import_react_desc = require("react-desc");
37
+ var import_ds_icons = require("@elliemae/ds-icons");
38
+ var import_FocusGroup = require("@elliemae/ds-shared/FocusGroup");
39
+ var import_ds_hidden = require("@elliemae/ds-hidden");
40
+ var import_ds_button = require("@elliemae/ds-button");
41
+ var import_ds_popper = require("@elliemae/ds-popper");
42
+ var import_styled_components = __toESM(require("styled-components"));
43
+ var import_DSMenu = require("../DSMenu");
44
+ var import_MenuItem = require("./MenuItem");
45
+ var import_menuItemFactory = require("./menuItemFactory");
46
+ const ChevronRightComp = import_styled_components.default.div`
47
+ display: flex;
48
+ justify-content: center;
49
+ align-items: center;
50
+ width: 28px; // same width as the ellipsis button
51
+ `;
52
+ const SubMenu = ({
53
+ noAddon,
54
+ leftAddon = void 0,
55
+ label = void 0,
56
+ interactionType = "hover",
57
+ children: subitems,
58
+ rightAddonType,
59
+ disabledAddonInactive,
60
+ checkableProps = {},
61
+ customRenderer,
62
+ onClick,
63
+ closeMenu,
64
+ id
65
+ }) => {
66
+ const itemRef = (0, import_react.useRef)(null);
67
+ const focusOnOpen = (0, import_react.useRef)(false);
68
+ const [isAddonHovered, setIsAddonHovered] = (0, import_react.useState)(false);
58
69
  const {
59
70
  visible = false,
60
71
  onShow,
61
72
  onHide
62
- } = dsHidden.useHiddenController(undefined, {
63
- interaction: 'click'
73
+ } = (0, import_ds_hidden.useHiddenController)(void 0, {
74
+ interaction: "click"
64
75
  });
65
- const interaction = rightAddonType === 'elipsis' ? 'click' : 'hover';
66
- const {
67
- focusItemByNode
68
- } = FocusGroup.useFocusGroupItem(); // todo: create a menu state to handle all related menu things
69
-
70
- const handleShowSubItemsWithMouse = e => {
76
+ const interaction = rightAddonType === "elipsis" ? "click" : "hover";
77
+ const { focusItemByNode } = (0, import_FocusGroup.useFocusGroupItem)();
78
+ const handleShowSubItemsWithMouse = (e) => {
71
79
  e.stopPropagation();
72
80
  onShow();
73
81
  focusOnOpen.current = true;
74
82
  };
75
-
76
- const handleShowWithMouse = e => {
77
- if (onClick) onClick(e);
83
+ const handleShowWithMouse = (e) => {
84
+ if (onClick)
85
+ onClick(e);
78
86
  };
79
-
80
87
  const handleShowWithMouseHover = () => {
81
88
  setIsAddonHovered(true);
82
89
  onShow();
83
90
  focusOnOpen.current = false;
84
91
  };
85
-
86
92
  const handleShowWithKeyboard = () => {
87
93
  onShow();
88
94
  focusOnOpen.current = true;
89
95
  };
90
-
91
- const handleOnMouseEnter = React.useCallback(() => {
96
+ const handleOnMouseEnter = (0, import_react.useCallback)(() => {
92
97
  setIsAddonHovered(true);
93
98
  }, []);
94
- const handleOnMouseLeave = React.useCallback(() => {
99
+ const handleOnMouseLeave = (0, import_react.useCallback)(() => {
95
100
  setIsAddonHovered(false);
96
101
  }, []);
97
- const hoverHandlers = interaction === 'hover' ? {
102
+ const hoverHandlers = interaction === "hover" ? {
98
103
  onMouseEnter: handleShowWithMouseHover,
99
104
  onMouseLeave: () => {
100
105
  onHide();
101
106
  setIsAddonHovered(false);
102
107
  }
103
- } : {
104
- onClick: handleShowWithMouse
105
- };
106
- const rightAddon = rightAddonType === 'elipsis' ? /*#__PURE__*/_jsx__default["default"](DSButton__default["default"], {
108
+ } : { onClick: handleShowWithMouse };
109
+ const rightAddon = rightAddonType === "elipsis" ? /* @__PURE__ */ import_react.default.createElement(import_ds_button.DSButton, {
107
110
  "aria-label": "vertical-elipsis",
108
111
  "data-testid": "vertical-elipsis",
109
112
  buttonType: "text",
110
- leftIcon: /*#__PURE__*/_jsx__default["default"](dsIcons.MoreOptionsVert, {
113
+ leftIcon: /* @__PURE__ */ import_react.default.createElement(import_ds_icons.MoreOptionsVert, {
111
114
  className: "submenu-arrow",
112
- color: visible || isAddonHovered ? ['brand-primary', 800] : ['neutral', 500],
115
+ color: visible || isAddonHovered ? ["brand-primary", 800] : ["neutral", 500],
113
116
  size: "s"
114
117
  }),
115
- onClick: e => handleShowSubItemsWithMouse(e),
118
+ onClick: (e) => handleShowSubItemsWithMouse(e),
116
119
  size: "m",
117
- variant: DSButton.BUTTON_VARIANT.DEFAULT
118
- }) : /*#__PURE__*/_jsx__default["default"](ChevronRightComp, {}, void 0, /*#__PURE__*/_jsx__default["default"](dsIcons.ChevronSmallRight, {
120
+ variant: import_ds_button.BUTTON_VARIANT.DEFAULT
121
+ }) : /* @__PURE__ */ import_react.default.createElement(ChevronRightComp, null, /* @__PURE__ */ import_react.default.createElement(import_ds_icons.ChevronSmallRight, {
119
122
  "data-testid": "chevron-right",
120
123
  className: "submenu-arrow",
121
- color: visible || isAddonHovered ? ['brand-primary', 800] : ['neutral', 500],
124
+ color: visible || isAddonHovered ? ["brand-primary", 800] : ["neutral", 500],
122
125
  size: "sm"
123
126
  }));
124
- return /*#__PURE__*/jsxRuntime.jsx(jsxRuntime.Fragment, {
125
- children: /*#__PURE__*/_jsx__default["default"](DSPopper__default["default"], {
126
- contentComponent: /*#__PURE__*/jsxRuntime.jsx(Menu.Menu, _objectSpread(_objectSpread({
127
- focusKeyBindings: {
128
- ArrowLeft: [() => focusItemByNode(itemRef.current), 'exit']
129
- },
130
- focusOnOpen: focusOnOpen.current,
131
- onExitFocusGroup: onHide
132
- }, hoverHandlers), {}, {
133
- closeMenu: closeMenu,
134
- visible: visible,
135
- children: subitems
136
- })),
137
- interactionType: interactionType,
138
- isOpen: visible,
139
- onOpen: opening => opening ? onShow() : onHide(),
140
- placement: "right-start",
141
- showArrow: false,
142
- triggerComponent: /*#__PURE__*/jsxRuntime.jsx(MenuItem["default"], _objectSpread(_objectSpread({
143
- customRenderer: customRenderer,
144
- disabledAddonInactive: disabledAddonInactive,
145
- id: id,
146
- innerRef: itemRef,
147
- label: label,
148
- leftAddon: leftAddon,
149
- noAddon: noAddon,
150
- onFocus: handleOnMouseEnter,
151
- onBlur: handleOnMouseLeave,
152
- onMouseEnter: handleOnMouseEnter,
153
- onMouseLeave: handleOnMouseLeave
154
- }, hoverHandlers), {}, {
155
- onKeyDown: e => {
156
- if (e.key === 'ArrowRight' || e.key === 'Enter' || e.keyCode === 32) {
157
- handleShowWithKeyboard();
158
- }
159
- },
160
- rightAddon: rightAddon
161
- }, checkableProps))
127
+ return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(import_ds_popper.DSPopper, {
128
+ contentComponent: /* @__PURE__ */ import_react.default.createElement(import_DSMenu.Menu, {
129
+ focusKeyBindings: {
130
+ ArrowLeft: [() => focusItemByNode(itemRef.current), "exit"]
131
+ },
132
+ focusOnOpen: focusOnOpen.current,
133
+ onExitFocusGroup: onHide,
134
+ ...hoverHandlers,
135
+ closeMenu,
136
+ visible
137
+ }, subitems),
138
+ interactionType,
139
+ isOpen: visible,
140
+ onOpen: (opening) => opening ? onShow() : onHide(),
141
+ placement: "right-start",
142
+ showArrow: false,
143
+ triggerComponent: /* @__PURE__ */ import_react.default.createElement(import_MenuItem.MenuItem, {
144
+ customRenderer,
145
+ disabledAddonInactive,
146
+ id,
147
+ innerRef: itemRef,
148
+ label,
149
+ leftAddon,
150
+ noAddon,
151
+ onFocus: handleOnMouseEnter,
152
+ onBlur: handleOnMouseLeave,
153
+ onMouseEnter: handleOnMouseEnter,
154
+ onMouseLeave: handleOnMouseLeave,
155
+ ...hoverHandlers,
156
+ onKeyDown: (e) => {
157
+ if (e.key === "ArrowRight" || e.key === "Enter" || e.keyCode === 32) {
158
+ handleShowWithKeyboard();
159
+ }
160
+ },
161
+ rightAddon,
162
+ ...checkableProps
162
163
  })
163
- });
164
- }
165
-
164
+ }));
165
+ };
166
166
  const props = {
167
- /** dont show addon for submenu */
168
- noAddon: reactDesc.PropTypes.bool.description('dont show addon for submenu'),
169
-
170
- /** left addon */
171
- leftAddon: reactDesc.PropTypes.node.description('left addon'),
172
-
173
- /** submenu label */
174
- label: reactDesc.PropTypes.string.description('submenu label'),
175
-
176
- /** A type indicating how to open/close the tooltip */
177
- interactionType: reactDesc.PropTypes.oneOf(DSPopper.interactions).description('A type indicating how to open/close the tooltip'),
178
-
179
- /** sub menu items */
180
- children: reactDesc.PropTypes.oneOfType([reactDesc.PropTypes.array, reactDesc.PropTypes.node]).description('sub menu items'),
181
-
182
- /** right addon, ellipsis or undefined */
183
- rightAddonType: reactDesc.PropTypes.oneOf(['ellipsis']).description('right addon, ellipsis or undefined'),
184
- disabledAddonInactive: reactDesc.PropTypes.bool.description(''),
185
-
186
- /** props passed to MenuItem component */
187
- checkableProps: reactDesc.PropTypes.object.description('props passed to MenuItem component'),
188
-
189
- /** custom renderer for menu item */
190
- customRenderer: reactDesc.PropTypes.func.description('custom renderer for menu item'),
191
-
192
- /** on click handler */
193
- onClick: reactDesc.PropTypes.func.description('on click handler'),
194
- closeMenu: reactDesc.PropTypes.any.description(''),
195
-
196
- /** component id */
197
- id: reactDesc.PropTypes.string.description('component id')
167
+ noAddon: import_react_desc.PropTypes.bool.description("dont show addon for submenu"),
168
+ leftAddon: import_react_desc.PropTypes.node.description("left addon"),
169
+ label: import_react_desc.PropTypes.string.description("submenu label"),
170
+ interactionType: import_react_desc.PropTypes.oneOf(import_ds_popper.interactions).description("A type indicating how to open/close the tooltip"),
171
+ children: import_react_desc.PropTypes.oneOfType([import_react_desc.PropTypes.array, import_react_desc.PropTypes.node]).description("sub menu items"),
172
+ rightAddonType: import_react_desc.PropTypes.oneOf(["ellipsis"]).description("right addon, ellipsis or undefined"),
173
+ disabledAddonInactive: import_react_desc.PropTypes.bool.description(""),
174
+ checkableProps: import_react_desc.PropTypes.object.description("props passed to MenuItem component"),
175
+ customRenderer: import_react_desc.PropTypes.func.description("custom renderer for menu item"),
176
+ onClick: import_react_desc.PropTypes.func.description("on click handler"),
177
+ closeMenu: import_react_desc.PropTypes.any.description(""),
178
+ id: import_react_desc.PropTypes.string.description("component id")
198
179
  };
199
- const DSSubMenuWithSchema = reactDesc.describe(SubMenu);
180
+ SubMenu.propTypes = props;
181
+ (0, import_menuItemFactory.registerMenuItem)("submenu", SubMenu);
182
+ const DSSubMenuWithSchema = (0, import_react_desc.describe)(SubMenu);
200
183
  DSSubMenuWithSchema.propTypes = props;
201
-
202
- exports.DSSubMenuWithSchema = DSSubMenuWithSchema;
203
- exports["default"] = SubMenu;
184
+ var SubMenu_default = SubMenu;
185
+ module.exports = __toCommonJS(SubMenu_exports);
186
+ //# sourceMappingURL=SubMenu.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/MenuItems/SubMenu.tsx", "../../../../../scripts/build/transpile/react-shim.js"],
4
+ "sourcesContent": ["/* eslint-disable indent */\n/* eslint-disable max-lines */\nimport React, { useCallback, useRef, useState } from 'react';\nimport { PropTypes, describe } from 'react-desc';\nimport { ChevronSmallRight, MoreOptionsVert } from '@elliemae/ds-icons';\nimport { useFocusGroupItem } from '@elliemae/ds-shared/FocusGroup';\nimport { useHiddenController } from '@elliemae/ds-hidden';\nimport { DSButton, BUTTON_VARIANT } from '@elliemae/ds-button';\nimport { DSPopper, interactions } from '@elliemae/ds-popper';\nimport styled from 'styled-components';\nimport { Menu } from '../DSMenu';\nimport { MenuItem } from './MenuItem';\nimport { registerMenuItem } from './menuItemFactory';\n\nconst ChevronRightComp = styled.div`\n display: flex;\n justify-content: center;\n align-items: center;\n width: 28px; // same width as the ellipsis button\n`;\n\nconst SubMenu = ({\n noAddon,\n leftAddon = undefined,\n label = undefined,\n interactionType = 'hover',\n children: subitems,\n rightAddonType,\n disabledAddonInactive,\n checkableProps = {},\n customRenderer,\n onClick,\n closeMenu,\n id,\n}) => {\n const itemRef = useRef(null);\n const focusOnOpen = useRef(false);\n const [isAddonHovered, setIsAddonHovered] = useState<boolean>(false);\n const {\n visible = false,\n onShow,\n onHide,\n } = useHiddenController(undefined, {\n interaction: 'click',\n });\n\n const interaction = rightAddonType === 'elipsis' ? 'click' : 'hover';\n\n const { focusItemByNode } = useFocusGroupItem();\n // todo: create a menu state to handle all related menu things\n const handleShowSubItemsWithMouse = (e) => {\n e.stopPropagation();\n onShow();\n focusOnOpen.current = true;\n };\n const handleShowWithMouse = (e) => {\n if (onClick) onClick(e);\n };\n const handleShowWithMouseHover = () => {\n setIsAddonHovered(true);\n onShow();\n focusOnOpen.current = false;\n };\n\n const handleShowWithKeyboard = () => {\n onShow();\n focusOnOpen.current = true;\n };\n\n const handleOnMouseEnter = useCallback(() => {\n setIsAddonHovered(true);\n }, []);\n\n const handleOnMouseLeave = useCallback(() => {\n setIsAddonHovered(false);\n }, []);\n\n const hoverHandlers =\n interaction === 'hover'\n ? {\n onMouseEnter: handleShowWithMouseHover,\n onMouseLeave: () => {\n onHide();\n setIsAddonHovered(false);\n },\n }\n : { onClick: handleShowWithMouse };\n\n const rightAddon =\n rightAddonType === 'elipsis' ? (\n <DSButton\n aria-label=\"vertical-elipsis\"\n data-testid=\"vertical-elipsis\"\n buttonType=\"text\"\n leftIcon={\n <MoreOptionsVert\n className=\"submenu-arrow\"\n color={visible || isAddonHovered ? ['brand-primary', 800] : ['neutral', 500]}\n size=\"s\"\n />\n }\n onClick={(e) => handleShowSubItemsWithMouse(e)}\n size=\"m\"\n variant={BUTTON_VARIANT.DEFAULT}\n />\n ) : (\n <ChevronRightComp>\n <ChevronSmallRight\n data-testid=\"chevron-right\"\n className=\"submenu-arrow\"\n color={visible || isAddonHovered ? ['brand-primary', 800] : ['neutral', 500]}\n size=\"sm\"\n />\n </ChevronRightComp>\n );\n\n return (\n <>\n <DSPopper\n contentComponent={\n <Menu\n focusKeyBindings={{\n ArrowLeft: [() => focusItemByNode(itemRef.current), 'exit'],\n }}\n focusOnOpen={focusOnOpen.current}\n onExitFocusGroup={onHide}\n {...hoverHandlers}\n closeMenu={closeMenu}\n visible={visible}\n >\n {subitems}\n </Menu>\n }\n interactionType={interactionType}\n isOpen={visible}\n onOpen={(opening) => (opening ? onShow() : onHide())}\n placement=\"right-start\"\n showArrow={false}\n triggerComponent={\n <MenuItem\n customRenderer={customRenderer}\n disabledAddonInactive={disabledAddonInactive}\n id={id}\n innerRef={itemRef}\n label={label}\n leftAddon={leftAddon}\n noAddon={noAddon}\n onFocus={handleOnMouseEnter}\n onBlur={handleOnMouseLeave}\n onMouseEnter={handleOnMouseEnter}\n onMouseLeave={handleOnMouseLeave}\n {...hoverHandlers}\n onKeyDown={(e) => {\n if (e.key === 'ArrowRight' || e.key === 'Enter' || e.keyCode === 32) {\n handleShowWithKeyboard();\n }\n }}\n rightAddon={rightAddon}\n {...checkableProps}\n />\n }\n />\n </>\n );\n};\n\nconst props = {\n /** dont show addon for submenu */\n noAddon: PropTypes.bool.description('dont show addon for submenu'),\n /** left addon */\n leftAddon: PropTypes.node.description('left addon'),\n /** submenu label */\n label: PropTypes.string.description('submenu label'),\n /** A type indicating how to open/close the tooltip */\n interactionType: PropTypes.oneOf(interactions).description('A type indicating how to open/close the tooltip'),\n /** sub menu items */\n children: PropTypes.oneOfType([PropTypes.array, PropTypes.node]).description('sub menu items'),\n /** right addon, ellipsis or undefined */\n rightAddonType: PropTypes.oneOf(['ellipsis']).description('right addon, ellipsis or undefined'),\n disabledAddonInactive: PropTypes.bool.description(''),\n /** props passed to MenuItem component */\n checkableProps: PropTypes.object.description('props passed to MenuItem component'),\n /** custom renderer for menu item */\n customRenderer: PropTypes.func.description('custom renderer for menu item'),\n /** on click handler */\n onClick: PropTypes.func.description('on click handler'),\n closeMenu: PropTypes.any.description(''),\n /** component id */\n id: PropTypes.string.description('component id'),\n};\n\nSubMenu.propTypes = props;\nregisterMenuItem('submenu', SubMenu);\n\nconst DSSubMenuWithSchema = describe(SubMenu);\n\nDSSubMenuWithSchema.propTypes = props;\n\nexport { DSSubMenuWithSchema, SubMenu };\nexport default SubMenu;\n", "import * as React from 'react';\nexport { React };\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB;ADEvB,mBAAqD;AACrD,wBAAoC;AACpC,sBAAmD;AACnD,wBAAkC;AAClC,uBAAoC;AACpC,uBAAyC;AACzC,uBAAuC;AACvC,+BAAmB;AACnB,oBAAqB;AACrB,sBAAyB;AACzB,6BAAiC;AAEjC,MAAM,mBAAmB,iCAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAOhC,MAAM,UAAU,CAAC;AAAA,EACf;AAAA,EACA,YAAY;AAAA,EACZ,QAAQ;AAAA,EACR,kBAAkB;AAAA,EAClB,UAAU;AAAA,EACV;AAAA,EACA;AAAA,EACA,iBAAiB;AAAA,EACjB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,MACI;AACJ,QAAM,UAAU,yBAAO;AACvB,QAAM,cAAc,yBAAO;AAC3B,QAAM,CAAC,gBAAgB,qBAAqB,2BAAkB;AAC9D,QAAM;AAAA,IACJ,UAAU;AAAA,IACV;AAAA,IACA;AAAA,MACE,0CAAoB,QAAW;AAAA,IACjC,aAAa;AAAA;AAGf,QAAM,cAAc,mBAAmB,YAAY,UAAU;AAE7D,QAAM,EAAE,oBAAoB;AAE5B,QAAM,8BAA8B,CAAC,MAAM;AACzC,MAAE;AACF;AACA,gBAAY,UAAU;AAAA;AAExB,QAAM,sBAAsB,CAAC,MAAM;AACjC,QAAI;AAAS,cAAQ;AAAA;AAEvB,QAAM,2BAA2B,MAAM;AACrC,sBAAkB;AAClB;AACA,gBAAY,UAAU;AAAA;AAGxB,QAAM,yBAAyB,MAAM;AACnC;AACA,gBAAY,UAAU;AAAA;AAGxB,QAAM,qBAAqB,8BAAY,MAAM;AAC3C,sBAAkB;AAAA,KACjB;AAEH,QAAM,qBAAqB,8BAAY,MAAM;AAC3C,sBAAkB;AAAA,KACjB;AAEH,QAAM,gBACJ,gBAAgB,UACZ;AAAA,IACE,cAAc;AAAA,IACd,cAAc,MAAM;AAClB;AACA,wBAAkB;AAAA;AAAA,MAGtB,EAAE,SAAS;AAEjB,QAAM,aACJ,mBAAmB,YACjB,mDAAC,2BAAD;AAAA,IACE,cAAW;AAAA,IACX,eAAY;AAAA,IACZ,YAAW;AAAA,IACX,UACE,mDAAC,iCAAD;AAAA,MACE,WAAU;AAAA,MACV,OAAO,WAAW,iBAAiB,CAAC,iBAAiB,OAAO,CAAC,WAAW;AAAA,MACxE,MAAK;AAAA;AAAA,IAGT,SAAS,CAAC,MAAM,4BAA4B;AAAA,IAC5C,MAAK;AAAA,IACL,SAAS,gCAAe;AAAA,OAG1B,mDAAC,kBAAD,MACE,mDAAC,mCAAD;AAAA,IACE,eAAY;AAAA,IACZ,WAAU;AAAA,IACV,OAAO,WAAW,iBAAiB,CAAC,iBAAiB,OAAO,CAAC,WAAW;AAAA,IACxE,MAAK;AAAA;AAKb,SACE,wFACE,mDAAC,2BAAD;AAAA,IACE,kBACE,mDAAC,oBAAD;AAAA,MACE,kBAAkB;AAAA,QAChB,WAAW,CAAC,MAAM,gBAAgB,QAAQ,UAAU;AAAA;AAAA,MAEtD,aAAa,YAAY;AAAA,MACzB,kBAAkB;AAAA,SACd;AAAA,MACJ;AAAA,MACA;AAAA,OAEC;AAAA,IAGL;AAAA,IACA,QAAQ;AAAA,IACR,QAAQ,CAAC,YAAa,UAAU,WAAW;AAAA,IAC3C,WAAU;AAAA,IACV,WAAW;AAAA,IACX,kBACE,mDAAC,0BAAD;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA,UAAU;AAAA,MACV;AAAA,MACA;AAAA,MACA;AAAA,MACA,SAAS;AAAA,MACT,QAAQ;AAAA,MACR,cAAc;AAAA,MACd,cAAc;AAAA,SACV;AAAA,MACJ,WAAW,CAAC,MAAM;AAChB,YAAI,EAAE,QAAQ,gBAAgB,EAAE,QAAQ,WAAW,EAAE,YAAY,IAAI;AACnE;AAAA;AAAA;AAAA,MAGJ;AAAA,SACI;AAAA;AAAA;AAAA;AAQhB,MAAM,QAAQ;AAAA,EAEZ,SAAS,4BAAU,KAAK,YAAY;AAAA,EAEpC,WAAW,4BAAU,KAAK,YAAY;AAAA,EAEtC,OAAO,4BAAU,OAAO,YAAY;AAAA,EAEpC,iBAAiB,4BAAU,MAAM,+BAAc,YAAY;AAAA,EAE3D,UAAU,4BAAU,UAAU,CAAC,4BAAU,OAAO,4BAAU,OAAO,YAAY;AAAA,EAE7E,gBAAgB,4BAAU,MAAM,CAAC,aAAa,YAAY;AAAA,EAC1D,uBAAuB,4BAAU,KAAK,YAAY;AAAA,EAElD,gBAAgB,4BAAU,OAAO,YAAY;AAAA,EAE7C,gBAAgB,4BAAU,KAAK,YAAY;AAAA,EAE3C,SAAS,4BAAU,KAAK,YAAY;AAAA,EACpC,WAAW,4BAAU,IAAI,YAAY;AAAA,EAErC,IAAI,4BAAU,OAAO,YAAY;AAAA;AAGnC,QAAQ,YAAY;AACpB,6CAAiB,WAAW;AAE5B,MAAM,sBAAsB,gCAAS;AAErC,oBAAoB,YAAY;AAGhC,IAAO,kBAAQ;",
6
+ "names": []
7
+ }
@@ -1,73 +1,41 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- var _defineProperty = require('@babel/runtime/helpers/defineProperty');
6
- require('core-js/modules/esnext.async-iterator.map.js');
7
- require('core-js/modules/esnext.iterator.map.js');
8
- require('core-js/modules/esnext.async-iterator.filter.js');
9
- require('core-js/modules/esnext.iterator.constructor.js');
10
- require('core-js/modules/esnext.iterator.filter.js');
11
- require('core-js/modules/esnext.async-iterator.for-each.js');
12
- require('core-js/modules/esnext.iterator.for-each.js');
13
- var React = require('react');
14
- var dsUtilities = require('@elliemae/ds-utilities');
15
- var Separator = require('./Separator.js');
16
- var MenuItem = require('./MenuItem.js');
17
- var SubMenu = require('./SubMenu.js');
18
- var SelectionGroup = require('./SelectionGroup.js');
19
- var MenuItemCheckbox = require('./MenuItemCheckbox.js');
20
- var MenuItemRadio = require('./MenuItemRadio.js');
21
-
22
- function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
23
-
24
- var _defineProperty__default = /*#__PURE__*/_interopDefaultLegacy(_defineProperty);
25
-
26
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
27
-
28
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty__default["default"](target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
29
-
30
- const itemTypes = () => ({
31
- separator: Separator["default"],
32
- menuitem: MenuItem["default"],
33
- radio: MenuItemRadio["default"],
34
- checkbox: MenuItemCheckbox,
35
- submenu: SubMenu["default"],
36
- 'selection-group': SelectionGroup["default"]
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __reExport = (target, module2, copyDefault, desc) => {
13
+ if (module2 && typeof module2 === "object" || typeof module2 === "function") {
14
+ for (let key of __getOwnPropNames(module2))
15
+ if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
16
+ __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
17
+ }
18
+ return target;
19
+ };
20
+ var __toESM = (module2, isNodeMode) => {
21
+ return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
22
+ };
23
+ var __toCommonJS = /* @__PURE__ */ ((cache) => {
24
+ return (module2, temp) => {
25
+ return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
26
+ };
27
+ })(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
28
+ var menuItemFactory_exports = {};
29
+ __export(menuItemFactory_exports, {
30
+ menuItemFactory: () => menuItemFactory,
31
+ registerMenuItem: () => registerMenuItem
37
32
  });
38
-
39
- const fallback = {
40
- SelectionGroup: 'selection-group'
33
+ var React = __toESM(require("react"));
34
+ const itemTypes = {};
35
+ const menuItemFactory = (type = "", items, defaultItem = itemTypes.menuitem) => {
36
+ const itemsObject = items || itemTypes;
37
+ return itemsObject[type] || itemsObject[type.toLowerCase()] || defaultItem;
41
38
  };
42
- function menuItemFactory() {
43
- let type = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
44
- let items = arguments.length > 1 ? arguments[1] : undefined;
45
- let defaultItem = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : itemTypes().menuitem;
46
- const itemsObject = items || itemTypes();
47
- const parsedType = fallback[type] || type.toLowerCase();
48
- return itemsObject[parsedType] || defaultItem;
49
- }
50
- function renderMenuItems(options) {
51
- let factory = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : menuItemFactory;
52
- return options.map((option, index) => {
53
- if (dsUtilities.isFunction(option.renderer)) {
54
- return option.renderer({
55
- key: option.id,
56
- item: option
57
- });
58
- }
59
-
60
- const ItemComponent = factory(option.type);
61
- const children = option.subItems && renderMenuItems(option.subItems, factory);
62
- return /*#__PURE__*/React.createElement(ItemComponent, _objectSpread(_objectSpread({}, option), {}, {
63
- key: option.id || index,
64
- item: option,
65
- onClick: null,
66
- onMouseDown: option.onClick // onClick callback called in onMouseDown due to events order issue
67
-
68
- }), children);
69
- });
70
- }
71
-
72
- exports.menuItemFactory = menuItemFactory;
73
- exports.renderMenuItems = renderMenuItems;
39
+ const registerMenuItem = (type, item) => itemTypes[type] = item;
40
+ module.exports = __toCommonJS(menuItemFactory_exports);
41
+ //# sourceMappingURL=menuItemFactory.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/MenuItems/menuItemFactory.tsx", "../../../../../scripts/build/transpile/react-shim.js"],
4
+ "sourcesContent": ["import React from 'react';\n\nconst itemTypes = {};\n\nexport const menuItemFactory = (type = '', items, defaultItem = itemTypes.menuitem) => {\n const itemsObject = items || itemTypes;\n return itemsObject[type] || itemsObject[type.toLowerCase()] || defaultItem;\n};\n\nexport const registerMenuItem = (type, item) => (itemTypes[type] = item);\n", "import * as React from 'react';\nexport { React };\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB;ADEvB,MAAM,YAAY;AAEX,MAAM,kBAAkB,CAAC,OAAO,IAAI,OAAO,cAAc,UAAU,aAAa;AACrF,QAAM,cAAc,SAAS;AAC7B,SAAO,YAAY,SAAS,YAAY,KAAK,kBAAkB;AAAA;AAG1D,MAAM,mBAAmB,CAAC,MAAM,SAAU,UAAU,QAAQ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,53 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __reExport = (target, module2, copyDefault, desc) => {
13
+ if (module2 && typeof module2 === "object" || typeof module2 === "function") {
14
+ for (let key of __getOwnPropNames(module2))
15
+ if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
16
+ __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
17
+ }
18
+ return target;
19
+ };
20
+ var __toESM = (module2, isNodeMode) => {
21
+ return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
22
+ };
23
+ var __toCommonJS = /* @__PURE__ */ ((cache) => {
24
+ return (module2, temp) => {
25
+ return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
26
+ };
27
+ })(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
28
+ var renderMenuItems_exports = {};
29
+ __export(renderMenuItems_exports, {
30
+ renderMenuItems: () => renderMenuItems
31
+ });
32
+ var React = __toESM(require("react"));
33
+ var import_react = __toESM(require("react"));
34
+ var import_ds_utilities = require("@elliemae/ds-utilities");
35
+ const renderMenuItems = (options, factory) => options.map((option, index) => {
36
+ if ((0, import_ds_utilities.isFunction)(option.renderer)) {
37
+ return option.renderer({
38
+ key: option.id,
39
+ item: option
40
+ });
41
+ }
42
+ const ItemComponent = factory(option.type);
43
+ const children = option.subItems && renderMenuItems(option.subItems, factory);
44
+ return /* @__PURE__ */ import_react.default.createElement(ItemComponent, {
45
+ ...option,
46
+ key: option.id || index,
47
+ item: option,
48
+ onClick: null,
49
+ onMouseDown: option.onClick
50
+ }, children);
51
+ });
52
+ module.exports = __toCommonJS(renderMenuItems_exports);
53
+ //# sourceMappingURL=renderMenuItems.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/MenuItems/renderMenuItems.tsx", "../../../../../scripts/build/transpile/react-shim.js"],
4
+ "sourcesContent": ["/* eslint-disable import/no-cycle */\nimport React from 'react';\nimport { isFunction } from '@elliemae/ds-utilities';\n\nexport const renderMenuItems = (options, factory) =>\n options.map((option, index) => {\n if (isFunction(option.renderer)) {\n return option.renderer({\n key: option.id,\n item: option,\n });\n }\n const ItemComponent = factory(option.type);\n const children = option.subItems && renderMenuItems(option.subItems, factory);\n return (\n <ItemComponent\n {...option}\n key={option.id || index}\n item={option}\n onClick={null}\n onMouseDown={option.onClick}\n // onClick callback called in onMouseDown due to events order issue\n >\n {children}\n </ItemComponent>\n );\n });\n", "import * as React from 'react';\nexport { React };\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB;ADCvB,mBAAkB;AAClB,0BAA2B;AAEpB,MAAM,kBAAkB,CAAC,SAAS,YACvC,QAAQ,IAAI,CAAC,QAAQ,UAAU;AAC7B,MAAI,oCAAW,OAAO,WAAW;AAC/B,WAAO,OAAO,SAAS;AAAA,MACrB,KAAK,OAAO;AAAA,MACZ,MAAM;AAAA;AAAA;AAGV,QAAM,gBAAgB,QAAQ,OAAO;AACrC,QAAM,WAAW,OAAO,YAAY,gBAAgB,OAAO,UAAU;AACrE,SACE,mDAAC,eAAD;AAAA,OACM;AAAA,IACJ,KAAK,OAAO,MAAM;AAAA,IAClB,MAAM;AAAA,IACN,SAAS;AAAA,IACT,aAAa,OAAO;AAAA,KAGnB;AAAA;",
6
+ "names": []
7
+ }