@jbrowse/plugin-data-management 2.2.2 → 2.3.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/AddTrackWidget/components/AddTrackWidget.js +28 -5
- package/dist/AddTrackWidget/components/AddTrackWidget.js.map +1 -1
- package/dist/AddTrackWidget/components/ConfirmTrack.d.ts +2 -3
- package/dist/AddTrackWidget/components/ConfirmTrack.js +30 -177
- package/dist/AddTrackWidget/components/ConfirmTrack.js.map +1 -1
- package/dist/AddTrackWidget/components/DefaultAddTrackWorkflow.js.map +1 -1
- package/dist/AddTrackWidget/components/TextIndexingConfig.d.ts +6 -0
- package/dist/AddTrackWidget/components/TextIndexingConfig.js +109 -0
- package/dist/AddTrackWidget/components/TextIndexingConfig.js.map +1 -0
- package/dist/AddTrackWidget/components/TrackAdapterSelector.d.ts +6 -0
- package/dist/AddTrackWidget/components/TrackAdapterSelector.js +50 -0
- package/dist/AddTrackWidget/components/TrackAdapterSelector.js.map +1 -0
- package/dist/AddTrackWidget/components/TrackTypeSelector.d.ts +6 -0
- package/dist/AddTrackWidget/components/TrackTypeSelector.js +27 -0
- package/dist/AddTrackWidget/components/TrackTypeSelector.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js +3 -4
- package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js.map +1 -1
- package/dist/HierarchicalTrackSelectorWidget/components/ToggleConnectionsDialog.js +3 -1
- package/dist/HierarchicalTrackSelectorWidget/components/ToggleConnectionsDialog.js.map +1 -1
- package/dist/HierarchicalTrackSelectorWidget/model.d.ts +2 -1
- package/dist/HierarchicalTrackSelectorWidget/model.js +5 -5
- package/dist/HierarchicalTrackSelectorWidget/model.js.map +1 -1
- package/dist/ucsc-trackhub/index.d.ts +2 -2
- package/dist/ucsc-trackhub/index.js.map +1 -1
- package/dist/ucsc-trackhub/model.d.ts +3 -2
- package/dist/ucsc-trackhub/model.js +41 -40
- package/dist/ucsc-trackhub/model.js.map +1 -1
- package/dist/ucsc-trackhub/ucscAssemblies.js.map +1 -1
- package/esm/AddTrackWidget/components/AddTrackWidget.js +6 -6
- package/esm/AddTrackWidget/components/AddTrackWidget.js.map +1 -1
- package/esm/AddTrackWidget/components/ConfirmTrack.d.ts +2 -3
- package/esm/AddTrackWidget/components/ConfirmTrack.js +28 -175
- package/esm/AddTrackWidget/components/ConfirmTrack.js.map +1 -1
- package/esm/AddTrackWidget/components/DefaultAddTrackWorkflow.js.map +1 -1
- package/esm/AddTrackWidget/components/TextIndexingConfig.d.ts +6 -0
- package/esm/AddTrackWidget/components/TextIndexingConfig.js +81 -0
- package/esm/AddTrackWidget/components/TextIndexingConfig.js.map +1 -0
- package/esm/AddTrackWidget/components/TrackAdapterSelector.d.ts +6 -0
- package/esm/AddTrackWidget/components/TrackAdapterSelector.js +45 -0
- package/esm/AddTrackWidget/components/TrackAdapterSelector.js.map +1 -0
- package/esm/AddTrackWidget/components/TrackTypeSelector.d.ts +6 -0
- package/esm/AddTrackWidget/components/TrackTypeSelector.js +22 -0
- package/esm/AddTrackWidget/components/TrackTypeSelector.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js +3 -4
- package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js.map +1 -1
- package/esm/HierarchicalTrackSelectorWidget/components/ToggleConnectionsDialog.js +3 -1
- package/esm/HierarchicalTrackSelectorWidget/components/ToggleConnectionsDialog.js.map +1 -1
- package/esm/HierarchicalTrackSelectorWidget/model.d.ts +2 -1
- package/esm/HierarchicalTrackSelectorWidget/model.js +5 -5
- package/esm/HierarchicalTrackSelectorWidget/model.js.map +1 -1
- package/esm/ucsc-trackhub/index.d.ts +2 -2
- package/esm/ucsc-trackhub/index.js.map +1 -1
- package/esm/ucsc-trackhub/model.d.ts +3 -2
- package/esm/ucsc-trackhub/model.js +41 -40
- package/esm/ucsc-trackhub/model.js.map +1 -1
- package/esm/ucsc-trackhub/ucscAssemblies.js.map +1 -1
- package/package.json +3 -4
- package/src/AddTrackWidget/components/AddTrackWidget.test.tsx +3 -4
- package/src/AddTrackWidget/components/AddTrackWidget.tsx +6 -9
- package/src/AddTrackWidget/components/ConfirmTrack.tsx +36 -296
- package/src/AddTrackWidget/components/DefaultAddTrackWorkflow.tsx +0 -1
- package/src/AddTrackWidget/components/TextIndexingConfig.tsx +134 -0
- package/src/AddTrackWidget/components/TrackAdapterSelector.tsx +73 -0
- package/src/AddTrackWidget/components/TrackTypeSelector.tsx +46 -0
- package/src/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.tsx +4 -4
- package/src/HierarchicalTrackSelectorWidget/components/ToggleConnectionsDialog.tsx +5 -1
- package/src/HierarchicalTrackSelectorWidget/components/__snapshots__/HierarchicalTrackSelector.test.tsx.snap +1 -1
- package/src/HierarchicalTrackSelectorWidget/model.ts +7 -7
- package/src/PluginStoreWidget/components/__snapshots__/PluginStoreWidget.test.js.snap +0 -22
- package/src/ucsc-trackhub/{index.js → index.ts} +0 -0
- package/src/ucsc-trackhub/model.ts +119 -0
- package/src/ucsc-trackhub/{ucscAssemblies.js → ucscAssemblies.ts} +0 -0
- package/src/ucsc-trackhub/model.js +0 -125
|
@@ -29,7 +29,7 @@ function filterTracks(tracks, self, assemblyName) {
|
|
|
29
29
|
return hasAnyOverlap(compatDisplays, trackDisplays);
|
|
30
30
|
});
|
|
31
31
|
}
|
|
32
|
-
export function generateHierarchy(model, trackConfigurations, collapsed) {
|
|
32
|
+
export function generateHierarchy(model, trackConfigurations, collapsed, extra) {
|
|
33
33
|
const hierarchy = { children: [] };
|
|
34
34
|
const { filterText, view } = model;
|
|
35
35
|
const session = getSession(model);
|
|
@@ -49,7 +49,7 @@ export function generateHierarchy(model, trackConfigurations, collapsed) {
|
|
|
49
49
|
for (let i = 0; i < categories.length; i++) {
|
|
50
50
|
const category = categories[i];
|
|
51
51
|
const ret = currLevel.children.find(c => c.name === category);
|
|
52
|
-
const id = categories.slice(0, i + 1).join(',');
|
|
52
|
+
const id = extra + '-' + categories.slice(0, i + 1).join(',');
|
|
53
53
|
if (!ret) {
|
|
54
54
|
const n = {
|
|
55
55
|
children: [],
|
|
@@ -166,7 +166,7 @@ export default function stateTreeFactory(pluginManager) {
|
|
|
166
166
|
const { assemblyManager } = getSession(self);
|
|
167
167
|
const assembly = assemblyManager.get(assemblyName);
|
|
168
168
|
const conns = (assembly &&
|
|
169
|
-
(connectionInstances === null || connectionInstances === void 0 ? void 0 : connectionInstances.
|
|
169
|
+
(connectionInstances === null || connectionInstances === void 0 ? void 0 : connectionInstances.map(c => ({
|
|
170
170
|
// @ts-ignore
|
|
171
171
|
id: getSnapshot(c).configuration,
|
|
172
172
|
name: getConf(c, 'name'),
|
|
@@ -174,7 +174,7 @@ export default function stateTreeFactory(pluginManager) {
|
|
|
174
174
|
state: {
|
|
175
175
|
expanded: true,
|
|
176
176
|
},
|
|
177
|
-
})))) ||
|
|
177
|
+
})).filter(f => f.children.length))) ||
|
|
178
178
|
[];
|
|
179
179
|
return {
|
|
180
180
|
name: 'Root',
|
|
@@ -188,7 +188,7 @@ export default function stateTreeFactory(pluginManager) {
|
|
|
188
188
|
connectionHierarchy(assemblyName, connection) {
|
|
189
189
|
return generateHierarchy(
|
|
190
190
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
191
|
-
self, self.connectionTrackConfigurations(assemblyName, connection), self.collapsed);
|
|
191
|
+
self, self.connectionTrackConfigurations(assemblyName, connection), self.collapsed, connection.name);
|
|
192
192
|
},
|
|
193
193
|
}));
|
|
194
194
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"model.js","sourceRoot":"","sources":["../../src/HierarchicalTrackSelectorWidget/model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,WAAW,EAAY,MAAM,iBAAiB,CAAA;AAC9D,OAAO,EACL,OAAO,EACP,cAAc,GAEf,MAAM,6BAA6B,CAAA;AACpC,OAAO,EAEL,MAAM,EACN,UAAU,EACV,MAAM,GACP,MAAM,oBAAoB,CAAA;AAC3B,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAA;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAA;AAGxD,SAAS,aAAa,CAAI,KAAU,EAAE,EAAE,KAAU,EAAE;IAClD,OAAO,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAA;AAC/C,CAAC;AAED,SAAS,YAAY,CACnB,MAAc,EACd,MAA6B,EAC7B,OAA6B;IAE7B,MAAM,UAAU,GAAG,cAAc,CAAC,MAAM,EAAE,UAAU,CAAyB,CAAA;IAC7E,MAAM,WAAW,GAAG,MAAM,CAAC,WAAW,EAAE,CAAA;IACxC,OAAO,CACL,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC;QACjE,CAAC,CAAC,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAA,CACxE,CAAA;AACH,CAAC;AAWD,SAAS,YAAY,CACnB,MAA+B,EAC/B,IAAgC,EAChC,YAAoB;IAEpB,MAAM,EAAE,eAAe,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,CAAA;IAC5C,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;IACtC,MAAM,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAC,YAAY,CAAC,CAAA;IAElD,IAAI,CAAC,QAAQ,EAAE;QACb,OAAO,EAAE,CAAA;KACV;IACD,MAAM,EAAE,UAAU,EAAE,GAAG,QAAQ,CAAA;IAC/B,OAAO,MAAM;SACV,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC,CAAC;SAC1E,MAAM,CAAC,CAAC,CAAC,EAAE;QACV,MAAM,EAAE,YAAY,EAAE,GAAG,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAClE,MAAM,cAAc,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC,CAAmB,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;QACxE,MAAM,aAAa,GAAG,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAmB,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;QACrE,OAAO,aAAa,CAAC,cAAc,EAAE,aAAa,CAAC,CAAA;IACrD,CAAC,CAAC,CAAA;AACN,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,KAAqC,EACrC,mBAA4C,EAC5C,SAAwD;
|
|
1
|
+
{"version":3,"file":"model.js","sourceRoot":"","sources":["../../src/HierarchicalTrackSelectorWidget/model.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export { default as modelFactory } from
|
|
2
|
-
export { default as configSchema } from
|
|
1
|
+
export { default as modelFactory } from './model';
|
|
2
|
+
export { default as configSchema } from './configSchema';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/ucsc-trackhub/index.
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/ucsc-trackhub/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,SAAS,CAAA;AACjD,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAA"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
|
|
1
|
+
import PluginManager from '@jbrowse/core/PluginManager';
|
|
2
|
+
export default function UCSCTrackHubConnection(pluginManager: PluginManager): import("mobx-state-tree").IModelType<{
|
|
2
3
|
name: import("mobx-state-tree").ISimpleType<string>;
|
|
3
4
|
tracks: import("mobx-state-tree").IArrayType<import("mobx-state-tree").IAnyModelType>;
|
|
4
5
|
} & {
|
|
@@ -23,5 +24,5 @@ export default function UCSCTrackHubConnection(pluginManager: any): import("mobx
|
|
|
23
24
|
} & import("mobx-state-tree").IStateTreeNode<import("@jbrowse/core/configuration").AnyConfigurationSchemaType>)[]): import("mobx-state-tree").IMSTArray<import("mobx-state-tree").IAnyModelType> & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IArrayType<import("mobx-state-tree").IAnyModelType>>;
|
|
24
25
|
clear(): void;
|
|
25
26
|
} & {
|
|
26
|
-
connect(): void
|
|
27
|
+
connect(): Promise<void>;
|
|
27
28
|
}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
|
|
@@ -2,81 +2,82 @@ import { BaseConnectionModelFactory } from '@jbrowse/core/pluggableElementTypes/
|
|
|
2
2
|
import { ConfigurationReference, readConfObject, getConf, } from '@jbrowse/core/configuration';
|
|
3
3
|
import { getSession } from '@jbrowse/core/util';
|
|
4
4
|
import { types } from 'mobx-state-tree';
|
|
5
|
+
// locals
|
|
5
6
|
import configSchema from './configSchema';
|
|
6
7
|
import { fetchGenomesFile, fetchHubFile, fetchTrackDbFile, generateTracks, } from './ucscTrackHub';
|
|
7
8
|
export default function UCSCTrackHubConnection(pluginManager) {
|
|
8
|
-
return types
|
|
9
|
-
.model({
|
|
9
|
+
return types
|
|
10
|
+
.compose('UCSCTrackHubConnection', BaseConnectionModelFactory(pluginManager), types.model({
|
|
10
11
|
configuration: ConfigurationReference(configSchema),
|
|
11
12
|
type: types.literal('UCSCTrackHubConnection'),
|
|
12
|
-
})
|
|
13
|
+
}))
|
|
13
14
|
.actions(self => ({
|
|
14
|
-
connect() {
|
|
15
|
-
const connectionName = getConf(self, 'name');
|
|
16
|
-
const hubFileLocation = getConf(self, 'hubTxtLocation');
|
|
15
|
+
async connect() {
|
|
17
16
|
const session = getSession(self);
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
const
|
|
17
|
+
try {
|
|
18
|
+
const connectionName = getConf(self, 'name');
|
|
19
|
+
const hubFileLocation = getConf(self, 'hubTxtLocation');
|
|
20
|
+
const hubFile = await fetchHubFile(hubFileLocation);
|
|
21
|
+
const genomeFile = hubFile.get('genomesFile');
|
|
22
|
+
if (!genomeFile) {
|
|
23
|
+
throw new Error('genomesFile not found on hub');
|
|
24
|
+
}
|
|
25
|
+
const hubUri = new URL(hubFileLocation.uri, hubFileLocation.baseUri);
|
|
26
|
+
const genomesFileLocation = hubUri
|
|
21
27
|
? {
|
|
22
|
-
uri: new URL(
|
|
28
|
+
uri: new URL(genomeFile, hubUri).href,
|
|
23
29
|
locationType: 'UriLocation',
|
|
24
30
|
}
|
|
25
31
|
: {
|
|
26
|
-
localPath:
|
|
32
|
+
localPath: genomeFile,
|
|
27
33
|
locationType: 'LocalPathLocation',
|
|
28
34
|
};
|
|
29
|
-
|
|
30
|
-
hubFile,
|
|
31
|
-
fetchGenomesFile(genomesFileLocation),
|
|
32
|
-
]);
|
|
33
|
-
})
|
|
34
|
-
.then(([hubFile, genomesFile]) => {
|
|
35
|
+
const genomesFile = await fetchGenomesFile(genomesFileLocation);
|
|
35
36
|
const trackDbData = [];
|
|
36
37
|
for (const [genomeName, genome] of genomesFile) {
|
|
37
38
|
const assemblyNames = getConf(self, 'assemblyNames');
|
|
38
39
|
if (assemblyNames.length > 0 &&
|
|
39
40
|
!assemblyNames.includes(genomeName)) {
|
|
40
|
-
|
|
41
|
+
continue;
|
|
41
42
|
}
|
|
42
|
-
const
|
|
43
|
-
if (!
|
|
43
|
+
const conf = session.assemblies.find(a => readConfObject(a, 'name') === genomeName);
|
|
44
|
+
if (!conf) {
|
|
44
45
|
throw new Error(`Cannot find assembly for "${genomeName}" from the genomes file for connection "${connectionName}"`);
|
|
45
46
|
}
|
|
46
|
-
const
|
|
47
|
+
const trackDb = genome.get('trackDb');
|
|
48
|
+
if (!trackDb) {
|
|
49
|
+
throw new Error('genomesFile not found on hub');
|
|
50
|
+
}
|
|
51
|
+
const trackDbFileLocation = hubUri
|
|
47
52
|
? {
|
|
48
|
-
uri: new URL(
|
|
53
|
+
uri: new URL(trackDb, new URL(genomeFile, hubUri)).href,
|
|
49
54
|
locationType: 'UriLocation',
|
|
50
55
|
}
|
|
51
56
|
: {
|
|
52
|
-
localPath:
|
|
57
|
+
localPath: trackDb,
|
|
53
58
|
locationType: 'LocalPathLocation',
|
|
54
59
|
};
|
|
55
|
-
trackDbData.push(
|
|
60
|
+
trackDbData.push([
|
|
56
61
|
trackDbFileLocation,
|
|
57
|
-
fetchTrackDbFile(trackDbFileLocation),
|
|
62
|
+
await fetchTrackDbFile(trackDbFileLocation),
|
|
58
63
|
genomeName,
|
|
59
|
-
|
|
60
|
-
])
|
|
64
|
+
conf,
|
|
65
|
+
]);
|
|
61
66
|
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
.then(trackDbData => {
|
|
65
|
-
for (const [trackDbFileLocation, trackDbFile, genomeName, assemblyConf,] of trackDbData) {
|
|
66
|
-
const sequenceAdapter = readConfObject(assemblyConf, [
|
|
67
|
+
for (const [trackDbFileLocation, trackDbFile, genomeName, conf,] of trackDbData) {
|
|
68
|
+
const sequenceAdapter = readConfObject(conf, [
|
|
67
69
|
'sequence',
|
|
68
70
|
'adapter',
|
|
69
71
|
]);
|
|
70
|
-
|
|
71
|
-
self.addTrackConfs(tracks);
|
|
72
|
+
self.addTrackConfs(generateTracks(trackDbFile, trackDbFileLocation, genomeName, sequenceAdapter));
|
|
72
73
|
}
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
console.error(
|
|
76
|
-
session.notify(`There was a problem connecting to the UCSC Track Hub "${self.name}". Please make sure you have entered a valid hub.txt file. The error that was thrown is: "${
|
|
74
|
+
}
|
|
75
|
+
catch (e) {
|
|
76
|
+
console.error(e);
|
|
77
|
+
session.notify(`There was a problem connecting to the UCSC Track Hub "${self.configuration.name}". Please make sure you have entered a valid hub.txt file. The error that was thrown is: "${e}"`, 'error');
|
|
77
78
|
session.breakConnection(self.configuration);
|
|
78
|
-
}
|
|
79
|
+
}
|
|
79
80
|
},
|
|
80
|
-
}))
|
|
81
|
+
}));
|
|
81
82
|
}
|
|
82
83
|
//# sourceMappingURL=model.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"model.js","sourceRoot":"","sources":["../../src/ucsc-trackhub/model.
|
|
1
|
+
{"version":3,"file":"model.js","sourceRoot":"","sources":["../../src/ucsc-trackhub/model.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ucscAssemblies.js","sourceRoot":"","sources":["../../src/ucsc-trackhub/ucscAssemblies.
|
|
1
|
+
{"version":3,"file":"ucscAssemblies.js","sourceRoot":"","sources":["../../src/ucsc-trackhub/ucscAssemblies.ts"],"names":[],"mappings":"AAAA,yEAAyE;AACzE,yFAAyF;AACzF,oDAAoD;AAEpD,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAoMP,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@jbrowse/plugin-data-management",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.3.0",
|
|
4
4
|
"description": "JBrowse 2 linear genome view",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"jbrowse",
|
|
@@ -51,9 +51,8 @@
|
|
|
51
51
|
"mobx": "^6.0.0",
|
|
52
52
|
"mobx-react": "^7.0.0",
|
|
53
53
|
"mobx-state-tree": "^5.0.0",
|
|
54
|
-
"prop-types": "^15.0.0",
|
|
55
54
|
"react": ">=16.8.0",
|
|
56
|
-
"tss-react": "^
|
|
55
|
+
"tss-react": "^4.0.0"
|
|
57
56
|
},
|
|
58
57
|
"publishConfig": {
|
|
59
58
|
"access": "public"
|
|
@@ -61,5 +60,5 @@
|
|
|
61
60
|
"distModule": "esm/index.js",
|
|
62
61
|
"srcModule": "src/index.ts",
|
|
63
62
|
"module": "esm/index.js",
|
|
64
|
-
"gitHead": "
|
|
63
|
+
"gitHead": "a85b280a8af4d1a11e81ab42913f5f6049e6e580"
|
|
65
64
|
}
|
|
@@ -103,16 +103,15 @@ describe('<AddTrackWidget />', () => {
|
|
|
103
103
|
})
|
|
104
104
|
fireEvent.click(getAllByTestId('addTrackNextButton')[0])
|
|
105
105
|
fireEvent.mouseDown(getByTestId('adapterTypeSelect'))
|
|
106
|
-
const bamAdapter = await findByText('
|
|
106
|
+
const bamAdapter = await findByText('BAM adapter')
|
|
107
107
|
fireEvent.click(bamAdapter)
|
|
108
108
|
fireEvent.change(getByTestId('trackNameInput'), {
|
|
109
109
|
target: { value: 'Test track name' },
|
|
110
110
|
})
|
|
111
111
|
fireEvent.mouseDown(getByTestId('trackTypeSelect'))
|
|
112
|
-
fireEvent.click(await findByText('
|
|
112
|
+
fireEvent.click(await findByText('Feature track'))
|
|
113
113
|
fireEvent.mouseDown(getByTestId('assemblyNameSelect'))
|
|
114
|
-
|
|
115
|
-
fireEvent.click(volMyt1[1])
|
|
114
|
+
fireEvent.click((await findAllByText('volMyt1'))[1])
|
|
116
115
|
fireEvent.click(getAllByTestId('addTrackNextButton')[0])
|
|
117
116
|
expect(session.sessionTracks.length).toBe(2)
|
|
118
117
|
})
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import React from 'react'
|
|
1
|
+
import React, { useState } from 'react'
|
|
2
2
|
import { observer } from 'mobx-react'
|
|
3
3
|
import { FormControl, FormHelperText, Select, MenuItem } from '@mui/material'
|
|
4
|
-
import {
|
|
5
|
-
import { getEnv, useLocalStorage } from '@jbrowse/core/util'
|
|
4
|
+
import { getEnv } from '@jbrowse/core/util'
|
|
6
5
|
|
|
7
6
|
// locals
|
|
8
7
|
import { AddTrackModel } from '../model'
|
|
@@ -10,19 +9,17 @@ import DefaultAddTrackWorkflow from './DefaultAddTrackWorkflow'
|
|
|
10
9
|
import PasteConfigWorkflow from './PasteConfigWorkflow'
|
|
11
10
|
|
|
12
11
|
function AddTrackSelector({ model }: { model: AddTrackModel }) {
|
|
13
|
-
const [val, setVal] =
|
|
12
|
+
const [val, setVal] = useState('Default add track workflow')
|
|
14
13
|
const { pluginManager } = getEnv(model)
|
|
15
|
-
const widgets = pluginManager.
|
|
16
|
-
'add track workflow',
|
|
17
|
-
) as AddTrackWorkflowType[]
|
|
14
|
+
const widgets = pluginManager.getAddTrackWorkflowElements()
|
|
18
15
|
const ComponentMap = {
|
|
19
|
-
Default: DefaultAddTrackWorkflow,
|
|
16
|
+
'Default add track workflow': DefaultAddTrackWorkflow,
|
|
20
17
|
'Add track JSON': PasteConfigWorkflow,
|
|
21
18
|
...Object.fromEntries(widgets.map(w => [w.name, w.ReactComponent])),
|
|
22
19
|
} as { [key: string]: React.FC<{ model: AddTrackModel }> }
|
|
23
20
|
|
|
24
21
|
// make sure the selected value is in the list
|
|
25
|
-
const val2 = ComponentMap[val] ? val : 'Default'
|
|
22
|
+
const val2 = ComponentMap[val] ? val : 'Default add track workflow'
|
|
26
23
|
const Component = ComponentMap[val2]
|
|
27
24
|
return (
|
|
28
25
|
<>
|