jbrowse-plugin-msaview 2.2.2 → 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.
Files changed (162) hide show
  1. package/CHANGELOG.md +1 -1
  2. package/README.md +229 -0
  3. package/dist/AddHighlightModel/GenomeMouseoverHighlight.js +23 -18
  4. package/dist/AddHighlightModel/GenomeMouseoverHighlight.js.map +1 -1
  5. package/dist/AddHighlightModel/MsaToGenomeHighlight.js +23 -13
  6. package/dist/AddHighlightModel/MsaToGenomeHighlight.js.map +1 -1
  7. package/dist/AddHighlightModel/index.js +8 -1
  8. package/dist/AddHighlightModel/index.js.map +1 -1
  9. package/dist/AddHighlightModel/util.d.ts +2 -2
  10. package/dist/BgzipFastaMsaAdapter/configSchema.d.ts +2 -2
  11. package/dist/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.js +5 -11
  12. package/dist/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.js.map +1 -1
  13. package/dist/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.js +5 -1
  14. package/dist/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.js.map +1 -1
  15. package/dist/LaunchMsaView/components/LaunchMsaViewDialog.js +16 -16
  16. package/dist/LaunchMsaView/components/LaunchMsaViewDialog.js.map +1 -1
  17. package/dist/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.js +38 -46
  18. package/dist/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.js.map +1 -1
  19. package/dist/LaunchMsaView/components/ManualMSALoader/launchView.d.ts +4 -3
  20. package/dist/LaunchMsaView/components/ManualMSALoader/launchView.js +4 -3
  21. package/dist/LaunchMsaView/components/ManualMSALoader/launchView.js.map +1 -1
  22. package/dist/LaunchMsaView/components/NCBIBlastQuery/CachedBlastResults.d.ts +9 -0
  23. package/dist/LaunchMsaView/components/NCBIBlastQuery/CachedBlastResults.js +76 -0
  24. package/dist/LaunchMsaView/components/NCBIBlastQuery/CachedBlastResults.js.map +1 -0
  25. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.js +35 -13
  26. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.js.map +1 -1
  27. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.js +6 -12
  28. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.js.map +1 -1
  29. package/dist/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.d.ts +6 -0
  30. package/dist/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.js +15 -0
  31. package/dist/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.js.map +1 -1
  32. package/dist/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.js +12 -34
  33. package/dist/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.js.map +1 -1
  34. package/dist/LaunchMsaView/components/PreLoadedMSA/consts.d.ts +1 -0
  35. package/dist/LaunchMsaView/components/PreLoadedMSA/consts.js +1 -0
  36. package/dist/LaunchMsaView/components/PreLoadedMSA/consts.js.map +1 -1
  37. package/dist/LaunchMsaView/components/TabPanel.d.ts +2 -2
  38. package/dist/LaunchMsaView/components/TranscriptSelector.d.ts +2 -2
  39. package/dist/LaunchMsaView/components/TranscriptSelector.js +3 -6
  40. package/dist/LaunchMsaView/components/TranscriptSelector.js.map +1 -1
  41. package/dist/LaunchMsaView/components/useSWRFeatureSequence.js +6 -4
  42. package/dist/LaunchMsaView/components/useSWRFeatureSequence.js.map +1 -1
  43. package/dist/LaunchMsaView/components/useTranscriptSelection.d.ts +16 -0
  44. package/dist/LaunchMsaView/components/useTranscriptSelection.js +31 -0
  45. package/dist/LaunchMsaView/components/useTranscriptSelection.js.map +1 -0
  46. package/dist/LaunchMsaView/components/util.d.ts +3 -1
  47. package/dist/LaunchMsaView/components/util.js +12 -2
  48. package/dist/LaunchMsaView/components/util.js.map +1 -1
  49. package/dist/LaunchMsaView/util.d.ts +2 -0
  50. package/dist/LaunchMsaView/util.js +16 -4
  51. package/dist/LaunchMsaView/util.js.map +1 -1
  52. package/dist/LaunchMsaViewExtensionPoint/index.d.ts +2 -0
  53. package/dist/LaunchMsaViewExtensionPoint/index.js +31 -0
  54. package/dist/LaunchMsaViewExtensionPoint/index.js.map +1 -0
  55. package/dist/MsaViewPanel/components/ConnectStructureDialog.d.ts +7 -0
  56. package/dist/MsaViewPanel/components/ConnectStructureDialog.js +56 -0
  57. package/dist/MsaViewPanel/components/ConnectStructureDialog.js.map +1 -0
  58. package/dist/MsaViewPanel/components/MsaViewPanel.js +4 -2
  59. package/dist/MsaViewPanel/components/MsaViewPanel.js.map +1 -1
  60. package/dist/MsaViewPanel/doLaunchBlast.d.ts +1 -0
  61. package/dist/MsaViewPanel/doLaunchBlast.js +65 -19
  62. package/dist/MsaViewPanel/doLaunchBlast.js.map +1 -1
  63. package/dist/MsaViewPanel/genomeToMSA.d.ts +6 -0
  64. package/dist/MsaViewPanel/genomeToMSA.js +38 -8
  65. package/dist/MsaViewPanel/genomeToMSA.js.map +1 -1
  66. package/dist/MsaViewPanel/genomeToMSA.test.d.ts +1 -0
  67. package/dist/MsaViewPanel/genomeToMSA.test.js +244 -0
  68. package/dist/MsaViewPanel/genomeToMSA.test.js.map +1 -0
  69. package/dist/MsaViewPanel/model.d.ts +727 -226
  70. package/dist/MsaViewPanel/model.js +496 -52
  71. package/dist/MsaViewPanel/model.js.map +1 -1
  72. package/dist/MsaViewPanel/msaCoordToGenomeCoord.d.ts +10 -2
  73. package/dist/MsaViewPanel/msaCoordToGenomeCoord.js +26 -27
  74. package/dist/MsaViewPanel/msaCoordToGenomeCoord.js.map +1 -1
  75. package/dist/MsaViewPanel/msaCoordToGenomeCoord.test.d.ts +1 -0
  76. package/dist/MsaViewPanel/msaCoordToGenomeCoord.test.js +240 -0
  77. package/dist/MsaViewPanel/msaCoordToGenomeCoord.test.js.map +1 -0
  78. package/dist/MsaViewPanel/msaDataStore.d.ts +14 -0
  79. package/dist/MsaViewPanel/msaDataStore.js +197 -0
  80. package/dist/MsaViewPanel/msaDataStore.js.map +1 -0
  81. package/dist/MsaViewPanel/pairwiseAlignment.d.ts +27 -0
  82. package/dist/MsaViewPanel/pairwiseAlignment.js +776 -0
  83. package/dist/MsaViewPanel/pairwiseAlignment.js.map +1 -0
  84. package/dist/MsaViewPanel/pairwiseAlignment.test.d.ts +1 -0
  85. package/dist/MsaViewPanel/pairwiseAlignment.test.js +112 -0
  86. package/dist/MsaViewPanel/pairwiseAlignment.test.js.map +1 -0
  87. package/dist/MsaViewPanel/structureConnection.d.ts +27 -0
  88. package/dist/MsaViewPanel/structureConnection.js +46 -0
  89. package/dist/MsaViewPanel/structureConnection.js.map +1 -0
  90. package/dist/MsaViewPanel/structureConnection.test.d.ts +1 -0
  91. package/dist/MsaViewPanel/structureConnection.test.js +122 -0
  92. package/dist/MsaViewPanel/structureConnection.test.js.map +1 -0
  93. package/dist/MsaViewPanel/types.d.ts +13 -0
  94. package/dist/MsaViewPanel/types.js +2 -0
  95. package/dist/MsaViewPanel/types.js.map +1 -0
  96. package/dist/MsaViewPanel/util.d.ts +7 -0
  97. package/dist/MsaViewPanel/util.js +10 -0
  98. package/dist/MsaViewPanel/util.js.map +1 -1
  99. package/dist/index.d.ts +5 -5
  100. package/dist/index.js +3 -1
  101. package/dist/index.js.map +1 -1
  102. package/dist/jbrowse-plugin-msaview.umd.production.min.js +39 -90
  103. package/dist/jbrowse-plugin-msaview.umd.production.min.js.map +4 -4
  104. package/dist/utils/blastCache.d.ts +34 -0
  105. package/dist/utils/blastCache.js +58 -0
  106. package/dist/utils/blastCache.js.map +1 -0
  107. package/dist/utils/fetch.d.ts +1 -1
  108. package/dist/utils/fetch.js +1 -1
  109. package/dist/utils/fetch.js.map +1 -1
  110. package/dist/utils/ncbiBlast.d.ts +1 -5
  111. package/dist/utils/taxonomyNames.d.ts +5 -0
  112. package/dist/utils/taxonomyNames.js +79 -0
  113. package/dist/utils/taxonomyNames.js.map +1 -0
  114. package/dist/utils/types.d.ts +8 -5
  115. package/package.json +50 -54
  116. package/src/AddHighlightModel/GenomeMouseoverHighlight.tsx +37 -21
  117. package/src/AddHighlightModel/MsaToGenomeHighlight.tsx +38 -17
  118. package/src/AddHighlightModel/index.tsx +9 -4
  119. package/src/LaunchMsaView/components/EnsemblGeneTree/EnsemblGeneTree.tsx +13 -13
  120. package/src/LaunchMsaView/components/EnsemblGeneTree/useGeneTree.ts +6 -0
  121. package/src/LaunchMsaView/components/LaunchMsaViewDialog.tsx +30 -23
  122. package/src/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.tsx +64 -51
  123. package/src/LaunchMsaView/components/ManualMSALoader/launchView.ts +9 -6
  124. package/src/LaunchMsaView/components/NCBIBlastQuery/CachedBlastResults.tsx +146 -0
  125. package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.tsx +53 -22
  126. package/src/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.tsx +8 -13
  127. package/src/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.ts +25 -0
  128. package/src/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.tsx +27 -47
  129. package/src/LaunchMsaView/components/PreLoadedMSA/consts.ts +1 -0
  130. package/src/LaunchMsaView/components/TabPanel.tsx +2 -2
  131. package/src/LaunchMsaView/components/TranscriptSelector.tsx +13 -20
  132. package/src/LaunchMsaView/components/useSWRFeatureSequence.ts +5 -5
  133. package/src/LaunchMsaView/components/useTranscriptSelection.ts +48 -0
  134. package/src/LaunchMsaView/components/util.ts +17 -2
  135. package/src/LaunchMsaView/index.ts +1 -1
  136. package/src/LaunchMsaView/util.ts +25 -6
  137. package/src/LaunchMsaViewExtensionPoint/index.ts +74 -0
  138. package/src/MsaViewPanel/components/ConnectStructureDialog.tsx +156 -0
  139. package/src/MsaViewPanel/components/MsaViewPanel.tsx +6 -1
  140. package/src/MsaViewPanel/doLaunchBlast.ts +83 -23
  141. package/src/MsaViewPanel/genomeToMSA.test.ts +281 -0
  142. package/src/MsaViewPanel/genomeToMSA.ts +43 -10
  143. package/src/MsaViewPanel/model.ts +617 -58
  144. package/src/MsaViewPanel/msaCoordToGenomeCoord.test.ts +256 -0
  145. package/src/MsaViewPanel/msaCoordToGenomeCoord.ts +42 -30
  146. package/src/MsaViewPanel/msaDataStore.ts +236 -0
  147. package/src/MsaViewPanel/pairwiseAlignment.test.ts +140 -0
  148. package/src/MsaViewPanel/pairwiseAlignment.ts +818 -0
  149. package/src/MsaViewPanel/structureConnection.test.ts +143 -0
  150. package/src/MsaViewPanel/structureConnection.ts +72 -0
  151. package/src/MsaViewPanel/types.ts +14 -0
  152. package/src/MsaViewPanel/util.ts +11 -0
  153. package/src/index.ts +3 -1
  154. package/src/utils/blastCache.ts +114 -0
  155. package/src/utils/fetch.ts +1 -1
  156. package/src/utils/taxonomyNames.ts +111 -0
  157. package/src/utils/types.ts +9 -1
  158. package/dist/LaunchMsaView/components/PreLoadedMSA/findValidTranscriptId.d.ts +0 -5
  159. package/dist/LaunchMsaView/components/PreLoadedMSA/findValidTranscriptId.js +0 -16
  160. package/dist/LaunchMsaView/components/PreLoadedMSA/findValidTranscriptId.js.map +0 -1
  161. package/dist/out.js +0 -55367
  162. 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":"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"}
