@jbrowse/plugin-sequence 1.7.11 → 2.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/BgzipFastaAdapter/BgzipFastaAdapter.js +50 -68
- package/dist/BgzipFastaAdapter/BgzipFastaAdapter.js.map +1 -0
- package/dist/BgzipFastaAdapter/configSchema.js +31 -43
- package/dist/BgzipFastaAdapter/configSchema.js.map +1 -0
- package/dist/BgzipFastaAdapter/index.js +8 -14
- package/dist/BgzipFastaAdapter/index.js.map +1 -0
- package/dist/ChromSizesAdapter/ChromSizesAdapter.d.ts +9 -9
- package/dist/ChromSizesAdapter/ChromSizesAdapter.js +134 -166
- package/dist/ChromSizesAdapter/ChromSizesAdapter.js.map +1 -0
- package/dist/ChromSizesAdapter/configSchema.js +12 -21
- package/dist/ChromSizesAdapter/configSchema.js.map +1 -0
- package/dist/ChromSizesAdapter/index.js +8 -14
- package/dist/ChromSizesAdapter/index.js.map +1 -0
- package/dist/DivSequenceRenderer/components/DivSequenceRendering.js +130 -229
- package/dist/DivSequenceRenderer/components/DivSequenceRendering.js.map +1 -0
- package/dist/DivSequenceRenderer/configSchema.js +10 -19
- package/dist/DivSequenceRenderer/configSchema.js.map +1 -0
- package/dist/DivSequenceRenderer/index.js +10 -22
- package/dist/DivSequenceRenderer/index.js.map +1 -0
- package/dist/GCContentAdapter/GCContentAdapter.js +181 -248
- package/dist/GCContentAdapter/GCContentAdapter.js.map +1 -0
- package/dist/GCContentAdapter/configSchema.js +7 -16
- package/dist/GCContentAdapter/configSchema.js.map +1 -0
- package/dist/GCContentAdapter/index.js +33 -28
- package/dist/GCContentAdapter/index.js.map +1 -0
- package/dist/IndexedFastaAdapter/IndexedFastaAdapter.js +177 -266
- package/dist/IndexedFastaAdapter/IndexedFastaAdapter.js.map +1 -0
- package/dist/IndexedFastaAdapter/configSchema.js +21 -36
- package/dist/IndexedFastaAdapter/configSchema.js.map +1 -0
- package/dist/IndexedFastaAdapter/index.js +8 -14
- package/dist/IndexedFastaAdapter/index.js.map +1 -0
- package/dist/LinearReferenceSequenceDisplay/configSchema.js +5 -16
- package/dist/LinearReferenceSequenceDisplay/configSchema.js.map +1 -0
- package/dist/LinearReferenceSequenceDisplay/index.js +7 -20
- package/dist/LinearReferenceSequenceDisplay/index.js.map +1 -0
- package/dist/LinearReferenceSequenceDisplay/model.d.ts +17 -15
- package/dist/LinearReferenceSequenceDisplay/model.js +88 -99
- package/dist/LinearReferenceSequenceDisplay/model.js.map +1 -0
- package/dist/TwoBitAdapter/TwoBitAdapter.js +178 -274
- package/dist/TwoBitAdapter/TwoBitAdapter.js.map +1 -0
- package/dist/TwoBitAdapter/configSchema.js +16 -28
- package/dist/TwoBitAdapter/configSchema.js.map +1 -0
- package/dist/TwoBitAdapter/index.js +8 -14
- package/dist/TwoBitAdapter/index.js.map +1 -0
- package/dist/index.js +255 -312
- package/dist/index.js.map +1 -0
- package/dist/referenceSeqTrackConfig.js +71 -86
- package/dist/referenceSeqTrackConfig.js.map +1 -0
- package/esm/BgzipFastaAdapter/BgzipFastaAdapter.d.ts +7 -0
- package/esm/BgzipFastaAdapter/BgzipFastaAdapter.js +28 -0
- package/esm/BgzipFastaAdapter/BgzipFastaAdapter.js.map +1 -0
- package/esm/BgzipFastaAdapter/configSchema.d.ts +2 -0
- package/esm/BgzipFastaAdapter/configSchema.js +30 -0
- package/esm/BgzipFastaAdapter/configSchema.js.map +1 -0
- package/esm/BgzipFastaAdapter/index.d.ts +1 -0
- package/esm/BgzipFastaAdapter/index.js +2 -0
- package/esm/BgzipFastaAdapter/index.js.map +1 -0
- package/esm/ChromSizesAdapter/ChromSizesAdapter.d.ts +19 -0
- package/esm/ChromSizesAdapter/ChromSizesAdapter.js +39 -0
- package/esm/ChromSizesAdapter/ChromSizesAdapter.js.map +1 -0
- package/esm/ChromSizesAdapter/configSchema.d.ts +2 -0
- package/esm/ChromSizesAdapter/configSchema.js +11 -0
- package/esm/ChromSizesAdapter/configSchema.js.map +1 -0
- package/esm/ChromSizesAdapter/index.d.ts +1 -0
- package/esm/ChromSizesAdapter/index.js +2 -0
- package/esm/ChromSizesAdapter/index.js.map +1 -0
- package/esm/DivSequenceRenderer/components/DivSequenceRendering.d.ts +21 -0
- package/esm/DivSequenceRenderer/components/DivSequenceRendering.js +97 -0
- package/esm/DivSequenceRenderer/components/DivSequenceRendering.js.map +1 -0
- package/esm/DivSequenceRenderer/configSchema.d.ts +2 -0
- package/esm/DivSequenceRenderer/configSchema.js +9 -0
- package/esm/DivSequenceRenderer/configSchema.js.map +1 -0
- package/esm/DivSequenceRenderer/index.d.ts +2 -0
- package/esm/DivSequenceRenderer/index.js +3 -0
- package/esm/DivSequenceRenderer/index.js.map +1 -0
- package/esm/GCContentAdapter/GCContentAdapter.d.ts +23 -0
- package/esm/GCContentAdapter/GCContentAdapter.js +97 -0
- package/esm/GCContentAdapter/GCContentAdapter.js.map +1 -0
- package/esm/GCContentAdapter/configSchema.d.ts +3 -0
- package/esm/GCContentAdapter/configSchema.js +7 -0
- package/esm/GCContentAdapter/configSchema.js.map +1 -0
- package/esm/GCContentAdapter/index.d.ts +6 -0
- package/esm/GCContentAdapter/index.js +8 -0
- package/esm/GCContentAdapter/index.js.map +1 -0
- package/esm/IndexedFastaAdapter/IndexedFastaAdapter.d.ts +27 -0
- package/esm/IndexedFastaAdapter/IndexedFastaAdapter.js +90 -0
- package/esm/IndexedFastaAdapter/IndexedFastaAdapter.js.map +1 -0
- package/esm/IndexedFastaAdapter/configSchema.d.ts +2 -0
- package/esm/IndexedFastaAdapter/configSchema.js +20 -0
- package/esm/IndexedFastaAdapter/configSchema.js.map +1 -0
- package/esm/IndexedFastaAdapter/index.d.ts +1 -0
- package/esm/IndexedFastaAdapter/index.js +2 -0
- package/esm/IndexedFastaAdapter/index.js.map +1 -0
- package/esm/LinearReferenceSequenceDisplay/configSchema.d.ts +1 -0
- package/esm/LinearReferenceSequenceDisplay/configSchema.js +4 -0
- package/esm/LinearReferenceSequenceDisplay/configSchema.js.map +1 -0
- package/esm/LinearReferenceSequenceDisplay/index.d.ts +2 -0
- package/esm/LinearReferenceSequenceDisplay/index.js +3 -0
- package/esm/LinearReferenceSequenceDisplay/index.js.map +1 -0
- package/esm/LinearReferenceSequenceDisplay/model.d.ts +210 -0
- package/esm/LinearReferenceSequenceDisplay/model.js +83 -0
- package/esm/LinearReferenceSequenceDisplay/model.js.map +1 -0
- package/esm/TwoBitAdapter/TwoBitAdapter.d.ts +26 -0
- package/esm/TwoBitAdapter/TwoBitAdapter.js +79 -0
- package/esm/TwoBitAdapter/TwoBitAdapter.js.map +1 -0
- package/esm/TwoBitAdapter/configSchema.d.ts +2 -0
- package/esm/TwoBitAdapter/configSchema.js +16 -0
- package/esm/TwoBitAdapter/configSchema.js.map +1 -0
- package/esm/TwoBitAdapter/index.d.ts +1 -0
- package/esm/TwoBitAdapter/index.js +2 -0
- package/esm/TwoBitAdapter/index.js.map +1 -0
- package/esm/index.d.ts +6 -0
- package/esm/index.js +197 -0
- package/esm/index.js.map +1 -0
- package/esm/referenceSeqTrackConfig.d.ts +2 -0
- package/esm/referenceSeqTrackConfig.js +63 -0
- package/esm/referenceSeqTrackConfig.js.map +1 -0
- package/package.json +20 -13
- package/src/ChromSizesAdapter/ChromSizesAdapter.ts +22 -42
- package/src/DivSequenceRenderer/components/DivSequenceRendering.test.js +1 -1
- package/src/LinearReferenceSequenceDisplay/model.ts +4 -2
- package/dist/BgzipFastaAdapter/BgzipFastaAdapter.test.js +0 -64
- package/dist/ChromSizesAdapter/ChromSizesAdapter.test.js +0 -46
- package/dist/DivSequenceRenderer/components/DivSequenceRendering.test.js +0 -245
- package/dist/IndexedFastaAdapter/IndexedFastaAdapter.test.js +0 -81
- package/dist/TwoBitAdapter/TwoBitAdapter.test.js +0 -94
- package/dist/declare.d.js +0 -1
- package/dist/index.test.js +0 -29
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { BaseFeatureDataAdapter, } from '@jbrowse/core/data_adapters/BaseAdapter';
|
|
2
|
+
import { ObservableCreate } from '@jbrowse/core/util/rxjs';
|
|
3
|
+
import SimpleFeature from '@jbrowse/core/util/simpleFeature';
|
|
4
|
+
import { readConfObject } from '@jbrowse/core/configuration';
|
|
5
|
+
import { toArray } from 'rxjs/operators';
|
|
6
|
+
export default class default_1 extends BaseFeatureDataAdapter {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(...arguments);
|
|
9
|
+
this.windowSize = 1000;
|
|
10
|
+
this.windowDelta = 1000;
|
|
11
|
+
this.gcMode = 'content';
|
|
12
|
+
}
|
|
13
|
+
async configure() {
|
|
14
|
+
var _a;
|
|
15
|
+
// instantiate the sequence adapter
|
|
16
|
+
const sequenceAdapter = readConfObject(this.config, 'sequenceAdapter');
|
|
17
|
+
const dataAdapter = await ((_a = this.getSubAdapter) === null || _a === void 0 ? void 0 : _a.call(this, sequenceAdapter));
|
|
18
|
+
if (!dataAdapter) {
|
|
19
|
+
throw new Error('Error getting subadapter');
|
|
20
|
+
}
|
|
21
|
+
return dataAdapter.dataAdapter;
|
|
22
|
+
}
|
|
23
|
+
async getRefNames() {
|
|
24
|
+
const sequenceAdapter = await this.configure();
|
|
25
|
+
return sequenceAdapter.getRefNames();
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Fetch features for a certain region
|
|
29
|
+
* @param param -
|
|
30
|
+
* @returns Observable of Feature objects in the region
|
|
31
|
+
*/
|
|
32
|
+
getFeatures(query, opts) {
|
|
33
|
+
this.windowSize = 1000;
|
|
34
|
+
this.windowDelta = 1000;
|
|
35
|
+
this.gcMode = 'content';
|
|
36
|
+
return ObservableCreate(async (observer) => {
|
|
37
|
+
var _a;
|
|
38
|
+
const sequenceAdapter = await this.configure();
|
|
39
|
+
const hw = this.windowSize === 1 ? 1 : this.windowSize / 2; // Half the window size
|
|
40
|
+
const f = this.windowSize === 1;
|
|
41
|
+
let { start: queryStart, end: queryEnd } = query;
|
|
42
|
+
queryStart = Math.max(0, queryStart - hw);
|
|
43
|
+
queryEnd += hw;
|
|
44
|
+
if (queryEnd < 0 || queryStart > queryEnd) {
|
|
45
|
+
observer.complete();
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
const ret = sequenceAdapter.getFeatures({
|
|
49
|
+
...query,
|
|
50
|
+
start: queryStart,
|
|
51
|
+
end: queryEnd,
|
|
52
|
+
});
|
|
53
|
+
const feats = await ret.pipe(toArray()).toPromise();
|
|
54
|
+
const residues = ((_a = feats[0]) === null || _a === void 0 ? void 0 : _a.get('seq')) || '';
|
|
55
|
+
for (let i = hw; i < residues.length - hw; i += this.windowDelta) {
|
|
56
|
+
const r = f ? residues[i] : residues.slice(i - hw, i + hw);
|
|
57
|
+
let nc = 0;
|
|
58
|
+
let ng = 0;
|
|
59
|
+
let len = 0;
|
|
60
|
+
for (let j = 0; j < r.length; j++) {
|
|
61
|
+
if (r[j] === 'c' || r[j] === 'C') {
|
|
62
|
+
nc++;
|
|
63
|
+
}
|
|
64
|
+
else if (r[j] === 'g' || r[j] === 'G') {
|
|
65
|
+
ng++;
|
|
66
|
+
}
|
|
67
|
+
if (r[j] !== 'N') {
|
|
68
|
+
len++;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
const pos = queryStart;
|
|
72
|
+
let score;
|
|
73
|
+
if (this.gcMode === 'content') {
|
|
74
|
+
score = (ng + nc) / (len || 1);
|
|
75
|
+
}
|
|
76
|
+
else if (this.gcMode === 'skew') {
|
|
77
|
+
score = (ng - nc) / (ng + nc || 1);
|
|
78
|
+
}
|
|
79
|
+
observer.next(new SimpleFeature({
|
|
80
|
+
uniqueId: `${this.id}_${pos + i}`,
|
|
81
|
+
start: pos + i,
|
|
82
|
+
end: pos + i + this.windowDelta,
|
|
83
|
+
score,
|
|
84
|
+
}));
|
|
85
|
+
}
|
|
86
|
+
observer.complete();
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* called to provide a hint that data tied to a certain region
|
|
91
|
+
* will not be needed for the forseeable future and can be purged
|
|
92
|
+
* from caches, etc
|
|
93
|
+
*/
|
|
94
|
+
freeResources( /* { region } */) { }
|
|
95
|
+
}
|
|
96
|
+
default_1.capabilities = ['hasLocalStats'];
|
|
97
|
+
//# sourceMappingURL=GCContentAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GCContentAdapter.js","sourceRoot":"","sources":["../../src/GCContentAdapter/GCContentAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ConfigurationSchema } from '@jbrowse/core/configuration';
|
|
2
|
+
export default (pluginManager) => {
|
|
3
|
+
return ConfigurationSchema('GCContentAdapter', {
|
|
4
|
+
sequenceAdapter: pluginManager.pluggableConfigSchemaType('adapter'),
|
|
5
|
+
}, { explicitlyTyped: true });
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=configSchema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/GCContentAdapter/configSchema.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AAEjE,eAAe,CAAC,aAA4B,EAAE,EAAE;IAC9C,OAAO,mBAAmB,CACxB,kBAAkB,EAClB;QACE,eAAe,EAAE,aAAa,CAAC,yBAAyB,CAAC,SAAS,CAAC;KACpE,EACD,EAAE,eAAe,EAAE,IAAI,EAAE,CAC1B,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import PluginManager from '@jbrowse/core/PluginManager';
|
|
2
|
+
declare const _default: (pluginManager: PluginManager) => {
|
|
3
|
+
configSchema: import("@jbrowse/core/configuration").AnyConfigurationSchemaType;
|
|
4
|
+
getAdapterClass: () => Promise<typeof import("./GCContentAdapter").default>;
|
|
5
|
+
};
|
|
6
|
+
export default _default;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/GCContentAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,aAAa,MAAM,gBAAgB,CAAA;AAE1C,eAAe,CAAC,aAA4B,EAAE,EAAE;IAC9C,OAAO;QACL,YAAY,EAAE,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC;QAC/C,eAAe,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;KACzE,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { IndexedFasta } from '@gmod/indexedfasta';
|
|
2
|
+
import { BaseSequenceAdapter, BaseOptions } from '@jbrowse/core/data_adapters/BaseAdapter';
|
|
3
|
+
import { NoAssemblyRegion } from '@jbrowse/core/util/types';
|
|
4
|
+
import { Feature } from '@jbrowse/core/util';
|
|
5
|
+
import { AnyConfigurationModel } from '@jbrowse/core/configuration';
|
|
6
|
+
import PluginManager from '@jbrowse/core/PluginManager';
|
|
7
|
+
import { getSubAdapterType } from '@jbrowse/core/data_adapters/dataAdapterCache';
|
|
8
|
+
export default class extends BaseSequenceAdapter {
|
|
9
|
+
protected fasta: IndexedFasta;
|
|
10
|
+
protected header?: Promise<string>;
|
|
11
|
+
private seqCache;
|
|
12
|
+
constructor(config: AnyConfigurationModel, getSubAdapter?: getSubAdapterType, pluginManager?: PluginManager);
|
|
13
|
+
getRefNames(opts?: BaseOptions): Promise<string[]>;
|
|
14
|
+
getRegions(opts?: BaseOptions): Promise<{
|
|
15
|
+
refName: string;
|
|
16
|
+
start: number;
|
|
17
|
+
end: number;
|
|
18
|
+
}[]>;
|
|
19
|
+
getHeader(): Promise<string | null>;
|
|
20
|
+
getFeatures(region: NoAssemblyRegion, opts?: BaseOptions): import("rxjs").Observable<Feature>;
|
|
21
|
+
/**
|
|
22
|
+
* called to provide a hint that data tied to a certain region
|
|
23
|
+
* will not be needed for the forseeable future and can be purged
|
|
24
|
+
* from caches, etc
|
|
25
|
+
*/
|
|
26
|
+
freeResources(): void;
|
|
27
|
+
}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { IndexedFasta } from '@gmod/indexedfasta';
|
|
2
|
+
import { BaseSequenceAdapter, } from '@jbrowse/core/data_adapters/BaseAdapter';
|
|
3
|
+
import { openLocation } from '@jbrowse/core/util/io';
|
|
4
|
+
import { ObservableCreate } from '@jbrowse/core/util/rxjs';
|
|
5
|
+
import { SimpleFeature } from '@jbrowse/core/util';
|
|
6
|
+
import AbortablePromiseCache from 'abortable-promise-cache';
|
|
7
|
+
import LRU from '@jbrowse/core/util/QuickLRU';
|
|
8
|
+
export default class extends BaseSequenceAdapter {
|
|
9
|
+
constructor(config, getSubAdapter, pluginManager) {
|
|
10
|
+
super(config, getSubAdapter, pluginManager);
|
|
11
|
+
this.seqCache = new AbortablePromiseCache({
|
|
12
|
+
cache: new LRU({ maxSize: 200 }),
|
|
13
|
+
fill: async (args, signal) => {
|
|
14
|
+
const { refName, start, end } = args;
|
|
15
|
+
return this.fasta.getSequence(refName, start, end, { ...args, signal });
|
|
16
|
+
},
|
|
17
|
+
});
|
|
18
|
+
const fastaLocation = this.getConf('fastaLocation');
|
|
19
|
+
const faiLocation = this.getConf('faiLocation');
|
|
20
|
+
const fastaOpts = {
|
|
21
|
+
fasta: openLocation(fastaLocation, this.pluginManager),
|
|
22
|
+
fai: openLocation(faiLocation, this.pluginManager),
|
|
23
|
+
};
|
|
24
|
+
this.fasta = new IndexedFasta(fastaOpts);
|
|
25
|
+
}
|
|
26
|
+
getRefNames(opts) {
|
|
27
|
+
return this.fasta.getSequenceNames(opts);
|
|
28
|
+
}
|
|
29
|
+
async getRegions(opts) {
|
|
30
|
+
const seqSizes = await this.fasta.getSequenceSizes(opts);
|
|
31
|
+
return Object.keys(seqSizes).map(refName => ({
|
|
32
|
+
refName,
|
|
33
|
+
start: 0,
|
|
34
|
+
end: seqSizes[refName],
|
|
35
|
+
}));
|
|
36
|
+
}
|
|
37
|
+
async getHeader() {
|
|
38
|
+
if (this.header) {
|
|
39
|
+
return this.header;
|
|
40
|
+
}
|
|
41
|
+
const loc = this.getConf('metadataLocation');
|
|
42
|
+
if (loc.uri === '' || loc.uri === '/path/to/fa.metadata.yaml') {
|
|
43
|
+
return null;
|
|
44
|
+
}
|
|
45
|
+
this.header = openLocation(loc)
|
|
46
|
+
.readFile('utf8')
|
|
47
|
+
.catch(e => {
|
|
48
|
+
this.header = undefined;
|
|
49
|
+
throw e;
|
|
50
|
+
});
|
|
51
|
+
return this.header;
|
|
52
|
+
}
|
|
53
|
+
getFeatures(region, opts) {
|
|
54
|
+
const { refName, start, end } = region;
|
|
55
|
+
return ObservableCreate(async (observer) => {
|
|
56
|
+
const size = await this.fasta.getSequenceSize(refName, opts);
|
|
57
|
+
const regionEnd = size !== undefined ? Math.min(size, end) : end;
|
|
58
|
+
const chunks = [];
|
|
59
|
+
const chunkSize = 128000;
|
|
60
|
+
const s = start - (start % chunkSize);
|
|
61
|
+
const e = end + (chunkSize - (end % chunkSize));
|
|
62
|
+
for (let chunkStart = s; chunkStart < e; chunkStart += chunkSize) {
|
|
63
|
+
const r = {
|
|
64
|
+
refName,
|
|
65
|
+
start: chunkStart,
|
|
66
|
+
end: chunkStart + chunkSize,
|
|
67
|
+
};
|
|
68
|
+
chunks.push(this.seqCache.get(JSON.stringify(r), r, opts === null || opts === void 0 ? void 0 : opts.signal));
|
|
69
|
+
}
|
|
70
|
+
const seq = (await Promise.all(chunks))
|
|
71
|
+
.join('')
|
|
72
|
+
.slice(start - s)
|
|
73
|
+
.slice(0, end - start);
|
|
74
|
+
if (seq) {
|
|
75
|
+
observer.next(new SimpleFeature({
|
|
76
|
+
id: `${refName} ${start}-${regionEnd}`,
|
|
77
|
+
data: { refName, start, end: regionEnd, seq },
|
|
78
|
+
}));
|
|
79
|
+
}
|
|
80
|
+
observer.complete();
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* called to provide a hint that data tied to a certain region
|
|
85
|
+
* will not be needed for the forseeable future and can be purged
|
|
86
|
+
* from caches, etc
|
|
87
|
+
*/
|
|
88
|
+
freeResources( /* { region } */) { }
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=IndexedFastaAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IndexedFastaAdapter.js","sourceRoot":"","sources":["../../src/IndexedFastaAdapter/IndexedFastaAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { ConfigurationSchema } from '@jbrowse/core/configuration';
|
|
2
|
+
export default ConfigurationSchema('IndexedFastaAdapter', {
|
|
3
|
+
fastaLocation: {
|
|
4
|
+
type: 'fileLocation',
|
|
5
|
+
defaultValue: { uri: '/path/to/seq.fa', locationType: 'UriLocation' },
|
|
6
|
+
},
|
|
7
|
+
faiLocation: {
|
|
8
|
+
type: 'fileLocation',
|
|
9
|
+
defaultValue: { uri: '/path/to/seq.fa.fai', locationType: 'UriLocation' },
|
|
10
|
+
},
|
|
11
|
+
metadataLocation: {
|
|
12
|
+
description: 'Optional metadata file',
|
|
13
|
+
type: 'fileLocation',
|
|
14
|
+
defaultValue: {
|
|
15
|
+
uri: '/path/to/fa.metadata.yaml',
|
|
16
|
+
locationType: 'UriLocation',
|
|
17
|
+
},
|
|
18
|
+
},
|
|
19
|
+
}, { explicitlyTyped: true });
|
|
20
|
+
//# sourceMappingURL=configSchema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/IndexedFastaAdapter/configSchema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AAEjE,eAAe,mBAAmB,CAChC,qBAAqB,EACrB;IACE,aAAa,EAAE;QACb,IAAI,EAAE,cAAc;QACpB,YAAY,EAAE,EAAE,GAAG,EAAE,iBAAiB,EAAE,YAAY,EAAE,aAAa,EAAE;KACtE;IACD,WAAW,EAAE;QACX,IAAI,EAAE,cAAc;QACpB,YAAY,EAAE,EAAE,GAAG,EAAE,qBAAqB,EAAE,YAAY,EAAE,aAAa,EAAE;KAC1E;IACD,gBAAgB,EAAE;QAChB,WAAW,EAAE,wBAAwB;QACrC,IAAI,EAAE,cAAc;QACpB,YAAY,EAAE;YACZ,GAAG,EAAE,2BAA2B;YAChC,YAAY,EAAE,aAAa;SAC5B;KACF;CACF,EACD,EAAE,eAAe,EAAE,IAAI,EAAE,CAC1B,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default as configSchema } from './configSchema';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/IndexedFastaAdapter/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const configSchema: import("@jbrowse/core/configuration").AnyConfigurationSchemaType;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { ConfigurationSchema } from '@jbrowse/core/configuration';
|
|
2
|
+
import { configSchema as divSequenceRendererConfigSchema } from '../DivSequenceRenderer';
|
|
3
|
+
export const configSchema = ConfigurationSchema('LinearReferenceSequenceDisplay', { renderer: divSequenceRendererConfigSchema }, { explicitIdentifier: 'displayId', explicitlyTyped: true });
|
|
4
|
+
//# sourceMappingURL=configSchema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/LinearReferenceSequenceDisplay/configSchema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AACjE,OAAO,EAAE,YAAY,IAAI,+BAA+B,EAAE,MAAM,wBAAwB,CAAA;AAExF,MAAM,CAAC,MAAM,YAAY,GAAG,mBAAmB,CAC7C,gCAAgC,EAChC,EAAE,QAAQ,EAAE,+BAA+B,EAAE,EAC7C,EAAE,kBAAkB,EAAE,WAAW,EAAE,eAAe,EAAE,IAAI,EAAE,CAC3D,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/LinearReferenceSequenceDisplay/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA"}
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { AnyConfigurationSchemaType } from '@jbrowse/core/configuration';
|
|
3
|
+
export declare function modelFactory(configSchema: AnyConfigurationSchemaType): import("mobx-state-tree").IModelType<{
|
|
4
|
+
id: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<string>, [undefined]>;
|
|
5
|
+
type: import("mobx-state-tree").ISimpleType<string>;
|
|
6
|
+
rpcDriverName: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<string>>;
|
|
7
|
+
} & {
|
|
8
|
+
height: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<number>, [undefined]>;
|
|
9
|
+
blockState: import("mobx-state-tree").IMapType<import("mobx-state-tree").IModelType<{
|
|
10
|
+
key: import("mobx-state-tree").ISimpleType<string>;
|
|
11
|
+
region: import("mobx-state-tree").IModelType<{
|
|
12
|
+
refName: import("mobx-state-tree").ISimpleType<string>;
|
|
13
|
+
start: import("mobx-state-tree").ISimpleType<number>;
|
|
14
|
+
end: import("mobx-state-tree").ISimpleType<number>;
|
|
15
|
+
reversed: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<boolean>, [undefined]>;
|
|
16
|
+
} & {
|
|
17
|
+
assemblyName: import("mobx-state-tree").ISimpleType<string>;
|
|
18
|
+
}, {
|
|
19
|
+
setRefName(newRefName: string): void;
|
|
20
|
+
}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
|
|
21
|
+
reloadFlag: import("mobx-state-tree").IType<number | undefined, number, number>;
|
|
22
|
+
isLeftEndOfDisplayedRegion: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
|
|
23
|
+
isRightEndOfDisplayedRegion: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
|
|
24
|
+
}, {
|
|
25
|
+
renderInProgress: AbortController | undefined;
|
|
26
|
+
filled: boolean;
|
|
27
|
+
reactElement: import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>> | undefined;
|
|
28
|
+
features: Map<string, import("@jbrowse/core/util").Feature> | undefined;
|
|
29
|
+
layout: any;
|
|
30
|
+
status: string;
|
|
31
|
+
error: unknown;
|
|
32
|
+
message: string | undefined;
|
|
33
|
+
maxHeightReached: boolean;
|
|
34
|
+
ReactComponent: ({ model, }: {
|
|
35
|
+
model: any;
|
|
36
|
+
}) => any;
|
|
37
|
+
renderProps: any;
|
|
38
|
+
} & {
|
|
39
|
+
doReload(): void;
|
|
40
|
+
afterAttach(): void;
|
|
41
|
+
setStatus(message: string): void;
|
|
42
|
+
setLoading(abortController: AbortController): void;
|
|
43
|
+
setMessage(messageText: string): void;
|
|
44
|
+
setRendered(props: {
|
|
45
|
+
reactElement: import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
|
|
46
|
+
features: Map<string, import("@jbrowse/core/util").Feature>;
|
|
47
|
+
layout: any;
|
|
48
|
+
maxHeightReached: boolean;
|
|
49
|
+
renderProps: any;
|
|
50
|
+
} | undefined): void;
|
|
51
|
+
setError(error: unknown): void;
|
|
52
|
+
reload(): void;
|
|
53
|
+
beforeDestroy(): void;
|
|
54
|
+
}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
|
|
55
|
+
userBpPerPxLimit: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<number>>;
|
|
56
|
+
userByteSizeLimit: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<number>>;
|
|
57
|
+
} & {
|
|
58
|
+
type: import("mobx-state-tree").ISimpleType<"LinearReferenceSequenceDisplay">;
|
|
59
|
+
configuration: import("mobx-state-tree").ITypeUnion<any, any, any>;
|
|
60
|
+
showForward: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<boolean>, [undefined]>;
|
|
61
|
+
showReverse: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<boolean>, [undefined]>;
|
|
62
|
+
showTranslation: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<boolean>, [undefined]>;
|
|
63
|
+
height: import("mobx-state-tree").IType<number | undefined, number, number>;
|
|
64
|
+
}, {
|
|
65
|
+
rendererTypeName: string;
|
|
66
|
+
error: unknown;
|
|
67
|
+
} & {
|
|
68
|
+
readonly RenderingComponent: import("react").FC<{
|
|
69
|
+
model: {
|
|
70
|
+
id: string;
|
|
71
|
+
type: string;
|
|
72
|
+
rpcDriverName: string | undefined;
|
|
73
|
+
} & import("mobx-state-tree/dist/internal").NonEmptyObject & {
|
|
74
|
+
rendererTypeName: string;
|
|
75
|
+
error: unknown;
|
|
76
|
+
} & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IModelType<{
|
|
77
|
+
id: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<string>, [undefined]>;
|
|
78
|
+
type: import("mobx-state-tree").ISimpleType<string>;
|
|
79
|
+
rpcDriverName: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<string>>;
|
|
80
|
+
}, {
|
|
81
|
+
rendererTypeName: string;
|
|
82
|
+
error: unknown;
|
|
83
|
+
}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
|
|
84
|
+
onHorizontalScroll?: Function | undefined;
|
|
85
|
+
blockState?: Record<string, any> | undefined;
|
|
86
|
+
}>;
|
|
87
|
+
readonly DisplayBlurb: import("react").FC<{
|
|
88
|
+
model: {
|
|
89
|
+
id: string;
|
|
90
|
+
type: string;
|
|
91
|
+
rpcDriverName: string | undefined;
|
|
92
|
+
} & import("mobx-state-tree/dist/internal").NonEmptyObject & {
|
|
93
|
+
rendererTypeName: string;
|
|
94
|
+
error: unknown;
|
|
95
|
+
} & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IModelType<{
|
|
96
|
+
id: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<string>, [undefined]>;
|
|
97
|
+
type: import("mobx-state-tree").ISimpleType<string>;
|
|
98
|
+
rpcDriverName: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<string>>;
|
|
99
|
+
}, {
|
|
100
|
+
rendererTypeName: string;
|
|
101
|
+
error: unknown;
|
|
102
|
+
}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
|
|
103
|
+
}> | null;
|
|
104
|
+
readonly adapterConfig: any;
|
|
105
|
+
readonly parentTrack: any;
|
|
106
|
+
renderProps(): any;
|
|
107
|
+
readonly rendererType: any;
|
|
108
|
+
readonly DisplayMessageComponent: import("react").FC<any> | undefined;
|
|
109
|
+
trackMenuItems(): import("@jbrowse/core/ui").MenuItem[];
|
|
110
|
+
readonly viewMenuActions: import("@jbrowse/core/ui").MenuItem[];
|
|
111
|
+
regionCannotBeRendered(): undefined;
|
|
112
|
+
} & {
|
|
113
|
+
setError(error?: unknown): void;
|
|
114
|
+
setRpcDriverName(rpcDriverName: string): void;
|
|
115
|
+
reload(): void;
|
|
116
|
+
} & {
|
|
117
|
+
currBpPerPx: number;
|
|
118
|
+
message: string;
|
|
119
|
+
featureIdUnderMouse: string | undefined;
|
|
120
|
+
contextMenuFeature: import("@jbrowse/core/util").Feature | undefined;
|
|
121
|
+
scrollTop: number;
|
|
122
|
+
estimatedRegionStatsP: Promise<import("@jbrowse/core/data_adapters/BaseAdapter").Stats> | undefined;
|
|
123
|
+
estimatedRegionStats: import("@jbrowse/core/data_adapters/BaseAdapter").Stats | undefined;
|
|
124
|
+
} & {
|
|
125
|
+
readonly blockType: "dynamicBlocks" | "staticBlocks";
|
|
126
|
+
readonly blockDefinitions: import("@jbrowse/core/util/blockTypes").BlockSet;
|
|
127
|
+
} & {
|
|
128
|
+
readonly renderDelay: number;
|
|
129
|
+
readonly TooltipComponent: import("react").FC<any>;
|
|
130
|
+
readonly selectedFeatureId: string | undefined;
|
|
131
|
+
readonly DisplayMessageComponent: import("react").FC<any> | undefined;
|
|
132
|
+
} & {
|
|
133
|
+
readonly features: import("@jbrowse/core/util/compositeMap").default<string, import("@jbrowse/core/util").Feature>;
|
|
134
|
+
readonly featureUnderMouse: import("@jbrowse/core/util").Feature | undefined;
|
|
135
|
+
getFeatureOverlapping(blockKey: string, x: number, y: number): any;
|
|
136
|
+
getFeatureByID(blockKey: string, id: string): [number, number, number, number] | undefined;
|
|
137
|
+
searchFeatureByID(id: string): [number, number, number, number] | undefined;
|
|
138
|
+
readonly currentBytesRequested: number;
|
|
139
|
+
readonly currentFeatureScreenDensity: number;
|
|
140
|
+
readonly maxFeatureScreenDensity: any;
|
|
141
|
+
readonly estimatedStatsReady: boolean;
|
|
142
|
+
readonly maxAllowableBytes: number;
|
|
143
|
+
} & {
|
|
144
|
+
setMessage(message: string): void;
|
|
145
|
+
afterAttach(): void;
|
|
146
|
+
estimateRegionsStats(regions: import("@jbrowse/core/util").Region[], opts: {
|
|
147
|
+
headers?: Record<string, string> | undefined;
|
|
148
|
+
signal?: AbortSignal | undefined;
|
|
149
|
+
filters?: string[] | undefined;
|
|
150
|
+
}): Promise<{}>;
|
|
151
|
+
setRegionStatsP(p?: Promise<import("@jbrowse/core/data_adapters/BaseAdapter").Stats> | undefined): void;
|
|
152
|
+
setRegionStats(estimatedRegionStats?: import("@jbrowse/core/data_adapters/BaseAdapter").Stats | undefined): void;
|
|
153
|
+
clearRegionStats(): void;
|
|
154
|
+
setHeight(displayHeight: number): number;
|
|
155
|
+
resizeHeight(distance: number): number;
|
|
156
|
+
setScrollTop(scrollTop: number): void;
|
|
157
|
+
updateStatsLimit(stats: import("@jbrowse/core/data_adapters/BaseAdapter").Stats): void;
|
|
158
|
+
addBlock(key: string, block: import("@jbrowse/core/util/blockTypes").BaseBlock): void;
|
|
159
|
+
setCurrBpPerPx(n: number): void;
|
|
160
|
+
deleteBlock(key: string): void;
|
|
161
|
+
selectFeature(feature: import("@jbrowse/core/util").Feature): void;
|
|
162
|
+
clearFeatureSelection(): void;
|
|
163
|
+
setFeatureIdUnderMouse(feature: string | undefined): void;
|
|
164
|
+
reload(): void;
|
|
165
|
+
setContextMenuFeature(feature?: import("@jbrowse/core/util").Feature | undefined): void;
|
|
166
|
+
} & {
|
|
167
|
+
readonly regionTooLarge: boolean;
|
|
168
|
+
readonly regionTooLargeReason: string;
|
|
169
|
+
} & {
|
|
170
|
+
reload(): Promise<void>;
|
|
171
|
+
afterAttach(): void;
|
|
172
|
+
} & {
|
|
173
|
+
regionCannotBeRenderedText(_region: import("@jbrowse/core/util").Region): "" | "Force load to see features";
|
|
174
|
+
regionCannotBeRendered(_region: import("@jbrowse/core/util").Region): JSX.Element | undefined;
|
|
175
|
+
trackMenuItems(): import("@jbrowse/core/ui").MenuItem[];
|
|
176
|
+
contextMenuItems(): {
|
|
177
|
+
label: string;
|
|
178
|
+
icon: import("@mui/material/OverridableComponent").OverridableComponent<import("@mui/material").SvgIconTypeMap<{}, "svg">> & {
|
|
179
|
+
muiName: string;
|
|
180
|
+
};
|
|
181
|
+
onClick: () => void;
|
|
182
|
+
}[];
|
|
183
|
+
renderProps(): any;
|
|
184
|
+
} & {
|
|
185
|
+
renderSvg(opts: import("@jbrowse/plugin-linear-genome-view/src/LinearGenomeView").ExportSvgOptions & {
|
|
186
|
+
overrideHeight: number;
|
|
187
|
+
}): Promise<JSX.Element>;
|
|
188
|
+
} & {
|
|
189
|
+
renderProps(): any;
|
|
190
|
+
regionCannotBeRendered(): "Zoom in to see sequence" | undefined;
|
|
191
|
+
readonly rendererTypeName: any;
|
|
192
|
+
} & {
|
|
193
|
+
toggleShowForward(): void;
|
|
194
|
+
toggleShowReverse(): void;
|
|
195
|
+
toggleShowTranslation(): void;
|
|
196
|
+
} & {
|
|
197
|
+
trackMenuItems(): {
|
|
198
|
+
label: string;
|
|
199
|
+
type: string;
|
|
200
|
+
checked: boolean;
|
|
201
|
+
onClick: () => void;
|
|
202
|
+
}[];
|
|
203
|
+
}, import("mobx-state-tree")._NotCustomized, {
|
|
204
|
+
type: string;
|
|
205
|
+
height: number;
|
|
206
|
+
id: string;
|
|
207
|
+
rpcDriverName: string | undefined;
|
|
208
|
+
userBpPerPxLimit: number | undefined;
|
|
209
|
+
userByteSizeLimit: number | undefined;
|
|
210
|
+
} & import("mobx-state-tree")._NotCustomized>;
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { types } from 'mobx-state-tree';
|
|
2
|
+
import { BaseLinearDisplay, } from '@jbrowse/plugin-linear-genome-view';
|
|
3
|
+
import { ConfigurationReference, } from '@jbrowse/core/configuration';
|
|
4
|
+
import { getContainingView } from '@jbrowse/core/util';
|
|
5
|
+
export function modelFactory(configSchema) {
|
|
6
|
+
return types
|
|
7
|
+
.compose('LinearReferenceSequenceDisplay', BaseLinearDisplay, types.model({
|
|
8
|
+
type: types.literal('LinearReferenceSequenceDisplay'),
|
|
9
|
+
configuration: ConfigurationReference(configSchema),
|
|
10
|
+
showForward: types.optional(types.boolean, true),
|
|
11
|
+
showReverse: types.optional(types.boolean, true),
|
|
12
|
+
showTranslation: types.optional(types.boolean, true),
|
|
13
|
+
height: 180,
|
|
14
|
+
}))
|
|
15
|
+
.views(self => {
|
|
16
|
+
const { renderProps: superRenderProps } = self;
|
|
17
|
+
return {
|
|
18
|
+
renderProps() {
|
|
19
|
+
const { showForward, showReverse, showTranslation } = self;
|
|
20
|
+
return {
|
|
21
|
+
...superRenderProps(),
|
|
22
|
+
rpcDriverName: self.rpcDriverName,
|
|
23
|
+
config: self.configuration.renderer,
|
|
24
|
+
showForward,
|
|
25
|
+
showReverse,
|
|
26
|
+
showTranslation,
|
|
27
|
+
};
|
|
28
|
+
},
|
|
29
|
+
regionCannotBeRendered( /* region */) {
|
|
30
|
+
const view = getContainingView(self);
|
|
31
|
+
if (view && view.bpPerPx >= 1) {
|
|
32
|
+
return 'Zoom in to see sequence';
|
|
33
|
+
}
|
|
34
|
+
return undefined;
|
|
35
|
+
},
|
|
36
|
+
get rendererTypeName() {
|
|
37
|
+
return self.configuration.renderer.type;
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
})
|
|
41
|
+
.actions(self => ({
|
|
42
|
+
toggleShowForward() {
|
|
43
|
+
self.showForward = !self.showForward;
|
|
44
|
+
},
|
|
45
|
+
toggleShowReverse() {
|
|
46
|
+
self.showReverse = !self.showReverse;
|
|
47
|
+
},
|
|
48
|
+
toggleShowTranslation() {
|
|
49
|
+
self.showTranslation = !self.showTranslation;
|
|
50
|
+
},
|
|
51
|
+
}))
|
|
52
|
+
.views(self => ({
|
|
53
|
+
trackMenuItems() {
|
|
54
|
+
return [
|
|
55
|
+
{
|
|
56
|
+
label: 'Show forward',
|
|
57
|
+
type: 'checkbox',
|
|
58
|
+
checked: self.showForward,
|
|
59
|
+
onClick: () => {
|
|
60
|
+
self.toggleShowForward();
|
|
61
|
+
},
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
label: 'Show reverse',
|
|
65
|
+
type: 'checkbox',
|
|
66
|
+
checked: self.showReverse,
|
|
67
|
+
onClick: () => {
|
|
68
|
+
self.toggleShowReverse();
|
|
69
|
+
},
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
label: 'Show translation',
|
|
73
|
+
type: 'checkbox',
|
|
74
|
+
checked: self.showTranslation,
|
|
75
|
+
onClick: () => {
|
|
76
|
+
self.toggleShowTranslation();
|
|
77
|
+
},
|
|
78
|
+
},
|
|
79
|
+
];
|
|
80
|
+
},
|
|
81
|
+
}));
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"model.js","sourceRoot":"","sources":["../../src/LinearReferenceSequenceDisplay/model.ts"],"names":[],"mappings":"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"}
|