@jbrowse/plugin-sequence 2.1.0 → 2.1.3
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/BgzipFastaAdapter/BgzipFastaAdapter.d.ts +4 -4
- package/dist/BgzipFastaAdapter/BgzipFastaAdapter.js +14 -43
- package/dist/BgzipFastaAdapter/BgzipFastaAdapter.js.map +1 -1
- package/dist/BgzipFastaAdapter/configSchema.js +1 -1
- package/dist/BgzipFastaAdapter/configSchema.js.map +1 -1
- package/dist/BgzipFastaAdapter/index.d.ts +3 -1
- package/dist/BgzipFastaAdapter/index.js +38 -3
- package/dist/BgzipFastaAdapter/index.js.map +1 -1
- package/dist/ChromSizesAdapter/ChromSizesAdapter.js +34 -130
- package/dist/ChromSizesAdapter/ChromSizesAdapter.js.map +1 -1
- package/dist/ChromSizesAdapter/configSchema.js +1 -1
- package/dist/ChromSizesAdapter/configSchema.js.map +1 -1
- package/dist/ChromSizesAdapter/index.d.ts +3 -1
- package/dist/ChromSizesAdapter/index.js +38 -3
- package/dist/ChromSizesAdapter/index.js.map +1 -1
- package/dist/DivSequenceRenderer/components/DivSequenceRendering.js +51 -89
- package/dist/DivSequenceRenderer/components/DivSequenceRendering.js.map +1 -1
- package/dist/DivSequenceRenderer/configSchema.js +1 -1
- package/dist/DivSequenceRenderer/configSchema.js.map +1 -1
- package/dist/DivSequenceRenderer/index.d.ts +3 -2
- package/dist/DivSequenceRenderer/index.js +25 -5
- package/dist/DivSequenceRenderer/index.js.map +1 -1
- package/dist/GCContentAdapter/GCContentAdapter.d.ts +1 -7
- package/dist/GCContentAdapter/GCContentAdapter.js +75 -180
- package/dist/GCContentAdapter/GCContentAdapter.js.map +1 -1
- package/dist/GCContentAdapter/configSchema.js +3 -3
- package/dist/GCContentAdapter/configSchema.js.map +1 -1
- package/dist/GCContentAdapter/index.d.ts +1 -4
- package/dist/GCContentAdapter/index.js +15 -7
- package/dist/GCContentAdapter/index.js.map +1 -1
- package/dist/IndexedFastaAdapter/IndexedFastaAdapter.d.ts +9 -2
- package/dist/IndexedFastaAdapter/IndexedFastaAdapter.js +83 -172
- package/dist/IndexedFastaAdapter/IndexedFastaAdapter.js.map +1 -1
- package/dist/IndexedFastaAdapter/configSchema.js +1 -1
- package/dist/IndexedFastaAdapter/configSchema.js.map +1 -1
- package/dist/IndexedFastaAdapter/index.d.ts +3 -1
- package/dist/IndexedFastaAdapter/index.js +38 -3
- package/dist/IndexedFastaAdapter/index.js.map +1 -1
- package/dist/LinearReferenceSequenceDisplay/configSchema.js +6 -3
- package/dist/LinearReferenceSequenceDisplay/configSchema.js.map +1 -1
- package/dist/LinearReferenceSequenceDisplay/index.d.ts +3 -2
- package/dist/LinearReferenceSequenceDisplay/index.js +16 -5
- package/dist/LinearReferenceSequenceDisplay/index.js.map +1 -1
- package/dist/LinearReferenceSequenceDisplay/model.d.ts +1 -1
- package/dist/LinearReferenceSequenceDisplay/model.js +29 -33
- package/dist/LinearReferenceSequenceDisplay/model.js.map +1 -1
- package/dist/{referenceSeqTrackConfig.d.ts → ReferenceSequenceTrack/configSchema.d.ts} +0 -0
- package/dist/{referenceSeqTrackConfig.js → ReferenceSequenceTrack/configSchema.js} +19 -30
- package/dist/ReferenceSequenceTrack/configSchema.js.map +1 -0
- package/dist/ReferenceSequenceTrack/index.d.ts +3 -0
- package/dist/ReferenceSequenceTrack/index.js +19 -0
- package/dist/ReferenceSequenceTrack/index.js.map +1 -0
- package/dist/SequenceSearchAdapter/SequenceSearchAdapter.d.ts +8 -0
- package/dist/SequenceSearchAdapter/SequenceSearchAdapter.js +84 -0
- package/dist/SequenceSearchAdapter/SequenceSearchAdapter.js.map +1 -0
- package/dist/SequenceSearchAdapter/configSchema.d.ts +2 -0
- package/dist/SequenceSearchAdapter/configSchema.js +28 -0
- package/dist/SequenceSearchAdapter/configSchema.js.map +1 -0
- package/dist/SequenceSearchAdapter/index.d.ts +3 -0
- package/dist/SequenceSearchAdapter/index.js +44 -0
- package/dist/SequenceSearchAdapter/index.js.map +1 -0
- package/dist/TwoBitAdapter/TwoBitAdapter.js +66 -174
- package/dist/TwoBitAdapter/TwoBitAdapter.js.map +1 -1
- package/dist/TwoBitAdapter/configSchema.js +1 -1
- package/dist/TwoBitAdapter/configSchema.js.map +1 -1
- package/dist/TwoBitAdapter/index.d.ts +3 -1
- package/dist/TwoBitAdapter/index.js +38 -3
- package/dist/TwoBitAdapter/index.js.map +1 -1
- package/dist/createExtensionPoints.d.ts +3 -0
- package/dist/createExtensionPoints.js +86 -0
- package/dist/createExtensionPoints.js.map +1 -0
- package/dist/index.js +27 -261
- package/dist/index.js.map +1 -1
- package/esm/BgzipFastaAdapter/BgzipFastaAdapter.d.ts +4 -4
- package/esm/BgzipFastaAdapter/BgzipFastaAdapter.js +5 -16
- package/esm/BgzipFastaAdapter/BgzipFastaAdapter.js.map +1 -1
- package/esm/BgzipFastaAdapter/index.d.ts +3 -1
- package/esm/BgzipFastaAdapter/index.js +15 -1
- package/esm/BgzipFastaAdapter/index.js.map +1 -1
- package/esm/ChromSizesAdapter/index.d.ts +3 -1
- package/esm/ChromSizesAdapter/index.js +15 -1
- package/esm/ChromSizesAdapter/index.js.map +1 -1
- package/esm/DivSequenceRenderer/index.d.ts +3 -2
- package/esm/DivSequenceRenderer/index.js +25 -2
- package/esm/DivSequenceRenderer/index.js.map +1 -1
- package/esm/GCContentAdapter/GCContentAdapter.d.ts +1 -7
- package/esm/GCContentAdapter/GCContentAdapter.js +7 -18
- package/esm/GCContentAdapter/GCContentAdapter.js.map +1 -1
- package/esm/GCContentAdapter/index.d.ts +1 -4
- package/esm/GCContentAdapter/index.js +11 -3
- package/esm/GCContentAdapter/index.js.map +1 -1
- package/esm/IndexedFastaAdapter/IndexedFastaAdapter.d.ts +9 -2
- package/esm/IndexedFastaAdapter/IndexedFastaAdapter.js +33 -28
- package/esm/IndexedFastaAdapter/IndexedFastaAdapter.js.map +1 -1
- package/esm/IndexedFastaAdapter/index.d.ts +3 -1
- package/esm/IndexedFastaAdapter/index.js +15 -1
- package/esm/IndexedFastaAdapter/index.js.map +1 -1
- package/esm/LinearReferenceSequenceDisplay/configSchema.js +1 -1
- package/esm/LinearReferenceSequenceDisplay/configSchema.js.map +1 -1
- package/esm/LinearReferenceSequenceDisplay/index.d.ts +3 -2
- package/esm/LinearReferenceSequenceDisplay/index.js +16 -2
- package/esm/LinearReferenceSequenceDisplay/index.js.map +1 -1
- package/esm/LinearReferenceSequenceDisplay/model.d.ts +1 -1
- package/esm/{referenceSeqTrackConfig.d.ts → ReferenceSequenceTrack/configSchema.d.ts} +0 -0
- package/esm/{referenceSeqTrackConfig.js → ReferenceSequenceTrack/configSchema.js} +1 -1
- package/esm/ReferenceSequenceTrack/configSchema.js.map +1 -0
- package/esm/ReferenceSequenceTrack/index.d.ts +3 -0
- package/esm/ReferenceSequenceTrack/index.js +14 -0
- package/esm/ReferenceSequenceTrack/index.js.map +1 -0
- package/esm/SequenceSearchAdapter/SequenceSearchAdapter.d.ts +8 -0
- package/esm/SequenceSearchAdapter/SequenceSearchAdapter.js +81 -0
- package/esm/SequenceSearchAdapter/SequenceSearchAdapter.js.map +1 -0
- package/esm/SequenceSearchAdapter/configSchema.d.ts +2 -0
- package/esm/SequenceSearchAdapter/configSchema.js +26 -0
- package/esm/SequenceSearchAdapter/configSchema.js.map +1 -0
- package/esm/SequenceSearchAdapter/index.d.ts +3 -0
- package/esm/SequenceSearchAdapter/index.js +16 -0
- package/esm/SequenceSearchAdapter/index.js.map +1 -0
- package/esm/TwoBitAdapter/index.d.ts +3 -1
- package/esm/TwoBitAdapter/index.js +15 -1
- package/esm/TwoBitAdapter/index.js.map +1 -1
- package/esm/createExtensionPoints.d.ts +3 -0
- package/esm/createExtensionPoints.js +84 -0
- package/esm/createExtensionPoints.js.map +1 -0
- package/esm/index.js +19 -186
- package/esm/index.js.map +1 -1
- package/package.json +2 -3
- package/src/BgzipFastaAdapter/BgzipFastaAdapter.ts +5 -23
- package/src/BgzipFastaAdapter/index.ts +22 -1
- package/src/ChromSizesAdapter/index.ts +22 -1
- package/src/DivSequenceRenderer/index.ts +31 -2
- package/src/GCContentAdapter/GCContentAdapter.ts +15 -25
- package/src/GCContentAdapter/index.ts +17 -4
- package/src/IndexedFastaAdapter/IndexedFastaAdapter.ts +41 -38
- package/src/IndexedFastaAdapter/index.ts +22 -1
- package/src/LinearReferenceSequenceDisplay/configSchema.ts +1 -1
- package/src/LinearReferenceSequenceDisplay/index.ts +19 -2
- package/src/{referenceSeqTrackConfig.ts → ReferenceSequenceTrack/configSchema.ts} +0 -0
- package/src/ReferenceSequenceTrack/index.ts +21 -0
- package/src/SequenceSearchAdapter/SequenceSearchAdapter.ts +103 -0
- package/src/SequenceSearchAdapter/configSchema.ts +31 -0
- package/src/SequenceSearchAdapter/index.ts +22 -0
- package/src/TwoBitAdapter/index.ts +21 -1
- package/src/createExtensionPoints.ts +122 -0
- package/src/index.ts +20 -268
- package/dist/referenceSeqTrackConfig.js.map +0 -1
- package/esm/referenceSeqTrackConfig.js.map +0 -1
- package/src/declare.d.ts +0 -1
|
@@ -1,20 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __assign = (this && this.__assign) || function () {
|
|
3
|
-
__assign = Object.assign || function(t) {
|
|
4
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
-
s = arguments[i];
|
|
6
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
-
t[p] = s[p];
|
|
8
|
-
}
|
|
9
|
-
return t;
|
|
10
|
-
};
|
|
11
|
-
return __assign.apply(this, arguments);
|
|
12
|
-
};
|
|
13
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
3
|
exports.createReferenceSeqTrackConfig = void 0;
|
|
15
4
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
16
|
-
|
|
17
|
-
|
|
5
|
+
const mobx_state_tree_1 = require("mobx-state-tree");
|
|
6
|
+
const configuration_1 = require("@jbrowse/core/configuration");
|
|
18
7
|
/*
|
|
19
8
|
Note: this is primarily a copy of createBaseTrackConfig, except with a subset
|
|
20
9
|
of the config slots, to avoid including fields that don't make sense for the
|
|
@@ -35,44 +24,44 @@ function createReferenceSeqTrackConfig(pluginManager) {
|
|
|
35
24
|
defaultValue: {},
|
|
36
25
|
},
|
|
37
26
|
}, {
|
|
38
|
-
preProcessSnapshot:
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
27
|
+
preProcessSnapshot: s => {
|
|
28
|
+
const snap = JSON.parse(JSON.stringify(s));
|
|
29
|
+
const displayTypes = new Set();
|
|
30
|
+
const { displays = [] } = snap;
|
|
42
31
|
if (snap.trackId !== 'placeholderId') {
|
|
43
32
|
// Gets the displays on the track snapshot and the possible displays
|
|
44
33
|
// from the track type and adds any missing possible displays to the
|
|
45
34
|
// snapshot
|
|
46
|
-
displays.forEach(
|
|
47
|
-
|
|
48
|
-
trackType.displayTypes.forEach(
|
|
35
|
+
displays.forEach((d) => d && displayTypes.add(d.type));
|
|
36
|
+
const trackType = pluginManager.getTrackType(snap.type);
|
|
37
|
+
trackType.displayTypes.forEach(displayType => {
|
|
49
38
|
if (!displayTypes.has(displayType.name)) {
|
|
50
39
|
displays.push({
|
|
51
|
-
displayId:
|
|
40
|
+
displayId: `${snap.trackId}-${displayType.name}`,
|
|
52
41
|
type: displayType.name,
|
|
53
42
|
});
|
|
54
43
|
}
|
|
55
44
|
});
|
|
56
45
|
}
|
|
57
|
-
return
|
|
46
|
+
return { ...snap, displays };
|
|
58
47
|
},
|
|
59
48
|
explicitIdentifier: 'trackId',
|
|
60
49
|
explicitlyTyped: true,
|
|
61
|
-
actions:
|
|
62
|
-
addDisplayConf
|
|
63
|
-
|
|
50
|
+
actions: (self) => ({
|
|
51
|
+
addDisplayConf(displayConf) {
|
|
52
|
+
const { type } = displayConf;
|
|
64
53
|
if (!type) {
|
|
65
|
-
throw new Error(
|
|
54
|
+
throw new Error(`unknown display type ${type}`);
|
|
66
55
|
}
|
|
67
|
-
|
|
56
|
+
const display = self.displays.find((d) => d && d.displayId === displayConf.displayId);
|
|
68
57
|
if (display) {
|
|
69
58
|
return display;
|
|
70
59
|
}
|
|
71
|
-
|
|
60
|
+
const length = self.displays.push(displayConf);
|
|
72
61
|
return self.displays[length - 1];
|
|
73
62
|
},
|
|
74
|
-
})
|
|
63
|
+
}),
|
|
75
64
|
});
|
|
76
65
|
}
|
|
77
66
|
exports.createReferenceSeqTrackConfig = createReferenceSeqTrackConfig;
|
|
78
|
-
//# sourceMappingURL=
|
|
67
|
+
//# sourceMappingURL=configSchema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/ReferenceSequenceTrack/configSchema.ts"],"names":[],"mappings":";;;AAAA,uDAAuD;AACvD,qDAAuC;AACvC,+DAAiE;AAGjE;;;;EAIE;AACF,SAAgB,6BAA6B,CAAC,aAA4B;IACxE,OAAO,IAAA,mCAAmB,EACxB,wBAAwB,EACxB;QACE,OAAO,EAAE,aAAa,CAAC,yBAAyB,CAAC,SAAS,CAAC;QAC3D,QAAQ,EAAE,uBAAK,CAAC,KAAK,CAAC,aAAa,CAAC,yBAAyB,CAAC,SAAS,CAAC,CAAC;QACzE,IAAI,EAAE;YACJ,IAAI,EAAE,QAAQ;YACd,WAAW,EAAE,qBAAqB;YAClC,YAAY,EAAE,EAAE;SACjB;QACD,QAAQ,EAAE;YACR,IAAI,EAAE,QAAQ;YACd,WAAW,EAAE,kCAAkC;YAC/C,YAAY,EAAE,EAAE;SACjB;KACF,EACD;QACE,kBAAkB,EAAE,CAAC,CAAC,EAAE;YACtB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAA;YAC1C,MAAM,YAAY,GAAG,IAAI,GAAG,EAAE,CAAA;YAC9B,MAAM,EAAE,QAAQ,GAAG,EAAE,EAAE,GAAG,IAAI,CAAA;YAC9B,IAAI,IAAI,CAAC,OAAO,KAAK,eAAe,EAAE;gBACpC,oEAAoE;gBACpE,oEAAoE;gBACpE,WAAW;gBACX,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,IAAI,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAA;gBAC3D,MAAM,SAAS,GAAG,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;gBACvD,SAAS,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;oBAC3C,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;wBACvC,QAAQ,CAAC,IAAI,CAAC;4BACZ,SAAS,EAAE,GAAG,IAAI,CAAC,OAAO,IAAI,WAAW,CAAC,IAAI,EAAE;4BAChD,IAAI,EAAE,WAAW,CAAC,IAAI;yBACvB,CAAC,CAAA;qBACH;gBACH,CAAC,CAAC,CAAA;aACH;YACD,OAAO,EAAE,GAAG,IAAI,EAAE,QAAQ,EAAE,CAAA;QAC9B,CAAC;QACD,kBAAkB,EAAE,SAAS;QAC7B,eAAe,EAAE,IAAI;QACrB,OAAO,EAAE,CAAC,IAAS,EAAE,EAAE,CAAC,CAAC;YACvB,cAAc,CAAC,WAAgD;gBAC7D,MAAM,EAAE,IAAI,EAAE,GAAG,WAAW,CAAA;gBAC5B,IAAI,CAAC,IAAI,EAAE;oBACT,MAAM,IAAI,KAAK,CAAC,wBAAwB,IAAI,EAAE,CAAC,CAAA;iBAChD;gBACD,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,KAAK,WAAW,CAAC,SAAS,CACvD,CAAA;gBACD,IAAI,OAAO,EAAE;oBACX,OAAO,OAAO,CAAA;iBACf;gBACD,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;gBAC9C,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;YAClC,CAAC;SACF,CAAC;KACH,CACF,CAAA;AACH,CAAC;AA3DD,sEA2DC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const TrackType_1 = __importDefault(require("@jbrowse/core/pluggableElementTypes/TrackType"));
|
|
7
|
+
const models_1 = require("@jbrowse/core/pluggableElementTypes/models");
|
|
8
|
+
const configSchema_1 = require("./configSchema");
|
|
9
|
+
exports.default = (pluginManager) => {
|
|
10
|
+
pluginManager.addTrackType(() => {
|
|
11
|
+
const configSchema = (0, configSchema_1.createReferenceSeqTrackConfig)(pluginManager);
|
|
12
|
+
return new TrackType_1.default({
|
|
13
|
+
name: 'ReferenceSequenceTrack',
|
|
14
|
+
configSchema,
|
|
15
|
+
stateModel: (0, models_1.createBaseTrackModel)(pluginManager, 'ReferenceSequenceTrack', configSchema),
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/ReferenceSequenceTrack/index.ts"],"names":[],"mappings":";;;;;AAEA,8FAAqE;AACrE,uEAAiF;AACjF,iDAA8D;AAE9D,kBAAe,CAAC,aAA4B,EAAE,EAAE;IAC9C,aAAa,CAAC,YAAY,CAAC,GAAG,EAAE;QAC9B,MAAM,YAAY,GAAG,IAAA,4CAA6B,EAAC,aAAa,CAAC,CAAA;QAEjE,OAAO,IAAI,mBAAS,CAAC;YACnB,IAAI,EAAE,wBAAwB;YAC9B,YAAY;YACZ,UAAU,EAAE,IAAA,6BAAoB,EAC9B,aAAa,EACb,wBAAwB,EACxB,YAAY,CACb;SACF,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { BaseFeatureDataAdapter, BaseOptions } from '@jbrowse/core/data_adapters/BaseAdapter';
|
|
2
|
+
import { Feature, Region } from '@jbrowse/core/util';
|
|
3
|
+
export default class extends BaseFeatureDataAdapter {
|
|
4
|
+
configure(): Promise<BaseFeatureDataAdapter>;
|
|
5
|
+
getRefNames(): Promise<string[]>;
|
|
6
|
+
getFeatures(query: Region, opts: BaseOptions): import("rxjs").Observable<Feature>;
|
|
7
|
+
freeResources(): void;
|
|
8
|
+
}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const BaseAdapter_1 = require("@jbrowse/core/data_adapters/BaseAdapter");
|
|
4
|
+
const rxjs_1 = require("@jbrowse/core/util/rxjs");
|
|
5
|
+
const util_1 = require("@jbrowse/core/util");
|
|
6
|
+
const operators_1 = require("rxjs/operators");
|
|
7
|
+
class default_1 extends BaseAdapter_1.BaseFeatureDataAdapter {
|
|
8
|
+
async configure() {
|
|
9
|
+
var _a;
|
|
10
|
+
const adapter = await ((_a = this.getSubAdapter) === null || _a === void 0 ? void 0 : _a.call(this, this.getConf('sequenceAdapter')));
|
|
11
|
+
if (!adapter) {
|
|
12
|
+
throw new Error('Error getting subadapter');
|
|
13
|
+
}
|
|
14
|
+
return adapter.dataAdapter;
|
|
15
|
+
}
|
|
16
|
+
async getRefNames() {
|
|
17
|
+
const adapter = await this.configure();
|
|
18
|
+
return adapter.getRefNames();
|
|
19
|
+
}
|
|
20
|
+
getFeatures(query, opts) {
|
|
21
|
+
return (0, rxjs_1.ObservableCreate)(async (observer) => {
|
|
22
|
+
var _a;
|
|
23
|
+
const sequenceAdapter = await this.configure();
|
|
24
|
+
const hw = 1000;
|
|
25
|
+
let { start: queryStart, end: queryEnd } = query;
|
|
26
|
+
queryStart = Math.max(0, queryStart - hw);
|
|
27
|
+
queryEnd += hw;
|
|
28
|
+
if (queryEnd < 0 || queryStart > queryEnd) {
|
|
29
|
+
observer.complete();
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
const ret = sequenceAdapter.getFeatures({
|
|
33
|
+
...query,
|
|
34
|
+
start: queryStart,
|
|
35
|
+
end: queryEnd,
|
|
36
|
+
}, opts);
|
|
37
|
+
const feats = await ret.pipe((0, operators_1.toArray)()).toPromise();
|
|
38
|
+
const residues = ((_a = feats[0]) === null || _a === void 0 ? void 0 : _a.get('seq')) || '';
|
|
39
|
+
const search = this.getConf('search');
|
|
40
|
+
const searchFoward = this.getConf('searchForward');
|
|
41
|
+
const searchReverse = this.getConf('searchReverse');
|
|
42
|
+
const caseInsensitive = this.getConf('caseInsensitive');
|
|
43
|
+
const re = new RegExp(search, 'g' + (caseInsensitive ? 'i' : ''));
|
|
44
|
+
if (search) {
|
|
45
|
+
if (searchFoward) {
|
|
46
|
+
const matches = residues.matchAll(re);
|
|
47
|
+
for (const match of matches) {
|
|
48
|
+
const s = queryStart + (match.index || 0);
|
|
49
|
+
if ((0, util_1.doesIntersect2)(s, s + search.length, query.start, query.end)) {
|
|
50
|
+
observer.next(new util_1.SimpleFeature({
|
|
51
|
+
uniqueId: `${this.id}-match-${s}-p`,
|
|
52
|
+
refName: query.refName,
|
|
53
|
+
start: s,
|
|
54
|
+
end: s + match[0].length,
|
|
55
|
+
name: match[0],
|
|
56
|
+
strand: 1,
|
|
57
|
+
}));
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
if (searchReverse) {
|
|
62
|
+
const matches = (0, util_1.revcom)(residues).matchAll(re);
|
|
63
|
+
for (const match of matches) {
|
|
64
|
+
const s = queryEnd - (match.index || 0);
|
|
65
|
+
if ((0, util_1.doesIntersect2)(s, s + search.length, query.start, query.end)) {
|
|
66
|
+
observer.next(new util_1.SimpleFeature({
|
|
67
|
+
uniqueId: `${this.id}-match-${s}-n`,
|
|
68
|
+
refName: query.refName,
|
|
69
|
+
start: s - match[0].length,
|
|
70
|
+
name: match[0],
|
|
71
|
+
end: s,
|
|
72
|
+
strand: -1,
|
|
73
|
+
}));
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
observer.complete();
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
freeResources() { }
|
|
82
|
+
}
|
|
83
|
+
exports.default = default_1;
|
|
84
|
+
//# sourceMappingURL=SequenceSearchAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SequenceSearchAdapter.js","sourceRoot":"","sources":["../../src/SequenceSearchAdapter/SequenceSearchAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const configuration_1 = require("@jbrowse/core/configuration");
|
|
4
|
+
const configSchema = (0, configuration_1.ConfigurationSchema)('SequenceSearchAdapter', {
|
|
5
|
+
search: {
|
|
6
|
+
type: 'string',
|
|
7
|
+
defaultValue: '',
|
|
8
|
+
description: 'Search string or regex to search for',
|
|
9
|
+
},
|
|
10
|
+
sequenceAdapter: {
|
|
11
|
+
type: 'frozen',
|
|
12
|
+
defaultValue: null,
|
|
13
|
+
},
|
|
14
|
+
searchForward: {
|
|
15
|
+
type: 'boolean',
|
|
16
|
+
defaultValue: true,
|
|
17
|
+
},
|
|
18
|
+
searchReverse: {
|
|
19
|
+
type: 'boolean',
|
|
20
|
+
defaultValue: true,
|
|
21
|
+
},
|
|
22
|
+
caseInsensitive: {
|
|
23
|
+
type: 'boolean',
|
|
24
|
+
defaultValue: true,
|
|
25
|
+
},
|
|
26
|
+
}, { explicitlyTyped: true });
|
|
27
|
+
exports.default = configSchema;
|
|
28
|
+
//# sourceMappingURL=configSchema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/SequenceSearchAdapter/configSchema.ts"],"names":[],"mappings":";;AAAA,+DAAiE;AAEjE,MAAM,YAAY,GAAG,IAAA,mCAAmB,EACtC,uBAAuB,EACvB;IACE,MAAM,EAAE;QACN,IAAI,EAAE,QAAQ;QACd,YAAY,EAAE,EAAE;QAChB,WAAW,EAAE,sCAAsC;KACpD;IACD,eAAe,EAAE;QACf,IAAI,EAAE,QAAQ;QACd,YAAY,EAAE,IAAI;KACnB;IACD,aAAa,EAAE;QACb,IAAI,EAAE,SAAS;QACf,YAAY,EAAE,IAAI;KACnB;IACD,aAAa,EAAE;QACb,IAAI,EAAE,SAAS;QACf,YAAY,EAAE,IAAI;KACnB;IACD,eAAe,EAAE;QACf,IAAI,EAAE,SAAS;QACf,YAAY,EAAE,IAAI;KACnB;CACF,EACD,EAAE,eAAe,EAAE,IAAI,EAAE,CAC1B,CAAA;AAED,kBAAe,YAAY,CAAA"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
const AdapterType_1 = __importDefault(require("@jbrowse/core/pluggableElementTypes/AdapterType"));
|
|
30
|
+
const configSchema_1 = __importDefault(require("./configSchema"));
|
|
31
|
+
exports.default = (pluginManager) => {
|
|
32
|
+
pluginManager.addAdapterType(() => new AdapterType_1.default({
|
|
33
|
+
name: 'SequenceSearchAdapter',
|
|
34
|
+
adapterMetadata: {
|
|
35
|
+
category: null,
|
|
36
|
+
hiddenFromGUI: true,
|
|
37
|
+
displayName: null,
|
|
38
|
+
description: null,
|
|
39
|
+
},
|
|
40
|
+
configSchema: configSchema_1.default,
|
|
41
|
+
getAdapterClass: () => Promise.resolve().then(() => __importStar(require('./SequenceSearchAdapter'))).then(r => r.default),
|
|
42
|
+
}));
|
|
43
|
+
};
|
|
44
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/SequenceSearchAdapter/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,kGAAyE;AAEzE,kEAAyC;AAEzC,kBAAe,CAAC,aAA4B,EAAE,EAAE;IAC9C,aAAa,CAAC,cAAc,CAC1B,GAAG,EAAE,CACH,IAAI,qBAAW,CAAC;QACd,IAAI,EAAE,uBAAuB;QAC7B,eAAe,EAAE;YACf,QAAQ,EAAE,IAAI;YACd,aAAa,EAAE,IAAI;YACnB,WAAW,EAAE,IAAI;YACjB,WAAW,EAAE,IAAI;SAClB;QACD,YAAY,EAAZ,sBAAY;QACZ,eAAe,EAAE,GAAG,EAAE,CACpB,kDAAO,yBAAyB,IAAE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;KACzD,CAAC,CACL,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -1,193 +1,85 @@
|
|
|
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
2
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
70
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
71
4
|
};
|
|
72
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
filehandle: (0, io_1.openLocation)((0, configuration_1.readConfObject)(config, 'twoBitLocation'), _this.pluginManager),
|
|
6
|
+
const BaseAdapter_1 = require("@jbrowse/core/data_adapters/BaseAdapter");
|
|
7
|
+
const io_1 = require("@jbrowse/core/util/io");
|
|
8
|
+
const rxjs_1 = require("@jbrowse/core/util/rxjs");
|
|
9
|
+
const simpleFeature_1 = __importDefault(require("@jbrowse/core/util/simpleFeature"));
|
|
10
|
+
const twobit_1 = require("@gmod/twobit");
|
|
11
|
+
const configuration_1 = require("@jbrowse/core/configuration");
|
|
12
|
+
class TwoBitAdapter extends BaseAdapter_1.BaseSequenceAdapter {
|
|
13
|
+
constructor(config, getSubAdapter, pluginManager) {
|
|
14
|
+
super(config, getSubAdapter, pluginManager);
|
|
15
|
+
this.chromSizesData = this.initChromSizes();
|
|
16
|
+
this.twobit = new twobit_1.TwoBitFile({
|
|
17
|
+
filehandle: (0, io_1.openLocation)((0, configuration_1.readConfObject)(config, 'twoBitLocation'), this.pluginManager),
|
|
86
18
|
});
|
|
87
|
-
return _this;
|
|
88
19
|
}
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
128
|
-
var chromSizesData, refSizes;
|
|
129
|
-
return __generator(this, function (_a) {
|
|
130
|
-
switch (_a.label) {
|
|
131
|
-
case 0: return [4 /*yield*/, this.chromSizesData];
|
|
132
|
-
case 1:
|
|
133
|
-
chromSizesData = _a.sent();
|
|
134
|
-
if (chromSizesData) {
|
|
135
|
-
return [2 /*return*/, Object.keys(chromSizesData).map(function (refName) { return ({
|
|
136
|
-
refName: refName,
|
|
137
|
-
start: 0,
|
|
138
|
-
end: chromSizesData[refName],
|
|
139
|
-
}); })];
|
|
140
|
-
}
|
|
141
|
-
return [4 /*yield*/, this.twobit.getSequenceSizes()];
|
|
142
|
-
case 2:
|
|
143
|
-
refSizes = _a.sent();
|
|
144
|
-
return [2 /*return*/, Object.keys(refSizes).map(function (refName) { return ({
|
|
145
|
-
refName: refName,
|
|
146
|
-
start: 0,
|
|
147
|
-
end: refSizes[refName],
|
|
148
|
-
}); })];
|
|
149
|
-
}
|
|
150
|
-
});
|
|
151
|
-
});
|
|
152
|
-
};
|
|
20
|
+
async initChromSizes() {
|
|
21
|
+
const conf = (0, configuration_1.readConfObject)(this.config, 'chromSizesLocation');
|
|
22
|
+
// check against default and empty in case someone makes the field blank in
|
|
23
|
+
// config editor, may want better way to check "optional config slots" in
|
|
24
|
+
// future
|
|
25
|
+
if (conf.uri !== '/path/to/default.chrom.sizes' && conf.uri !== '') {
|
|
26
|
+
const file = (0, io_1.openLocation)(conf, this.pluginManager);
|
|
27
|
+
const data = await file.readFile('utf8');
|
|
28
|
+
return Object.fromEntries(data === null || data === void 0 ? void 0 : data.split('\n').filter(line => !!line.trim()).map(line => {
|
|
29
|
+
const [name, length] = line.split('\t');
|
|
30
|
+
return [name, +length];
|
|
31
|
+
}));
|
|
32
|
+
}
|
|
33
|
+
return undefined;
|
|
34
|
+
}
|
|
35
|
+
async getRefNames() {
|
|
36
|
+
const chromSizesData = await this.chromSizesData;
|
|
37
|
+
if (chromSizesData) {
|
|
38
|
+
return Object.keys(chromSizesData);
|
|
39
|
+
}
|
|
40
|
+
return this.twobit.getSequenceNames();
|
|
41
|
+
}
|
|
42
|
+
async getRegions() {
|
|
43
|
+
const chromSizesData = await this.chromSizesData;
|
|
44
|
+
if (chromSizesData) {
|
|
45
|
+
return Object.keys(chromSizesData).map(refName => ({
|
|
46
|
+
refName,
|
|
47
|
+
start: 0,
|
|
48
|
+
end: chromSizesData[refName],
|
|
49
|
+
}));
|
|
50
|
+
}
|
|
51
|
+
const refSizes = await this.twobit.getSequenceSizes();
|
|
52
|
+
return Object.keys(refSizes).map(refName => ({
|
|
53
|
+
refName,
|
|
54
|
+
start: 0,
|
|
55
|
+
end: refSizes[refName],
|
|
56
|
+
}));
|
|
57
|
+
}
|
|
153
58
|
/**
|
|
154
59
|
* Fetch features for a certain region
|
|
155
60
|
* @param param -
|
|
156
61
|
* @returns Observable of Feature objects in the region
|
|
157
62
|
*/
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
if (seq) {
|
|
173
|
-
observer.next(new simpleFeature_1.default({
|
|
174
|
-
id: "".concat(refName, " ").concat(start, "-").concat(regionEnd),
|
|
175
|
-
data: { refName: refName, start: start, end: regionEnd, seq: seq },
|
|
176
|
-
}));
|
|
177
|
-
}
|
|
178
|
-
observer.complete();
|
|
179
|
-
return [2 /*return*/];
|
|
180
|
-
}
|
|
181
|
-
});
|
|
182
|
-
}); });
|
|
183
|
-
};
|
|
63
|
+
getFeatures({ refName, start, end }) {
|
|
64
|
+
return (0, rxjs_1.ObservableCreate)(async (observer) => {
|
|
65
|
+
const size = await this.twobit.getSequenceSize(refName);
|
|
66
|
+
const regionEnd = size !== undefined ? Math.min(size, end) : end;
|
|
67
|
+
const seq = await this.twobit.getSequence(refName, start, regionEnd);
|
|
68
|
+
if (seq) {
|
|
69
|
+
observer.next(new simpleFeature_1.default({
|
|
70
|
+
id: `${refName} ${start}-${regionEnd}`,
|
|
71
|
+
data: { refName, start, end: regionEnd, seq },
|
|
72
|
+
}));
|
|
73
|
+
}
|
|
74
|
+
observer.complete();
|
|
75
|
+
});
|
|
76
|
+
}
|
|
184
77
|
/**
|
|
185
78
|
* called to provide a hint that data tied to a certain region
|
|
186
79
|
* will not be needed for the forseeable future and can be purged
|
|
187
80
|
* from caches, etc
|
|
188
81
|
*/
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
}(BaseAdapter_1.BaseSequenceAdapter));
|
|
82
|
+
freeResources( /* { region } */) { }
|
|
83
|
+
}
|
|
192
84
|
exports.default = TwoBitAdapter;
|
|
193
85
|
//# sourceMappingURL=TwoBitAdapter.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TwoBitAdapter.js","sourceRoot":"","sources":["../../src/TwoBitAdapter/TwoBitAdapter.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"TwoBitAdapter.js","sourceRoot":"","sources":["../../src/TwoBitAdapter/TwoBitAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
|
|
3
|
+
const configuration_1 = require("@jbrowse/core/configuration");
|
|
4
4
|
exports.default = (0, configuration_1.ConfigurationSchema)('TwoBitAdapter', {
|
|
5
5
|
twoBitLocation: {
|
|
6
6
|
type: 'fileLocation',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/TwoBitAdapter/configSchema.ts"],"names":[],"mappings":";;AAAA
|
|
1
|
+
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/TwoBitAdapter/configSchema.ts"],"names":[],"mappings":";;AAAA,+DAAiE;AAEjE,kBAAe,IAAA,mCAAmB,EAChC,eAAe,EACf;IACE,cAAc,EAAE;QACd,IAAI,EAAE,cAAc;QACpB,YAAY,EAAE,EAAE,GAAG,EAAE,kBAAkB,EAAE,YAAY,EAAE,aAAa,EAAE;KACvE;IACD,kBAAkB,EAAE;QAClB,IAAI,EAAE,cAAc;QACpB,YAAY,EAAE;YACZ,GAAG,EAAE,8BAA8B;YACnC,YAAY,EAAE,aAAa;SAC5B;QACD,WAAW,EACT,8GAA8G;KACjH;CACF,EACD,EAAE,eAAe,EAAE,IAAI,EAAE,CAC1B,CAAA"}
|