@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
@@ -1,161 +1,99 @@
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 _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
-
14
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
-
16
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
-
18
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
19
-
20
- var _react = _interopRequireWildcard(require("react"));
21
-
22
- var _material = require("@mui/material");
23
-
24
- var _mui = require("tss-react/mui");
25
-
26
- var _excluded = ["value", "setValue", "variant"];
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
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
33
-
34
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
35
-
36
- var useStyles = (0, _mui.makeStyles)()(function (theme) {
37
- 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 material_1 = require("@mui/material");
28
+ const mui_1 = require("tss-react/mui");
29
+ const useStyles = (0, mui_1.makeStyles)()(theme => ({
38
30
  input: {},
39
31
  inputBase: {},
40
32
  typography: {
41
- top: 6,
42
- left: 2,
43
- position: 'absolute',
44
- whiteSpace: 'nowrap',
45
- visibility: 'hidden'
33
+ top: 6,
34
+ left: 2,
35
+ position: 'absolute',
36
+ whiteSpace: 'nowrap',
37
+ visibility: 'hidden',
46
38
  },
47
39
  inputRoot: {
48
- padding: theme.spacing(0.5)
40
+ padding: theme.spacing(0.5),
49
41
  },
50
42
  inputFocused: {
51
- borderStyle: 'solid',
52
- borderWidth: 2
53
- }
54
- };
55
- });
56
-
57
- // using forwardRef so that MUI Tooltip can wrap this component
58
- var EditableTypography = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
59
- var value = props.value,
60
- setValue = props.setValue,
61
- variant = props.variant,
62
- other = (0, _objectWithoutProperties2.default)(props, _excluded);
63
-
64
- var _useState = (0, _react.useState)(),
65
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
66
- editedValue = _useState2[0],
67
- setEditedValue = _useState2[1];
68
-
69
- var _useState3 = (0, _react.useState)(0),
70
- _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
71
- width = _useState4[0],
72
- setWidth = _useState4[1];
73
-
74
- var _useState5 = (0, _react.useState)(null),
75
- _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
76
- sizerNode = _useState6[0],
77
- setSizerNode = _useState6[1];
78
-
79
- var _useState7 = (0, _react.useState)(null),
80
- _useState8 = (0, _slicedToArray2.default)(_useState7, 2),
81
- inputNode = _useState8[0],
82
- setInputNode = _useState8[1];
83
-
84
- var _useState9 = (0, _react.useState)(false),
85
- _useState10 = (0, _slicedToArray2.default)(_useState9, 2),
86
- blur = _useState10[0],
87
- setBlur = _useState10[1];
88
-
89
- (0, _react.useEffect)(function () {
90
- if (blur) {
91
- inputNode && inputNode.blur();
92
- setBlur(false);
93
- }
94
- }, [blur, inputNode]); // possibly tss-react does not understand the passing of props to
95
- // useStyles, but it appears to work
96
- // @ts-ignore
97
-
98
- var _useStyles = useStyles(props, {
99
- props: props
100
- }),
101
- classes = _useStyles.classes;
102
-
103
- var theme = (0, _material.useTheme)();
104
- var clientWidth = sizerNode === null || sizerNode === void 0 ? void 0 : sizerNode.clientWidth;
105
-
106
- if (clientWidth && clientWidth !== width) {
107
- setWidth(clientWidth);
108
- }
109
-
110
- return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({}, other, {
111
- ref: ref
112
- }), /*#__PURE__*/_react.default.createElement("div", {
113
- style: {
114
- position: 'relative'
115
- }
116
- }, /*#__PURE__*/_react.default.createElement(_material.Typography, {
117
- ref: function ref(node) {
118
- return setSizerNode(node);
43
+ borderStyle: 'solid',
44
+ borderWidth: 2,
119
45
  },
120
- component: "span",
121
- variant: variant,
122
- className: classes.typography
123
- }, editedValue === undefined ? value : editedValue)), /*#__PURE__*/_react.default.createElement(_material.InputBase, {
124
- inputRef: function inputRef(node) {
125
- return setInputNode(node);
126
- },
127
- className: classes.inputBase,
128
- inputProps: {
129
- style: _objectSpread({
130
- width: width
131
- }, variant && variant !== 'inherit' ? theme.typography[variant] : {})
132
- },
133
- classes: {
134
- input: classes.input,
135
- root: classes.inputRoot,
136
- focused: classes.inputFocused
137
- },
138
- value: editedValue === undefined ? value : editedValue,
139
- onChange: function onChange(event) {
140
- return setEditedValue(event.target.value);
141
- },
142
- onKeyDown: function onKeyDown(event) {
143
- if (event.key === 'Enter') {
144
- inputNode && inputNode.blur();
145
- } else if (event.key === 'Escape') {
146
- setEditedValue(undefined);
147
- setBlur(true);
148
- }
149
- },
150
- onBlur: function onBlur() {
151
- if (editedValue && editedValue !== value) {
152
- setValue(editedValue);
153
- }
154
-
155
- setEditedValue(undefined);
46
+ }));
47
+ // using forwardRef so that MUI Tooltip can wrap this component
48
+ const EditableTypography = react_1.default.forwardRef((props, ref) => {
49
+ const { value, setValue, variant, ...other } = props;
50
+ const [editedValue, setEditedValue] = (0, react_1.useState)();
51
+ const [width, setWidth] = (0, react_1.useState)(0);
52
+ const [sizerNode, setSizerNode] = (0, react_1.useState)(null);
53
+ const [inputNode, setInputNode] = (0, react_1.useState)(null);
54
+ const [blur, setBlur] = (0, react_1.useState)(false);
55
+ (0, react_1.useEffect)(() => {
56
+ if (blur) {
57
+ inputNode && inputNode.blur();
58
+ setBlur(false);
59
+ }
60
+ }, [blur, inputNode]);
61
+ // possibly tss-react does not understand the passing of props to
62
+ // useStyles, but it appears to work
63
+ // @ts-ignore
64
+ const { classes } = useStyles(props, { props });
65
+ const theme = (0, material_1.useTheme)();
66
+ const clientWidth = sizerNode === null || sizerNode === void 0 ? void 0 : sizerNode.clientWidth;
67
+ if (clientWidth && clientWidth !== width) {
68
+ setWidth(clientWidth);
156
69
  }
157
- }));
70
+ return (react_1.default.createElement("div", { ...other, ref: ref },
71
+ react_1.default.createElement("div", { style: { position: 'relative' } },
72
+ react_1.default.createElement(material_1.Typography, { ref: (node) => setSizerNode(node), component: "span", variant: variant, className: classes.typography }, editedValue === undefined ? value : editedValue)),
73
+ react_1.default.createElement(material_1.InputBase, { inputRef: node => setInputNode(node), className: classes.inputBase, inputProps: {
74
+ style: {
75
+ width,
76
+ ...(variant && variant !== 'inherit'
77
+ ? theme.typography[variant]
78
+ : {}),
79
+ },
80
+ }, classes: {
81
+ input: classes.input,
82
+ root: classes.inputRoot,
83
+ focused: classes.inputFocused,
84
+ }, value: editedValue === undefined ? value : editedValue, onChange: event => setEditedValue(event.target.value), onKeyDown: event => {
85
+ if (event.key === 'Enter') {
86
+ inputNode && inputNode.blur();
87
+ }
88
+ else if (event.key === 'Escape') {
89
+ setEditedValue(undefined);
90
+ setBlur(true);
91
+ }
92
+ }, onBlur: () => {
93
+ if (editedValue && editedValue !== value) {
94
+ setValue(editedValue);
95
+ }
96
+ setEditedValue(undefined);
97
+ } })));
158
98
  });
