jbrowse-plugin-msaview 2.2.3 → 2.2.4
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/CHANGELOG.md +1 -1
- package/README.md +229 -0
- package/dist/AddHighlightModel/GenomeMouseoverHighlight.js +23 -18
- package/dist/AddHighlightModel/GenomeMouseoverHighlight.js.map +1 -1
- package/dist/AddHighlightModel/MsaToGenomeHighlight.js +23 -13
- package/dist/AddHighlightModel/MsaToGenomeHighlight.js.map +1 -1
- package/dist/AddHighlightModel/index.js +8 -1
- package/dist/AddHighlightModel/index.js.map +1 -1
- package/dist/AddHighlightModel/util.d.ts +2 -2
- package/dist/BgzipFastaMsaAdapter/configSchema.d.ts +2 -2
- package/dist/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.js +5 -11
- package/dist/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.js.map +1 -1
- package/dist/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.js +5 -1
- package/dist/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.js.map +1 -1
- package/dist/LaunchMsaView/components/LaunchMsaViewDialog.js +16 -16
- package/dist/LaunchMsaView/components/LaunchMsaViewDialog.js.map +1 -1
- package/dist/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.js +38 -46
- package/dist/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.js.map +1 -1
- package/dist/LaunchMsaView/components/ManualMSALoader/launchView.d.ts +4 -3
- package/dist/LaunchMsaView/components/ManualMSALoader/launchView.js +4 -3
- package/dist/LaunchMsaView/components/ManualMSALoader/launchView.js.map +1 -1
- package/dist/LaunchMsaView/components/NCBIBlastQuery/CachedBlastResults.d.ts +9 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/CachedBlastResults.js +76 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/CachedBlastResults.js.map +1 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.js +35 -13
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.js.map +1 -1
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.js +6 -12
- package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.js.map +1 -1
- package/dist/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.d.ts +6 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.js +15 -0
- package/dist/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.js.map +1 -1
- package/dist/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.js +12 -34
- package/dist/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.js.map +1 -1
- package/dist/LaunchMsaView/components/PreLoadedMSA/consts.d.ts +1 -0
- package/dist/LaunchMsaView/components/PreLoadedMSA/consts.js +1 -0
- package/dist/LaunchMsaView/components/PreLoadedMSA/consts.js.map +1 -1
- package/dist/LaunchMsaView/components/TabPanel.d.ts +2 -2
- package/dist/LaunchMsaView/components/TranscriptSelector.d.ts +2 -2
- package/dist/LaunchMsaView/components/TranscriptSelector.js +3 -6
- package/dist/LaunchMsaView/components/TranscriptSelector.js.map +1 -1
- package/dist/LaunchMsaView/components/useSWRFeatureSequence.js +6 -4
- package/dist/LaunchMsaView/components/useSWRFeatureSequence.js.map +1 -1
- package/dist/LaunchMsaView/components/useTranscriptSelection.d.ts +16 -0
- package/dist/LaunchMsaView/components/useTranscriptSelection.js +31 -0
- package/dist/LaunchMsaView/components/useTranscriptSelection.js.map +1 -0
- package/dist/LaunchMsaView/components/util.d.ts +3 -1
- package/dist/LaunchMsaView/components/util.js +12 -2
- package/dist/LaunchMsaView/components/util.js.map +1 -1
- package/dist/LaunchMsaView/util.d.ts +2 -0
- package/dist/LaunchMsaView/util.js +16 -4
- package/dist/LaunchMsaView/util.js.map +1 -1
- package/dist/LaunchMsaViewExtensionPoint/index.d.ts +2 -0
- package/dist/LaunchMsaViewExtensionPoint/index.js +31 -0
- package/dist/LaunchMsaViewExtensionPoint/index.js.map +1 -0
- package/dist/MsaViewPanel/components/ConnectStructureDialog.d.ts +7 -0
- package/dist/MsaViewPanel/components/ConnectStructureDialog.js +56 -0
- package/dist/MsaViewPanel/components/ConnectStructureDialog.js.map +1 -0
- package/dist/MsaViewPanel/components/MsaViewPanel.js +4 -2
- package/dist/MsaViewPanel/components/MsaViewPanel.js.map +1 -1
- package/dist/MsaViewPanel/doLaunchBlast.d.ts +1 -0
- package/dist/MsaViewPanel/doLaunchBlast.js +65 -19
- package/dist/MsaViewPanel/doLaunchBlast.js.map +1 -1
- package/dist/MsaViewPanel/genomeToMSA.d.ts +6 -0
- package/dist/MsaViewPanel/genomeToMSA.js +38 -8
- package/dist/MsaViewPanel/genomeToMSA.js.map +1 -1
- package/dist/MsaViewPanel/genomeToMSA.test.d.ts +1 -0
- package/dist/MsaViewPanel/genomeToMSA.test.js +244 -0
- package/dist/MsaViewPanel/genomeToMSA.test.js.map +1 -0
- package/dist/MsaViewPanel/model.d.ts +717 -226
- package/dist/MsaViewPanel/model.js +467 -39
- package/dist/MsaViewPanel/model.js.map +1 -1
- package/dist/MsaViewPanel/msaCoordToGenomeCoord.d.ts +7 -2
- package/dist/MsaViewPanel/msaCoordToGenomeCoord.js +26 -27
- package/dist/MsaViewPanel/msaCoordToGenomeCoord.js.map +1 -1
- package/dist/MsaViewPanel/msaCoordToGenomeCoord.test.d.ts +1 -0
- package/dist/MsaViewPanel/msaCoordToGenomeCoord.test.js +240 -0
- package/dist/MsaViewPanel/msaCoordToGenomeCoord.test.js.map +1 -0
- package/dist/MsaViewPanel/msaDataStore.d.ts +14 -0
- package/dist/MsaViewPanel/msaDataStore.js +197 -0
- package/dist/MsaViewPanel/msaDataStore.js.map +1 -0
- package/dist/MsaViewPanel/pairwiseAlignment.d.ts +27 -0
- package/dist/MsaViewPanel/pairwiseAlignment.js +776 -0
- package/dist/MsaViewPanel/pairwiseAlignment.js.map +1 -0
- package/dist/MsaViewPanel/pairwiseAlignment.test.d.ts +1 -0
- package/dist/MsaViewPanel/pairwiseAlignment.test.js +112 -0
- package/dist/MsaViewPanel/pairwiseAlignment.test.js.map +1 -0
- package/dist/MsaViewPanel/structureConnection.d.ts +27 -0
- package/dist/MsaViewPanel/structureConnection.js +46 -0
- package/dist/MsaViewPanel/structureConnection.js.map +1 -0
- package/dist/MsaViewPanel/structureConnection.test.d.ts +1 -0
- package/dist/MsaViewPanel/structureConnection.test.js +122 -0
- package/dist/MsaViewPanel/structureConnection.test.js.map +1 -0
- package/dist/MsaViewPanel/types.d.ts +13 -0
- package/dist/MsaViewPanel/types.js +2 -0
- package/dist/MsaViewPanel/types.js.map +1 -0
- package/dist/MsaViewPanel/util.d.ts +7 -0
- package/dist/MsaViewPanel/util.js +10 -0
- package/dist/MsaViewPanel/util.js.map +1 -1
- package/dist/index.d.ts +5 -5
- package/dist/index.js +3 -1
- package/dist/index.js.map +1 -1
- package/dist/jbrowse-plugin-msaview.umd.production.min.js +39 -90
- package/dist/jbrowse-plugin-msaview.umd.production.min.js.map +4 -4
- package/dist/utils/blastCache.d.ts +34 -0
- package/dist/utils/blastCache.js +58 -0
- package/dist/utils/blastCache.js.map +1 -0
- package/dist/utils/fetch.d.ts +1 -1
- package/dist/utils/fetch.js +1 -1
- package/dist/utils/fetch.js.map +1 -1
- package/dist/utils/ncbiBlast.d.ts +1 -5
- package/dist/utils/taxonomyNames.d.ts +5 -0
- package/dist/utils/taxonomyNames.js +79 -0
- package/dist/utils/taxonomyNames.js.map +1 -0
- package/dist/utils/types.d.ts +8 -5
- package/package.json +50 -54
- package/src/AddHighlightModel/GenomeMouseoverHighlight.tsx +37 -21
- package/src/AddHighlightModel/MsaToGenomeHighlight.tsx +38 -17
- package/src/AddHighlightModel/index.tsx +9 -4
- package/src/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.tsx +13 -13
- package/src/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.ts +6 -0
- package/src/LaunchMsaView/components/LaunchMsaViewDialog.tsx +30 -23
- package/src/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.tsx +64 -51
- package/src/LaunchMsaView/components/ManualMSALoader/launchView.ts +9 -6
- package/src/LaunchMsaView/components/NCBIBlastQuery/CachedBlastResults.tsx +146 -0
- package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.tsx +53 -22
- package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.tsx +8 -13
- package/src/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.ts +25 -0
- package/src/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.tsx +27 -47
- package/src/LaunchMsaView/components/PreLoadedMSA/consts.ts +1 -0
- package/src/LaunchMsaView/components/TabPanel.tsx +2 -2
- package/src/LaunchMsaView/components/TranscriptSelector.tsx +13 -20
- package/src/LaunchMsaView/components/useSWRFeatureSequence.ts +5 -5
- package/src/LaunchMsaView/components/useTranscriptSelection.ts +48 -0
- package/src/LaunchMsaView/components/util.ts +17 -2
- package/src/LaunchMsaView/index.ts +1 -1
- package/src/LaunchMsaView/util.ts +25 -6
- package/src/LaunchMsaViewExtensionPoint/index.ts +74 -0
- package/src/MsaViewPanel/components/ConnectStructureDialog.tsx +156 -0
- package/src/MsaViewPanel/components/MsaViewPanel.tsx +6 -1
- package/src/MsaViewPanel/doLaunchBlast.ts +83 -23
- package/src/MsaViewPanel/genomeToMSA.test.ts +281 -0
- package/src/MsaViewPanel/genomeToMSA.ts +43 -10
- package/src/MsaViewPanel/model.ts +590 -43
- package/src/MsaViewPanel/msaCoordToGenomeCoord.test.ts +256 -0
- package/src/MsaViewPanel/msaCoordToGenomeCoord.ts +43 -29
- package/src/MsaViewPanel/msaDataStore.ts +236 -0
- package/src/MsaViewPanel/pairwiseAlignment.test.ts +140 -0
- package/src/MsaViewPanel/pairwiseAlignment.ts +818 -0
- package/src/MsaViewPanel/structureConnection.test.ts +143 -0
- package/src/MsaViewPanel/structureConnection.ts +72 -0
- package/src/MsaViewPanel/types.ts +14 -0
- package/src/MsaViewPanel/util.ts +11 -0
- package/src/index.ts +3 -1
- package/src/utils/blastCache.ts +114 -0
- package/src/utils/fetch.ts +1 -1
- package/src/utils/taxonomyNames.ts +111 -0
- package/src/utils/types.ts +9 -1
- package/dist/LaunchMsaView/components/PreLoadedMSA/findValidTranscriptId.d.ts +0 -5
- package/dist/LaunchMsaView/components/PreLoadedMSA/findValidTranscriptId.js +0 -16
- package/dist/LaunchMsaView/components/PreLoadedMSA/findValidTranscriptId.js.map +0 -1
- package/dist/out.js +0 -55381
- package/src/LaunchMsaView/components/PreLoadedMSA/findValidTranscriptId.ts +0 -25
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PreLoadedMSADataPanel.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,
|
|
1
|
+
{"version":3,"file":"PreLoadedMSADataPanel.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"consts.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/PreLoadedMSA/consts.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB,iBAAiB,EAAE,KAAK;IACxB,qBAAqB,EAAE,KAAK;IAC5B,iBAAiB,EAAE,KAAK;IACxB,kBAAkB,EAAE,KAAK;IACzB,kBAAkB,EAAE,KAAK;CAC1B,CAAA"}
|
|
1
|
+
{"version":3,"file":"consts.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/PreLoadedMSA/consts.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB,iBAAiB,EAAE,KAAK;IACxB,qBAAqB,EAAE,KAAK;IAC5B,iBAAiB,EAAE,KAAK;IACxB,iBAAiB,EAAE,KAAK;IACxB,kBAAkB,EAAE,KAAK;IACzB,kBAAkB,EAAE,KAAK;CAC1B,CAAA"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { Feature } from '@jbrowse/core/util';
|
|
3
|
-
export default function TranscriptSelector({ feature, options,
|
|
3
|
+
export default function TranscriptSelector({ feature, options, selectedTranscript, onTranscriptChange, proteinSequence, validSet, }: {
|
|
4
4
|
feature: Feature;
|
|
5
5
|
options: Feature[];
|
|
6
|
-
|
|
6
|
+
selectedTranscript: Feature | undefined;
|
|
7
7
|
onTranscriptChange: (transcriptId: string) => void;
|
|
8
8
|
proteinSequence: string | undefined;
|
|
9
9
|
validSet?: Set<string>;
|
|
@@ -12,17 +12,14 @@ const useStyles = makeStyles()({
|
|
|
12
12
|
minWidth: 300,
|
|
13
13
|
},
|
|
14
14
|
});
|
|
15
|
-
export default function TranscriptSelector({ feature, options,
|
|
15
|
+
export default function TranscriptSelector({ feature, options, selectedTranscript, onTranscriptChange, proteinSequence, validSet, }) {
|
|
16
16
|
const { classes } = useStyles();
|
|
17
17
|
const [showSequence, setShowSequence] = useState(false);
|
|
18
|
-
const selectedTranscript = options.find(val => getId(val) === selectedTranscriptId);
|
|
19
18
|
return (React.createElement(React.Fragment, null,
|
|
20
19
|
React.createElement("div", { className: classes.flex },
|
|
21
|
-
React.createElement(TextField2, { variant: "outlined", label: `Choose isoform of ${getGeneDisplayName(feature)}`, select: true, className: classes.minWidth, value:
|
|
20
|
+
React.createElement(TextField2, { variant: "outlined", label: `Choose isoform of ${getGeneDisplayName(feature)}`, select: true, className: classes.minWidth, value: getId(selectedTranscript), onChange: event => {
|
|
22
21
|
onTranscriptChange(event.target.value);
|
|
23
|
-
} }, options
|
|
24
|
-
.toSorted((a, b) => getTranscriptLength(b).len - getTranscriptLength(a).len)
|
|
25
|
-
.map(val => {
|
|
22
|
+
} }, options.map(val => {
|
|
26
23
|
const inSet = validSet ? validSet.has(getId(val)) : true;
|
|
27
24
|
const { len, mod } = getTranscriptLength(val);
|
|
28
25
|
return (React.createElement(MenuItem, { value: getId(val), key: val.id(), disabled: !inSet },
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TranscriptSelector.js","sourceRoot":"","sources":["../../../src/LaunchMsaView/components/TranscriptSelector.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAGvC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,OAAO,kBAAkB,MAAM,qCAAqC,CAAA;AACpE,OAAO,UAAU,MAAM,6BAA6B,CAAA;AACpD,OAAO,EACL,kBAAkB,EAClB,KAAK,EACL,wBAAwB,EACxB,mBAAmB,GACpB,MAAM,SAAS,CAAA;AAEhB,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC;IAC7B,IAAI,EAAE;QACJ,OAAO,EAAE,MAAM;KAChB;IACD,QAAQ,EAAE;QACR,QAAQ,EAAE,GAAG;KACd;CACF,CAAC,CAAA;AAEF,MAAM,CAAC,OAAO,UAAU,kBAAkB,CAAC,EACzC,OAAO,EACP,OAAO,EACP,
|
|
1
|
+
{"version":3,"file":"TranscriptSelector.js","sourceRoot":"","sources":["../../../src/LaunchMsaView/components/TranscriptSelector.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAGvC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,OAAO,kBAAkB,MAAM,qCAAqC,CAAA;AACpE,OAAO,UAAU,MAAM,6BAA6B,CAAA;AACpD,OAAO,EACL,kBAAkB,EAClB,KAAK,EACL,wBAAwB,EACxB,mBAAmB,GACpB,MAAM,SAAS,CAAA;AAEhB,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC;IAC7B,IAAI,EAAE;QACJ,OAAO,EAAE,MAAM;KAChB;IACD,QAAQ,EAAE;QACR,QAAQ,EAAE,GAAG;KACd;CACF,CAAC,CAAA;AAEF,MAAM,CAAC,OAAO,UAAU,kBAAkB,CAAC,EACzC,OAAO,EACP,OAAO,EACP,kBAAkB,EAClB,kBAAkB,EAClB,eAAe,EACf,QAAQ,GAQT;IACC,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAA;IAC/B,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAEvD,OAAO,CACL;QACE,6BAAK,SAAS,EAAE,OAAO,CAAC,IAAI;YAC1B,oBAAC,UAAU,IACT,OAAO,EAAC,UAAU,EAClB,KAAK,EAAE,qBAAqB,kBAAkB,CAAC,OAAO,CAAC,EAAE,EACzD,MAAM,QACN,SAAS,EAAE,OAAO,CAAC,QAAQ,EAC3B,KAAK,EAAE,KAAK,CAAC,kBAAkB,CAAC,EAChC,QAAQ,EAAE,KAAK,CAAC,EAAE;oBAChB,kBAAkB,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;gBACxC,CAAC,IAEA,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBACjB,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;gBACxD,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,mBAAmB,CAAC,GAAG,CAAC,CAAA;gBAC7C,OAAO,CACL,oBAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,CAAC,KAAK;oBACzD,wBAAwB,CAAC,GAAG,CAAC;;oBAAI,GAAG;;oBAAM,GAAG;oBAC7C,GAAG,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAAE;oBACjC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAC9C,CACZ,CAAA;YACH,CAAC,CAAC,CACS;YACb,6BAAK,KAAK,EAAE,EAAE,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE,EAAE;gBACpD,oBAAC,MAAM,IACL,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,SAAS,EACf,OAAO,EAAE,GAAG,EAAE;wBACZ,eAAe,CAAC,CAAC,YAAY,CAAC,CAAA;oBAChC,CAAC,IAEA,YAAY,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAC1C,CACL,CACF;QAEL,YAAY,IAAI,CACf,oBAAC,kBAAkB,IACjB,KAAK,EACH,eAAe;gBACb,CAAC,CAAC,IAAI,wBAAwB,CAAC,kBAAkB,CAAC,KAAK,eAAe,EAAE;gBACxE,CAAC,CAAC,YAAY,GAElB,CACH,CACA,CACJ,CAAA;AACH,CAAC"}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { getSession } from '@jbrowse/core/util';
|
|
2
2
|
import useSWR from 'swr';
|
|
3
3
|
import { fetchSeq } from './fetchSeq';
|
|
4
|
-
|
|
5
|
-
async function featureSequenceFetcher({ feature, assemblyName, upDownBp, view, forceLoad, }) {
|
|
4
|
+
async function featureSequenceFetcher({ feature, assemblyName, upDownBp, view, }) {
|
|
6
5
|
const session = getSession(view);
|
|
7
6
|
const { start, end, refName } = feature.toJSON();
|
|
8
7
|
const b = start - upDownBp;
|
|
@@ -43,8 +42,11 @@ export function useSWRFeatureSequence({ view, feature, upDownBp = 0, forceLoad =
|
|
|
43
42
|
assemblyName: assemblyName,
|
|
44
43
|
upDownBp,
|
|
45
44
|
view: view,
|
|
46
|
-
|
|
47
|
-
|
|
45
|
+
}), {
|
|
46
|
+
revalidateOnFocus: false,
|
|
47
|
+
revalidateOnReconnect: false,
|
|
48
|
+
revalidateIfStale: false,
|
|
49
|
+
});
|
|
48
50
|
return {
|
|
49
51
|
sequence: data,
|
|
50
52
|
error,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSWRFeatureSequence.js","sourceRoot":"","sources":["../../../src/LaunchMsaView/components/useSWRFeatureSequence.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAC/C,OAAO,MAAM,MAAM,KAAK,CAAA;AAExB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAKrC,
|
|
1
|
+
{"version":3,"file":"useSWRFeatureSequence.js","sourceRoot":"","sources":["../../../src/LaunchMsaView/components/useSWRFeatureSequence.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAC/C,OAAO,MAAM,MAAM,KAAK,CAAA;AAExB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAKrC,KAAK,UAAU,sBAAsB,CAAC,EACpC,OAAO,EACP,YAAY,EACZ,QAAQ,EACR,IAAI,GAML;IACC,MAAM,OAAO,GAAG,UAAU,CAAC,IAAI,CAAC,CAAA;IAChC,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,MAAM,EAI7C,CAAA;IAED,MAAM,CAAC,GAAG,KAAK,GAAG,QAAQ,CAAA;IAC1B,MAAM,CAAC,GAAG,GAAG,GAAG,QAAQ,CAAA;IACxB,MAAM,CAAC,GAAG,EAAE,QAAQ,EAAE,UAAU,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACpD,QAAQ,CAAC;YACP,KAAK;YACL,GAAG;YACH,OAAO;YACP,YAAY;YACZ,OAAO;SACR,CAAC;QACF,QAAQ,CAAC;YACP,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YACrB,GAAG,EAAE,KAAK;YACV,OAAO;YACP,YAAY;YACZ,OAAO;SACR,CAAC;QACF,QAAQ,CAAC;YACP,KAAK,EAAE,GAAG;YACV,GAAG,EAAE,CAAC;YACN,OAAO;YACP,YAAY;YACZ,OAAO;SACR,CAAC;KACH,CAAC,CAAA;IACF,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,UAAU,EAAE,CAAA;AACtC,CAAC;AAED,MAAM,UAAU,qBAAqB,CAAC,EACpC,IAAI,EACJ,OAAO,EACP,QAAQ,GAAG,CAAC,EACZ,SAAS,GAAG,IAAI,GAMjB;IACC,MAAM,YAAY,GAAG,IAAI,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC,CAAA;IAC7C,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM;IAC5B,uEAAuE;IACvE,OAAO,IAAI,YAAY,IAAI,IAAI;QAC7B,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,YAAY,EAAE,QAAQ,EAAE,SAAS,EAAE,kBAAkB,CAAC;QACvE,CAAC,CAAC,IAAI,EACR,GAAG,EAAE,CACH,sBAAsB,CAAC;QACrB,OAAO,EAAE,OAAQ;QACjB,YAAY,EAAE,YAAa;QAC3B,QAAQ;QACR,IAAI,EAAE,IAAK;KACZ,CAAC,EACJ;QACE,iBAAiB,EAAE,KAAK;QACxB,qBAAqB,EAAE,KAAK;QAC5B,iBAAiB,EAAE,KAAK;KACzB,CACF,CAAA;IAED,OAAO;QACL,QAAQ,EAAE,IAAI;QACd,KAAK;KACN,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { Feature } from '@jbrowse/core/util';
|
|
2
|
+
export declare function useTranscriptSelection({ feature, view, validIds, }: {
|
|
3
|
+
feature: Feature;
|
|
4
|
+
view: {
|
|
5
|
+
assemblyNames?: string[];
|
|
6
|
+
} | undefined;
|
|
7
|
+
validIds?: string[];
|
|
8
|
+
}): {
|
|
9
|
+
options: Feature[];
|
|
10
|
+
selectedId: string;
|
|
11
|
+
setSelectedId: import("react").Dispatch<import("react").SetStateAction<string>>;
|
|
12
|
+
selectedTranscript: Feature | undefined;
|
|
13
|
+
proteinSequence: string;
|
|
14
|
+
error: any;
|
|
15
|
+
validSet: Set<string> | undefined;
|
|
16
|
+
};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { useEffect, useMemo, useState } from 'react';
|
|
2
|
+
import { getId, getSortedTranscriptFeatures } from '../util';
|
|
3
|
+
import { useFeatureSequence } from './useFeatureSequence';
|
|
4
|
+
export function useTranscriptSelection({ feature, view, validIds, }) {
|
|
5
|
+
const options = getSortedTranscriptFeatures(feature);
|
|
6
|
+
const [selectedId, setSelectedId] = useState(getId(options[0]));
|
|
7
|
+
const selectedTranscript = options.find(val => getId(val) === selectedId);
|
|
8
|
+
const { proteinSequence, error } = useFeatureSequence({
|
|
9
|
+
view,
|
|
10
|
+
feature: selectedTranscript,
|
|
11
|
+
});
|
|
12
|
+
const validSet = useMemo(() => (validIds ? new Set(validIds) : undefined), [validIds]);
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
if (validIds && validIds.length > 0 && !validIds.includes(selectedId)) {
|
|
15
|
+
const validOption = options.find(opt => validIds.includes(getId(opt)));
|
|
16
|
+
if (validOption) {
|
|
17
|
+
setSelectedId(getId(validOption));
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}, [validIds, options, selectedId]);
|
|
21
|
+
return {
|
|
22
|
+
options,
|
|
23
|
+
selectedId,
|
|
24
|
+
setSelectedId,
|
|
25
|
+
selectedTranscript,
|
|
26
|
+
proteinSequence,
|
|
27
|
+
error,
|
|
28
|
+
validSet,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=useTranscriptSelection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useTranscriptSelection.js","sourceRoot":"","sources":["../../../src/LaunchMsaView/components/useTranscriptSelection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEpD,OAAO,EAAE,KAAK,EAAE,2BAA2B,EAAE,MAAM,SAAS,CAAA;AAC5D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAA;AAIzD,MAAM,UAAU,sBAAsB,CAAC,EACrC,OAAO,EACP,IAAI,EACJ,QAAQ,GAKT;IACC,MAAM,OAAO,GAAG,2BAA2B,CAAC,OAAO,CAAC,CAAA;IACpD,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IAC/D,MAAM,kBAAkB,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,UAAU,CAAC,CAAA;IACzE,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,GAAG,kBAAkB,CAAC;QACpD,IAAI;QACJ,OAAO,EAAE,kBAAkB;KAC5B,CAAC,CAAA;IAEF,MAAM,QAAQ,GAAG,OAAO,CACtB,GAAG,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,EAChD,CAAC,QAAQ,CAAC,CACX,CAAA;IAED,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,QAAQ,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;YACtE,MAAM,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;YACtE,IAAI,WAAW,EAAE,CAAC;gBAChB,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAA;YACnC,CAAC;QACH,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC,CAAA;IAEnC,OAAO;QACL,OAAO;QACP,UAAU;QACV,aAAa;QACb,kBAAkB;QAClB,eAAe;QACf,KAAK;QACL,QAAQ;KACT,CAAA;AACH,CAAC"}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
|
+
import type { TaxonomyInfo } from '../../utils/taxonomyNames';
|
|
1
2
|
export declare function makeId(h: {
|
|
2
3
|
accession: string;
|
|
3
4
|
sciname: string;
|
|
4
|
-
|
|
5
|
+
taxid?: number;
|
|
6
|
+
}, taxonomyInfo?: Map<number, TaxonomyInfo>): string;
|
|
5
7
|
export declare function strip(s: string): string;
|
|
@@ -1,5 +1,15 @@
|
|
|
1
|
-
export function makeId(h) {
|
|
2
|
-
|
|
1
|
+
export function makeId(h, taxonomyInfo) {
|
|
2
|
+
let speciesName = h.sciname.replaceAll(' ', '_');
|
|
3
|
+
if (h.taxid && taxonomyInfo?.has(h.taxid)) {
|
|
4
|
+
const info = taxonomyInfo.get(h.taxid);
|
|
5
|
+
if (info.commonName) {
|
|
6
|
+
speciesName = info.commonName
|
|
7
|
+
.split(' ')
|
|
8
|
+
.map(word => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())
|
|
9
|
+
.join('_');
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
return `${h.accession}-${speciesName}`;
|
|
3
13
|
}
|
|
4
14
|
export function strip(s) {
|
|
5
15
|
return s.replace('-', '');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../src/LaunchMsaView/components/util.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../src/LaunchMsaView/components/util.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,MAAM,CACpB,CAAyD,EACzD,YAAwC;IAExC,IAAI,WAAW,GAAG,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;IAChD,IAAI,CAAC,CAAC,KAAK,IAAI,YAAY,EAAE,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1C,MAAM,IAAI,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAE,CAAA;QACvC,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,WAAW,GAAG,IAAI,CAAC,UAAU;iBAC1B,KAAK,CAAC,GAAG,CAAC;iBACV,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;iBACvE,IAAI,CAAC,GAAG,CAAC,CAAA;QACd,CAAC;IACH,CAAC;IACD,OAAO,GAAG,CAAC,CAAC,SAAS,IAAI,WAAW,EAAE,CAAA;AACxC,CAAC;AAED,MAAM,UAAU,KAAK,CAAC,CAAS;IAC7B,OAAO,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;AAC3B,CAAC"}
|
|
@@ -7,3 +7,5 @@ export declare function getTranscriptLength(feature: Feature): {
|
|
|
7
7
|
export declare function getId(val?: Feature): string;
|
|
8
8
|
export declare function getTranscriptDisplayName(val?: Feature): string;
|
|
9
9
|
export declare function getGeneDisplayName(val?: Feature): string;
|
|
10
|
+
export declare function getSortedTranscriptFeatures(feature: Feature): Feature[];
|
|
11
|
+
export declare function cleanProteinSequence(seq: string): string;
|
|
@@ -3,10 +3,16 @@ export function getTranscriptFeatures(feature) {
|
|
|
3
3
|
// check if we are looking at a 'two-level' or 'three-level' feature by
|
|
4
4
|
// finding exon/CDS subfeatures. we want to select from transcript names
|
|
5
5
|
const subfeatures = feature.get('subfeatures') ?? [];
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
6
|
+
// Check for mRNA/transcript subfeatures (three-level: gene → mRNA → CDS)
|
|
7
|
+
// Filter to only those that have CDS subfeatures (i.e. are coding)
|
|
8
|
+
const transcripts = subfeatures.filter((f) => (f.get('type') === 'mRNA' || f.get('type') === 'transcript') &&
|
|
9
|
+
f.get('subfeatures')?.some((s) => s.get('type') === 'CDS'));
|
|
10
|
+
if (transcripts.length > 0) {
|
|
11
|
+
return transcripts;
|
|
12
|
+
}
|
|
13
|
+
// Has direct CDS children, treat feature itself as the transcript
|
|
14
|
+
// (two-level: gene → CDS or mRNA → CDS)
|
|
15
|
+
return [feature];
|
|
10
16
|
}
|
|
11
17
|
export function getTranscriptLength(feature) {
|
|
12
18
|
const cdsLen = sum(feature
|
|
@@ -36,4 +42,10 @@ export function getGeneDisplayName(val) {
|
|
|
36
42
|
.filter(f => !!f)
|
|
37
43
|
.join(' ');
|
|
38
44
|
}
|
|
45
|
+
export function getSortedTranscriptFeatures(feature) {
|
|
46
|
+
return getTranscriptFeatures(feature).toSorted((a, b) => getTranscriptLength(b).len - getTranscriptLength(a).len);
|
|
47
|
+
}
|
|
48
|
+
export function cleanProteinSequence(seq) {
|
|
49
|
+
return seq.replaceAll('*', '').replaceAll('&', '');
|
|
50
|
+
}
|
|
39
51
|
//# sourceMappingURL=util.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/LaunchMsaView/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAA;AAIxC,MAAM,UAAU,qBAAqB,CAAC,OAAgB;IACpD,uEAAuE;IACvE,wEAAwE;IACxE,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,EAAE,CAAA;
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/LaunchMsaView/util.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
export default function LaunchMsaViewExtensionPointF(pluginManager) {
|
|
2
|
+
pluginManager.addToExtensionPoint('LaunchView-MsaView',
|
|
3
|
+
// @ts-expect-error
|
|
4
|
+
({ session, data, msaFileLocation, treeFileLocation, connectedViewId, connectedFeature, displayName, colorSchemeName, colWidth, rowHeight, treeAreaWidth, treeWidth, drawNodeBubbles, labelsAlignRight, showBranchLen, querySeqName, }) => {
|
|
5
|
+
if (!data && !msaFileLocation) {
|
|
6
|
+
throw new Error('No MSA data or file location provided when launching MSA view');
|
|
7
|
+
}
|
|
8
|
+
session.addView('MsaView', {
|
|
9
|
+
type: 'MsaView',
|
|
10
|
+
displayName,
|
|
11
|
+
connectedViewId,
|
|
12
|
+
connectedFeature,
|
|
13
|
+
colorSchemeName,
|
|
14
|
+
colWidth,
|
|
15
|
+
rowHeight,
|
|
16
|
+
treeAreaWidth,
|
|
17
|
+
treeWidth,
|
|
18
|
+
drawNodeBubbles,
|
|
19
|
+
labelsAlignRight,
|
|
20
|
+
showBranchLen,
|
|
21
|
+
init: {
|
|
22
|
+
msaData: data?.msa,
|
|
23
|
+
treeData: data?.tree,
|
|
24
|
+
msaUrl: msaFileLocation?.uri,
|
|
25
|
+
treeUrl: treeFileLocation?.uri,
|
|
26
|
+
querySeqName,
|
|
27
|
+
},
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/LaunchMsaViewExtensionPoint/index.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,OAAO,UAAU,4BAA4B,CAClD,aAA4B;IAE5B,aAAa,CAAC,mBAAmB,CAC/B,oBAAoB;IACpB,mBAAmB;IACnB,CAAC,EACC,OAAO,EACP,IAAI,EACJ,eAAe,EACf,gBAAgB,EAChB,eAAe,EACf,gBAAgB,EAChB,WAAW,EACX,eAAe,EACf,QAAQ,EACR,SAAS,EACT,aAAa,EACb,SAAS,EACT,eAAe,EACf,gBAAgB,EAChB,aAAa,EACb,YAAY,GAkBb,EAAE,EAAE;QACH,IAAI,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YAC9B,MAAM,IAAI,KAAK,CACb,+DAA+D,CAChE,CAAA;QACH,CAAC;QAED,OAAO,CAAC,OAAO,CAAC,SAAS,EAAE;YACzB,IAAI,EAAE,SAAS;YACf,WAAW;YACX,eAAe;YACf,gBAAgB;YAChB,eAAe;YACf,QAAQ;YACR,SAAS;YACT,aAAa;YACb,SAAS;YACT,eAAe;YACf,gBAAgB;YAChB,aAAa;YACb,IAAI,EAAE;gBACJ,OAAO,EAAE,IAAI,EAAE,GAAG;gBAClB,QAAQ,EAAE,IAAI,EAAE,IAAI;gBACpB,MAAM,EAAE,eAAe,EAAE,GAAG;gBAC5B,OAAO,EAAE,gBAAgB,EAAE,GAAG;gBAC9B,YAAY;aACb;SACF,CAAC,CAAA;IACJ,CAAC,CACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { JBrowsePluginMsaViewModel } from '../model';
|
|
3
|
+
declare const ConnectStructureDialog: ({ model, handleClose, }: {
|
|
4
|
+
model: JBrowsePluginMsaViewModel;
|
|
5
|
+
handleClose: () => void;
|
|
6
|
+
}) => React.JSX.Element;
|
|
7
|
+
export default ConnectStructureDialog;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { Dialog } from '@jbrowse/core/ui';
|
|
3
|
+
import { getSession } from '@jbrowse/core/util';
|
|
4
|
+
import { Button, DialogActions, DialogContent, FormControl, InputLabel, MenuItem, Select, Typography, } from '@mui/material';
|
|
5
|
+
import { observer } from 'mobx-react';
|
|
6
|
+
const ConnectStructureDialog = observer(function ConnectStructureDialog({ model, handleClose, }) {
|
|
7
|
+
const session = getSession(model);
|
|
8
|
+
const [selectedViewId, setSelectedViewId] = useState('');
|
|
9
|
+
const [selectedStructureIdx, setSelectedStructureIdx] = useState(0);
|
|
10
|
+
const [selectedMsaRow, setSelectedMsaRow] = useState(model.querySeqName);
|
|
11
|
+
const [error, setError] = useState();
|
|
12
|
+
// Find all ProteinViews in the session
|
|
13
|
+
const proteinViews = session.views.filter((v) => v.type === 'ProteinView');
|
|
14
|
+
// Get structures for the selected view
|
|
15
|
+
const selectedView = proteinViews.find(v => v.id === selectedViewId);
|
|
16
|
+
const structures = selectedView?.structures ?? [];
|
|
17
|
+
// Get MSA row names
|
|
18
|
+
const msaRowNames = model.rows.map(r => r[0]);
|
|
19
|
+
const handleConnect = () => {
|
|
20
|
+
if (!selectedViewId) {
|
|
21
|
+
setError('Please select a protein view');
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
try {
|
|
25
|
+
model.connectToStructure(selectedViewId, selectedStructureIdx, selectedMsaRow);
|
|
26
|
+
handleClose();
|
|
27
|
+
}
|
|
28
|
+
catch (e) {
|
|
29
|
+
setError(e instanceof Error ? e.message : String(e));
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
return (React.createElement(Dialog, { maxWidth: "sm", title: "Connect to Protein Structure", open: true, onClose: handleClose },
|
|
33
|
+
React.createElement(DialogContent, null, proteinViews.length === 0 ? (React.createElement(Typography, { color: "textSecondary" }, "No protein views are currently open. Please open a protein structure view first.")) : (React.createElement(React.Fragment, null,
|
|
34
|
+
React.createElement(FormControl, { fullWidth: true, sx: { mb: 2 } },
|
|
35
|
+
React.createElement(InputLabel, null, "Protein View"),
|
|
36
|
+
React.createElement(Select, { value: selectedViewId, label: "Protein View", onChange: e => {
|
|
37
|
+
setSelectedViewId(e.target.value);
|
|
38
|
+
setSelectedStructureIdx(0);
|
|
39
|
+
} }, proteinViews.map(view => (React.createElement(MenuItem, { key: view.id, value: view.id }, view.displayName ?? `ProteinView ${view.id}`))))),
|
|
40
|
+
structures.length > 1 && (React.createElement(FormControl, { fullWidth: true, sx: { mb: 2 } },
|
|
41
|
+
React.createElement(InputLabel, null, "Structure"),
|
|
42
|
+
React.createElement(Select, { value: selectedStructureIdx, label: "Structure", onChange: e => {
|
|
43
|
+
setSelectedStructureIdx(e.target.value);
|
|
44
|
+
} }, structures.map((structure, idx) => (React.createElement(MenuItem, { key: idx, value: idx }, structure.url ?? `Structure ${idx + 1}`)))))),
|
|
45
|
+
React.createElement(FormControl, { fullWidth: true, sx: { mb: 2 } },
|
|
46
|
+
React.createElement(InputLabel, null, "MSA Row"),
|
|
47
|
+
React.createElement(Select, { value: selectedMsaRow, label: "MSA Row", onChange: e => {
|
|
48
|
+
setSelectedMsaRow(e.target.value);
|
|
49
|
+
} }, msaRowNames.map(name => (React.createElement(MenuItem, { key: name, value: name }, name))))),
|
|
50
|
+
error && (React.createElement(Typography, { color: "error", sx: { mt: 1 } }, error))))),
|
|
51
|
+
React.createElement(DialogActions, null,
|
|
52
|
+
React.createElement(Button, { onClick: handleClose }, "Cancel"),
|
|
53
|
+
React.createElement(Button, { onClick: handleConnect, variant: "contained", disabled: proteinViews.length === 0 || !selectedViewId }, "Connect"))));
|
|
54
|
+
});
|
|
55
|
+
export default ConnectStructureDialog;
|
|
56
|
+
//# sourceMappingURL=ConnectStructureDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConnectStructureDialog.js","sourceRoot":"","sources":["../../../src/MsaViewPanel/components/ConnectStructureDialog.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
+
import { LoadingEllipses } from '@jbrowse/core/ui';
|
|
2
3
|
import { observer } from 'mobx-react';
|
|
3
4
|
import { MSAView } from 'react-msaview';
|
|
4
5
|
import LoadingBLAST from './LoadingBLAST';
|
|
5
6
|
const MsaViewPanel = observer(function MsaViewPanel2({ model, }) {
|
|
6
|
-
const { blastParams } = model;
|
|
7
|
-
return (React.createElement("div", null, blastParams ? (React.createElement(LoadingBLAST, { model: model, baseUrl: blastParams.baseUrl })) : (React.createElement(
|
|
7
|
+
const { blastParams, loadingStoredData } = model;
|
|
8
|
+
return (React.createElement("div", null, blastParams ? (React.createElement(LoadingBLAST, { model: model, baseUrl: blastParams.baseUrl })) : loadingStoredData ? (React.createElement("div", { style: { padding: 20 } },
|
|
9
|
+
React.createElement(LoadingEllipses, { message: "Loading MSA data", variant: "h6" }))) : (React.createElement(MSAView, { model: model }))));
|
|
8
10
|
});
|
|
9
11
|
export default MsaViewPanel;
|
|
10
12
|
//# sourceMappingURL=MsaViewPanel.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MsaViewPanel.js","sourceRoot":"","sources":["../../../src/MsaViewPanel/components/MsaViewPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AACrC,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AAGvC,OAAO,YAAY,MAAM,gBAAgB,CAAA;AAEzC,MAAM,YAAY,GAAG,QAAQ,CAAC,SAAS,aAAa,CAAC,EACnD,KAAK,GAGN;IACC,MAAM,EAAE,WAAW,EAAE,GAAG,KAAK,CAAA;
|
|
1
|
+
{"version":3,"file":"MsaViewPanel.js","sourceRoot":"","sources":["../../../src/MsaViewPanel/components/MsaViewPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AACrC,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AAGvC,OAAO,YAAY,MAAM,gBAAgB,CAAA;AAEzC,MAAM,YAAY,GAAG,QAAQ,CAAC,SAAS,aAAa,CAAC,EACnD,KAAK,GAGN;IACC,MAAM,EAAE,WAAW,EAAE,iBAAiB,EAAE,GAAG,KAAK,CAAA;IAChD,OAAO,CACL,iCACG,WAAW,CAAC,CAAC,CAAC,CACb,oBAAC,YAAY,IAAC,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,WAAW,CAAC,OAAO,GAAI,CAC7D,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,CACtB,6BAAK,KAAK,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE;QACzB,oBAAC,eAAe,IAAC,OAAO,EAAC,kBAAkB,EAAC,OAAO,EAAC,IAAI,GAAG,CACvD,CACP,CAAC,CAAC,CAAC,CACF,oBAAC,OAAO,IAAC,KAAK,EAAE,KAAK,GAAI,CAC1B,CACG,CACP,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,YAAY,CAAA"}
|
|
@@ -1,38 +1,84 @@
|
|
|
1
1
|
import { makeId, strip } from '../LaunchMsaView/components/util';
|
|
2
|
+
import { cleanProteinSequence } from '../LaunchMsaView/util';
|
|
3
|
+
import { saveBlastResult } from '../utils/blastCache';
|
|
2
4
|
import { launchMSA } from '../utils/msa';
|
|
3
5
|
import { queryBlast } from '../utils/ncbiBlast';
|
|
6
|
+
import { fetchTaxonomyInfo } from '../utils/taxonomyNames';
|
|
4
7
|
export async function doLaunchBlast({ self, }) {
|
|
5
|
-
const { baseUrl, blastDatabase, blastProgram, msaAlgorithm, proteinSequence, } = self.blastParams;
|
|
6
|
-
const
|
|
7
|
-
|
|
8
|
+
const { baseUrl, blastDatabase, blastProgram, msaAlgorithm, proteinSequence, selectedTranscript, } = self.blastParams;
|
|
9
|
+
const cleanedSeq = cleanProteinSequence(proteinSequence);
|
|
10
|
+
const { hits, rid } = await queryBlast({
|
|
11
|
+
query: cleanedSeq,
|
|
8
12
|
blastDatabase,
|
|
9
13
|
blastProgram,
|
|
10
14
|
baseUrl,
|
|
11
15
|
onProgress: arg => {
|
|
12
16
|
self.setProgress(arg);
|
|
13
17
|
},
|
|
14
|
-
onRid:
|
|
15
|
-
self.setRid(
|
|
18
|
+
onRid: r => {
|
|
19
|
+
self.setRid(r);
|
|
16
20
|
},
|
|
17
21
|
});
|
|
18
|
-
|
|
22
|
+
self.setProgress('Fetching species taxonomy info...');
|
|
23
|
+
const taxids = hits
|
|
24
|
+
.map(h => h.description[0]?.taxid)
|
|
25
|
+
.filter((t) => t !== undefined);
|
|
26
|
+
const taxonomyInfo = await fetchTaxonomyInfo(taxids);
|
|
27
|
+
const treeMetadata = {};
|
|
28
|
+
const sequences = hits.map(h => {
|
|
29
|
+
const desc = h.description[0] ?? {
|
|
30
|
+
accession: 'unknown',
|
|
31
|
+
id: 'unknown',
|
|
32
|
+
sciname: 'unknown',
|
|
33
|
+
};
|
|
34
|
+
const rowName = makeId(desc, taxonomyInfo);
|
|
35
|
+
const seq = strip(h.hsps[0]?.hseq ?? '');
|
|
36
|
+
treeMetadata[rowName] = buildRowMetadata(desc, taxonomyInfo);
|
|
37
|
+
return `>${rowName}\n${seq}`;
|
|
38
|
+
});
|
|
39
|
+
const result = await launchMSA({
|
|
19
40
|
algorithm: msaAlgorithm,
|
|
20
|
-
sequence: [
|
|
21
|
-
`>QUERY\n${proteinSequence.replaceAll('*', '').replaceAll('&', '')}`,
|
|
22
|
-
...hits
|
|
23
|
-
.map(h => [
|
|
24
|
-
makeId(h.description[0] ?? {
|
|
25
|
-
accession: 'unknown',
|
|
26
|
-
id: 'unknown',
|
|
27
|
-
sciname: 'unknown',
|
|
28
|
-
}),
|
|
29
|
-
strip(h.hsps[0]?.hseq ?? ''),
|
|
30
|
-
])
|
|
31
|
-
.map(([id, seq]) => `>${id}\n${seq}`),
|
|
32
|
-
].join('\n'),
|
|
41
|
+
sequence: [`>QUERY\n${cleanedSeq}`, ...sequences].join('\n'),
|
|
33
42
|
onProgress: arg => {
|
|
34
43
|
self.setProgress(arg);
|
|
35
44
|
},
|
|
36
45
|
});
|
|
46
|
+
const treeMetadataJson = JSON.stringify(treeMetadata);
|
|
47
|
+
await saveBlastResult({
|
|
48
|
+
proteinSequence: cleanedSeq,
|
|
49
|
+
blastDatabase,
|
|
50
|
+
blastProgram,
|
|
51
|
+
msaAlgorithm,
|
|
52
|
+
msa: result.msa,
|
|
53
|
+
tree: result.tree,
|
|
54
|
+
treeMetadata: treeMetadataJson,
|
|
55
|
+
rid,
|
|
56
|
+
geneId: selectedTranscript?.get('parentId'),
|
|
57
|
+
transcriptId: selectedTranscript?.get('id'),
|
|
58
|
+
});
|
|
59
|
+
return {
|
|
60
|
+
...result,
|
|
61
|
+
treeMetadata: treeMetadataJson,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
function buildRowMetadata(desc, taxonomyInfo) {
|
|
65
|
+
const metadata = {};
|
|
66
|
+
const taxInfo = desc.taxid ? taxonomyInfo.get(desc.taxid) : undefined;
|
|
67
|
+
if (taxInfo?.sciname) {
|
|
68
|
+
metadata['Scientific name'] = taxInfo.sciname;
|
|
69
|
+
}
|
|
70
|
+
if (taxInfo?.commonName) {
|
|
71
|
+
metadata['Common name'] = taxInfo.commonName;
|
|
72
|
+
}
|
|
73
|
+
if (desc.accession) {
|
|
74
|
+
metadata.Accession = desc.accession;
|
|
75
|
+
}
|
|
76
|
+
if (desc.id) {
|
|
77
|
+
metadata.ID = desc.id;
|
|
78
|
+
}
|
|
79
|
+
if (desc.title) {
|
|
80
|
+
metadata.Description = desc.title;
|
|
81
|
+
}
|
|
82
|
+
return metadata;
|
|
37
83
|
}
|
|
38
84
|
//# sourceMappingURL=doLaunchBlast.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"doLaunchBlast.js","sourceRoot":"","sources":["../../src/MsaViewPanel/doLaunchBlast.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAA;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAA;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;
|
|
1
|
+
{"version":3,"file":"doLaunchBlast.js","sourceRoot":"","sources":["../../src/MsaViewPanel/doLaunchBlast.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,kCAAkC,CAAA;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAA;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAA;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAK1D,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,EAClC,IAAI,GAGL;IACC,MAAM,EACJ,OAAO,EACP,aAAa,EACb,YAAY,EACZ,YAAY,EACZ,eAAe,EACf,kBAAkB,GACnB,GAAG,IAAI,CAAC,WAAY,CAAA;IACrB,MAAM,UAAU,GAAG,oBAAoB,CAAC,eAAe,CAAC,CAAA;IAExD,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,MAAM,UAAU,CAAC;QACrC,KAAK,EAAE,UAAU;QACjB,aAAa;QACb,YAAY;QACZ,OAAO;QACP,UAAU,EAAE,GAAG,CAAC,EAAE;YAChB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAA;QACvB,CAAC;QACD,KAAK,EAAE,CAAC,CAAC,EAAE;YACT,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;QAChB,CAAC;KACF,CAAC,CAAA;IAEF,IAAI,CAAC,WAAW,CAAC,mCAAmC,CAAC,CAAA;IACrD,MAAM,MAAM,GAAG,IAAI;SAChB,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC;SACjC,MAAM,CAAC,CAAC,CAAC,EAAe,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAA;IAC9C,MAAM,YAAY,GAAG,MAAM,iBAAiB,CAAC,MAAM,CAAC,CAAA;IAEpD,MAAM,YAAY,GAA2C,EAAE,CAAA;IAE/D,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;QAC7B,MAAM,IAAI,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI;YAC/B,SAAS,EAAE,SAAS;YACpB,EAAE,EAAE,SAAS;YACb,OAAO,EAAE,SAAS;SACnB,CAAA;QACD,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,EAAE,YAAY,CAAC,CAAA;QAC1C,MAAM,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,EAAE,CAAC,CAAA;QAExC,YAAY,CAAC,OAAO,CAAC,GAAG,gBAAgB,CAAC,IAAI,EAAE,YAAY,CAAC,CAAA;QAE5D,OAAO,IAAI,OAAO,KAAK,GAAG,EAAE,CAAA;IAC9B,CAAC,CAAC,CAAA;IAEF,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC;QAC7B,SAAS,EAAE,YAAY;QACvB,QAAQ,EAAE,CAAC,WAAW,UAAU,EAAE,EAAE,GAAG,SAAS,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;QAC5D,UAAU,EAAE,GAAG,CAAC,EAAE;YAChB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAA;QACvB,CAAC;KACF,CAAC,CAAA;IAEF,MAAM,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAA;IAErD,MAAM,eAAe,CAAC;QACpB,eAAe,EAAE,UAAU;QAC3B,aAAa;QACb,YAAY;QACZ,YAAY;QACZ,GAAG,EAAE,MAAM,CAAC,GAAG;QACf,IAAI,EAAE,MAAM,CAAC,IAAI;QACjB,YAAY,EAAE,gBAAgB;QAC9B,GAAG;QACH,MAAM,EAAE,kBAAkB,EAAE,GAAG,CAAC,UAAU,CAAC;QAC3C,YAAY,EAAE,kBAAkB,EAAE,GAAG,CAAC,IAAI,CAAC;KAC5C,CAAC,CAAA;IAEF,OAAO;QACL,GAAG,MAAM;QACT,YAAY,EAAE,gBAAgB;KAC/B,CAAA;AACH,CAAC;AAED,SAAS,gBAAgB,CACvB,IAAyB,EACzB,YAAuC;IAEvC,MAAM,QAAQ,GAA2B,EAAE,CAAA;IAC3C,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;IAErE,IAAI,OAAO,EAAE,OAAO,EAAE,CAAC;QACrB,QAAQ,CAAC,iBAAiB,CAAC,GAAG,OAAO,CAAC,OAAO,CAAA;IAC/C,CAAC;IACD,IAAI,OAAO,EAAE,UAAU,EAAE,CAAC;QACxB,QAAQ,CAAC,aAAa,CAAC,GAAG,OAAO,CAAC,UAAU,CAAA;IAC9C,CAAC;IACD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,QAAQ,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAA;IACrC,CAAC;IACD,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;QACZ,QAAQ,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAA;IACvB,CAAC;IACD,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,QAAQ,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAA;IACnC,CAAC;IAED,OAAO,QAAQ,CAAA;AACjB,CAAC"}
|
|
@@ -1,4 +1,10 @@
|
|
|
1
1
|
import { JBrowsePluginMsaViewModel } from './model';
|
|
2
|
+
/**
|
|
3
|
+
* Convert a genome coordinate from session.hovered to a visible MSA column.
|
|
4
|
+
*
|
|
5
|
+
* @param model - The MSA view model
|
|
6
|
+
* @returns The visible column index, or undefined if no mapping exists
|
|
7
|
+
*/
|
|
2
8
|
export declare function genomeToMSA({ model }: {
|
|
3
9
|
model: JBrowsePluginMsaViewModel;
|
|
4
10
|
}): number | undefined;
|