@jbrowse/plugin-alignments 2.0.0 → 2.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (139) hide show
  1. package/dist/AlignmentsFeatureDetail/AlignmentsFeatureDetail.js +61 -90
  2. package/dist/AlignmentsFeatureDetail/AlignmentsFeatureDetail.js.map +1 -1
  3. package/dist/AlignmentsFeatureDetail/index.js +14 -16
  4. package/dist/AlignmentsFeatureDetail/index.js.map +1 -1
  5. package/dist/AlignmentsTrack/index.js +8 -8
  6. package/dist/AlignmentsTrack/index.js.map +1 -1
  7. package/dist/BamAdapter/BamAdapter.d.ts +6 -1
  8. package/dist/BamAdapter/BamAdapter.js +157 -336
  9. package/dist/BamAdapter/BamAdapter.js.map +1 -1
  10. package/dist/BamAdapter/BamSlightlyLazyFeature.js +68 -103
  11. package/dist/BamAdapter/BamSlightlyLazyFeature.js.map +1 -1
  12. package/dist/BamAdapter/MismatchParser.d.ts +1 -1
  13. package/dist/BamAdapter/MismatchParser.js +97 -162
  14. package/dist/BamAdapter/MismatchParser.js.map +1 -1
  15. package/dist/BamAdapter/configSchema.js +27 -29
  16. package/dist/BamAdapter/configSchema.js.map +1 -1
  17. package/dist/BamAdapter/index.js +9 -11
  18. package/dist/BamAdapter/index.js.map +1 -1
  19. package/dist/CramAdapter/CramAdapter.js +193 -351
  20. package/dist/CramAdapter/CramAdapter.js.map +1 -1
  21. package/dist/CramAdapter/CramSlightlyLazyFeature.js +119 -154
  22. package/dist/CramAdapter/CramSlightlyLazyFeature.js.map +1 -1
  23. package/dist/CramAdapter/CramTestAdapters.js +51 -148
  24. package/dist/CramAdapter/CramTestAdapters.js.map +1 -1
  25. package/dist/CramAdapter/configSchema.js +23 -25
  26. package/dist/CramAdapter/configSchema.js.map +1 -1
  27. package/dist/CramAdapter/index.js +9 -11
  28. package/dist/CramAdapter/index.js.map +1 -1
  29. package/dist/HtsgetBamAdapter/HtsgetBamAdapter.js +25 -87
  30. package/dist/HtsgetBamAdapter/HtsgetBamAdapter.js.map +1 -1
  31. package/dist/HtsgetBamAdapter/configSchema.js +16 -18
  32. package/dist/HtsgetBamAdapter/configSchema.js.map +1 -1
  33. package/dist/HtsgetBamAdapter/index.js +15 -19
  34. package/dist/HtsgetBamAdapter/index.js.map +1 -1
  35. package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.js +14 -15
  36. package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.js.map +1 -1
  37. package/dist/LinearAlignmentsDisplay/index.js +7 -7
  38. package/dist/LinearAlignmentsDisplay/index.js.map +1 -1
  39. package/dist/LinearAlignmentsDisplay/models/configSchema.js +5 -5
  40. package/dist/LinearAlignmentsDisplay/models/configSchema.js.map +1 -1
  41. package/dist/LinearAlignmentsDisplay/models/model.js +64 -140
  42. package/dist/LinearAlignmentsDisplay/models/model.js.map +1 -1
  43. package/dist/LinearPileupDisplay/components/ColorByModifications.js +24 -53
  44. package/dist/LinearPileupDisplay/components/ColorByModifications.js.map +1 -1
  45. package/dist/LinearPileupDisplay/components/ColorByTag.js +14 -30
  46. package/dist/LinearPileupDisplay/components/ColorByTag.js.map +1 -1
  47. package/dist/LinearPileupDisplay/components/FilterByTag.js +33 -49
  48. package/dist/LinearPileupDisplay/components/FilterByTag.js.map +1 -1
  49. package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js +7 -7
  50. package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js.map +1 -1
  51. package/dist/LinearPileupDisplay/components/SetFeatureHeight.js +17 -33
  52. package/dist/LinearPileupDisplay/components/SetFeatureHeight.js.map +1 -1
  53. package/dist/LinearPileupDisplay/components/SetMaxHeight.js +14 -30
  54. package/dist/LinearPileupDisplay/components/SetMaxHeight.js.map +1 -1
  55. package/dist/LinearPileupDisplay/components/SortByTag.js +14 -30
  56. package/dist/LinearPileupDisplay/components/SortByTag.js.map +1 -1
  57. package/dist/LinearPileupDisplay/configSchema.js +4 -4
  58. package/dist/LinearPileupDisplay/configSchema.js.map +1 -1
  59. package/dist/LinearPileupDisplay/index.js +7 -7
  60. package/dist/LinearPileupDisplay/index.js.map +1 -1
  61. package/dist/LinearPileupDisplay/model.js +534 -645
  62. package/dist/LinearPileupDisplay/model.js.map +1 -1
  63. package/dist/LinearSNPCoverageDisplay/components/Tooltip.d.ts +5 -2
  64. package/dist/LinearSNPCoverageDisplay/components/Tooltip.js +30 -79
  65. package/dist/LinearSNPCoverageDisplay/components/Tooltip.js.map +1 -1
  66. package/dist/LinearSNPCoverageDisplay/index.js +7 -7
  67. package/dist/LinearSNPCoverageDisplay/index.js.map +1 -1
  68. package/dist/LinearSNPCoverageDisplay/models/configSchema.js +4 -4
  69. package/dist/LinearSNPCoverageDisplay/models/configSchema.js.map +1 -1
  70. package/dist/LinearSNPCoverageDisplay/models/model.d.ts +27 -5
  71. package/dist/LinearSNPCoverageDisplay/models/model.js +171 -244
  72. package/dist/LinearSNPCoverageDisplay/models/model.js.map +1 -1
  73. package/dist/NestedFrequencyTable.js +27 -40
  74. package/dist/NestedFrequencyTable.js.map +1 -1
  75. package/dist/PileupRPC/rpcMethods.js +63 -191
  76. package/dist/PileupRPC/rpcMethods.js.map +1 -1
  77. package/dist/PileupRenderer/PileupLayoutSession.js +25 -47
  78. package/dist/PileupRenderer/PileupLayoutSession.js.map +1 -1
  79. package/dist/PileupRenderer/PileupRenderer.d.ts +0 -4
  80. package/dist/PileupRenderer/PileupRenderer.js +395 -529
  81. package/dist/PileupRenderer/PileupRenderer.js.map +1 -1
  82. package/dist/PileupRenderer/components/PileupRendering.js +41 -68
  83. package/dist/PileupRenderer/components/PileupRendering.js.map +1 -1
  84. package/dist/PileupRenderer/configSchema.js +2 -2
  85. package/dist/PileupRenderer/configSchema.js.map +1 -1
  86. package/dist/PileupRenderer/index.js +9 -11
  87. package/dist/PileupRenderer/index.js.map +1 -1
  88. package/dist/PileupRenderer/sortUtil.js +36 -40
  89. package/dist/PileupRenderer/sortUtil.js.map +1 -1
  90. package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js +229 -414
  91. package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js.map +1 -1
  92. package/dist/SNPCoverageAdapter/configSchema.js +5 -9
  93. package/dist/SNPCoverageAdapter/configSchema.js.map +1 -1
  94. package/dist/SNPCoverageAdapter/index.js +17 -21
  95. package/dist/SNPCoverageAdapter/index.js.map +1 -1
  96. package/dist/SNPCoverageRenderer/SNPCoverageRenderer.d.ts +1 -1
  97. package/dist/SNPCoverageRenderer/SNPCoverageRenderer.js +175 -259
  98. package/dist/SNPCoverageRenderer/SNPCoverageRenderer.js.map +1 -1
  99. package/dist/SNPCoverageRenderer/configSchema.js +1 -1
  100. package/dist/SNPCoverageRenderer/configSchema.js.map +1 -1
  101. package/dist/SNPCoverageRenderer/index.js +10 -12
  102. package/dist/SNPCoverageRenderer/index.js.map +1 -1
  103. package/dist/index.js +40 -58
  104. package/dist/index.js.map +1 -1
  105. package/dist/shared.js +23 -78
  106. package/dist/shared.js.map +1 -1
  107. package/dist/util.js +13 -66
  108. package/dist/util.js.map +1 -1
  109. package/esm/BamAdapter/BamAdapter.d.ts +6 -1
  110. package/esm/BamAdapter/BamAdapter.js.map +1 -1
  111. package/esm/BamAdapter/MismatchParser.d.ts +1 -1
  112. package/esm/BamAdapter/MismatchParser.js +2 -2
  113. package/esm/BamAdapter/MismatchParser.js.map +1 -1
  114. package/esm/LinearPileupDisplay/model.js +0 -1
  115. package/esm/LinearPileupDisplay/model.js.map +1 -1
  116. package/esm/LinearSNPCoverageDisplay/components/Tooltip.d.ts +4 -1
  117. package/esm/LinearSNPCoverageDisplay/components/Tooltip.js +0 -1
  118. package/esm/LinearSNPCoverageDisplay/components/Tooltip.js.map +1 -1
  119. package/esm/LinearSNPCoverageDisplay/models/model.d.ts +27 -5
  120. package/esm/LinearSNPCoverageDisplay/models/model.js +1 -0
  121. package/esm/LinearSNPCoverageDisplay/models/model.js.map +1 -1
  122. package/esm/PileupRenderer/PileupRenderer.d.ts +0 -4
  123. package/esm/PileupRenderer/PileupRenderer.js +1 -3
  124. package/esm/PileupRenderer/PileupRenderer.js.map +1 -1
  125. package/esm/SNPCoverageAdapter/SNPCoverageAdapter.js +4 -3
  126. package/esm/SNPCoverageAdapter/SNPCoverageAdapter.js.map +1 -1
  127. package/esm/SNPCoverageRenderer/SNPCoverageRenderer.d.ts +1 -1
  128. package/esm/SNPCoverageRenderer/SNPCoverageRenderer.js +0 -1
  129. package/esm/SNPCoverageRenderer/SNPCoverageRenderer.js.map +1 -1
  130. package/package.json +6 -7
  131. package/src/AlignmentsFeatureDetail/__snapshots__/index.test.js.snap +12 -12
  132. package/src/BamAdapter/BamAdapter.ts +1 -1
  133. package/src/BamAdapter/MismatchParser.ts +2 -2
  134. package/src/LinearPileupDisplay/model.ts +2 -2
  135. package/src/LinearSNPCoverageDisplay/components/Tooltip.tsx +3 -4
  136. package/src/LinearSNPCoverageDisplay/models/model.ts +3 -1
  137. package/src/PileupRenderer/PileupRenderer.tsx +13 -19
  138. package/src/SNPCoverageAdapter/SNPCoverageAdapter.ts +4 -3
  139. package/src/SNPCoverageRenderer/SNPCoverageRenderer.ts +1 -3
