@genome-spy/core 0.69.1 → 0.71.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.
- package/dist/bundle/{AbortablePromiseCache-CcuMrnn7.js → AbortablePromiseCache-Dj0vzLnp.js} +4 -4
- package/dist/bundle/{browser-BRemItdO.js → browser-0iNU5Wit.js} +33 -33
- package/dist/bundle/index-BYsZN7b0.js +1597 -0
- package/dist/bundle/{index-Cq3QFUxX.js → index-C3kClAEN.js} +583 -593
- package/dist/bundle/{index-D-w7Mmt9.js → index-C7wOh6y1.js} +138 -140
- package/dist/bundle/index-CRaQAuki.js +326 -0
- package/dist/bundle/{index-D74H8TTz.js → index-D9v1PCj9.js} +1 -2
- package/dist/bundle/{index-BatuyGAI.js → index-GDOuv_D5.js} +75 -80
- package/dist/bundle/{index-DbJ0oeYM.js → index-Gt44EOIH.js} +160 -163
- package/dist/bundle/index.es.js +9095 -9129
- package/dist/bundle/index.js +121 -163
- package/dist/bundle/{unzip-NywezaRR.js → unzip-Bac01w6X.js} +1 -1
- package/dist/schema.json +0 -48
- package/dist/src/genomeSpy/containerUi.d.ts.map +1 -1
- package/dist/src/genomeSpy/containerUi.js +0 -1
- package/dist/src/genomeSpy/viewHighlight.js +2 -2
- package/dist/src/genomeSpy.d.ts +3 -3
- package/dist/src/genomeSpy.d.ts.map +1 -1
- package/dist/src/genomeSpy.js +27 -3
- package/dist/src/gl/colorUtils.d.ts +2 -1
- package/dist/src/gl/colorUtils.d.ts.map +1 -1
- package/dist/src/gl/colorUtils.js +15 -3
- package/dist/src/gl/webGLHelper.d.ts.map +1 -1
- package/dist/src/gl/webGLHelper.js +2 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +2 -5
- package/dist/src/marks/mark.d.ts +1 -3
- package/dist/src/marks/mark.d.ts.map +1 -1
- package/dist/src/marks/mark.js +0 -8
- package/dist/src/marks/rect.d.ts.map +1 -1
- package/dist/src/marks/rect.js +0 -8
- package/dist/src/spec/view.d.ts +0 -10
- package/dist/src/utils/deepEqual.d.ts +14 -0
- package/dist/src/utils/deepEqual.d.ts.map +1 -0
- package/dist/src/utils/deepEqual.js +63 -0
- package/dist/src/utils/fetchUtils.d.ts +27 -0
- package/dist/src/utils/fetchUtils.d.ts.map +1 -0
- package/dist/src/utils/fetchUtils.js +47 -0
- package/dist/src/utils/keyboardZoomMotion.d.ts +93 -0
- package/dist/src/utils/keyboardZoomMotion.d.ts.map +1 -0
- package/dist/src/utils/keyboardZoomMotion.js +285 -0
- package/dist/src/utils/url.d.ts +12 -0
- package/dist/src/utils/url.d.ts.map +1 -1
- package/dist/src/utils/url.js +45 -0
- package/dist/src/view/axisGridView.d.ts +1 -1
- package/dist/src/view/axisGridView.js +0 -1
- package/dist/src/view/axisView.d.ts +1 -1
- package/dist/src/view/concatView.d.ts +6 -3
- package/dist/src/view/concatView.d.ts.map +1 -1
- package/dist/src/view/concatView.js +9 -2
- package/dist/src/view/containerMutationHelper.d.ts +6 -6
- package/dist/src/view/containerMutationHelper.d.ts.map +1 -1
- package/dist/src/view/containerView.d.ts +7 -5
- package/dist/src/view/containerView.d.ts.map +1 -1
- package/dist/src/view/containerView.js +4 -1
- package/dist/src/view/facetView.d.ts +1 -1
- package/dist/src/view/flowBuilder.d.ts +1 -1
- package/dist/src/view/flowBuilder.d.ts.map +1 -1
- package/dist/src/view/gridView/gridChild.d.ts +3 -3
- package/dist/src/view/gridView/gridChild.d.ts.map +1 -1
- package/dist/src/view/gridView/gridChild.js +0 -2
- package/dist/src/view/gridView/gridView.d.ts +13 -11
- package/dist/src/view/gridView/gridView.d.ts.map +1 -1
- package/dist/src/view/gridView/gridView.js +17 -26
- package/dist/src/view/gridView/keyboardZoomController.d.ts +21 -0
- package/dist/src/view/gridView/keyboardZoomController.d.ts.map +1 -0
- package/dist/src/view/gridView/keyboardZoomController.js +202 -0
- package/dist/src/view/gridView/scrollbar.d.ts +1 -1
- package/dist/src/view/gridView/scrollbar.d.ts.map +1 -1
- package/dist/src/view/gridView/scrollbar.js +0 -1
- package/dist/src/view/gridView/selectionRect.d.ts +1 -1
- package/dist/src/view/gridView/selectionRect.d.ts.map +1 -1
- package/dist/src/view/gridView/selectionRect.js +0 -1
- package/dist/src/view/gridView/separatorView.js +0 -1
- package/dist/src/view/gridView/zoomNavigationUtils.d.ts +19 -0
- package/dist/src/view/gridView/zoomNavigationUtils.d.ts.map +1 -0
- package/dist/src/view/gridView/zoomNavigationUtils.js +51 -0
- package/dist/src/view/layerView.d.ts +8 -5
- package/dist/src/view/layerView.d.ts.map +1 -1
- package/dist/src/view/layerView.js +6 -2
- package/dist/src/view/title.d.ts.map +1 -1
- package/dist/src/view/title.js +0 -1
- package/dist/src/view/unitView.d.ts +7 -4
- package/dist/src/view/unitView.d.ts.map +1 -1
- package/dist/src/view/unitView.js +5 -1
- package/dist/src/view/view.d.ts +13 -9
- package/dist/src/view/view.d.ts.map +1 -1
- package/dist/src/view/view.js +7 -1
- package/dist/src/view/viewError.d.ts +1 -1
- package/dist/src/view/viewError.d.ts.map +1 -1
- package/dist/src/view/viewFactory.d.ts +3 -44
- package/dist/src/view/viewFactory.d.ts.map +1 -1
- package/dist/src/view/viewFactory.js +28 -69
- package/dist/src/view/viewSelectors.d.ts.map +1 -1
- package/dist/src/view/viewSelectors.js +123 -160
- package/dist/src/view/viewSpecGuards.d.ts +43 -0
- package/dist/src/view/viewSpecGuards.d.ts.map +1 -0
- package/dist/src/view/viewSpecGuards.js +69 -0
- package/dist/src/view/viewUtils.d.ts +1 -1
- package/dist/src/view/viewUtils.d.ts.map +1 -1
- package/dist/src/view/viewUtils.js +4 -5
- package/dist/src/view/zoom.d.ts +1 -0
- package/dist/src/view/zoom.d.ts.map +1 -1
- package/dist/src/view/zoom.js +5 -1
- package/package.json +3 -3
- package/dist/bundle/index-ByuE8dvu.js +0 -332
- package/dist/bundle/index-D28m8tSW.js +0 -1607
- package/dist/src/data/collector.test.d.ts +0 -2
- package/dist/src/data/collector.test.d.ts.map +0 -1
- package/dist/src/data/dataFlow.test.d.ts +0 -2
- package/dist/src/data/dataFlow.test.d.ts.map +0 -1
- package/dist/src/data/flow.test.d.ts +0 -2
- package/dist/src/data/flow.test.d.ts.map +0 -1
- package/dist/src/data/flowInit.test.d.ts +0 -2
- package/dist/src/data/flowInit.test.d.ts.map +0 -1
- package/dist/src/data/flowNode.test.d.ts +0 -2
- package/dist/src/data/flowNode.test.d.ts.map +0 -1
- package/dist/src/data/flowOptimizer.test.d.ts +0 -2
- package/dist/src/data/flowOptimizer.test.d.ts.map +0 -1
- package/dist/src/data/formats/fasta.test.d.ts +0 -2
- package/dist/src/data/formats/fasta.test.d.ts.map +0 -1
- package/dist/src/data/keyIndex.test.d.ts +0 -2
- package/dist/src/data/keyIndex.test.d.ts.map +0 -1
- package/dist/src/data/sources/inlineSource.test.d.ts +0 -2
- package/dist/src/data/sources/inlineSource.test.d.ts.map +0 -1
- package/dist/src/data/sources/sequenceSource.test.d.ts +0 -2
- package/dist/src/data/sources/sequenceSource.test.d.ts.map +0 -1
- package/dist/src/data/transforms/aggregate.test.d.ts +0 -2
- package/dist/src/data/transforms/aggregate.test.d.ts.map +0 -1
- package/dist/src/data/transforms/clone.test.d.ts +0 -2
- package/dist/src/data/transforms/clone.test.d.ts.map +0 -1
- package/dist/src/data/transforms/coverage.test.d.ts +0 -2
- package/dist/src/data/transforms/coverage.test.d.ts.map +0 -1
- package/dist/src/data/transforms/filter.test.d.ts +0 -2
- package/dist/src/data/transforms/filter.test.d.ts.map +0 -1
- package/dist/src/data/transforms/filterScoredLabels.test.d.ts +0 -2
- package/dist/src/data/transforms/filterScoredLabels.test.d.ts.map +0 -1
- package/dist/src/data/transforms/flatten.test.d.ts +0 -2
- package/dist/src/data/transforms/flatten.test.d.ts.map +0 -1
- package/dist/src/data/transforms/flattenDelimited.test.d.ts +0 -2
- package/dist/src/data/transforms/flattenDelimited.test.d.ts.map +0 -1
- package/dist/src/data/transforms/flattenSequence.test.d.ts +0 -2
- package/dist/src/data/transforms/flattenSequence.test.d.ts.map +0 -1
- package/dist/src/data/transforms/formula.test.d.ts +0 -2
- package/dist/src/data/transforms/formula.test.d.ts.map +0 -1
- package/dist/src/data/transforms/identifier.test.d.ts +0 -2
- package/dist/src/data/transforms/identifier.test.d.ts.map +0 -1
- package/dist/src/data/transforms/pileup.test.d.ts +0 -2
- package/dist/src/data/transforms/pileup.test.d.ts.map +0 -1
- package/dist/src/data/transforms/project.test.d.ts +0 -2
- package/dist/src/data/transforms/project.test.d.ts.map +0 -1
- package/dist/src/data/transforms/regexExtract.test.d.ts +0 -2
- package/dist/src/data/transforms/regexExtract.test.d.ts.map +0 -1
- package/dist/src/data/transforms/regexFold.test.d.ts +0 -2
- package/dist/src/data/transforms/regexFold.test.d.ts.map +0 -1
- package/dist/src/data/transforms/sample.test.d.ts +0 -2
- package/dist/src/data/transforms/sample.test.d.ts.map +0 -1
- package/dist/src/data/transforms/stack.test.d.ts +0 -2
- package/dist/src/data/transforms/stack.test.d.ts.map +0 -1
- package/dist/src/encoder/accessor.test.d.ts +0 -2
- package/dist/src/encoder/accessor.test.d.ts.map +0 -1
- package/dist/src/encoder/encoder.test.d.ts +0 -2
- package/dist/src/encoder/encoder.test.d.ts.map +0 -1
- package/dist/src/encoder/metadataChannels.test.d.ts +0 -2
- package/dist/src/encoder/metadataChannels.test.d.ts.map +0 -1
- package/dist/src/genome/genome.test.d.ts +0 -2
- package/dist/src/genome/genome.test.d.ts.map +0 -1
- package/dist/src/genome/genomes.test.d.ts +0 -2
- package/dist/src/genome/genomes.test.d.ts.map +0 -1
- package/dist/src/genome/scaleIndex.test.d.ts +0 -2
- package/dist/src/genome/scaleIndex.test.d.ts.map +0 -1
- package/dist/src/genome/scaleLocus.test.d.ts +0 -2
- package/dist/src/genome/scaleLocus.test.d.ts.map +0 -1
- package/dist/src/genomeSpy/viewDataInit.test.d.ts +0 -2
- package/dist/src/genomeSpy/viewDataInit.test.d.ts.map +0 -1
- package/dist/src/paramRuntime/expressionRef.test.d.ts +0 -2
- package/dist/src/paramRuntime/expressionRef.test.d.ts.map +0 -1
- package/dist/src/paramRuntime/graphRuntime.test.d.ts +0 -2
- package/dist/src/paramRuntime/graphRuntime.test.d.ts.map +0 -1
- package/dist/src/paramRuntime/paramRuntime.test.d.ts +0 -2
- package/dist/src/paramRuntime/paramRuntime.test.d.ts.map +0 -1
- package/dist/src/paramRuntime/paramStore.test.d.ts +0 -2
- package/dist/src/paramRuntime/paramStore.test.d.ts.map +0 -1
- package/dist/src/scale/scale.test.d.ts +0 -2
- package/dist/src/scale/scale.test.d.ts.map +0 -1
- package/dist/src/scale/ticks.test.d.ts +0 -2
- package/dist/src/scale/ticks.test.d.ts.map +0 -1
- package/dist/src/scales/axisResolution.test.d.ts +0 -2
- package/dist/src/scales/axisResolution.test.d.ts.map +0 -1
- package/dist/src/scales/domainPlanner.test.d.ts +0 -2
- package/dist/src/scales/domainPlanner.test.d.ts.map +0 -1
- package/dist/src/scales/scaleInstanceManager.test.d.ts +0 -2
- package/dist/src/scales/scaleInstanceManager.test.d.ts.map +0 -1
- package/dist/src/scales/scaleInteractionController.test.d.ts +0 -2
- package/dist/src/scales/scaleInteractionController.test.d.ts.map +0 -1
- package/dist/src/scales/scaleResolution.test.d.ts +0 -2
- package/dist/src/scales/scaleResolution.test.d.ts.map +0 -1
- package/dist/src/scales/scaleRules.test.d.ts +0 -2
- package/dist/src/scales/scaleRules.test.d.ts.map +0 -1
- package/dist/src/selection/selection.test.d.ts +0 -2
- package/dist/src/selection/selection.test.d.ts.map +0 -1
- package/dist/src/tooltip/dataTooltipHandler.test.d.ts +0 -2
- package/dist/src/tooltip/dataTooltipHandler.test.d.ts.map +0 -1
- package/dist/src/tooltip/flattenDatumRows.test.d.ts +0 -2
- package/dist/src/tooltip/flattenDatumRows.test.d.ts.map +0 -1
- package/dist/src/tooltip/tooltipContext.test.d.ts +0 -2
- package/dist/src/tooltip/tooltipContext.test.d.ts.map +0 -1
- package/dist/src/utils/addBaseUrl.test.d.ts +0 -2
- package/dist/src/utils/addBaseUrl.test.d.ts.map +0 -1
- package/dist/src/utils/binnedIndex.test.d.ts +0 -2
- package/dist/src/utils/binnedIndex.test.d.ts.map +0 -1
- package/dist/src/utils/cloner.test.d.ts +0 -2
- package/dist/src/utils/cloner.test.d.ts.map +0 -1
- package/dist/src/utils/coalesce.test.d.ts +0 -2
- package/dist/src/utils/coalesce.test.d.ts.map +0 -1
- package/dist/src/utils/concatIterables.test.d.ts +0 -2
- package/dist/src/utils/concatIterables.test.d.ts.map +0 -1
- package/dist/src/utils/domainArray.test.d.ts +0 -2
- package/dist/src/utils/domainArray.test.d.ts.map +0 -1
- package/dist/src/utils/indexer.test.d.ts +0 -2
- package/dist/src/utils/indexer.test.d.ts.map +0 -1
- package/dist/src/utils/interactionEvent.test.d.ts +0 -2
- package/dist/src/utils/interactionEvent.test.d.ts.map +0 -1
- package/dist/src/utils/iterateNestedMaps.test.d.ts +0 -2
- package/dist/src/utils/iterateNestedMaps.test.d.ts.map +0 -1
- package/dist/src/utils/kWayMerge.test.d.ts +0 -2
- package/dist/src/utils/kWayMerge.test.d.ts.map +0 -1
- package/dist/src/utils/mergeObjects.test.d.ts +0 -2
- package/dist/src/utils/mergeObjects.test.d.ts.map +0 -1
- package/dist/src/utils/numberExtractor.test.d.ts +0 -2
- package/dist/src/utils/numberExtractor.test.d.ts.map +0 -1
- package/dist/src/utils/propertyCacher.test.d.ts +0 -2
- package/dist/src/utils/propertyCacher.test.d.ts.map +0 -1
- package/dist/src/utils/propertyCoalescer.test.d.ts +0 -2
- package/dist/src/utils/propertyCoalescer.test.d.ts.map +0 -1
- package/dist/src/utils/radixSort.test.d.ts +0 -2
- package/dist/src/utils/radixSort.test.d.ts.map +0 -1
- package/dist/src/utils/reservationMap.test.d.ts +0 -2
- package/dist/src/utils/reservationMap.test.d.ts.map +0 -1
- package/dist/src/utils/ringBuffer.test.d.ts +0 -2
- package/dist/src/utils/ringBuffer.test.d.ts.map +0 -1
- package/dist/src/utils/throttle.test.d.ts +0 -2
- package/dist/src/utils/throttle.test.d.ts.map +0 -1
- package/dist/src/utils/topK.test.d.ts +0 -2
- package/dist/src/utils/topK.test.d.ts.map +0 -1
- package/dist/src/utils/trees.test.d.ts +0 -2
- package/dist/src/utils/trees.test.d.ts.map +0 -1
- package/dist/src/utils/ui/tooltip.test.d.ts +0 -2
- package/dist/src/utils/ui/tooltip.test.d.ts.map +0 -1
- package/dist/src/utils/url.test.d.ts +0 -2
- package/dist/src/utils/url.test.d.ts.map +0 -1
- package/dist/src/utils/variableTools.test.d.ts +0 -2
- package/dist/src/utils/variableTools.test.d.ts.map +0 -1
- package/dist/src/view/concatView.test.d.ts +0 -2
- package/dist/src/view/concatView.test.d.ts.map +0 -1
- package/dist/src/view/dataReadiness.test.d.ts +0 -2
- package/dist/src/view/dataReadiness.test.d.ts.map +0 -1
- package/dist/src/view/flowBuilder.test.d.ts +0 -2
- package/dist/src/view/flowBuilder.test.d.ts.map +0 -1
- package/dist/src/view/gridView/gridView.test.d.ts +0 -2
- package/dist/src/view/gridView/gridView.test.d.ts.map +0 -1
- package/dist/src/view/gridView/selectionRect.test.d.ts +0 -2
- package/dist/src/view/gridView/selectionRect.test.d.ts.map +0 -1
- package/dist/src/view/layerView.test.d.ts +0 -2
- package/dist/src/view/layerView.test.d.ts.map +0 -1
- package/dist/src/view/layout/flexLayout.test.d.ts +0 -2
- package/dist/src/view/layout/flexLayout.test.d.ts.map +0 -1
- package/dist/src/view/layout/grid.test.d.ts +0 -2
- package/dist/src/view/layout/grid.test.d.ts.map +0 -1
- package/dist/src/view/layout/rectangle.test.d.ts +0 -2
- package/dist/src/view/layout/rectangle.test.d.ts.map +0 -1
- package/dist/src/view/multiscale.test.d.ts +0 -2
- package/dist/src/view/multiscale.test.d.ts.map +0 -1
- package/dist/src/view/view.test.d.ts +0 -2
- package/dist/src/view/view.test.d.ts.map +0 -1
- package/dist/src/view/viewDispose.test.d.ts +0 -2
- package/dist/src/view/viewDispose.test.d.ts.map +0 -1
- package/dist/src/view/viewFactory.test.d.ts +0 -2
- package/dist/src/view/viewFactory.test.d.ts.map +0 -1
- package/dist/src/view/viewParamRuntime.test.d.ts +0 -2
- package/dist/src/view/viewParamRuntime.test.d.ts.map +0 -1
- package/dist/src/view/viewSelectors.test.d.ts +0 -2
- package/dist/src/view/viewSelectors.test.d.ts.map +0 -1
- package/dist/src/view/viewUtils.test.d.ts +0 -2
- package/dist/src/view/viewUtils.test.d.ts.map +0 -1
|
@@ -1,78 +1,78 @@
|
|
|
1
|
-
function
|
|
2
|
-
const r = /* @__PURE__ */ Object.create(null),
|
|
1
|
+
function S(m, t, e) {
|
|
2
|
+
const r = /* @__PURE__ */ Object.create(null), o = e.length, s = t.length, c = 9, i = 58;
|
|
3
3
|
let n = 0;
|
|
4
|
-
if (
|
|
5
|
-
for (let
|
|
6
|
-
const
|
|
7
|
-
for (; n <
|
|
4
|
+
if (m === "GT") {
|
|
5
|
+
for (let l = 0; l < o; l++) {
|
|
6
|
+
const d = n;
|
|
7
|
+
for (; n < s && t.charCodeAt(n) !== c; )
|
|
8
8
|
n++;
|
|
9
|
-
r[e[
|
|
9
|
+
r[e[l]] = t.slice(d, n), n++;
|
|
10
10
|
}
|
|
11
11
|
return r;
|
|
12
12
|
}
|
|
13
|
-
const
|
|
14
|
-
if (
|
|
13
|
+
const a = m.indexOf("GT");
|
|
14
|
+
if (a === -1)
|
|
15
15
|
return r;
|
|
16
|
-
if (
|
|
17
|
-
for (let
|
|
18
|
-
const
|
|
19
|
-
for (; n <
|
|
16
|
+
if (a === 0) {
|
|
17
|
+
for (let l = 0; l < o; l++) {
|
|
18
|
+
const d = n;
|
|
19
|
+
for (; n < s && t.charCodeAt(n) !== i && t.charCodeAt(n) !== c; )
|
|
20
20
|
n++;
|
|
21
|
-
for (r[e[
|
|
21
|
+
for (r[e[l]] = t.slice(d, n); n < s && t.charCodeAt(n) !== c; )
|
|
22
22
|
n++;
|
|
23
23
|
n++;
|
|
24
24
|
}
|
|
25
25
|
return r;
|
|
26
26
|
}
|
|
27
|
-
let
|
|
28
|
-
for (let
|
|
29
|
-
|
|
30
|
-
for (let
|
|
31
|
-
const
|
|
32
|
-
let
|
|
33
|
-
for (;
|
|
34
|
-
|
|
35
|
-
let
|
|
36
|
-
for (let
|
|
37
|
-
if (
|
|
38
|
-
if (
|
|
39
|
-
r[e[
|
|
27
|
+
let u = 0;
|
|
28
|
+
for (let l = 0; l < a; l++)
|
|
29
|
+
m.charCodeAt(l) === i && u++;
|
|
30
|
+
for (let l = 0; l < o; l++) {
|
|
31
|
+
const d = n;
|
|
32
|
+
let f = n;
|
|
33
|
+
for (; f < s && t.charCodeAt(f) !== c; )
|
|
34
|
+
f++;
|
|
35
|
+
let y = 0, b = d;
|
|
36
|
+
for (let p = d; p <= f; p++)
|
|
37
|
+
if (p === f || t.charCodeAt(p) === i) {
|
|
38
|
+
if (y === u) {
|
|
39
|
+
r[e[l]] = t.slice(b, p);
|
|
40
40
|
break;
|
|
41
41
|
}
|
|
42
|
-
|
|
42
|
+
y++, b = p + 1;
|
|
43
43
|
}
|
|
44
|
-
n =
|
|
44
|
+
n = f + 1;
|
|
45
45
|
}
|
|
46
46
|
return r;
|
|
47
47
|
}
|
|
48
|
-
function
|
|
48
|
+
function R(m) {
|
|
49
49
|
const t = [], e = [];
|
|
50
|
-
let r = !1,
|
|
51
|
-
const
|
|
52
|
-
for (let
|
|
53
|
-
const
|
|
54
|
-
|
|
50
|
+
let r = !1, o = !1;
|
|
51
|
+
const s = m.length;
|
|
52
|
+
for (let c = 0; c < s; c++) {
|
|
53
|
+
const i = m[c];
|
|
54
|
+
i === '"' ? (r = !r, e.push(i)) : i === "[" ? (o = !0, e.push(i)) : i === "]" ? (o = !1, e.push(i)) : i === "," && !r && !o ? (t.push(e.join("").trim()), e.length = 0) : e.push(i);
|
|
55
55
|
}
|
|
56
56
|
return e.length > 0 && t.push(e.join("").trim()), t;
|
|
57
57
|
}
|
|
58
|
-
function
|
|
59
|
-
const e =
|
|
60
|
-
return [
|
|
58
|
+
function E(m, t) {
|
|
59
|
+
const e = m.indexOf(t);
|
|
60
|
+
return [m.slice(0, e), m.slice(e + 1)];
|
|
61
61
|
}
|
|
62
|
-
function
|
|
63
|
-
const t =
|
|
64
|
-
for (let
|
|
65
|
-
const
|
|
66
|
-
if (
|
|
67
|
-
const n =
|
|
68
|
-
for (let
|
|
69
|
-
n[
|
|
70
|
-
r.push([
|
|
71
|
-
} else
|
|
62
|
+
function F(m) {
|
|
63
|
+
const t = m.slice(1, -1), e = R(t), r = [];
|
|
64
|
+
for (let o = 0; o < e.length; o++) {
|
|
65
|
+
const s = e[o], [c, i] = E(s, "=");
|
|
66
|
+
if (i && i.startsWith("[") && i.endsWith("]")) {
|
|
67
|
+
const n = i.slice(1, -1).split(",");
|
|
68
|
+
for (let a = 0; a < n.length; a++)
|
|
69
|
+
n[a] = n[a].trim();
|
|
70
|
+
r.push([c, n]);
|
|
71
|
+
} else i && i.startsWith('"') && i.endsWith('"') ? r.push([c, i.slice(1, -1)]) : r.push([c, i]);
|
|
72
72
|
}
|
|
73
73
|
return Object.fromEntries(r);
|
|
74
74
|
}
|
|
75
|
-
const
|
|
75
|
+
const A = {
|
|
76
76
|
// INFO fields
|
|
77
77
|
InfoFields: {
|
|
78
78
|
// from the VCF4.3 spec, https://samtools.github.io/hts-specs/VCFv4.3.pdf
|
|
@@ -417,14 +417,14 @@ const S = {
|
|
|
417
417
|
}
|
|
418
418
|
}
|
|
419
419
|
};
|
|
420
|
-
function
|
|
420
|
+
function C(m) {
|
|
421
421
|
try {
|
|
422
|
-
return decodeURIComponent(
|
|
422
|
+
return decodeURIComponent(m);
|
|
423
423
|
} catch {
|
|
424
|
-
return
|
|
424
|
+
return m;
|
|
425
425
|
}
|
|
426
426
|
}
|
|
427
|
-
class
|
|
427
|
+
class L {
|
|
428
428
|
constructor({ header: t = "", strict: e = !0 }) {
|
|
429
429
|
if (!t.length)
|
|
430
430
|
throw new Error("empty header received");
|
|
@@ -432,22 +432,22 @@ class M {
|
|
|
432
432
|
if (!r.length)
|
|
433
433
|
throw new Error("no non-empty header lines specified");
|
|
434
434
|
this.strict = e, this.metadata = {
|
|
435
|
-
INFO: { ...
|
|
436
|
-
FORMAT: { ...
|
|
437
|
-
ALT: { ...
|
|
438
|
-
FILTER: { ...
|
|
435
|
+
INFO: { ...A.InfoFields },
|
|
436
|
+
FORMAT: { ...A.GenotypeFields },
|
|
437
|
+
ALT: { ...A.AltTypes },
|
|
438
|
+
FILTER: { ...A.FilterTypes }
|
|
439
439
|
};
|
|
440
|
-
let
|
|
440
|
+
let o;
|
|
441
441
|
for (let n = 0; n < r.length; n++) {
|
|
442
|
-
const
|
|
443
|
-
if (
|
|
444
|
-
|
|
442
|
+
const a = r[n];
|
|
443
|
+
if (a.startsWith("#"))
|
|
444
|
+
a.startsWith("##") ? this.parseMetadata(a) : o = a;
|
|
445
445
|
else throw new Error(`Bad line in header:
|
|
446
|
-
${
|
|
446
|
+
${a}`);
|
|
447
447
|
}
|
|
448
|
-
if (!
|
|
448
|
+
if (!o)
|
|
449
449
|
throw new Error("No format line found in header");
|
|
450
|
-
const
|
|
450
|
+
const s = o.trim().split(" "), c = s.slice(0, 8), i = [
|
|
451
451
|
"#CHROM",
|
|
452
452
|
"POS",
|
|
453
453
|
"ID",
|
|
@@ -457,85 +457,83 @@ ${c}`);
|
|
|
457
457
|
"FILTER",
|
|
458
458
|
"INFO"
|
|
459
459
|
];
|
|
460
|
-
if (
|
|
460
|
+
if (s.length < 8)
|
|
461
461
|
throw new Error(`VCF header missing columns:
|
|
462
|
-
${
|
|
463
|
-
if (
|
|
462
|
+
${o}`);
|
|
463
|
+
if (c.length !== i.length || !c.every((n, a) => n === i[a]))
|
|
464
464
|
throw new Error(`VCF column headers not correct:
|
|
465
|
-
${
|
|
466
|
-
this.samples =
|
|
465
|
+
${o}`);
|
|
466
|
+
this.samples = s.slice(9);
|
|
467
467
|
}
|
|
468
468
|
parseInfo(t) {
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
e[o] = !0;
|
|
469
|
+
const e = {}, r = t.includes("%"), o = t.split(";"), s = this.metadata.INFO, c = o.length;
|
|
470
|
+
for (let i = 0; i < c; i++) {
|
|
471
|
+
const n = o[i], a = n.indexOf("="), u = a === -1 ? n : n.slice(0, a), l = a === -1 ? void 0 : n.slice(a + 1), d = s[u]?.Type;
|
|
472
|
+
if (d === "Flag")
|
|
473
|
+
e[u] = !0;
|
|
474
|
+
else if (!l)
|
|
475
|
+
e[u] = !0;
|
|
477
476
|
else {
|
|
478
|
-
const
|
|
477
|
+
const f = d === "Integer" || d === "Float", y = l.split(","), b = y.length;
|
|
479
478
|
if (r) {
|
|
480
|
-
const
|
|
481
|
-
for (let
|
|
482
|
-
const
|
|
483
|
-
if (
|
|
484
|
-
|
|
479
|
+
const p = [];
|
|
480
|
+
for (let h = 0; h < b; h++) {
|
|
481
|
+
const D = y[h];
|
|
482
|
+
if (D === ".")
|
|
483
|
+
p.push(void 0);
|
|
485
484
|
else {
|
|
486
|
-
const
|
|
487
|
-
|
|
485
|
+
const g = C(D);
|
|
486
|
+
p.push(f ? Number(g) : g);
|
|
488
487
|
}
|
|
489
488
|
}
|
|
490
|
-
e[
|
|
489
|
+
e[u] = p;
|
|
491
490
|
} else {
|
|
492
|
-
const
|
|
493
|
-
for (let
|
|
494
|
-
const
|
|
495
|
-
|
|
491
|
+
const p = [];
|
|
492
|
+
for (let h = 0; h < b; h++) {
|
|
493
|
+
const D = y[h];
|
|
494
|
+
D === "." ? p.push(void 0) : p.push(f ? Number(D) : D);
|
|
496
495
|
}
|
|
497
|
-
e[
|
|
496
|
+
e[u] = p;
|
|
498
497
|
}
|
|
499
498
|
}
|
|
500
499
|
}
|
|
501
500
|
return e;
|
|
502
501
|
}
|
|
503
502
|
parseSamples(t, e) {
|
|
504
|
-
var i;
|
|
505
503
|
const r = {};
|
|
506
504
|
if (t) {
|
|
507
|
-
const
|
|
508
|
-
for (let
|
|
509
|
-
const
|
|
510
|
-
|
|
505
|
+
const o = e.split(" "), s = t.split(":"), c = this.metadata.FORMAT, i = [];
|
|
506
|
+
for (let u = 0; u < s.length; u++) {
|
|
507
|
+
const l = c[s[u]]?.Type;
|
|
508
|
+
i.push(l === "Integer" || l === "Float");
|
|
511
509
|
}
|
|
512
|
-
const
|
|
513
|
-
for (let
|
|
514
|
-
const
|
|
515
|
-
let
|
|
516
|
-
for (let
|
|
517
|
-
if (
|
|
518
|
-
const
|
|
519
|
-
if (
|
|
520
|
-
|
|
510
|
+
const n = s.length, a = this.samples.length;
|
|
511
|
+
for (let u = 0; u < a; u++) {
|
|
512
|
+
const l = this.samples[u], d = {}, f = o[u], y = f.length;
|
|
513
|
+
let b = 0, p = 0;
|
|
514
|
+
for (let h = 0; h <= y; h++)
|
|
515
|
+
if (h === y || f[h] === ":") {
|
|
516
|
+
const D = f.slice(b, h);
|
|
517
|
+
if (D === "" || D === ".")
|
|
518
|
+
d[s[p]] = void 0;
|
|
521
519
|
else {
|
|
522
|
-
const
|
|
523
|
-
if (
|
|
524
|
-
for (let
|
|
525
|
-
const
|
|
526
|
-
|
|
520
|
+
const g = D.split(","), T = [];
|
|
521
|
+
if (i[p])
|
|
522
|
+
for (let N = 0; N < g.length; N++) {
|
|
523
|
+
const I = g[N];
|
|
524
|
+
T.push(I === "." ? void 0 : +I);
|
|
527
525
|
}
|
|
528
526
|
else
|
|
529
|
-
for (let
|
|
530
|
-
const
|
|
531
|
-
|
|
527
|
+
for (let N = 0; N < g.length; N++) {
|
|
528
|
+
const I = g[N];
|
|
529
|
+
T.push(I === "." ? void 0 : I);
|
|
532
530
|
}
|
|
533
|
-
|
|
531
|
+
d[s[p]] = T;
|
|
534
532
|
}
|
|
535
|
-
if (
|
|
533
|
+
if (b = h + 1, p += 1, p >= n)
|
|
536
534
|
break;
|
|
537
535
|
}
|
|
538
|
-
r[
|
|
536
|
+
r[l] = d;
|
|
539
537
|
}
|
|
540
538
|
}
|
|
541
539
|
return r;
|
|
@@ -551,13 +549,13 @@ ${i}`);
|
|
|
551
549
|
const e = /^##(.+?)=(.*)/.exec(t.trim());
|
|
552
550
|
if (!e)
|
|
553
551
|
throw new Error(`Line is not a valid metadata line: ${t}`);
|
|
554
|
-
const [r,
|
|
555
|
-
if (
|
|
556
|
-
|
|
557
|
-
const [
|
|
558
|
-
|
|
552
|
+
const [r, o] = e.slice(1, 3), s = r;
|
|
553
|
+
if (o?.startsWith("<")) {
|
|
554
|
+
s in this.metadata || (this.metadata[s] = {});
|
|
555
|
+
const [c, i] = this.parseStructuredMetaVal(o);
|
|
556
|
+
c ? this.metadata[s][c] = i : this.metadata[s] = i;
|
|
559
557
|
} else
|
|
560
|
-
this.metadata[
|
|
558
|
+
this.metadata[s] = o;
|
|
561
559
|
}
|
|
562
560
|
/**
|
|
563
561
|
* Parse a VCF header structured meta string (i.e. a meta value that starts
|
|
@@ -569,7 +567,7 @@ ${i}`);
|
|
|
569
567
|
* and 2) an object with the other key-value pairs in the metadata
|
|
570
568
|
*/
|
|
571
569
|
parseStructuredMetaVal(t) {
|
|
572
|
-
const e =
|
|
570
|
+
const e = F(t), r = e.ID;
|
|
573
571
|
return delete e.ID, "Number" in e && (Number.isNaN(Number(e.Number)) || (e.Number = Number(e.Number))), [r, e];
|
|
574
572
|
}
|
|
575
573
|
/**
|
|
@@ -584,8 +582,8 @@ ${i}`);
|
|
|
584
582
|
getMetadata(...t) {
|
|
585
583
|
let e = this.metadata;
|
|
586
584
|
const r = t.length;
|
|
587
|
-
for (let
|
|
588
|
-
if (e = e[t[
|
|
585
|
+
for (let o = 0; o < r; o++)
|
|
586
|
+
if (e = e[t[o]], !e)
|
|
589
587
|
return e;
|
|
590
588
|
return e;
|
|
591
589
|
}
|
|
@@ -635,25 +633,25 @@ ${i}`);
|
|
|
635
633
|
let e = 0, r = 0;
|
|
636
634
|
for (; e < t.length && r < 9; )
|
|
637
635
|
t[e] === " " && (r += 1), e += 1;
|
|
638
|
-
const
|
|
639
|
-
if (this.strict && !
|
|
636
|
+
const o = r === 9 ? e - 1 : e, s = t.slice(0, o).split(" "), c = t.slice(o + 1), [i, n, a, u, l, d, f] = s, y = i, b = +n, p = a === "." ? void 0 : a.split(";"), h = u, D = l === "." ? void 0 : l.split(","), g = d === "." ? void 0 : +d, T = f === "." ? void 0 : f.split(";"), N = s[8];
|
|
637
|
+
if (this.strict && !s[7])
|
|
640
638
|
throw new Error("no INFO field specified, must contain at least a '.' (turn off strict mode to allow)");
|
|
641
|
-
const
|
|
639
|
+
const I = s[7] === void 0 || s[7] === "." ? {} : this.parseInfo(s[7]);
|
|
642
640
|
return {
|
|
643
|
-
CHROM:
|
|
644
|
-
POS:
|
|
645
|
-
ALT:
|
|
646
|
-
INFO:
|
|
647
|
-
REF:
|
|
648
|
-
FILTER:
|
|
649
|
-
ID:
|
|
650
|
-
QUAL:
|
|
651
|
-
FORMAT:
|
|
652
|
-
SAMPLES: () => this.parseSamples(
|
|
653
|
-
GENOTYPES: () =>
|
|
641
|
+
CHROM: y,
|
|
642
|
+
POS: b,
|
|
643
|
+
ALT: D,
|
|
644
|
+
INFO: I,
|
|
645
|
+
REF: h,
|
|
646
|
+
FILTER: T?.length === 1 && T[0] === "PASS" ? "PASS" : T,
|
|
647
|
+
ID: p,
|
|
648
|
+
QUAL: g,
|
|
649
|
+
FORMAT: N,
|
|
650
|
+
SAMPLES: () => this.parseSamples(s[8] ?? "", c),
|
|
651
|
+
GENOTYPES: () => S(s[8] ?? "", c, this.samples)
|
|
654
652
|
};
|
|
655
653
|
}
|
|
656
654
|
}
|
|
657
655
|
export {
|
|
658
|
-
|
|
656
|
+
L as default
|
|
659
657
|
};
|