@jbrowse/core 2.0.1 → 2.1.0

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 (179) hide show
  1. package/BaseFeatureWidget/BaseFeatureDetail.d.ts +6 -0
  2. package/BaseFeatureWidget/BaseFeatureDetail.js +313 -592
  3. package/BaseFeatureWidget/SequenceFeatureDetails.js +213 -479
  4. package/BaseFeatureWidget/index.js +88 -126
  5. package/BaseFeatureWidget/types.js +1 -4
  6. package/BaseFeatureWidget/util.js +40 -75
  7. package/CorePlugin.js +55 -94
  8. package/Plugin.js +9 -34
  9. package/PluginLoader.js +153 -422
  10. package/PluginManager.d.ts +17 -14
  11. package/PluginManager.js +377 -666
  12. package/ReExports/Attributes.js +3 -10
  13. package/ReExports/BaseCard.js +3 -10
  14. package/ReExports/DataGrid.js +5 -12
  15. package/ReExports/FeatureDetails.js +3 -10
  16. package/ReExports/index.js +6 -12
  17. package/ReExports/list.d.ts +5 -0
  18. package/ReExports/list.js +271 -7
  19. package/ReExports/material-ui-colors.js +15 -16
  20. package/ReExports/modules.d.ts +0 -1
  21. package/ReExports/modules.js +453 -798
  22. package/TextSearch/BaseResults.js +51 -123
  23. package/TextSearch/TextSearchManager.js +66 -144
  24. package/assemblyManager/assembly.js +280 -555
  25. package/assemblyManager/assemblyConfigSchema.js +47 -64
  26. package/assemblyManager/assemblyManager.js +126 -272
  27. package/assemblyManager/index.js +9 -22
  28. package/configuration/configurationSchema.js +167 -203
  29. package/configuration/configurationSlot.js +248 -326
  30. package/configuration/index.js +19 -35
  31. package/configuration/util.js +131 -173
  32. package/data_adapters/BaseAdapter.d.ts +2 -2
  33. package/data_adapters/BaseAdapter.js +132 -521
  34. package/data_adapters/CytobandAdapter.js +40 -126
  35. package/data_adapters/dataAdapterCache.js +77 -158
  36. package/package.json +4 -5
  37. package/pluggableElementTypes/AdapterType.js +24 -79
  38. package/pluggableElementTypes/AddTrackWorkflowType.d.ts +17 -0
  39. package/pluggableElementTypes/AddTrackWorkflowType.js +20 -0
  40. package/pluggableElementTypes/ConnectionType.js +22 -65
  41. package/pluggableElementTypes/DisplayType.js +35 -82
  42. package/pluggableElementTypes/InternetAccountType.js +23 -64
  43. package/pluggableElementTypes/PluggableElementBase.js +8 -20
  44. package/pluggableElementTypes/RpcMethodType.js +85 -427
  45. package/pluggableElementTypes/TextSearchAdapterType.js +16 -55
  46. package/pluggableElementTypes/TrackType.js +26 -70
  47. package/pluggableElementTypes/ViewType.js +21 -63
  48. package/pluggableElementTypes/WidgetType.js +21 -64
  49. package/pluggableElementTypes/index.d.ts +4 -3
  50. package/pluggableElementTypes/index.js +42 -125
  51. package/pluggableElementTypes/models/BaseConnectionModelFactory.js +28 -43
  52. package/pluggableElementTypes/models/BaseDisplayModel.js +58 -95
  53. package/pluggableElementTypes/models/BaseTrackModel.js +139 -199
  54. package/pluggableElementTypes/models/BaseViewModel.js +24 -40
  55. package/pluggableElementTypes/models/InternetAccountModel.js +116 -263
  56. package/pluggableElementTypes/models/baseConnectionConfig.js +14 -25
  57. package/pluggableElementTypes/models/baseInternetAccountConfig.js +29 -38
  58. package/pluggableElementTypes/models/baseTrackConfig.js +106 -133
  59. package/pluggableElementTypes/models/index.js +21 -70
  60. package/pluggableElementTypes/renderers/BoxRendererType.js +132 -291
  61. package/pluggableElementTypes/renderers/CircularChordRendererType.js +8 -38
  62. package/pluggableElementTypes/renderers/ComparativeServerSideRendererType.js +60 -192
  63. package/pluggableElementTypes/renderers/FeatureRendererType.d.ts +0 -2
  64. package/pluggableElementTypes/renderers/FeatureRendererType.js +89 -264
  65. package/pluggableElementTypes/renderers/RendererType.js +31 -105
  66. package/pluggableElementTypes/renderers/ServerSideRenderedContent.js +61 -72
  67. package/pluggableElementTypes/renderers/ServerSideRendererType.js +112 -265
  68. package/pluggableElementTypes/renderers/index.js +19 -62
  69. package/pluggableElementTypes/renderers/util/serializableFilterChain.js +27 -65
  70. package/rpc/BaseRpcDriver.js +169 -405
  71. package/rpc/MainThreadRpcDriver.js +27 -150
  72. package/rpc/RpcManager.js +58 -159
  73. package/rpc/WebWorkerRpcDriver.js +54 -171
  74. package/rpc/configSchema.js +25 -49
  75. package/rpc/coreRpcMethods.js +221 -959
  76. package/rpc/remoteAbortSignals.js +46 -70
  77. package/tsconfig.build.tsbuildinfo +1 -1
  78. package/ui/AboutDialog.js +106 -162
  79. package/ui/App.js +157 -242
  80. package/ui/AssemblySelector.js +59 -120
  81. package/ui/CascadingMenu.js +101 -196
  82. package/ui/ColorPicker.d.ts +16 -0
  83. package/ui/ColorPicker.js +97 -0
  84. package/ui/Drawer.js +28 -61
  85. package/ui/DrawerWidget.js +108 -202
  86. package/ui/DropDownMenu.js +60 -91
  87. package/ui/EditableTypography.js +87 -149
  88. package/ui/ErrorMessage.js +41 -56
  89. package/ui/FactoryResetDialog.js +24 -57
  90. package/ui/FatalErrorDialog.js +59 -91
  91. package/ui/FileSelector/FileSelector.js +123 -189
  92. package/ui/FileSelector/LocalFileChooser.js +44 -75
  93. package/ui/FileSelector/UrlChooser.js +17 -38
  94. package/ui/FileSelector/index.js +6 -12
  95. package/ui/Icons.js +45 -69
  96. package/ui/Logo.js +57 -110
  97. package/ui/Menu.js +232 -354
  98. package/ui/PrerenderedCanvas.js +63 -87
  99. package/ui/ResizeHandle.js +87 -116
  100. package/ui/ReturnToImportFormDialog.js +32 -63
  101. package/ui/SanitizedHTML.js +64 -47
  102. package/ui/Snackbar.js +74 -101
  103. package/ui/SnackbarModel.js +37 -51
  104. package/ui/Tooltip.js +49 -76
  105. package/ui/ViewContainer.js +113 -196
  106. package/ui/colors.d.ts +10 -0
  107. package/ui/colors.js +78 -0
  108. package/ui/index.js +51 -181
  109. package/ui/react-colorful.d.ts +17 -0
  110. package/ui/react-colorful.js +455 -0
  111. package/ui/theme.js +199 -247
  112. package/util/Base1DUtils.js +163 -202
  113. package/util/Base1DViewModel.js +121 -168
  114. package/util/QuickLRU.js +84 -332
  115. package/util/TimeTraveller.d.ts +19 -0
  116. package/util/TimeTraveller.js +86 -0
  117. package/util/aborting.js +49 -127
  118. package/util/analytics.js +91 -154
  119. package/util/blockTypes.js +106 -240
  120. package/util/calculateDynamicBlocks.js +98 -128
  121. package/util/calculateStaticBlocks.js +105 -125
  122. package/util/color/cssColorsLevel4.js +156 -160
  123. package/util/color/index.js +33 -55
  124. package/util/compositeMap.js +49 -333
  125. package/util/formatFastaStrings.js +9 -14
  126. package/util/idMaker.js +18 -31
  127. package/util/index.d.ts +7 -20
  128. package/util/index.js +742 -1188
  129. package/util/io/RemoteFileWithRangeCache.js +88 -257
  130. package/util/io/index.js +95 -169
  131. package/util/jexl.js +60 -115
  132. package/util/jexlStrings.js +24 -29
  133. package/util/layouts/BaseLayout.js +1 -4
  134. package/util/layouts/GranularRectLayout.js +388 -555
  135. package/util/layouts/MultiLayout.js +41 -109
  136. package/util/layouts/PrecomputedLayout.js +56 -112
  137. package/util/layouts/PrecomputedMultiLayout.js +22 -59
  138. package/util/layouts/SceneGraph.js +127 -197
  139. package/util/layouts/index.js +29 -66
  140. package/util/mst-reflection.js +55 -71
  141. package/util/offscreenCanvasPonyfill.js +66 -134
  142. package/util/offscreenCanvasUtils.d.ts +2 -7
  143. package/util/offscreenCanvasUtils.js +49 -146
  144. package/util/range.js +29 -40
  145. package/util/rxjs.js +20 -27
  146. package/util/simpleFeature.js +88 -152
  147. package/util/stats.js +91 -151
  148. package/util/tracks.js +130 -173
  149. package/util/types/index.js +110 -179
  150. package/util/types/mst.js +91 -146
  151. package/util/types/util.js +1 -4
  152. package/util/when.js +54 -101
  153. package/BaseFeatureWidget/SequenceFeatureDetails.test.js +0 -122
  154. package/BaseFeatureWidget/index.test.js +0 -69
  155. package/TextSearch/BaseResults.test.js +0 -42
  156. package/configuration/configurationSchema.test.js +0 -266
  157. package/configuration/configurationSlot.test.js +0 -69
  158. package/configuration/util.test.js +0 -39
  159. package/data_adapters/BaseAdapter.test.js +0 -200
  160. package/declare.d.js +0 -1
  161. package/pluggableElementTypes/RpcMethodType.test.js +0 -118
  162. package/pluggableElementTypes/renderers/declare.d.js +0 -1
  163. package/pluggableElementTypes/renderers/util/serializableFilterChain.test.js +0 -20
  164. package/rpc/BaseRpcDriver.test.js +0 -540
  165. package/rpc/declaration.d.js +0 -1
  166. package/ui/FatalErrorDialog.test.js +0 -82
  167. package/ui/SanitizedHTML.test.js +0 -36
  168. package/ui/theme.test.js +0 -92
  169. package/util/Base1DViewModel.test.js +0 -130
  170. package/util/calculateDynamicBlocks.test.js +0 -74
  171. package/util/calculateStaticBlocks.test.js +0 -297
  172. package/util/declare.d.js +0 -1
  173. package/util/formatFastaStrings.test.js +0 -40
  174. package/util/index.test.js +0 -213
  175. package/util/jexlStrings.test.js +0 -48
  176. package/util/layouts/GranularRectLayout.test.js +0 -99
  177. package/util/range.test.js +0 -64
  178. package/util/simpleFeature.test.js +0 -34
  179. package/util/stats.test.js +0 -172