1
+ {"version":3,"file":"PreLoadedMSADataPanel.js","sourceRoot":"","sources":["../../../../src/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.tsx"],"names":[],"mappings":"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"}
@@ -1,6 +1,7 @@
1
1
  export declare const swrFlags: {
2
2
  revalidateOnFocus: boolean;
3
3
  revalidateOnReconnect: boolean;
4
+ revalidateIfStale: boolean;
4
5
  refreshWhenHidden: boolean;
5
6
  refreshWhenOffline: boolean;
6
7
  shouldRetryOnError: boolean;
@@ -1,6 +1,7 @@
1
1
  export const swrFlags = {
2
2
  revalidateOnFocus: false,
3
3
  revalidateOnReconnect: false,
4
+ revalidateIfStale: false,
4
5
  refreshWhenHidden: false,
5
6
  refreshWhenOffline: false,
6
7
  shouldRetryOnError: false,
@@ -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,6 +1,6 @@
1
1
  import React from 'react';
2
2
  export default function TabPanel({ children, value, index, ...other }: {
3
3
  children?: React.ReactNode;
4
- index: number;
5
- value: number;
4
+ index: number | string;
5
+ value: number | string;
6
6
  }): React.JSX.Element;
@@ -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, selectedTranscriptId, onTranscriptChange, proteinSequence, validSet, }: {
3
+ export default function TranscriptSelector({ feature, options, selectedTranscript, onTranscriptChange, proteinSequence, validSet, }: {
4
4
  feature: Feature;
5
5
  options: Feature[];
6
- selectedTranscriptId: string;
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, selectedTranscriptId, onTranscriptChange, proteinSequence, validSet, }) {
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: selectedTranscriptId, onChange: event => {
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":"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"}
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
- const BPLIMIT = 500_000;
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
- forceLoad,
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,MAAM,OAAO,GAAG,OAAO,CAAA;AAEvB,KAAK,UAAU,sBAAsB,CAAC,EACpC,OAAO,EACP,YAAY,EACZ,QAAQ,EACR,IAAI,EACJ,SAAS,GAOV;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;QACX,SAAS;KACV,CAAC,CACL,CAAA;IAED,OAAO;QACL,QAAQ,EAAE,IAAI;QACd,KAAK;KACN,CAAA;AACH,CAAC"}
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
- }): string;
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
- return `${h.accession}-${h.sciname.replaceAll(' ', '_')}`;
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":"AAAA,MAAM,UAAU,MAAM,CAAC,CAAyC;IAC9D,OAAO,GAAG,CAAC,CAAC,SAAS,IAAI,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAA;AAC3D,CAAC;AAED,MAAM,UAAU,KAAK,CAAC,CAAS;IAC7B,OAAO,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;AAC3B,CAAC"}
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
- return subfeatures.some(f => f.get('type') === 'CDS')
7
- ? [feature]
8
- : // filter out non-coding by finding subfeatures with CDS subfeatures
9
- subfeatures.filter(f => f.get('subfeatures')?.some(f => f.get('type') === 'CDS'));
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;IACpD,OAAO,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,KAAK,CAAC;QACnD,CAAC,CAAC,CAAC,OAAO,CAAC;QACX,CAAC,CAAC,oEAAoE;YACpE,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CACrB,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,KAAK,CAAC,CACzD,CAAA;AACP,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,OAAgB;IAClD,MAAM,MAAM,GAAG,GAAG,CAChB,OAAO;SACJ,GAAG,CAAC,aAAa,CAAC;QACnB,EAAE,MAAM,CACN,CAAC,CAAC,EAAE,CAAE,CAAC,CAAC,GAAG,CAAC,MAAM,CAAwB,EAAE,WAAW,EAAE,KAAK,KAAK,CACpE;SACA,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CACjD,CAAA;IACD,OAAO;QACL,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QAC3B,GAAG,EAAE,MAAM,GAAG,CAAC;KAChB,CAAA;AACH,CAAC;AACD,MAAM,UAAU,KAAK,CAAC,GAAa;IACjC,OAAO,GAAG,EAAE,GAAG,CAAC,MAAM,CAAC,IAAI,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAA;AACjD,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,GAAa;IACpD,OAAO,GAAG,KAAK,SAAS;QACtB,CAAC,CAAC,EAAE;QACJ,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;AACjE,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,GAAa;IAC9C,OAAO,GAAG,KAAK,SAAS;QACtB,CAAC,CAAC,EAAE;QACJ,CAAC,CAAC;YACE,GAAG,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC;YACvC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;SAC1C;aACE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;aAChB,IAAI,CAAC,GAAG,CAAC,CAAA;AAClB,CAAC"}
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;IAEpD,yEAAyE;IACzE,mEAAmE;IACnE,MAAM,WAAW,GAAG,WAAW,CAAC,MAAM,CACpC,CAAC,CAAU,EAAE,EAAE,CACb,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,MAAM,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,YAAY,CAAC;QAC5D,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,IAAI,CAAC,CAAC,CAAU,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,KAAK,CAAC,CACtE,CAAA;IACD,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3B,OAAO,WAAW,CAAA;IACpB,CAAC;IAED,kEAAkE;IAClE,wCAAwC;IACxC,OAAO,CAAC,OAAO,CAAC,CAAA;AAClB,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,OAAgB;IAClD,MAAM,MAAM,GAAG,GAAG,CAChB,OAAO;SACJ,GAAG,CAAC,aAAa,CAAC;QACnB,EAAE,MAAM,CACN,CAAC,CAAC,EAAE,CAAE,CAAC,CAAC,GAAG,CAAC,MAAM,CAAwB,EAAE,WAAW,EAAE,KAAK,KAAK,CACpE;SACA,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CACjD,CAAA;IACD,OAAO;QACL,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QAC3B,GAAG,EAAE,MAAM,GAAG,CAAC;KAChB,CAAA;AACH,CAAC;AACD,MAAM,UAAU,KAAK,CAAC,GAAa;IACjC,OAAO,GAAG,EAAE,GAAG,CAAC,MAAM,CAAC,IAAI,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAA;AACjD,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,GAAa;IACpD,OAAO,GAAG,KAAK,SAAS;QACtB,CAAC,CAAC,EAAE;QACJ,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;AACjE,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,GAAa;IAC9C,OAAO,GAAG,KAAK,SAAS;QACtB,CAAC,CAAC,EAAE;QACJ,CAAC,CAAC;YACE,GAAG,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC;YACvC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;SAC1C;aACE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;aAChB,IAAI,CAAC,GAAG,CAAC,CAAA;AAClB,CAAC;AAED,MAAM,UAAU,2BAA2B,CAAC,OAAgB;IAC1D,OAAO,qBAAqB,CAAC,OAAO,CAAC,CAAC,QAAQ,CAC5C,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC,GAAG,CAClE,CAAA;AACH,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,GAAW;IAC9C,OAAO,GAAG,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;AACpD,CAAC"}
@@ -0,0 +1,2 @@
1
+ import type PluginManager from '@jbrowse/core/PluginManager';
2
+ export default function LaunchMsaViewExtensionPointF(pluginManager: PluginManager): void;
@@ -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(MSAView, { model: model }))));
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;IAC7B,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,CACF,oBAAC,OAAO,IAAC,KAAK,EAAE,KAAK,GAAI,CAC1B,CACG,CACP,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,YAAY,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"}
@@ -2,6 +2,7 @@ import { JBrowsePluginMsaViewModel } from './model';
2
2
  export declare function doLaunchBlast({ self, }: {
3
3
  self: JBrowsePluginMsaViewModel;
4
4
  }): Promise<{
5
+ treeMetadata: string;
5
6
  msa: string;
6
7
  tree: string;
7
8
  }>;
