jbrowse-plugin-protein3d 0.0.3 → 0.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AddHighlightModel/GenomeMouseoverHighlight.js +3 -9
- package/dist/AddHighlightModel/GenomeMouseoverHighlight.js.map +1 -1
- package/dist/AddHighlightModel/ProteinToGenomeClickHighlight.js +4 -3
- package/dist/AddHighlightModel/ProteinToGenomeClickHighlight.js.map +1 -1
- package/dist/AddHighlightModel/ProteinToGenomeHoverHighlight.d.ts +1 -2
- package/dist/AddHighlightModel/ProteinToGenomeHoverHighlight.js +4 -3
- package/dist/AddHighlightModel/ProteinToGenomeHoverHighlight.js.map +1 -1
- package/dist/AddHighlightModel/util.js +1 -1
- package/dist/AddHighlightModel/util.js.map +1 -1
- package/dist/AlphaFoldConfidenceAdapter/AlphaFoldConfidenceAdapter.d.ts +16 -0
- package/dist/AlphaFoldConfidenceAdapter/AlphaFoldConfidenceAdapter.js +43 -0
- package/dist/AlphaFoldConfidenceAdapter/AlphaFoldConfidenceAdapter.js.map +1 -0
- package/dist/AlphaFoldConfidenceAdapter/configSchema.d.ts +13 -0
- package/dist/AlphaFoldConfidenceAdapter/configSchema.js +16 -0
- package/dist/AlphaFoldConfidenceAdapter/configSchema.js.map +1 -0
- package/dist/AlphaFoldConfidenceAdapter/index.d.ts +2 -0
- package/dist/AlphaFoldConfidenceAdapter/index.js +11 -0
- package/dist/AlphaFoldConfidenceAdapter/index.js.map +1 -0
- package/dist/AlphaMissensePathogenicityAdapter/AlphaMissensePathogenicityAdapter.d.ts +30 -0
- package/dist/AlphaMissensePathogenicityAdapter/AlphaMissensePathogenicityAdapter.js +78 -0
- package/dist/AlphaMissensePathogenicityAdapter/AlphaMissensePathogenicityAdapter.js.map +1 -0
- package/dist/AlphaMissensePathogenicityAdapter/configSchema.d.ts +13 -0
- package/dist/AlphaMissensePathogenicityAdapter/configSchema.js +16 -0
- package/dist/AlphaMissensePathogenicityAdapter/configSchema.js.map +1 -0
- package/dist/AlphaMissensePathogenicityAdapter/index.d.ts +2 -0
- package/dist/AlphaMissensePathogenicityAdapter/index.js +11 -0
- package/dist/AlphaMissensePathogenicityAdapter/index.js.map +1 -0
- package/dist/LaunchProteinView/components/AlphaFoldDBSearch.js +161 -11
- package/dist/LaunchProteinView/components/AlphaFoldDBSearch.js.map +1 -1
- package/dist/LaunchProteinView/components/AlphaFoldDBSearchStatus.js +8 -6
- package/dist/LaunchProteinView/components/AlphaFoldDBSearchStatus.js.map +1 -1
- package/dist/LaunchProteinView/components/HelpButton.js +6 -2
- package/dist/LaunchProteinView/components/HelpButton.js.map +1 -1
- package/dist/LaunchProteinView/components/HelpDialog.js +3 -1
- package/dist/LaunchProteinView/components/HelpDialog.js.map +1 -1
- package/dist/LaunchProteinView/components/LaunchProteinViewDialog.js +6 -2
- package/dist/LaunchProteinView/components/LaunchProteinViewDialog.js.map +1 -1
- package/dist/LaunchProteinView/components/MSATable.js +3 -1
- package/dist/LaunchProteinView/components/MSATable.js.map +1 -1
- package/dist/LaunchProteinView/components/TranscriptSelector.js +3 -1
- package/dist/LaunchProteinView/components/TranscriptSelector.js.map +1 -1
- package/dist/LaunchProteinView/components/UserProvidedStructure.js +18 -11
- package/dist/LaunchProteinView/components/UserProvidedStructure.js.map +1 -1
- package/dist/LaunchProteinView/components/calculateProteinSequence.js +5 -3
- package/dist/LaunchProteinView/components/calculateProteinSequence.js.map +1 -1
- package/dist/LaunchProteinView/components/useLocalStructureFileSequence.d.ts +1 -1
- package/dist/LaunchProteinView/components/useLocalStructureFileSequence.js +29 -9
- package/dist/LaunchProteinView/components/useLocalStructureFileSequence.js.map +1 -1
- package/dist/LaunchProteinView/components/useRemoteStructureFileSequence.d.ts +1 -1
- package/dist/LaunchProteinView/components/useRemoteStructureFileSequence.js +25 -8
- package/dist/LaunchProteinView/components/useRemoteStructureFileSequence.js.map +1 -1
- package/dist/LaunchProteinView/components/util.js +1 -1
- package/dist/LaunchProteinView/index.js +7 -3
- package/dist/LaunchProteinView/index.js.map +1 -1
- package/dist/ProteinView/{loadStructureFromData.d.ts → addStructureFromData.d.ts} +2 -2
- package/dist/ProteinView/{loadStructureFromData.js → addStructureFromData.js} +3 -8
- package/dist/ProteinView/addStructureFromData.js.map +1 -0
- package/dist/ProteinView/{loadStructureFromURL.d.ts → addStructureFromURL.d.ts} +2 -2
- package/dist/ProteinView/{loadStructureFromURL.js → addStructureFromURL.js} +11 -9
- package/dist/ProteinView/addStructureFromURL.js.map +1 -0
- package/dist/ProteinView/clearSelection.js +1 -1
- package/dist/ProteinView/clearSelection.js.map +1 -1
- package/dist/ProteinView/components/ProteinAlignment.d.ts +2 -2
- package/dist/ProteinView/components/ProteinAlignment.js +37 -26
- package/dist/ProteinView/components/ProteinAlignment.js.map +1 -1
- package/dist/ProteinView/components/ProteinAlignmentHelpButton.d.ts +2 -2
- package/dist/ProteinView/components/ProteinAlignmentHelpButton.js +6 -4
- package/dist/ProteinView/components/ProteinAlignmentHelpButton.js.map +1 -1
- package/dist/ProteinView/components/ProteinAlignmentHelpDialog.js +6 -5
- package/dist/ProteinView/components/ProteinAlignmentHelpDialog.js.map +1 -1
- package/dist/ProteinView/components/ProteinView.js +18 -60
- package/dist/ProteinView/components/ProteinView.js.map +1 -1
- package/dist/ProteinView/components/{Header.js → ProteinViewHeader.js} +29 -12
- package/dist/ProteinView/components/ProteinViewHeader.js.map +1 -0
- package/dist/ProteinView/components/SplitString.d.ts +4 -4
- package/dist/ProteinView/components/SplitString.js +3 -3
- package/dist/ProteinView/components/SplitString.js.map +1 -1
- package/dist/ProteinView/genomeToProtein.d.ts +2 -2
- package/dist/ProteinView/genomeToProtein.js +4 -5
- package/dist/ProteinView/genomeToProtein.js.map +1 -1
- package/dist/ProteinView/highlightResidue.js +2 -2
- package/dist/ProteinView/highlightResidue.js.map +1 -1
- package/dist/ProteinView/launchRemotePairwiseAlignment.d.ts +2 -5
- package/dist/ProteinView/launchRemotePairwiseAlignment.js +7 -3
- package/dist/ProteinView/launchRemotePairwiseAlignment.js.map +1 -1
- package/dist/ProteinView/model.d.ts +496 -160
- package/dist/ProteinView/model.js +61 -246
- package/dist/ProteinView/model.js.map +1 -1
- package/dist/ProteinView/proteinToGenomeMapping.d.ts +6 -6
- package/dist/ProteinView/proteinToGenomeMapping.js +29 -28
- package/dist/ProteinView/proteinToGenomeMapping.js.map +1 -1
- package/dist/ProteinView/selectResidue.js +1 -1
- package/dist/ProteinView/selectResidue.js.map +1 -1
- package/dist/ProteinView/structureModel.d.ts +183 -0
- package/dist/ProteinView/structureModel.js +407 -0
- package/dist/ProteinView/structureModel.js.map +1 -0
- package/dist/ProteinView/useProteinView.d.ts +1 -4
- package/dist/ProteinView/useProteinView.js +3 -15
- package/dist/ProteinView/useProteinView.js.map +1 -1
- package/dist/ProteinView/util.d.ts +3 -3
- package/dist/ProteinView/util.js +8 -6
- package/dist/ProteinView/util.js.map +1 -1
- package/dist/UniProtVariationAdapter/UniProtVariationAdapter.d.ts +15 -0
- package/dist/UniProtVariationAdapter/UniProtVariationAdapter.js +55 -0
- package/dist/UniProtVariationAdapter/UniProtVariationAdapter.js.map +1 -0
- package/dist/UniProtVariationAdapter/configSchema.d.ts +17 -0
- package/dist/UniProtVariationAdapter/configSchema.js +20 -0
- package/dist/UniProtVariationAdapter/configSchema.js.map +1 -0
- package/dist/UniProtVariationAdapter/index.d.ts +2 -0
- package/dist/UniProtVariationAdapter/index.js +11 -0
- package/dist/UniProtVariationAdapter/index.js.map +1 -0
- package/dist/genomeToTranscriptMapping.d.ts +2 -2
- package/dist/genomeToTranscriptMapping.js +3 -3
- package/dist/genomeToTranscriptMapping.js.map +1 -1
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -1
- package/dist/jbrowse-plugin-protein3d.umd.production.min.js +1467 -1482
- package/dist/jbrowse-plugin-protein3d.umd.production.min.js.map +4 -4
- package/dist/mappings.d.ts +12 -10
- package/dist/mappings.js +7 -7
- package/dist/mappings.js.map +1 -1
- package/dist/mappings.test.js +7 -5
- package/dist/mappings.test.js.map +1 -1
- package/dist/test_data/gene.d.ts +577 -64
- package/dist/test_data/gene.js +1 -1
- package/dist/test_data/gene.js.map +1 -1
- package/package.json +16 -15
- package/src/AddHighlightModel/GenomeMouseoverHighlight.tsx +4 -17
- package/src/AddHighlightModel/ProteinToGenomeClickHighlight.tsx +17 -14
- package/src/AddHighlightModel/ProteinToGenomeHoverHighlight.tsx +18 -17
- package/src/AddHighlightModel/util.ts +1 -1
- package/src/AlphaFoldConfidenceAdapter/AlphaFoldConfidenceAdapter.ts +63 -0
- package/src/AlphaFoldConfidenceAdapter/configSchema.ts +21 -0
- package/src/AlphaFoldConfidenceAdapter/index.ts +19 -0
- package/src/AlphaMissensePathogenicityAdapter/AlphaMissensePathogenicityAdapter.ts +109 -0
- package/src/AlphaMissensePathogenicityAdapter/configSchema.ts +21 -0
- package/src/AlphaMissensePathogenicityAdapter/index.ts +19 -0
- package/src/LaunchProteinView/components/AlphaFoldDBSearch.tsx +172 -10
- package/src/LaunchProteinView/components/AlphaFoldDBSearchStatus.tsx +8 -6
- package/src/LaunchProteinView/components/HelpButton.tsx +10 -2
- package/src/LaunchProteinView/components/HelpDialog.tsx +6 -1
- package/src/LaunchProteinView/components/LaunchProteinViewDialog.tsx +9 -2
- package/src/LaunchProteinView/components/MSATable.tsx +3 -1
- package/src/LaunchProteinView/components/TranscriptSelector.tsx +9 -7
- package/src/LaunchProteinView/components/UserProvidedStructure.tsx +17 -12
- package/src/LaunchProteinView/components/calculateProteinSequence.ts +6 -4
- package/src/LaunchProteinView/components/useLocalStructureFileSequence.ts +28 -9
- package/src/LaunchProteinView/components/useRemoteStructureFileSequence.ts +23 -8
- package/src/LaunchProteinView/components/util.ts +1 -1
- package/src/LaunchProteinView/index.ts +36 -26
- package/src/ProteinView/{loadStructureFromData.ts → addStructureFromData.ts} +2 -8
- package/src/ProteinView/{loadStructureFromURL.ts → addStructureFromURL.ts} +11 -11
- package/src/ProteinView/clearSelection.ts +1 -1
- package/src/ProteinView/components/ProteinAlignment.tsx +51 -35
- package/src/ProteinView/components/ProteinAlignmentHelpButton.tsx +4 -4
- package/src/ProteinView/components/ProteinAlignmentHelpDialog.tsx +15 -11
- package/src/ProteinView/components/ProteinView.tsx +22 -82
- package/src/ProteinView/components/{Header.tsx → ProteinViewHeader.tsx} +44 -23
- package/src/ProteinView/components/SplitString.tsx +8 -8
- package/src/ProteinView/genomeToProtein.ts +5 -9
- package/src/ProteinView/highlightResidue.ts +2 -2
- package/src/ProteinView/launchRemotePairwiseAlignment.ts +6 -3
- package/src/ProteinView/model.ts +74 -287
- package/src/ProteinView/proteinToGenomeMapping.ts +40 -38
- package/src/ProteinView/selectResidue.ts +1 -1
- package/src/ProteinView/structureModel.ts +512 -0
- package/src/ProteinView/useProteinView.ts +2 -19
- package/src/ProteinView/util.ts +20 -9
- package/src/UniProtVariationAdapter/UniProtVariationAdapter.ts +99 -0
- package/src/UniProtVariationAdapter/configSchema.ts +25 -0
- package/src/UniProtVariationAdapter/index.ts +17 -0
- package/src/__snapshots__/mappings.test.ts.snap +224 -224
- package/src/genomeToTranscriptMapping.ts +9 -9
- package/src/index.ts +6 -0
- package/src/mappings.test.ts +7 -5
- package/src/mappings.ts +25 -23
- package/src/test_data/gene.ts +3 -3
- package/dist/ProteinView/components/Header.js.map +0 -1
- package/dist/ProteinView/loadStructureFromData.js.map +0 -1
- package/dist/ProteinView/loadStructureFromURL.js.map +0 -1
- package/dist/ProteinView/useProteinViewClickBehavior.d.ts +0 -8
- package/dist/ProteinView/useProteinViewClickBehavior.js +0 -34
- package/dist/ProteinView/useProteinViewClickBehavior.js.map +0 -1
- package/dist/ProteinView/useProteinViewHoverBehavior.d.ts +0 -6
- package/dist/ProteinView/useProteinViewHoverBehavior.js +0 -31
- package/dist/ProteinView/useProteinViewHoverBehavior.js.map +0 -1
- package/src/ProteinView/useProteinViewClickBehavior.ts +0 -48
- package/src/ProteinView/useProteinViewHoverBehavior.ts +0 -44
- /package/dist/ProteinView/components/{Header.d.ts → ProteinViewHeader.d.ts} +0 -0
|
@@ -3,18 +3,12 @@ import { observer } from 'mobx-react';
|
|
|
3
3
|
import { getSession } from '@jbrowse/core/util';
|
|
4
4
|
// locals
|
|
5
5
|
import Highlight from './Highlight';
|
|
6
|
+
import { checkHovered } from '../ProteinView/util';
|
|
6
7
|
const GenomeMouseoverHighlight = observer(function ({ model, }) {
|
|
7
|
-
const { hovered } = getSession(model);
|
|
8
|
-
return hovered &&
|
|
9
|
-
typeof hovered === 'object' &&
|
|
10
|
-
'hoverPosition' in hovered ? (React.createElement(HoverHighlight, { model: model })) : null;
|
|
11
|
-
});
|
|
12
|
-
const HoverHighlight = observer(function ({ model, }) {
|
|
13
8
|
const session = getSession(model);
|
|
14
|
-
|
|
15
|
-
|
|
9
|
+
const { views, hovered } = session;
|
|
10
|
+
if (checkHovered(hovered) && views.some(s => s.type === 'ProteinView')) {
|
|
16
11
|
const { assemblyNames } = model;
|
|
17
|
-
// @ts-expect-error
|
|
18
12
|
const { coord, refName } = hovered.hoverPosition;
|
|
19
13
|
return (React.createElement(Highlight, { model: model, start: coord - 1, end: coord, refName: refName, assemblyName: assemblyNames[0] }));
|
|
20
14
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GenomeMouseoverHighlight.js","sourceRoot":"","sources":["../../src/AddHighlightModel/GenomeMouseoverHighlight.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAC/C,SAAS;AACT,OAAO,SAAS,MAAM,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"GenomeMouseoverHighlight.js","sourceRoot":"","sources":["../../src/AddHighlightModel/GenomeMouseoverHighlight.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAC/C,SAAS;AACT,OAAO,SAAS,MAAM,aAAa,CAAA;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAElD,MAAM,wBAAwB,GAAG,QAAQ,CAAC,UAAU,EAClD,KAAK,GAGN;IACC,MAAM,OAAO,GAAG,UAAU,CAAC,KAAK,CAAC,CAAA;IACjC,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,OAAO,CAAA;IAClC,IAAI,YAAY,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,aAAa,CAAC,EAAE,CAAC;QACvE,MAAM,EAAE,aAAa,EAAE,GAAG,KAAK,CAAA;QAC/B,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,aAAa,CAAA;QAChD,OAAO,CACL,oBAAC,SAAS,IACR,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK,GAAG,CAAC,EAChB,GAAG,EAAE,KAAK,EACV,OAAO,EAAE,OAAO,EAChB,YAAY,EAAE,aAAa,CAAC,CAAC,CAAE,GAC/B,CACH,CAAA;IACH,CAAC;IACD,OAAO,IAAI,CAAA;AACb,CAAC,CAAC,CAAA;AAEF,eAAe,wBAAwB,CAAA"}
|
|
@@ -5,9 +5,10 @@ import Highlight from './Highlight';
|
|
|
5
5
|
const ProteinToGenomeClickHighlight = observer(function ({ model, }) {
|
|
6
6
|
const { assemblyManager, views } = getSession(model);
|
|
7
7
|
const { assemblyNames } = model;
|
|
8
|
-
const
|
|
9
|
-
const
|
|
10
|
-
|
|
8
|
+
const proteinView = views.find(f => f.type === 'ProteinView');
|
|
9
|
+
const assemblyName = assemblyNames[0];
|
|
10
|
+
const assembly = assemblyManager.get(assemblyName);
|
|
11
|
+
return assembly ? (React.createElement(React.Fragment, null, proteinView?.structures.map(structure => structure.clickGenomeHighlights.map((r, idx) => (React.createElement(Highlight, { key: `${JSON.stringify(r)}-${idx}}`, start: r.start, end: r.end, refName: r.refName, assemblyName: assemblyName, model: model })))))) : null;
|
|
11
12
|
});
|
|
12
13
|
export default ProteinToGenomeClickHighlight;
|
|
13
14
|
//# sourceMappingURL=ProteinToGenomeClickHighlight.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProteinToGenomeClickHighlight.js","sourceRoot":"","sources":["../../src/AddHighlightModel/ProteinToGenomeClickHighlight.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAI/C,OAAO,SAAS,MAAM,aAAa,CAAA;AAInC,MAAM,6BAA6B,GAAG,QAAQ,CAAC,UAAU,EACvD,KAAK,GAGN;IACC,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,GAAG,UAAU,CAAC,KAAK,CAAC,CAAA;IACpD,MAAM,EAAE,aAAa,EAAE,GAAG,KAAK,CAAA;IAC/B,MAAM,
|
|
1
|
+
{"version":3,"file":"ProteinToGenomeClickHighlight.js","sourceRoot":"","sources":["../../src/AddHighlightModel/ProteinToGenomeClickHighlight.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAI/C,OAAO,SAAS,MAAM,aAAa,CAAA;AAInC,MAAM,6BAA6B,GAAG,QAAQ,CAAC,UAAU,EACvD,KAAK,GAGN;IACC,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,GAAG,UAAU,CAAC,KAAK,CAAC,CAAA;IACpD,MAAM,EAAE,aAAa,EAAE,GAAG,KAAK,CAAA;IAC/B,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,aAAa,CAE/C,CAAA;IACb,MAAM,YAAY,GAAG,aAAa,CAAC,CAAC,CAAE,CAAA;IACtC,MAAM,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAC,YAAY,CAAC,CAAA;IAClD,OAAO,QAAQ,CAAC,CAAC,CAAC,CAChB,0CACG,WAAW,EAAE,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CACvC,SAAS,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,CAAC,CAC9C,oBAAC,SAAS,IACR,GAAG,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,GAAG,GAAG,EACnC,KAAK,EAAE,CAAC,CAAC,KAAK,EACd,GAAG,EAAE,CAAC,CAAC,GAAG,EACV,OAAO,EAAE,CAAC,CAAC,OAAO,EAClB,YAAY,EAAE,YAAY,EAC1B,KAAK,EAAE,KAAK,GACZ,CACH,CAAC,CACH,CACA,CACJ,CAAC,CAAC,CAAC,IAAI,CAAA;AACV,CAAC,CAAC,CAAA;AAEF,eAAe,6BAA6B,CAAA"}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { LinearGenomeViewModel } from '@jbrowse/plugin-linear-genome-view';
|
|
3
|
-
type LGV = LinearGenomeViewModel;
|
|
4
3
|
declare const ProteinToGenomeHoverHighlight: ({ model, }: {
|
|
5
|
-
model:
|
|
4
|
+
model: LinearGenomeViewModel;
|
|
6
5
|
}) => React.JSX.Element | null;
|
|
7
6
|
export default ProteinToGenomeHoverHighlight;
|
|
@@ -5,9 +5,10 @@ import Highlight from './Highlight';
|
|
|
5
5
|
const ProteinToGenomeHoverHighlight = observer(function ({ model, }) {
|
|
6
6
|
const { assemblyManager, views } = getSession(model);
|
|
7
7
|
const { assemblyNames } = model;
|
|
8
|
-
const
|
|
9
|
-
const
|
|
10
|
-
|
|
8
|
+
const proteinView = views.find(f => f.type === 'ProteinView');
|
|
9
|
+
const assemblyName = assemblyNames[0];
|
|
10
|
+
const assembly = assemblyManager.get(assemblyName);
|
|
11
|
+
return assembly ? (React.createElement(React.Fragment, null, proteinView?.structures.map(structure => structure.hoverGenomeHighlights.map((r, idx) => (React.createElement(Highlight, { key: `${JSON.stringify(r)}-${idx}`, start: r.start, end: r.end, refName: r.refName, assemblyName: assemblyName, model: model })))))) : null;
|
|
11
12
|
});
|
|
12
13
|
export default ProteinToGenomeHoverHighlight;
|
|
13
14
|
//# sourceMappingURL=ProteinToGenomeHoverHighlight.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProteinToGenomeHoverHighlight.js","sourceRoot":"","sources":["../../src/AddHighlightModel/ProteinToGenomeHoverHighlight.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAI/C,OAAO,SAAS,MAAM,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"ProteinToGenomeHoverHighlight.js","sourceRoot":"","sources":["../../src/AddHighlightModel/ProteinToGenomeHoverHighlight.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAI/C,OAAO,SAAS,MAAM,aAAa,CAAA;AAEnC,MAAM,6BAA6B,GAAG,QAAQ,CAAC,UAAU,EACvD,KAAK,GAGN;IACC,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,GAAG,UAAU,CAAC,KAAK,CAAC,CAAA;IACpD,MAAM,EAAE,aAAa,EAAE,GAAG,KAAK,CAAA;IAC/B,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,aAAa,CAE/C,CAAA;IACb,MAAM,YAAY,GAAG,aAAa,CAAC,CAAC,CAAE,CAAA;IACtC,MAAM,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAC,YAAY,CAAC,CAAA;IAClD,OAAO,QAAQ,CAAC,CAAC,CAAC,CAChB,0CACG,WAAW,EAAE,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CACvC,SAAS,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,CAAC,CAC9C,oBAAC,SAAS,IACR,GAAG,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE,EAClC,KAAK,EAAE,CAAC,CAAC,KAAK,EACd,GAAG,EAAE,CAAC,CAAC,GAAG,EACV,OAAO,EAAE,CAAC,CAAC,OAAO,EAClB,YAAY,EAAE,YAAY,EAC1B,KAAK,EAAE,KAAK,GACZ,CACH,CAAC,CACH,CACA,CACJ,CAAC,CAAC,CAAC,IAAI,CAAA;AACV,CAAC,CAAC,CAAA;AAEF,eAAe,6BAA6B,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/AddHighlightModel/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,MAAM,CAAC,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC;IACpC,SAAS,EAAE;QACT,MAAM,EAAE,MAAM;QACd,UAAU,EAAE,qBAAqB;QACjC,MAAM,EAAE,6BAA6B;QACrC,QAAQ,EAAE,UAAU;QACpB,MAAM,EAAE,
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/AddHighlightModel/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,MAAM,CAAC,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC;IACpC,SAAS,EAAE;QACT,MAAM,EAAE,MAAM;QACd,UAAU,EAAE,qBAAqB;QACjC,MAAM,EAAE,6BAA6B;QACrC,QAAQ,EAAE,UAAU;QACpB,MAAM,EAAE,EAAE;QACV,SAAS,EAAE,QAAQ;QACnB,aAAa,EAAE,MAAM;QACrB,QAAQ,EAAE,QAAQ;KACnB;IACD,UAAU,EAAE;QACV,MAAM,EAAE,iBAAiB;KAC1B;CACF,CAAC,CAAA"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BaseFeatureDataAdapter, BaseOptions } from '@jbrowse/core/data_adapters/BaseAdapter';
|
|
2
|
+
import { Region, Feature } from '@jbrowse/core/util';
|
|
3
|
+
export default class AlphaFoldConfidenceAdapter extends BaseFeatureDataAdapter {
|
|
4
|
+
static capabilities: string[];
|
|
5
|
+
feats: Promise<{
|
|
6
|
+
uniqueId: string;
|
|
7
|
+
start: number;
|
|
8
|
+
end: number;
|
|
9
|
+
score: number;
|
|
10
|
+
}[]> | undefined;
|
|
11
|
+
private loadDataP;
|
|
12
|
+
private loadData;
|
|
13
|
+
getRefNames(_opts?: BaseOptions): Promise<never[]>;
|
|
14
|
+
getFeatures(query: Region, opts?: BaseOptions): import("rxjs").Observable<Feature>;
|
|
15
|
+
freeResources(): void;
|
|
16
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { BaseFeatureDataAdapter, } from '@jbrowse/core/data_adapters/BaseAdapter';
|
|
2
|
+
import { openLocation } from '@jbrowse/core/util/io';
|
|
3
|
+
import { ObservableCreate } from '@jbrowse/core/util/rxjs';
|
|
4
|
+
import { doesIntersect2, SimpleFeature, } from '@jbrowse/core/util';
|
|
5
|
+
export default class AlphaFoldConfidenceAdapter extends BaseFeatureDataAdapter {
|
|
6
|
+
static capabilities = ['getFeatures', 'getRefNames'];
|
|
7
|
+
feats;
|
|
8
|
+
async loadDataP() {
|
|
9
|
+
const scores = JSON.parse(await openLocation(this.getConf('location')).readFile('utf8'));
|
|
10
|
+
return scores.residueNumber.map((value, idx) => ({
|
|
11
|
+
uniqueId: `feat-${idx}`,
|
|
12
|
+
start: value,
|
|
13
|
+
end: value + 1,
|
|
14
|
+
score: scores.confidenceScore[idx],
|
|
15
|
+
}));
|
|
16
|
+
}
|
|
17
|
+
async loadData(_opts = {}) {
|
|
18
|
+
if (!this.feats) {
|
|
19
|
+
this.feats = this.loadDataP().catch((e) => {
|
|
20
|
+
this.feats = undefined;
|
|
21
|
+
throw e;
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
return this.feats;
|
|
25
|
+
}
|
|
26
|
+
async getRefNames(_opts = {}) {
|
|
27
|
+
return [];
|
|
28
|
+
}
|
|
29
|
+
getFeatures(query, opts = {}) {
|
|
30
|
+
return ObservableCreate(async (observer) => {
|
|
31
|
+
const { start, end, refName } = query;
|
|
32
|
+
const data = await this.loadData();
|
|
33
|
+
for (const f of data) {
|
|
34
|
+
if (doesIntersect2(f.start, f.end, start, end)) {
|
|
35
|
+
observer.next(new SimpleFeature({ ...f, refName }));
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
observer.complete();
|
|
39
|
+
}, opts.signal);
|
|
40
|
+
}
|
|
41
|
+
freeResources() { }
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=AlphaFoldConfidenceAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AlphaFoldConfidenceAdapter.js","sourceRoot":"","sources":["../../src/AlphaFoldConfidenceAdapter/AlphaFoldConfidenceAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,GAEvB,MAAM,yCAAyC,CAAA;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAA;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAC1D,OAAO,EAGL,cAAc,EACd,aAAa,GACd,MAAM,oBAAoB,CAAA;AAE3B,MAAM,CAAC,OAAO,OAAO,0BAA2B,SAAQ,sBAAsB;IACrE,MAAM,CAAC,YAAY,GAAG,CAAC,aAAa,EAAE,aAAa,CAAC,CAAA;IAEpD,KAAK,CAEC;IAEL,KAAK,CAAC,SAAS;QACrB,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CACvB,MAAM,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CACJ,CAAA;QAE3D,OAAO,MAAM,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;YAC/C,QAAQ,EAAE,QAAQ,GAAG,EAAE;YACvB,KAAK,EAAE,KAAK;YACZ,GAAG,EAAE,KAAK,GAAG,CAAC;YACd,KAAK,EAAE,MAAM,CAAC,eAAe,CAAC,GAAG,CAAE;SACpC,CAAC,CAAC,CAAA;IACL,CAAC;IAEO,KAAK,CAAC,QAAQ,CAAC,QAAqB,EAAE;QAC5C,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,CAAC,CAAU,EAAE,EAAE;gBACjD,IAAI,CAAC,KAAK,GAAG,SAAS,CAAA;gBACtB,MAAM,CAAC,CAAA;YACT,CAAC,CAAC,CAAA;QACJ,CAAC;QAED,OAAO,IAAI,CAAC,KAAK,CAAA;IACnB,CAAC;IAEM,KAAK,CAAC,WAAW,CAAC,QAAqB,EAAE;QAC9C,OAAO,EAAE,CAAA;IACX,CAAC;IAEM,WAAW,CAAC,KAAa,EAAE,OAAoB,EAAE;QACtD,OAAO,gBAAgB,CAAU,KAAK,EAAC,QAAQ,EAAC,EAAE;YAChD,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,KAAK,CAAA;YACrC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAA;YAClC,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;gBACrB,IAAI,cAAc,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,GAAG,CAAC,EAAE,CAAC;oBAC/C,QAAQ,CAAC,IAAI,CAAC,IAAI,aAAa,CAAC,EAAE,GAAG,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,CAAA;gBACrD,CAAC;YACH,CAAC;YACD,QAAQ,CAAC,QAAQ,EAAE,CAAA;QACrB,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;IACjB,CAAC;IAEM,aAAa,KAAU,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
declare const AlphaFoldConfidenceAdapter: import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaType<{
|
|
2
|
+
/**
|
|
3
|
+
* #slot
|
|
4
|
+
*/
|
|
5
|
+
location: {
|
|
6
|
+
type: string;
|
|
7
|
+
defaultValue: {
|
|
8
|
+
uri: string;
|
|
9
|
+
locationType: string;
|
|
10
|
+
};
|
|
11
|
+
};
|
|
12
|
+
}, import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaOptions<undefined, undefined>>;
|
|
13
|
+
export default AlphaFoldConfidenceAdapter;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ConfigurationSchema } from '@jbrowse/core/configuration';
|
|
2
|
+
/**
|
|
3
|
+
* #config AlphaFoldConfidenceAdapter
|
|
4
|
+
*/
|
|
5
|
+
function x() { } // eslint-disable-line @typescript-eslint/no-unused-vars
|
|
6
|
+
const AlphaFoldConfidenceAdapter = ConfigurationSchema('AlphaFoldConfidenceAdapter', {
|
|
7
|
+
/**
|
|
8
|
+
* #slot
|
|
9
|
+
*/
|
|
10
|
+
location: {
|
|
11
|
+
type: 'fileLocation',
|
|
12
|
+
defaultValue: { uri: '/path/to/my.bed.gz', locationType: 'UriLocation' },
|
|
13
|
+
},
|
|
14
|
+
}, { explicitlyTyped: true });
|
|
15
|
+
export default AlphaFoldConfidenceAdapter;
|
|
16
|
+
//# sourceMappingURL=configSchema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/AlphaFoldConfidenceAdapter/configSchema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AAEjE;;GAEG;AACH,SAAS,CAAC,KAAI,CAAC,CAAC,wDAAwD;AAExE,MAAM,0BAA0B,GAAG,mBAAmB,CACpD,4BAA4B,EAC5B;IACE;;OAEG;IACH,QAAQ,EAAE;QACR,IAAI,EAAE,cAAc;QACpB,YAAY,EAAE,EAAE,GAAG,EAAE,oBAAoB,EAAE,YAAY,EAAE,aAAa,EAAE;KACzE;CACF,EACD,EAAE,eAAe,EAAE,IAAI,EAAE,CAC1B,CAAA;AACD,eAAe,0BAA0B,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import AdapterType from '@jbrowse/core/pluggableElementTypes/AdapterType';
|
|
2
|
+
import configSchema from './configSchema';
|
|
3
|
+
export default function AlphaFoldConfidenceAdapterF(pluginManager) {
|
|
4
|
+
pluginManager.addAdapterType(() => new AdapterType({
|
|
5
|
+
name: 'AlphaFoldConfidenceAdapter',
|
|
6
|
+
displayName: 'AlphaFoldConfidence adapter',
|
|
7
|
+
configSchema,
|
|
8
|
+
getAdapterClass: () => import('./AlphaFoldConfidenceAdapter').then(r => r.default),
|
|
9
|
+
}));
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/AlphaFoldConfidenceAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,WAAW,MAAM,iDAAiD,CAAA;AAEzE,OAAO,YAAY,MAAM,gBAAgB,CAAA;AAEzC,MAAM,CAAC,OAAO,UAAU,2BAA2B,CACjD,aAA4B;IAE5B,aAAa,CAAC,cAAc,CAC1B,GAAG,EAAE,CACH,IAAI,WAAW,CAAC;QACd,IAAI,EAAE,4BAA4B;QAClC,WAAW,EAAE,6BAA6B;QAC1C,YAAY;QACZ,eAAe,EAAE,GAAG,EAAE,CACpB,MAAM,CAAC,8BAA8B,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;KAC9D,CAAC,CACL,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { BaseFeatureDataAdapter, BaseOptions } from '@jbrowse/core/data_adapters/BaseAdapter';
|
|
2
|
+
import { Region, Feature } from '@jbrowse/core/util';
|
|
3
|
+
export default class AlphaMissensePathogenicityAdapter extends BaseFeatureDataAdapter {
|
|
4
|
+
static capabilities: string[];
|
|
5
|
+
feats: Promise<{
|
|
6
|
+
uniqueId: string;
|
|
7
|
+
start: number;
|
|
8
|
+
end: number;
|
|
9
|
+
score: number;
|
|
10
|
+
ref: string;
|
|
11
|
+
variant: string;
|
|
12
|
+
am_class: string;
|
|
13
|
+
}[]> | undefined;
|
|
14
|
+
private loadDataP;
|
|
15
|
+
private loadData;
|
|
16
|
+
getGlobalStats(_opts?: BaseOptions): Promise<{
|
|
17
|
+
scoreMin: number;
|
|
18
|
+
scoreMax: number;
|
|
19
|
+
}>;
|
|
20
|
+
getMultiRegionFeatureDensityStats(_regions: Region[]): Promise<{
|
|
21
|
+
featureDensity: number;
|
|
22
|
+
}>;
|
|
23
|
+
getRefNames(_opts?: BaseOptions): Promise<never[]>;
|
|
24
|
+
getFeatures(query: Region, opts?: BaseOptions): import("rxjs").Observable<Feature>;
|
|
25
|
+
getSources(): Promise<{
|
|
26
|
+
name: string;
|
|
27
|
+
__name: string;
|
|
28
|
+
}[]>;
|
|
29
|
+
freeResources(): void;
|
|
30
|
+
}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { BaseFeatureDataAdapter, } from '@jbrowse/core/data_adapters/BaseAdapter';
|
|
2
|
+
import { openLocation } from '@jbrowse/core/util/io';
|
|
3
|
+
import { ObservableCreate } from '@jbrowse/core/util/rxjs';
|
|
4
|
+
import { doesIntersect2, SimpleFeature, max, min, } from '@jbrowse/core/util';
|
|
5
|
+
export default class AlphaMissensePathogenicityAdapter extends BaseFeatureDataAdapter {
|
|
6
|
+
static capabilities = ['getFeatures', 'getRefNames'];
|
|
7
|
+
feats;
|
|
8
|
+
async loadDataP() {
|
|
9
|
+
const scores = await openLocation(this.getConf('location')).readFile('utf8');
|
|
10
|
+
return scores
|
|
11
|
+
.split('\n')
|
|
12
|
+
.slice(1)
|
|
13
|
+
.map(f => f.trim())
|
|
14
|
+
.filter(f => !!f)
|
|
15
|
+
.map((row, idx) => {
|
|
16
|
+
const [protein_variant, score, am_class] = row.split(',');
|
|
17
|
+
const ref = protein_variant[0];
|
|
18
|
+
const variant = protein_variant.at(-1);
|
|
19
|
+
const coord = protein_variant.slice(1, -1);
|
|
20
|
+
return {
|
|
21
|
+
uniqueId: `feat-${idx}`,
|
|
22
|
+
ref: ref,
|
|
23
|
+
variant: variant,
|
|
24
|
+
start: +coord,
|
|
25
|
+
end: +coord + 1,
|
|
26
|
+
score: +score,
|
|
27
|
+
am_class: am_class,
|
|
28
|
+
};
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
async loadData(_opts = {}) {
|
|
32
|
+
if (!this.feats) {
|
|
33
|
+
this.feats = this.loadDataP().catch((e) => {
|
|
34
|
+
this.feats = undefined;
|
|
35
|
+
throw e;
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
return this.feats;
|
|
39
|
+
}
|
|
40
|
+
async getGlobalStats(_opts) {
|
|
41
|
+
const data = await this.loadData();
|
|
42
|
+
const scoreMin = min(data.map(s => s.score));
|
|
43
|
+
const scoreMax = max(data.map(s => s.score));
|
|
44
|
+
return { scoreMin, scoreMax };
|
|
45
|
+
}
|
|
46
|
+
// always render bigwig instead of calculating a feature density for it
|
|
47
|
+
async getMultiRegionFeatureDensityStats(_regions) {
|
|
48
|
+
return { featureDensity: 0 };
|
|
49
|
+
}
|
|
50
|
+
async getRefNames(_opts = {}) {
|
|
51
|
+
return [];
|
|
52
|
+
}
|
|
53
|
+
getFeatures(query, opts = {}) {
|
|
54
|
+
return ObservableCreate(async (observer) => {
|
|
55
|
+
const { start, end, refName } = query;
|
|
56
|
+
const data = await this.loadData();
|
|
57
|
+
for (const f of data) {
|
|
58
|
+
if (doesIntersect2(f.start, f.end, start, end)) {
|
|
59
|
+
observer.next(new SimpleFeature({ ...f, refName, source: f.variant }));
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
observer.complete();
|
|
63
|
+
}, opts.signal);
|
|
64
|
+
}
|
|
65
|
+
async getSources() {
|
|
66
|
+
const sources = new Set();
|
|
67
|
+
const data = await this.loadData();
|
|
68
|
+
for (const f of data) {
|
|
69
|
+
sources.add(f.variant);
|
|
70
|
+
}
|
|
71
|
+
return [...sources].map(s => ({
|
|
72
|
+
name: s,
|
|
73
|
+
__name: s,
|
|
74
|
+
}));
|
|
75
|
+
}
|
|
76
|
+
freeResources() { }
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=AlphaMissensePathogenicityAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AlphaMissensePathogenicityAdapter.js","sourceRoot":"","sources":["../../src/AlphaMissensePathogenicityAdapter/AlphaMissensePathogenicityAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
declare const AlphaMissensePathogenicityAdapter: import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaType<{
|
|
2
|
+
/**
|
|
3
|
+
* #slot
|
|
4
|
+
*/
|
|
5
|
+
location: {
|
|
6
|
+
type: string;
|
|
7
|
+
defaultValue: {
|
|
8
|
+
uri: string;
|
|
9
|
+
locationType: string;
|
|
10
|
+
};
|
|
11
|
+
};
|
|
12
|
+
}, import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaOptions<undefined, undefined>>;
|
|
13
|
+
export default AlphaMissensePathogenicityAdapter;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ConfigurationSchema } from '@jbrowse/core/configuration';
|
|
2
|
+
/**
|
|
3
|
+
* #config AlphaMissensePathogenicityAdapter
|
|
4
|
+
*/
|
|
5
|
+
function x() { } // eslint-disable-line @typescript-eslint/no-unused-vars
|
|
6
|
+
const AlphaMissensePathogenicityAdapter = ConfigurationSchema('AlphaMissensePathogenicityAdapter', {
|
|
7
|
+
/**
|
|
8
|
+
* #slot
|
|
9
|
+
*/
|
|
10
|
+
location: {
|
|
11
|
+
type: 'fileLocation',
|
|
12
|
+
defaultValue: { uri: '/path/to/my.bed.gz', locationType: 'UriLocation' },
|
|
13
|
+
},
|
|
14
|
+
}, { explicitlyTyped: true });
|
|
15
|
+
export default AlphaMissensePathogenicityAdapter;
|
|
16
|
+
//# sourceMappingURL=configSchema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/AlphaMissensePathogenicityAdapter/configSchema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AAEjE;;GAEG;AACH,SAAS,CAAC,KAAI,CAAC,CAAC,wDAAwD;AAExE,MAAM,iCAAiC,GAAG,mBAAmB,CAC3D,mCAAmC,EACnC;IACE;;OAEG;IACH,QAAQ,EAAE;QACR,IAAI,EAAE,cAAc;QACpB,YAAY,EAAE,EAAE,GAAG,EAAE,oBAAoB,EAAE,YAAY,EAAE,aAAa,EAAE;KACzE;CACF,EACD,EAAE,eAAe,EAAE,IAAI,EAAE,CAC1B,CAAA;AACD,eAAe,iCAAiC,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import AdapterType from '@jbrowse/core/pluggableElementTypes/AdapterType';
|
|
2
|
+
import configSchema from './configSchema';
|
|
3
|
+
export default function AlphaMissensePathogenicityAdapterF(pluginManager) {
|
|
4
|
+
pluginManager.addAdapterType(() => new AdapterType({
|
|
5
|
+
name: 'AlphaMissensePathogenicityAdapter',
|
|
6
|
+
displayName: 'AlphaMissensePathogenicity adapter',
|
|
7
|
+
configSchema,
|
|
8
|
+
getAdapterClass: () => import('./AlphaMissensePathogenicityAdapter').then(r => r.default),
|
|
9
|
+
}));
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/AlphaMissensePathogenicityAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,WAAW,MAAM,iDAAiD,CAAA;AAEzE,OAAO,YAAY,MAAM,gBAAgB,CAAA;AAEzC,MAAM,CAAC,OAAO,UAAU,kCAAkC,CACxD,aAA4B;IAE5B,aAAa,CAAC,cAAc,CAC1B,GAAG,EAAE,CACH,IAAI,WAAW,CAAC;QACd,IAAI,EAAE,mCAAmC;QACzC,WAAW,EAAE,oCAAoC;QACjD,YAAY;QACZ,eAAe,EAAE,GAAG,EAAE,CACpB,MAAM,CAAC,qCAAqC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;KACrE,CAAC,CACL,CAAA;AACH,CAAC"}
|
|
@@ -2,7 +2,7 @@ import React, { useEffect, useState } from 'react';
|
|
|
2
2
|
import { observer } from 'mobx-react';
|
|
3
3
|
import { Button, DialogActions, DialogContent, Typography } from '@mui/material';
|
|
4
4
|
import { makeStyles } from 'tss-react/mui';
|
|
5
|
-
import { getContainingView, getSession, } from '@jbrowse/core/util';
|
|
5
|
+
import { getContainingView, getSession, isSessionWithAddTracks, } from '@jbrowse/core/util';
|
|
6
6
|
import { ErrorMessage, LoadingEllipses } from '@jbrowse/core/ui';
|
|
7
7
|
// locals
|
|
8
8
|
import { getDisplayName, getGeneDisplayName, getId, getTranscriptDisplayName, getTranscriptFeatures, } from './util';
|
|
@@ -42,8 +42,9 @@ const AlphaFoldDBSearch = observer(function ({ feature, model, handleClose, }) {
|
|
|
42
42
|
const url = uniprotId
|
|
43
43
|
? `https://alphafold.ebi.ac.uk/files/AF-${uniprotId}-F1-model_v4.cif`
|
|
44
44
|
: undefined;
|
|
45
|
-
const {
|
|
45
|
+
const { sequences: structureSequences, isLoading: isRemoteStructureSequenceLoading, error: remoteStructureSequenceError, } = useRemoteStructureFileSequence({ url });
|
|
46
46
|
const e = myGeneError || isoformProteinSequencesError || remoteStructureSequenceError;
|
|
47
|
+
const structureSequence = structureSequences?.[0];
|
|
47
48
|
useEffect(() => {
|
|
48
49
|
if (isoformSequences !== undefined) {
|
|
49
50
|
const ret = options.find(f => isoformSequences[f.id()]?.seq.replaceAll('*', '') ==
|
|
@@ -59,30 +60,179 @@ const AlphaFoldDBSearch = observer(function ({ feature, model, handleClose, }) {
|
|
|
59
60
|
' ',
|
|
60
61
|
React.createElement(HelpButton, null)),
|
|
61
62
|
isRemoteStructureSequenceLoading ? (React.createElement(LoadingEllipses, { variant: "h6", message: "Loading sequence from remote structure file" })) : null,
|
|
62
|
-
isMyGeneLoading ? (React.createElement(LoadingEllipses, { variant: "h6", message: "Looking up UniProt ID from mygene.info" })) :
|
|
63
|
+
isMyGeneLoading ? (React.createElement(LoadingEllipses, { variant: "h6", message: "Looking up UniProt ID from mygene.info" })) : uniprotId ? null : (React.createElement("div", null,
|
|
63
64
|
"UniProt ID not found. Search sequence on AlphaFoldDB",
|
|
64
65
|
' ',
|
|
65
66
|
React.createElement("a", { href: `https://alphafold.ebi.ac.uk/search/sequence/${userSelectedProteinSequence?.seq.replaceAll('*', '')}`, target: "_blank", rel: "noreferrer" }, "here"),
|
|
66
67
|
' ',
|
|
67
68
|
React.createElement("br", null),
|
|
68
|
-
"After visiting the above link, then paste the structure URL into the Manual tab"))
|
|
69
|
+
"After visiting the above link, then paste the structure URL into the Manual tab")),
|
|
69
70
|
isIsoformProteinSequencesLoading ? (React.createElement(LoadingEllipses, { variant: "h6", message: "Loading protein sequences from transcript isoforms" })) : null,
|
|
70
71
|
isoformSequences && structureSequence && selectedTranscript ? (React.createElement(React.Fragment, null,
|
|
71
72
|
React.createElement(TranscriptSelector, { val: userSelection ?? '', setVal: setUserSelection, structureSequence: structureSequence, feature: feature, isoforms: options, isoformSequences: isoformSequences }),
|
|
72
73
|
React.createElement(AlphaFoldDBSearchStatus, { uniprotId: uniprotId, selectedTranscript: selectedTranscript, structureSequence: structureSequence, isoformSequences: isoformSequences }))) : null),
|
|
73
74
|
React.createElement(DialogActions, null,
|
|
74
|
-
React.createElement(Button, { variant: "contained", color: "secondary", onClick: () =>
|
|
75
|
+
React.createElement(Button, { variant: "contained", color: "secondary", onClick: () => {
|
|
76
|
+
handleClose();
|
|
77
|
+
} }, "Cancel"),
|
|
75
78
|
React.createElement(Button, { variant: "contained", color: "primary", disabled: !uniprotId || !userSelectedProteinSequence || !selectedTranscript, onClick: () => {
|
|
76
79
|
session.addView('ProteinView', {
|
|
77
80
|
type: 'ProteinView',
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
81
|
+
isFloating: true,
|
|
82
|
+
structures: [
|
|
83
|
+
{
|
|
84
|
+
url,
|
|
85
|
+
userProvidedTranscriptSequence: userSelectedProteinSequence?.seq,
|
|
86
|
+
feature: selectedTranscript?.toJSON(),
|
|
87
|
+
connectedViewId: view.id,
|
|
88
|
+
},
|
|
89
|
+
],
|
|
90
|
+
displayName: [
|
|
91
|
+
'Protein view',
|
|
92
|
+
uniprotId,
|
|
93
|
+
getGeneDisplayName(feature),
|
|
94
|
+
getTranscriptDisplayName(selectedTranscript),
|
|
95
|
+
].join(' - '),
|
|
83
96
|
});
|
|
84
97
|
handleClose();
|
|
85
|
-
} }, "
|
|
98
|
+
} }, "Launch 3-D protein structure view"),
|
|
99
|
+
React.createElement(Button, { variant: "contained", disabled: !uniprotId || !userSelectedProteinSequence || !selectedTranscript, onClick: () => {
|
|
100
|
+
if (uniprotId && isSessionWithAddTracks(session)) {
|
|
101
|
+
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
102
|
+
;
|
|
103
|
+
(async () => {
|
|
104
|
+
try {
|
|
105
|
+
session.addTemporaryAssembly?.({
|
|
106
|
+
name: uniprotId,
|
|
107
|
+
sequence: {
|
|
108
|
+
type: 'ReferenceSequenceTrack',
|
|
109
|
+
trackId: `${uniprotId}-ReferenceSequenceTrack`,
|
|
110
|
+
sequenceType: 'pep',
|
|
111
|
+
adapter: {
|
|
112
|
+
type: 'UnindexedFastaAdapter',
|
|
113
|
+
rewriteRefNames: "jexl:split(refName,'|')[1]",
|
|
114
|
+
fastaLocation: {
|
|
115
|
+
uri: `https://rest.uniprot.org/uniprotkb/${uniprotId}.fasta`,
|
|
116
|
+
},
|
|
117
|
+
},
|
|
118
|
+
},
|
|
119
|
+
});
|
|
120
|
+
const url = `https://rest.uniprot.org/uniprotkb/${uniprotId}.gff`;
|
|
121
|
+
const res = await fetch(url);
|
|
122
|
+
if (!res.ok) {
|
|
123
|
+
throw new Error(`HTTP ${res.status} fetching ${url}`);
|
|
124
|
+
}
|
|
125
|
+
const data = await res.text();
|
|
126
|
+
const types = [
|
|
127
|
+
...new Set(data
|
|
128
|
+
.split('\n')
|
|
129
|
+
.filter(f => !f.startsWith('#'))
|
|
130
|
+
.map(f => f.trim())
|
|
131
|
+
.filter(f => !!f)
|
|
132
|
+
.map(f => f.split('\t')[2])),
|
|
133
|
+
];
|
|
134
|
+
types.forEach(type => {
|
|
135
|
+
const s = `${uniprotId}-${type}`;
|
|
136
|
+
session.addTrackConf({
|
|
137
|
+
type: 'FeatureTrack',
|
|
138
|
+
trackId: s,
|
|
139
|
+
name: type,
|
|
140
|
+
adapter: {
|
|
141
|
+
type: 'Gff3Adapter',
|
|
142
|
+
gffLocation: {
|
|
143
|
+
uri: `https://rest.uniprot.org/uniprotkb/${uniprotId}.gff`,
|
|
144
|
+
},
|
|
145
|
+
},
|
|
146
|
+
assemblyNames: [uniprotId],
|
|
147
|
+
displays: [
|
|
148
|
+
{
|
|
149
|
+
displayId: `${type}-LinearBasicDisplay`,
|
|
150
|
+
type: 'LinearBasicDisplay',
|
|
151
|
+
jexlFilters: [`get(feature,'type')=='${type}'`],
|
|
152
|
+
},
|
|
153
|
+
],
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
session.addTrackConf({
|
|
157
|
+
type: 'FeatureTrack',
|
|
158
|
+
trackId: 'Antigen',
|
|
159
|
+
name: 'Antigen',
|
|
160
|
+
adapter: {
|
|
161
|
+
type: 'Gff3Adapter',
|
|
162
|
+
gffLocation: {
|
|
163
|
+
uri: `https://www.ebi.ac.uk/proteins/api/antigen/${uniprotId}?format=gff`,
|
|
164
|
+
},
|
|
165
|
+
},
|
|
166
|
+
assemblyNames: [uniprotId],
|
|
167
|
+
});
|
|
168
|
+
session.addTrackConf({
|
|
169
|
+
type: 'FeatureTrack',
|
|
170
|
+
trackId: 'Variation',
|
|
171
|
+
name: 'Variation',
|
|
172
|
+
adapter: {
|
|
173
|
+
type: 'UniProtVariationAdapter',
|
|
174
|
+
location: {
|
|
175
|
+
uri: `https://www.ebi.ac.uk/proteins/api/variation/${uniprotId}.json`,
|
|
176
|
+
},
|
|
177
|
+
},
|
|
178
|
+
assemblyNames: [uniprotId],
|
|
179
|
+
});
|
|
180
|
+
session.addTrackConf({
|
|
181
|
+
type: 'QuantitativeTrack',
|
|
182
|
+
trackId: 'AlphaFold confidence',
|
|
183
|
+
name: 'AlphaFold confidence',
|
|
184
|
+
adapter: {
|
|
185
|
+
type: 'AlphaFoldConfidenceAdapter',
|
|
186
|
+
location: {
|
|
187
|
+
uri: `https://alphafold.ebi.ac.uk/files/AF-${uniprotId}-F1-confidence_v4.json`,
|
|
188
|
+
},
|
|
189
|
+
},
|
|
190
|
+
assemblyNames: [uniprotId],
|
|
191
|
+
});
|
|
192
|
+
session.addTrackConf({
|
|
193
|
+
type: 'MultiQuantitativeTrack',
|
|
194
|
+
trackId: 'AlphaMissense scores',
|
|
195
|
+
name: 'AlphaMissense scores',
|
|
196
|
+
assemblyNames: [uniprotId],
|
|
197
|
+
adapter: {
|
|
198
|
+
type: 'AlphaMissensePathogenicityAdapter',
|
|
199
|
+
location: {
|
|
200
|
+
uri: `https://alphafold.ebi.ac.uk/files/AF-${uniprotId}-F1-aa-substitutions.csv`,
|
|
201
|
+
},
|
|
202
|
+
},
|
|
203
|
+
displays: [
|
|
204
|
+
{
|
|
205
|
+
type: 'MultiLinearWiggleDisplay',
|
|
206
|
+
displayId: 'AlphaMissense scores-MultiLinearWiggleDisplay',
|
|
207
|
+
defaultRendering: 'multirowdensity',
|
|
208
|
+
renderers: {
|
|
209
|
+
MultiDensityRenderer: {
|
|
210
|
+
type: 'MultiDensityRenderer',
|
|
211
|
+
bicolorPivotValue: 0.5,
|
|
212
|
+
},
|
|
213
|
+
},
|
|
214
|
+
},
|
|
215
|
+
],
|
|
216
|
+
});
|
|
217
|
+
const view = session.addView('LinearGenomeView', {
|
|
218
|
+
type: 'LinearGenomeView',
|
|
219
|
+
displayName: [
|
|
220
|
+
'Protein view',
|
|
221
|
+
uniprotId,
|
|
222
|
+
getGeneDisplayName(feature),
|
|
223
|
+
getTranscriptDisplayName(selectedTranscript),
|
|
224
|
+
].join(' - '),
|
|
225
|
+
});
|
|
226
|
+
await view.navToLocString(uniprotId, uniprotId);
|
|
227
|
+
}
|
|
228
|
+
catch (e) {
|
|
229
|
+
console.error(e);
|
|
230
|
+
session.notifyError(`${e}`, e);
|
|
231
|
+
}
|
|
232
|
+
})();
|
|
233
|
+
}
|
|
234
|
+
handleClose();
|
|
235
|
+
} }, "Launch linear protein annotation view"))));
|
|
86
236
|
});
|
|
87
237
|
export default AlphaFoldDBSearch;
|
|
88
238
|
//# sourceMappingURL=AlphaFoldDBSearch.js.map
|