@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,577 +1,302 @@
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 = assemblyFactory;
9
-
10
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
11
-
12
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
-
14
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
15
-
16
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
17
-
18
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
19
-
20
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
21
-
22
- var _jsonStableStringify = _interopRequireDefault(require("json-stable-stringify"));
23
-
24
- var _mobxStateTree = require("mobx-state-tree");
25
-
26
- var _abortablePromiseCache = _interopRequireDefault(require("abortable-promise-cache"));
27
-
28
- var _configuration = require("../configuration");
29
-
30
- var _util = require("../util");
31
-
32
- var _QuickLRU = _interopRequireDefault(require("../util/QuickLRU"));
33
-
34
- var _excluded = ["signal", "statusCallback"];
35
-
36
- 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; }
37
-
38
- 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; }
39
-
40
- var refNameRegex = new RegExp('[0-9A-Za-z!#$%&+./:;?@^_|~-][0-9A-Za-z!#$%&*+./:;=?@^_|~-]*'); // Based on the UCSC Genome Browser chromosome color palette:
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 json_stable_stringify_1 = __importDefault(require("json-stable-stringify"));
7
+ const mobx_state_tree_1 = require("mobx-state-tree");
8
+ const abortable_promise_cache_1 = __importDefault(require("abortable-promise-cache"));
9
+ const configuration_1 = require("../configuration");
10
+ const util_1 = require("../util");
11
+ const QuickLRU_1 = __importDefault(require("../util/QuickLRU"));
12
+ const refNameRegex = new RegExp('[0-9A-Za-z!#$%&+./:;?@^_|~-][0-9A-Za-z!#$%&*+./:;=?@^_|~-]*');
13
+ // Based on the UCSC Genome Browser chromosome color palette:
41
14
  // https://github.com/ucscGenomeBrowser/kent/blob/a50ed53aff81d6fb3e34e6913ce18578292bc24e/src/hg/inc/chromColors.h
42
15
  // Some colors darkened to have at least a 3:1 contrast ratio on a white
43
16
  // background
