@jbrowse/core 2.0.0 → 2.1.2

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 (184) hide show
  1. package/BaseFeatureWidget/BaseFeatureDetail.d.ts +9 -3
  2. package/BaseFeatureWidget/BaseFeatureDetail.js +313 -581
  3. package/BaseFeatureWidget/SequenceFeatureDetails.js +213 -478
  4. package/BaseFeatureWidget/index.js +88 -126
  5. package/BaseFeatureWidget/types.d.ts +1 -0
  6. package/BaseFeatureWidget/types.js +1 -4
  7. package/BaseFeatureWidget/util.js +40 -75
  8. package/CorePlugin.js +55 -94
  9. package/Plugin.js +9 -34
  10. package/PluginLoader.js +153 -422
  11. package/PluginManager.d.ts +28 -33
  12. package/PluginManager.js +377 -666
  13. package/ReExports/Attributes.js +3 -10
  14. package/ReExports/BaseCard.js +3 -10
  15. package/ReExports/DataGrid.js +5 -12
  16. package/ReExports/FeatureDetails.js +3 -10
  17. package/ReExports/index.js +6 -12
  18. package/ReExports/list.d.ts +5 -0
  19. package/ReExports/list.js +271 -7
  20. package/ReExports/material-ui-colors.js +15 -16
  21. package/ReExports/modules.d.ts +11 -20
  22. package/ReExports/modules.js +453 -798
  23. package/TextSearch/BaseResults.js +51 -123
  24. package/TextSearch/TextSearchManager.js +66 -144
  25. package/assemblyManager/assembly.js +280 -555
  26. package/assemblyManager/assemblyConfigSchema.js +47 -64
  27. package/assemblyManager/assemblyManager.js +126 -272
  28. package/assemblyManager/index.js +9 -22
  29. package/configuration/configurationSchema.js +167 -203
  30. package/configuration/configurationSlot.js +248 -326
  31. package/configuration/index.js +19 -35
  32. package/configuration/util.js +131 -173
  33. package/data_adapters/BaseAdapter.d.ts +2 -2
  34. package/data_adapters/BaseAdapter.js +132 -521
  35. package/data_adapters/CytobandAdapter.js +40 -126
  36. package/data_adapters/dataAdapterCache.js +77 -158
  37. package/package.json +4 -5
  38. package/pluggableElementTypes/AdapterType.js +24 -79
  39. package/pluggableElementTypes/AddTrackWorkflowType.d.ts +17 -0
  40. package/pluggableElementTypes/AddTrackWorkflowType.js +20 -0
  41. package/pluggableElementTypes/ConnectionType.js +22 -65
  42. package/pluggableElementTypes/DisplayType.js +35 -82
  43. package/pluggableElementTypes/InternetAccountType.js +23 -64
  44. package/pluggableElementTypes/PluggableElementBase.js +8 -20
  45. package/pluggableElementTypes/RpcMethodType.js +85 -427
  46. package/pluggableElementTypes/TextSearchAdapterType.js +16 -55
  47. package/pluggableElementTypes/TrackType.js +26 -70
  48. package/pluggableElementTypes/ViewType.js +21 -63
  49. package/pluggableElementTypes/WidgetType.js +21 -64
  50. package/pluggableElementTypes/index.d.ts +4 -3
  51. package/pluggableElementTypes/index.js +42 -125
  52. package/pluggableElementTypes/models/BaseConnectionModelFactory.js +28 -43
  53. package/pluggableElementTypes/models/BaseDisplayModel.js +58 -95
  54. package/pluggableElementTypes/models/BaseTrackModel.js +139 -199
  55. package/pluggableElementTypes/models/BaseViewModel.js +24 -40
  56. package/pluggableElementTypes/models/InternetAccountModel.js +116 -263
  57. package/pluggableElementTypes/models/baseConnectionConfig.js +14 -25
  58. package/pluggableElementTypes/models/baseInternetAccountConfig.js +29 -38
  59. package/pluggableElementTypes/models/baseTrackConfig.js +106 -133
  60. package/pluggableElementTypes/models/index.js +21 -70
  61. package/pluggableElementTypes/renderers/BoxRendererType.js +132 -291
  62. package/pluggableElementTypes/renderers/CircularChordRendererType.js +8 -38
  63. package/pluggableElementTypes/renderers/ComparativeServerSideRendererType.js +60 -192
  64. package/pluggableElementTypes/renderers/FeatureRendererType.d.ts +0 -2
  65. package/pluggableElementTypes/renderers/FeatureRendererType.js +89 -255
  66. package/pluggableElementTypes/renderers/RendererType.js +31 -105
  67. package/pluggableElementTypes/renderers/ServerSideRenderedContent.js +61 -72
  68. package/pluggableElementTypes/renderers/ServerSideRendererType.js +112 -265
  69. package/pluggableElementTypes/renderers/index.js +19 -62
  70. package/pluggableElementTypes/renderers/util/serializableFilterChain.js +27 -65
  71. package/rpc/BaseRpcDriver.js +169 -405
  72. package/rpc/MainThreadRpcDriver.js +27 -150
  73. package/rpc/RpcManager.js +58 -159
  74. package/rpc/WebWorkerRpcDriver.js +54 -171
  75. package/rpc/configSchema.js +25 -49
  76. package/rpc/coreRpcMethods.d.ts +1 -3
  77. package/rpc/coreRpcMethods.js +221 -959
  78. package/rpc/remoteAbortSignals.js +46 -70
  79. package/tsconfig.build.tsbuildinfo +1 -1
  80. package/ui/AboutDialog.js +106 -162
  81. package/ui/App.js +157 -242
  82. package/ui/AssemblySelector.js +59 -120
  83. package/ui/CascadingMenu.js +101 -196
  84. package/ui/ColorPicker.d.ts +16 -0
  85. package/ui/ColorPicker.js +97 -0
  86. package/ui/Drawer.js +28 -61
  87. package/ui/DrawerWidget.js +108 -202
  88. package/ui/DropDownMenu.js +60 -91
  89. package/ui/EditableTypography.js +87 -149
  90. package/ui/ErrorMessage.js +41 -56
  91. package/ui/FactoryResetDialog.js +24 -57
  92. package/ui/FatalErrorDialog.js +59 -91
  93. package/ui/FileSelector/FileSelector.js +123 -189
  94. package/ui/FileSelector/LocalFileChooser.js +44 -75
  95. package/ui/FileSelector/UrlChooser.js +17 -38
  96. package/ui/FileSelector/index.js +6 -12
  97. package/ui/Icons.js +45 -69
  98. package/ui/Logo.js +57 -110
  99. package/ui/Menu.js +232 -354
  100. package/ui/PrerenderedCanvas.js +63 -87
  101. package/ui/ResizeHandle.js +87 -116
  102. package/ui/ReturnToImportFormDialog.js +32 -63
  103. package/ui/SanitizedHTML.js +64 -47
  104. package/ui/Snackbar.js +74 -101
  105. package/ui/SnackbarModel.js +37 -51
  106. package/ui/Tooltip.js +49 -76
  107. package/ui/ViewContainer.js +113 -196
  108. package/ui/colors.d.ts +10 -0
  109. package/ui/colors.js +78 -0
  110. package/ui/index.js +51 -181
  111. package/ui/react-colorful.d.ts +17 -0
  112. package/ui/react-colorful.js +455 -0
  113. package/ui/theme.d.ts +23 -1
  114. package/ui/theme.js +199 -247
  115. package/util/Base1DUtils.d.ts +32 -0
  116. package/util/Base1DUtils.js +174 -0
  117. package/util/Base1DViewModel.d.ts +16 -30
  118. package/util/Base1DViewModel.js +116 -293
  119. package/util/QuickLRU.js +84 -332
  120. package/util/TimeTraveller.d.ts +19 -0
  121. package/util/TimeTraveller.js +86 -0
  122. package/util/aborting.js +49 -127
  123. package/util/analytics.js +91 -154
  124. package/util/blockTypes.js +106 -240
  125. package/util/calculateDynamicBlocks.js +98 -128
  126. package/util/calculateStaticBlocks.js +105 -125
  127. package/util/color/cssColorsLevel4.js +156 -160
  128. package/util/color/index.js +33 -55
  129. package/util/compositeMap.js +49 -333
  130. package/util/formatFastaStrings.js +9 -14
  131. package/util/idMaker.js +18 -31
  132. package/util/index.d.ts +18 -32
  133. package/util/index.js +747 -1226
  134. package/util/io/RemoteFileWithRangeCache.js +88 -257
  135. package/util/io/index.js +95 -169
  136. package/util/jexl.js +60 -115
  137. package/util/jexlStrings.js +24 -29
  138. package/util/layouts/BaseLayout.js +1 -4
  139. package/util/layouts/GranularRectLayout.js +388 -555
  140. package/util/layouts/MultiLayout.js +41 -109
  141. package/util/layouts/PrecomputedLayout.js +56 -112
  142. package/util/layouts/PrecomputedMultiLayout.js +22 -59
  143. package/util/layouts/SceneGraph.js +127 -197
  144. package/util/layouts/index.js +29 -66
  145. package/util/mst-reflection.js +55 -71
  146. package/util/offscreenCanvasPonyfill.js +66 -134
  147. package/util/offscreenCanvasUtils.d.ts +2 -7
  148. package/util/offscreenCanvasUtils.js +49 -146
  149. package/util/range.js +29 -40
  150. package/util/rxjs.js +20 -27
  151. package/util/simpleFeature.js +88 -152
  152. package/util/stats.js +91 -151
  153. package/util/tracks.js +130 -173
  154. package/util/types/index.js +110 -179
  155. package/util/types/mst.js +91 -146
  156. package/util/types/util.js +1 -4
  157. package/util/when.js +54 -101
  158. package/BaseFeatureWidget/SequenceFeatureDetails.test.js +0 -122
  159. package/BaseFeatureWidget/index.test.js +0 -69
  160. package/TextSearch/BaseResults.test.js +0 -42
  161. package/configuration/configurationSchema.test.js +0 -266
  162. package/configuration/configurationSlot.test.js +0 -69
  163. package/configuration/util.test.js +0 -39
  164. package/data_adapters/BaseAdapter.test.js +0 -200
  165. package/declare.d.js +0 -1
  166. package/pluggableElementTypes/RpcMethodType.test.js +0 -118
  167. package/pluggableElementTypes/renderers/declare.d.js +0 -1
  168. package/pluggableElementTypes/renderers/util/serializableFilterChain.test.js +0 -20
  169. package/rpc/BaseRpcDriver.test.js +0 -540
  170. package/rpc/declaration.d.js +0 -1
  171. package/ui/FatalErrorDialog.test.js +0 -82
  172. package/ui/SanitizedHTML.test.js +0 -36
  173. package/ui/theme.test.js +0 -92
  174. package/util/Base1DViewModel.test.js +0 -130
  175. package/util/calculateDynamicBlocks.test.js +0 -74
  176. package/util/calculateStaticBlocks.test.js +0 -297
  177. package/util/declare.d.js +0 -1
  178. package/util/formatFastaStrings.test.js +0 -40
  179. package/util/index.test.js +0 -213
  180. package/util/jexlStrings.test.js +0 -48
  181. package/util/layouts/GranularRectLayout.test.js +0 -99
  182. package/util/range.test.js +0 -64
  183. package/util/simpleFeature.test.js +0 -34
  184. package/util/stats.test.js +0 -172
