jbrowse-plugin-msaview 2.1.0 → 2.2.1

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.
Files changed (170) hide show
  1. package/dist/AddHighlightModel/GenomeMouseoverHighlight.js +3 -3
  2. package/dist/AddHighlightModel/GenomeMouseoverHighlight.js.map +1 -1
  3. package/dist/AddHighlightModel/MsaToGenomeHighlight.js +3 -1
  4. package/dist/AddHighlightModel/MsaToGenomeHighlight.js.map +1 -1
  5. package/dist/ExternalLink.d.ts +3 -0
  6. package/dist/ExternalLink.js +11 -0
  7. package/dist/ExternalLink.js.map +1 -0
  8. package/dist/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.js +28 -33
  9. package/dist/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.js.map +1 -1
  10. package/dist/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeLaunchView.js +0 -6
  11. package/dist/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeLaunchView.js.map +1 -1
  12. package/dist/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeUtils.d.ts +1 -0
  13. package/dist/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeUtils.js +12 -22
  14. package/dist/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeUtils.js.map +1 -1
  15. package/dist/LaunchMsaView/components/EnsemblGeneTree/gatherSequencesFromTree.d.ts +2 -0
  16. package/dist/LaunchMsaView/components/EnsemblGeneTree/gatherSequencesFromTree.js +20 -0
  17. package/dist/LaunchMsaView/components/EnsemblGeneTree/gatherSequencesFromTree.js.map +1 -0
  18. package/dist/LaunchMsaView/components/EnsemblGeneTree/types.d.ts +24 -0
  19. package/dist/LaunchMsaView/components/EnsemblGeneTree/types.js.map +1 -0
  20. package/dist/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.d.ts +10 -0
  21. package/dist/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.js +27 -0
  22. package/dist/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.js.map +1 -0
  23. package/dist/LaunchMsaView/components/LaunchMsaViewDialog.js +5 -5
  24. package/dist/LaunchMsaView/components/LaunchMsaViewDialog.js.map +1 -1
  25. package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/NcbiBlastPanel.d.ts → ManualMSALoader/ManualMSALoader.d.ts} +2 -2
  26. package/dist/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.js +103 -0
  27. package/dist/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.js.map +1 -0
  28. package/dist/LaunchMsaView/components/{EnsemblGeneTree → ManualMSALoader}/fetchGeneList.js.map +1 -1
  29. package/dist/LaunchMsaView/components/ManualMSALoader/launchView.d.ts +14 -0
  30. package/dist/LaunchMsaView/components/ManualMSALoader/launchView.js +12 -0
  31. package/dist/LaunchMsaView/components/ManualMSALoader/launchView.js.map +1 -0
  32. package/dist/LaunchMsaView/components/{MSALoader/MSALoader.d.ts → NCBIBlastQuery/NCBIBlastAutomaticPanel.d.ts} +4 -2
  33. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.js +89 -0
  34. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.js.map +1 -0
  35. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.d.ts +10 -0
  36. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.js +55 -0
  37. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.js.map +1 -0
  38. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastMethodSelector.d.ts +5 -0
  39. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastMethodSelector.js +11 -0
  40. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastMethodSelector.js.map +1 -0
  41. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastPanel.d.ts +7 -0
  42. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastPanel.js +30 -0
  43. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastPanel.js.map +1 -0
  44. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBISettingsDialog.d.ts +5 -0
  45. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBISettingsDialog.js +26 -0
  46. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBISettingsDialog.js.map +1 -0
  47. package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/ncbiBlastLaunchView.d.ts → NCBIBlastQuery/blastLaunchView.d.ts} +2 -1
  48. package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/ncbiBlastLaunchView.js → NCBIBlastQuery/blastLaunchView.js} +3 -6
  49. package/dist/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.js.map +1 -0
  50. package/dist/LaunchMsaView/components/NCBIBlastQuery/consts.d.ts +1 -0
  51. package/dist/LaunchMsaView/components/NCBIBlastQuery/consts.js +2 -0
  52. package/dist/LaunchMsaView/components/NCBIBlastQuery/consts.js.map +1 -0
  53. package/dist/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.js +17 -16
  54. package/dist/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.js.map +1 -1
  55. package/dist/LaunchMsaView/components/TranscriptSelector.d.ts +10 -0
  56. package/dist/LaunchMsaView/components/TranscriptSelector.js +45 -0
  57. package/dist/LaunchMsaView/components/TranscriptSelector.js.map +1 -0
  58. package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/calculateProteinSequence.d.ts → calculateProteinSequence.d.ts} +1 -2
  59. package/dist/LaunchMsaView/components/calculateProteinSequence.js +39 -0
  60. package/dist/LaunchMsaView/components/calculateProteinSequence.js.map +1 -0
  61. package/dist/LaunchMsaView/components/fetchSeq.js.map +1 -0
  62. package/dist/LaunchMsaView/components/types.js +2 -0
  63. package/dist/LaunchMsaView/components/types.js.map +1 -0
  64. package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/useFeatureSequence.d.ts → useFeatureSequence.d.ts} +2 -1
  65. package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/useFeatureSequence.js → useFeatureSequence.js} +12 -1
  66. package/dist/LaunchMsaView/components/useFeatureSequence.js.map +1 -0
  67. package/dist/LaunchMsaView/components/util.js.map +1 -0
  68. package/dist/LaunchMsaView/util.d.ts +5 -1
  69. package/dist/LaunchMsaView/util.js +15 -1
  70. package/dist/LaunchMsaView/util.js.map +1 -1
  71. package/dist/MsaViewPanel/components/LoadingBLAST.d.ts +2 -1
  72. package/dist/MsaViewPanel/components/LoadingBLAST.js +6 -6
  73. package/dist/MsaViewPanel/components/LoadingBLAST.js.map +1 -1
  74. package/dist/MsaViewPanel/components/MsaViewPanel.js +1 -1
  75. package/dist/MsaViewPanel/components/MsaViewPanel.js.map +1 -1
  76. package/dist/MsaViewPanel/components/RIDLink.d.ts +2 -1
  77. package/dist/MsaViewPanel/components/RIDLink.js +6 -9
  78. package/dist/MsaViewPanel/components/RIDLink.js.map +1 -1
  79. package/dist/MsaViewPanel/doLaunchBlast.js +18 -20
  80. package/dist/MsaViewPanel/doLaunchBlast.js.map +1 -1
  81. package/dist/MsaViewPanel/model.d.ts +3 -4
  82. package/dist/MsaViewPanel/model.js.map +1 -1
  83. package/dist/ReadOnlyTextField2.d.ts +4 -0
  84. package/dist/ReadOnlyTextField2.js +20 -0
  85. package/dist/ReadOnlyTextField2.js.map +1 -0
  86. package/dist/jbrowse-plugin-msaview.umd.production.min.js +41 -51
  87. package/dist/jbrowse-plugin-msaview.umd.production.min.js.map +4 -4
  88. package/dist/utils/fetch.d.ts +1 -1
  89. package/dist/utils/fetch.js.map +1 -1
  90. package/dist/utils/ncbiBlast.d.ts +2 -2
  91. package/dist/utils/ncbiBlast.js +29 -15
  92. package/dist/utils/ncbiBlast.js.map +1 -1
  93. package/dist/utils/types.d.ts +20 -0
  94. package/dist/utils/types.js +2 -0
  95. package/dist/utils/types.js.map +1 -0
  96. package/package.json +3 -3
  97. package/src/AddHighlightModel/GenomeMouseoverHighlight.tsx +3 -3
  98. package/src/AddHighlightModel/MsaToGenomeHighlight.tsx +2 -1
  99. package/src/ExternalLink.tsx +15 -0
  100. package/src/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.tsx +39 -55
  101. package/src/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeLaunchView.ts +0 -6
  102. package/src/LaunchMsaView/components/EnsemblGeneTree/ensemblGeneTreeUtils.ts +19 -54
  103. package/src/LaunchMsaView/components/EnsemblGeneTree/gatherSequencesFromTree.ts +22 -0
  104. package/src/LaunchMsaView/components/EnsemblGeneTree/types.ts +28 -0
  105. package/src/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.ts +29 -0
  106. package/src/LaunchMsaView/components/LaunchMsaViewDialog.tsx +9 -5
  107. package/src/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.tsx +219 -0
  108. package/src/LaunchMsaView/components/ManualMSALoader/launchView.ts +34 -0
  109. package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.tsx +226 -0
  110. package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.tsx +111 -0
  111. package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastMethodSelector.tsx +34 -0
  112. package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastPanel.tsx +82 -0
  113. package/src/LaunchMsaView/components/NCBIBlastQuery/NCBISettingsDialog.tsx +75 -0
  114. package/src/LaunchMsaView/components/{NewNCBIBlastQuery/ncbiBlastLaunchView.ts → NCBIBlastQuery/blastLaunchView.ts} +4 -5
  115. package/src/LaunchMsaView/components/NCBIBlastQuery/consts.ts +1 -0
  116. package/src/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.tsx +27 -37
  117. package/src/LaunchMsaView/components/TranscriptSelector.tsx +99 -0
  118. package/src/LaunchMsaView/components/{NewNCBIBlastQuery/calculateProteinSequence.ts → calculateProteinSequence.ts} +12 -22
  119. package/src/LaunchMsaView/components/{NewNCBIBlastQuery/useFeatureSequence.ts → useFeatureSequence.ts} +16 -2
  120. package/src/LaunchMsaView/util.ts +22 -2
  121. package/src/MsaViewPanel/components/LoadingBLAST.tsx +26 -8
  122. package/src/MsaViewPanel/components/MsaViewPanel.tsx +5 -1
  123. package/src/MsaViewPanel/components/RIDLink.tsx +8 -8
  124. package/src/MsaViewPanel/doLaunchBlast.ts +29 -30
  125. package/src/MsaViewPanel/model.ts +1 -0
  126. package/src/ReadOnlyTextField2.tsx +33 -0
  127. package/src/utils/fetch.ts +2 -2
  128. package/src/utils/ncbiBlast.ts +40 -30
  129. package/src/utils/types.ts +14 -0
  130. package/dist/LaunchMsaView/components/MSALoader/MSALoader.js +0 -94
  131. package/dist/LaunchMsaView/components/MSALoader/MSALoader.js.map +0 -1
  132. package/dist/LaunchMsaView/components/MSALoader/fetchGeneList.d.ts +0 -1
  133. package/dist/LaunchMsaView/components/MSALoader/fetchGeneList.js +0 -12
  134. package/dist/LaunchMsaView/components/MSALoader/fetchGeneList.js.map +0 -1
  135. package/dist/LaunchMsaView/components/MSALoader/preCalculatedLaunchView.d.ts +0 -9
  136. package/dist/LaunchMsaView/components/MSALoader/preCalculatedLaunchView.js +0 -36
  137. package/dist/LaunchMsaView/components/MSALoader/preCalculatedLaunchView.js.map +0 -1
  138. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/NcbiBlastPanel.js +0 -85
  139. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/NcbiBlastPanel.js.map +0 -1
  140. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/calculateProteinSequence.js +0 -47
  141. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/calculateProteinSequence.js.map +0 -1
  142. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/fetchSeq.js.map +0 -1
  143. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/index.d.ts +0 -1
  144. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/index.js +0 -2
  145. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/index.js.map +0 -1
  146. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/ncbiBlastLaunchView.js.map +0 -1
  147. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/types.js.map +0 -1
  148. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/useFeatureSequence.js.map +0 -1
  149. package/dist/LaunchMsaView/components/NewNCBIBlastQuery/util.js.map +0 -1
  150. package/dist/OpenInNewIcon.d.ts +0 -3
  151. package/dist/OpenInNewIcon.js +0 -8
  152. package/dist/OpenInNewIcon.js.map +0 -1
  153. package/src/LaunchMsaView/components/MSALoader/MSALoader.tsx +0 -130
  154. package/src/LaunchMsaView/components/MSALoader/fetchGeneList.ts +0 -13
  155. package/src/LaunchMsaView/components/MSALoader/preCalculatedLaunchView.ts +0 -55
  156. package/src/LaunchMsaView/components/NewNCBIBlastQuery/NcbiBlastPanel.tsx +0 -171
  157. package/src/LaunchMsaView/components/NewNCBIBlastQuery/index.tsx +0 -1
  158. package/src/OpenInNewIcon.tsx +0 -14
  159. /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery → EnsemblGeneTree}/types.js +0 -0
  160. /package/dist/LaunchMsaView/components/{EnsemblGeneTree → ManualMSALoader}/fetchGeneList.d.ts +0 -0
  161. /package/dist/LaunchMsaView/components/{EnsemblGeneTree → ManualMSALoader}/fetchGeneList.js +0 -0
  162. /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/fetchSeq.d.ts → fetchSeq.d.ts} +0 -0
  163. /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/fetchSeq.js → fetchSeq.js} +0 -0
  164. /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/types.d.ts → types.d.ts} +0 -0
  165. /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/util.d.ts → util.d.ts} +0 -0
  166. /package/dist/LaunchMsaView/components/{NewNCBIBlastQuery/util.js → util.js} +0 -0
  167. /package/src/LaunchMsaView/components/{EnsemblGeneTree → ManualMSALoader}/fetchGeneList.ts +0 -0
  168. /package/src/LaunchMsaView/components/{NewNCBIBlastQuery/fetchSeq.ts → fetchSeq.ts} +0 -0
  169. /package/src/LaunchMsaView/components/{NewNCBIBlastQuery/types.ts → types.ts} +0 -0
  170. /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":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEvC,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAA;AAC/C,OAAO,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAChE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,OAAO,YAAY,MAAM,uBAAuB,CAAA;AAChD,OAAO,EAAE,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAA;AACzD,OAAO,kBAAkB,MAAM,uBAAuB,CAAA;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAA;AAK1D,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC;IAC7B,aAAa,EAAE;QACb,KAAK,EAAE,MAAM;KACd;IACD,YAAY,EAAE;QACZ,UAAU,EAAE,aAAa;KAC1B;IACD,QAAQ,EAAE;QACR,SAAS,EAAE,WAAW;QACtB,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE,GAAG;KACd;CACF,CAAC,CAAA;AAEF,MAAM,oBAAoB,GAAG,QAAQ,CAAC,UAAU,EAC9C,WAAW,EACX,OAAO,EACP,KAAK,EACL,QAAQ,EACR,OAAO,GAOR;IACC,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAA;IAC/B,MAAM,IAAI,GAAG,iBAAiB,CAAC,KAAK,CAA0B,CAAA;IAC9D,MAAM,OAAO,GAAG,qBAAqB,CAAC,OAAO,CAAC,CAAA;IAC9C,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IACrE,MAAM,kBAAkB,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,aAAa,CAAE,CAAA;IAC7E,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,GAAG,kBAAkB,CAAC;QACpD,IAAI;QACJ,OAAO,EAAE,kBAAkB;KAC5B,CAAC,CAAA;IAEF,MAAM,EAAE,GAAG,eAAe,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;IAClE,MAAM,IAAI,GAAG,GAAG,OAAO,6DAA6D,EAAE,EAAE,CAAA;IACxF,MAAM,KAAK,GAAG,GAAG,OAAO,6DAA6D,QAAQ,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAA;IAEvG,OAAO,CACL;QACE,oBAAC,aAAa,IAAC,SAAS,EAAE,OAAO,CAAC,aAAa;YAC5C,QAAQ;YACR,KAAK,CAAC,CAAC,CAAC,oBAAC,YAAY,IAAC,KAAK,EAAE,KAAK,GAAI,CAAC,CAAC,CAAC,IAAI;YAE9C,oBAAC,kBAAkB,IACjB,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,OAAO,EAChB,oBAAoB,EAAE,aAAa,EACnC,kBAAkB,EAAE,gBAAgB,EACpC,eAAe,EAAE,eAAe,GAChC;YAED,eAAe,CAAC,CAAC,CAAC,CACjB,6BAAK,SAAS,EAAE,OAAO,CAAC,QAAQ;;gBACV,oBAAC,YAAY,IAAC,IAAI,EAAE,IAAI,IAAG,KAAK,CAAgB,CAChE,CACP,CAAC,CAAC,CAAC,IAAI;YAER,oBAAC,UAAU,IAAC,KAAK,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,2UAMvB,CACC;QAEhB,oBAAC,aAAa;YACZ,oBAAC,MAAM,IACL,KAAK,EAAC,SAAS,EACf,OAAO,EAAC,WAAW,EACnB,OAAO,EAAE,GAAG,EAAE;oBACZ,WAAW,EAAE,CAAA;gBACf,CAAC,aAGM;YACT,oBAAC,MAAM,IACL,KAAK,EAAC,WAAW,EACjB,OAAO,EAAC,WAAW,EACnB,OAAO,EAAE,GAAG,EAAE;oBACZ,WAAW,EAAE,CAAA;gBACf,CAAC,YAGM,CACK,CACf,CACJ,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,oBAAoB,CAAA"}
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ export default function NCBIBlastMethodSelector({ lookupMethod, setLookupMethod, }: {
3
+ lookupMethod: string;
4
+ setLookupMethod: (method: string) => void;
5
+ }): React.JSX.Element;
@@ -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,5 @@
1
+ import React from 'react';
2
+ export default function NCBISettingsDialog({ handleClose, baseUrl, }: {
3
+ handleClose: (arg?: string) => void;
4
+ baseUrl: string;
5
+ }): React.JSX.Element;
@@ -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 ncbiBlastLaunchView({ newViewTitle, view, feature, }: {
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 ncbiBlastLaunchView({ newViewTitle, view, feature, }) {
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
- colorSchemeName: 'percent_identity_dynamic',
11
+ blastParams,
15
12
  });
16
13
  }
17
- //# sourceMappingURL=ncbiBlastLaunchView.js.map
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,2 @@
1
+ export const BASE_BLAST_URL = 'https://blast.ncbi.nlm.nih.gov/Blast.cgi';
2
+ //# sourceMappingURL=consts.js.map
@@ -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, MenuItem, TextField, Typography, } from '@mui/material';
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 { getGeneDisplayName, getId, getTranscriptDisplayName, getTranscriptFeatures, } from '../../util';
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 [error, setError] = useState();
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 set = new Set(geneNameList);
44
+ const validSet = new Set(geneNameList);
42
45
  const options = getTranscriptFeatures(feature);
43
- const ret = options.find(val => set.has(getId(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("a", { href: "https://hgdownload.soe.ucsc.edu/goldenPath/hg38/multiz100way/alignments/" }, "knownCanonical.multiz100way.protAA.fa.gz")),
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(TextField, { select: true, label: "Choose isoform to view MSA for", value: userSelection, onChange: event => {
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":"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"}
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 dedupe(list: Feat[]): Feat[];
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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -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
- return { sequence, error };
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