44
-
45
- var refNameColors = ['rgb(153, 102, 0)', 'rgb(102, 102, 0)', 'rgb(153, 153, 30)', 'rgb(204, 0, 0)', 'rgb(255, 0, 0)', 'rgb(255, 0, 204)', 'rgb(165, 132, 132)', // originally 'rgb(255, 204, 204)'
46
- 'rgb(204, 122, 0)', // originally rgb(255, 153, 0)'
47
- 'rgb(178, 142, 0)', // originally 'rgb(255, 204, 0)'
48
- 'rgb(153, 153, 0)', // originally 'rgb(255, 255, 0)'
49
- 'rgb(122, 153, 0)', // originally 'rgb(204, 255, 0)'
50
- 'rgb(0, 165, 0)', // originally 'rgb(0, 255, 0)'
51
- 'rgb(53, 128, 0)', 'rgb(0, 0, 204)', 'rgb(96, 145, 242)', // originally 'rgb(102, 153, 255)'
52
- 'rgb(107, 142, 178)', // originally 'rgb(153, 204, 255)'
53
- 'rgb(0, 165, 165)', // originally 'rgb(0, 255, 255)'
54
- 'rgb(122, 153, 153)', // originally 'rgb(204, 255, 255)'
55
- 'rgb(153, 0, 204)', 'rgb(204, 51, 255)', 'rgb(173, 130, 216)', // originally 'rgb(204, 153, 255)'
56
- 'rgb(102, 102, 102)', 'rgb(145, 145, 145)', // originally 'rgb(153, 153, 153)'
57
- 'rgb(142, 142, 142)', // originally 'rgb(204, 204, 204)'
58
- 'rgb(142, 142, 107)', // originally 'rgb(204, 204, 153)'
59
- 'rgb(96, 163, 48)' // originally 'rgb(121, 204, 61)'
17
+ const refNameColors = [
18
+ 'rgb(153, 102, 0)',
19
+ 'rgb(102, 102, 0)',
20
+ 'rgb(153, 153, 30)',
21
+ 'rgb(204, 0, 0)',
22
+ 'rgb(255, 0, 0)',
23
+ 'rgb(255, 0, 204)',
24
+ 'rgb(165, 132, 132)',
25
+ 'rgb(204, 122, 0)',
26
+ 'rgb(178, 142, 0)',
27
+ 'rgb(153, 153, 0)',
28
+ 'rgb(122, 153, 0)',
29
+ 'rgb(0, 165, 0)',
30
+ 'rgb(53, 128, 0)',
31
+ 'rgb(0, 0, 204)',
32
+ 'rgb(96, 145, 242)',
33
+ 'rgb(107, 142, 178)',
34
+ 'rgb(0, 165, 165)',
35
+ 'rgb(122, 153, 153)',
36
+ 'rgb(153, 0, 204)',
37
+ 'rgb(204, 51, 255)',
38
+ 'rgb(173, 130, 216)',
39
+ 'rgb(102, 102, 102)',
40
+ 'rgb(145, 145, 145)',
41
+ 'rgb(142, 142, 142)',
42
+ 'rgb(142, 142, 107)',
43
+ 'rgb(96, 163, 48)', // originally 'rgb(121, 204, 61)'
60
44
  ];
61
-
62
- function loadRefNameMap(_x, _x2, _x3, _x4) {
63
- return _loadRefNameMap.apply(this, arguments);
64
- } // Valid refName pattern from https://samtools.github.io/hts-specs/SAMv1.pdf
65
-
66
-
67
- function _loadRefNameMap() {
68
- _loadRefNameMap = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(assembly, adapterConfig, options, signal) {
69
- var sessionId, refNames, refNameAliases, refNameMap, reversed;
70
- return _regenerator.default.wrap(function _callee4$(_context4) {
71
- while (1) {
72
- switch (_context4.prev = _context4.next) {
73
- case 0:
74
- sessionId = options.sessionId;
75
- _context4.next = 3;
76
- return (0, _util.when)(function () {
77
- return Boolean(assembly.regions && assembly.refNameAliases);
78
- }, {
79
- signal: signal,
80
- name: 'when assembly ready'
81
- });
82
-
83
- case 3:
84
- _context4.next = 5;
85
- return assembly.rpcManager.call(sessionId, 'CoreGetRefNames', _objectSpread({
86
- adapterConfig: adapterConfig,
87
- signal: signal
88
- }, options), {
89
- timeout: 1000000
90
- });
91
-
92
- case 5:
93
- refNames = _context4.sent;
94
- refNameAliases = assembly.refNameAliases;
95
-
96
- if (refNameAliases) {
97
- _context4.next = 9;
98
- break;
99
- }
100
-
101
- throw new Error("error loading assembly ".concat(assembly.name, "'s refNameAliases"));
102
-
103
- case 9:
104
- refNameMap = Object.fromEntries(refNames.map(function (name) {
105
- checkRefName(name);
106
- return [assembly.getCanonicalRefName(name), name];
107
- })); // make the reversed map too
108
-
109
- reversed = Object.fromEntries(Object.entries(refNameMap).map(function (_ref2) {
110
- var _ref3 = (0, _slicedToArray2.default)(_ref2, 2),
111
- canonicalName = _ref3[0],
112
- adapterName = _ref3[1];
113
-
114
- return [adapterName, canonicalName];
115
- }));
116
- return _context4.abrupt("return", {
117
- forwardMap: refNameMap,
118
- reverseMap: reversed
119
- });
120
-
121
- case 12:
122
- case "end":
123
- return _context4.stop();
124
- }
125
- }
126
- }, _callee4);
127
- }));
128
- return _loadRefNameMap.apply(this, arguments);
45
+ async function loadRefNameMap(assembly, adapterConfig, options, signal) {
46
+ const { sessionId } = options;
47
+ await (0, util_1.when)(() => Boolean(assembly.regions && assembly.refNameAliases), {
48
+ signal,
49
+ name: 'when assembly ready',
50
+ });
51
+ const refNames = (await assembly.rpcManager.call(sessionId, 'CoreGetRefNames', {
52
+ adapterConfig,
53
+ signal,
54
+ ...options,
55
+ }, { timeout: 1000000 }));
56
+ const { refNameAliases } = assembly;
57
+ if (!refNameAliases) {
58
+ throw new Error(`error loading assembly ${assembly.name}'s refNameAliases`);
59
+ }
60
+ const refNameMap = Object.fromEntries(refNames.map(name => {
61
+ checkRefName(name);
62
+ return [assembly.getCanonicalRefName(name), name];
63
+ }));
64
+ // make the reversed map too
65
+ const reversed = Object.fromEntries(Object.entries(refNameMap).map(([canonicalName, adapterName]) => [
66
+ adapterName,
67
+ canonicalName,
68
+ ]));
69
+ return {
70
+ forwardMap: refNameMap,
71
+ reverseMap: reversed,
72
+ };
129
73
  }
