@jbrowse/core 2.0.1 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (179) hide show
  1. package/BaseFeatureWidget/BaseFeatureDetail.d.ts +6 -0
  2. package/BaseFeatureWidget/BaseFeatureDetail.js +313 -592
  3. package/BaseFeatureWidget/SequenceFeatureDetails.js +213 -479
  4. package/BaseFeatureWidget/index.js +88 -126
  5. package/BaseFeatureWidget/types.js +1 -4
  6. package/BaseFeatureWidget/util.js +40 -75
  7. package/CorePlugin.js +55 -94
  8. package/Plugin.js +9 -34
  9. package/PluginLoader.js +153 -422
  10. package/PluginManager.d.ts +17 -14
  11. package/PluginManager.js +377 -666
  12. package/ReExports/Attributes.js +3 -10
  13. package/ReExports/BaseCard.js +3 -10
  14. package/ReExports/DataGrid.js +5 -12
  15. package/ReExports/FeatureDetails.js +3 -10
  16. package/ReExports/index.js +6 -12
  17. package/ReExports/list.d.ts +5 -0
  18. package/ReExports/list.js +271 -7
  19. package/ReExports/material-ui-colors.js +15 -16
  20. package/ReExports/modules.d.ts +0 -1
  21. package/ReExports/modules.js +453 -798
  22. package/TextSearch/BaseResults.js +51 -123
  23. package/TextSearch/TextSearchManager.js +66 -144
  24. package/assemblyManager/assembly.js +280 -555
  25. package/assemblyManager/assemblyConfigSchema.js +47 -64
  26. package/assemblyManager/assemblyManager.js +126 -272
  27. package/assemblyManager/index.js +9 -22
  28. package/configuration/configurationSchema.js +167 -203
  29. package/configuration/configurationSlot.js +248 -326
  30. package/configuration/index.js +19 -35
  31. package/configuration/util.js +131 -173
  32. package/data_adapters/BaseAdapter.d.ts +2 -2
  33. package/data_adapters/BaseAdapter.js +132 -521
  34. package/data_adapters/CytobandAdapter.js +40 -126
  35. package/data_adapters/dataAdapterCache.js +77 -158
  36. package/package.json +4 -5
  37. package/pluggableElementTypes/AdapterType.js +24 -79
  38. package/pluggableElementTypes/AddTrackWorkflowType.d.ts +17 -0
  39. package/pluggableElementTypes/AddTrackWorkflowType.js +20 -0
  40. package/pluggableElementTypes/ConnectionType.js +22 -65
  41. package/pluggableElementTypes/DisplayType.js +35 -82
  42. package/pluggableElementTypes/InternetAccountType.js +23 -64
  43. package/pluggableElementTypes/PluggableElementBase.js +8 -20
  44. package/pluggableElementTypes/RpcMethodType.js +85 -427
  45. package/pluggableElementTypes/TextSearchAdapterType.js +16 -55
  46. package/pluggableElementTypes/TrackType.js +26 -70
  47. package/pluggableElementTypes/ViewType.js +21 -63
  48. package/pluggableElementTypes/WidgetType.js +21 -64
  49. package/pluggableElementTypes/index.d.ts +4 -3
  50. package/pluggableElementTypes/index.js +42 -125
  51. package/pluggableElementTypes/models/BaseConnectionModelFactory.js +28 -43
  52. package/pluggableElementTypes/models/BaseDisplayModel.js +58 -95
  53. package/pluggableElementTypes/models/BaseTrackModel.js +139 -199
  54. package/pluggableElementTypes/models/BaseViewModel.js +24 -40
  55. package/pluggableElementTypes/models/InternetAccountModel.js +116 -263
  56. package/pluggableElementTypes/models/baseConnectionConfig.js +14 -25
  57. package/pluggableElementTypes/models/baseInternetAccountConfig.js +29 -38
  58. package/pluggableElementTypes/models/baseTrackConfig.js +106 -133
  59. package/pluggableElementTypes/models/index.js +21 -70
  60. package/pluggableElementTypes/renderers/BoxRendererType.js +132 -291
  61. package/pluggableElementTypes/renderers/CircularChordRendererType.js +8 -38
  62. package/pluggableElementTypes/renderers/ComparativeServerSideRendererType.js +60 -192
  63. package/pluggableElementTypes/renderers/FeatureRendererType.d.ts +0 -2
  64. package/pluggableElementTypes/renderers/FeatureRendererType.js +89 -264
  65. package/pluggableElementTypes/renderers/RendererType.js +31 -105
  66. package/pluggableElementTypes/renderers/ServerSideRenderedContent.js +61 -72
  67. package/pluggableElementTypes/renderers/ServerSideRendererType.js +112 -265
  68. package/pluggableElementTypes/renderers/index.js +19 -62
  69. package/pluggableElementTypes/renderers/util/serializableFilterChain.js +27 -65
  70. package/rpc/BaseRpcDriver.js +169 -405
  71. package/rpc/MainThreadRpcDriver.js +27 -150
  72. package/rpc/RpcManager.js +58 -159
  73. package/rpc/WebWorkerRpcDriver.js +54 -171
  74. package/rpc/configSchema.js +25 -49
  75. package/rpc/coreRpcMethods.js +221 -959
  76. package/rpc/remoteAbortSignals.js +46 -70
  77. package/tsconfig.build.tsbuildinfo +1 -1
  78. package/ui/AboutDialog.js +106 -162
  79. package/ui/App.js +157 -242
  80. package/ui/AssemblySelector.js +59 -120
  81. package/ui/CascadingMenu.js +101 -196
  82. package/ui/ColorPicker.d.ts +16 -0
  83. package/ui/ColorPicker.js +97 -0
  84. package/ui/Drawer.js +28 -61
  85. package/ui/DrawerWidget.js +108 -202
  86. package/ui/DropDownMenu.js +60 -91
  87. package/ui/EditableTypography.js +87 -149
  88. package/ui/ErrorMessage.js +41 -56
  89. package/ui/FactoryResetDialog.js +24 -57
  90. package/ui/FatalErrorDialog.js +59 -91
  91. package/ui/FileSelector/FileSelector.js +123 -189
  92. package/ui/FileSelector/LocalFileChooser.js +44 -75
  93. package/ui/FileSelector/UrlChooser.js +17 -38
  94. package/ui/FileSelector/index.js +6 -12
  95. package/ui/Icons.js +45 -69
  96. package/ui/Logo.js +57 -110
  97. package/ui/Menu.js +232 -354
  98. package/ui/PrerenderedCanvas.js +63 -87
  99. package/ui/ResizeHandle.js +87 -116
  100. package/ui/ReturnToImportFormDialog.js +32 -63
  101. package/ui/SanitizedHTML.js +64 -47
  102. package/ui/Snackbar.js +74 -101
  103. package/ui/SnackbarModel.js +37 -51
  104. package/ui/Tooltip.js +49 -76
  105. package/ui/ViewContainer.js +113 -196
  106. package/ui/colors.d.ts +10 -0
  107. package/ui/colors.js +78 -0
  108. package/ui/index.js +51 -181
  109. package/ui/react-colorful.d.ts +17 -0
  110. package/ui/react-colorful.js +455 -0
  111. package/ui/theme.js +199 -247
  112. package/util/Base1DUtils.js +163 -202
  113. package/util/Base1DViewModel.js +121 -168
  114. package/util/QuickLRU.js +84 -332
  115. package/util/TimeTraveller.d.ts +19 -0
  116. package/util/TimeTraveller.js +86 -0
  117. package/util/aborting.js +49 -127
  118. package/util/analytics.js +91 -154
  119. package/util/blockTypes.js +106 -240
  120. package/util/calculateDynamicBlocks.js +98 -128
  121. package/util/calculateStaticBlocks.js +105 -125
  122. package/util/color/cssColorsLevel4.js +156 -160
  123. package/util/color/index.js +33 -55
  124. package/util/compositeMap.js +49 -333
  125. package/util/formatFastaStrings.js +9 -14
  126. package/util/idMaker.js +18 -31
  127. package/util/index.d.ts +7 -20
  128. package/util/index.js +742 -1188
  129. package/util/io/RemoteFileWithRangeCache.js +88 -257
  130. package/util/io/index.js +95 -169
  131. package/util/jexl.js +60 -115
  132. package/util/jexlStrings.js +24 -29
  133. package/util/layouts/BaseLayout.js +1 -4
  134. package/util/layouts/GranularRectLayout.js +388 -555
  135. package/util/layouts/MultiLayout.js +41 -109
  136. package/util/layouts/PrecomputedLayout.js +56 -112
  137. package/util/layouts/PrecomputedMultiLayout.js +22 -59
  138. package/util/layouts/SceneGraph.js +127 -197
  139. package/util/layouts/index.js +29 -66
  140. package/util/mst-reflection.js +55 -71
  141. package/util/offscreenCanvasPonyfill.js +66 -134
  142. package/util/offscreenCanvasUtils.d.ts +2 -7
  143. package/util/offscreenCanvasUtils.js +49 -146
  144. package/util/range.js +29 -40
  145. package/util/rxjs.js +20 -27
  146. package/util/simpleFeature.js +88 -152
  147. package/util/stats.js +91 -151
  148. package/util/tracks.js +130 -173
  149. package/util/types/index.js +110 -179
  150. package/util/types/mst.js +91 -146
  151. package/util/types/util.js +1 -4
  152. package/util/when.js +54 -101
  153. package/BaseFeatureWidget/SequenceFeatureDetails.test.js +0 -122
  154. package/BaseFeatureWidget/index.test.js +0 -69
  155. package/TextSearch/BaseResults.test.js +0 -42
  156. package/configuration/configurationSchema.test.js +0 -266
  157. package/configuration/configurationSlot.test.js +0 -69
  158. package/configuration/util.test.js +0 -39
  159. package/data_adapters/BaseAdapter.test.js +0 -200
  160. package/declare.d.js +0 -1
  161. package/pluggableElementTypes/RpcMethodType.test.js +0 -118
  162. package/pluggableElementTypes/renderers/declare.d.js +0 -1
  163. package/pluggableElementTypes/renderers/util/serializableFilterChain.test.js +0 -20
  164. package/rpc/BaseRpcDriver.test.js +0 -540
  165. package/rpc/declaration.d.js +0 -1
  166. package/ui/FatalErrorDialog.test.js +0 -82
  167. package/ui/SanitizedHTML.test.js +0 -36
  168. package/ui/theme.test.js +0 -92
  169. package/util/Base1DViewModel.test.js +0 -130
  170. package/util/calculateDynamicBlocks.test.js +0 -74
  171. package/util/calculateStaticBlocks.test.js +0 -297
  172. package/util/declare.d.js +0 -1
  173. package/util/formatFastaStrings.test.js +0 -40
  174. package/util/index.test.js +0 -213
  175. package/util/jexlStrings.test.js +0 -48
  176. package/util/layouts/GranularRectLayout.test.js +0 -99
  177. package/util/range.test.js +0 -64
  178. package/util/simpleFeature.test.js +0 -34
  179. package/util/stats.test.js +0 -172
