@jbrowse/plugin-alignments 2.1.7 → 2.2.1
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/AlignmentsFeatureDetail/AlignmentsFeatureDetail.js +12 -13
- package/dist/AlignmentsFeatureDetail/AlignmentsFeatureDetail.js.map +1 -1
- package/dist/AlignmentsTrack/index.d.ts +1 -1
- package/dist/AlignmentsTrack/index.js +16 -6
- package/dist/AlignmentsTrack/index.js.map +1 -1
- package/dist/BamAdapter/BamAdapter.d.ts +7 -3
- package/dist/BamAdapter/BamAdapter.js +36 -31
- package/dist/BamAdapter/BamAdapter.js.map +1 -1
- package/dist/BamAdapter/BamSlightlyLazyFeature.js +1 -0
- package/dist/BamAdapter/BamSlightlyLazyFeature.js.map +1 -1
- package/dist/BamAdapter/MismatchParser.d.ts +2 -2
- package/dist/BamAdapter/MismatchParser.js +4 -7
- package/dist/BamAdapter/MismatchParser.js.map +1 -1
- package/dist/BamAdapter/configSchema.d.ts +2 -2
- package/dist/BamAdapter/configSchema.js +27 -2
- package/dist/BamAdapter/configSchema.js.map +1 -1
- package/dist/BamAdapter/index.js +7 -5
- package/dist/BamAdapter/index.js.map +1 -1
- package/dist/CramAdapter/CramAdapter.d.ts +13 -7
- package/dist/CramAdapter/CramAdapter.js +56 -61
- package/dist/CramAdapter/CramAdapter.js.map +1 -1
- package/dist/CramAdapter/CramSlightlyLazyFeature.d.ts +15 -23
- package/dist/CramAdapter/CramSlightlyLazyFeature.js +10 -217
- package/dist/CramAdapter/CramSlightlyLazyFeature.js.map +1 -1
- package/dist/CramAdapter/CramTestAdapters.d.ts +1 -1
- package/dist/CramAdapter/CramTestAdapters.js +1 -1
- package/dist/CramAdapter/CramTestAdapters.js.map +1 -1
- package/dist/CramAdapter/configSchema.d.ts +2 -3
- package/dist/CramAdapter/configSchema.js +44 -22
- package/dist/CramAdapter/configSchema.js.map +1 -1
- package/dist/CramAdapter/index.js +7 -5
- package/dist/CramAdapter/index.js.map +1 -1
- package/dist/CramAdapter/util.d.ts +18 -0
- package/dist/CramAdapter/util.js +241 -0
- package/dist/CramAdapter/util.js.map +1 -0
- package/dist/HtsgetBamAdapter/HtsgetBamAdapter.d.ts +5 -2
- package/dist/HtsgetBamAdapter/HtsgetBamAdapter.js +15 -20
- package/dist/HtsgetBamAdapter/HtsgetBamAdapter.js.map +1 -1
- package/dist/HtsgetBamAdapter/configSchema.d.ts +2 -2
- package/dist/HtsgetBamAdapter/configSchema.js +20 -3
- package/dist/HtsgetBamAdapter/configSchema.js.map +1 -1
- package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.js +1 -1
- package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.js.map +1 -1
- package/dist/LinearAlignmentsDisplay/models/configSchema.d.ts +2 -2
- package/dist/LinearAlignmentsDisplay/models/configSchema.js +23 -6
- package/dist/LinearAlignmentsDisplay/models/configSchema.js.map +1 -1
- package/dist/LinearAlignmentsDisplay/models/model.d.ts +77 -10
- package/dist/LinearAlignmentsDisplay/models/model.js +102 -9
- package/dist/LinearAlignmentsDisplay/models/model.js.map +1 -1
- package/dist/LinearPileupDisplay/configSchema.d.ts +4 -4
- package/dist/LinearPileupDisplay/configSchema.js +22 -5
- package/dist/LinearPileupDisplay/configSchema.js.map +1 -1
- package/dist/LinearPileupDisplay/index.d.ts +3 -0
- package/dist/LinearPileupDisplay/index.js +3 -0
- package/dist/LinearPileupDisplay/index.js.map +1 -1
- package/dist/LinearPileupDisplay/model.d.ts +100 -6
- package/dist/LinearPileupDisplay/model.js +611 -503
- package/dist/LinearPileupDisplay/model.js.map +1 -1
- package/dist/LinearSNPCoverageDisplay/components/Tooltip.d.ts +1 -1
- package/dist/LinearSNPCoverageDisplay/models/configSchema.js +33 -4
- package/dist/LinearSNPCoverageDisplay/models/configSchema.js.map +1 -1
- package/dist/LinearSNPCoverageDisplay/models/model.d.ts +87 -4
- package/dist/LinearSNPCoverageDisplay/models/model.js +240 -159
- package/dist/LinearSNPCoverageDisplay/models/model.js.map +1 -1
- package/dist/PileupRPC/rpcMethods.d.ts +1 -1
- package/dist/PileupRPC/rpcMethods.js +12 -7
- package/dist/PileupRPC/rpcMethods.js.map +1 -1
- package/dist/PileupRenderer/PileupLayoutSession.d.ts +1 -1
- package/dist/PileupRenderer/PileupRenderer.d.ts +1 -1
- package/dist/PileupRenderer/PileupRenderer.js +37 -34
- package/dist/PileupRenderer/PileupRenderer.js.map +1 -1
- package/dist/PileupRenderer/configSchema.d.ts +2 -2
- package/dist/PileupRenderer/configSchema.js +37 -2
- package/dist/PileupRenderer/configSchema.js.map +1 -1
- package/dist/PileupRenderer/index.js +8 -6
- package/dist/PileupRenderer/index.js.map +1 -1
- package/dist/SNPCoverageAdapter/configSchema.d.ts +2 -3
- package/dist/SNPCoverageAdapter/configSchema.js +15 -4
- package/dist/SNPCoverageAdapter/configSchema.js.map +1 -1
- package/dist/SNPCoverageAdapter/index.d.ts +1 -2
- package/dist/SNPCoverageAdapter/index.js +17 -14
- package/dist/SNPCoverageAdapter/index.js.map +1 -1
- package/dist/SNPCoverageRenderer/configSchema.d.ts +2 -2
- package/dist/SNPCoverageRenderer/configSchema.js +21 -1
- package/dist/SNPCoverageRenderer/configSchema.js.map +1 -1
- package/dist/SNPCoverageRenderer/index.d.ts +0 -1
- package/dist/SNPCoverageRenderer/index.js +1 -4
- package/dist/SNPCoverageRenderer/index.js.map +1 -1
- package/dist/index.d.ts +3 -2
- package/dist/index.js +4 -2
- package/dist/index.js.map +1 -1
- package/esm/AlignmentsFeatureDetail/AlignmentsFeatureDetail.js +12 -13
- package/esm/AlignmentsFeatureDetail/AlignmentsFeatureDetail.js.map +1 -1
- package/esm/AlignmentsTrack/index.d.ts +1 -1
- package/esm/AlignmentsTrack/index.js +16 -6
- package/esm/AlignmentsTrack/index.js.map +1 -1
- package/esm/BamAdapter/BamAdapter.d.ts +7 -3
- package/esm/BamAdapter/BamAdapter.js +36 -31
- package/esm/BamAdapter/BamAdapter.js.map +1 -1
- package/esm/BamAdapter/BamSlightlyLazyFeature.js +1 -0
- package/esm/BamAdapter/BamSlightlyLazyFeature.js.map +1 -1
- package/esm/BamAdapter/MismatchParser.d.ts +2 -2
- package/esm/BamAdapter/MismatchParser.js +4 -7
- package/esm/BamAdapter/MismatchParser.js.map +1 -1
- package/esm/BamAdapter/configSchema.d.ts +2 -2
- package/esm/BamAdapter/configSchema.js +27 -2
- package/esm/BamAdapter/configSchema.js.map +1 -1
- package/esm/BamAdapter/index.js +7 -5
- package/esm/BamAdapter/index.js.map +1 -1
- package/esm/CramAdapter/CramAdapter.d.ts +13 -7
- package/esm/CramAdapter/CramAdapter.js +56 -61
- package/esm/CramAdapter/CramAdapter.js.map +1 -1
- package/esm/CramAdapter/CramSlightlyLazyFeature.d.ts +15 -23
- package/esm/CramAdapter/CramSlightlyLazyFeature.js +10 -217
- package/esm/CramAdapter/CramSlightlyLazyFeature.js.map +1 -1
- package/esm/CramAdapter/CramTestAdapters.d.ts +1 -1
- package/esm/CramAdapter/CramTestAdapters.js +1 -1
- package/esm/CramAdapter/CramTestAdapters.js.map +1 -1
- package/esm/CramAdapter/configSchema.d.ts +2 -3
- package/esm/CramAdapter/configSchema.js +44 -22
- package/esm/CramAdapter/configSchema.js.map +1 -1
- package/esm/CramAdapter/index.js +8 -6
- package/esm/CramAdapter/index.js.map +1 -1
- package/esm/CramAdapter/util.d.ts +18 -0
- package/esm/CramAdapter/util.js +236 -0
- package/esm/CramAdapter/util.js.map +1 -0
- package/esm/HtsgetBamAdapter/HtsgetBamAdapter.d.ts +5 -2
- package/esm/HtsgetBamAdapter/HtsgetBamAdapter.js +15 -20
- package/esm/HtsgetBamAdapter/HtsgetBamAdapter.js.map +1 -1
- package/esm/HtsgetBamAdapter/configSchema.d.ts +2 -2
- package/esm/HtsgetBamAdapter/configSchema.js +20 -3
- package/esm/HtsgetBamAdapter/configSchema.js.map +1 -1
- package/esm/LinearAlignmentsDisplay/components/AlignmentsDisplay.js +1 -1
- package/esm/LinearAlignmentsDisplay/components/AlignmentsDisplay.js.map +1 -1
- package/esm/LinearAlignmentsDisplay/models/configSchema.d.ts +2 -2
- package/esm/LinearAlignmentsDisplay/models/configSchema.js +23 -6
- package/esm/LinearAlignmentsDisplay/models/configSchema.js.map +1 -1
- package/esm/LinearAlignmentsDisplay/models/model.d.ts +77 -10
- package/esm/LinearAlignmentsDisplay/models/model.js +102 -9
- package/esm/LinearAlignmentsDisplay/models/model.js.map +1 -1
- package/esm/LinearPileupDisplay/configSchema.d.ts +4 -4
- package/esm/LinearPileupDisplay/configSchema.js +22 -5
- package/esm/LinearPileupDisplay/configSchema.js.map +1 -1
- package/esm/LinearPileupDisplay/index.d.ts +3 -0
- package/esm/LinearPileupDisplay/index.js +1 -0
- package/esm/LinearPileupDisplay/index.js.map +1 -1
- package/esm/LinearPileupDisplay/model.d.ts +100 -6
- package/esm/LinearPileupDisplay/model.js +611 -503
- package/esm/LinearPileupDisplay/model.js.map +1 -1
- package/esm/LinearSNPCoverageDisplay/components/Tooltip.d.ts +1 -1
- package/esm/LinearSNPCoverageDisplay/models/configSchema.js +33 -4
- package/esm/LinearSNPCoverageDisplay/models/configSchema.js.map +1 -1
- package/esm/LinearSNPCoverageDisplay/models/model.d.ts +87 -4
- package/esm/LinearSNPCoverageDisplay/models/model.js +240 -159
- package/esm/LinearSNPCoverageDisplay/models/model.js.map +1 -1
- package/esm/PileupRPC/rpcMethods.d.ts +1 -1
- package/esm/PileupRPC/rpcMethods.js +12 -7
- package/esm/PileupRPC/rpcMethods.js.map +1 -1
- package/esm/PileupRenderer/PileupLayoutSession.d.ts +1 -1
- package/esm/PileupRenderer/PileupRenderer.d.ts +1 -1
- package/esm/PileupRenderer/PileupRenderer.js +37 -34
- package/esm/PileupRenderer/PileupRenderer.js.map +1 -1
- package/esm/PileupRenderer/configSchema.d.ts +2 -2
- package/esm/PileupRenderer/configSchema.js +37 -2
- package/esm/PileupRenderer/configSchema.js.map +1 -1
- package/esm/PileupRenderer/index.js +8 -6
- package/esm/PileupRenderer/index.js.map +1 -1
- package/esm/SNPCoverageAdapter/configSchema.d.ts +2 -3
- package/esm/SNPCoverageAdapter/configSchema.js +15 -4
- package/esm/SNPCoverageAdapter/configSchema.js.map +1 -1
- package/esm/SNPCoverageAdapter/index.d.ts +1 -2
- package/esm/SNPCoverageAdapter/index.js +17 -15
- package/esm/SNPCoverageAdapter/index.js.map +1 -1
- package/esm/SNPCoverageRenderer/configSchema.d.ts +2 -2
- package/esm/SNPCoverageRenderer/configSchema.js +21 -1
- package/esm/SNPCoverageRenderer/configSchema.js.map +1 -1
- package/esm/SNPCoverageRenderer/index.d.ts +0 -1
- package/esm/SNPCoverageRenderer/index.js +1 -3
- package/esm/SNPCoverageRenderer/index.js.map +1 -1
- package/esm/index.d.ts +3 -2
- package/esm/index.js +2 -2
- package/esm/index.js.map +1 -1
- package/package.json +4 -3
- package/src/AlignmentsFeatureDetail/AlignmentsFeatureDetail.tsx +17 -16
- package/src/AlignmentsFeatureDetail/__snapshots__/index.test.js.snap +41 -513
- package/src/AlignmentsFeatureDetail/index.test.js +6 -4
- package/src/AlignmentsTrack/index.ts +18 -12
- package/src/BamAdapter/BamAdapter.ts +42 -41
- package/src/BamAdapter/BamSlightlyLazyFeature.ts +2 -1
- package/src/BamAdapter/MismatchParser.test.ts +21 -12
- package/src/BamAdapter/MismatchParser.ts +7 -10
- package/src/BamAdapter/__snapshots__/BamAdapter.test.ts.snap +135 -135
- package/src/BamAdapter/configSchema.ts +57 -29
- package/src/BamAdapter/index.ts +7 -8
- package/src/CombinationTest.test.ts +107 -0
- package/src/CramAdapter/CramAdapter.test.ts +1 -2
- package/src/CramAdapter/CramAdapter.ts +83 -84
- package/src/CramAdapter/CramSlightlyLazyFeature.ts +18 -218
- package/src/CramAdapter/CramTestAdapters.ts +1 -1
- package/src/CramAdapter/__snapshots__/CramAdapter.test.ts.snap +31 -31
- package/src/CramAdapter/__snapshots__/util.test.ts.snap +14 -0
- package/src/CramAdapter/configSchema.ts +54 -30
- package/src/CramAdapter/index.ts +8 -9
- package/src/CramAdapter/util.test.ts +26 -0
- package/src/CramAdapter/util.ts +251 -0
- package/src/HtsgetBamAdapter/HtsgetBamAdapter.ts +14 -21
- package/src/HtsgetBamAdapter/configSchema.ts +36 -19
- package/src/LinearAlignmentsDisplay/components/AlignmentsDisplay.tsx +3 -1
- package/src/LinearAlignmentsDisplay/models/configSchema.ts +23 -10
- package/src/LinearAlignmentsDisplay/models/model.tsx +107 -11
- package/src/LinearPileupDisplay/configSchema.ts +25 -9
- package/src/LinearPileupDisplay/index.ts +5 -0
- package/src/LinearPileupDisplay/model.ts +151 -34
- package/src/LinearSNPCoverageDisplay/models/configSchema.ts +36 -9
- package/src/LinearSNPCoverageDisplay/models/model.ts +83 -4
- package/src/PileupRPC/rpcMethods.ts +15 -20
- package/src/PileupRenderer/{PileupRenderer.tsx → PileupRenderer.ts} +53 -63
- package/src/PileupRenderer/configSchema.ts +39 -2
- package/src/PileupRenderer/index.ts +8 -9
- package/src/SNPCoverageAdapter/configSchema.ts +21 -12
- package/src/SNPCoverageAdapter/index.ts +17 -18
- package/src/SNPCoverageRenderer/configSchema.ts +23 -1
- package/src/SNPCoverageRenderer/index.ts +1 -8
- package/src/__snapshots__/index.test.ts.snap +1 -1
- package/src/index.ts +11 -4
- package/src/declare.d.ts +0 -1
package/dist/index.js
CHANGED
|
@@ -26,7 +26,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
26
26
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
27
|
};
|
|
28
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.MismatchParser = void 0;
|
|
29
|
+
exports.MismatchParser = exports.linearPileupDisplayStateModelFactory = exports.linearPileupDisplayConfigSchemaFactory = void 0;
|
|
30
30
|
const Plugin_1 = __importDefault(require("@jbrowse/core/Plugin"));
|
|
31
31
|
const MismatchParser = __importStar(require("./BamAdapter/MismatchParser"));
|
|
32
32
|
exports.MismatchParser = MismatchParser;
|
|
@@ -38,7 +38,9 @@ const SNPCoverageRenderer_1 = __importDefault(require("./SNPCoverageRenderer"));
|
|
|
38
38
|
const PileupRenderer_1 = __importDefault(require("./PileupRenderer"));
|
|
39
39
|
const LinearAlignmentsDisplay_1 = __importDefault(require("./LinearAlignmentsDisplay"));
|
|
40
40
|
const LinearSNPCoverageDisplay_1 = __importDefault(require("./LinearSNPCoverageDisplay"));
|
|
41
|
-
const LinearPileupDisplay_1 =
|
|
41
|
+
const LinearPileupDisplay_1 = __importStar(require("./LinearPileupDisplay"));
|
|
42
|
+
Object.defineProperty(exports, "linearPileupDisplayStateModelFactory", { enumerable: true, get: function () { return LinearPileupDisplay_1.linearPileupDisplayStateModelFactory; } });
|
|
43
|
+
Object.defineProperty(exports, "linearPileupDisplayConfigSchemaFactory", { enumerable: true, get: function () { return LinearPileupDisplay_1.linearPileupDisplayConfigSchemaFactory; } });
|
|
42
44
|
const AlignmentsTrack_1 = __importDefault(require("./AlignmentsTrack"));
|
|
43
45
|
const AlignmentsFeatureDetail_1 = __importDefault(require("./AlignmentsFeatureDetail"));
|
|
44
46
|
const rpcMethods_1 = require("./PileupRPC/rpcMethods");
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,kEAAyC;AAEzC,4EAA6D;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,15 +4,16 @@ import { makeStyles } from 'tss-react/mui';
|
|
|
4
4
|
import { observer } from 'mobx-react';
|
|
5
5
|
import { getSession } from '@jbrowse/core/util';
|
|
6
6
|
import copy from 'copy-to-clipboard';
|
|
7
|
+
import clone from 'clone';
|
|
7
8
|
import { FeatureDetails, BaseCard, SimpleValue, } from '@jbrowse/core/BaseFeatureWidget/BaseFeatureDetail';
|
|
8
9
|
import { parseCigar } from '../BamAdapter/MismatchParser';
|
|
9
|
-
const useStyles = makeStyles()(
|
|
10
|
+
const useStyles = makeStyles()({
|
|
10
11
|
compact: {
|
|
11
12
|
paddingRight: 0,
|
|
12
13
|
paddingTop: 0,
|
|
13
14
|
paddingBottom: 0,
|
|
14
15
|
},
|
|
15
|
-
})
|
|
16
|
+
});
|
|
16
17
|
const omit = ['clipPos', 'flags'];
|
|
17
18
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
18
19
|
function AlignmentFlags(props) {
|
|
@@ -92,12 +93,12 @@ function SupplementaryAlignments(props) {
|
|
|
92
93
|
const displayEnd = end.toLocaleString('en-US');
|
|
93
94
|
const displayString = `${saRef}:${displayStart}-${displayEnd} (${saStrand})`;
|
|
94
95
|
return (React.createElement("li", { key: `${locString}-${index}` },
|
|
95
|
-
React.createElement(Link, { onClick: event => {
|
|
96
|
+
React.createElement(Link, { onClick: async (event) => {
|
|
96
97
|
event.preventDefault();
|
|
97
98
|
const { view } = model;
|
|
98
99
|
try {
|
|
99
100
|
if (view) {
|
|
100
|
-
view.navToLocString(locString);
|
|
101
|
+
await view.navToLocString(locString);
|
|
101
102
|
}
|
|
102
103
|
else {
|
|
103
104
|
throw new Error('No view associated with this view anymore');
|
|
@@ -113,15 +114,13 @@ function SupplementaryAlignments(props) {
|
|
|
113
114
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
114
115
|
function PairLink({ locString, model }) {
|
|
115
116
|
const session = getSession(model);
|
|
116
|
-
return (React.createElement(Link, { onClick: () => {
|
|
117
|
+
return (React.createElement(Link, { onClick: async () => {
|
|
117
118
|
const { view } = model;
|
|
119
|
+
if (!view) {
|
|
120
|
+
throw new Error('No view associated with this feature detail panel anymore');
|
|
121
|
+
}
|
|
118
122
|
try {
|
|
119
|
-
|
|
120
|
-
view.navToLocString(locString);
|
|
121
|
-
}
|
|
122
|
-
else {
|
|
123
|
-
session.notify('No view associated with this feature detail panel anymore', 'warning');
|
|
124
|
-
}
|
|
123
|
+
await view.navToLocString(locString);
|
|
125
124
|
}
|
|
126
125
|
catch (e) {
|
|
127
126
|
console.error(e);
|
|
@@ -132,14 +131,14 @@ function PairLink({ locString, model }) {
|
|
|
132
131
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
133
132
|
function AlignmentFeatureDetails(props) {
|
|
134
133
|
const { model } = props;
|
|
135
|
-
const feat =
|
|
134
|
+
const feat = clone(model.featureData);
|
|
136
135
|
const SA = (feat.tags && feat.tags.SA) || feat.SA;
|
|
137
136
|
return (React.createElement(Paper, { "data-testid": "alignment-side-drawer" },
|
|
138
137
|
React.createElement(FeatureDetails, { ...props, omit: omit, feature: feat, formatter: (value, key) => {
|
|
139
138
|
return key === 'next_segment_position' ? (React.createElement(PairLink, { model: model, locString: value })) : (React.createElement(Formatter, { value: value }));
|
|
140
139
|
} }),
|
|
141
140
|
SA ? React.createElement(SupplementaryAlignments, { model: model, tag: SA }) : null,
|
|
142
|
-
React.createElement(AlignmentFlags, { feature: feat, ...props })));
|
|
141
|
+
feat.flags !== undefined ? (React.createElement(AlignmentFlags, { feature: feat, ...props })) : null));
|
|
143
142
|
}
|
|
144
143
|
export default observer(AlignmentFeatureDetails);
|
|
145
144
|
//# sourceMappingURL=AlignmentsFeatureDetail.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AlignmentsFeatureDetail.js","sourceRoot":"","sources":["../../src/AlignmentsFeatureDetail/AlignmentsFeatureDetail.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACvC,OAAO,EACL,UAAU,EACV,IAAI,EACJ,KAAK,EACL,QAAQ,EACR,gBAAgB,EAChB,SAAS,GACV,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAC/C,OAAO,IAAI,MAAM,mBAAmB,CAAA;AACpC,OAAO,EACL,cAAc,EACd,QAAQ,EACR,WAAW,GACZ,MAAM,mDAAmD,CAAA;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAA;AAEzD,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC
|
|
1
|
+
{"version":3,"file":"AlignmentsFeatureDetail.js","sourceRoot":"","sources":["../../src/AlignmentsFeatureDetail/AlignmentsFeatureDetail.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import PluginManager from '@jbrowse/core/PluginManager';
|
|
2
|
-
export default function register(
|
|
2
|
+
export default function register(pm: PluginManager): void;
|
|
@@ -1,18 +1,28 @@
|
|
|
1
1
|
import TrackType from '@jbrowse/core/pluggableElementTypes/TrackType';
|
|
2
2
|
import { ConfigurationSchema } from '@jbrowse/core/configuration';
|
|
3
3
|
import { createBaseTrackConfig, createBaseTrackModel, } from '@jbrowse/core/pluggableElementTypes/models';
|
|
4
|
+
/**
|
|
5
|
+
* #config AlignmentsTrack
|
|
6
|
+
* has very little config; most config and state logic is on the display
|
|
7
|
+
*/
|
|
8
|
+
function x() { } // eslint-disable-line @typescript-eslint/no-unused-vars
|
|
4
9
|
function configSchemaFactory(pluginManager) {
|
|
5
|
-
return ConfigurationSchema('AlignmentsTrack', {}, {
|
|
10
|
+
return ConfigurationSchema('AlignmentsTrack', {}, {
|
|
11
|
+
/**
|
|
12
|
+
* #baseConfiguration
|
|
13
|
+
*/
|
|
14
|
+
baseConfiguration: createBaseTrackConfig(pluginManager),
|
|
15
|
+
});
|
|
6
16
|
}
|
|
7
|
-
export default function register(
|
|
8
|
-
|
|
9
|
-
const configSchema = configSchemaFactory(
|
|
17
|
+
export default function register(pm) {
|
|
18
|
+
pm.addTrackType(() => {
|
|
19
|
+
const configSchema = configSchemaFactory(pm);
|
|
10
20
|
const track = new TrackType({
|
|
11
21
|
name: 'AlignmentsTrack',
|
|
12
22
|
configSchema,
|
|
13
|
-
stateModel: createBaseTrackModel(
|
|
23
|
+
stateModel: createBaseTrackModel(pm, 'AlignmentsTrack', configSchema),
|
|
14
24
|
});
|
|
15
|
-
const linearAlignmentsDisplay =
|
|
25
|
+
const linearAlignmentsDisplay = pm.getDisplayType('LinearAlignmentsDisplay');
|
|
16
26
|
// Add LinearAlignmentsDisplay here so that it has priority over the other
|
|
17
27
|
// linear displays (defaults to order the displays are added, but we have
|
|
18
28
|
// to add the Pileup and SNPCoverage displays first).
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/AlignmentsTrack/index.ts"],"names":[],"mappings":"AACA,OAAO,SAAS,MAAM,+CAA+C,CAAA;AACrE,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AACjE,OAAO,EACL,qBAAqB,EACrB,oBAAoB,GACrB,MAAM,4CAA4C,CAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/AlignmentsTrack/index.ts"],"names":[],"mappings":"AACA,OAAO,SAAS,MAAM,+CAA+C,CAAA;AACrE,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AACjE,OAAO,EACL,qBAAqB,EACrB,oBAAoB,GACrB,MAAM,4CAA4C,CAAA;AAEnD;;;GAGG;AACH,SAAS,CAAC,KAAI,CAAC,CAAC,wDAAwD;AAExE,SAAS,mBAAmB,CAAC,aAA4B;IACvD,OAAO,mBAAmB,CACxB,iBAAiB,EACjB,EAAE,EACF;QACE;;WAEG;QACH,iBAAiB,EAAE,qBAAqB,CAAC,aAAa,CAAC;KACxD,CACF,CAAA;AACH,CAAC;AACD,MAAM,CAAC,OAAO,UAAU,QAAQ,CAAC,EAAiB;IAChD,EAAE,CAAC,YAAY,CAAC,GAAG,EAAE;QACnB,MAAM,YAAY,GAAG,mBAAmB,CAAC,EAAE,CAAC,CAAA;QAC5C,MAAM,KAAK,GAAG,IAAI,SAAS,CAAC;YAC1B,IAAI,EAAE,iBAAiB;YACvB,YAAY;YACZ,UAAU,EAAE,oBAAoB,CAAC,EAAE,EAAE,iBAAiB,EAAE,YAAY,CAAC;SACtE,CAAC,CAAA;QACF,MAAM,uBAAuB,GAAG,EAAE,CAAC,cAAc,CAAC,yBAAyB,CAAC,CAAA;QAC5E,0EAA0E;QAC1E,yEAAyE;QACzE,qDAAqD;QACrD,KAAK,CAAC,cAAc,CAAC,uBAAuB,CAAC,CAAA;QAC7C,OAAO,KAAK,CAAA;IACd,CAAC,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { BamFile } from '@gmod/bam';
|
|
2
2
|
import { BaseFeatureDataAdapter, BaseOptions } from '@jbrowse/core/data_adapters/BaseAdapter';
|
|
3
3
|
import { Region } from '@jbrowse/core/util/types';
|
|
4
|
-
import { Feature } from '@jbrowse/core/util
|
|
4
|
+
import { Feature } from '@jbrowse/core/util';
|
|
5
5
|
interface Header {
|
|
6
6
|
idToName: string[];
|
|
7
7
|
nameToId: Record<string, number>;
|
|
@@ -9,9 +9,13 @@ interface Header {
|
|
|
9
9
|
export default class BamAdapter extends BaseFeatureDataAdapter {
|
|
10
10
|
private samHeader?;
|
|
11
11
|
private setupP?;
|
|
12
|
-
|
|
12
|
+
private configureP?;
|
|
13
|
+
protected configurePre(): Promise<{
|
|
13
14
|
bam: BamFile;
|
|
14
|
-
sequenceAdapter
|
|
15
|
+
sequenceAdapter: BaseFeatureDataAdapter;
|
|
16
|
+
} | {
|
|
17
|
+
bam: BamFile;
|
|
18
|
+
sequenceAdapter?: undefined;
|
|
15
19
|
}>;
|
|
16
20
|
protected configure(): Promise<{
|
|
17
21
|
bam: BamFile;
|
|
@@ -4,43 +4,48 @@ import { bytesForRegions, updateStatus } from '@jbrowse/core/util';
|
|
|
4
4
|
import { openLocation } from '@jbrowse/core/util/io';
|
|
5
5
|
import { ObservableCreate } from '@jbrowse/core/util/rxjs';
|
|
6
6
|
import { toArray } from 'rxjs/operators';
|
|
7
|
-
|
|
7
|
+
// locals
|
|
8
8
|
import BamSlightlyLazyFeature from './BamSlightlyLazyFeature';
|
|
9
9
|
export default class BamAdapter extends BaseFeatureDataAdapter {
|
|
10
10
|
// derived classes may not use the same configuration so a custom
|
|
11
11
|
// configure method allows derived classes to override this behavior
|
|
12
|
+
async configurePre() {
|
|
13
|
+
const bamLocation = this.getConf('bamLocation');
|
|
14
|
+
const location = this.getConf(['index', 'location']);
|
|
15
|
+
const indexType = this.getConf(['index', 'indexType']);
|
|
16
|
+
const pm = this.pluginManager;
|
|
17
|
+
const csi = indexType === 'CSI';
|
|
18
|
+
const bam = new BamFile({
|
|
19
|
+
bamFilehandle: openLocation(bamLocation, pm),
|
|
20
|
+
csiFilehandle: csi ? openLocation(location, pm) : undefined,
|
|
21
|
+
baiFilehandle: !csi ? openLocation(location, pm) : undefined,
|
|
22
|
+
// chunkSizeLimit and fetchSizeLimit are more troublesome than
|
|
23
|
+
// helpful, and have given overly large values on the ultra long
|
|
24
|
+
// nanopore reads even with 500MB limits, so disabled with infinity
|
|
25
|
+
chunkSizeLimit: Infinity,
|
|
26
|
+
fetchSizeLimit: Infinity,
|
|
27
|
+
yieldThreadTime: Infinity,
|
|
28
|
+
});
|
|
29
|
+
const adapterConfig = this.getConf('sequenceAdapter');
|
|
30
|
+
if (adapterConfig && this.getSubAdapter) {
|
|
31
|
+
const { dataAdapter } = await this.getSubAdapter(adapterConfig);
|
|
32
|
+
return {
|
|
33
|
+
bam,
|
|
34
|
+
sequenceAdapter: dataAdapter,
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
return { bam };
|
|
39
|
+
}
|
|
40
|
+
}
|
|
12
41
|
async configure() {
|
|
13
|
-
if (!this.
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
const bam = new BamFile({
|
|
18
|
-
bamFilehandle: openLocation(bamLocation, this.pluginManager),
|
|
19
|
-
csiFilehandle: indexType === 'CSI'
|
|
20
|
-
? openLocation(location, this.pluginManager)
|
|
21
|
-
: undefined,
|
|
22
|
-
baiFilehandle: indexType !== 'CSI'
|
|
23
|
-
? openLocation(location, this.pluginManager)
|
|
24
|
-
: undefined,
|
|
25
|
-
// chunkSizeLimit and fetchSizeLimit are more troublesome than
|
|
26
|
-
// helpful, and have given overly large values on the ultra long
|
|
27
|
-
// nanopore reads even with 500MB limits, so disabled with infinity
|
|
28
|
-
chunkSizeLimit: Infinity,
|
|
29
|
-
fetchSizeLimit: Infinity,
|
|
30
|
-
yieldThreadTime: Infinity,
|
|
42
|
+
if (!this.configureP) {
|
|
43
|
+
this.configureP = this.configurePre().catch(e => {
|
|
44
|
+
this.configureP = undefined;
|
|
45
|
+
throw e;
|
|
31
46
|
});
|
|
32
|
-
const adapterConfig = readConfObject(this.config, 'sequenceAdapter');
|
|
33
|
-
if (adapterConfig && this.getSubAdapter) {
|
|
34
|
-
this.configured = this.getSubAdapter(adapterConfig).then(({ dataAdapter }) => ({
|
|
35
|
-
bam,
|
|
36
|
-
sequenceAdapter: dataAdapter,
|
|
37
|
-
}));
|
|
38
|
-
}
|
|
39
|
-
else {
|
|
40
|
-
this.configured = Promise.resolve({ bam });
|
|
41
|
-
}
|
|
42
47
|
}
|
|
43
|
-
return this.
|
|
48
|
+
return this.configureP;
|
|
44
49
|
}
|
|
45
50
|
async getHeader(opts) {
|
|
46
51
|
const { bam } = await this.configure();
|
|
@@ -156,7 +161,7 @@ export default class BamAdapter extends BaseFeatureDataAdapter {
|
|
|
156
161
|
// @ts-ignore
|
|
157
162
|
if (bam.index.filehandle !== '?') {
|
|
158
163
|
const bytes = await bytesForRegions(regions, bam);
|
|
159
|
-
const fetchSizeLimit =
|
|
164
|
+
const fetchSizeLimit = this.getConf('fetchSizeLimit');
|
|
160
165
|
return { bytes, fetchSizeLimit };
|
|
161
166
|
}
|
|
162
167
|
else {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BamAdapter.js","sourceRoot":"","sources":["../../src/BamAdapter/BamAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EACL,sBAAsB,GAEvB,MAAM,yCAAyC,CAAA;AAEhD,OAAO,EAAE,eAAe,EAAE,YAAY,
|
|
1
|
+
{"version":3,"file":"BamAdapter.js","sourceRoot":"","sources":["../../src/BamAdapter/BamAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BamSlightlyLazyFeature.js","sourceRoot":"","sources":["../../src/BamAdapter/BamSlightlyLazyFeature.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"BamSlightlyLazyFeature.js","sourceRoot":"","sources":["../../src/BamAdapter/BamSlightlyLazyFeature.ts"],"names":[],"mappings":"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"}
|
|
@@ -10,13 +10,13 @@ export interface Mismatch {
|
|
|
10
10
|
cliplen?: number;
|
|
11
11
|
}
|
|
12
12
|
export declare function parseCigar(cigar?: string): string[];
|
|
13
|
-
export declare function cigarToMismatches(ops: string[], seq
|
|
13
|
+
export declare function cigarToMismatches(ops: string[], seq?: string, ref?: string, qual?: Buffer): Mismatch[];
|
|
14
14
|
/**
|
|
15
15
|
* parse a SAM MD tag to find mismatching bases of the template versus the reference
|
|
16
16
|
* @returns array of mismatches and their positions
|
|
17
17
|
*/
|
|
18
18
|
export declare function mdToMismatches(mdstring: string, ops: string[], cigarMismatches: Mismatch[], seq: string, qual?: Buffer): Mismatch[];
|
|
19
|
-
export declare function getMismatches(cigar: string, md
|
|
19
|
+
export declare function getMismatches(cigar: string, md?: string, seq?: string, ref?: string, qual?: Buffer): Mismatch[];
|
|
20
20
|
export declare function getNextRefPos(cigarOps: string[], positions: number[]): Generator<number, void, unknown>;
|
|
21
21
|
export declare function getModificationPositions(mm: string, fseq: string, fstrand: number): {
|
|
22
22
|
type: string;
|
|
@@ -56,7 +56,7 @@ export function cigarToMismatches(ops, seq, ref, qual) {
|
|
|
56
56
|
});
|
|
57
57
|
}
|
|
58
58
|
else if (op === 'X') {
|
|
59
|
-
const r = seq.slice(soffset, soffset + len);
|
|
59
|
+
const r = (seq === null || seq === void 0 ? void 0 : seq.slice(soffset, soffset + len)) || [];
|
|
60
60
|
const q = (qual === null || qual === void 0 ? void 0 : qual.slice(soffset, soffset + len)) || [];
|
|
61
61
|
for (let j = 0; j < len; j++) {
|
|
62
62
|
mismatches.push({
|
|
@@ -167,10 +167,7 @@ export function mdToMismatches(mdstring, ops, cigarMismatches, seq, qual) {
|
|
|
167
167
|
}
|
|
168
168
|
const s = getTemplateCoordLocal(curr.start);
|
|
169
169
|
curr.base = seq[s] || 'X';
|
|
170
|
-
|
|
171
|
-
if (qualScore) {
|
|
172
|
-
curr.qual = qualScore;
|
|
173
|
-
}
|
|
170
|
+
curr.qual = qual === null || qual === void 0 ? void 0 : qual[s];
|
|
174
171
|
curr.altbase = token;
|
|
175
172
|
nextRecord();
|
|
176
173
|
}
|
|
@@ -186,7 +183,7 @@ export function getMismatches(cigar, md, seq, ref, qual) {
|
|
|
186
183
|
mismatches = mismatches.concat(cigarToMismatches(ops, seq, ref, qual));
|
|
187
184
|
}
|
|
188
185
|
// now let's look for CRAM or MD mismatches
|
|
189
|
-
if (md) {
|
|
186
|
+
if (md && seq) {
|
|
190
187
|
mismatches = mismatches.concat(mdToMismatches(md, ops, mismatches, seq, qual));
|
|
191
188
|
}
|
|
192
189
|
return mismatches;
|
|
@@ -282,7 +279,7 @@ export function getModificationTypes(mm) {
|
|
|
282
279
|
const [basemod] = mod.split(',');
|
|
283
280
|
const matches = basemod.match(modificationRegex);
|
|
284
281
|
if (!matches) {
|
|
285
|
-
throw new Error(
|
|
282
|
+
throw new Error(`bad format for MM tag: ${mm}`);
|
|
286
283
|
}
|
|
287
284
|
const [, , , typestr] = matches;
|
|
288
285
|
// can be a multi e.g. C+mh for both meth (m) and hydroxymeth (h) so
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MismatchParser.js","sourceRoot":"","sources":["../../src/BamAdapter/MismatchParser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAW3C,MAAM,OAAO,GAAG,IAAI,MAAM,CAAC,wBAAwB,CAAC,CAAA;AACpD,MAAM,iBAAiB,GAAG,IAAI,MAAM,CAAC,+BAA+B,CAAC,CAAA;AACrE,MAAM,UAAU,UAAU,CAAC,KAAK,GAAG,EAAE;IACnC,OAAO,KAAK,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;AAClD,CAAC;AACD,MAAM,UAAU,iBAAiB,CAC/B,GAAa,EACb,
|
|
1
|
+
{"version":3,"file":"MismatchParser.js","sourceRoot":"","sources":["../../src/BamAdapter/MismatchParser.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
declare const
|
|
2
|
-
export default
|
|
1
|
+
declare const configSchema: import("@jbrowse/core/configuration").AnyConfigurationSchemaType;
|
|
2
|
+
export default configSchema;
|
|
@@ -1,16 +1,30 @@
|
|
|
1
1
|
import { ConfigurationSchema } from '@jbrowse/core/configuration';
|
|
2
2
|
import { types } from 'mobx-state-tree';
|
|
3
|
-
|
|
3
|
+
/**
|
|
4
|
+
* #config BamAdapter
|
|
5
|
+
* used to configure BAM adapter
|
|
6
|
+
*/
|
|
7
|
+
function x() { } // eslint-disable-line @typescript-eslint/no-unused-vars
|
|
8
|
+
const configSchema = ConfigurationSchema('BamAdapter', {
|
|
9
|
+
/**
|
|
10
|
+
* #slot
|
|
11
|
+
*/
|
|
4
12
|
bamLocation: {
|
|
5
13
|
type: 'fileLocation',
|
|
6
14
|
defaultValue: { uri: '/path/to/my.bam', locationType: 'UriLocation' },
|
|
7
15
|
},
|
|
8
16
|
index: ConfigurationSchema('BamIndex', {
|
|
17
|
+
/**
|
|
18
|
+
* #slot index.indexType
|
|
19
|
+
*/
|
|
9
20
|
indexType: {
|
|
10
21
|
model: types.enumeration('IndexType', ['BAI', 'CSI']),
|
|
11
22
|
type: 'stringEnum',
|
|
12
23
|
defaultValue: 'BAI',
|
|
13
24
|
},
|
|
25
|
+
/**
|
|
26
|
+
* #slot index.location
|
|
27
|
+
*/
|
|
14
28
|
location: {
|
|
15
29
|
type: 'fileLocation',
|
|
16
30
|
defaultValue: {
|
|
@@ -19,13 +33,24 @@ export default types.late(() => ConfigurationSchema('BamAdapter', {
|
|
|
19
33
|
},
|
|
20
34
|
},
|
|
21
35
|
}),
|
|
36
|
+
/**
|
|
37
|
+
* #slot
|
|
38
|
+
*/
|
|
22
39
|
fetchSizeLimit: {
|
|
23
40
|
type: 'number',
|
|
41
|
+
description: 'size to fetch in bytes over which to display a warning to the user that too much data will be fetched',
|
|
24
42
|
defaultValue: 5000000,
|
|
25
43
|
},
|
|
44
|
+
/**
|
|
45
|
+
* #slot
|
|
46
|
+
* generally refers to the reference genome assembly's sequence adapter
|
|
47
|
+
* currently needs to be manually added
|
|
48
|
+
*/
|
|
26
49
|
sequenceAdapter: {
|
|
27
50
|
type: 'frozen',
|
|
51
|
+
description: 'sequence data adapter, used to calculate SNPs when BAM reads lacking MD tags',
|
|
28
52
|
defaultValue: null,
|
|
29
53
|
},
|
|
30
|
-
}, { explicitlyTyped: true })
|
|
54
|
+
}, { explicitlyTyped: true });
|
|
55
|
+
export default configSchema;
|
|
31
56
|
//# sourceMappingURL=configSchema.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/BamAdapter/configSchema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AACjE,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAEvC,
|
|
1
|
+
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/BamAdapter/configSchema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AACjE,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAEvC;;;GAGG;AACH,SAAS,CAAC,KAAI,CAAC,CAAC,wDAAwD;AAExE,MAAM,YAAY,GAAG,mBAAmB,CACtC,YAAY,EACZ;IACE;;OAEG;IACH,WAAW,EAAE;QACX,IAAI,EAAE,cAAc;QACpB,YAAY,EAAE,EAAE,GAAG,EAAE,iBAAiB,EAAE,YAAY,EAAE,aAAa,EAAE;KACtE;IAED,KAAK,EAAE,mBAAmB,CAAC,UAAU,EAAE;QACrC;;WAEG;QACH,SAAS,EAAE;YACT,KAAK,EAAE,KAAK,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YACrD,IAAI,EAAE,YAAY;YAClB,YAAY,EAAE,KAAK;SACpB;QACD;;WAEG;QACH,QAAQ,EAAE;YACR,IAAI,EAAE,cAAc;YACpB,YAAY,EAAE;gBACZ,GAAG,EAAE,qBAAqB;gBAC1B,YAAY,EAAE,aAAa;aAC5B;SACF;KACF,CAAC;IACF;;OAEG;IACH,cAAc,EAAE;QACd,IAAI,EAAE,QAAQ;QACd,WAAW,EACT,uGAAuG;QACzG,YAAY,EAAE,OAAS;KACxB;IACD;;;;OAIG;IACH,eAAe,EAAE;QACf,IAAI,EAAE,QAAQ;QACd,WAAW,EACT,8EAA8E;QAChF,YAAY,EAAE,IAAI;KACnB;CACF,EACD,EAAE,eAAe,EAAE,IAAI,EAAE,CAC1B,CAAA;AAED,eAAe,YAAY,CAAA"}
|
package/esm/BamAdapter/index.js
CHANGED
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import AdapterType from '@jbrowse/core/pluggableElementTypes/AdapterType';
|
|
2
2
|
import configSchema from './configSchema';
|
|
3
3
|
export default (pluginManager) => {
|
|
4
|
-
pluginManager.addAdapterType(() =>
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
4
|
+
pluginManager.addAdapterType(() => {
|
|
5
|
+
return new AdapterType({
|
|
6
|
+
name: 'BamAdapter',
|
|
7
|
+
configSchema,
|
|
8
|
+
getAdapterClass: () => import('./BamAdapter').then(r => r.default),
|
|
9
|
+
});
|
|
10
|
+
});
|
|
9
11
|
};
|
|
10
12
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/BamAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,WAAW,MAAM,iDAAiD,CAAA;AACzE,OAAO,YAAY,MAAM,gBAAgB,CAAA;AAEzC,eAAe,CAAC,aAA4B,EAAE,EAAE;IAC9C,aAAa,CAAC,cAAc,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/BamAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,WAAW,MAAM,iDAAiD,CAAA;AACzE,OAAO,YAAY,MAAM,gBAAgB,CAAA;AAEzC,eAAe,CAAC,aAA4B,EAAE,EAAE;IAC9C,aAAa,CAAC,cAAc,CAAC,GAAG,EAAE;QAChC,OAAO,IAAI,WAAW,CAAC;YACrB,IAAI,EAAE,YAAY;YAClB,YAAY;YACZ,eAAe,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;SACnE,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { IndexedCramFile, CramRecord } from '@gmod/cram';
|
|
2
|
+
import { BaseFeatureDataAdapter, BaseOptions, BaseSequenceAdapter } from '@jbrowse/core/data_adapters/BaseAdapter';
|
|
2
3
|
import { Region, Feature } from '@jbrowse/core/util';
|
|
3
4
|
import CramSlightlyLazyFeature from './CramSlightlyLazyFeature';
|
|
4
5
|
interface Header {
|
|
5
6
|
idToName?: string[];
|
|
6
7
|
nameToId?: Record<string, number>;
|
|
7
|
-
readGroups?:
|
|
8
|
+
readGroups?: (string | undefined)[];
|
|
8
9
|
}
|
|
9
10
|
interface FilterBy {
|
|
10
11
|
flagInclude: number;
|
|
@@ -18,13 +19,18 @@ interface FilterBy {
|
|
|
18
19
|
export default class CramAdapter extends BaseFeatureDataAdapter {
|
|
19
20
|
samHeader: Header;
|
|
20
21
|
private setupP?;
|
|
22
|
+
private configureP?;
|
|
21
23
|
private seqIdToRefName;
|
|
22
24
|
private seqIdToOriginalRefName;
|
|
25
|
+
configurePre(): Promise<{
|
|
26
|
+
cram: IndexedCramFile;
|
|
27
|
+
sequenceAdapter: BaseSequenceAdapter;
|
|
28
|
+
}>;
|
|
23
29
|
configure(): Promise<{
|
|
24
|
-
cram:
|
|
25
|
-
sequenceAdapter:
|
|
30
|
+
cram: IndexedCramFile;
|
|
31
|
+
sequenceAdapter: BaseSequenceAdapter;
|
|
26
32
|
}>;
|
|
27
|
-
getHeader(opts?: BaseOptions): Promise<
|
|
33
|
+
getHeader(opts?: BaseOptions): Promise<string | undefined>;
|
|
28
34
|
private seqFetch;
|
|
29
35
|
private setupPre;
|
|
30
36
|
private setup;
|
|
@@ -38,9 +44,9 @@ export default class CramAdapter extends BaseFeatureDataAdapter {
|
|
|
38
44
|
filterBy: FilterBy;
|
|
39
45
|
}): import("rxjs").Observable<Feature>;
|
|
40
46
|
freeResources(): void;
|
|
41
|
-
cramRecordToFeature(record:
|
|
47
|
+
cramRecordToFeature(record: CramRecord): CramSlightlyLazyFeature;
|
|
42
48
|
estimateRegionsStats(regions: Region[], opts?: BaseOptions): Promise<{
|
|
43
|
-
bytes:
|
|
49
|
+
bytes: number;
|
|
44
50
|
fetchSizeLimit: any;
|
|
45
51
|
}>;
|
|
46
52
|
/**
|