130
-
74
+ // Valid refName pattern from https://samtools.github.io/hts-specs/SAMv1.pdf
131
75
  function checkRefName(refName) {
132
- if (!refName.match(refNameRegex)) {
133
- throw new Error("Encountered invalid refName: \"".concat(refName, "\""));
134
- }
76
+ if (!refName.match(refNameRegex)) {
77
+ throw new Error(`Encountered invalid refName: "${refName}"`);
78
+ }
135
79
  }
136
-
137
80
  function getAdapterId(adapterConf) {
138
- return (0, _jsonStableStringify.default)(adapterConf);
81
+ return (0, json_stable_stringify_1.default)(adapterConf);
139
82
  }
140
-
141
83
  function assemblyFactory(assemblyConfigType, pluginManager) {
142
- var adapterLoads = new _abortablePromiseCache.default({
143
- cache: new _QuickLRU.default({
144
- maxSize: 1000
145
- }),
146
- fill: function fill(args, abortSignal, statusCallback) {
147
- return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
148
- var adapterConf, self, options;
149
- return _regenerator.default.wrap(function _callee$(_context) {
150
- while (1) {
151
- switch (_context.prev = _context.next) {
152
- case 0:
153
- adapterConf = args.adapterConf, self = args.self, options = args.options;
154
- return _context.abrupt("return", loadRefNameMap(self, adapterConf, _objectSpread(_objectSpread({}, options), {}, {
155
- statusCallback: statusCallback
156
- }), abortSignal));
157
-
158
- case 2:
159
- case "end":
160
- return _context.stop();
84
+ const adapterLoads = new abortable_promise_cache_1.default({
85
+ cache: new QuickLRU_1.default({ maxSize: 1000 }),
86
+ async fill(args, abortSignal, statusCallback) {
87
+ const { adapterConf, self, options } = args;
88
+ return loadRefNameMap(self, adapterConf, { ...options, statusCallback }, abortSignal);
89
+ },
90
+ });
91
+ return mobx_state_tree_1.types
92
+ .model({
93
+ configuration: mobx_state_tree_1.types.safeReference(assemblyConfigType),
94
+ })
95
+ .volatile(() => ({
96
+ error: undefined,
97
+ regions: undefined,
98
+ refNameAliases: undefined,
99
+ lowerCaseRefNameAliases: undefined,
100
+ cytobands: undefined,
101
+ }))
102
+ .views(self => ({
103
+ get initialized() {
104
+ return !!self.refNameAliases;
105
+ },
106
+ get name() {
107
+ return (0, configuration_1.getConf)(self, 'name');
108
+ },
109
+ get aliases() {
110
+ return (0, configuration_1.getConf)(self, 'aliases');
111
+ },
112
+ hasName(name) {
113
+ return this.allAliases.includes(name);
114
+ },
115
+ get allAliases() {
116
+ return [this.name, ...this.aliases];
117
+ },
118
+ get refNames() {
119
+ var _a;
120
+ return (_a = self.regions) === null || _a === void 0 ? void 0 : _a.map(region => region.refName);
121
+ },
122
+ // note: lowerCaseRefNameAliases not included here: this allows the list
123
+ // of refnames to be just the "normal casing", but things like
124
+ // getCanonicalRefName can resolve a lower-case name if needed
125
+ get allRefNames() {
126
+ return !self.refNameAliases
127
+ ? undefined
128
+ : Object.keys(self.refNameAliases);
129
+ },
130
+ get rpcManager() {
131
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
132
+ return (0, mobx_state_tree_1.getParent)(self, 2).rpcManager;
133
+ },
134
+ get refNameColors() {
135
+ const colors = (0, configuration_1.getConf)(self, 'refNameColors');
136
+ return colors.length === 0 ? refNameColors : colors;
137
+ },
138
+ }))
139
+ .views(self => ({
140
+ getCanonicalRefName(refName) {
141
+ if (!self.refNameAliases || !self.lowerCaseRefNameAliases) {
142
+ throw new Error('aliases not loaded, we expect them to be loaded before getCanonicalRefName can be called');
161
143
  }
162
- }
163
- }, _callee);
164
- }))();
165
- }
166
- });
167
- return _mobxStateTree.types.model({
168
- configuration: _mobxStateTree.types.safeReference(assemblyConfigType)
169
- }).volatile(function () {
170
- return {
171
- error: undefined,
172
- regions: undefined,
173
- refNameAliases: undefined,
174
- lowerCaseRefNameAliases: undefined,
175
- cytobands: undefined
176
- };
177
- }).views(function (self) {
178
- return {
179
- get initialized() {
180
- return !!self.refNameAliases;
181
- },
182
-
183
- get name() {
184
- return (0, _configuration.getConf)(self, 'name');
185
- },
186
-
187
- get aliases() {
188
- return (0, _configuration.getConf)(self, 'aliases');
189
- },
190
-
191
- hasName: function hasName(name) {
192
- return this.allAliases.includes(name);
193
- },
194
-
195
- get allAliases() {
196
- return [this.name].concat((0, _toConsumableArray2.default)(this.aliases));
197
- },
198
-
199
- get refNames() {
200
- var _self$regions;
201
-
202
- return (_self$regions = self.regions) === null || _self$regions === void 0 ? void 0 : _self$regions.map(function (region) {
203
- return region.refName;
204
- });
205
- },
206
-
207
- // note: lowerCaseRefNameAliases not included here: this allows the list
208
- // of refnames to be just the "normal casing", but things like
209
- // getCanonicalRefName can resolve a lower-case name if needed
210
- get allRefNames() {
211
- return !self.refNameAliases ? undefined : Object.keys(self.refNameAliases);
212
- },
213
-
214
- get rpcManager() {
215
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
216
- return (0, _mobxStateTree.getParent)(self, 2).rpcManager;
217
- },
218
-
219
- get refNameColors() {
220
- var colors = (0, _configuration.getConf)(self, 'refNameColors');
221
- return colors.length === 0 ? refNameColors : colors;
222
- }
223
-
224
- };
225
- }).views(function (self) {
226
- return {
227
- getCanonicalRefName: function getCanonicalRefName(refName) {
228
- if (!self.refNameAliases || !self.lowerCaseRefNameAliases) {
229
- throw new Error('aliases not loaded, we expect them to be loaded before getCanonicalRefName can be called');
230
- }
231
-
232
- return self.refNameAliases[refName] || self.lowerCaseRefNameAliases[refName];
233
- },
234
- getRefNameColor: function getRefNameColor(refName) {
235
- var _self$refNames;
236
-
237
- var idx = (_self$refNames = self.refNames) === null || _self$refNames === void 0 ? void 0 : _self$refNames.findIndex(function (r) {
238
- return r === refName;
239
- });
240
-
241
- if (idx === undefined || idx === -1) {
242
- return undefined;
243
- }
244
-
245
- return self.refNameColors[idx % self.refNameColors.length];
246
- },
247
- isValidRefName: function isValidRefName(refName) {
248
- if (!self.refNameAliases) {
249
- throw new Error('isValidRefName cannot be called yet, the assembly has not finished loading');
250
- }
251
-
252
- return !!this.getCanonicalRefName(refName);
253
- }
254
- };
255
- }).actions(function (self) {
256
- return {
257
- setLoading: function setLoading() {},
258
- setLoaded: function setLoaded(_ref) {
259
- var adapterRegionsWithAssembly = _ref.adapterRegionsWithAssembly,
260
- refNameAliases = _ref.refNameAliases,
261
- lowerCaseRefNameAliases = _ref.lowerCaseRefNameAliases,
262
- cytobands = _ref.cytobands;
263
- this.setRegions(adapterRegionsWithAssembly);
264
- this.setRefNameAliases(refNameAliases, lowerCaseRefNameAliases);
265
- this.setCytobands(cytobands);
266
- },
267
- setError: function setError(e) {
268
- console.error(e);
269
- self.error = e;
270
- },
271
- setRegions: function setRegions(regions) {
272
- self.regions = regions;
273
- },
274
- setRefNameAliases: function setRefNameAliases(refNameAliases, lowerCaseRefNameAliases) {
275
- self.refNameAliases = refNameAliases;
276
- self.lowerCaseRefNameAliases = lowerCaseRefNameAliases;
277
- },
278
- setCytobands: function setCytobands(cytobands) {
279
- self.cytobands = cytobands;
280
- },
281
- afterAttach: function afterAttach() {
282
- (0, _util.makeAbortableReaction)( // eslint-disable-next-line @typescript-eslint/no-explicit-any
283
- self, // @ts-ignore
284
- makeLoadAssemblyData(pluginManager), loadAssemblyReaction, {
285
- name: "".concat(self.name, " assembly loading"),
286
- fireImmediately: true
287
- }, this.setLoading, this.setLoaded, this.setError);
288
- }
289
- };
290
- }).views(function (self) {
291
- return {
292
- getAdapterMapEntry: function getAdapterMapEntry(adapterConf, options) {
293
- var signal = options.signal,
294
- statusCallback = options.statusCallback,
295
- rest = (0, _objectWithoutProperties2.default)(options, _excluded);
296
-
297
- if (!options.sessionId) {
298
- throw new Error('sessionId is required');
299
- }
300
-
301
- var adapterId = getAdapterId(adapterConf);
302
- return adapterLoads.get(adapterId, {
303
- adapterConf: adapterConf,
304
- self: self,
305
- options: rest
306
- }, // signal intentionally not passed here, fixes issues like #2221.
307
- // alternative fix #2540 was proposed but non-working currently
308
- undefined, statusCallback);
309
- },
310
-
311
- /**
312
- * get Map of `canonical-name -> adapter-specific-name`
313
- */
314
- getRefNameMapForAdapter: function getRefNameMapForAdapter(adapterConf, opts) {
315
- var _this = this;
316
-
317
- return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
318
- var map;
319
- return _regenerator.default.wrap(function _callee2$(_context2) {
320
- while (1) {
321
- switch (_context2.prev = _context2.next) {
322
- case 0:
323
- if (!(!opts || !opts.sessionId)) {
324
- _context2.next = 2;
325
- break;
326
- }
327
-
328
- throw new Error('sessionId is required');
329
-
330
- case 2:
331
- _context2.next = 4;
332
- return _this.getAdapterMapEntry(adapterConf, opts);
333
-
334
- case 4:
335
- map = _context2.sent;
336
- return _context2.abrupt("return", map.forwardMap);
337
-
338
- case 6:
339
- case "end":
340
- return _context2.stop();
341
- }
144
+ return (self.refNameAliases[refName] || self.lowerCaseRefNameAliases[refName]);
145
+ },
146
+ getRefNameColor(refName) {
147
+ var _a;
148
+ const idx = (_a = self.refNames) === null || _a === void 0 ? void 0 : _a.findIndex(r => r === refName);
149
+ if (idx === undefined || idx === -1) {
150
+ return undefined;
342
151
  }
343
- }, _callee2);
344
- }))();
345
- },
346
-
347
- /**
348
- * get Map of `adapter-specific-name -> canonical-name`
349
- */
350
- getReverseRefNameMapForAdapter: function getReverseRefNameMapForAdapter(adapterConf, opts) {
351
- var _this2 = this;
352
-
353
- return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3() {
354
- var map;
355
- return _regenerator.default.wrap(function _callee3$(_context3) {
356
- while (1) {
357
- switch (_context3.prev = _context3.next) {
358
- case 0:
359
- _context3.next = 2;
360
- return _this2.getAdapterMapEntry(adapterConf, opts);
361
-
362
- case 2:
363
- map = _context3.sent;
364
- return _context3.abrupt("return", map.reverseMap);
365
-
366
- case 4:
367
- case "end":
368
- return _context3.stop();
369
- }
152
+ return self.refNameColors[idx % self.refNameColors.length];
153
+ },
154
+ isValidRefName(refName) {
155
+ if (!self.refNameAliases) {
156
+ throw new Error('isValidRefName cannot be called yet, the assembly has not finished loading');
370
157
  }
371
- }, _callee3);
372
- }))();
373
- }
374
- };
375
- });
158
+ return !!this.getCanonicalRefName(refName);
159
+ },
160
+ }))
161
+ .actions(self => ({
162
+ setLoading() { },
163
+ setLoaded({ adapterRegionsWithAssembly, refNameAliases, lowerCaseRefNameAliases, cytobands, }) {
164
+ this.setRegions(adapterRegionsWithAssembly);
165
+ this.setRefNameAliases(refNameAliases, lowerCaseRefNameAliases);
166
+ this.setCytobands(cytobands);
167
+ },
168
+ setError(e) {
169
+ console.error(e);
170
+ self.error = e;
171
+ },
172
+ setRegions(regions) {
173
+ self.regions = regions;
174
+ },
175
+ setRefNameAliases(refNameAliases, lowerCaseRefNameAliases) {
176
+ self.refNameAliases = refNameAliases;
177
+ self.lowerCaseRefNameAliases = lowerCaseRefNameAliases;
178
+ },
179
+ setCytobands(cytobands) {
180
+ self.cytobands = cytobands;
181
+ },
182
+ afterAttach() {
183
+ (0, util_1.makeAbortableReaction)(
184
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
185
+ self,
186
+ // @ts-ignore
187
+ makeLoadAssemblyData(pluginManager), loadAssemblyReaction, { name: `${self.name} assembly loading`, fireImmediately: true }, this.setLoading, this.setLoaded, this.setError);
188
+ },
189
+ }))
190
+ .views(self => ({
191
+ getAdapterMapEntry(adapterConf, options) {
192
+ const { signal, statusCallback, ...rest } = options;
193
+ if (!options.sessionId) {
194
+ throw new Error('sessionId is required');
195
+ }
196
+ const adapterId = getAdapterId(adapterConf);
197
+ return adapterLoads.get(adapterId, {
198
+ adapterConf,
199
+ self: self,
200
+ options: rest,
201
+ },
202
+ // signal intentionally not passed here, fixes issues like #2221.
203
+ // alternative fix #2540 was proposed but non-working currently
204
+ undefined, statusCallback);
205
+ },
206
+ /**
207
+ * get Map of `canonical-name -> adapter-specific-name`
208
+ */
209
+ async getRefNameMapForAdapter(adapterConf, opts) {
210
+ if (!opts || !opts.sessionId) {
211
+ throw new Error('sessionId is required');
212
+ }
213
+ const map = await this.getAdapterMapEntry(adapterConf, opts);
214
+ return map.forwardMap;
215
+ },
216
+ /**
217
+ * get Map of `adapter-specific-name -> canonical-name`
218
+ */
219
+ async getReverseRefNameMapForAdapter(adapterConf, opts) {
220
+ const map = await this.getAdapterMapEntry(adapterConf, opts);
221
+ return map.reverseMap;
222
+ },
223
+ }));
376
224
  }