@@ -1,218 +1,124 @@
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.default = void 0;
11
-
12
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
-
14
- var _react = _interopRequireWildcard(require("react"));
15
-
16
- var _material = require("@mui/material");
17
-
18
- var _mui = require("tss-react/mui");
19
-
20
- var _mobxReact = require("mobx-react");
21
-
22
- var _mobxStateTree = require("mobx-state-tree");
23
-
24
- var _Delete = _interopRequireDefault(require("@mui/icons-material/Delete"));
25
-
26
- var _Close = _interopRequireDefault(require("@mui/icons-material/Close"));
27
-
28
- var _Minimize = _interopRequireDefault(require("@mui/icons-material/Minimize"));
29
-
30
- var _MoreVert = _interopRequireDefault(require("@mui/icons-material/MoreVert"));
31
-
32
- var _Drawer = _interopRequireDefault(require("./Drawer"));
33
-
34
- 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); }
35
-
36
- 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; }
37
-
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
+ const react_1 = __importStar(require("react"));
30
+ const material_1 = require("@mui/material");
31
+ const mui_1 = require("tss-react/mui");
32
+ const mobx_react_1 = require("mobx-react");
33
+ const mobx_state_tree_1 = require("mobx-state-tree");
38
34
  // icons
35
+ const Delete_1 = __importDefault(require("@mui/icons-material/Delete"));
36
+ const Close_1 = __importDefault(require("@mui/icons-material/Close"));
37
+ const Minimize_1 = __importDefault(require("@mui/icons-material/Minimize"));
38
+ const MoreVert_1 = __importDefault(require("@mui/icons-material/MoreVert"));
39
39
  // locals