@@ -1,93 +1,15 @@
1
1
  "use strict";
2
- var __extends = (this && this.__extends) || (function () {
3
- var extendStatics = function (d, b) {
4
- extendStatics = Object.setPrototypeOf ||
5
- ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
- function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
- return extendStatics(d, b);
8
- };
9
- return function (d, b) {
10
- if (typeof b !== "function" && b !== null)
11
- throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
- extendStatics(d, b);
13
- function __() { this.constructor = d; }
14
- d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
- };
16
- })();
17
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
18
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
19
- return new (P || (P = Promise))(function (resolve, reject) {
20
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
21
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
22
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
23
- step((generator = generator.apply(thisArg, _arguments || [])).next());
24
- });
25
- };
26
- var __generator = (this && this.__generator) || function (thisArg, body) {
27
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
28
- return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
29
- function verb(n) { return function (v) { return step([n, v]); }; }
30
- function step(op) {
31
- if (f) throw new TypeError("Generator is already executing.");
32
- while (_) try {
33
- if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
34
- if (y = 0, t) op = [op[0] & 2, t.value];
35
- switch (op[0]) {
36
- case 0: case 1: t = op; break;
37
- case 4: _.label++; return { value: op[1], done: false };
38
- case 5: _.label++; y = op[1]; op = [0]; continue;
39
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
40
- default:
41
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
42
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
43
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
44
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
45
- if (t[2]) _.ops.pop();
46
- _.trys.pop(); continue;
47
- }
48
- op = body.call(thisArg, _);
49
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
50
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
51
- }
52
- };
53
- var __read = (this && this.__read) || function (o, n) {
54
- var m = typeof Symbol === "function" && o[Symbol.iterator];
55
- if (!m) return o;
56
- var i = m.call(o), r, ar = [], e;
57
- try {
58
- while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
59
- }
60
- catch (error) { e = { error: error }; }
61
- finally {
62
- try {
63
- if (r && !r.done && (m = i["return"])) m.call(i);
64
- }
65
- finally { if (e) throw e.error; }
66
- }
67
- return ar;
68
- };
69
- var __values = (this && this.__values) || function(o) {
70
- var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
71
- if (m) return m.call(o);
72
- if (o && typeof o.length === "number") return {
73
- next: function () {
74
- if (o && i >= o.length) o = void 0;
75
- return { value: o && o[i++], done: !o };
76
- }
77
- };
78
- throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
79
- };
80
2
  var __importDefault = (this && this.__importDefault) || function (mod) {
81
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
82
4
  };
83
5
  Object.defineProperty(exports, "__esModule", { value: true });
84
6
  exports.capabilities = void 0;
85
- var BaseAdapter_1 = require("@jbrowse/core/data_adapters/BaseAdapter");
86
- var simpleFeature_1 = __importDefault(require("@jbrowse/core/util/simpleFeature"));
87
- var rxjs_1 = require("@jbrowse/core/util/rxjs");
88
- var operators_1 = require("rxjs/operators");
89
- var util_1 = require("../util");
90
- var MismatchParser_1 = require("../BamAdapter/MismatchParser");
7
+ const BaseAdapter_1 = require("@jbrowse/core/data_adapters/BaseAdapter");
8
+ const simpleFeature_1 = __importDefault(require("@jbrowse/core/util/simpleFeature"));
9
+ const rxjs_1 = require("@jbrowse/core/util/rxjs");
10
+ const operators_1 = require("rxjs/operators");
11
+ const util_1 = require("../util");
12
+ const MismatchParser_1 = require("../BamAdapter/MismatchParser");
91
13
  function mismatchLen(mismatch) {
92
14
  return !isInterbase(mismatch.type) ? mismatch.length : 1;
93
15
  }
@@ -96,7 +18,7 @@ function isInterbase(type) {
96
18
  }
97
19
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
98
20
  function inc(bin, strand, type, field) {
99
- var thisBin = bin[type][field];
21
+ let thisBin = bin[type][field];
100
22
  if (thisBin === undefined) {
101
23
  thisBin = bin[type][field] = {
102
24
  total: 0,
@@ -108,345 +30,238 @@ function inc(bin, strand, type, field) {
108
30
  thisBin.total++;
109
31
  thisBin[strand]++;
110
32
  }
111
- var SNPCoverageAdapter = /** @class */ (function (_super) {
112
- __extends(SNPCoverageAdapter, _super);
113
- function SNPCoverageAdapter() {
114
- return _super !== null && _super.apply(this, arguments) || this;
115
- }
116
- SNPCoverageAdapter.prototype.configure = function () {
33
+ class SNPCoverageAdapter extends BaseAdapter_1.BaseFeatureDataAdapter {
34
+ async configure() {
117
35
  var _a, _b;
118
- return __awaiter(this, void 0, void 0, function () {
119
- var subadapterConfig, sequenceConf, dataAdapter, sequenceAdapter, _c;
120
- return __generator(this, function (_d) {
121
- switch (_d.label) {
122
- case 0:
123
- subadapterConfig = this.getConf('subadapter');
124
- sequenceConf = this.getConf(['subadapter', 'sequenceAdapter']);
125
- return [4 /*yield*/, ((_a = this.getSubAdapter) === null || _a === void 0 ? void 0 : _a.call(this, subadapterConfig))];
126
- case 1:
127
- dataAdapter = _d.sent();
128
- if (!sequenceConf) return [3 /*break*/, 3];
129
- return [4 /*yield*/, ((_b = this.getSubAdapter) === null || _b === void 0 ? void 0 : _b.call(this, sequenceConf))];
130
- case 2:
131
- _c = _d.sent();
132
- return [3 /*break*/, 4];
133
- case 3:
134
- _c = undefined;
135
- _d.label = 4;
136
- case 4:
137
- sequenceAdapter = _c;
138
- if (!dataAdapter) {
139
- throw new Error('Failed to get subadapter');
140
- }
141
- return [2 /*return*/, {
142
- subadapter: dataAdapter.dataAdapter,
143
- sequenceAdapter: sequenceAdapter === null || sequenceAdapter === void 0 ? void 0 : sequenceAdapter.dataAdapter,
144
- }];
145
- }
146
- });
147
- });
148
- };
149
- SNPCoverageAdapter.prototype.fetchSequence = function (region) {
150
- return __awaiter(this, void 0, void 0, function () {
151
- var sequenceAdapter;
152
- return __generator(this, function (_a) {
153
- switch (_a.label) {
154
- case 0: return [4 /*yield*/, this.configure()];
155
- case 1:
156
- sequenceAdapter = (_a.sent()).sequenceAdapter;
157
- if (!sequenceAdapter) {
158
- return [2 /*return*/, undefined];
159
- }
160
- return [2 /*return*/, (0, util_1.fetchSequence)(region, sequenceAdapter)];
161
- }
162
- });
163
- });
164
- };
165
- SNPCoverageAdapter.prototype.getFeatures = function (region, opts) {
166
- var _this = this;
167
- if (opts === void 0) { opts = {}; }
168
- return (0, rxjs_1.ObservableCreate)(function (observer) { return __awaiter(_this, void 0, void 0, function () {
169
- var subadapter, feats, _a, bins, skipmap;
170
- var _this = this;
171
- return __generator(this, function (_b) {
172
- switch (_b.label) {
173
- case 0: return [4 /*yield*/, this.configure()];
174
- case 1:
175
- subadapter = (_b.sent()).subadapter;
176
- return [4 /*yield*/, subadapter
177
- .getFeatures(region, opts)
178
- .pipe((0, operators_1.toArray)())
179
- .toPromise()];
180
- case 2:
181
- feats = _b.sent();
182
- return [4 /*yield*/, this.generateCoverageBins(feats, region, opts)];
183
- case 3:
184
- _a = _b.sent(), bins = _a.bins, skipmap = _a.skipmap;
185
- bins.forEach(function (bin, index) {
186
- observer.next(new simpleFeature_1.default({
187
- id: "".concat(_this.id, "-").concat(region.start + index),
188
- data: {
189
- score: bin.total,
190
- snpinfo: bin,
191
- start: region.start + index,
192
- end: region.start + index + 1,
193
- refName: region.refName,
194
- },
195
- }));
196
- });
197
- // make fake features from the coverage
198
- Object.entries(skipmap).forEach(function (_a) {
199
- var _b = __read(_a, 2), key = _b[0], skip = _b[1];
200
- observer.next(new simpleFeature_1.default({
201
- id: key,
202
- data: {
203
- type: 'skip',
204
- start: skip.start,
205
- end: skip.end,
206
- strand: skip.strand,
207
- score: skip.score,
208
- xs: skip.xs,
209
- },
210
- }));
211
- });
212
- observer.complete();
213
- return [2 /*return*/];
214
- }
215
- });
216
- }); }, opts.signal);
217
- };
218
- SNPCoverageAdapter.prototype.estimateRegionsStats = function (regions, opts) {
219
- return __awaiter(this, void 0, void 0, function () {
220
- var subadapter;
221
- return __generator(this, function (_a) {
222
- switch (_a.label) {
223
- case 0: return [4 /*yield*/, this.configure()];
224
- case 1:
225
- subadapter = (_a.sent()).subadapter;
226
- return [2 /*return*/, subadapter.estimateRegionsStats(regions, opts)];
227
- }
36
+ const subadapterConfig = this.getConf('subadapter');
37
+ const sequenceConf = this.getConf(['subadapter', 'sequenceAdapter']);
38
+ const dataAdapter = await ((_a = this.getSubAdapter) === null || _a === void 0 ? void 0 : _a.call(this, subadapterConfig));
39
+ const sequenceAdapter = sequenceConf
40
+ ? await ((_b = this.getSubAdapter) === null || _b === void 0 ? void 0 : _b.call(this, sequenceConf))
41
+ : undefined;
42
+ if (!dataAdapter) {
43
+ throw new Error('Failed to get subadapter');
44
+ }
45
+ return {
46
+ subadapter: dataAdapter.dataAdapter,
47
+ sequenceAdapter: sequenceAdapter === null || sequenceAdapter === void 0 ? void 0 : sequenceAdapter.dataAdapter,
48
+ };
49
+ }
50
+ async fetchSequence(region) {
51
+ const { sequenceAdapter } = await this.configure();
52
+ if (!sequenceAdapter) {
53
+ return undefined;
54
+ }
55
+ return (0, util_1.fetchSequence)(region, sequenceAdapter);
56
+ }
57
+ getFeatures(region, opts = {}) {
58
+ return (0, rxjs_1.ObservableCreate)(async (observer) => {
59
+ const { subadapter } = await this.configure();
60
+ const feats = await subadapter
61
+ .getFeatures(region, opts)
62
+ .pipe((0, operators_1.toArray)())
63
+ .toPromise();
64
+ const { bins, skipmap } = await this.generateCoverageBins(feats, region, opts);
65
+ bins.forEach((bin, index) => {
66
+ const start = region.start + index;
67
+ observer.next(new simpleFeature_1.default({
68
+ id: `${this.id}-${start}`,
69
+ data: {
70
+ score: bin.total,
71
+ snpinfo: bin,
72
+ start,
73
+ end: start + 1,
74
+ refName: region.refName,
75
+ },
76
+ }));
228
77
  });
229
- });
230
- };
231
- SNPCoverageAdapter.prototype.getRefNames = function (opts) {
232
- if (opts === void 0) { opts = {}; }
233
- return __awaiter(this, void 0, void 0, function () {
234
- var subadapter;
235
- return __generator(this, function (_a) {
236
- switch (_a.label) {
237
- case 0: return [4 /*yield*/, this.configure()];
238
- case 1:
239
- subadapter = (_a.sent()).subadapter;
240
- return [2 /*return*/, subadapter.getRefNames(opts)];
241
- }
78
+ // make fake features from the coverage
79
+ Object.entries(skipmap).forEach(([key, skip]) => {
80
+ observer.next(new simpleFeature_1.default({
81
+ id: key,
82
+ data: {
83
+ type: 'skip',
84
+ start: skip.start,
85
+ end: skip.end,
86
+ strand: skip.strand,
87
+ score: skip.score,
88
+ xs: skip.xs,
89
+ },
90
+ }));
242
91
  });
243
- });
244
- };
245
- SNPCoverageAdapter.prototype.freeResources = function ( /* { region } */) { };
246
- SNPCoverageAdapter.prototype.generateCoverageBins = function (features, region, opts) {
92
+ observer.complete();
93
+ }, opts.signal);
94
+ }
95
+ async estimateRegionsStats(regions, opts) {
96
+ const { subadapter } = await this.configure();
97
+ return subadapter.estimateRegionsStats(regions, opts);
98
+ }
99
+ async getRefNames(opts = {}) {
100
+ const { subadapter } = await this.configure();
101
+ return subadapter.getRefNames(opts);
102
+ }
103
+ freeResources( /* { region } */) { }
104
+ async generateCoverageBins(features, region, opts) {
247
105
  var _a;
248
- return __awaiter(this, void 0, void 0, function () {
249
- var colorBy, binMax, skipmap, regionSeq, _b, bins, _loop_1, i;
250
- return __generator(this, function (_c) {
251
- switch (_c.label) {
252
- case 0:
253
- colorBy = opts.colorBy;
254
- binMax = Math.ceil(region.end - region.start);
255
- skipmap = {};
256
- if (!(features.length && (0, util_1.shouldFetchReferenceSequence)((_a = opts.colorBy) === null || _a === void 0 ? void 0 : _a.type))) return [3 /*break*/, 2];
257
- return [4 /*yield*/, this.fetchSequence(region)];
258
- case 1:
259
- _b = _c.sent();
260
- return [3 /*break*/, 3];
261
- case 2:
262
- _b = undefined;
263
- _c.label = 3;
264
- case 3:
265
- regionSeq = _b;
266
- bins = [];
267
- _loop_1 = function (i) {
268
- var feature = features[i];
269
- var fstart = feature.get('start');
270
- var fend = feature.get('end');
271
- var fstrand = feature.get('strand');
272
- for (var j = fstart; j < fend + 1; j++) {
273
- var i_1 = j - region.start;
274
- if (i_1 >= 0 && i_1 < binMax) {
275
- if (bins[i_1] === undefined) {
276
- bins[i_1] = {
277
- total: 0,
278
- all: 0,
279
- ref: 0,
280
- '-1': 0,
281
- '0': 0,
282
- '1': 0,
283
- lowqual: {},
284
- cov: {},
285
- delskips: {},
286
- noncov: {},
287
- };
288
- }
289
- if (j !== fend) {
290
- bins[i_1].total++;
291
- bins[i_1].all++;
292
- bins[i_1].ref++;
293
- bins[i_1][fstrand]++;
294
- }
295
- }
106
+ const { colorBy } = opts;
107
+ const binMax = Math.ceil(region.end - region.start);
108
+ const skipmap = {};
109
+ const regionSeq = features.length && (0, util_1.shouldFetchReferenceSequence)((_a = opts.colorBy) === null || _a === void 0 ? void 0 : _a.type)
110
+ ? await this.fetchSequence(region)
111
+ : undefined;
112
+ const bins = [];
113
+ for (let i = 0; i < features.length; i++) {
114
+ const feature = features[i];
115
+ const fstart = feature.get('start');
116
+ const fend = feature.get('end');
117
+ const fstrand = feature.get('strand');
118
+ for (let j = fstart; j < fend + 1; j++) {
119
+ const i = j - region.start;
120
+ if (i >= 0 && i < binMax) {
121
+ if (bins[i] === undefined) {
122
+ bins[i] = {
123
+ total: 0,
124
+ all: 0,
125
+ ref: 0,
126
+ '-1': 0,
127
+ '0': 0,
128
+ '1': 0,
129
+ lowqual: {},
130
+ cov: {},
131
+ delskips: {},
132
+ noncov: {},
133
+ };
134
+ }
135
+ if (j !== fend) {
136
+ bins[i].total++;
137
+ bins[i].all++;
138
+ bins[i].ref++;
139
+ bins[i][fstrand]++;
140
+ }
141
+ }
142
+ }
143
+ if ((colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) === 'modifications') {
144
+ const seq = feature.get('seq');
145
+ const mm = (0, util_1.getTagAlt)(feature, 'MM', 'Mm') || '';
146
+ const ops = (0, MismatchParser_1.parseCigar)(feature.get('CIGAR'));
147
+ const fend = feature.get('end');
148
+ (0, MismatchParser_1.getModificationPositions)(mm, seq, fstrand).forEach(({ type, positions }) => {
149
+ const mod = `mod_${type}`;
150
+ for (const pos of (0, MismatchParser_1.getNextRefPos)(ops, positions)) {
151
+ const epos = pos + fstart - region.start;
152
+ if (epos >= 0 && epos < bins.length && pos + fstart < fend) {
153
+ const bin = bins[epos];
154
+ if (bin) {
155
+ inc(bin, fstrand, 'cov', mod);
296
156
  }
297
- if ((colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) === 'modifications') {
298
- var seq = feature.get('seq');
299
- var mm = (0, util_1.getTagAlt)(feature, 'MM', 'Mm') || '';
300
- var ops_1 = (0, MismatchParser_1.parseCigar)(feature.get('CIGAR'));
301
- var fend_1 = feature.get('end');
302
- (0, MismatchParser_1.getModificationPositions)(mm, seq, fstrand).forEach(function (_a) {
303
- var e_1, _b;
304
- var type = _a.type, positions = _a.positions;
305
- var mod = "mod_".concat(type);
306
- try {
307
- for (var _c = (e_1 = void 0, __values((0, MismatchParser_1.getNextRefPos)(ops_1, positions))), _d = _c.next(); !_d.done; _d = _c.next()) {
308
- var pos = _d.value;
309
- var epos = pos + fstart - region.start;
310
- if (epos >= 0 && epos < bins.length && pos + fstart < fend_1) {
311
- var bin = bins[epos];
312
- if (bin) {
313
- inc(bin, fstrand, 'cov', mod);
314
- }
315
- else {
316
- console.warn('Undefined position in modifications snpcoverage encountered');
317
- }
318
- }
319
- }
320
- }
321
- catch (e_1_1) { e_1 = { error: e_1_1 }; }
322
- finally {
323
- try {
324
- if (_d && !_d.done && (_b = _c.return)) _b.call(_c);
325
- }
326
- finally { if (e_1) throw e_1.error; }
327
- }
328
- });
157
+ else {
158
+ console.warn('Undefined position in modifications snpcoverage encountered');
329
159
  }
330
- // methylation based coloring takes into account both reference
331
- // sequence CpG detection and reads
332
- else if ((colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) === 'methylation') {
333
- if (!regionSeq) {
334
- throw new Error('no region sequence detected, need sequenceAdapter configuration');
335
- }
336
- var seq = feature.get('seq');
337
- var mm = (0, util_1.getTagAlt)(feature, 'MM', 'Mm') || '';
338
- var methBins_1 = new Array(region.end - region.start).fill(0);
339
- var ops_2 = (0, MismatchParser_1.parseCigar)(feature.get('CIGAR'));
340
- (0, MismatchParser_1.getModificationPositions)(mm, seq, fstrand).forEach(function (_a) {
341
- var e_2, _b;
342
- var type = _a.type, positions = _a.positions;
343
- // we are processing methylation
344
- if (type === 'm') {
345
- try {
346
- for (var _c = (e_2 = void 0, __values((0, MismatchParser_1.getNextRefPos)(ops_2, positions))), _d = _c.next(); !_d.done; _d = _c.next()) {
347
- var pos = _d.value;
348
- var epos = pos + fstart - region.start;
349
- if (epos >= 0 && epos < methBins_1.length) {
350
- methBins_1[epos] = 1;
351
- }
352
- }
353
- }
354
- catch (e_2_1) { e_2 = { error: e_2_1 }; }
355
- finally {
356
- try {
357
- if (_d && !_d.done && (_b = _c.return)) _b.call(_c);
358
- }
359
- finally { if (e_2) throw e_2.error; }
360
- }
361
- }
362
- });
363
- for (var j = fstart; j < fend; j++) {
364
- var i_2 = j - region.start;
365
- if (i_2 >= 0 && i_2 < bins.length - 1) {
366
- var l1 = regionSeq[i_2].toLowerCase();
367
- var l2 = regionSeq[i_2 + 1].toLowerCase();
368
- var bin = bins[i_2];
369
- var bin1 = bins[i_2 + 1];
370
- // color
371
- if (l1 === 'c' && l2 === 'g') {
372
- if (methBins_1[i_2] || methBins_1[i_2 + 1]) {
373
- inc(bin, fstrand, 'cov', 'meth');
374
- inc(bin1, fstrand, 'cov', 'meth');
375
- bins[i_2].ref--;
376
- bins[i_2][fstrand]--;
377
- bins[i_2 + 1].ref--;
378
- bins[i_2 + 1][fstrand]--;
379
- }
380
- else {
381
- inc(bin, fstrand, 'cov', 'unmeth');
382
- inc(bin1, fstrand, 'cov', 'unmeth');
383
- bins[i_2].ref--;
384
- bins[i_2][fstrand]--;
385
- bins[i_2 + 1].ref--;
386
- bins[i_2 + 1][fstrand]--;
387
- }
388
- }
389
- }
390
- }
160
+ }
161
+ }
162
+ });
163
+ }
164
+ // methylation based coloring takes into account both reference
165
+ // sequence CpG detection and reads
166
+ else if ((colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) === 'methylation') {
167
+ if (!regionSeq) {
168
+ throw new Error('no region sequence detected, need sequenceAdapter configuration');
169
+ }
170
+ const seq = feature.get('seq');
171
+ const mm = (0, util_1.getTagAlt)(feature, 'MM', 'Mm') || '';
172
+ const methBins = new Array(region.end - region.start).fill(0);
173
+ const ops = (0, MismatchParser_1.parseCigar)(feature.get('CIGAR'));
174
+ (0, MismatchParser_1.getModificationPositions)(mm, seq, fstrand).forEach(({ type, positions }) => {
175
+ // we are processing methylation
176
+ if (type === 'm') {
177
+ for (const pos of (0, MismatchParser_1.getNextRefPos)(ops, positions)) {
178
+ const epos = pos + fstart - region.start;
179
+ if (epos >= 0 && epos < methBins.length) {
180
+ methBins[epos] = 1;
181
+ }
182
+ }
183
+ }
184
+ });
185
+ for (let j = fstart; j < fend; j++) {
186
+ const i = j - region.start;
187
+ if (i >= 0 && i < bins.length - 1) {
188
+ const l1 = regionSeq[i].toLowerCase();
189
+ const l2 = regionSeq[i + 1].toLowerCase();
190
+ const bin = bins[i];
191
+ const bin1 = bins[i + 1];
192
+ // color
193
+ if (l1 === 'c' && l2 === 'g') {
194
+ if (methBins[i] || methBins[i + 1]) {
195
+ inc(bin, fstrand, 'cov', 'meth');
196
+ inc(bin1, fstrand, 'cov', 'meth');
197
+ bins[i].ref--;
198
+ bins[i][fstrand]--;
199
+ bins[i + 1].ref--;
200
+ bins[i + 1][fstrand]--;
391
201
  }
392
- // normal SNP based coloring
393
- var mismatches = feature.get('mismatches') || [];
394
- var colorSNPs = (colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) !== 'modifications' && (colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) !== 'methylation';
395
- for (var i_3 = 0; i_3 < mismatches.length; i_3++) {
396
- var mismatch = mismatches[i_3];
397
- var mstart = fstart + mismatch.start;
398
- var mlen = mismatchLen(mismatch);
399
- var mend = mstart + mlen;
400
- for (var j = mstart; j < mstart + mlen; j++) {
401
- var epos = j - region.start;
402
- if (epos >= 0 && epos < bins.length) {
403
- var bin = bins[epos];
404
- var base = mismatch.base, type = mismatch.type;
405
- var interbase = isInterbase(type);
406
- if (!interbase) {
407
- bin.ref--;
408
- bin[fstrand]--;
409
- }
410
- else {
411
- inc(bin, fstrand, 'noncov', type);
412
- }
413
- if (type === 'deletion' || type === 'skip') {
414
- inc(bin, fstrand, 'delskips', type);
415
- bin.total--;
416
- }
417
- else if (!interbase && colorSNPs) {
418
- inc(bin, fstrand, 'cov', base);
419
- bin.refbase = mismatch.altbase;
420
- }
421
- }
422
- }
423
- if (mismatch.type === 'skip') {
424
- var hash = "".concat(mstart, "_").concat(mend, "_").concat(fstrand);
425
- if (skipmap[hash] === undefined) {
426
- skipmap[hash] = {
427
- feature: feature,
428
- start: mstart,
429
- end: mend,
430
- strand: fstrand,
431
- xs: (0, util_1.getTag)(feature, 'XS') || (0, util_1.getTag)(feature, 'TS'),
432
- score: 0,
433
- };
434
- }
435
- skipmap[hash].score++;
436
- }
202
+ else {
203
+ inc(bin, fstrand, 'cov', 'unmeth');
204
+ inc(bin1, fstrand, 'cov', 'unmeth');
205
+ bins[i].ref--;
206
+ bins[i][fstrand]--;
207
+ bins[i + 1].ref--;
208
+ bins[i + 1][fstrand]--;
437
209
  }
438
- };
439
- for (i = 0; i < features.length; i++) {
440
- _loop_1(i);
441
210
  }
442
- return [2 /*return*/, { bins: bins, skipmap: skipmap }];
211
+ }
443
212
  }
444
- });
445
- });
446
- };
447
- return SNPCoverageAdapter;
448
- }(BaseAdapter_1.BaseFeatureDataAdapter));
213
+ }
214
+ // normal SNP based coloring
215
+ const mismatches = feature.get('mismatches') || [];
216
+ const colorSNPs = (colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) !== 'modifications' && (colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) !== 'methylation';
217
+ for (let i = 0; i < mismatches.length; i++) {
218
+ const mismatch = mismatches[i];
219
+ const mstart = fstart + mismatch.start;
220
+ const mlen = mismatchLen(mismatch);
221
+ const mend = mstart + mlen;
222
+ for (let j = mstart; j < mstart + mlen; j++) {
223
+ const epos = j - region.start;
224
+ if (epos >= 0 && epos < bins.length) {
225
+ const bin = bins[epos];
226
+ const { base, type } = mismatch;
227
+ const interbase = isInterbase(type);
228
+ if (!interbase) {
229
+ bin.ref--;
230
+ bin[fstrand]--;
231
+ }
232
+ else {
233
+ inc(bin, fstrand, 'noncov', type);
234
+ }
235
+ if (type === 'deletion' || type === 'skip') {
236
+ inc(bin, fstrand, 'delskips', type);
237
+ bin.total--;
238
+ }
239
+ else if (!interbase && colorSNPs) {
240
+ inc(bin, fstrand, 'cov', base);
241
+ bin.refbase = mismatch.altbase;
242
+ }
243
+ }
244
+ }
245
+ if (mismatch.type === 'skip') {
246
+ const hash = `${mstart}_${mend}_${fstrand}`;
247
+ if (skipmap[hash] === undefined) {
248
+ skipmap[hash] = {
249
+ feature: feature,
250
+ start: mstart,
251
+ end: mend,
252
+ strand: fstrand,
253
+ xs: (0, util_1.getTag)(feature, 'XS') || (0, util_1.getTag)(feature, 'TS'),
254
+ score: 0,
255
+ };
256
+ }
257
+ skipmap[hash].score++;
258
+ }
259
+ }
260
+ }
261
+ return { bins, skipmap };
262
+ }
263
+ }
449
264
  exports.default = SNPCoverageAdapter;
450
- var capabilities = SNPCoverageAdapter.capabilities;
265
+ const { capabilities } = SNPCoverageAdapter;
451
266
  exports.capabilities = capabilities;
452
267
  //# sourceMappingURL=SNPCoverageAdapter.js.map