377
-
225
+ exports.default = assemblyFactory;
378
226
  function makeLoadAssemblyData(pluginManager) {
379
- return function (self) {
380
- if (self.configuration) {
381
- // use full configuration instead of snapshot of the config, the
382
- // rpcManager normally receives a snapshot but we bypass rpcManager here
383
- // to avoid spinning up a webworker
384
- var _self$configuration = self.configuration,
385
- sequence = _self$configuration.sequence,
386
- refNameAliases = _self$configuration.refNameAliases,
387
- cytobands = _self$configuration.cytobands;
388
- var sequenceAdapterConfig = sequence.adapter;
389
- var refNameAliasesAdapterConfig = refNameAliases === null || refNameAliases === void 0 ? void 0 : refNameAliases.adapter;
390
- var cytobandAdapterConfig = cytobands === null || cytobands === void 0 ? void 0 : cytobands.adapter;
391
- return {
392
- sequenceAdapterConfig: sequenceAdapterConfig,
393
- assemblyName: self.name,
394
- refNameAliasesAdapterConfig: refNameAliasesAdapterConfig,
395
- cytobandAdapterConfig: cytobandAdapterConfig,
396
- pluginManager: pluginManager
397
- };
398
- }
399
-
400
- return undefined;
401
- };
402
- }
403
-
404
- function loadAssemblyReaction(_x5, _x6) {
405
- return _loadAssemblyReaction.apply(this, arguments);
406
- }
407
-
408
- function _loadAssemblyReaction() {
409
- _loadAssemblyReaction = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5(props, signal) {
410
- var sequenceAdapterConfig, assemblyName, refNameAliasesAdapterConfig, cytobandAdapterConfig, pluginManager, adapterRegions, adapterRegionsWithAssembly, refNameAliases, aliases, cytobands, lowerCaseRefNameAliases;
411
- return _regenerator.default.wrap(function _callee5$(_context5) {
412
- while (1) {
413
- switch (_context5.prev = _context5.next) {
414
- case 0:
415
- if (props) {
416
- _context5.next = 2;
417
- break;
418
- }
419
-
420
- return _context5.abrupt("return");
421
-
422
- case 2:
423
- sequenceAdapterConfig = props.sequenceAdapterConfig, assemblyName = props.assemblyName, refNameAliasesAdapterConfig = props.refNameAliasesAdapterConfig, cytobandAdapterConfig = props.cytobandAdapterConfig, pluginManager = props.pluginManager;
424
- _context5.next = 5;
425
- return getAssemblyRegions(sequenceAdapterConfig, pluginManager, signal);
426
-
427
- case 5:
428
- adapterRegions = _context5.sent;
429
- adapterRegionsWithAssembly = adapterRegions.map(function (adapterRegion) {
430
- checkRefName(adapterRegion.refName);
431
- return _objectSpread(_objectSpread({}, adapterRegion), {}, {
432
- assemblyName: assemblyName
433
- });
434
- });
435
- refNameAliases = {};
436
- _context5.next = 10;
437
- return getRefNameAliases(refNameAliasesAdapterConfig, pluginManager, signal);
438
-
439
- case 10:
440
- aliases = _context5.sent;
441
- _context5.next = 13;
442
- return getCytobands(cytobandAdapterConfig, pluginManager);
443
-
444
- case 13:
445
- cytobands = _context5.sent;
446
- aliases.forEach(function (_ref4) {
447
- var refName = _ref4.refName,
448
- aliases = _ref4.aliases;
449
- aliases.forEach(function (alias) {
450
- checkRefName(alias);
451
- refNameAliases[alias] = refName;
452
- });
453
- }); // add identity to the refNameAliases list
454
-
455
- adapterRegionsWithAssembly.forEach(function (region) {
456
- refNameAliases[region.refName] = region.refName;
457
- });
458
- lowerCaseRefNameAliases = Object.fromEntries(Object.entries(refNameAliases).map(function (_ref5) {
459
- var _ref6 = (0, _slicedToArray2.default)(_ref5, 2),
460
- key = _ref6[0],
461
- val = _ref6[1];
462
-
463
- return [key.toLowerCase(), val];
464
- }));
465
- return _context5.abrupt("return", {
466
- adapterRegionsWithAssembly: adapterRegionsWithAssembly,
467
- refNameAliases: refNameAliases,
468
- lowerCaseRefNameAliases: lowerCaseRefNameAliases,
469
- cytobands: cytobands
470
- });
471
-
472
- case 18:
473
- case "end":
474
- return _context5.stop();
227
+ return (self) => {
228
+ if (self.configuration) {
229
+ // use full configuration instead of snapshot of the config, the
230
+ // rpcManager normally receives a snapshot but we bypass rpcManager here
231
+ // to avoid spinning up a webworker
232
+ const { sequence, refNameAliases, cytobands } = self.configuration;
233
+ const sequenceAdapterConfig = sequence.adapter;
234
+ const refNameAliasesAdapterConfig = refNameAliases === null || refNameAliases === void 0 ? void 0 : refNameAliases.adapter;
235
+ const cytobandAdapterConfig = cytobands === null || cytobands === void 0 ? void 0 : cytobands.adapter;
236
+ return {
237
+ sequenceAdapterConfig,
238
+ assemblyName: self.name,
239
+ refNameAliasesAdapterConfig,
240
+ cytobandAdapterConfig,
241
+ pluginManager,
242
+ };
475
243
  }
476
- }
477
- }, _callee5);
478
- }));
479
- return _loadAssemblyReaction.apply(this, arguments);
480
- }
481
-
482
- function getRefNameAliases(_x7, _x8, _x9) {
483
- return _getRefNameAliases.apply(this, arguments);
244
+ return undefined;
245
+ };
484
246
  }