159
-
160
- var _default = EditableTypography;
161
- exports.default = _default;
99
+ exports.default = EditableTypography;
@@ -1,59 +1,44 @@
1
1
  "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.default = void 0;
9
-
10
- var _react = _interopRequireDefault(require("react"));
11
-
12
- var ErrorMessage = function ErrorMessage(_ref) {
13
- var error = _ref.error;
14
- var snapshotError = '';
15
- var str = "".concat(error);
16
- var findStr = 'is not assignable';
17
- var idx = str.indexOf(findStr);
18
-
19
- if (idx !== -1) {
20
- var trim = str.slice(0, idx + findStr.length); // best effort to make a better error message than the default
21
- // mobx-state-tree
22
- // case 1. element has a path
23
-
24
- var match = trim.match(/.*at path "(.*)" snapshot `(.*)` is not assignable/m);
25
-
26
- if (match) {
27
- str = "Failed to load element at ".concat(match[1], "...Failed element had snapshot");
28
- snapshotError = match[2];
29
- } // case 2. element has no path
30
-
31
-
32
- var match2 = trim.match(/.*snapshot `(.*)` is not assignable/);
33
-
34
- if (match2) {
35
- str = "Failed to load element...Failed element had snapshot";
36
- snapshotError = match2[1];
37
- }
38
- }
39
-
40
- return /*#__PURE__*/_react.default.createElement("div", {
41
- style: {
42
- padding: 4,
43
- margin: 4,
44
- overflow: 'auto',
45
- maxHeight: 200,
46
- background: '#f88',
47
- border: '1px solid black'
48
- }
49
- }, str.slice(0, 10000), snapshotError ? /*#__PURE__*/_react.default.createElement("pre", {
50
- style: {
51
- background: 'lightgrey',
52
- border: '1px solid black',
53
- margin: 20
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const ErrorMessage = ({ error }) => {
8
+ let snapshotError = '';
9
+ let str = `${error}`;
10
+ const findStr = 'is not assignable';
11
+ const idx = str.indexOf(findStr);
12
+ if (idx !== -1) {
13
+ const trim = str.slice(0, idx + findStr.length);
14
+ // best effort to make a better error message than the default
15
+ // mobx-state-tree
16
+ // case 1. element has a path
17
+ const match = trim.match(/.*at path "(.*)" snapshot `(.*)` is not assignable/m);
18
+ if (match) {
19
+ str = `Failed to load element at ${match[1]}...Failed element had snapshot`;
20
+ snapshotError = match[2];
21
+ }
22
+ // case 2. element has no path
23
+ const match2 = trim.match(/.*snapshot `(.*)` is not assignable/);
24
+ if (match2) {
25
+ str = `Failed to load element...Failed element had snapshot`;
26
+ snapshotError = match2[1];
27
+ }
54
28
  }
55
- }, JSON.stringify(JSON.parse(snapshotError), null, 2)) : null);
29
+ return (react_1.default.createElement("div", { style: {
30
+ padding: 4,
31
+ margin: 4,
32
+ overflow: 'auto',
33
+ maxHeight: 200,
34
+ background: '#f88',
35
+ border: '1px solid black',
36
+ } },
37
+ str.slice(0, 10000),
38
+ snapshotError ? (react_1.default.createElement("pre", { style: {
39
+ background: 'lightgrey',
40
+ border: '1px solid black',
41
+ margin: 20,
42
+ } }, JSON.stringify(JSON.parse(snapshotError), null, 2))) : null));
56
43
  };
57
-
58
- var _default = ErrorMessage;
59
- exports.default = _default;
44
+ exports.default = ErrorMessage;
@@ -1,60 +1,27 @@
1
1
  "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.default = void 0;
9
-
10
- var _Button = _interopRequireDefault(require("@mui/material/Button"));
11
-
12
- var _Dialog = _interopRequireDefault(require("@mui/material/Dialog"));
13
-
14
- var _DialogTitle = _interopRequireDefault(require("@mui/material/DialogTitle"));
15
-
16
- var _DialogContent = _interopRequireDefault(require("@mui/material/DialogContent"));
17
-
18
- var _DialogContentText = _interopRequireDefault(require("@mui/material/DialogContentText"));
19
-
20
- var _DialogActions = _interopRequireDefault(require("@mui/material/DialogActions"));
21
-
22
- var _react = _interopRequireDefault(require("react"));
23
-
24
- var _default = function _default(_ref) {
25
- var onClose = _ref.onClose,
26
- open = _ref.open,
27
- onFactoryReset = _ref.onFactoryReset;
28
-
29
- function handleDialogClose(action) {
30
- if (action === 'reset') {
31
- onFactoryReset();
32
- }
33
-
34
- onClose();
35
- }
36
-
37
- return /*#__PURE__*/_react.default.createElement(_Dialog.default, {
38
- open: open,
39
- onClose: function onClose() {
40
- return handleDialogClose();
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const Button_1 = __importDefault(require("@mui/material/Button"));
7
+ const Dialog_1 = __importDefault(require("@mui/material/Dialog"));
8
+ const DialogTitle_1 = __importDefault(require("@mui/material/DialogTitle"));
9
+ const DialogContent_1 = __importDefault(require("@mui/material/DialogContent"));
10
+ const DialogContentText_1 = __importDefault(require("@mui/material/DialogContentText"));
11
+ const DialogActions_1 = __importDefault(require("@mui/material/DialogActions"));
12
+ const react_1 = __importDefault(require("react"));
13
+ exports.default = ({ onClose, open, onFactoryReset, }) => {
14
+ function handleDialogClose(action) {
15
+ if (action === 'reset') {
16
+ onFactoryReset();
17
+ }
18
+ onClose();
41
19
  }
42
- }, /*#__PURE__*/_react.default.createElement(_DialogTitle.default, {
43
- id: "alert-dialog-title"
44
- }, "Reset"), /*#__PURE__*/_react.default.createElement(_DialogContent.default, null, /*#__PURE__*/_react.default.createElement(_DialogContentText.default, {
45
- id: "alert-dialog-description"
46
- }, "Are you sure you want to reset? This will restore the default configuration.")), /*#__PURE__*/_react.default.createElement(_DialogActions.default, null, /*#__PURE__*/_react.default.createElement(_Button.default, {
47
- onClick: function onClick() {
48
- return handleDialogClose();
49
- },
50
- color: "primary"
51
- }, "Cancel"), /*#__PURE__*/_react.default.createElement(_Button.default, {
52
- onClick: function onClick() {
53
- return handleDialogClose('reset');
54
- },
55
- color: "primary",
56
- variant: "contained"
57
- }, "OK")));
20
+ return (react_1.default.createElement(Dialog_1.default, { open: open, onClose: () => handleDialogClose() },
21
+ react_1.default.createElement(DialogTitle_1.default, { id: "alert-dialog-title" }, "Reset"),
22
+ react_1.default.createElement(DialogContent_1.default, null,
23
+ react_1.default.createElement(DialogContentText_1.default, { id: "alert-dialog-description" }, "Are you sure you want to reset? This will restore the default configuration.")),
24
+ react_1.default.createElement(DialogActions_1.default, null,
25
+ react_1.default.createElement(Button_1.default, { onClick: () => handleDialogClose(), color: "primary" }, "Cancel"),
26
+ react_1.default.createElement(Button_1.default, { onClick: () => handleDialogClose('reset'), color: "primary", variant: "contained" }, "OK"))));
58
27
  };
59
-
60
- exports.default = _default;
@@ -1,101 +1,69 @@
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
9
- });
10
- exports.default = void 0;
11
-
12
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
-
14
- var _Button = _interopRequireDefault(require("@mui/material/Button"));
15
-
16
- var _Dialog = _interopRequireDefault(require("@mui/material/Dialog"));
17
-
18
- var _DialogActions = _interopRequireDefault(require("@mui/material/DialogActions"));
19
-
20
- var _DialogContent = _interopRequireDefault(require("@mui/material/DialogContent"));
21
-
22
- var _DialogTitle = _interopRequireDefault(require("@mui/material/DialogTitle"));
23
-
24
- var _propTypes = _interopRequireDefault(require("prop-types"));
25
-
26
- var _react = _interopRequireWildcard(require("react"));
27
-
28
- var _FactoryResetDialog = _interopRequireDefault(require("./FactoryResetDialog"));
29
-
30
- 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); }
31
-
32
- 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; }
33
-
34
- var ResetComponent = function ResetComponent(_ref) {
35
- var onFactoryReset = _ref.onFactoryReset,
36
- resetButtonText = _ref.resetButtonText;
37
-
38
- var _useState = (0, _react.useState)(false),
39
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
40
- dialogOpen = _useState2[0],
41
- setDialogOpen = _useState2[1];
42
-
43
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_Button.default, {
44
- "data-testid": "fatal-error",
45
- color: "primary",
46
- variant: "contained",
47
- onClick: function onClick() {
48
- return setDialogOpen(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]; } };
49
7
  }
