jbrowse-plugin-msaview 2.1.0 → 2.2.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/AddHighlightModel/GenomeMouseoverHighlight.js +3 -3
- package/dist/AddHighlightModel/GenomeMouseoverHighlight.js.map +1 -1
- package/dist/AddHighlightModel/MsaToGenomeHighlight.js +3 -1
- package/dist/AddHighlightModel/MsaToGenomeHighlight.js.map +1 -1
- package/dist/ExternalLink.d.ts +3 -0
- package/dist/ExternalLink.js +11 -0
- package/dist/ExternalLink.js.map +1 -0
- package/dist/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.js +28 -33
- package/dist/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.js.map +1 -1
- package/dist/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeLaunchView.js +0 -6
- package/dist/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeLaunchView.js.map +1 -1
- package/dist/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeUtils.d.ts +1 -0
- package/dist/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeUtils.js +12 -22
- package/dist/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeUtils.js.map +1 -1
- package/dist/LaunchMsaView/components/EnsemblGeneTree/gatherSequencesFromTree.d.ts +2 -0
- package/dist/LaunchMsaView/components/EnsemblGeneTree/gatherSequencesFromTree.js +20 -0
- package/dist/LaunchMsaView/components/EnsemblGeneTree/gatherSequencesFromTree.js.map +1 -0
- package/dist/LaunchMsaView/components/EnsemblGeneTree/types.d.ts +24 -0
- package/dist/LaunchMsaView/components/EnsemblGeneTree/types.js.map +1 -0
- package/dist/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.d.ts +10 -0
- package/dist/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.js +27 -0
- package/dist/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.js.map +1 -0
- package/dist/LaunchMsaView/components/LaunchMsaViewDialog.js +5 -5
- package/dist/LaunchMsaView/components/LaunchMsaViewDialog.js.map +1 -1
- package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/NcbiBlastPanel.d.ts → ManualMSALoader/ManualMSALoader.d.ts} +2 -2
- package/dist/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.js +103 -0
- package/dist/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.js.map +1 -0
- package/dist/LaunchMsaView/components/{EnsemblGeneTree → ManualMSALoader}/fetchGeneList.js.map +1 -1
- package/dist/LaunchMsaView/components/ManualMSALoader/launchView.d.ts +14 -0
- package/dist/LaunchMsaView/components/ManualMSALoader/launchView.js +12 -0
- package/dist/LaunchMsaView/components/ManualMSALoader/launchView.js.map +1 -0
- package/dist/LaunchMsaView/components/{MSALoader/MSALoader.d.ts → NCBIBlastQuery/NCBIBlastAutomaticPanel.d.ts} +4 -2
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.js +89 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.js.map +1 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.d.ts +10 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.js +55 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.js.map +1 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastMethodSelector.d.ts +5 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastMethodSelector.js +11 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastMethodSelector.js.map +1 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastPanel.d.ts +7 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastPanel.js +30 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastPanel.js.map +1 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBISettingsDialog.d.ts +5 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBISettingsDialog.js +26 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBISettingsDialog.js.map +1 -0
- package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/ncbiBlastLaunchView.d.ts → NCBIBlastQuery/blastLaunchView.d.ts} +2 -1
- package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/ncbiBlastLaunchView.js → NCBIBlastQuery/blastLaunchView.js} +3 -6
- package/dist/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.js.map +1 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/consts.d.ts +1 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/consts.js +2 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/consts.js.map +1 -0
- package/dist/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.js +17 -16
- package/dist/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.js.map +1 -1
- package/dist/LaunchMsaView/components/TranscriptSelector.d.ts +10 -0
- package/dist/LaunchMsaView/components/TranscriptSelector.js +45 -0
- package/dist/LaunchMsaView/components/TranscriptSelector.js.map +1 -0
- package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/calculateProteinSequence.d.ts → calculateProteinSequence.d.ts} +1 -2
- package/dist/LaunchMsaView/components/calculateProteinSequence.js +39 -0
- package/dist/LaunchMsaView/components/calculateProteinSequence.js.map +1 -0
- package/dist/LaunchMsaView/components/fetchSeq.js.map +1 -0
- package/dist/LaunchMsaView/components/types.js +2 -0
- package/dist/LaunchMsaView/components/types.js.map +1 -0
- package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/useFeatureSequence.d.ts → useFeatureSequence.d.ts} +2 -1
- package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/useFeatureSequence.js → useFeatureSequence.js} +12 -1
- package/dist/LaunchMsaView/components/useFeatureSequence.js.map +1 -0
- package/dist/LaunchMsaView/components/util.js.map +1 -0
- package/dist/LaunchMsaView/util.d.ts +5 -1
- package/dist/LaunchMsaView/util.js +15 -1
- package/dist/LaunchMsaView/util.js.map +1 -1
- package/dist/MsaViewPanel/components/LoadingBLAST.d.ts +2 -1
- package/dist/MsaViewPanel/components/LoadingBLAST.js +6 -6
- package/dist/MsaViewPanel/components/LoadingBLAST.js.map +1 -1
- package/dist/MsaViewPanel/components/MsaViewPanel.js +1 -1
- package/dist/MsaViewPanel/components/MsaViewPanel.js.map +1 -1
- package/dist/MsaViewPanel/components/RIDLink.d.ts +2 -1
- package/dist/MsaViewPanel/components/RIDLink.js +6 -9
- package/dist/MsaViewPanel/components/RIDLink.js.map +1 -1
- package/dist/MsaViewPanel/doLaunchBlast.js +18 -20
- package/dist/MsaViewPanel/doLaunchBlast.js.map +1 -1
- package/dist/MsaViewPanel/model.d.ts +3 -4
- package/dist/MsaViewPanel/model.js.map +1 -1
- package/dist/ReadOnlyTextField2.d.ts +4 -0
- package/dist/ReadOnlyTextField2.js +20 -0
- package/dist/ReadOnlyTextField2.js.map +1 -0
- package/dist/index.d.ts +15 -0
- package/dist/index.js +17 -0
- package/dist/index.js.map +1 -1
- package/dist/jbrowse-plugin-msaview.umd.production.min.js +41 -51
- package/dist/jbrowse-plugin-msaview.umd.production.min.js.map +4 -4
- package/dist/utils/fetch.d.ts +1 -1
- package/dist/utils/fetch.js.map +1 -1
- package/dist/utils/ncbiBlast.d.ts +2 -2
- package/dist/utils/ncbiBlast.js +29 -15
- package/dist/utils/ncbiBlast.js.map +1 -1
- package/dist/utils/types.d.ts +20 -0
- package/dist/utils/types.js +2 -0
- package/dist/utils/types.js.map +1 -0
- package/package.json +3 -3
- package/src/AddHighlightModel/GenomeMouseoverHighlight.tsx +3 -3
- package/src/AddHighlightModel/MsaToGenomeHighlight.tsx +2 -1
- package/src/ExternalLink.tsx +15 -0
- package/src/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.tsx +39 -55
- package/src/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeLaunchView.ts +0 -6
- package/src/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeUtils.ts +19 -54
- package/src/LaunchMsaView/components/EnsemblGeneTree/gatherSequencesFromTree.ts +22 -0
- package/src/LaunchMsaView/components/EnsemblGeneTree/types.ts +28 -0
- package/src/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.ts +29 -0
- package/src/LaunchMsaView/components/LaunchMsaViewDialog.tsx +9 -5
- package/src/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.tsx +219 -0
- package/src/LaunchMsaView/components/ManualMSALoader/launchView.ts +34 -0
- package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.tsx +226 -0
- package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.tsx +111 -0
- package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastMethodSelector.tsx +34 -0
- package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastPanel.tsx +82 -0
- package/src/LaunchMsaView/components/NCBIBlastQuery/NCBISettingsDialog.tsx +75 -0
- package/src/LaunchMsaView/components/{NewNCBIBlastQuery/ncbiBlastLaunchView.ts → NCBIBlastQuery/blastLaunchView.ts} +4 -5
- package/src/LaunchMsaView/components/NCBIBlastQuery/consts.ts +1 -0
- package/src/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.tsx +27 -37
- package/src/LaunchMsaView/components/TranscriptSelector.tsx +99 -0
- package/src/LaunchMsaView/components/{NewNCBIBlastQuery/calculateProteinSequence.ts → calculateProteinSequence.ts} +12 -22
- package/src/LaunchMsaView/components/{NewNCBIBlastQuery/useFeatureSequence.ts → useFeatureSequence.ts} +16 -2
- package/src/LaunchMsaView/util.ts +22 -2
- package/src/MsaViewPanel/components/LoadingBLAST.tsx +26 -8
- package/src/MsaViewPanel/components/MsaViewPanel.tsx +5 -1
- package/src/MsaViewPanel/components/RIDLink.tsx +8 -8
- package/src/MsaViewPanel/doLaunchBlast.ts +29 -30
- package/src/MsaViewPanel/model.ts +1 -0
- package/src/ReadOnlyTextField2.tsx +33 -0
- package/src/index.ts +23 -0
- package/src/utils/fetch.ts +2 -2
- package/src/utils/ncbiBlast.ts +40 -30
- package/src/utils/types.ts +14 -0
- package/dist/LaunchMsaView/components/MSALoader/MSALoader.js +0 -94
- package/dist/LaunchMsaView/components/MSALoader/MSALoader.js.map +0 -1
- package/dist/LaunchMsaView/components/MSALoader/fetchGeneList.d.ts +0 -1
- package/dist/LaunchMsaView/components/MSALoader/fetchGeneList.js +0 -12
- package/dist/LaunchMsaView/components/MSALoader/fetchGeneList.js.map +0 -1
- package/dist/LaunchMsaView/components/MSALoader/preCalculatedLaunchView.d.ts +0 -9
- package/dist/LaunchMsaView/components/MSALoader/preCalculatedLaunchView.js +0 -36
- package/dist/LaunchMsaView/components/MSALoader/preCalculatedLaunchView.js.map +0 -1
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/NcbiBlastPanel.js +0 -85
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/NcbiBlastPanel.js.map +0 -1
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/calculateProteinSequence.js +0 -47
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/calculateProteinSequence.js.map +0 -1
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/fetchSeq.js.map +0 -1
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/index.d.ts +0 -1
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/index.js +0 -2
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/index.js.map +0 -1
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/ncbiBlastLaunchView.js.map +0 -1
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/types.js.map +0 -1
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/useFeatureSequence.js.map +0 -1
- package/dist/LaunchMsaView/components/NewNCBIBlastQuery/util.js.map +0 -1
- package/dist/OpenInNewIcon.d.ts +0 -3
- package/dist/OpenInNewIcon.js +0 -8
- package/dist/OpenInNewIcon.js.map +0 -1
- package/src/LaunchMsaView/components/MSALoader/MSALoader.tsx +0 -130
- package/src/LaunchMsaView/components/MSALoader/fetchGeneList.ts +0 -13
- package/src/LaunchMsaView/components/MSALoader/preCalculatedLaunchView.ts +0 -55
- package/src/LaunchMsaView/components/NewNCBIBlastQuery/NcbiBlastPanel.tsx +0 -171
- package/src/LaunchMsaView/components/NewNCBIBlastQuery/index.tsx +0 -1
- package/src/OpenInNewIcon.tsx +0 -14
- /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery → EnsemblGeneTree}/types.js +0 -0
- /package/dist/LaunchMsaView/components/{EnsemblGeneTree → ManualMSALoader}/fetchGeneList.d.ts +0 -0
- /package/dist/LaunchMsaView/components/{EnsemblGeneTree → ManualMSALoader}/fetchGeneList.js +0 -0
- /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/fetchSeq.d.ts → fetchSeq.d.ts} +0 -0
- /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/fetchSeq.js → fetchSeq.js} +0 -0
- /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/types.d.ts → types.d.ts} +0 -0
- /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/util.d.ts → util.d.ts} +0 -0
- /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/util.js → util.js} +0 -0
- /package/src/LaunchMsaView/components/{EnsemblGeneTree → ManualMSALoader}/fetchGeneList.ts +0 -0
- /package/src/LaunchMsaView/components/{NewNCBIBlastQuery/fetchSeq.ts → fetchSeq.ts} +0 -0
- /package/src/LaunchMsaView/components/{NewNCBIBlastQuery/types.ts → types.ts} +0 -0
- /package/src/LaunchMsaView/components/{NewNCBIBlastQuery/util.ts → util.ts} +0 -0
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import React, { useEffect, useState } from 'react';
|
|
2
|
+
import { ErrorMessage } from '@jbrowse/core/ui';
|
|
3
|
+
import { getContainingView, } from '@jbrowse/core/util';
|
|
4
|
+
import { Button, DialogActions, DialogContent, MenuItem, Typography, } from '@mui/material';
|
|
5
|
+
import { observer } from 'mobx-react';
|
|
6
|
+
import { makeStyles } from 'tss-react/mui';
|
|
7
|
+
import { blastLaunchView } from './blastLaunchView';
|
|
8
|
+
import TextField2 from '../../../TextField2';
|
|
9
|
+
import { getGeneDisplayName, getId, getTranscriptDisplayName, getTranscriptFeatures, } from '../../util';
|
|
10
|
+
import TranscriptSelector from '../TranscriptSelector';
|
|
11
|
+
import { useFeatureSequence } from '../useFeatureSequence';
|
|
12
|
+
const useStyles = makeStyles()({
|
|
13
|
+
dialogContent: {
|
|
14
|
+
width: '80em',
|
|
15
|
+
},
|
|
16
|
+
textAreaFont: {
|
|
17
|
+
fontFamily: 'Courier New',
|
|
18
|
+
},
|
|
19
|
+
});
|
|
20
|
+
const blastDatabaseOptions = ['nr', 'nr_cluster_seq'];
|
|
21
|
+
const msaAlgorithms = ['clustalo', 'muscle', 'kalign', 'mafft'];
|
|
22
|
+
const blastPrograms = ['blastp', 'quick-blastp'];
|
|
23
|
+
const NCBIBlastAutomaticPanel = observer(function ({ handleClose, feature, model, children, baseUrl, }) {
|
|
24
|
+
const { classes } = useStyles();
|
|
25
|
+
const view = getContainingView(model);
|
|
26
|
+
const [launchViewError, setLaunchViewError] = useState();
|
|
27
|
+
const [selectedBlastDatabase, setSelectedBlastDatabase] = useState('nr');
|
|
28
|
+
const [selectedMsaAlgorithm, setSelectedMsaAlgorithm] = useState('clustalo');
|
|
29
|
+
const options = getTranscriptFeatures(feature);
|
|
30
|
+
const [selectedTranscriptId, setSelectedTranscriptId] = useState(getId(options[0]));
|
|
31
|
+
const [selectedBlastProgram, setSelectedBlastProgram] = useState('blastp');
|
|
32
|
+
const selectedTranscript = options.find(val => getId(val) === selectedTranscriptId);
|
|
33
|
+
const { error, proteinSequence } = useFeatureSequence({
|
|
34
|
+
view,
|
|
35
|
+
feature: selectedTranscript,
|
|
36
|
+
});
|
|
37
|
+
useEffect(() => {
|
|
38
|
+
if (selectedBlastDatabase === 'nr_cluster_seq') {
|
|
39
|
+
setSelectedBlastProgram('blastp');
|
|
40
|
+
}
|
|
41
|
+
}, [selectedBlastDatabase]);
|
|
42
|
+
const e = error ?? launchViewError;
|
|
43
|
+
return (React.createElement(React.Fragment, null,
|
|
44
|
+
React.createElement(DialogContent, { className: classes.dialogContent },
|
|
45
|
+
children,
|
|
46
|
+
e ? React.createElement(ErrorMessage, { error: e }) : null,
|
|
47
|
+
React.createElement(TextField2, { variant: "outlined", label: "BLAST database", style: { width: 150 }, select: true, value: selectedBlastDatabase, onChange: event => {
|
|
48
|
+
setSelectedBlastDatabase(event.target.value);
|
|
49
|
+
} }, blastDatabaseOptions.map(val => (React.createElement(MenuItem, { value: val, key: val }, val)))),
|
|
50
|
+
React.createElement(TextField2, { variant: "outlined", label: "MSA Algorithm", style: { width: 150 }, select: true, value: selectedMsaAlgorithm, onChange: event => {
|
|
51
|
+
setSelectedMsaAlgorithm(event.target.value);
|
|
52
|
+
} }, msaAlgorithms.map(val => (React.createElement(MenuItem, { value: val, key: val }, val)))),
|
|
53
|
+
React.createElement("div", { style: { display: 'flex' } },
|
|
54
|
+
React.createElement(TextField2, { variant: "outlined", label: "BLAST program", disabled: selectedBlastDatabase === 'nr_cluster_seq', style: { width: 150 }, select: true, value: selectedBlastProgram, onChange: event => {
|
|
55
|
+
setSelectedBlastProgram(event.target.value);
|
|
56
|
+
} }, blastPrograms.map(val => (React.createElement(MenuItem, { value: val, key: val }, val)))),
|
|
57
|
+
selectedBlastDatabase === 'nr_cluster_seq' ? (React.createElement(Typography, { variant: "subtitle2", style: { marginLeft: 4, alignContent: 'center' } }, "Can only use blastp on nr_cluster_seq")) : null),
|
|
58
|
+
React.createElement(TranscriptSelector, { feature: feature, options: options, selectedTranscriptId: selectedTranscriptId, onTranscriptChange: setSelectedTranscriptId, proteinSequence: proteinSequence }),
|
|
59
|
+
React.createElement(Typography, { style: { marginTop: 20 } }, "This panel will automatically submit a query to NCBI. Using blastp can take 10+ minutes to run, quick-blastp is generally a lot faster but is not available for the clustered database. After completion, all the hits will be run through a multiple sequence alignment. Note: we are not able to currently run NCBI COBALT automatically on the BLAST results, even though that is the method NCBI uses on their website. If you need a COBALT alignment, please use the manual approach of submitting BLAST yourself and downloading the resulting files")),
|
|
60
|
+
React.createElement(DialogActions, null,
|
|
61
|
+
React.createElement(Button, { color: "primary", variant: "contained", onClick: () => {
|
|
62
|
+
try {
|
|
63
|
+
setLaunchViewError(undefined);
|
|
64
|
+
blastLaunchView({
|
|
65
|
+
feature: selectedTranscript,
|
|
66
|
+
view,
|
|
67
|
+
newViewTitle: `BLAST - ${getGeneDisplayName(feature)} - ${getTranscriptDisplayName(selectedTranscript)}`,
|
|
68
|
+
blastParams: {
|
|
69
|
+
baseUrl,
|
|
70
|
+
blastProgram: selectedBlastProgram,
|
|
71
|
+
blastDatabase: selectedBlastDatabase,
|
|
72
|
+
msaAlgorithm: selectedMsaAlgorithm,
|
|
73
|
+
selectedTranscript,
|
|
74
|
+
proteinSequence,
|
|
75
|
+
},
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
catch (e) {
|
|
79
|
+
console.error(e);
|
|
80
|
+
setLaunchViewError(e);
|
|
81
|
+
}
|
|
82
|
+
handleClose();
|
|
83
|
+
}, disabled: !proteinSequence }, "Submit"),
|
|
84
|
+
React.createElement(Button, { color: "secondary", variant: "contained", onClick: () => {
|
|
85
|
+
handleClose();
|
|
86
|
+
} }, "Cancel"))));
|
|
87
|
+
});
|
|
88
|
+
export default NCBIBlastAutomaticPanel;
|
|
89
|
+
//# sourceMappingURL=NCBIBlastAutomaticPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NCBIBlastAutomaticPanel.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { AbstractTrackModel, Feature } from '@jbrowse/core/util';
|
|
3
|
+
declare const NCBIBlastManualPanel: ({ handleClose, feature, model, children, baseUrl, }: {
|
|
4
|
+
children: React.ReactNode;
|
|
5
|
+
model: AbstractTrackModel;
|
|
6
|
+
feature: Feature;
|
|
7
|
+
baseUrl: string;
|
|
8
|
+
handleClose: () => void;
|
|
9
|
+
}) => React.JSX.Element;
|
|
10
|
+
export default NCBIBlastManualPanel;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { ErrorMessage } from '@jbrowse/core/ui';
|
|
3
|
+
import { getContainingView, shorten2 } from '@jbrowse/core/util';
|
|
4
|
+
import { Button, DialogActions, DialogContent, Typography } from '@mui/material';
|
|
5
|
+
import { observer } from 'mobx-react';
|
|
6
|
+
import { makeStyles } from 'tss-react/mui';
|
|
7
|
+
import ExternalLink from '../../../ExternalLink';
|
|
8
|
+
import { getId, getTranscriptFeatures } from '../../util';
|
|
9
|
+
import TranscriptSelector from '../TranscriptSelector';
|
|
10
|
+
import { useFeatureSequence } from '../useFeatureSequence';
|
|
11
|
+
const useStyles = makeStyles()({
|
|
12
|
+
dialogContent: {
|
|
13
|
+
width: '80em',
|
|
14
|
+
},
|
|
15
|
+
textAreaFont: {
|
|
16
|
+
fontFamily: 'Courier New',
|
|
17
|
+
},
|
|
18
|
+
ncbiLink: {
|
|
19
|
+
wordBreak: 'break-all',
|
|
20
|
+
margin: 30,
|
|
21
|
+
maxWidth: 600,
|
|
22
|
+
},
|
|
23
|
+
});
|
|
24
|
+
const NCBIBlastManualPanel = observer(function ({ handleClose, feature, model, children, baseUrl, }) {
|
|
25
|
+
const { classes } = useStyles();
|
|
26
|
+
const view = getContainingView(model);
|
|
27
|
+
const options = getTranscriptFeatures(feature);
|
|
28
|
+
const [userSelection, setUserSelection] = useState(getId(options[0]));
|
|
29
|
+
const selectedTranscript = options.find(val => getId(val) === userSelection);
|
|
30
|
+
const { proteinSequence, error } = useFeatureSequence({
|
|
31
|
+
view,
|
|
32
|
+
feature: selectedTranscript,
|
|
33
|
+
});
|
|
34
|
+
const s2 = proteinSequence.replaceAll('*', '').replaceAll('&', '');
|
|
35
|
+
const link = `${baseUrl}?PAGE_TYPE=BlastSearch&PAGE=Proteins&PROGRAM=blastp&QUERY=${s2}`;
|
|
36
|
+
const link2 = `${baseUrl}?PAGE_TYPE=BlastSearch&PAGE=Proteins&PROGRAM=blastp&QUERY=${shorten2(s2, 10)}`;
|
|
37
|
+
return (React.createElement(React.Fragment, null,
|
|
38
|
+
React.createElement(DialogContent, { className: classes.dialogContent },
|
|
39
|
+
children,
|
|
40
|
+
error ? React.createElement(ErrorMessage, { error: error }) : null,
|
|
41
|
+
React.createElement(TranscriptSelector, { feature: feature, options: options, selectedTranscriptId: userSelection, onTranscriptChange: setUserSelection, proteinSequence: proteinSequence }),
|
|
42
|
+
proteinSequence ? (React.createElement("div", { className: classes.ncbiLink },
|
|
43
|
+
"Link to NCBI BLAST: ",
|
|
44
|
+
React.createElement(ExternalLink, { href: link }, link2))) : null,
|
|
45
|
+
React.createElement(Typography, { style: { marginTop: 20 } }, "Click the link above and run your BLAST query, and once you have results, click \"Multiple Alignment\" at the top of the results page to be redirected to COBALT, NCBI's multiple sequence aligner. Once COBALT completes, you can download an MSA (.aln file) and optionally a Newick tree (.nh) and paste the results into JBrowse")),
|
|
46
|
+
React.createElement(DialogActions, null,
|
|
47
|
+
React.createElement(Button, { color: "primary", variant: "contained", onClick: () => {
|
|
48
|
+
handleClose();
|
|
49
|
+
} }, "Submit"),
|
|
50
|
+
React.createElement(Button, { color: "secondary", variant: "contained", onClick: () => {
|
|
51
|
+
handleClose();
|
|
52
|
+
} }, "Close"))));
|
|
53
|
+
});
|
|
54
|
+
export default NCBIBlastManualPanel;
|
|
55
|
+
//# sourceMappingURL=NCBIBlastManualPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NCBIBlastManualPanel.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { FormControl, FormControlLabel, Radio, RadioGroup } from '@mui/material';
|
|
3
|
+
export default function NCBIBlastMethodSelector({ lookupMethod, setLookupMethod, }) {
|
|
4
|
+
return (React.createElement(FormControl, { component: "fieldset" },
|
|
5
|
+
React.createElement(RadioGroup, { row: true, value: lookupMethod, onChange: event => {
|
|
6
|
+
setLookupMethod(event.target.value);
|
|
7
|
+
} },
|
|
8
|
+
React.createElement(FormControlLabel, { value: "automatic", control: React.createElement(Radio, null), label: "Run NCBI BLAST and load results automatically" }),
|
|
9
|
+
React.createElement(FormControlLabel, { value: "manual", control: React.createElement(Radio, null), label: "Link to NCBI BLAST and import results manually" }))));
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=NCBIBlastMethodSelector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NCBIBlastMethodSelector.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastMethodSelector.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAEhF,MAAM,CAAC,OAAO,UAAU,uBAAuB,CAAC,EAC9C,YAAY,EACZ,eAAe,GAIhB;IACC,OAAO,CACL,oBAAC,WAAW,IAAC,SAAS,EAAC,UAAU;QAC/B,oBAAC,UAAU,IACT,GAAG,QACH,KAAK,EAAE,YAAY,EACnB,QAAQ,EAAE,KAAK,CAAC,EAAE;gBAChB,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;YACrC,CAAC;YAED,oBAAC,gBAAgB,IACf,KAAK,EAAC,WAAW,EACjB,OAAO,EAAE,oBAAC,KAAK,OAAG,EAClB,KAAK,EAAC,+CAA+C,GACrD;YACF,oBAAC,gBAAgB,IACf,KAAK,EAAC,QAAQ,EACd,OAAO,EAAE,oBAAC,KAAK,OAAG,EAClB,KAAK,EAAC,gDAAgD,GACtD,CACS,CACD,CACf,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { AbstractTrackModel, Feature } from '@jbrowse/core/util';
|
|
3
|
+
export default function NCBIBlastPanel({ handleClose, model, feature, }: {
|
|
4
|
+
handleClose: () => void;
|
|
5
|
+
model: AbstractTrackModel;
|
|
6
|
+
feature: Feature;
|
|
7
|
+
}): React.JSX.Element;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { useLocalStorage } from '@jbrowse/core/util';
|
|
3
|
+
import SettingsIcon from '@mui/icons-material/Settings';
|
|
4
|
+
import { IconButton } from '@mui/material';
|
|
5
|
+
import NCBIBlastAutomaticPanel from './NCBIBlastAutomaticPanel';
|
|
6
|
+
import NCBIBlastManualPanel from './NCBIBlastManualPanel';
|
|
7
|
+
import NCBIBlastMethodSelector from './NCBIBlastMethodSelector';
|
|
8
|
+
import NCBISettingsDialog from './NCBISettingsDialog';
|
|
9
|
+
import { BASE_BLAST_URL } from './consts';
|
|
10
|
+
export default function NCBIBlastPanel({ handleClose, model, feature, }) {
|
|
11
|
+
const [lookupMethod, setLookupMethod] = useState('automatic');
|
|
12
|
+
const [baseUrl, setBaseUrl] = useLocalStorage('msa-blastRootUrl', BASE_BLAST_URL);
|
|
13
|
+
const [settingsOpen, setSettingsOpen] = useState(false);
|
|
14
|
+
return (React.createElement(React.Fragment, null,
|
|
15
|
+
React.createElement(IconButton, { style: { float: 'right' }, size: "small", onClick: () => {
|
|
16
|
+
setSettingsOpen(true);
|
|
17
|
+
} },
|
|
18
|
+
React.createElement(SettingsIcon, null)),
|
|
19
|
+
lookupMethod === 'automatic' ? (React.createElement(NCBIBlastAutomaticPanel, { model: model, feature: feature, handleClose: handleClose, baseUrl: baseUrl },
|
|
20
|
+
React.createElement(NCBIBlastMethodSelector, { lookupMethod: lookupMethod, setLookupMethod: setLookupMethod }))) : null,
|
|
21
|
+
lookupMethod === 'manual' ? (React.createElement(NCBIBlastManualPanel, { model: model, feature: feature, handleClose: handleClose, baseUrl: baseUrl },
|
|
22
|
+
React.createElement(NCBIBlastMethodSelector, { lookupMethod: lookupMethod, setLookupMethod: setLookupMethod }))) : null,
|
|
23
|
+
settingsOpen ? (React.createElement(NCBISettingsDialog, { baseUrl: baseUrl, handleClose: arg => {
|
|
24
|
+
if (arg) {
|
|
25
|
+
setBaseUrl(arg);
|
|
26
|
+
}
|
|
27
|
+
setSettingsOpen(false);
|
|
28
|
+
} })) : null));
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=NCBIBlastPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NCBIBlastPanel.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEvC,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACpD,OAAO,YAAY,MAAM,8BAA8B,CAAA;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,OAAO,uBAAuB,MAAM,2BAA2B,CAAA;AAC/D,OAAO,oBAAoB,MAAM,wBAAwB,CAAA;AACzD,OAAO,uBAAuB,MAAM,2BAA2B,CAAA;AAC/D,OAAO,kBAAkB,MAAM,sBAAsB,CAAA;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAA;AAIzC,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,EACrC,WAAW,EACX,KAAK,EACL,OAAO,GAKR;IACC,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,WAAW,CAAC,CAAA;IAC7D,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,eAAe,CAC3C,kBAAkB,EAClB,cAAc,CACf,CAAA;IACD,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAEvD,OAAO,CACL;QACE,oBAAC,UAAU,IACT,KAAK,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,EACzB,IAAI,EAAC,OAAO,EACZ,OAAO,EAAE,GAAG,EAAE;gBACZ,eAAe,CAAC,IAAI,CAAC,CAAA;YACvB,CAAC;YAED,oBAAC,YAAY,OAAG,CACL;QAEZ,YAAY,KAAK,WAAW,CAAC,CAAC,CAAC,CAC9B,oBAAC,uBAAuB,IACtB,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,OAAO,EAChB,WAAW,EAAE,WAAW,EACxB,OAAO,EAAE,OAAO;YAEhB,oBAAC,uBAAuB,IACtB,YAAY,EAAE,YAAY,EAC1B,eAAe,EAAE,eAAe,GAChC,CACsB,CAC3B,CAAC,CAAC,CAAC,IAAI;QACP,YAAY,KAAK,QAAQ,CAAC,CAAC,CAAC,CAC3B,oBAAC,oBAAoB,IACnB,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,OAAO,EAChB,WAAW,EAAE,WAAW,EACxB,OAAO,EAAE,OAAO;YAEhB,oBAAC,uBAAuB,IACtB,YAAY,EAAE,YAAY,EAC1B,eAAe,EAAE,eAAe,GAChC,CACmB,CACxB,CAAC,CAAC,CAAC,IAAI;QACP,YAAY,CAAC,CAAC,CAAC,CACd,oBAAC,kBAAkB,IACjB,OAAO,EAAE,OAAO,EAChB,WAAW,EAAE,GAAG,CAAC,EAAE;gBACjB,IAAI,GAAG,EAAE,CAAC;oBACR,UAAU,CAAC,GAAG,CAAC,CAAA;gBACjB,CAAC;gBACD,eAAe,CAAC,KAAK,CAAC,CAAA;YACxB,CAAC,GACD,CACH,CAAC,CAAC,CAAC,IAAI,CACP,CACJ,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { Button, Dialog, DialogActions, DialogContent, DialogTitle, } from '@mui/material';
|
|
3
|
+
import { BASE_BLAST_URL } from './consts';
|
|
4
|
+
import TextField2 from '../../../TextField2';
|
|
5
|
+
export default function NCBISettingsDialog({ handleClose, baseUrl, }) {
|
|
6
|
+
const [tempBaseUrl, setTempBaseUrl] = useState(baseUrl);
|
|
7
|
+
return (React.createElement(Dialog, { open: true, maxWidth: "lg", onClose: () => {
|
|
8
|
+
handleClose();
|
|
9
|
+
} },
|
|
10
|
+
React.createElement(DialogTitle, null, "BLAST Settings"),
|
|
11
|
+
React.createElement(DialogContent, null,
|
|
12
|
+
React.createElement(TextField2, { autoFocus: true, margin: "dense", label: "BLAST Base URL", fullWidth: true, variant: "outlined", value: tempBaseUrl, style: { minWidth: '300px' }, onChange: e => {
|
|
13
|
+
setTempBaseUrl(e.target.value);
|
|
14
|
+
} }),
|
|
15
|
+
React.createElement(Button, { variant: "contained", onClick: () => {
|
|
16
|
+
setTempBaseUrl(BASE_BLAST_URL);
|
|
17
|
+
} }, "Reset")),
|
|
18
|
+
React.createElement(DialogActions, null,
|
|
19
|
+
React.createElement(Button, { variant: "contained", color: "secondary", onClick: () => {
|
|
20
|
+
handleClose();
|
|
21
|
+
} }, "Cancel"),
|
|
22
|
+
React.createElement(Button, { color: "primary", variant: "contained", onClick: () => {
|
|
23
|
+
handleClose(tempBaseUrl);
|
|
24
|
+
} }, "Save"))));
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=NCBISettingsDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NCBISettingsDialog.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/NCBIBlastQuery/NCBISettingsDialog.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEvC,OAAO,EACL,MAAM,EACN,MAAM,EACN,aAAa,EACb,aAAa,EACb,WAAW,GACZ,MAAM,eAAe,CAAA;AAEtB,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAA;AACzC,OAAO,UAAU,MAAM,qBAAqB,CAAA;AAE5C,MAAM,CAAC,OAAO,UAAU,kBAAkB,CAAC,EACzC,WAAW,EACX,OAAO,GAIR;IACC,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAA;IACvD,OAAO,CACL,oBAAC,MAAM,IACL,IAAI,QACJ,QAAQ,EAAC,IAAI,EACb,OAAO,EAAE,GAAG,EAAE;YACZ,WAAW,EAAE,CAAA;QACf,CAAC;QAED,oBAAC,WAAW,yBAA6B;QACzC,oBAAC,aAAa;YACZ,oBAAC,UAAU,IACT,SAAS,QACT,MAAM,EAAC,OAAO,EACd,KAAK,EAAC,gBAAgB,EACtB,SAAS,QACT,OAAO,EAAC,UAAU,EAClB,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,EAC5B,QAAQ,EAAE,CAAC,CAAC,EAAE;oBACZ,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;gBAChC,CAAC,GACD;YACF,oBAAC,MAAM,IACL,OAAO,EAAC,WAAW,EACnB,OAAO,EAAE,GAAG,EAAE;oBACZ,cAAc,CAAC,cAAc,CAAC,CAAA;gBAChC,CAAC,YAGM,CACK;QAChB,oBAAC,aAAa;YACZ,oBAAC,MAAM,IACL,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,WAAW,EACjB,OAAO,EAAE,GAAG,EAAE;oBACZ,WAAW,EAAE,CAAA;gBACf,CAAC,aAGM;YACT,oBAAC,MAAM,IACL,KAAK,EAAC,SAAS,EACf,OAAO,EAAC,WAAW,EACnB,OAAO,EAAE,GAAG,EAAE;oBACZ,WAAW,CAAC,WAAW,CAAC,CAAA;gBAC1B,CAAC,WAGM,CACK,CACT,CACV,CAAA;AACH,CAAC"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { Feature } from '@jbrowse/core/util';
|
|
2
2
|
import type { JBrowsePluginMsaViewModel } from '../../../MsaViewPanel/model';
|
|
3
3
|
import type { LinearGenomeViewModel } from '@jbrowse/plugin-linear-genome-view';
|
|
4
|
-
export declare function
|
|
4
|
+
export declare function blastLaunchView({ newViewTitle, view, feature, blastParams, }: {
|
|
5
5
|
newViewTitle: string;
|
|
6
6
|
view: LinearGenomeViewModel;
|
|
7
7
|
feature: Feature;
|
|
8
|
+
blastParams: Record<string, unknown>;
|
|
8
9
|
}): JBrowsePluginMsaViewModel;
|
|
@@ -1,17 +1,14 @@
|
|
|
1
1
|
import { getSession } from '@jbrowse/core/util';
|
|
2
|
-
export function
|
|
2
|
+
export function blastLaunchView({ newViewTitle, view, feature, blastParams, }) {
|
|
3
3
|
return getSession(view).addView('MsaView', {
|
|
4
4
|
type: 'MsaView',
|
|
5
5
|
displayName: newViewTitle,
|
|
6
6
|
connectedViewId: view.id,
|
|
7
7
|
connectedFeature: feature.toJSON(),
|
|
8
|
-
treeAreaWidth: 250,
|
|
9
|
-
treeWidth: 100,
|
|
10
8
|
drawNodeBubbles: true,
|
|
11
|
-
labelsAlignRight: true,
|
|
12
9
|
colWidth: 10,
|
|
13
10
|
rowHeight: 12,
|
|
14
|
-
|
|
11
|
+
blastParams,
|
|
15
12
|
});
|
|
16
13
|
}
|
|
17
|
-
//# sourceMappingURL=
|
|
14
|
+
//# sourceMappingURL=blastLaunchView.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"blastLaunchView.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAKxD,MAAM,UAAU,eAAe,CAAC,EAC9B,YAAY,EACZ,IAAI,EACJ,OAAO,EACP,WAAW,GAMZ;IACC,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,SAAS,EAAE;QACzC,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,YAAY;QACzB,eAAe,EAAE,IAAI,CAAC,EAAE;QACxB,gBAAgB,EAAE,OAAO,CAAC,MAAM,EAAE;QAClC,eAAe,EAAE,IAAI;QACrB,QAAQ,EAAE,EAAE;QACZ,SAAS,EAAE,EAAE;QACb,WAAW;KACZ,CAA8B,CAAA;AACjC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const BASE_BLAST_URL = "https://blast.ncbi.nlm.nih.gov/Blast.cgi";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"consts.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/NCBIBlastQuery/consts.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,cAAc,GAAG,0CAA0C,CAAA"}
|
|
@@ -1,12 +1,15 @@
|
|
|
1
1
|
import React, { useEffect, useState } from 'react';
|
|
2
2
|
import { ErrorMessage } from '@jbrowse/core/ui';
|
|
3
3
|
import { getContainingView, getSession, } from '@jbrowse/core/util';
|
|
4
|
-
import { Button, DialogActions, DialogContent,
|
|
4
|
+
import { Button, DialogActions, DialogContent, Typography } from '@mui/material';
|
|
5
5
|
import { observer } from 'mobx-react';
|
|
6
6
|
import { makeStyles } from 'tss-react/mui';
|
|
7
7
|
import { fetchGeneList } from './fetchGeneList';
|
|
8
8
|
import { preCalculatedLaunchView } from './preCalculatedLaunchView';
|
|
9
|
-
import
|
|
9
|
+
import ExternalLink from '../../../ExternalLink';
|
|
10
|
+
import { getGeneDisplayName, getId, getTranscriptFeatures } from '../../util';
|
|
11
|
+
import TranscriptSelector from '../TranscriptSelector';
|
|
12
|
+
import { useFeatureSequence } from '../useFeatureSequence';
|
|
10
13
|
const useStyles = makeStyles()({
|
|
11
14
|
dialogContent: {
|
|
12
15
|
width: '80em',
|
|
@@ -16,7 +19,7 @@ const PreLoadedMSA = observer(function PreLoadedMSA2({ model, feature, handleClo
|
|
|
16
19
|
const session = getSession(model);
|
|
17
20
|
const view = getContainingView(model);
|
|
18
21
|
const { classes } = useStyles();
|
|
19
|
-
const [
|
|
22
|
+
const [error1, setError] = useState();
|
|
20
23
|
const [geneNameList, setGeneNameList] = useState();
|
|
21
24
|
useEffect(() => {
|
|
22
25
|
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
@@ -38,27 +41,25 @@ const PreLoadedMSA = observer(function PreLoadedMSA2({ model, feature, handleClo
|
|
|
38
41
|
}
|
|
39
42
|
})();
|
|
40
43
|
}, [feature]);
|
|
41
|
-
const
|
|
44
|
+
const validSet = new Set(geneNameList);
|
|
42
45
|
const options = getTranscriptFeatures(feature);
|
|
43
|
-
const ret = options.find(val =>
|
|
46
|
+
const ret = options.find(val => validSet.has(getId(val)));
|
|
44
47
|
const [userSelection, setUserSelection] = useState(getId(options[0]));
|
|
48
|
+
const selectedTranscript = options.find(val => getId(val) === userSelection);
|
|
49
|
+
const { proteinSequence, error: error2 } = useFeatureSequence({
|
|
50
|
+
view,
|
|
51
|
+
feature: selectedTranscript,
|
|
52
|
+
});
|
|
53
|
+
const e = error1 ?? error2;
|
|
45
54
|
return (React.createElement(React.Fragment, null,
|
|
46
55
|
React.createElement(DialogContent, { className: classes.dialogContent },
|
|
56
|
+
e ? React.createElement(ErrorMessage, { error: e }) : null,
|
|
47
57
|
React.createElement(Typography, null,
|
|
48
58
|
"The source data for these multiple sequence alignments is from",
|
|
49
59
|
' ',
|
|
50
|
-
React.createElement(
|
|
51
|
-
error ? React.createElement(ErrorMessage, { error: error }) : null,
|
|
60
|
+
React.createElement(ExternalLink, { href: "https://hgdownload.soe.ucsc.edu/goldenPath/hg38/multiz100way/alignments/" }, "knownCanonical.multiz100way.protAA.fa.gz")),
|
|
52
61
|
geneNameList && !ret ? (React.createElement(Typography, { color: "error" }, "No MSA data for this gene found")) : null,
|
|
53
|
-
React.createElement(
|
|
54
|
-
setUserSelection(event.target.value);
|
|
55
|
-
} }, options.map(val => {
|
|
56
|
-
const inSet = set.has(getId(val));
|
|
57
|
-
return (React.createElement(MenuItem, { value: getId(val), key: val.id(), disabled: !inSet },
|
|
58
|
-
getTranscriptDisplayName(val),
|
|
59
|
-
" ",
|
|
60
|
-
inSet ? ' (has data)' : ''));
|
|
61
|
-
}))),
|
|
62
|
+
React.createElement(TranscriptSelector, { feature: feature, options: options, selectedTranscriptId: userSelection, onTranscriptChange: setUserSelection, proteinSequence: proteinSequence, validSet: validSet })),
|
|
62
63
|
React.createElement(DialogActions, null,
|
|
63
64
|
React.createElement(Button, { color: "primary", variant: "contained", onClick: () => {
|
|
64
65
|
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PreLoadedMSADataPanel.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAElD,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAA;AAC/C,OAAO,EAGL,iBAAiB,EACjB,UAAU,GACX,MAAM,oBAAoB,CAAA;AAC3B,OAAO,
|
|
1
|
+
{"version":3,"file":"PreLoadedMSADataPanel.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Feature } from '@jbrowse/core/util';
|
|
3
|
+
export default function TranscriptSelector({ feature, options, selectedTranscriptId, onTranscriptChange, proteinSequence, validSet, }: {
|
|
4
|
+
feature: Feature;
|
|
5
|
+
options: Feature[];
|
|
6
|
+
selectedTranscriptId: string;
|
|
7
|
+
onTranscriptChange: (transcriptId: string) => void;
|
|
8
|
+
proteinSequence: string | undefined;
|
|
9
|
+
validSet?: Set<string>;
|
|
10
|
+
}): React.JSX.Element;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { Button, MenuItem } from '@mui/material';
|
|
3
|
+
import { makeStyles } from 'tss-react/mui';
|
|
4
|
+
import ReadOnlyTextField2 from '../../ReadOnlyTextField2';
|
|
5
|
+
import TextField2 from '../../TextField2';
|
|
6
|
+
import { getGeneDisplayName, getId, getTranscriptDisplayName, getTranscriptLength, } from '../util';
|
|
7
|
+
const useStyles = makeStyles()({
|
|
8
|
+
flex: {
|
|
9
|
+
display: 'flex',
|
|
10
|
+
},
|
|
11
|
+
minWidth: {
|
|
12
|
+
minWidth: 300,
|
|
13
|
+
},
|
|
14
|
+
});
|
|
15
|
+
export default function TranscriptSelector({ feature, options, selectedTranscriptId, onTranscriptChange, proteinSequence, validSet, }) {
|
|
16
|
+
const { classes } = useStyles();
|
|
17
|
+
const [showSequence, setShowSequence] = useState(false);
|
|
18
|
+
const selectedTranscript = options.find(val => getId(val) === selectedTranscriptId);
|
|
19
|
+
return (React.createElement(React.Fragment, null,
|
|
20
|
+
React.createElement("div", { className: classes.flex },
|
|
21
|
+
React.createElement(TextField2, { variant: "outlined", label: `Choose isoform of ${getGeneDisplayName(feature)}`, select: true, className: classes.minWidth, value: selectedTranscriptId, onChange: event => {
|
|
22
|
+
onTranscriptChange(event.target.value);
|
|
23
|
+
} }, options
|
|
24
|
+
.toSorted((a, b) => getTranscriptLength(b).len - getTranscriptLength(a).len)
|
|
25
|
+
.map(val => {
|
|
26
|
+
const inSet = validSet ? validSet.has(getId(val)) : true;
|
|
27
|
+
const { len, mod } = getTranscriptLength(val);
|
|
28
|
+
return (React.createElement(MenuItem, { value: getId(val), key: val.id(), disabled: !inSet },
|
|
29
|
+
getTranscriptDisplayName(val),
|
|
30
|
+
" (",
|
|
31
|
+
len,
|
|
32
|
+
" aa)",
|
|
33
|
+
' ',
|
|
34
|
+
mod ? ` (possible fragment)` : '',
|
|
35
|
+
validSet ? (inSet ? ' (has data)' : ' (no data)') : ''));
|
|
36
|
+
})),
|
|
37
|
+
React.createElement("div", { style: { alignContent: 'center', marginLeft: 20 } },
|
|
38
|
+
React.createElement(Button, { variant: "contained", color: "primary", onClick: () => {
|
|
39
|
+
setShowSequence(!showSequence);
|
|
40
|
+
} }, showSequence ? 'Hide sequence' : 'Show sequence'))),
|
|
41
|
+
showSequence && (React.createElement(ReadOnlyTextField2, { value: proteinSequence
|
|
42
|
+
? `>${getTranscriptDisplayName(selectedTranscript)}\n${proteinSequence}`
|
|
43
|
+
: 'Loading...' }))));
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=TranscriptSelector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TranscriptSelector.js","sourceRoot":"","sources":["../../../src/LaunchMsaView/components/TranscriptSelector.tsx"],"names":[],"mappings":"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"}
|
|
@@ -11,8 +11,7 @@ export declare function revlist(list: Feat[], seqlen: number): {
|
|
|
11
11
|
end: number;
|
|
12
12
|
type?: string;
|
|
13
13
|
}[];
|
|
14
|
-
export declare function
|
|
15
|
-
export declare function getProteinSequence({ selectedTranscript, seq, }: {
|
|
14
|
+
export declare function getProteinSequenceFromFeature({ selectedTranscript, seq, }: {
|
|
16
15
|
seq: string;
|
|
17
16
|
selectedTranscript: Feature;
|
|
18
17
|
}): string;
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { dedupe, defaultCodonTable, generateCodonTable, revcom, } from '@jbrowse/core/util';
|
|
2
|
+
export function stitch(subfeats, sequence) {
|
|
3
|
+
return subfeats.map(sub => sequence.slice(sub.start, sub.end)).join('');
|
|
4
|
+
}
|
|
5
|
+
export function calculateProteinSequence({ cds, sequence, codonTable, }) {
|
|
6
|
+
const str = stitch(cds, sequence);
|
|
7
|
+
let protein = '';
|
|
8
|
+
for (let i = 0; i < str.length; i += 3) {
|
|
9
|
+
// use & symbol for undefined codon, or partial slice
|
|
10
|
+
protein += codonTable[str.slice(i, i + 3)] ?? '&';
|
|
11
|
+
}
|
|
12
|
+
return protein;
|
|
13
|
+
}
|
|
14
|
+
export function revlist(list, seqlen) {
|
|
15
|
+
return list
|
|
16
|
+
.map(sub => ({
|
|
17
|
+
...sub,
|
|
18
|
+
start: seqlen - sub.end,
|
|
19
|
+
end: seqlen - sub.start,
|
|
20
|
+
}))
|
|
21
|
+
.toSorted((a, b) => a.start - b.start);
|
|
22
|
+
}
|
|
23
|
+
export function getProteinSequenceFromFeature({ selectedTranscript, seq, }) {
|
|
24
|
+
const { subfeatures, start, strand } = selectedTranscript.toJSON();
|
|
25
|
+
const cds = dedupe(subfeatures
|
|
26
|
+
?.toSorted((a, b) => a.start - b.start)
|
|
27
|
+
.map(sub => ({
|
|
28
|
+
...sub,
|
|
29
|
+
start: sub.start - start,
|
|
30
|
+
end: sub.end - start,
|
|
31
|
+
}))
|
|
32
|
+
.filter(subfeature => subfeature.type === 'CDS') ?? [], feat => `${feat.start}-${feat.end}`);
|
|
33
|
+
return calculateProteinSequence({
|
|
34
|
+
cds: strand === -1 ? revlist(cds, seq.length) : cds,
|
|
35
|
+
sequence: strand === -1 ? revcom(seq) : seq,
|
|
36
|
+
codonTable: generateCodonTable(defaultCodonTable),
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=calculateProteinSequence.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calculateProteinSequence.js","sourceRoot":"","sources":["../../../src/LaunchMsaView/components/calculateProteinSequence.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,MAAM,EACN,iBAAiB,EACjB,kBAAkB,EAClB,MAAM,GACP,MAAM,oBAAoB,CAAA;AAK3B,MAAM,UAAU,MAAM,CAAC,QAAgB,EAAE,QAAgB;IACvD,OAAO,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;AACzE,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,EACvC,GAAG,EACH,QAAQ,EACR,UAAU,GAKX;IACC,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAA;IACjC,IAAI,OAAO,GAAG,EAAE,CAAA;IAChB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;QACvC,qDAAqD;QACrD,OAAO,IAAI,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,GAAG,CAAA;IACnD,CAAC;IACD,OAAO,OAAO,CAAA;AAChB,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,IAAY,EAAE,MAAc;IAClD,OAAO,IAAI;SACR,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACX,GAAG,GAAG;QACN,KAAK,EAAE,MAAM,GAAG,GAAG,CAAC,GAAG;QACvB,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC,KAAK;KACxB,CAAC,CAAC;SACF,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAA;AAC1C,CAAC;AAED,MAAM,UAAU,6BAA6B,CAAC,EAC5C,kBAAkB,EAClB,GAAG,GAIJ;IACC,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,kBAAkB,CAAC,MAAM,EAAE,CAAA;IAClE,MAAM,GAAG,GAAG,MAAM,CAChB,WAAW;QACT,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;SACtC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACX,GAAG,GAAG;QACN,KAAK,EAAE,GAAG,CAAC,KAAK,GAAG,KAAK;QACxB,GAAG,EAAE,GAAG,CAAC,GAAG,GAAG,KAAK;KACrB,CAAC,CAAC;SACF,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,EAAE,EACxD,IAAI,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,GAAG,EAAE,CACpC,CAAA;IAED,OAAO,wBAAwB,CAAC;QAC9B,GAAG,EAAE,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG;QACnD,QAAQ,EAAE,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG;QAC3C,UAAU,EAAE,kBAAkB,CAAC,iBAAiB,CAAC;KAClD,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetchSeq.js","sourceRoot":"","sources":["../../../src/LaunchMsaView/components/fetchSeq.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,6BAA6B,CAAA;AAIrD,MAAM,CAAC,KAAK,UAAU,QAAQ,CAAC,EAC7B,KAAK,EACL,GAAG,EACH,OAAO,EACP,OAAO,EACP,YAAY,GAOb;IACC,MAAM,EAAE,eAAe,EAAE,UAAU,EAAE,GAAG,OAAO,CAAA;IAC/C,MAAM,QAAQ,GAAG,MAAM,eAAe,CAAC,eAAe,CAAC,YAAY,CAAC,CAAA;IACpE,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAA;IACvC,CAAC;IACD,MAAM,SAAS,GAAG,aAAa,CAAA;IAC/B,MAAM,KAAK,GAAG,CAAC,MAAM,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,iBAAiB,EAAE;QACjE,aAAa,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;QACzD,SAAS;QACT,OAAO,EAAE;YACP;gBACE,KAAK;gBACL,GAAG;gBACH,OAAO,EAAE,QAAQ,CAAC,mBAAmB,CAAC,OAAO,CAAC;gBAC9C,YAAY;aACb;SACF;KACF,CAAC,CAAc,CAAA;IAChB,OAAQ,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,KAAK,CAAwB,IAAI,EAAE,CAAA;AAC3D,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/LaunchMsaView/components/types.ts"],"names":[],"mappings":""}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type { Feature } from '@jbrowse/core/util';
|
|
2
1
|
import type { SeqState } from './types';
|
|
2
|
+
import type { Feature } from '@jbrowse/core/util';
|
|
3
3
|
export interface ErrorState {
|
|
4
4
|
error: string;
|
|
5
5
|
}
|
|
@@ -11,6 +11,7 @@ export declare function useFeatureSequence({ view, feature, upDownBp, forceLoad,
|
|
|
11
11
|
upDownBp?: number;
|
|
12
12
|
forceLoad?: boolean;
|
|
13
13
|
}): {
|
|
14
|
+
proteinSequence: string;
|
|
14
15
|
sequence: SeqState | ErrorState | undefined;
|
|
15
16
|
error: unknown;
|
|
16
17
|
};
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { useEffect, useState } from 'react';
|
|
2
2
|
import { getSession } from '@jbrowse/core/util';
|
|
3
|
+
import { getProteinSequenceFromFeature } from './calculateProteinSequence';
|
|
3
4
|
import { fetchSeq } from './fetchSeq';
|
|
4
5
|
const BPLIMIT = 500_000;
|
|
5
6
|
export function useFeatureSequence({ view, feature, upDownBp = 0, forceLoad = true, }) {
|
|
@@ -59,6 +60,16 @@ export function useFeatureSequence({ view, feature, upDownBp = 0, forceLoad = tr
|
|
|
59
60
|
})();
|
|
60
61
|
}
|
|
61
62
|
}, [feature, view, upDownBp, assemblyName, forceLoad]);
|
|
62
|
-
|
|
63
|
+
const proteinSequence = sequence && !('error' in sequence)
|
|
64
|
+
? getProteinSequenceFromFeature({
|
|
65
|
+
seq: sequence.seq,
|
|
66
|
+
selectedTranscript: feature,
|
|
67
|
+
})
|
|
68
|
+
: '';
|
|
69
|
+
return {
|
|
70
|
+
proteinSequence,
|
|
71
|
+
sequence,
|
|
72
|
+
error,
|
|
73
|
+
};
|
|
63
74
|
}
|
|
64
75
|
//# sourceMappingURL=useFeatureSequence.js.map
|