485
-
486
- function _getRefNameAliases() {
487
- _getRefNameAliases = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee6(config, pluginManager, signal) {
488
- var _type$getAdapterClass;
489
-
490
- var type, CLASS, adapter;
491
- return _regenerator.default.wrap(function _callee6$(_context6) {
492
- while (1) {
493
- switch (_context6.prev = _context6.next) {
494
- case 0:
495
- type = pluginManager.getAdapterType(config.type);
496
- _context6.next = 3;
497
- return (_type$getAdapterClass = type.getAdapterClass) === null || _type$getAdapterClass === void 0 ? void 0 : _type$getAdapterClass.call(type);
498
-
499
- case 3:
500
- CLASS = _context6.sent;
501
- adapter = new CLASS(config, undefined, pluginManager);
502
- return _context6.abrupt("return", adapter.getRefNameAliases({
503
- signal: signal
504
- }));
505
-
506
- case 6:
507
- case "end":
508
- return _context6.stop();
509
- }
510
- }
511
- }, _callee6);
512
- }));
513
- return _getRefNameAliases.apply(this, arguments);
247
+ async function loadAssemblyReaction(props, signal) {
248
+ if (!props) {
249
+ return;
250
+ }
251
+ const { sequenceAdapterConfig, assemblyName, refNameAliasesAdapterConfig, cytobandAdapterConfig, pluginManager, } = props;
252
+ const adapterRegions = await getAssemblyRegions(sequenceAdapterConfig, pluginManager, signal);
253
+ const adapterRegionsWithAssembly = adapterRegions.map(adapterRegion => {
254
+ checkRefName(adapterRegion.refName);
255
+ return { ...adapterRegion, assemblyName };
256
+ });
257
+ const refNameAliases = {};
258
+ const aliases = await getRefNameAliases(refNameAliasesAdapterConfig, pluginManager, signal);
259
+ const cytobands = await getCytobands(cytobandAdapterConfig, pluginManager);
260
+ aliases.forEach(({ refName, aliases }) => {
261
+ aliases.forEach(alias => {
262
+ checkRefName(alias);
263
+ refNameAliases[alias] = refName;
264
+ });
265
+ });
266
+ // add identity to the refNameAliases list
267
+ adapterRegionsWithAssembly.forEach(region => {
268
+ refNameAliases[region.refName] = region.refName;
269
+ });
270
+ const lowerCaseRefNameAliases = Object.fromEntries(Object.entries(refNameAliases).map(([key, val]) => [
271
+ key.toLowerCase(),
272
+ val,
273
+ ]));
274
+ return {
275
+ adapterRegionsWithAssembly,
276
+ refNameAliases,
277
+ lowerCaseRefNameAliases,
278
+ cytobands,
279
+ };
514
280
  }