package/ui/Menu.js CHANGED
@@ -1,373 +1,251 @@
1
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
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
9
17
  });
10
- exports.MenuItemEndDecoration = MenuItemEndDecoration;
11
- exports.default = void 0;
12
-
13
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
14
-
15
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
16
-
17
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
18
-
19
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
20
-
21
- var _react = _interopRequireWildcard(require("react"));
22
-
23
- var _material = require("@mui/material");
24
-
25
- var _mui = require("tss-react/mui");
26
-
27
- var _ArrowRight = _interopRequireDefault(require("@mui/icons-material/ArrowRight"));
28
-
29
- var _CheckBox = _interopRequireDefault(require("@mui/icons-material/CheckBox"));
30
-
31
- var _CheckBoxOutlineBlank = _interopRequireDefault(require("@mui/icons-material/CheckBoxOutlineBlank"));
32
-
33
- var _RadioButtonChecked = _interopRequireDefault(require("@mui/icons-material/RadioButtonChecked"));
34
-
35
- var _RadioButtonUnchecked = _interopRequireDefault(require("@mui/icons-material/RadioButtonUnchecked"));
36
-
37
- var _util = require("../util");
38
-
39
- var _excluded = ["open", "onClose", "menuItems", "onMenuItemClick"];
40
-
41
- 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); }
42
-
43
- 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; }
44
-
45
- 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; }
46
-
47
- 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) { (0, _defineProperty2.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; }
48
-
49
- var useStyles = (0, _mui.makeStyles)()({
50
- paper: {
51
- position: 'fixed',
52
- overflowY: 'auto',
53
- overflowX: 'hidden',
54
- // So we see the popover when it's empty.
55
- minWidth: 16,
56
- minHeight: 16,
57
- maxWidth: 'calc(100% - 32px)',
58
- maxHeight: 'calc(100% - 32px)',
59
- top: 0,
60
- left: 0,
61
- // We disable the focus ring for mouse, touch and keyboard users.
62
- outline: 0
63
- },
64
- menuItemEndDecoration: {
65
- padding: 0,
66
- margin: 0,
67
- height: 16
68
- }
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.MenuItemEndDecoration = void 0;
30
+ const react_1 = __importStar(require("react"));
31
+ const material_1 = require("@mui/material");
32
+ const mui_1 = require("tss-react/mui");
33
+ // icons
34
+ const ArrowRight_1 = __importDefault(require("@mui/icons-material/ArrowRight"));
35
+ const CheckBox_1 = __importDefault(require("@mui/icons-material/CheckBox"));
36
+ const CheckBoxOutlineBlank_1 = __importDefault(require("@mui/icons-material/CheckBoxOutlineBlank"));
37
+ const RadioButtonChecked_1 = __importDefault(require("@mui/icons-material/RadioButtonChecked"));
38
+ const RadioButtonUnchecked_1 = __importDefault(require("@mui/icons-material/RadioButtonUnchecked"));
39
+ // other
40
+ const util_1 = require("../util");
41
+ const useStyles = (0, mui_1.makeStyles)()({
42
+ paper: {
43
+ position: 'fixed',
44
+ overflowY: 'auto',
45
+ overflowX: 'hidden',
46
+ // So we see the popover when it's empty.
47
+ minWidth: 16,
48
+ minHeight: 16,
49
+ maxWidth: 'calc(100% - 32px)',
50
+ maxHeight: 'calc(100% - 32px)',
51
+ top: 0,
52
+ left: 0,
53
+ // We disable the focus ring for mouse, touch and keyboard users.
54
+ outline: 0,
55
+ },
56
+ menuItemEndDecoration: {
57
+ padding: 0,
58
+ margin: 0,
59
+ height: 16,
60
+ },
69
61
  });
70
-
71
62
  function MenuItemEndDecoration(props) {
72
- var _useStyles = useStyles(),
73
- classes = _useStyles.classes;
74
-
75
- var type = props.type;
76
- var checked;
77
- var disabled;
78
-
79
- if ('checked' in props) {
80
- ;
81
- checked = props.checked;
82
- disabled = props.disabled;
83
- }
84
-
85
- var icon;
86
-
87
- if (type === 'subMenu') {
88
- icon = /*#__PURE__*/_react.default.createElement(_ArrowRight.default, {
89
- color: "action"
90
- });
91
- } else if (type === 'checkbox') {
92
- if (checked) {
93
- var color = disabled ? 'inherit' : 'secondary';
94
- icon = /*#__PURE__*/_react.default.createElement(_CheckBox.default, {
95
- color: color
96
- });
97
- } else {
98
- icon = /*#__PURE__*/_react.default.createElement(_CheckBoxOutlineBlank.default, {
99
- color: "action"
100
- });
63
+ const { classes } = useStyles();
64
+ const { type } = props;
65
+ let checked;
66
+ let disabled;
67
+ if ('checked' in props) {
68
+ ;
69
+ ({ checked, disabled } = props);
101
70
  }
102
- } else if (type === 'radio') {
103
- if (checked) {
104
- var _color = disabled ? 'inherit' : 'secondary';
105
-
106
- icon = /*#__PURE__*/_react.default.createElement(_RadioButtonChecked.default, {
107
- color: _color
108
- });
109
- } else {
110
- icon = /*#__PURE__*/_react.default.createElement(_RadioButtonUnchecked.default, {
111
- color: "action"
112
- });
71
+ let icon;
72
+ if (type === 'subMenu') {
73
+ icon = react_1.default.createElement(ArrowRight_1.default, { color: "action" });
113
74
  }
114
- }
115
-
116
- return /*#__PURE__*/_react.default.createElement("div", {
117
- className: classes.menuItemEndDecoration
118
- }, icon);
75
+ else if (type === 'checkbox') {
76
+ if (checked) {
77
+ const color = disabled ? 'inherit' : 'secondary';
78
+ icon = react_1.default.createElement(CheckBox_1.default, { color: color });
79
+ }
80
+ else {
81
+ icon = react_1.default.createElement(CheckBoxOutlineBlank_1.default, { color: "action" });
82
+ }
83
+ }
84
+ else if (type === 'radio') {
85
+ if (checked) {
86
+ const color = disabled ? 'inherit' : 'secondary';
87
+ icon = react_1.default.createElement(RadioButtonChecked_1.default, { color: color });
88
+ }
89
+ else {
90
+ icon = react_1.default.createElement(RadioButtonUnchecked_1.default, { color: "action" });
91
+ }
92
+ }
93
+ return react_1.default.createElement("div", { className: classes.menuItemEndDecoration }, icon);
119
94
  }
120
-
95
+ exports.MenuItemEndDecoration = MenuItemEndDecoration;
121
96
  function findNextValidIdx(menuItems, currentIdx) {
122
- var idx = menuItems.slice(currentIdx + 1).findIndex(function (menuItem) {
123
- return menuItem.type !== 'divider' && menuItem.type !== 'subHeader' && !menuItem.disabled;
124
- });
125
-
126
- if (idx === -1) {
127
- return idx;
128
- }
129
-
130
- return currentIdx + 1 + idx;
97
+ const idx = menuItems
98
+ .slice(currentIdx + 1)
99
+ .findIndex(menuItem => menuItem.type !== 'divider' &&
100
+ menuItem.type !== 'subHeader' &&
101
+ !menuItem.disabled);
102
+ if (idx === -1) {
103
+ return idx;
104
+ }
105
+ return currentIdx + 1 + idx;
131
106
  }
132
-
133
107
  function findPreviousValidIdx(menuItems, currentIdx) {
134
- return (0, _util.findLastIndex)(menuItems.slice(0, currentIdx), function (menuItem) {
135
- return menuItem.type !== 'divider' && menuItem.type !== 'subHeader' && !menuItem.disabled;
136
- });
108
+ return (0, util_1.findLastIndex)(menuItems.slice(0, currentIdx), menuItem => menuItem.type !== 'divider' &&
109
+ menuItem.type !== 'subHeader' &&
110
+ !menuItem.disabled);
137
111
  }
138
-
139
- var MenuPage = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
140
- var _useState = (0, _react.useState)(),
141
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
142
- subMenuAnchorEl = _useState2[0],
143
- setSubMenuAnchorEl = _useState2[1];
144
-
145
- var _useState3 = (0, _react.useState)(),
146
- _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
147
- openSubMenuIdx = _useState4[0],
148
- setOpenSubMenuIdx = _useState4[1];
149
-
150
- var _useState5 = (0, _react.useState)(false),
151
- _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
152
- isSubMenuOpen = _useState6[0],
153
- setIsSubMenuOpen = _useState6[1];
154
-
155
- var _useState7 = (0, _react.useState)(),
156
- _useState8 = (0, _slicedToArray2.default)(_useState7, 2),
157
- selectedMenuItemIdx = _useState8[0],
158
- setSelectedMenuItemIdx = _useState8[1];
159
-
160
- var _useState9 = (0, _react.useState)(),
161
- _useState10 = (0, _slicedToArray2.default)(_useState9, 2),
162
- position = _useState10[0],
163
- setPosition = _useState10[1];
164
-
165
- var paperRef = (0, _react.useRef)(null);
166
-
167
- var _useStyles2 = useStyles(),
168
- classes = _useStyles2.classes;
169
-
170
- var menuItems = props.menuItems,
171
- onMenuItemClick = props.onMenuItemClick,
172
- open = props.open,
173
- onClose = props.onClose,
174
- anchorEl = props.anchorEl,
175
- _props$top = props.top,
176
- top = _props$top === void 0 ? false : _props$top;
177
- (0, _react.useEffect)(function () {
178
- if (!open) {
179
- setSubMenuAnchorEl(undefined);
180
- setOpenSubMenuIdx(undefined);
181
- }
182
- }, [open]);
183
- (0, _react.useEffect)(function () {
184
- var shouldSubMenuBeOpen = open && Boolean(subMenuAnchorEl);
185
- var timer;
186
-
187
- if (shouldSubMenuBeOpen && !isSubMenuOpen) {
188
- timer = setTimeout(function () {
189
- setIsSubMenuOpen(true);
190
- }, 300);
191
- } else if (!shouldSubMenuBeOpen && isSubMenuOpen) {
192
- timer = setTimeout(function () {
193
- setIsSubMenuOpen(false);
194
- }, 300);
195
- }
196
-
197
- return function () {
198
- clearTimeout(timer);
199
- };
200
- }, [isSubMenuOpen, open, subMenuAnchorEl]);
201
- (0, _react.useEffect)(function () {
202
- if (anchorEl) {
203
- var rect = anchorEl.getBoundingClientRect();
204
-
205
- if (position) {
206
- if (rect.top !== position.top || rect.left + rect.width !== position.left) {
207
- setPosition({
208
- top: rect.top,
209
- left: rect.left + rect.width
210
- });
112
+ const MenuPage = react_1.default.forwardRef((props, ref) => {
113
+ const [subMenuAnchorEl, setSubMenuAnchorEl] = (0, react_1.useState)();
114
+ const [openSubMenuIdx, setOpenSubMenuIdx] = (0, react_1.useState)();
115
+ const [isSubMenuOpen, setIsSubMenuOpen] = (0, react_1.useState)(false);
116
+ const [selectedMenuItemIdx, setSelectedMenuItemIdx] = (0, react_1.useState)();
117
+ const [position, setPosition] = (0, react_1.useState)();
118
+ const paperRef = (0, react_1.useRef)(null);
119
+ const { classes } = useStyles();
120
+ const { menuItems, onMenuItemClick, open, onClose, anchorEl, top = false, } = props;
121
+ (0, react_1.useEffect)(() => {
122
+ if (!open) {
123
+ setSubMenuAnchorEl(undefined);
124
+ setOpenSubMenuIdx(undefined);
211
125
  }
212
- } else {
213
- setPosition({
214
- top: rect.top,
215
- left: rect.left + rect.width
216
- });
217
- }
218
- } else if (!position) {
219
- setPosition({});
220
- }
221
- }, [position, anchorEl]);
222
- var hasIcon = menuItems.some(function (menuItem) {
223
- return 'icon' in menuItem && menuItem.icon;
224
- });
225
- var menuItemStyle = {};
226
-
227
- function handleClick(callback) {
228
- return function (event) {
229
- onMenuItemClick(event, callback);
230
- };
231
- }
232
-
233
- var ListContents = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_material.MenuList, {
234
- autoFocusItem: open && !isSubMenuOpen,
235
- dense: true
236
- }, menuItems.sort(function (a, b) {
237
- return (b.priority || 0) - (a.priority || 0);
238
- }).map(function (menuItem, idx) {
239
- if (menuItem.type === 'divider') {
240
- return /*#__PURE__*/_react.default.createElement(_material.Divider, {
241
- key: "divider-".concat(idx),
242
- component: "li"
243
- });
244
- }
245
-
246
- if (menuItem.type === 'subHeader') {
247
- return /*#__PURE__*/_react.default.createElement(_material.ListSubheader, {
248
- key: "subHeader-".concat(menuItem.label, "-").concat(idx)
249
- }, menuItem.label);
250
- }
251
-
252
- var icon = null;
253
- var endDecoration = null;
254
-
255
- if (menuItem.icon) {
256
- var Icon = menuItem.icon;
257
- icon = /*#__PURE__*/_react.default.createElement(_material.ListItemIcon, null, /*#__PURE__*/_react.default.createElement(Icon, null));
258
- }
259
-
260
- if ('subMenu' in menuItem) {
261
- endDecoration = /*#__PURE__*/_react.default.createElement(MenuItemEndDecoration, {
262
- type: "subMenu"
263
- });
264
- } else if (menuItem.type === 'checkbox' || menuItem.type === 'radio') {
265
- endDecoration = /*#__PURE__*/_react.default.createElement(MenuItemEndDecoration, {
266
- type: menuItem.type,
267
- checked: menuItem.checked,
268
- disabled: menuItem.disabled
269
- });
270
- }
271
-
272
- var onClick = 'onClick' in menuItem ? handleClick(menuItem.onClick) : undefined;
273
- return /*#__PURE__*/_react.default.createElement(_material.MenuItem, {
274
- key: menuItem.label,
275
- style: menuItemStyle,
276
- selected: idx === selectedMenuItemIdx,
277
- onClick: onClick,
278
- onMouseMove: function onMouseMove(e) {
279
- if (e.currentTarget !== document.activeElement) {
280
- e.currentTarget.focus();
281
- setSelectedMenuItemIdx(idx);
126
+ }, [open]);
127
+ (0, react_1.useEffect)(() => {
128
+ const shouldSubMenuBeOpen = open && Boolean(subMenuAnchorEl);
129
+ let timer;
130
+ if (shouldSubMenuBeOpen && !isSubMenuOpen) {
131
+ timer = setTimeout(() => {
132
+ setIsSubMenuOpen(true);
133
+ }, 300);
134
+ }
135
+ else if (!shouldSubMenuBeOpen && isSubMenuOpen) {
136
+ timer = setTimeout(() => {
137
+ setIsSubMenuOpen(false);
138
+ }, 300);
282
139
  }
283
-
284
- if ('subMenu' in menuItem) {
285
- if (openSubMenuIdx !== idx) {
286
- setSubMenuAnchorEl(e.currentTarget);
287
- setOpenSubMenuIdx(idx);
288
- }
289
- } else {
290
- setSubMenuAnchorEl(undefined);
291
- setOpenSubMenuIdx(undefined);
140
+ return () => {
141
+ clearTimeout(timer);
142
+ };
143
+ }, [isSubMenuOpen, open, subMenuAnchorEl]);
144
+ (0, react_1.useEffect)(() => {
145
+ if (anchorEl) {
146
+ const rect = anchorEl.getBoundingClientRect();
147
+ if (position) {
148
+ if (rect.top !== position.top ||
149
+ rect.left + rect.width !== position.left) {
150
+ setPosition({ top: rect.top, left: rect.left + rect.width });
151
+ }
152
+ }
153
+ else {
154
+ setPosition({ top: rect.top, left: rect.left + rect.width });
155
+ }
292
156
  }
293
- },
294
- onKeyDown: function onKeyDown(e) {
295
- if (e.key === 'ArrowLeft' || e.key === 'Escape') {
296
- onClose && onClose(e, 'escapeKeyDown');
297
- } else if (e.key === 'ArrowUp') {
298
- setSelectedMenuItemIdx(findPreviousValidIdx(menuItems, idx));
299
- } else if (e.key === 'ArrowDown') {
300
- var a = findNextValidIdx(menuItems, idx);
301
- setSelectedMenuItemIdx(a);
302
- } else if ('subMenu' in menuItem) {
303
- if (e.key === 'ArrowRight' || e.key === 'Enter') {
304
- setSubMenuAnchorEl(e.currentTarget);
305
- setOpenSubMenuIdx(idx);
306
- setIsSubMenuOpen(true);
307
- }
157
+ else if (!position) {
158
+ setPosition({});
308
159
  }
309
- },
310
- disabled: Boolean(menuItem.disabled)
311
- }, icon, /*#__PURE__*/_react.default.createElement(_material.ListItemText, {
312
- primary: menuItem.label,
313
- secondary: menuItem.subLabel,
314
- inset: hasIcon && !menuItem.icon
315
- }), endDecoration);
316
- })), menuItems.map(function (menuItem, idx) {
317
- var subMenu = null;
318
-
319
- if ('subMenu' in menuItem) {
320
- subMenu = /*#__PURE__*/_react.default.createElement(MenuPage, {
321
- key: menuItem.label,
322
- anchorEl: subMenuAnchorEl,
323
- open: isSubMenuOpen && openSubMenuIdx === idx,
324
- onClose: function onClose() {
325
- setIsSubMenuOpen(false);
326
- setSubMenuAnchorEl(undefined);
327
- },
328
- onMenuItemClick: onMenuItemClick,
329
- menuItems: menuItem.subMenu
330
- });
160
+ }, [position, anchorEl]);
161
+ const hasIcon = menuItems.some(menuItem => 'icon' in menuItem && menuItem.icon);
162
+ const menuItemStyle = {};
163
+ function handleClick(callback) {
164
+ return (event) => {
165
+ onMenuItemClick(event, callback);
166
+ };
331
167
  }
332
-
333
- return subMenu;
334
- }));
335
-
336
- return top ? ListContents : /*#__PURE__*/_react.default.createElement(_material.Grow, {
337
- in: open,
338
- style: {
339
- transformOrigin: "0 0 0"
340
- },
341
- ref: ref
342
- }, /*#__PURE__*/_react.default.createElement(_material.Paper, {
343
- elevation: 8,
344
- ref: paperRef,
345
- className: classes.paper,
346
- style: _objectSpread({}, position)
347
- }, ListContents));
168
+ const ListContents = (react_1.default.createElement(react_1.default.Fragment, null,
169
+ react_1.default.createElement(material_1.MenuList, { autoFocusItem: open && !isSubMenuOpen, dense: true }, menuItems
170
+ .sort((a, b) => (b.priority || 0) - (a.priority || 0))
171
+ .map((menuItem, idx) => {
172
+ if (menuItem.type === 'divider') {
173
+ return react_1.default.createElement(material_1.Divider, { key: `divider-${idx}`, component: "li" });
174
+ }
175
+ if (menuItem.type === 'subHeader') {
176
+ return (react_1.default.createElement(material_1.ListSubheader, { key: `subHeader-${menuItem.label}-${idx}` }, menuItem.label));
177
+ }
178
+ let icon = null;
179
+ let endDecoration = null;
180
+ if (menuItem.icon) {
181
+ const Icon = menuItem.icon;
182
+ icon = (react_1.default.createElement(material_1.ListItemIcon, null,
183
+ react_1.default.createElement(Icon, null)));
184
+ }
185
+ if ('subMenu' in menuItem) {
186
+ endDecoration = react_1.default.createElement(MenuItemEndDecoration, { type: "subMenu" });
187
+ }
188
+ else if (menuItem.type === 'checkbox' ||
189
+ menuItem.type === 'radio') {
190
+ endDecoration = (react_1.default.createElement(MenuItemEndDecoration, { type: menuItem.type, checked: menuItem.checked, disabled: menuItem.disabled }));
191
+ }
192
+ const onClick = 'onClick' in menuItem
193
+ ? handleClick(menuItem.onClick)
194
+ : undefined;
195
+ return (react_1.default.createElement(material_1.MenuItem, { key: menuItem.label, style: menuItemStyle, selected: idx === selectedMenuItemIdx, onClick: onClick, onMouseMove: e => {
196
+ if (e.currentTarget !== document.activeElement) {
197
+ e.currentTarget.focus();
198
+ setSelectedMenuItemIdx(idx);
199
+ }
200
+ if ('subMenu' in menuItem) {
201
+ if (openSubMenuIdx !== idx) {
202
+ setSubMenuAnchorEl(e.currentTarget);
203
+ setOpenSubMenuIdx(idx);
204
+ }
205
+ }
206
+ else {
207
+ setSubMenuAnchorEl(undefined);
208
+ setOpenSubMenuIdx(undefined);
209
+ }
210
+ }, onKeyDown: e => {
211
+ if (e.key === 'ArrowLeft' || e.key === 'Escape') {
212
+ onClose && onClose(e, 'escapeKeyDown');
213
+ }
214
+ else if (e.key === 'ArrowUp') {
215
+ setSelectedMenuItemIdx(findPreviousValidIdx(menuItems, idx));
216
+ }
217
+ else if (e.key === 'ArrowDown') {
218
+ const a = findNextValidIdx(menuItems, idx);
219
+ setSelectedMenuItemIdx(a);
220
+ }
221
+ else if ('subMenu' in menuItem) {
222
+ if (e.key === 'ArrowRight' || e.key === 'Enter') {
223
+ setSubMenuAnchorEl(e.currentTarget);
224
+ setOpenSubMenuIdx(idx);
225
+ setIsSubMenuOpen(true);
226
+ }
227
+ }
228
+ }, disabled: Boolean(menuItem.disabled) },
229
+ icon,
230
+ react_1.default.createElement(material_1.ListItemText, { primary: menuItem.label, secondary: menuItem.subLabel, inset: hasIcon && !menuItem.icon }),
231
+ endDecoration));
232
+ })),
233
+ menuItems.map((menuItem, idx) => {
234
+ let subMenu = null;
235
+ if ('subMenu' in menuItem) {
236
+ subMenu = (react_1.default.createElement(MenuPage, { key: menuItem.label, anchorEl: subMenuAnchorEl, open: isSubMenuOpen && openSubMenuIdx === idx, onClose: () => {
237
+ setIsSubMenuOpen(false);
238
+ setSubMenuAnchorEl(undefined);
239
+ }, onMenuItemClick: onMenuItemClick, menuItems: menuItem.subMenu }));
240
+ }
241
+ return subMenu;
242
+ })));
243
+ return top ? (ListContents) : (react_1.default.createElement(material_1.Grow, { in: open, style: { transformOrigin: `0 0 0` }, ref: ref },
244
+ react_1.default.createElement(material_1.Paper, { elevation: 8, ref: paperRef, className: classes.paper, style: { ...position } }, ListContents)));
348
245
  });
349
-
350
246
  function Menu(props) {
351
- var open = props.open,
352
- onClose = props.onClose,
353
- menuItems = props.menuItems,
354
- onMenuItemClick = props.onMenuItemClick,
355
- other = (0, _objectWithoutProperties2.default)(props, _excluded);
356
- return /*#__PURE__*/_react.default.createElement(_material.Popover, (0, _extends2.default)({
357
- transitionDuration: 0,
358
- open: open,
359
- onClose: onClose,
360
- BackdropProps: {
361
- invisible: true
362
- }
363
- }, other), /*#__PURE__*/_react.default.createElement(MenuPage, {
364
- open: open,
365
- onClose: onClose,
366
- menuItems: menuItems,
367
- onMenuItemClick: onMenuItemClick,
368
- top: true
369
- }));
247
+ const { open, onClose, menuItems, onMenuItemClick, ...other } = props;
248
+ return (react_1.default.createElement(material_1.Popover, { transitionDuration: 0, open: open, onClose: onClose, BackdropProps: { invisible: true }, ...other },
249
+ react_1.default.createElement(MenuPage, { open: open, onClose: onClose, menuItems: menuItems, onMenuItemClick: onMenuItemClick, top: true })));
370
250
  }
371
-
372
- var _default = Menu;
373
- exports.default = _default;
251
+ exports.default = Menu;