50
- }, resetButtonText), /*#__PURE__*/_react.default.createElement(_FactoryResetDialog.default, {
51
- onClose: function onClose() {
52
- return setDialogOpen(false);
53
- },
54
- open: dialogOpen,
55
- onFactoryReset: onFactoryReset
56
- }));
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;
17
+ });
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 Button_1 = __importDefault(require("@mui/material/Button"));
30
+ const Dialog_1 = __importDefault(require("@mui/material/Dialog"));
31
+ const DialogActions_1 = __importDefault(require("@mui/material/DialogActions"));
32
+ const DialogContent_1 = __importDefault(require("@mui/material/DialogContent"));
33
+ const DialogTitle_1 = __importDefault(require("@mui/material/DialogTitle"));
34
+ const prop_types_1 = __importDefault(require("prop-types"));
35
+ const react_1 = __importStar(require("react"));
36
+ const FactoryResetDialog_1 = __importDefault(require("./FactoryResetDialog"));
37
+ const ResetComponent = ({ onFactoryReset, resetButtonText, }) => {
38
+ const [dialogOpen, setDialogOpen] = (0, react_1.useState)(false);
39
+ return (react_1.default.createElement(react_1.default.Fragment, null,
40
+ react_1.default.createElement(Button_1.default, { "data-testid": "fatal-error", color: "primary", variant: "contained", onClick: () => setDialogOpen(true) }, resetButtonText),
41
+ react_1.default.createElement(FactoryResetDialog_1.default, { onClose: () => setDialogOpen(false), open: dialogOpen, onFactoryReset: onFactoryReset })));
57
42
  };