515
-
516
- function getCytobands(_x10, _x11) {
517
- return _getCytobands.apply(this, arguments);
281
+ async function getRefNameAliases(config, pluginManager, signal) {
282
+ var _a;
283
+ const type = pluginManager.getAdapterType(config.type);
284
+ const CLASS = await ((_a = type.getAdapterClass) === null || _a === void 0 ? void 0 : _a.call(type));
285
+ const adapter = new CLASS(config, undefined, pluginManager);
286
+ return adapter.getRefNameAliases({
287
+ signal,
288
+ });
518
289
  }
519
-
520
- function _getCytobands() {
521
- _getCytobands = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee7(config, pluginManager) {
522
- var type, CLASS, adapter;
523
- return _regenerator.default.wrap(function _callee7$(_context7) {
524
- while (1) {
525
- switch (_context7.prev = _context7.next) {
526
- case 0:
527
- type = pluginManager.getAdapterType(config.type);
528
- _context7.next = 3;
529
- return type.getAdapterClass();
530
-
531
- case 3:
532
- CLASS = _context7.sent;
533
- adapter = new CLASS(config, undefined, pluginManager); // @ts-ignore
534
-
535
- return _context7.abrupt("return", adapter.getData());
536
-
537
- case 6:
538
- case "end":
539
- return _context7.stop();
540
- }
541
- }
542
- }, _callee7);
543
- }));
544
- return _getCytobands.apply(this, arguments);
290
+ async function getCytobands(config, pluginManager) {
291
+ const type = pluginManager.getAdapterType(config.type);
292
+ const CLASS = await type.getAdapterClass();
293
+ const adapter = new CLASS(config, undefined, pluginManager);
294
+ // @ts-ignore
295
+ return adapter.getData();
545
296
  }