@@ -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 { hits } = await queryBlast({
7
- query: proteinSequence.replaceAll('*', '').replaceAll('&', ''),
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: rid => {
15
- self.setRid(rid);
18
+ onRid: r => {
19
+ self.setRid(r);
16
20
  },
17
21
  });
18
- return launchMSA({
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;AAE/C,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,EAClC,IAAI,GAGL;IACC,MAAM,EACJ,OAAO,EACP,aAAa,EACb,YAAY,EACZ,YAAY,EACZ,eAAe,GAChB,GAAG,IAAI,CAAC,WAAY,CAAA;IACrB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,UAAU,CAAC;QAChC,KAAK,EAAE,eAAe,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC;QAC9D,aAAa;QACb,YAAY;QACZ,OAAO;QACP,UAAU,EAAE,GAAG,CAAC,EAAE;YAChB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAA;QACvB,CAAC;QACD,KAAK,EAAE,GAAG,CAAC,EAAE;YACX,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;QAClB,CAAC;KACF,CAAC,CAAA;IAEF,OAAO,SAAS,CAAC;QACf,SAAS,EAAE,YAAY;QACvB,QAAQ,EAAE;YACR,WAAW,eAAe,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE;YACpE,GAAG,IAAI;iBACJ,GAAG,CACF,CAAC,CAAC,EAAE,CACF;gBACE,MAAM,CACJ,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI;oBAClB,SAAS,EAAE,SAAS;oBACpB,EAAE,EAAE,SAAS;oBACb,OAAO,EAAE,SAAS;iBACnB,CACF;gBACD,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,EAAE,CAAC;aACpB,CACb;iBACA,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,KAAK,GAAG,EAAE,CAAC;SACxC,CAAC,IAAI,CAAC,IAAI,CAAC;QACZ,UAAU,EAAE,GAAG,CAAC,EAAE;YAChB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAA;QACvB,CAAC;KACF,CAAC,CAAA;AACJ,CAAC"}
1
+ {"version":3,"file":"doLaunchBlast.js","sourceRoot":"","sources":["../../src/MsaViewPanel/doLaunchBlast.ts"],"names":[],"mappings":"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"}
@@ -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;