@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.
- package/BaseFeatureWidget/BaseFeatureDetail.d.ts +9 -3
- package/BaseFeatureWidget/BaseFeatureDetail.js +313 -581
- package/BaseFeatureWidget/SequenceFeatureDetails.js +213 -478
- package/BaseFeatureWidget/index.js +88 -126
- package/BaseFeatureWidget/types.d.ts +1 -0
- package/BaseFeatureWidget/types.js +1 -4
- package/BaseFeatureWidget/util.js +40 -75
- package/CorePlugin.js +55 -94
- package/Plugin.js +9 -34
- package/PluginLoader.js +153 -422
- package/PluginManager.d.ts +28 -33
- package/PluginManager.js +377 -666
- package/ReExports/Attributes.js +3 -10
- package/ReExports/BaseCard.js +3 -10
- package/ReExports/DataGrid.js +5 -12
- package/ReExports/FeatureDetails.js +3 -10
- package/ReExports/index.js +6 -12
- package/ReExports/list.d.ts +5 -0
- package/ReExports/list.js +271 -7
- package/ReExports/material-ui-colors.js +15 -16
- package/ReExports/modules.d.ts +11 -20
- package/ReExports/modules.js +453 -798
- package/TextSearch/BaseResults.js +51 -123
- package/TextSearch/TextSearchManager.js +66 -144
- package/assemblyManager/assembly.js +280 -555
- package/assemblyManager/assemblyConfigSchema.js +47 -64
- package/assemblyManager/assemblyManager.js +126 -272
- package/assemblyManager/index.js +9 -22
- package/configuration/configurationSchema.js +167 -203
- package/configuration/configurationSlot.js +248 -326
- package/configuration/index.js +19 -35
- package/configuration/util.js +131 -173
- package/data_adapters/BaseAdapter.d.ts +2 -2
- package/data_adapters/BaseAdapter.js +132 -521
- package/data_adapters/CytobandAdapter.js +40 -126
- package/data_adapters/dataAdapterCache.js +77 -158
- package/package.json +4 -5
- package/pluggableElementTypes/AdapterType.js +24 -79
- package/pluggableElementTypes/AddTrackWorkflowType.d.ts +17 -0
- package/pluggableElementTypes/AddTrackWorkflowType.js +20 -0
- package/pluggableElementTypes/ConnectionType.js +22 -65
- package/pluggableElementTypes/DisplayType.js +35 -82
- package/pluggableElementTypes/InternetAccountType.js +23 -64
- package/pluggableElementTypes/PluggableElementBase.js +8 -20
- package/pluggableElementTypes/RpcMethodType.js +85 -427
- package/pluggableElementTypes/TextSearchAdapterType.js +16 -55
- package/pluggableElementTypes/TrackType.js +26 -70
- package/pluggableElementTypes/ViewType.js +21 -63
- package/pluggableElementTypes/WidgetType.js +21 -64
- package/pluggableElementTypes/index.d.ts +4 -3
- package/pluggableElementTypes/index.js +42 -125
- package/pluggableElementTypes/models/BaseConnectionModelFactory.js +28 -43
- package/pluggableElementTypes/models/BaseDisplayModel.js +58 -95
- package/pluggableElementTypes/models/BaseTrackModel.js +139 -199
- package/pluggableElementTypes/models/BaseViewModel.js +24 -40
- package/pluggableElementTypes/models/InternetAccountModel.js +116 -263
- package/pluggableElementTypes/models/baseConnectionConfig.js +14 -25
- package/pluggableElementTypes/models/baseInternetAccountConfig.js +29 -38
- package/pluggableElementTypes/models/baseTrackConfig.js +106 -133
- package/pluggableElementTypes/models/index.js +21 -70
- package/pluggableElementTypes/renderers/BoxRendererType.js +132 -291
- package/pluggableElementTypes/renderers/CircularChordRendererType.js +8 -38
- package/pluggableElementTypes/renderers/ComparativeServerSideRendererType.js +60 -192
- package/pluggableElementTypes/renderers/FeatureRendererType.d.ts +0 -2
- package/pluggableElementTypes/renderers/FeatureRendererType.js +89 -255
- package/pluggableElementTypes/renderers/RendererType.js +31 -105
- package/pluggableElementTypes/renderers/ServerSideRenderedContent.js +61 -72
- package/pluggableElementTypes/renderers/ServerSideRendererType.js +112 -265
- package/pluggableElementTypes/renderers/index.js +19 -62
- package/pluggableElementTypes/renderers/util/serializableFilterChain.js +27 -65
- package/rpc/BaseRpcDriver.js +169 -405
- package/rpc/MainThreadRpcDriver.js +27 -150
- package/rpc/RpcManager.js +58 -159
- package/rpc/WebWorkerRpcDriver.js +54 -171
- package/rpc/configSchema.js +25 -49
- package/rpc/coreRpcMethods.d.ts +1 -3
- package/rpc/coreRpcMethods.js +221 -959
- package/rpc/remoteAbortSignals.js +46 -70
- package/tsconfig.build.tsbuildinfo +1 -1
- package/ui/AboutDialog.js +106 -162
- package/ui/App.js +157 -242
- package/ui/AssemblySelector.js +59 -120
- package/ui/CascadingMenu.js +101 -196
- package/ui/ColorPicker.d.ts +16 -0
- package/ui/ColorPicker.js +97 -0
- package/ui/Drawer.js +28 -61
- package/ui/DrawerWidget.js +108 -202
- package/ui/DropDownMenu.js +60 -91
- package/ui/EditableTypography.js +87 -149
- package/ui/ErrorMessage.js +41 -56
- package/ui/FactoryResetDialog.js +24 -57
- package/ui/FatalErrorDialog.js +59 -91
- package/ui/FileSelector/FileSelector.js +123 -189
- package/ui/FileSelector/LocalFileChooser.js +44 -75
- package/ui/FileSelector/UrlChooser.js +17 -38
- package/ui/FileSelector/index.js +6 -12
- package/ui/Icons.js +45 -69
- package/ui/Logo.js +57 -110
- package/ui/Menu.js +232 -354
- package/ui/PrerenderedCanvas.js +63 -87
- package/ui/ResizeHandle.js +87 -116
- package/ui/ReturnToImportFormDialog.js +32 -63
- package/ui/SanitizedHTML.js +64 -47
- package/ui/Snackbar.js +74 -101
- package/ui/SnackbarModel.js +37 -51
- package/ui/Tooltip.js +49 -76
- package/ui/ViewContainer.js +113 -196
- package/ui/colors.d.ts +10 -0
- package/ui/colors.js +78 -0
- package/ui/index.js +51 -181
- package/ui/react-colorful.d.ts +17 -0
- package/ui/react-colorful.js +455 -0
- package/ui/theme.d.ts +23 -1
- package/ui/theme.js +199 -247
- package/util/Base1DUtils.d.ts +32 -0
- package/util/Base1DUtils.js +174 -0
- package/util/Base1DViewModel.d.ts +16 -30
- package/util/Base1DViewModel.js +116 -293
- package/util/QuickLRU.js +84 -332
- package/util/TimeTraveller.d.ts +19 -0
- package/util/TimeTraveller.js +86 -0
- package/util/aborting.js +49 -127
- package/util/analytics.js +91 -154
- package/util/blockTypes.js +106 -240
- package/util/calculateDynamicBlocks.js +98 -128
- package/util/calculateStaticBlocks.js +105 -125
- package/util/color/cssColorsLevel4.js +156 -160
- package/util/color/index.js +33 -55
- package/util/compositeMap.js +49 -333
- package/util/formatFastaStrings.js +9 -14
- package/util/idMaker.js +18 -31
- package/util/index.d.ts +18 -32
- package/util/index.js +747 -1226
- package/util/io/RemoteFileWithRangeCache.js +88 -257
- package/util/io/index.js +95 -169
- package/util/jexl.js +60 -115
- package/util/jexlStrings.js +24 -29
- package/util/layouts/BaseLayout.js +1 -4
- package/util/layouts/GranularRectLayout.js +388 -555
- package/util/layouts/MultiLayout.js +41 -109
- package/util/layouts/PrecomputedLayout.js +56 -112
- package/util/layouts/PrecomputedMultiLayout.js +22 -59
- package/util/layouts/SceneGraph.js +127 -197
- package/util/layouts/index.js +29 -66
- package/util/mst-reflection.js +55 -71
- package/util/offscreenCanvasPonyfill.js +66 -134
- package/util/offscreenCanvasUtils.d.ts +2 -7
- package/util/offscreenCanvasUtils.js +49 -146
- package/util/range.js +29 -40
- package/util/rxjs.js +20 -27
- package/util/simpleFeature.js +88 -152
- package/util/stats.js +91 -151
- package/util/tracks.js +130 -173
- package/util/types/index.js +110 -179
- package/util/types/mst.js +91 -146
- package/util/types/util.js +1 -4
- package/util/when.js +54 -101
- package/BaseFeatureWidget/SequenceFeatureDetails.test.js +0 -122
- package/BaseFeatureWidget/index.test.js +0 -69
- package/TextSearch/BaseResults.test.js +0 -42
- package/configuration/configurationSchema.test.js +0 -266
- package/configuration/configurationSlot.test.js +0 -69
- package/configuration/util.test.js +0 -39
- package/data_adapters/BaseAdapter.test.js +0 -200
- package/declare.d.js +0 -1
- package/pluggableElementTypes/RpcMethodType.test.js +0 -118
- package/pluggableElementTypes/renderers/declare.d.js +0 -1
- package/pluggableElementTypes/renderers/util/serializableFilterChain.test.js +0 -20
- package/rpc/BaseRpcDriver.test.js +0 -540
- package/rpc/declaration.d.js +0 -1
- package/ui/FatalErrorDialog.test.js +0 -82
- package/ui/SanitizedHTML.test.js +0 -36
- package/ui/theme.test.js +0 -92
- package/util/Base1DViewModel.test.js +0 -130
- package/util/calculateDynamicBlocks.test.js +0 -74
- package/util/calculateStaticBlocks.test.js +0 -297
- package/util/declare.d.js +0 -1
- package/util/formatFastaStrings.test.js +0 -40
- package/util/index.test.js +0 -213
- package/util/jexlStrings.test.js +0 -48
- package/util/layouts/GranularRectLayout.test.js +0 -99
- package/util/range.test.js +0 -64
- package/util/simpleFeature.test.js +0 -34
- package/util/stats.test.js +0 -172
|
@@ -1,577 +1,302 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
Object.defineProperty(exports, "__esModule", {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
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
|
-
|
|
46
|
-
'rgb(
|
|
47
|
-
'rgb(
|
|
48
|
-
'rgb(
|
|
49
|
-
'rgb(
|
|
50
|
-
'rgb(
|
|
51
|
-
'rgb(
|
|
52
|
-
'rgb(
|
|
53
|
-
'rgb(
|
|
54
|
-
'rgb(
|
|
55
|
-
'rgb(153, 0
|
|
56
|
-
'rgb(
|
|
57
|
-
'rgb(
|
|
58
|
-
'rgb(
|
|
59
|
-
'rgb(96,
|
|
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
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
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
|
-
|
|
133
|
-
|
|
134
|
-
|
|
76
|
+
if (!refName.match(refNameRegex)) {
|
|
77
|
+
throw new Error(`Encountered invalid refName: "${refName}"`);
|
|
78
|
+
}
|
|
135
79
|
}
|
|
136
|
-
|
|
137
80
|
function getAdapterId(adapterConf) {
|
|
138
|
-
|
|
81
|
+
return (0, json_stable_stringify_1.default)(adapterConf);
|
|
139
82
|
}
|
|
140
|
-
|
|
141
83
|
function assemblyFactory(assemblyConfigType, pluginManager) {
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
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
|
-
},
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
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
|
-
}
|
|
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
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
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
|
-
|
|
517
|
-
|
|
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
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
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
|
-
|
|
548
|
-
|
|
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
|
-
}
|