40
- var useStyles = (0, _mui.makeStyles)()(function (theme) {
41
- return {
40
+ const Drawer_1 = __importDefault(require("./Drawer"));
41
+ const useStyles = (0, mui_1.makeStyles)()(theme => ({
42
42
  formControl: {
43
- margin: 0
43
+ margin: 0,
44
44
  },
45
45
  spacer: {
46
- flexGrow: 1
46
+ flexGrow: 1,
47
47
  },
48
48
  drawerSelect: {
49
- margin: 0,
50
- color: theme.palette.secondary.contrastText
49
+ margin: 0,
50
+ color: theme.palette.secondary.contrastText,
51
51
  },
52
52
  dropDownIcon: {
53
- color: theme.palette.secondary.contrastText
53
+ color: theme.palette.secondary.contrastText,
54
54
  },
55
55
  header: {
56
- background: theme.palette.secondary.main
57
- }
58
- };
59
- });
60
- var DrawerHeader = (0, _mobxReact.observer)(function (_ref) {
61
- var session = _ref.session,
62
- setToolbarHeight = _ref.setToolbarHeight;
63
-
64
- var _getEnv = (0, _mobxStateTree.getEnv)(session),
65
- pluginManager = _getEnv.pluginManager;
66
-
67
- var visibleWidget = session.visibleWidget,
68
- activeWidgets = session.activeWidgets,
69
- drawerPosition = session.drawerPosition;
70
-
71
- var _useStyles = useStyles(),
72
- classes = _useStyles.classes;
73
-
74
- var _React$useState = _react.default.useState(null),
75
- _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
76
- anchorEl = _React$useState2[0],
77
- setAnchorEl = _React$useState2[1];
78
-
79
- return /*#__PURE__*/_react.default.createElement(_material.AppBar, {
80
- position: "sticky",
81
- className: classes.header,
82
- ref: function ref(_ref2) {
83
- return setToolbarHeight((_ref2 === null || _ref2 === void 0 ? void 0 : _ref2.getBoundingClientRect().height) || 0);
84
- }
85
- }, /*#__PURE__*/_react.default.createElement(_material.Toolbar, {
86
- disableGutters: true
87
- }, /*#__PURE__*/_react.default.createElement(_material.FormControl, {
88
- className: classes.formControl
89
- }, /*#__PURE__*/_react.default.createElement(_material.Select, {
90
- value: visibleWidget === null || visibleWidget === void 0 ? void 0 : visibleWidget.id,
91
- "data-testid": "widget-drawer-selects",
92
- className: classes.drawerSelect,
93
- classes: {
94
- icon: classes.dropDownIcon
95
- },
96
- renderValue: function renderValue(widgetId) {
97
- var widget = session.activeWidgets.get(widgetId);
98
-
99
- if (!widget) {
100
- return /*#__PURE__*/_react.default.createElement(_material.Typography, {
101
- variant: "h6",
102
- color: "inherit"
103
- }, "Unknown widget");
104
- }
105
-
106
- var widgetType = pluginManager.getWidgetType(widget.type);
107
- var HeadingComponent = widgetType.HeadingComponent,
108
- heading = widgetType.heading;
109
- return HeadingComponent ? /*#__PURE__*/_react.default.createElement(HeadingComponent, {
110
- model: widget
111
- }) : /*#__PURE__*/_react.default.createElement(_material.Typography, {
112
- variant: "h6",
113
- color: "inherit"
114
- }, heading);
56
+ background: theme.palette.secondary.main,
115
57
  },
116
- onChange: function onChange(e) {
117
- var w = session.activeWidgets.get(e.target.value);
118
-
119
- if (!w) {
120
- session.notify("Widget not found ".concat(e.target.value), 'warning');
121
- } else {
122
- session.showWidget(w);
123
- }
124
- }
125
- }, Array.from(activeWidgets.values()).map(function (widget) {
126
- var widgetType = pluginManager.getWidgetType(widget.type);
127
- var HeadingComponent = widgetType.HeadingComponent,
128
- heading = widgetType.heading;
129
- return /*#__PURE__*/_react.default.createElement(_material.MenuItem, {
130
- "data-testid": "widget-drawer-selects-item-".concat(widget.type),
131
- key: widget.id,
132
- value: widget.id
133
- }, HeadingComponent ? /*#__PURE__*/_react.default.createElement(HeadingComponent, {
134
- model: widget
135
- }) : /*#__PURE__*/_react.default.createElement(_material.Typography, {
136
- variant: "h6",
137
- color: "inherit"
138
- }, heading), /*#__PURE__*/_react.default.createElement(_material.IconButton, {
139
- "data-testid": "".concat(widget.type, "-drawer-delete"),
140
- color: "inherit",
141
- "aria-label": "Delete",
142
- onClick: function onClick() {
143
- return session.hideWidget(widget);
144
- }
145
- }, /*#__PURE__*/_react.default.createElement(_Delete.default, null)));
146
- }))), /*#__PURE__*/_react.default.createElement("div", {
147
- className: classes.spacer
148
- }), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_material.IconButton, {
149
- "data-testid": "drawer-close",
150
- color: "inherit",
151
- onClick: function onClick(event) {
152
- return setAnchorEl(event.currentTarget);
153
- }
154
- }, /*#__PURE__*/_react.default.createElement(_MoreVert.default, null)), /*#__PURE__*/_react.default.createElement(_material.Tooltip, {
155
- title: "Minimize drawer"
156
- }, /*#__PURE__*/_react.default.createElement(_material.IconButton, {
157
- "data-testid": "drawer-minimize",
158
- color: "inherit",
159
- onClick: function onClick() {
160
- session.notify("Drawer minimized, click button on ".concat(drawerPosition, " side of screen to re-open"), 'info');
161
- session.minimizeWidgetDrawer();
162
- }
163
- }, /*#__PURE__*/_react.default.createElement(_Minimize.default, null))), /*#__PURE__*/_react.default.createElement(_material.Tooltip, {
164
- title: "Close drawer"
165
- }, /*#__PURE__*/_react.default.createElement(_material.IconButton, {
166
- "data-testid": "drawer-close",
167
- color: "inherit",
168
- onClick: function onClick() {
169
- return session.hideWidget(visibleWidget);
170
- }
171
- }, /*#__PURE__*/_react.default.createElement(_Close.default, null))))), /*#__PURE__*/_react.default.createElement(_material.Menu, {
172
- anchorEl: anchorEl,
173
- open: Boolean(anchorEl),
174
- onClose: function onClose() {
175
- return setAnchorEl(null);
176
- }
177
- }, ['left', 'right'].map(function (option) {
178
- return /*#__PURE__*/_react.default.createElement(_material.MenuItem, {
179
- key: option,
180
- selected: drawerPosition === 'option',
181
- onClick: function onClick() {
182
- session.setDrawerPosition(option);
183
- setAnchorEl(null);
184
- }
185
- }, option);
186
- })));
58
+ }));
59
+ const DrawerHeader = (0, mobx_react_1.observer)(({ session, setToolbarHeight, }) => {
60
+ const { pluginManager } = (0, mobx_state_tree_1.getEnv)(session);
61
+ const { visibleWidget, activeWidgets, drawerPosition } = session;
62
+ const { classes } = useStyles();
63
+ const [anchorEl, setAnchorEl] = react_1.default.useState(null);
64
+ return (react_1.default.createElement(material_1.AppBar, { position: "sticky", className: classes.header, ref: ref => setToolbarHeight((ref === null || ref === void 0 ? void 0 : ref.getBoundingClientRect().height) || 0) },
65
+ react_1.default.createElement(material_1.Toolbar, { disableGutters: true },
66
+ react_1.default.createElement(material_1.FormControl, { className: classes.formControl },
67
+ react_1.default.createElement(material_1.Select, { value: visibleWidget === null || visibleWidget === void 0 ? void 0 : visibleWidget.id, "data-testid": "widget-drawer-selects", className: classes.drawerSelect, classes: { icon: classes.dropDownIcon }, renderValue: widgetId => {
68
+ const widget = session.activeWidgets.get(widgetId);
69
+ if (!widget) {
70
+ return (react_1.default.createElement(material_1.Typography, { variant: "h6", color: "inherit" }, "Unknown widget"));
71
+ }
72
+ const widgetType = pluginManager.getWidgetType(widget.type);
73
+ const { HeadingComponent, heading } = widgetType;
74
+ return HeadingComponent ? (react_1.default.createElement(HeadingComponent, { model: widget })) : (react_1.default.createElement(material_1.Typography, { variant: "h6", color: "inherit" }, heading));
75
+ }, onChange: e => {
76
+ const w = session.activeWidgets.get(e.target.value);
77
+ if (!w) {
78
+ session.notify(`Widget not found ${e.target.value}`, 'warning');
79
+ }
80
+ else {
81
+ session.showWidget(w);
82
+ }
83
+ } }, Array.from(activeWidgets.values()).map(widget => {
84
+ const widgetType = pluginManager.getWidgetType(widget.type);
85
+ const { HeadingComponent, heading } = widgetType;
86
+ return (react_1.default.createElement(material_1.MenuItem, { "data-testid": `widget-drawer-selects-item-${widget.type}`, key: widget.id, value: widget.id },
87
+ HeadingComponent ? (react_1.default.createElement(HeadingComponent, { model: widget })) : (react_1.default.createElement(material_1.Typography, { variant: "h6", color: "inherit" }, heading)),
88
+ react_1.default.createElement(material_1.IconButton, { "data-testid": `${widget.type}-drawer-delete`, color: "inherit", "aria-label": "Delete", onClick: () => session.hideWidget(widget) },
89
+ react_1.default.createElement(Delete_1.default, null))));
90
+ }))),
91
+ react_1.default.createElement("div", { className: classes.spacer }),
92
+ react_1.default.createElement("div", null,
93
+ react_1.default.createElement(material_1.IconButton, { "data-testid": "drawer-close", color: "inherit", onClick: event => setAnchorEl(event.currentTarget) },
94
+ react_1.default.createElement(MoreVert_1.default, null)),
95
+ react_1.default.createElement(material_1.Tooltip, { title: "Minimize drawer" },
96
+ react_1.default.createElement(material_1.IconButton, { "data-testid": "drawer-minimize", color: "inherit", onClick: () => {
97
+ session.notify(`Drawer minimized, click button on ${drawerPosition} side of screen to re-open`, 'info');
98
+ session.minimizeWidgetDrawer();
99
+ } },
100
+ react_1.default.createElement(Minimize_1.default, null))),
101
+ react_1.default.createElement(material_1.Tooltip, { title: "Close drawer" },
102
+ react_1.default.createElement(material_1.IconButton, { "data-testid": "drawer-close", color: "inherit", onClick: () => session.hideWidget(visibleWidget) },
103
+ react_1.default.createElement(Close_1.default, null))))),
104
+ react_1.default.createElement(material_1.Menu, { anchorEl: anchorEl, open: Boolean(anchorEl), onClose: () => setAnchorEl(null) }, ['left', 'right'].map(option => (react_1.default.createElement(material_1.MenuItem, { key: option, selected: drawerPosition === 'option', onClick: () => {
105
+ session.setDrawerPosition(option);
106
+ setAnchorEl(null);
107
+ } }, option))))));
187
108
  });
