@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,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
- }