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