188
- var DrawerWidget = (0, _mobxReact.observer)(function (_ref3) {
189
- var session = _ref3.session;
190
- var visibleWidget = session.visibleWidget;
191
-
192
- var _getEnv2 = (0, _mobxStateTree.getEnv)(session),
193
- pluginManager = _getEnv2.pluginManager;
194
-
195
- var DrawerComponent = visibleWidget ? pluginManager.getWidgetType(visibleWidget.type).ReactComponent : null; // we track the toolbar height because components that use virtualized
196
- // height want to be able to fill the contained, minus the toolbar height
197
- // (the position static/sticky is included in AutoSizer estimates)
198
-
199
- var _useState = (0, _react.useState)(0),
200
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
201
- toolbarHeight = _useState2[0],
202
- setToolbarHeight = _useState2[1];
203
-
204
- return /*#__PURE__*/_react.default.createElement(_Drawer.default, {
205
- session: session
206
- }, /*#__PURE__*/_react.default.createElement(DrawerHeader, {
207
- session: session,
208
- setToolbarHeight: setToolbarHeight
209
- }), /*#__PURE__*/_react.default.createElement(_react.Suspense, {
210
- fallback: /*#__PURE__*/_react.default.createElement("div", null, "Loading...")
211
- }, /*#__PURE__*/_react.default.createElement(DrawerComponent, {
212
- model: visibleWidget,
213
- session: session,
214
- toolbarHeight: toolbarHeight
215
- })));
109
+ const DrawerWidget = (0, mobx_react_1.observer)(({ session }) => {
110
+ const { visibleWidget } = session;
111
+ const { pluginManager } = (0, mobx_state_tree_1.getEnv)(session);
112
+ const DrawerComponent = visibleWidget
113
+ ? pluginManager.getWidgetType(visibleWidget.type).ReactComponent
114
+ : null;
115
+ // we track the toolbar height because components that use virtualized
116
+ // height want to be able to fill the contained, minus the toolbar height
117
+ // (the position static/sticky is included in AutoSizer estimates)
118
+ const [toolbarHeight, setToolbarHeight] = (0, react_1.useState)(0);
119
+ return (react_1.default.createElement(Drawer_1.default, { session: session },
120
+ react_1.default.createElement(DrawerHeader, { session: session, setToolbarHeight: setToolbarHeight }),
121
+ react_1.default.createElement(react_1.Suspense, { fallback: react_1.default.createElement("div", null, "Loading...") },
122
+ react_1.default.createElement(DrawerComponent, { model: visibleWidget, session: session, toolbarHeight: toolbarHeight }))));
216
123
  });
217
- var _default = DrawerWidget;
218
- exports.default = _default;
124
+ exports.default = DrawerWidget;
@@ -1,99 +1,68 @@
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.default = void 0;
11
-
12
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
-
14
- var _react = _interopRequireWildcard(require("react"));
15
-
16
- var _material = require("@mui/material");
17
-
18
- var _mui = require("tss-react/mui");
19
-
20
- var _mobxReact = require("mobx-react");
21
-
22
- var _ArrowDropDown = _interopRequireDefault(require("@mui/icons-material/ArrowDropDown"));
23
-
24
- var _Menu = _interopRequireDefault(require("./Menu"));
25
-
26
- 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); }
27
-
28
- 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; }
29
-
30
- var useStyles = (0, _mui.makeStyles)()(function (theme) {
31
- return {
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
+ const react_1 = __importStar(require("react"));
30
+ const material_1 = require("@mui/material");
31
+ const mui_1 = require("tss-react/mui");
32
+ const mobx_react_1 = require("mobx-react");
33
+ const ArrowDropDown_1 = __importDefault(require("@mui/icons-material/ArrowDropDown"));
34
+ const Menu_1 = __importDefault(require("./Menu"));
35
+ const useStyles = (0, mui_1.makeStyles)()(theme => ({
32
36
  root: {
33
- display: 'flex'
37
+ display: 'flex',
34
38
  },
35
39
  buttonRoot: {
36
- '&:hover': {
37
- backgroundColor: (0, _material.alpha)(theme.palette.primary.contrastText, theme.palette.action.hoverOpacity),
38
- '@media (hover: none)': {
39
- backgroundColor: 'transparent'
40
- }
41
- }
40
+ '&:hover': {
41
+ backgroundColor: (0, material_1.alpha)(theme.palette.primary.contrastText, theme.palette.action.hoverOpacity),
42
+ '@media (hover: none)': {
43
+ backgroundColor: 'transparent',
44
+ },
45
+ },
46
+ },
47
+ }));
48
+ function DropDownMenu({ menuTitle, session, menuItems, }) {
49
+ const [open, setOpen] = (0, react_1.useState)(false);
50
+ const anchorEl = (0, react_1.useRef)(null);
51
+ const { classes } = useStyles();
52
+ function handleToggle() {
53
+ setOpen(!open);
42
54
  }
43
- };
44
- });
45
-
46
- function DropDownMenu(_ref) {
47
- var menuTitle = _ref.menuTitle,
48
- session = _ref.session,
49
- menuItems = _ref.menuItems;
50
-
51
- var _useState = (0, _react.useState)(false),
52
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
53
- open = _useState2[0],
54
- setOpen = _useState2[1];
55
-
56
- var anchorEl = (0, _react.useRef)(null);
57
-
58
- var _useStyles = useStyles(),
59
- classes = _useStyles.classes;
60
-
61
- function handleToggle() {
62
- setOpen(!open);
63
- }
64
-
65
- function handleMenuItemClick(_event, callback) {
66
- callback(session);
67
- handleClose();
68
- }
69
-
70
- function handleClose() {
71
- setOpen(false);
72
- }
73
-
74
- return /*#__PURE__*/_react.default.createElement("div", {
75
- className: classes.root
76
- }, /*#__PURE__*/_react.default.createElement(_material.Button, {
77
- ref: anchorEl,
78
- onClick: handleToggle,
79
- color: "inherit",
80
- "data-testid": "dropDownMenuButton",
81
- classes: {
82
- root: classes.buttonRoot
55
+ function handleMenuItemClick(_event, callback) {
56
+ callback(session);
57
+ handleClose();
83
58
  }
84
- }, menuTitle, /*#__PURE__*/_react.default.createElement(_ArrowDropDown.default, null)), /*#__PURE__*/_react.default.createElement(_Menu.default, {
85
- anchorEl: anchorEl.current,
86
- anchorOrigin: {
87
- vertical: 'bottom',
88
- horizontal: 'left'
89
- },
90
- onMenuItemClick: handleMenuItemClick,
91
- open: open,
92
- onClose: handleClose,
93
- menuItems: menuItems
94
- }));
59
+ function handleClose() {
60
+ setOpen(false);
61
+ }
62
+ return (react_1.default.createElement("div", { className: classes.root },
63
+ react_1.default.createElement(material_1.Button, { ref: anchorEl, onClick: handleToggle, color: "inherit", "data-testid": "dropDownMenuButton", classes: { root: classes.buttonRoot } },
64
+ menuTitle,
65
+ react_1.default.createElement(ArrowDropDown_1.default, null)),
66
+ react_1.default.createElement(Menu_1.default, { anchorEl: anchorEl.current, anchorOrigin: { vertical: 'bottom', horizontal: 'left' }, onMenuItemClick: handleMenuItemClick, open: open, onClose: handleClose, menuItems: menuItems })));
95
67
  }
96
-
97
- var _default = (0, _mobxReact.observer)(DropDownMenu);
98
-
99
- exports.default = _default;
68
+ exports.default = (0, mobx_react_1.observer)(DropDownMenu);