@jbrowse/plugin-alignments 2.2.0 → 2.2.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/dist/AlignmentsFeatureDetail/AlignmentsFeatureDetail.js +12 -13
- package/dist/AlignmentsFeatureDetail/AlignmentsFeatureDetail.js.map +1 -1
- package/dist/BamAdapter/BamAdapter.d.ts +1 -1
- package/dist/BamAdapter/BamAdapter.js +1 -0
- 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.js +1 -1
- 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/CramSlightlyLazyFeature.d.ts +1 -10
- package/dist/CramAdapter/CramSlightlyLazyFeature.js +5 -218
- package/dist/CramAdapter/CramSlightlyLazyFeature.js.map +1 -1
- package/dist/CramAdapter/CramTestAdapters.d.ts +1 -1
- package/dist/CramAdapter/CramTestAdapters.js +3 -2
- package/dist/CramAdapter/CramTestAdapters.js.map +1 -1
- package/dist/CramAdapter/configSchema.js +2 -2
- 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/LinearAlignmentsDisplay/components/AlignmentsDisplay.js +1 -1
- package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.js.map +1 -1
- package/dist/LinearAlignmentsDisplay/models/configSchema.d.ts +1 -1
- package/dist/LinearAlignmentsDisplay/models/model.d.ts +5 -5
- package/dist/LinearAlignmentsDisplay/models/model.js +7 -7
- package/dist/LinearAlignmentsDisplay/models/model.js.map +1 -1
- package/dist/LinearPileupDisplay/components/ColorByModifications.d.ts +3 -1
- package/dist/LinearPileupDisplay/components/ColorByModifications.js +7 -22
- package/dist/LinearPileupDisplay/components/ColorByModifications.js.map +1 -1
- package/dist/LinearPileupDisplay/components/ColorByTag.js +2 -22
- package/dist/LinearPileupDisplay/components/ColorByTag.js.map +1 -1
- package/dist/LinearPileupDisplay/components/FilterByTag.js +2 -15
- package/dist/LinearPileupDisplay/components/FilterByTag.js.map +1 -1
- package/dist/LinearPileupDisplay/components/SetFeatureHeight.js +2 -19
- package/dist/LinearPileupDisplay/components/SetFeatureHeight.js.map +1 -1
- package/dist/LinearPileupDisplay/components/SetMaxHeight.js +2 -18
- package/dist/LinearPileupDisplay/components/SetMaxHeight.js.map +1 -1
- package/dist/LinearPileupDisplay/components/SortByTag.js +2 -23
- package/dist/LinearPileupDisplay/components/SortByTag.js.map +1 -1
- package/dist/LinearPileupDisplay/configSchema.d.ts +4 -4
- package/dist/LinearPileupDisplay/configSchema.js +2 -2
- 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 +19 -9
- package/dist/LinearPileupDisplay/model.js +25 -30
- package/dist/LinearPileupDisplay/model.js.map +1 -1
- package/dist/LinearSNPCoverageDisplay/components/Tooltip.d.ts +1 -1
- package/dist/LinearSNPCoverageDisplay/models/model.d.ts +14 -10
- package/dist/LinearSNPCoverageDisplay/models/model.js +8 -6
- 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.js +32 -28
- package/dist/PileupRenderer/PileupRenderer.js.map +1 -1
- package/dist/PileupRenderer/configSchema.js +1 -1
- 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/SNPCoverageAdapter.d.ts +0 -51
- package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js +3 -182
- package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js.map +1 -1
- package/dist/SNPCoverageAdapter/configSchema.d.ts +2 -3
- package/dist/SNPCoverageAdapter/configSchema.js +6 -3
- package/dist/SNPCoverageAdapter/configSchema.js.map +1 -1
- package/dist/SNPCoverageAdapter/generateCoverageBins.d.ts +53 -0
- package/dist/SNPCoverageAdapter/generateCoverageBins.js +185 -0
- package/dist/SNPCoverageAdapter/generateCoverageBins.js.map +1 -0
- 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/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/BamAdapter/BamAdapter.d.ts +1 -1
- package/esm/BamAdapter/BamAdapter.js +1 -0
- 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.js +1 -1
- 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/CramSlightlyLazyFeature.d.ts +1 -10
- package/esm/CramAdapter/CramSlightlyLazyFeature.js +5 -218
- package/esm/CramAdapter/CramSlightlyLazyFeature.js.map +1 -1
- package/esm/CramAdapter/CramTestAdapters.d.ts +1 -1
- package/esm/CramAdapter/CramTestAdapters.js +3 -2
- package/esm/CramAdapter/CramTestAdapters.js.map +1 -1
- package/esm/CramAdapter/configSchema.js +2 -2
- package/esm/CramAdapter/configSchema.js.map +1 -1
- package/esm/CramAdapter/index.js +7 -5
- 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/LinearAlignmentsDisplay/components/AlignmentsDisplay.js +1 -1
- package/esm/LinearAlignmentsDisplay/components/AlignmentsDisplay.js.map +1 -1
- package/esm/LinearAlignmentsDisplay/models/configSchema.d.ts +1 -1
- package/esm/LinearAlignmentsDisplay/models/model.d.ts +5 -5
- package/esm/LinearAlignmentsDisplay/models/model.js +7 -7
- package/esm/LinearAlignmentsDisplay/models/model.js.map +1 -1
- package/esm/LinearPileupDisplay/components/ColorByModifications.d.ts +3 -1
- package/esm/LinearPileupDisplay/components/ColorByModifications.js +8 -23
- package/esm/LinearPileupDisplay/components/ColorByModifications.js.map +1 -1
- package/esm/LinearPileupDisplay/components/ColorByTag.js +3 -20
- package/esm/LinearPileupDisplay/components/ColorByTag.js.map +1 -1
- package/esm/LinearPileupDisplay/components/FilterByTag.js +3 -13
- package/esm/LinearPileupDisplay/components/FilterByTag.js.map +1 -1
- package/esm/LinearPileupDisplay/components/SetFeatureHeight.js +3 -17
- package/esm/LinearPileupDisplay/components/SetFeatureHeight.js.map +1 -1
- package/esm/LinearPileupDisplay/components/SetMaxHeight.js +3 -16
- package/esm/LinearPileupDisplay/components/SetMaxHeight.js.map +1 -1
- package/esm/LinearPileupDisplay/components/SortByTag.js +3 -21
- package/esm/LinearPileupDisplay/components/SortByTag.js.map +1 -1
- package/esm/LinearPileupDisplay/configSchema.d.ts +4 -4
- package/esm/LinearPileupDisplay/configSchema.js +2 -2
- 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 +19 -9
- package/esm/LinearPileupDisplay/model.js +25 -30
- package/esm/LinearPileupDisplay/model.js.map +1 -1
- package/esm/LinearSNPCoverageDisplay/components/Tooltip.d.ts +1 -1
- package/esm/LinearSNPCoverageDisplay/models/model.d.ts +14 -10
- package/esm/LinearSNPCoverageDisplay/models/model.js +9 -7
- 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.js +32 -28
- package/esm/PileupRenderer/PileupRenderer.js.map +1 -1
- package/esm/PileupRenderer/configSchema.js +1 -1
- 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/SNPCoverageAdapter.d.ts +0 -51
- package/esm/SNPCoverageAdapter/SNPCoverageAdapter.js +4 -183
- package/esm/SNPCoverageAdapter/SNPCoverageAdapter.js.map +1 -1
- package/esm/SNPCoverageAdapter/configSchema.d.ts +2 -3
- package/esm/SNPCoverageAdapter/configSchema.js +6 -3
- package/esm/SNPCoverageAdapter/configSchema.js.map +1 -1
- package/esm/SNPCoverageAdapter/generateCoverageBins.d.ts +53 -0
- package/esm/SNPCoverageAdapter/generateCoverageBins.js +182 -0
- package/esm/SNPCoverageAdapter/generateCoverageBins.js.map +1 -0
- 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/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 +1 -473
- package/src/AlignmentsFeatureDetail/index.test.js +6 -4
- package/src/BamAdapter/BamAdapter.ts +3 -2
- 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 +1 -1
- package/src/BamAdapter/index.ts +7 -8
- package/src/CombinationTest.test.ts +107 -0
- package/src/CramAdapter/CramSlightlyLazyFeature.ts +10 -219
- package/src/CramAdapter/CramTestAdapters.ts +2 -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 +2 -3
- package/src/CramAdapter/index.ts +7 -8
- package/src/CramAdapter/util.test.ts +26 -0
- package/src/CramAdapter/util.ts +251 -0
- package/src/LinearAlignmentsDisplay/components/AlignmentsDisplay.tsx +3 -1
- package/src/LinearAlignmentsDisplay/models/model.tsx +8 -7
- package/src/LinearPileupDisplay/components/ColorByModifications.tsx +5 -34
- package/src/LinearPileupDisplay/components/ColorByTag.tsx +2 -29
- package/src/LinearPileupDisplay/components/FilterByTag.tsx +2 -22
- package/src/LinearPileupDisplay/components/SetFeatureHeight.tsx +2 -22
- package/src/LinearPileupDisplay/components/SetMaxHeight.tsx +2 -24
- package/src/LinearPileupDisplay/components/SortByTag.tsx +2 -31
- package/src/LinearPileupDisplay/configSchema.ts +3 -5
- package/src/LinearPileupDisplay/index.ts +5 -0
- package/src/LinearPileupDisplay/model.ts +31 -30
- package/src/LinearSNPCoverageDisplay/models/model.ts +12 -8
- package/src/PileupRPC/rpcMethods.ts +15 -20
- package/src/PileupRenderer/{PileupRenderer.tsx → PileupRenderer.ts} +48 -54
- package/src/PileupRenderer/configSchema.ts +1 -1
- package/src/PileupRenderer/index.ts +8 -9
- package/src/SNPCoverageAdapter/SNPCoverageAdapter.ts +5 -249
- package/src/SNPCoverageAdapter/configSchema.ts +14 -13
- package/src/SNPCoverageAdapter/generateCoverageBins.ts +245 -0
- package/src/SNPCoverageAdapter/index.ts +17 -18
- package/src/__snapshots__/index.test.ts.snap +1 -1
- package/src/index.ts +11 -4
|
@@ -32,15 +32,16 @@ const mui_1 = require("tss-react/mui");
|
|
|
32
32
|
const mobx_react_1 = require("mobx-react");
|
|
33
33
|
const util_1 = require("@jbrowse/core/util");
|
|
34
34
|
const copy_to_clipboard_1 = __importDefault(require("copy-to-clipboard"));
|
|
35
|
+
const clone_1 = __importDefault(require("clone"));
|
|
35
36
|
const BaseFeatureDetail_1 = require("@jbrowse/core/BaseFeatureWidget/BaseFeatureDetail");
|
|
36
37
|
const MismatchParser_1 = require("../BamAdapter/MismatchParser");
|
|
37
|
-
const useStyles = (0, mui_1.makeStyles)()(
|
|
38
|
+
const useStyles = (0, mui_1.makeStyles)()({
|
|
38
39
|
compact: {
|
|
39
40
|
paddingRight: 0,
|
|
40
41
|
paddingTop: 0,
|
|
41
42
|
paddingBottom: 0,
|
|
42
43
|
},
|
|
43
|
-
})
|
|
44
|
+
});
|
|
44
45
|
const omit = ['clipPos', 'flags'];
|
|
45
46
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
46
47
|
function AlignmentFlags(props) {
|
|
@@ -120,12 +121,12 @@ function SupplementaryAlignments(props) {
|
|
|
120
121
|
const displayEnd = end.toLocaleString('en-US');
|
|
121
122
|
const displayString = `${saRef}:${displayStart}-${displayEnd} (${saStrand})`;
|
|
122
123
|
return (react_1.default.createElement("li", { key: `${locString}-${index}` },
|
|
123
|
-
react_1.default.createElement(material_1.Link, { onClick: event => {
|
|
124
|
+
react_1.default.createElement(material_1.Link, { onClick: async (event) => {
|
|
124
125
|
event.preventDefault();
|
|
125
126
|
const { view } = model;
|
|
126
127
|
try {
|
|
127
128
|
if (view) {
|
|
128
|
-
view.navToLocString(locString);
|
|
129
|
+
await view.navToLocString(locString);
|
|
129
130
|
}
|
|
130
131
|
else {
|
|
131
132
|
throw new Error('No view associated with this view anymore');
|
|
@@ -141,15 +142,13 @@ function SupplementaryAlignments(props) {
|
|
|
141
142
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
142
143
|
function PairLink({ locString, model }) {
|
|
143
144
|
const session = (0, util_1.getSession)(model);
|
|
144
|
-
return (react_1.default.createElement(material_1.Link, { onClick: () => {
|
|
145
|
+
return (react_1.default.createElement(material_1.Link, { onClick: async () => {
|
|
145
146
|
const { view } = model;
|
|
147
|
+
if (!view) {
|
|
148
|
+
throw new Error('No view associated with this feature detail panel anymore');
|
|
149
|
+
}
|
|
146
150
|
try {
|
|
147
|
-
|
|
148
|
-
view.navToLocString(locString);
|
|
149
|
-
}
|
|
150
|
-
else {
|
|
151
|
-
session.notify('No view associated with this feature detail panel anymore', 'warning');
|
|
152
|
-
}
|
|
151
|
+
await view.navToLocString(locString);
|
|
153
152
|
}
|
|
154
153
|
catch (e) {
|
|
155
154
|
console.error(e);
|
|
@@ -160,14 +159,14 @@ function PairLink({ locString, model }) {
|
|
|
160
159
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
161
160
|
function AlignmentFeatureDetails(props) {
|
|
162
161
|
const { model } = props;
|
|
163
|
-
const feat =
|
|
162
|
+
const feat = (0, clone_1.default)(model.featureData);
|
|
164
163
|
const SA = (feat.tags && feat.tags.SA) || feat.SA;
|
|
165
164
|
return (react_1.default.createElement(material_1.Paper, { "data-testid": "alignment-side-drawer" },
|
|
166
165
|
react_1.default.createElement(BaseFeatureDetail_1.FeatureDetails, { ...props, omit: omit, feature: feat, formatter: (value, key) => {
|
|
167
166
|
return key === 'next_segment_position' ? (react_1.default.createElement(PairLink, { model: model, locString: value })) : (react_1.default.createElement(Formatter, { value: value }));
|
|
168
167
|
} }),
|
|
169
168
|
SA ? react_1.default.createElement(SupplementaryAlignments, { model: model, tag: SA }) : null,
|
|
170
|
-
react_1.default.createElement(AlignmentFlags, { feature: feat, ...props })));
|
|
169
|
+
feat.flags !== undefined ? (react_1.default.createElement(AlignmentFlags, { feature: feat, ...props })) : null));
|
|
171
170
|
}
|
|
172
171
|
exports.default = (0, mobx_react_1.observer)(AlignmentFeatureDetails);
|
|
173
172
|
//# sourceMappingURL=AlignmentsFeatureDetail.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AlignmentsFeatureDetail.js","sourceRoot":"","sources":["../../src/AlignmentsFeatureDetail/AlignmentsFeatureDetail.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAuC;AACvC,4CAOsB;AACtB,uCAA0C;AAC1C,2CAAqC;AACrC,6CAA+C;AAC/C,0EAAoC;AACpC,yFAI0D;AAC1D,iEAAyD;AAEzD,MAAM,SAAS,GAAG,IAAA,gBAAU,GAAE,CAAC
|
|
1
|
+
{"version":3,"file":"AlignmentsFeatureDetail.js","sourceRoot":"","sources":["../../src/AlignmentsFeatureDetail/AlignmentsFeatureDetail.tsx"],"names":[],"mappings":"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"}
|
|
@@ -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,6 +9,7 @@ const util_1 = require("@jbrowse/core/util");
|
|
|
9
9
|
const io_1 = require("@jbrowse/core/util/io");
|
|
10
10
|
const rxjs_1 = require("@jbrowse/core/util/rxjs");
|
|
11
11
|
const operators_1 = require("rxjs/operators");
|
|
12
|
+
// locals
|
|
12
13
|
const BamSlightlyLazyFeature_1 = __importDefault(require("./BamSlightlyLazyFeature"));
|
|
13
14
|
class BamAdapter extends BaseAdapter_1.BaseFeatureDataAdapter {
|
|
14
15
|
// derived classes may not use the same configuration so a custom
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BamAdapter.js","sourceRoot":"","sources":["../../src/BamAdapter/BamAdapter.ts"],"names":[],"mappings":";;;;;AAAA,mCAAmC;AACnC,yEAGgD;AAEhD,
|
|
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;
|
|
@@ -60,7 +60,7 @@ function cigarToMismatches(ops, seq, ref, qual) {
|
|
|
60
60
|
});
|
|
61
61
|
}
|
|
62
62
|
else if (op === 'X') {
|
|
63
|
-
const r = seq.slice(soffset, soffset + len);
|
|
63
|
+
const r = (seq === null || seq === void 0 ? void 0 : seq.slice(soffset, soffset + len)) || [];
|
|
64
64
|
const q = (qual === null || qual === void 0 ? void 0 : qual.slice(soffset, soffset + len)) || [];
|
|
65
65
|
for (let j = 0; j < len; j++) {
|
|
66
66
|
mismatches.push({
|
|
@@ -172,10 +172,7 @@ function mdToMismatches(mdstring, ops, cigarMismatches, seq, qual) {
|
|
|
172
172
|
}
|
|
173
173
|
const s = getTemplateCoordLocal(curr.start);
|
|
174
174
|
curr.base = seq[s] || 'X';
|
|
175
|
-
|
|
176
|
-
if (qualScore) {
|
|
177
|
-
curr.qual = qualScore;
|
|
178
|
-
}
|
|
175
|
+
curr.qual = qual === null || qual === void 0 ? void 0 : qual[s];
|
|
179
176
|
curr.altbase = token;
|
|
180
177
|
nextRecord();
|
|
181
178
|
}
|
|
@@ -192,7 +189,7 @@ function getMismatches(cigar, md, seq, ref, qual) {
|
|
|
192
189
|
mismatches = mismatches.concat(cigarToMismatches(ops, seq, ref, qual));
|
|
193
190
|
}
|
|
194
191
|
// now let's look for CRAM or MD mismatches
|
|
195
|
-
if (md) {
|
|
192
|
+
if (md && seq) {
|
|
196
193
|
mismatches = mismatches.concat(mdToMismatches(md, ops, mismatches, seq, qual));
|
|
197
194
|
}
|
|
198
195
|
return mismatches;
|
|
@@ -291,7 +288,7 @@ function getModificationTypes(mm) {
|
|
|
291
288
|
const [basemod] = mod.split(',');
|
|
292
289
|
const matches = basemod.match(modificationRegex);
|
|
293
290
|
if (!matches) {
|
|
294
|
-
throw new Error(
|
|
291
|
+
throw new Error(`bad format for MM tag: ${mm}`);
|
|
295
292
|
}
|
|
296
293
|
const [, , , typestr] = matches;
|
|
297
294
|
// 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,6CAA2C;AAW3C,MAAM,OAAO,GAAG,IAAI,MAAM,CAAC,wBAAwB,CAAC,CAAA;AACpD,MAAM,iBAAiB,GAAG,IAAI,MAAM,CAAC,+BAA+B,CAAC,CAAA;AACrE,SAAgB,UAAU,CAAC,KAAK,GAAG,EAAE;IACnC,OAAO,KAAK,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;AAClD,CAAC;AAFD,gCAEC;AACD,SAAgB,iBAAiB,CAC/B,GAAa,EACb,
|
|
1
|
+
{"version":3,"file":"MismatchParser.js","sourceRoot":"","sources":["../../src/BamAdapter/MismatchParser.ts"],"names":[],"mappings":"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"}
|
|
@@ -40,7 +40,7 @@ const configSchema = (0, configuration_1.ConfigurationSchema)('BamAdapter', {
|
|
|
40
40
|
*/
|
|
41
41
|
fetchSizeLimit: {
|
|
42
42
|
type: 'number',
|
|
43
|
-
description: '
|
|
43
|
+
description: 'size to fetch in bytes over which to display a warning to the user that too much data will be fetched',
|
|
44
44
|
defaultValue: 5000000,
|
|
45
45
|
},
|
|
46
46
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/BamAdapter/configSchema.ts"],"names":[],"mappings":";;AAAA,+DAAiE;AACjE,qDAAuC;AAEvC;;;GAGG;AACH,SAAS,CAAC,KAAI,CAAC,CAAC,wDAAwD;AAExE,MAAM,YAAY,GAAG,IAAA,mCAAmB,EACtC,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,IAAA,mCAAmB,EAAC,UAAU,EAAE;QACrC;;WAEG;QACH,SAAS,EAAE;YACT,KAAK,EAAE,uBAAK,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,
|
|
1
|
+
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/BamAdapter/configSchema.ts"],"names":[],"mappings":";;AAAA,+DAAiE;AACjE,qDAAuC;AAEvC;;;GAGG;AACH,SAAS,CAAC,KAAI,CAAC,CAAC,wDAAwD;AAExE,MAAM,YAAY,GAAG,IAAA,mCAAmB,EACtC,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,IAAA,mCAAmB,EAAC,UAAU,EAAE;QACrC;;WAEG;QACH,SAAS,EAAE;YACT,KAAK,EAAE,uBAAK,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,kBAAe,YAAY,CAAA"}
|
package/dist/BamAdapter/index.js
CHANGED
|
@@ -29,10 +29,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
29
29
|
const AdapterType_1 = __importDefault(require("@jbrowse/core/pluggableElementTypes/AdapterType"));
|
|
30
30
|
const configSchema_1 = __importDefault(require("./configSchema"));
|
|
31
31
|
exports.default = (pluginManager) => {
|
|
32
|
-
pluginManager.addAdapterType(() =>
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
32
|
+
pluginManager.addAdapterType(() => {
|
|
33
|
+
return new AdapterType_1.default({
|
|
34
|
+
name: 'BamAdapter',
|
|
35
|
+
configSchema: configSchema_1.default,
|
|
36
|
+
getAdapterClass: () => Promise.resolve().then(() => __importStar(require('./BamAdapter'))).then(r => r.default),
|
|
37
|
+
});
|
|
38
|
+
});
|
|
37
39
|
};
|
|
38
40
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/BamAdapter/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,kGAAyE;AACzE,kEAAyC;AAEzC,kBAAe,CAAC,aAA4B,EAAE,EAAE;IAC9C,aAAa,CAAC,cAAc,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/BamAdapter/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,kGAAyE;AACzE,kEAAyC;AAEzC,kBAAe,CAAC,aAA4B,EAAE,EAAE;IAC9C,aAAa,CAAC,cAAc,CAAC,GAAG,EAAE;QAChC,OAAO,IAAI,qBAAW,CAAC;YACrB,IAAI,EAAE,YAAY;YAClB,YAAY,EAAZ,sBAAY;YACZ,eAAe,EAAE,GAAG,EAAE,CAAC,kDAAO,cAAc,IAAE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;SACnE,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
|
@@ -1,16 +1,7 @@
|
|
|
1
1
|
import { Feature, SimpleFeatureSerialized } from '@jbrowse/core/util/simpleFeature';
|
|
2
2
|
import { CramRecord } from '@gmod/cram';
|
|
3
3
|
import CramAdapter from './CramAdapter';
|
|
4
|
-
|
|
5
|
-
qual?: number;
|
|
6
|
-
start: number;
|
|
7
|
-
length: number;
|
|
8
|
-
type: string;
|
|
9
|
-
base: string;
|
|
10
|
-
altbase?: string;
|
|
11
|
-
seq?: string;
|
|
12
|
-
cliplen?: number;
|
|
13
|
-
}
|
|
4
|
+
import { Mismatch } from './util';
|
|
14
5
|
export default class CramSlightlyLazyFeature implements Feature {
|
|
15
6
|
private record;
|
|
16
7
|
private _store;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const util_1 = require("./util");
|
|
3
4
|
class CramSlightlyLazyFeature {
|
|
4
5
|
// uses parameter properties to automatically create fields on the class
|
|
5
6
|
// https://www.typescriptlang.org/docs/handbook/classes.html#parameter-properties
|
|
@@ -81,123 +82,10 @@ class CramSlightlyLazyFeature {
|
|
|
81
82
|
}
|
|
82
83
|
// generate a CIGAR, based on code from jkbonfield
|
|
83
84
|
_get_CIGAR() {
|
|
84
|
-
|
|
85
|
-
let cigar = '';
|
|
86
|
-
let op = 'M';
|
|
87
|
-
let oplen = 0;
|
|
88
|
-
if (!this.record._refRegion) {
|
|
89
|
-
return '';
|
|
90
|
-
}
|
|
91
|
-
// not sure I should access these, but...
|
|
92
|
-
const ref = this.record._refRegion.seq;
|
|
93
|
-
const refStart = this.record._refRegion.start;
|
|
94
|
-
let last_pos = this.record.alignmentStart;
|
|
95
|
-
let sublen = 0;
|
|
96
|
-
if (typeof this.record.readFeatures !== 'undefined') {
|
|
97
|
-
let insLen = 0;
|
|
98
|
-
// @ts-ignore
|
|
99
|
-
for (let i = 0; i < this.record.readFeatures.length; i++) {
|
|
100
|
-
const { code, refPos, sub, data } = this.record.readFeatures[i];
|
|
101
|
-
sublen = refPos - last_pos;
|
|
102
|
-
seq += ref.substring(last_pos - refStart, refPos - refStart);
|
|
103
|
-
last_pos = refPos;
|
|
104
|
-
if (oplen && op !== 'M') {
|
|
105
|
-
cigar += oplen + op;
|
|
106
|
-
oplen = 0;
|
|
107
|
-
}
|
|
108
|
-
if (sublen) {
|
|
109
|
-
op = 'M';
|
|
110
|
-
oplen += sublen;
|
|
111
|
-
}
|
|
112
|
-
if (insLen > 0 && code !== 'i') {
|
|
113
|
-
cigar += `${insLen}I`;
|
|
114
|
-
insLen = 0;
|
|
115
|
-
}
|
|
116
|
-
if (code === 'b') {
|
|
117
|
-
// An array of bases stored verbatim
|
|
118
|
-
const ret = data.split(',');
|
|
119
|
-
const added = String.fromCharCode(...ret);
|
|
120
|
-
seq += added;
|
|
121
|
-
last_pos += added.length;
|
|
122
|
-
oplen += added.length;
|
|
123
|
-
}
|
|
124
|
-
else if (code === 'B') {
|
|
125
|
-
// Single base (+ qual score)
|
|
126
|
-
seq += sub;
|
|
127
|
-
last_pos++;
|
|
128
|
-
oplen++;
|
|
129
|
-
}
|
|
130
|
-
else if (code === 'X') {
|
|
131
|
-
// Substitution
|
|
132
|
-
seq += sub;
|
|
133
|
-
last_pos++;
|
|
134
|
-
oplen++;
|
|
135
|
-
}
|
|
136
|
-
else if (code === 'D' || code === 'N') {
|
|
137
|
-
// Deletion or Ref Skip
|
|
138
|
-
last_pos += data;
|
|
139
|
-
if (oplen) {
|
|
140
|
-
cigar += oplen + op;
|
|
141
|
-
}
|
|
142
|
-
cigar += data + code;
|
|
143
|
-
oplen = 0;
|
|
144
|
-
}
|
|
145
|
-
else if (code === 'I' || code === 'S') {
|
|
146
|
-
// Insertion or soft-clip
|
|
147
|
-
seq += data;
|
|
148
|
-
if (oplen) {
|
|
149
|
-
cigar += oplen + op;
|
|
150
|
-
}
|
|
151
|
-
cigar += data.length + code;
|
|
152
|
-
oplen = 0;
|
|
153
|
-
}
|
|
154
|
-
else if (code === 'i') {
|
|
155
|
-
// Single base insertion
|
|
156
|
-
// seq += data
|
|
157
|
-
if (oplen) {
|
|
158
|
-
cigar += oplen + op;
|
|
159
|
-
}
|
|
160
|
-
insLen++;
|
|
161
|
-
oplen = 0;
|
|
162
|
-
}
|
|
163
|
-
else if (code === 'P') {
|
|
164
|
-
// Padding
|
|
165
|
-
if (oplen) {
|
|
166
|
-
cigar += oplen + op;
|
|
167
|
-
}
|
|
168
|
-
cigar += `${data}P`;
|
|
169
|
-
}
|
|
170
|
-
else if (code === 'H') {
|
|
171
|
-
// Hard clip
|
|
172
|
-
if (oplen) {
|
|
173
|
-
cigar += oplen + op;
|
|
174
|
-
}
|
|
175
|
-
cigar += `${data}H`;
|
|
176
|
-
oplen = 0;
|
|
177
|
-
} // else q or Q
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
else {
|
|
181
|
-
sublen = this.record.readLength - seq.length;
|
|
182
|
-
}
|
|
183
|
-
if (seq.length !== this.record.readLength) {
|
|
184
|
-
sublen = this.record.readLength - seq.length;
|
|
185
|
-
seq += ref.substring(last_pos - refStart, last_pos - refStart + sublen);
|
|
186
|
-
if (oplen && op !== 'M') {
|
|
187
|
-
cigar += oplen + op;
|
|
188
|
-
oplen = 0;
|
|
189
|
-
}
|
|
190
|
-
op = 'M';
|
|
191
|
-
oplen += sublen;
|
|
192
|
-
}
|
|
193
|
-
if (oplen) {
|
|
194
|
-
cigar += oplen + op;
|
|
195
|
-
}
|
|
196
|
-
return cigar;
|
|
85
|
+
return (0, util_1.readFeaturesToCIGAR)(this.record.readFeatures, this.record.alignmentStart, this.record.readLength, this.record._refRegion);
|
|
197
86
|
}
|
|
198
87
|
tags() {
|
|
199
|
-
|
|
200
|
-
return properties
|
|
88
|
+
return Object.getOwnPropertyNames(CramSlightlyLazyFeature.prototype)
|
|
201
89
|
.filter(prop => prop.startsWith('_get_') &&
|
|
202
90
|
prop !== '_get_mismatches' &&
|
|
203
91
|
prop !== '_get_cram_read_features')
|
|
@@ -247,111 +135,10 @@ class CramSlightlyLazyFeature {
|
|
|
247
135
|
};
|
|
248
136
|
}
|
|
249
137
|
_get_mismatches() {
|
|
250
|
-
const readFeatures = this.
|
|
138
|
+
const readFeatures = this.record.readFeatures;
|
|
251
139
|
const qual = this.qualRaw();
|
|
252
|
-
if (!readFeatures) {
|
|
253
|
-
return [];
|
|
254
|
-
}
|
|
255
140
|
const start = this.get('start');
|
|
256
|
-
|
|
257
|
-
let j = 0;
|
|
258
|
-
let insLen = 0;
|
|
259
|
-
let refPos = 0;
|
|
260
|
-
for (let i = 0; i < readFeatures.length; i++) {
|
|
261
|
-
const f = readFeatures[i];
|
|
262
|
-
const { code, pos, data, sub, ref } = f;
|
|
263
|
-
if (insLen > 0 && code !== 'i') {
|
|
264
|
-
mismatches[j++] = {
|
|
265
|
-
start: refPos,
|
|
266
|
-
type: 'insertion',
|
|
267
|
-
base: `${insLen}`,
|
|
268
|
-
length: 0,
|
|
269
|
-
};
|
|
270
|
-
insLen = 0;
|
|
271
|
-
}
|
|
272
|
-
refPos = f.refPos - 1 - start;
|
|
273
|
-
if (code === 'X') {
|
|
274
|
-
// substitution
|
|
275
|
-
mismatches[j++] = {
|
|
276
|
-
start: refPos,
|
|
277
|
-
length: 1,
|
|
278
|
-
base: sub,
|
|
279
|
-
qual: qual === null || qual === void 0 ? void 0 : qual[pos],
|
|
280
|
-
altbase: ref,
|
|
281
|
-
type: 'mismatch',
|
|
282
|
-
};
|
|
283
|
-
}
|
|
284
|
-
else if (code === 'I') {
|
|
285
|
-
// insertion
|
|
286
|
-
mismatches[j++] = {
|
|
287
|
-
start: refPos,
|
|
288
|
-
type: 'insertion',
|
|
289
|
-
base: `${data.length}`,
|
|
290
|
-
length: 0,
|
|
291
|
-
};
|
|
292
|
-
}
|
|
293
|
-
else if (code === 'N') {
|
|
294
|
-
// reference skip
|
|
295
|
-
mismatches[j++] = {
|
|
296
|
-
type: 'skip',
|
|
297
|
-
length: data,
|
|
298
|
-
start: refPos,
|
|
299
|
-
base: 'N',
|
|
300
|
-
};
|
|
301
|
-
}
|
|
302
|
-
else if (code === 'S') {
|
|
303
|
-
// soft clip
|
|
304
|
-
const len = data.length;
|
|
305
|
-
mismatches[j++] = {
|
|
306
|
-
start: refPos,
|
|
307
|
-
type: 'softclip',
|
|
308
|
-
base: `S${len}`,
|
|
309
|
-
cliplen: len,
|
|
310
|
-
length: 1,
|
|
311
|
-
};
|
|
312
|
-
}
|
|
313
|
-
else if (code === 'P') {
|
|
314
|
-
// padding
|
|
315
|
-
}
|
|
316
|
-
else if (code === 'H') {
|
|
317
|
-
// hard clip
|
|
318
|
-
const len = data;
|
|
319
|
-
mismatches[j++] = {
|
|
320
|
-
start: refPos,
|
|
321
|
-
type: 'hardclip',
|
|
322
|
-
base: `H${len}`,
|
|
323
|
-
cliplen: len,
|
|
324
|
-
length: 1,
|
|
325
|
-
};
|
|
326
|
-
}
|
|
327
|
-
else if (code === 'D') {
|
|
328
|
-
// deletion
|
|
329
|
-
mismatches[j++] = {
|
|
330
|
-
type: 'deletion',
|
|
331
|
-
length: data,
|
|
332
|
-
start: refPos,
|
|
333
|
-
base: '*',
|
|
334
|
-
};
|
|
335
|
-
}
|
|
336
|
-
else if (code === 'b') {
|
|
337
|
-
// stretch of bases
|
|
338
|
-
}
|
|
339
|
-
else if (code === 'q') {
|
|
340
|
-
// stretch of qual scores
|
|
341
|
-
}
|
|
342
|
-
else if (code === 'B') {
|
|
343
|
-
// a pair of [base, qual]
|
|
344
|
-
}
|
|
345
|
-
else if (code === 'i') {
|
|
346
|
-
// single-base insertion
|
|
347
|
-
// insertion
|
|
348
|
-
insLen++;
|
|
349
|
-
}
|
|
350
|
-
else if (code === 'Q') {
|
|
351
|
-
// single quality value
|
|
352
|
-
}
|
|
353
|
-
}
|
|
354
|
-
return mismatches.slice(0, j);
|
|
141
|
+
return (0, util_1.readFeaturesToMismatches)(readFeatures, start, qual);
|
|
355
142
|
}
|
|
356
143
|
}
|
|
357
144
|
exports.default = CramSlightlyLazyFeature;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CramSlightlyLazyFeature.js","sourceRoot":"","sources":["../../src/CramAdapter/CramSlightlyLazyFeature.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"CramSlightlyLazyFeature.js","sourceRoot":"","sources":["../../src/CramAdapter/CramSlightlyLazyFeature.ts"],"names":[],"mappings":"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"}
|