@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/App.js CHANGED
@@ -1,274 +1,189 @@
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 _Launch = _interopRequireDefault(require("@mui/icons-material/Launch"));
21
-
22
- var _mobxReact = require("mobx-react");
23
-
24
- var _mobxStateTree = require("mobx-state-tree");
25
-
26
- var _configuration = require("../configuration");
27
-
28
- var _DrawerWidget = _interopRequireDefault(require("./DrawerWidget"));
29
-
30
- var _DropDownMenu = _interopRequireDefault(require("./DropDownMenu"));
31
-
32
- var _EditableTypography = _interopRequireDefault(require("./EditableTypography"));
33
-
34
- var _Logo = require("./Logo");
35
-
36
- var _Snackbar = _interopRequireDefault(require("./Snackbar"));
37
-
38
- var _ViewContainer = _interopRequireDefault(require("./ViewContainer"));
39
-
40
- 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); }
41
-
42
- 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; }
43
-
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 Launch_1 = __importDefault(require("@mui/icons-material/Launch"));
33
+ const mobx_react_1 = require("mobx-react");
34
+ const mobx_state_tree_1 = require("mobx-state-tree");
44
35
  // locals
45
- var useStyles = (0, _mui.makeStyles)()(function (theme) {
46
- return {
36
+ const configuration_1 = require("../configuration");
37
+ const DrawerWidget_1 = __importDefault(require("./DrawerWidget"));
38
+ const DropDownMenu_1 = __importDefault(require("./DropDownMenu"));
39
+ const EditableTypography_1 = __importDefault(require("./EditableTypography"));
40
+ const Logo_1 = require("./Logo");
41
+ const Snackbar_1 = __importDefault(require("./Snackbar"));
42
+ const ViewContainer_1 = __importDefault(require("./ViewContainer"));
43
+ const useStyles = (0, mui_1.makeStyles)()(theme => ({
47
44
  root: {
48
- fontFamily: 'Roboto',
49
- display: 'grid',
50
- height: '100vh',
51
- width: '100%'
45
+ fontFamily: 'Roboto',
46
+ display: 'grid',
47
+ height: '100vh',
48
+ width: '100%',
52
49
  },
53
50
  fabLeft: {
54
- zIndex: 10000,
55
- position: 'fixed',
56
- bottom: theme.spacing(2),
57
- left: theme.spacing(2)
51
+ zIndex: 10000,
52
+ position: 'fixed',
53
+ bottom: theme.spacing(2),
54
+ left: theme.spacing(2),
58
55
  },
59
56
  fabRight: {
60
- zIndex: 10000,
61
- position: 'fixed',
62
- bottom: theme.spacing(2),
63
- right: theme.spacing(2)
57
+ zIndex: 10000,
58
+ position: 'fixed',
59
+ bottom: theme.spacing(2),
60
+ right: theme.spacing(2),
64
61
  },
65
62
  menuBarAndComponents: {
66
- gridColumn: 'main',
67
- display: 'grid',
68
- gridTemplateRows: '[menubar] min-content [components] auto',
69
- height: '100vh'
63
+ gridColumn: 'main',
64
+ display: 'grid',
65
+ gridTemplateRows: '[menubar] min-content [components] auto',
66
+ height: '100vh',
70
67
  },
71
68
  menuBar: {
72
- gridRow: 'menubar'
69
+ gridRow: 'menubar',
73
70
  },
74
71
  components: {
75
- overflowY: 'auto',
76
- gridRow: 'components'
72
+ overflowY: 'auto',
73
+ gridRow: 'components',
77
74
  },
78
75
  appBar: {
79
- flexGrow: 1
76
+ flexGrow: 1,
80
77
  },
81
78
  grow: {
82
- flexGrow: 1
79
+ flexGrow: 1,
83
80
  },
84
81
  inputBase: {
85
- color: theme.palette.primary.contrastText
82
+ color: theme.palette.primary.contrastText,
86
83
  },
87
84
  inputRoot: {
88
- '&:hover': {
89
- backgroundColor: theme.palette.primary.light
90
- }
85
+ '&:hover': {
86
+ backgroundColor: theme.palette.primary.light,
87
+ },
91
88
  },
92
89
  inputFocused: {
93
- borderColor: theme.palette.secondary.main,
94
- backgroundColor: theme.palette.primary.light
90
+ borderColor: theme.palette.secondary.main,
91
+ backgroundColor: theme.palette.primary.light,
95
92
  },
96
93
  selectPaper: {
97
- padding: theme.spacing(4)
98
- }
99
- };
100
- });
101
- var Logo = (0, _mobxReact.observer)(function (_ref) {
102
- var session = _ref.session;
103
- var configuration = session.configuration;
104
- var logoPath = (0, _configuration.readConfObject)(configuration, 'logoPath');
105
-
106
- if (!(logoPath !== null && logoPath !== void 0 && logoPath.uri)) {
107
- return /*#__PURE__*/_react.default.createElement(_Logo.LogoFull, {
108
- variant: "white"
109
- });
110
- } else {
111
- return /*#__PURE__*/_react.default.createElement("img", {
112
- src: logoPath.uri,
113
- alt: "Custom logo"
114
- });
115
- }
116
- });
117
- var App = (0, _mobxReact.observer)(function (_ref2) {
118
- var _viewTypes$, _grid;
119
-
120
- var session = _ref2.session,
121
- _ref2$HeaderButtons = _ref2.HeaderButtons,
122
- HeaderButtons = _ref2$HeaderButtons === void 0 ? /*#__PURE__*/_react.default.createElement("div", null) : _ref2$HeaderButtons;
123
-
124
- var _useStyles = useStyles(),
125
- classes = _useStyles.classes;
126
-
127
- var _getEnv = (0, _mobxStateTree.getEnv)(session),
128
- pluginManager = _getEnv.pluginManager;
129
-
130
- var viewTypes = pluginManager.getElementTypeRecord('view').all();
131
-
132
- var _useState = (0, _react.useState)((_viewTypes$ = viewTypes[0]) === null || _viewTypes$ === void 0 ? void 0 : _viewTypes$.name),
133
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
134
- value = _useState2[0],
135
- setValue = _useState2[1];
136
-
137
- var visibleWidget = session.visibleWidget,
138
- drawerWidth = session.drawerWidth,
139
- minimized = session.minimized,
140
- activeWidgets = session.activeWidgets,
141
- savedSessionNames = session.savedSessionNames,
142
- name = session.name,
143
- menus = session.menus,
144
- views = session.views,
145
- drawerPosition = session.drawerPosition;
146
-
147
- function handleNameChange(newName) {
148
- if (savedSessionNames !== null && savedSessionNames !== void 0 && savedSessionNames.includes(newName)) {
149
- session.notify("Cannot rename session to \"".concat(newName, "\", a saved session with that name already exists"), 'warning');
150
- } else {
151
- session.renameCurrentSession(newName);
152
- }
153
- }
154
-
155
- var drawerVisible = visibleWidget && !minimized;
156
- var grid;
157
-
158
- if (drawerPosition === 'right') {
159
- grid = ["[main] 1fr", drawerVisible ? "[drawer] ".concat(drawerWidth, "px") : undefined];
160
- } else if (drawerPosition === 'left') {
161
- grid = [drawerVisible ? "[drawer] ".concat(drawerWidth, "px") : undefined, "[main] 1fr"];
162
- }
163
-
164
- return /*#__PURE__*/_react.default.createElement("div", {
165
- className: classes.root,
166
- style: {
167
- gridTemplateColumns: (_grid = grid) === null || _grid === void 0 ? void 0 : _grid.filter(function (f) {
168
- return !!f;
169
- }).join(' ')
170
- }
171
- }, drawerVisible && drawerPosition === 'left' ? /*#__PURE__*/_react.default.createElement(_DrawerWidget.default, {
172
- session: session
173
- }) : null, session.DialogComponent ? /*#__PURE__*/_react.default.createElement(_react.Suspense, {
174
- fallback: /*#__PURE__*/_react.default.createElement("div", null)
175
- }, /*#__PURE__*/_react.default.createElement(session.DialogComponent, session.DialogProps)) : null, /*#__PURE__*/_react.default.createElement("div", {
176
- className: classes.menuBarAndComponents
177
- }, /*#__PURE__*/_react.default.createElement("div", {
178
- className: classes.menuBar
179
- }, /*#__PURE__*/_react.default.createElement(_material.AppBar, {
180
- className: classes.appBar,
181
- position: "static"
182
- }, /*#__PURE__*/_react.default.createElement(_material.Toolbar, null, menus.map(function (menu) {
183
- return /*#__PURE__*/_react.default.createElement(_DropDownMenu.default, {
184
- key: menu.label,
185
- menuTitle: menu.label,
186
- menuItems: menu.menuItems,
187
- session: session
188
- });
189
- }), /*#__PURE__*/_react.default.createElement("div", {
190
- className: classes.grow
191
- }), /*#__PURE__*/_react.default.createElement(_material.Tooltip, {
192
- title: "Rename Session",
193
- arrow: true
194
- }, /*#__PURE__*/_react.default.createElement(_EditableTypography.default, {
195
- value: name,
196
- setValue: handleNameChange,
197
- variant: "body1",
198
- classes: {
199
- inputBase: classes.inputBase,
200
- inputRoot: classes.inputRoot,
201
- inputFocused: classes.inputFocused
202
- }
203
- })), HeaderButtons, /*#__PURE__*/_react.default.createElement("div", {
204
- className: classes.grow
205
- }), /*#__PURE__*/_react.default.createElement("div", {
206
- style: {
207
- width: 150,
208
- maxHeight: 48
94
+ padding: theme.spacing(4),
95
+ },
96
+ }));
97
+ const Logo = (0, mobx_react_1.observer)(({ session }) => {
98
+ const { configuration } = session;
99
+ const logoPath = (0, configuration_1.readConfObject)(configuration, 'logoPath');
100
+ if (!(logoPath === null || logoPath === void 0 ? void 0 : logoPath.uri)) {
101
+ return react_1.default.createElement(Logo_1.LogoFull, { variant: "white" });
209
102
  }
210
- }, /*#__PURE__*/_react.default.createElement(Logo, {
211
- session: session
212
- }))))), /*#__PURE__*/_react.default.createElement("div", {
213
- className: classes.components
214
- }, views.length ? views.map(function (view) {
215
- var viewType = pluginManager.getViewType(view.type);
216
-
217
- if (!viewType) {
218
- throw new Error("unknown view type ".concat(view.type));
103
+ else {
104
+ return react_1.default.createElement("img", { src: logoPath.uri, alt: "Custom logo" });
219
105
  }
220
-
221
- var ReactComponent = viewType.ReactComponent;
222
- return /*#__PURE__*/_react.default.createElement(_ViewContainer.default, {
223
- key: "view-".concat(view.id),
224
- view: view,
225
- onClose: function onClose() {
226
- return session.removeView(view);
227
- }
228
- }, /*#__PURE__*/_react.default.createElement(_react.Suspense, {
229
- fallback: /*#__PURE__*/_react.default.createElement("div", null, "Loading...")
230
- }, /*#__PURE__*/_react.default.createElement(ReactComponent, {
231
- model: view,
232
- session: session,
233
- getTrackType: pluginManager.getTrackType
234
- })));
235
- }) : /*#__PURE__*/_react.default.createElement(_material.Paper, {
236
- className: classes.selectPaper
237
- }, /*#__PURE__*/_react.default.createElement(_material.Typography, null, "Select a view to launch"), /*#__PURE__*/_react.default.createElement(_material.Select, {
238
- value: value,
239
- onChange: function onChange(event) {
240
- return setValue(event.target.value);
106
+ });
107
+ const App = (0, mobx_react_1.observer)(({ session, HeaderButtons = react_1.default.createElement("div", null), }) => {
108
+ var _a;
109
+ const { classes } = useStyles();
110
+ const { pluginManager } = (0, mobx_state_tree_1.getEnv)(session);
111
+ const viewTypes = pluginManager.getElementTypeRecord('view').all();
112
+ const [value, setValue] = (0, react_1.useState)((_a = viewTypes[0]) === null || _a === void 0 ? void 0 : _a.name);
113
+ const { visibleWidget, drawerWidth, minimized, activeWidgets, savedSessionNames, name, menus, views, drawerPosition, } = session;
114
+ function handleNameChange(newName) {
115
+ if (savedSessionNames === null || savedSessionNames === void 0 ? void 0 : savedSessionNames.includes(newName)) {
116
+ session.notify(`Cannot rename session to "${newName}", a saved session with that name already exists`, 'warning');
117
+ }
118
+ else {
119
+ session.renameCurrentSession(newName);
120
+ }
241
121
  }
242
- }, viewTypes.map(function (_ref3) {
243
- var name = _ref3.name;
244
- return /*#__PURE__*/_react.default.createElement(_material.MenuItem, {
245
- key: name,
246
- value: name
247
- }, name);
248
- })), /*#__PURE__*/_react.default.createElement(_material.Button, {
249
- onClick: function onClick() {
250
- session.addView(value, {});
251
- },
252
- variant: "contained",
253
- color: "primary"
254
- }, "Launch view")), /*#__PURE__*/_react.default.createElement("div", {
255
- style: {
256
- height: 300
122
+ const drawerVisible = visibleWidget && !minimized;
123
+ let grid;
124
+ if (drawerPosition === 'right') {
125
+ grid = [
126
+ `[main] 1fr`,
127
+ drawerVisible ? `[drawer] ${drawerWidth}px` : undefined,
128
+ ];
257
129
  }
258
- }))), activeWidgets.size > 0 && minimized ? /*#__PURE__*/_react.default.createElement(_material.Tooltip, {
259
- title: "Open drawer widget"
260
- }, /*#__PURE__*/_react.default.createElement(_material.Fab, {
261
- className: drawerPosition === 'right' ? classes.fabRight : classes.fabLeft,
262
- color: "primary",
263
- "data-testid": "drawer-maximize",
264
- onClick: function onClick() {
265
- return session.showWidgetDrawer();
130
+ else if (drawerPosition === 'left') {
131
+ grid = [
132
+ drawerVisible ? `[drawer] ${drawerWidth}px` : undefined,
133
+ `[main] 1fr`,
134
+ ];
266
135
  }
267
- }, /*#__PURE__*/_react.default.createElement(_Launch.default, null))) : null, drawerVisible && drawerPosition === 'right' ? /*#__PURE__*/_react.default.createElement(_DrawerWidget.default, {
268
- session: session
269
- }) : null, /*#__PURE__*/_react.default.createElement(_Snackbar.default, {
270
- session: session
271
- }));
136
+ return (react_1.default.createElement("div", { className: classes.root, style: {
137
+ gridTemplateColumns: grid === null || grid === void 0 ? void 0 : grid.filter(f => !!f).join(' '),
138
+ } },
139
+ drawerVisible && drawerPosition === 'left' ? (react_1.default.createElement(DrawerWidget_1.default, { session: session })) : null,
140
+ session.DialogComponent ? (react_1.default.createElement(react_1.Suspense, { fallback: react_1.default.createElement("div", null) },
141
+ react_1.default.createElement(session.DialogComponent, { ...session.DialogProps }))) : null,
142
+ react_1.default.createElement("div", { className: classes.menuBarAndComponents },
143
+ react_1.default.createElement("div", { className: classes.menuBar },
144
+ react_1.default.createElement(material_1.AppBar, { className: classes.appBar, position: "static" },
145
+ react_1.default.createElement(material_1.Toolbar, null,
146
+ menus.map(menu => (react_1.default.createElement(DropDownMenu_1.default, { key: menu.label, menuTitle: menu.label, menuItems: menu.menuItems, session: session }))),
147
+ react_1.default.createElement("div", { className: classes.grow }),
148
+ react_1.default.createElement(material_1.Tooltip, { title: "Rename Session", arrow: true },
149
+ react_1.default.createElement(EditableTypography_1.default, { value: name, setValue: handleNameChange, variant: "body1", classes: {
150
+ inputBase: classes.inputBase,
151
+ inputRoot: classes.inputRoot,
152
+ inputFocused: classes.inputFocused,
153
+ } })),
154
+ HeaderButtons,
155
+ react_1.default.createElement("div", { className: classes.grow }),
156
+ react_1.default.createElement("div", { style: { width: 150, maxHeight: 48 } },
157
+ react_1.default.createElement(Logo, { session: session }))))),
158
+ react_1.default.createElement("div", { className: classes.components },
159
+ views.length ? (views.map(view => {
160
+ const viewType = pluginManager.getViewType(view.type);
161
+ if (!viewType) {
162
+ throw new Error(`unknown view type ${view.type}`);
163
+ }
164
+ const { ReactComponent } = viewType;
165
+ return (react_1.default.createElement(ViewContainer_1.default, { key: `view-${view.id}`, view: view, onClose: () => {
166
+ session.removeView(view);
167
+ session.notify(`A view has been closed`, 'info', {
168
+ name: 'undo',
169
+ onClick: () => {
170
+ pluginManager.rootModel.history.undo();
171
+ },
172
+ });
173
+ } },
174
+ react_1.default.createElement(react_1.Suspense, { fallback: react_1.default.createElement("div", null, "Loading...") },
175
+ react_1.default.createElement(ReactComponent, { model: view, session: session, getTrackType: pluginManager.getTrackType }))));
176
+ })) : (react_1.default.createElement(material_1.Paper, { className: classes.selectPaper },
177
+ react_1.default.createElement(material_1.Typography, null, "Select a view to launch"),
178
+ react_1.default.createElement(material_1.Select, { value: value, onChange: event => setValue(event.target.value) }, viewTypes.map(({ name }) => (react_1.default.createElement(material_1.MenuItem, { key: name, value: name }, name)))),
179
+ react_1.default.createElement(material_1.Button, { onClick: () => {
180
+ session.addView(value, {});
181
+ }, variant: "contained", color: "primary" }, "Launch view"))),
182
+ react_1.default.createElement("div", { style: { height: 300 } }))),
183
+ activeWidgets.size > 0 && minimized ? (react_1.default.createElement(material_1.Tooltip, { title: "Open drawer widget" },
184
+ react_1.default.createElement(material_1.Fab, { className: drawerPosition === 'right' ? classes.fabRight : classes.fabLeft, color: "primary", "data-testid": "drawer-maximize", onClick: () => session.showWidgetDrawer() },
185
+ react_1.default.createElement(Launch_1.default, null)))) : null,
186
+ drawerVisible && drawerPosition === 'right' ? (react_1.default.createElement(DrawerWidget_1.default, { session: session })) : null,
187
+ react_1.default.createElement(Snackbar_1.default, { session: session })));
272
188
  });
273
- var _default = App;
274
- exports.default = _default;
189
+ exports.default = App;
@@ -1,125 +1,64 @@
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 _mobxReact = require("mobx-react");
17
-
18
- var _configuration = require("../configuration");
19
-
20
- var _material = require("@mui/material");
21
-
22
- var _mui = require("tss-react/mui");
23
-
24
- 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); }
25
-
26
- 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; }
27
-
28
- var useStyles = (0, _mui.makeStyles)()(function () {
29
- 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
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ const react_1 = __importStar(require("react"));
27
+ const mobx_react_1 = require("mobx-react");
28
+ const material_1 = require("@mui/material");
29
+ const util_1 = require("@jbrowse/core/util");
30
+ const mui_1 = require("tss-react/mui");
31
+ // locals
32
+ const configuration_1 = require("../configuration");
33
+ const useStyles = (0, mui_1.makeStyles)()(() => ({
30
34
  importFormEntry: {
31
- minWidth: 180
32
- }
33
- };
34
- }); // Hook from https://usehooks.com/useLocalStorage/
35
-
36
- function useLocalStorage(key, initialValue) {
37
- var _useState = (0, _react.useState)(function () {
38
- if (typeof window === 'undefined') {
39
- return initialValue;
40
- }
41
-
42
- try {
43
- var item = window.localStorage.getItem(key);
44
- return item ? JSON.parse(item) : initialValue;
45
- } catch (error) {
46
- console.error(error);
47
- return initialValue;
48
- }
49
- }),
50
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
51
- storedValue = _useState2[0],
52
- setStoredValue = _useState2[1];
53
-
54
- var setValue = function setValue(value) {
55
- try {
56
- var valueToStore = value instanceof Function ? value(storedValue) : value;
57
- setStoredValue(valueToStore);
58
-
59
- if (typeof window !== 'undefined') {
60
- window.localStorage.setItem(key, JSON.stringify(valueToStore));
61
- }
62
- } catch (error) {
63
- console.error(error);
64
- }
65
- };
66
-
67
- return [storedValue, setValue];
68
- }
69
-
70
- var AssemblySelector = (0, _mobxReact.observer)(function (_ref) {
71
- var session = _ref.session,
72
- onChange = _ref.onChange,
73
- selected = _ref.selected,
74
- InputProps = _ref.InputProps,
75
- _ref$extra = _ref.extra,
76
- extra = _ref$extra === void 0 ? 0 : _ref$extra;
77
-
78
- var _useStyles = useStyles(),
79
- classes = _useStyles.classes;
80
-
81
- var assemblyNames = session.assemblyNames,
82
- assemblyManager = session.assemblyManager; // constructs a localstorage key based on host/path/config to help
83
- // remember. non-config assists usage with e.g. embedded apps
84
-
85
- var config = new URLSearchParams(window.location.search).get('config');
86
-
87
- var _useLocalStorage = useLocalStorage("lastAssembly-".concat([window.location.host + window.location.pathname, config, extra].join('-')), selected),
88
- _useLocalStorage2 = (0, _slicedToArray2.default)(_useLocalStorage, 2),
89
- lastSelected = _useLocalStorage2[0],
90
- setLastSelected = _useLocalStorage2[1];
91
-
92
- var selection = assemblyNames.includes(lastSelected || '') ? lastSelected : selected;
93
- (0, _react.useEffect)(function () {
94
- if (selection && selection !== selected) {
95
- onChange(selection);
96
- }
97
- }, [selection, onChange, selected]);
98
- var error = assemblyNames.length ? '' : 'No configured assemblies';
99
- return /*#__PURE__*/_react.default.createElement(_material.TextField, {
100
- select: true,
101
- label: "Assembly",
102
- variant: "outlined",
103
- helperText: error || 'Select assembly to view',
104
- value: error ? '' : selection,
105
- inputProps: {
106
- 'data-testid': 'assembly-selector'
107
- },
108
- onChange: function onChange(event) {
109
- return setLastSelected(event.target.value);
35
+ minWidth: 180,
110
36
  },
111
- error: !!error,
112
- InputProps: InputProps,
113
- disabled: !!error,
114
- className: classes.importFormEntry
115
- }, assemblyNames.map(function (name) {
116
- var assembly = assemblyManager.get(name);
117
- var displayName = assembly ? (0, _configuration.getConf)(assembly, 'displayName') : '';
118
- return /*#__PURE__*/_react.default.createElement(_material.MenuItem, {
119
- key: name,
120
- value: name
121
- }, displayName || name);
122
- }));
37
+ }));
38
+ const AssemblySelector = (0, mobx_react_1.observer)(({ session, onChange, selected, InputProps, extra = 0, }) => {
39
+ const { classes } = useStyles();
40
+ const { assemblyNames, assemblyManager } = session;
41
+ // constructs a localstorage key based on host/path/config to help
42
+ // remember. non-config assists usage with e.g. embedded apps
43
+ const config = new URLSearchParams(window.location.search).get('config');
44
+ const [lastSelected, setLastSelected] = (0, util_1.useLocalStorage)(`lastAssembly-${[
45
+ window.location.host + window.location.pathname,
46
+ config,
47
+ extra,
48
+ ].join('-')}`, selected);
49
+ const selection = assemblyNames.includes(lastSelected || '')
50
+ ? lastSelected
51
+ : selected;
52
+ (0, react_1.useEffect)(() => {
53
+ if (selection && selection !== selected) {
54
+ onChange(selection);
55
+ }
56
+ }, [selection, onChange, selected]);
57
+ const error = assemblyNames.length ? '' : 'No configured assemblies';
58
+ return (react_1.default.createElement(material_1.TextField, { select: true, label: "Assembly", variant: "outlined", helperText: error || 'Select assembly to view', value: error ? '' : selection, inputProps: { 'data-testid': 'assembly-selector' }, onChange: event => setLastSelected(event.target.value), error: !!error, InputProps: InputProps, disabled: !!error, className: classes.importFormEntry }, assemblyNames.map(name => {
59
+ const assembly = assemblyManager.get(name);
60
+ const displayName = assembly ? (0, configuration_1.getConf)(assembly, 'displayName') : '';
61
+ return (react_1.default.createElement(material_1.MenuItem, { key: name, value: name }, displayName || name));
62
+ })));
123
63
  });
124
- var _default = AssemblySelector;
125
- exports.default = _default;
64
+ exports.default = AssemblySelector;