58
-
59
43
  ResetComponent.propTypes = {
60
- onFactoryReset: _propTypes.default.func.isRequired,
61
- resetButtonText: _propTypes.default.string.isRequired
44
+ onFactoryReset: prop_types_1.default.func.isRequired,
45
+ resetButtonText: prop_types_1.default.string.isRequired,
62
46
  };
63
-
64
- var FatalErrorDialog = function FatalErrorDialog(_ref2) {
65
- var componentStack = _ref2.componentStack,
66
- error = _ref2.error,
67
- onFactoryReset = _ref2.onFactoryReset,
68
- resetButtonText = _ref2.resetButtonText;
69
- return /*#__PURE__*/_react.default.createElement(_Dialog.default, {
70
- open: true
71
- }, /*#__PURE__*/_react.default.createElement(_DialogTitle.default, {
72
- style: {
73
- backgroundColor: '#e88'
74
- }
75
- }, "Fatal error"), /*#__PURE__*/_react.default.createElement(_DialogContent.default, null, /*#__PURE__*/_react.default.createElement("pre", null, error.toString(), componentStack)), /*#__PURE__*/_react.default.createElement(_DialogActions.default, null, /*#__PURE__*/_react.default.createElement(_Button.default, {
76
- color: "secondary",
77
- variant: "contained",
78
- onClick: function onClick() {
79
- return window.location.reload();
80
- }
81
- }, "Refresh"), /*#__PURE__*/_react.default.createElement(ResetComponent, {
82
- onFactoryReset: onFactoryReset,
83
- resetButtonText: resetButtonText
84
- })));
47
+ const FatalErrorDialog = ({ componentStack, error, onFactoryReset, resetButtonText, }) => {
48
+ return (react_1.default.createElement(Dialog_1.default, { open: true },
49
+ react_1.default.createElement(DialogTitle_1.default, { style: { backgroundColor: '#e88' } }, "Fatal error"),
50
+ react_1.default.createElement(DialogContent_1.default, null,
51
+ react_1.default.createElement("pre", null,
52
+ error.toString(),
53
+ componentStack)),
54
+ react_1.default.createElement(DialogActions_1.default, null,
55
+ react_1.default.createElement(Button_1.default, { color: "secondary", variant: "contained", onClick: () => window.location.reload() }, "Refresh"),
56
+ react_1.default.createElement(ResetComponent, { onFactoryReset: onFactoryReset, resetButtonText: resetButtonText }))));
85
57
  };
86
-
87
58
  FatalErrorDialog.propTypes = {
88
- componentStack: _propTypes.default.string,
89
- error: _propTypes.default.shape({}),
90
- onFactoryReset: _propTypes.default.func.isRequired,
91
- resetButtonText: _propTypes.default.string
59
+ componentStack: prop_types_1.default.string,
60
+ error: prop_types_1.default.shape({}),
61
+ onFactoryReset: prop_types_1.default.func.isRequired,
62
+ resetButtonText: prop_types_1.default.string,
92
63
  };
93
64
  FatalErrorDialog.defaultProps = {
94
- error: {
95
- message: 'No error message provided'
96
- },
97
- componentStack: '',
98
- resetButtonText: 'Factory Reset'
65
+ error: { message: 'No error message provided' },
66
+ componentStack: '',
67
+ resetButtonText: 'Factory Reset',
99
68
  };
100
- var _default = FatalErrorDialog;
101
- exports.default = _default;
69
+ exports.default = FatalErrorDialog;