546
-
547
- function getAssemblyRegions(_x12, _x13, _x14) {
548
- return _getAssemblyRegions.apply(this, arguments);
297
+ async function getAssemblyRegions(config, pluginManager, signal) {
298
+ const type = pluginManager.getAdapterType(config.type);
299
+ const CLASS = await type.getAdapterClass();
300
+ const adapter = new CLASS(config, undefined, pluginManager);
301
+ return adapter.getRegions({ signal });
549
302
  }
550
-
551
- function _getAssemblyRegions() {
552
- _getAssemblyRegions = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee8(config, pluginManager, signal) {
553
- var type, CLASS, adapter;
554
- return _regenerator.default.wrap(function _callee8$(_context8) {
555
- while (1) {
556
- switch (_context8.prev = _context8.next) {
557
- case 0:
558
- type = pluginManager.getAdapterType(config.type);
559
- _context8.next = 3;
560
- return type.getAdapterClass();
561
-
562
- case 3:
563
- CLASS = _context8.sent;
564
- adapter = new CLASS(config, undefined, pluginManager);
565
- return _context8.abrupt("return", adapter.getRegions({
566
- signal: signal
567
- }));
568
-
569
- case 6:
570
- case "end":
571
- return _context8.stop();
572
- }
573
- }
574
- }, _callee8);
575
- }));
576
- return _getAssemblyRegions.apply(this, arguments);
577
- }