@@ -1,186 +1,142 @@
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 _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
11
-
12
- var _mobxStateTree = require("mobx-state-tree");
13
-
14
- var _index = require("./index");
15
-
16
- var _mst = require("./types/mst");
17
-
18
- var _calculateDynamicBlocks = _interopRequireDefault(require("./calculateDynamicBlocks"));
19
-
20
- var _calculateStaticBlocks = _interopRequireDefault(require("./calculateStaticBlocks"));
21
-
22
- var _Base1DUtils = require("./Base1DUtils");
23
-
24
- var Base1DView = _mobxStateTree.types.model('Base1DView', {
25
- id: _mst.ElementId,
26
- displayedRegions: _mobxStateTree.types.array(_mst.Region),
27
- bpPerPx: 0,
28
- offsetPx: 0,
29
- interRegionPaddingWidth: _mobxStateTree.types.optional(_mobxStateTree.types.number, 0),
30
- minimumBlockWidth: _mobxStateTree.types.optional(_mobxStateTree.types.number, 0)
31
- }).volatile(function () {
32
- return {
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 mobx_state_tree_1 = require("mobx-state-tree");
7
+ const index_1 = require("./index");
8
+ const mst_1 = require("./types/mst");
9
+ const calculateDynamicBlocks_1 = __importDefault(require("./calculateDynamicBlocks"));
10
+ const calculateStaticBlocks_1 = __importDefault(require("./calculateStaticBlocks"));
11
+ const Base1DUtils_1 = require("./Base1DUtils");
12
+ const Base1DView = mobx_state_tree_1.types
13
+ .model('Base1DView', {
14
+ id: mst_1.ElementId,
15
+ displayedRegions: mobx_state_tree_1.types.array(mst_1.Region),
16
+ bpPerPx: 0,
17
+ offsetPx: 0,
18
+ interRegionPaddingWidth: mobx_state_tree_1.types.optional(mobx_state_tree_1.types.number, 0),
19
+ minimumBlockWidth: mobx_state_tree_1.types.optional(mobx_state_tree_1.types.number, 0),
20
+ })
21
+ .volatile(() => ({
33
22
  features: undefined,
34
- volatileWidth: 0
35
- };
36
- }).actions(function (self) {
37
- return {
38
- setDisplayedRegions: function setDisplayedRegions(regions) {
39
- self.displayedRegions = (0, _mobxStateTree.cast)(regions);
40
- },
41
- setBpPerPx: function setBpPerPx(val) {
42
- self.bpPerPx = val;
43
- },
44
- setVolatileWidth: function setVolatileWidth(width) {
45
- self.volatileWidth = width;
46
- }
47
- };
48
- }).views(function (self) {
49
- return {
23
+ volatileWidth: 0,
24
+ }))
25
+ .actions(self => ({
26
+ setDisplayedRegions(regions) {
27
+ self.displayedRegions = (0, mobx_state_tree_1.cast)(regions);
28
+ },
29
+ setBpPerPx(val) {
30
+ self.bpPerPx = val;
31
+ },
32
+ setVolatileWidth(width) {
33
+ self.volatileWidth = width;
34
+ },
35
+ }))
36
+ .views(self => ({
50
37
  get width() {
51
- return self.volatileWidth;
38
+ return self.volatileWidth;
52
39
  },
53
-
54
40
  get assemblyNames() {
55
- return (0, _toConsumableArray2.default)(new Set(self.displayedRegions.map(function (region) {
56
- return region.assemblyName;
57
- })));
41
+ return [
42
+ ...new Set(self.displayedRegions.map(region => region.assemblyName)),
43
+ ];
58
44
  },
59
-
60
45
  get displayedRegionsTotalPx() {
61
- return this.totalBp / self.bpPerPx;
46
+ return this.totalBp / self.bpPerPx;
62
47
  },
63
-
64
48
  get maxOffset() {
65
- // objectively determined to keep the linear genome on the main screen
66
- var leftPadding = 10;
67
- return this.displayedRegionsTotalPx - leftPadding;
49
+ // objectively determined to keep the linear genome on the main screen
50
+ const leftPadding = 10;
51
+ return this.displayedRegionsTotalPx - leftPadding;
68
52
  },
69
-
70
53
  get minOffset() {
71
- // objectively determined to keep the linear genome on the main screen
72
- var rightPadding = 30;
73
- return -this.width + rightPadding;
54
+ // objectively determined to keep the linear genome on the main screen
55
+ const rightPadding = 30;
56
+ return -this.width + rightPadding;
74
57
  },
75
-
76
58
  get totalBp() {
77
- return self.displayedRegions.map(function (a) {
78
- return a.end - a.start;
79
- }).reduce(function (a, b) {
80
- return a + b;
81
- }, 0);
82
- }
83
-
84
- };
85
- }).views(function (self) {
86
- return {
59
+ return self.displayedRegions
60
+ .map(a => a.end - a.start)
61
+ .reduce((a, b) => a + b, 0);
62
+ },
63
+ }))
64
+ .views(self => ({
87
65
  get dynamicBlocks() {
88
- return (0, _calculateDynamicBlocks.default)(self);
66
+ return (0, calculateDynamicBlocks_1.default)(self);
89
67
  },
90
-
91
68
  get staticBlocks() {
92
- return (0, _calculateStaticBlocks.default)(self);
69
+ return (0, calculateStaticBlocks_1.default)(self);
93
70
  },
94
-
95
71
  get currBp() {
96
- return this.dynamicBlocks.map(function (a) {
97
- return a.end - a.start;
98
- }).reduce(function (a, b) {
99
- return a + b;
100
- }, 0);
101
- }
102
-
103
- };
104
- }).views(function (self) {
105
- return {
106
- pxToBp: function pxToBp(px) {
107
- return (0, _Base1DUtils.pxToBp)(self, px);
108
- },
109
- bpToPx: function bpToPx(_ref) {
110
- var _bpToPx2;
111
-
112
- var refName = _ref.refName,
113
- coord = _ref.coord,
114
- regionNumber = _ref.regionNumber;
115
- return (_bpToPx2 = (0, _Base1DUtils.bpToPx)({
116
- refName: refName,
117
- coord: coord,
118
- regionNumber: regionNumber,
119
- self: self
120
- })) === null || _bpToPx2 === void 0 ? void 0 : _bpToPx2.offsetPx;
121
- }
122
- };
123
- }).actions(function (self) {
124
- return {
125
- setFeatures: function setFeatures(features) {
126
- self.features = features;
72
+ return this.dynamicBlocks
73
+ .map(a => a.end - a.start)
74
+ .reduce((a, b) => a + b, 0);
127
75
  },
128
- // this makes a zoomed out view that shows all displayedRegions
129
- // that makes the overview bar square with the scale bar
130
- showAllRegions: function showAllRegions() {
131
- self.bpPerPx = self.totalBp / self.width;
132
- self.offsetPx = 0;
76
+ }))
77
+ .views(self => ({
78
+ pxToBp(px) {
79
+ return (0, Base1DUtils_1.pxToBp)(self, px);
133
80
  },
134
- zoomOut: function zoomOut() {
135
- this.zoomTo(self.bpPerPx * 2);
81
+ bpToPx({ refName, coord, regionNumber, }) {
82
+ var _a;
83
+ return (_a = (0, Base1DUtils_1.bpToPx)({ refName, coord, regionNumber, self })) === null || _a === void 0 ? void 0 : _a.offsetPx;
136
84
  },
137
- zoomIn: function zoomIn() {
138
- this.zoomTo(self.bpPerPx / 2);
85
+ }))
86
+ .actions(self => ({
87
+ setFeatures(features) {
88
+ self.features = features;
139
89
  },
140
- zoomTo: function zoomTo(newBpPerPx) {
141
- var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : self.width / 2;
142
- var bpPerPx = newBpPerPx;
143
-
144
- if (bpPerPx === self.bpPerPx) {
90
+ // this makes a zoomed out view that shows all displayedRegions
91
+ // that makes the overview bar square with the scale bar
92
+ showAllRegions() {
93
+ self.bpPerPx = self.totalBp / self.width;
94
+ self.offsetPx = 0;
95
+ },
96
+ zoomOut() {
97
+ this.zoomTo(self.bpPerPx * 2);
98
+ },
99
+ zoomIn() {
100
+ this.zoomTo(self.bpPerPx / 2);
101
+ },
102
+ zoomTo(newBpPerPx, offset = self.width / 2) {
103
+ const bpPerPx = newBpPerPx;
104
+ if (bpPerPx === self.bpPerPx) {
105
+ return self.bpPerPx;
106
+ }
107
+ const oldBpPerPx = self.bpPerPx;
108
+ self.bpPerPx = bpPerPx;
109
+ // tweak the offset so that the center of the view remains at the same coordinate
110
+ self.offsetPx = (0, index_1.clamp)(Math.round(((self.offsetPx + offset) * oldBpPerPx) / bpPerPx - offset), self.minOffset, self.maxOffset);
145
111
  return self.bpPerPx;
146
- }
147
-
148
- var oldBpPerPx = self.bpPerPx;
149
- self.bpPerPx = bpPerPx; // tweak the offset so that the center of the view remains at the same coordinate
150
-
151
- self.offsetPx = (0, _index.clamp)(Math.round((self.offsetPx + offset) * oldBpPerPx / bpPerPx - offset), self.minOffset, self.maxOffset);
152
- return self.bpPerPx;
153
- },
154
- scrollTo: function scrollTo(offsetPx) {
155
- var newOffsetPx = (0, _index.clamp)(offsetPx, self.minOffset, self.maxOffset);
156
- self.offsetPx = newOffsetPx;
157
- return newOffsetPx;
158
- },
159
- centerAt: function centerAt(coord, refName, regionNumber) {
160
- if (!refName) {
161
- return;
162
- }
163
-
164
- var centerPx = self.bpToPx({
165
- refName: refName,
166
- coord: coord,
167
- regionNumber: regionNumber
168
- });
169
-
170
- if (centerPx) {
171
- this.scrollTo(Math.round(centerPx - self.width / 2));
172
- }
173
- },
174
- scroll: function scroll(distance) {
175
- var oldOffsetPx = self.offsetPx; // the scroll is clamped to keep the linear genome on the main screen
176
-
177
- var newOffsetPx = (0, _index.clamp)(self.offsetPx + distance, self.minOffset, self.maxOffset);
178
- self.offsetPx = newOffsetPx;
179
- return newOffsetPx - oldOffsetPx;
180
- }
181
- };
182
- }).actions(function (self) {
183
- return {
112
+ },
113
+ scrollTo(offsetPx) {
114
+ const newOffsetPx = (0, index_1.clamp)(offsetPx, self.minOffset, self.maxOffset);
115
+ self.offsetPx = newOffsetPx;
116
+ return newOffsetPx;
117
+ },
118
+ centerAt(coord, refName, regionNumber) {
119
+ if (!refName) {
120
+ return;
121
+ }
122
+ const centerPx = self.bpToPx({
123
+ refName,
124
+ coord,
125
+ regionNumber,
126
+ });
127
+ if (centerPx) {
128
+ this.scrollTo(Math.round(centerPx - self.width / 2));
129
+ }
130
+ },
131
+ scroll(distance) {
132
+ const oldOffsetPx = self.offsetPx;
133
+ // the scroll is clamped to keep the linear genome on the main screen
134
+ const newOffsetPx = (0, index_1.clamp)(self.offsetPx + distance, self.minOffset, self.maxOffset);
135
+ self.offsetPx = newOffsetPx;
136
+ return newOffsetPx - oldOffsetPx;
137
+ },
138
+ }))
139
+ .actions(self => ({
184
140
  /**
185
141
  * offset is the base-pair-offset in the displayed region, index is the index of the
186
142
  * displayed region in the linear genome view
@@ -188,11 +144,8 @@ var Base1DView = _mobxStateTree.types.model('Base1DView', {
188
144
  * @param start - object as `{start, end, offset, index}`
189
145
  * @param end - object as `{start, end, offset, index}`
190
146
  */
191
- moveTo: function moveTo(start, end) {
192
- (0, _Base1DUtils.moveTo)(self, start, end);
193
- }
194
- };
195
- });
196
-
197
- var _default = Base1DView;
198
- exports.default = _default;
147
+ moveTo(start, end) {
148
+ (0, Base1DUtils_1.moveTo)(self, start, end);
149
+ },
150
+ }));
151
+ exports.default = Base1DView;