@jbrowse/plugin-alignments 2.4.2 → 2.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AlignmentsFeatureDetail/AlignmentsFeatureDetail.d.ts +2 -2
- package/dist/AlignmentsFeatureDetail/AlignmentsFeatureFlags.d.ts +2 -2
- package/dist/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js +2 -1
- package/dist/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js.map +1 -1
- package/dist/AlignmentsFeatureDetail/AlignmentsFeatureSuppAligns.d.ts +2 -2
- package/dist/AlignmentsFeatureDetail/index.d.ts +4 -1
- package/dist/AlignmentsTrack/configSchemaF.d.ts +74 -0
- package/dist/AlignmentsTrack/configSchemaF.js +19 -0
- package/dist/AlignmentsTrack/configSchemaF.js.map +1 -0
- package/dist/AlignmentsTrack/index.js +2 -15
- package/dist/AlignmentsTrack/index.js.map +1 -1
- package/dist/BamAdapter/BamAdapter.d.ts +2 -2
- package/dist/BamAdapter/BamAdapter.js +27 -32
- package/dist/BamAdapter/BamAdapter.js.map +1 -1
- package/dist/BamAdapter/BamSlightlyLazyFeature.d.ts +1 -1
- package/dist/BamAdapter/configSchema.d.ts +50 -1
- package/dist/CramAdapter/CramAdapter.d.ts +1 -1
- package/dist/CramAdapter/CramAdapter.js +49 -47
- package/dist/CramAdapter/CramAdapter.js.map +1 -1
- package/dist/CramAdapter/CramSlightlyLazyFeature.js +3 -5
- package/dist/CramAdapter/CramSlightlyLazyFeature.js.map +1 -1
- package/dist/CramAdapter/CramTestAdapters.js +3 -3
- package/dist/CramAdapter/CramTestAdapters.js.map +1 -1
- package/dist/CramAdapter/configSchema.d.ts +40 -1
- package/dist/HtsgetBamAdapter/configSchema.d.ts +26 -1
- package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.d.ts +2 -2
- package/dist/LinearAlignmentsDisplay/models/configSchema.d.ts +39 -1
- package/dist/LinearAlignmentsDisplay/models/model.d.ts +20 -6
- package/dist/LinearAlignmentsDisplay/models/model.js +9 -4
- package/dist/LinearAlignmentsDisplay/models/model.js.map +1 -1
- package/dist/LinearPileupDisplay/components/ColorByModifications.d.ts +2 -2
- package/dist/LinearPileupDisplay/components/ColorByModifications.js +3 -23
- package/dist/LinearPileupDisplay/components/ColorByModifications.js.map +1 -1
- package/dist/LinearPileupDisplay/components/ColorByTag.d.ts +2 -2
- package/dist/LinearPileupDisplay/components/ColorByTag.js +2 -6
- package/dist/LinearPileupDisplay/components/ColorByTag.js.map +1 -1
- package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.d.ts +3 -3
- package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js +6 -6
- package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js.map +1 -1
- package/dist/LinearPileupDisplay/components/ModificationsTable.d.ts +4 -0
- package/dist/LinearPileupDisplay/components/ModificationsTable.js +29 -0
- package/dist/LinearPileupDisplay/components/ModificationsTable.js.map +1 -0
- package/dist/LinearPileupDisplay/components/SetFeatureHeight.d.ts +2 -2
- package/dist/LinearPileupDisplay/components/SetMaxHeight.d.ts +2 -2
- package/dist/LinearPileupDisplay/components/SetMaxHeight.js +3 -5
- package/dist/LinearPileupDisplay/components/SetMaxHeight.js.map +1 -1
- package/dist/LinearPileupDisplay/components/SortByTag.d.ts +2 -2
- package/dist/LinearPileupDisplay/configSchema.d.ts +57 -1
- package/dist/LinearPileupDisplay/model.d.ts +160 -80
- package/dist/LinearPileupDisplay/model.js +181 -138
- package/dist/LinearPileupDisplay/model.js.map +1 -1
- package/dist/LinearReadArcsDisplay/components/ReactComponent.d.ts +2 -2
- package/dist/LinearReadArcsDisplay/components/ReactComponent.js +36 -39
- package/dist/LinearReadArcsDisplay/components/ReactComponent.js.map +1 -1
- package/dist/LinearReadArcsDisplay/configSchema.d.ts +59 -1
- package/dist/LinearReadArcsDisplay/drawFeats.d.ts +2 -15
- package/dist/LinearReadArcsDisplay/drawFeats.js +58 -66
- package/dist/LinearReadArcsDisplay/drawFeats.js.map +1 -1
- package/dist/LinearReadArcsDisplay/model.d.ts +58 -193
- package/dist/LinearReadArcsDisplay/model.js +65 -115
- package/dist/LinearReadArcsDisplay/model.js.map +1 -1
- package/dist/LinearReadArcsDisplay/util.d.ts +2 -0
- package/dist/LinearReadArcsDisplay/util.js +13 -0
- package/dist/LinearReadArcsDisplay/util.js.map +1 -0
- package/dist/LinearReadCloudDisplay/components/ReactComponent.d.ts +2 -2
- package/dist/LinearReadCloudDisplay/components/ReactComponent.js +34 -36
- package/dist/LinearReadCloudDisplay/components/ReactComponent.js.map +1 -1
- package/dist/LinearReadCloudDisplay/configSchema.d.ts +52 -1
- package/dist/LinearReadCloudDisplay/drawFeats.d.ts +2 -10
- package/dist/LinearReadCloudDisplay/drawFeats.js +11 -127
- package/dist/LinearReadCloudDisplay/drawFeats.js.map +1 -1
- package/dist/LinearReadCloudDisplay/drawLongReadChains.d.ts +11 -0
- package/dist/LinearReadCloudDisplay/drawLongReadChains.js +69 -0
- package/dist/LinearReadCloudDisplay/drawLongReadChains.js.map +1 -0
- package/dist/LinearReadCloudDisplay/drawPairChains.d.ts +17 -0
- package/dist/LinearReadCloudDisplay/drawPairChains.js +100 -0
- package/dist/LinearReadCloudDisplay/drawPairChains.js.map +1 -0
- package/dist/LinearReadCloudDisplay/model.d.ts +65 -196
- package/dist/LinearReadCloudDisplay/model.js +55 -92
- package/dist/LinearReadCloudDisplay/model.js.map +1 -1
- package/dist/LinearReadCloudDisplay/util.d.ts +2 -0
- package/dist/LinearReadCloudDisplay/util.js +35 -0
- package/dist/LinearReadCloudDisplay/util.js.map +1 -0
- package/dist/LinearSNPCoverageDisplay/components/Tooltip.d.ts +2 -2
- package/dist/LinearSNPCoverageDisplay/models/configSchema.d.ts +79 -1
- package/dist/LinearSNPCoverageDisplay/models/model.d.ts +157 -70
- package/dist/LinearSNPCoverageDisplay/models/model.js +46 -33
- package/dist/LinearSNPCoverageDisplay/models/model.js.map +1 -1
- package/dist/MismatchParser/index.d.ts +7 -2
- package/dist/MismatchParser/index.js +44 -5
- package/dist/MismatchParser/index.js.map +1 -1
- package/dist/PileupRPC/methods/GetReducedFeatures.d.ts +15 -2
- package/dist/PileupRPC/methods/GetReducedFeatures.js +1 -8
- package/dist/PileupRPC/methods/GetReducedFeatures.js.map +1 -1
- package/dist/PileupRenderer/PileupLayoutSession.d.ts +1 -1
- package/dist/PileupRenderer/PileupRenderer.d.ts +4 -117
- package/dist/PileupRenderer/PileupRenderer.js +18 -752
- package/dist/PileupRenderer/PileupRenderer.js.map +1 -1
- package/dist/PileupRenderer/colorBy.d.ts +7 -0
- package/dist/PileupRenderer/colorBy.js +69 -0
- package/dist/PileupRenderer/colorBy.js.map +1 -0
- package/dist/PileupRenderer/components/PileupRendering.d.ts +7 -2
- package/dist/PileupRenderer/components/PileupRendering.js +17 -18
- package/dist/PileupRenderer/components/PileupRendering.js.map +1 -1
- package/dist/PileupRenderer/configSchema.d.ts +87 -1
- package/dist/PileupRenderer/getAlignmentShapeColor.d.ts +10 -0
- package/dist/PileupRenderer/getAlignmentShapeColor.js +60 -0
- package/dist/PileupRenderer/getAlignmentShapeColor.js.map +1 -0
- package/dist/PileupRenderer/index.js +1 -1
- package/dist/PileupRenderer/index.js.map +1 -1
- package/dist/PileupRenderer/layoutFeature.d.ts +18 -0
- package/dist/PileupRenderer/layoutFeature.js +41 -0
- package/dist/PileupRenderer/layoutFeature.js.map +1 -0
- package/dist/PileupRenderer/layoutFeatures.d.ts +2 -0
- package/dist/PileupRenderer/layoutFeatures.js +35 -0
- package/dist/PileupRenderer/layoutFeatures.js.map +1 -0
- package/dist/PileupRenderer/makeImageData.d.ts +17 -0
- package/dist/PileupRenderer/makeImageData.js +64 -0
- package/dist/PileupRenderer/makeImageData.js.map +1 -0
- package/dist/PileupRenderer/renderAlignment.d.ts +13 -0
- package/dist/PileupRenderer/renderAlignment.js +72 -0
- package/dist/PileupRenderer/renderAlignment.js.map +1 -0
- package/dist/PileupRenderer/renderAlignmentShape.d.ts +7 -0
- package/dist/PileupRenderer/renderAlignmentShape.js +41 -0
- package/dist/PileupRenderer/renderAlignmentShape.js.map +1 -0
- package/dist/PileupRenderer/renderMethylation.d.ts +11 -0
- package/dist/PileupRenderer/renderMethylation.js +63 -0
- package/dist/PileupRenderer/renderMethylation.js.map +1 -0
- package/dist/PileupRenderer/renderMismatches.d.ts +21 -0
- package/dist/PileupRenderer/renderMismatches.js +135 -0
- package/dist/PileupRenderer/renderMismatches.js.map +1 -0
- package/dist/PileupRenderer/renderModifications.d.ts +11 -0
- package/dist/PileupRenderer/renderModifications.js +54 -0
- package/dist/PileupRenderer/renderModifications.js.map +1 -0
- package/dist/PileupRenderer/renderPerBaseLettering.d.ts +13 -0
- package/dist/PileupRenderer/renderPerBaseLettering.js +47 -0
- package/dist/PileupRenderer/renderPerBaseLettering.js.map +1 -0
- package/dist/PileupRenderer/renderPerBaseQuality.d.ts +9 -0
- package/dist/PileupRenderer/renderPerBaseQuality.js +39 -0
- package/dist/PileupRenderer/renderPerBaseQuality.js.map +1 -0
- package/dist/PileupRenderer/renderSoftClipping.d.ts +13 -0
- package/dist/PileupRenderer/renderSoftClipping.js +48 -0
- package/dist/PileupRenderer/renderSoftClipping.js.map +1 -0
- package/dist/PileupRenderer/sortUtil.js +1 -2
- package/dist/PileupRenderer/sortUtil.js.map +1 -1
- package/dist/PileupRenderer/util.d.ts +24 -0
- package/dist/PileupRenderer/util.js +51 -0
- package/dist/PileupRenderer/util.js.map +1 -0
- package/dist/SNPCoverageAdapter/SNPCoverageAdapter.d.ts +1 -3
- package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js +2 -5
- package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js.map +1 -1
- package/dist/SNPCoverageAdapter/configSchema.d.ts +10 -1
- package/dist/SNPCoverageAdapter/generateCoverageBins.d.ts +3 -43
- package/dist/SNPCoverageAdapter/generateCoverageBins.js +86 -59
- package/dist/SNPCoverageAdapter/generateCoverageBins.js.map +1 -1
- package/dist/SNPCoverageAdapter/index.js +0 -2
- package/dist/SNPCoverageAdapter/index.js.map +1 -1
- package/dist/SNPCoverageAdapter/util.d.ts +29 -0
- package/dist/SNPCoverageAdapter/util.js +3 -0
- package/dist/SNPCoverageAdapter/util.js.map +1 -0
- package/dist/SNPCoverageRenderer/SNPCoverageRenderer.d.ts +1 -1
- package/dist/SNPCoverageRenderer/SNPCoverageRenderer.js +2 -2
- package/dist/SNPCoverageRenderer/SNPCoverageRenderer.js.map +1 -1
- package/dist/SNPCoverageRenderer/configSchema.d.ts +47 -1
- package/dist/SNPCoverageRenderer/configSchema.js +5 -0
- package/dist/SNPCoverageRenderer/configSchema.js.map +1 -1
- package/dist/shared/BaseDisplayComponent.d.ts +8 -0
- package/dist/shared/BaseDisplayComponent.js +49 -0
- package/dist/shared/BaseDisplayComponent.js.map +1 -0
- package/dist/shared/FilterByTag.d.ts +13 -12
- package/dist/shared/FilterByTag.js +8 -13
- package/dist/shared/FilterByTag.js.map +1 -1
- package/dist/shared/afterAttach.d.ts +2 -0
- package/dist/shared/afterAttach.js +44 -0
- package/dist/shared/afterAttach.js.map +1 -0
- package/dist/shared/color.d.ts +44 -6
- package/dist/shared/color.js +57 -23
- package/dist/shared/color.js.map +1 -1
- package/dist/shared/fetchChains.d.ts +3 -2
- package/dist/shared/fetchChains.js +14 -20
- package/dist/shared/fetchChains.js.map +1 -1
- package/dist/shared/renderSvg.d.ts +7 -0
- package/dist/shared/renderSvg.js +69 -0
- package/dist/shared/renderSvg.js.map +1 -0
- package/dist/shared/util.d.ts +2 -0
- package/dist/shared/util.js +13 -0
- package/dist/shared/util.js.map +1 -0
- package/dist/util.d.ts +16 -2
- package/dist/util.js +45 -4
- package/dist/util.js.map +1 -1
- package/esm/AlignmentsFeatureDetail/AlignmentsFeatureDetail.d.ts +2 -2
- package/esm/AlignmentsFeatureDetail/AlignmentsFeatureFlags.d.ts +2 -2
- package/esm/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js +3 -2
- package/esm/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js.map +1 -1
- package/esm/AlignmentsFeatureDetail/AlignmentsFeatureSuppAligns.d.ts +2 -2
- package/esm/AlignmentsFeatureDetail/index.d.ts +4 -1
- package/esm/AlignmentsTrack/configSchemaF.d.ts +74 -0
- package/esm/AlignmentsTrack/configSchemaF.js +16 -0
- package/esm/AlignmentsTrack/configSchemaF.js.map +1 -0
- package/esm/AlignmentsTrack/index.js +3 -16
- package/esm/AlignmentsTrack/index.js.map +1 -1
- package/esm/BamAdapter/BamAdapter.d.ts +2 -2
- package/esm/BamAdapter/BamAdapter.js +27 -32
- package/esm/BamAdapter/BamAdapter.js.map +1 -1
- package/esm/BamAdapter/BamSlightlyLazyFeature.d.ts +1 -1
- package/esm/BamAdapter/configSchema.d.ts +50 -1
- package/esm/CramAdapter/CramAdapter.d.ts +1 -1
- package/esm/CramAdapter/CramAdapter.js +50 -48
- package/esm/CramAdapter/CramAdapter.js.map +1 -1
- package/esm/CramAdapter/CramSlightlyLazyFeature.js +3 -5
- package/esm/CramAdapter/CramSlightlyLazyFeature.js.map +1 -1
- package/esm/CramAdapter/CramTestAdapters.js +2 -2
- package/esm/CramAdapter/CramTestAdapters.js.map +1 -1
- package/esm/CramAdapter/configSchema.d.ts +40 -1
- package/esm/HtsgetBamAdapter/configSchema.d.ts +26 -1
- package/esm/LinearAlignmentsDisplay/components/AlignmentsDisplay.d.ts +2 -2
- package/esm/LinearAlignmentsDisplay/models/configSchema.d.ts +39 -1
- package/esm/LinearAlignmentsDisplay/models/model.d.ts +20 -6
- package/esm/LinearAlignmentsDisplay/models/model.js +9 -4
- package/esm/LinearAlignmentsDisplay/models/model.js.map +1 -1
- package/esm/LinearPileupDisplay/components/ColorByModifications.d.ts +2 -2
- package/esm/LinearPileupDisplay/components/ColorByModifications.js +2 -22
- package/esm/LinearPileupDisplay/components/ColorByModifications.js.map +1 -1
- package/esm/LinearPileupDisplay/components/ColorByTag.d.ts +2 -2
- package/esm/LinearPileupDisplay/components/ColorByTag.js +2 -6
- package/esm/LinearPileupDisplay/components/ColorByTag.js.map +1 -1
- package/esm/LinearPileupDisplay/components/LinearPileupDisplayBlurb.d.ts +3 -3
- package/esm/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js +6 -6
- package/esm/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js.map +1 -1
- package/esm/LinearPileupDisplay/components/ModificationsTable.d.ts +4 -0
- package/esm/LinearPileupDisplay/components/ModificationsTable.js +23 -0
- package/esm/LinearPileupDisplay/components/ModificationsTable.js.map +1 -0
- package/esm/LinearPileupDisplay/components/SetFeatureHeight.d.ts +2 -2
- package/esm/LinearPileupDisplay/components/SetMaxHeight.d.ts +2 -2
- package/esm/LinearPileupDisplay/components/SetMaxHeight.js +3 -5
- package/esm/LinearPileupDisplay/components/SetMaxHeight.js.map +1 -1
- package/esm/LinearPileupDisplay/components/SortByTag.d.ts +2 -2
- package/esm/LinearPileupDisplay/configSchema.d.ts +57 -1
- package/esm/LinearPileupDisplay/model.d.ts +160 -80
- package/esm/LinearPileupDisplay/model.js +182 -139
- package/esm/LinearPileupDisplay/model.js.map +1 -1
- package/esm/LinearReadArcsDisplay/components/ReactComponent.d.ts +2 -2
- package/esm/LinearReadArcsDisplay/components/ReactComponent.js +13 -39
- package/esm/LinearReadArcsDisplay/components/ReactComponent.js.map +1 -1
- package/esm/LinearReadArcsDisplay/configSchema.d.ts +59 -1
- package/esm/LinearReadArcsDisplay/drawFeats.d.ts +2 -15
- package/esm/LinearReadArcsDisplay/drawFeats.js +56 -63
- package/esm/LinearReadArcsDisplay/drawFeats.js.map +1 -1
- package/esm/LinearReadArcsDisplay/model.d.ts +58 -193
- package/esm/LinearReadArcsDisplay/model.js +69 -119
- package/esm/LinearReadArcsDisplay/model.js.map +1 -1
- package/esm/LinearReadArcsDisplay/util.d.ts +2 -0
- package/esm/LinearReadArcsDisplay/util.js +9 -0
- package/esm/LinearReadArcsDisplay/util.js.map +1 -0
- package/esm/LinearReadCloudDisplay/components/ReactComponent.d.ts +2 -2
- package/esm/LinearReadCloudDisplay/components/ReactComponent.js +11 -36
- package/esm/LinearReadCloudDisplay/components/ReactComponent.js.map +1 -1
- package/esm/LinearReadCloudDisplay/configSchema.d.ts +52 -1
- package/esm/LinearReadCloudDisplay/drawFeats.d.ts +2 -10
- package/esm/LinearReadCloudDisplay/drawFeats.js +9 -126
- package/esm/LinearReadCloudDisplay/drawFeats.js.map +1 -1
- package/esm/LinearReadCloudDisplay/drawLongReadChains.d.ts +11 -0
- package/esm/LinearReadCloudDisplay/drawLongReadChains.js +65 -0
- package/esm/LinearReadCloudDisplay/drawLongReadChains.js.map +1 -0
- package/esm/LinearReadCloudDisplay/drawPairChains.d.ts +17 -0
- package/esm/LinearReadCloudDisplay/drawPairChains.js +95 -0
- package/esm/LinearReadCloudDisplay/drawPairChains.js.map +1 -0
- package/esm/LinearReadCloudDisplay/model.d.ts +65 -196
- package/esm/LinearReadCloudDisplay/model.js +59 -96
- package/esm/LinearReadCloudDisplay/model.js.map +1 -1
- package/esm/LinearReadCloudDisplay/util.d.ts +2 -0
- package/esm/LinearReadCloudDisplay/util.js +30 -0
- package/esm/LinearReadCloudDisplay/util.js.map +1 -0
- package/esm/LinearSNPCoverageDisplay/components/Tooltip.d.ts +2 -2
- package/esm/LinearSNPCoverageDisplay/models/configSchema.d.ts +79 -1
- package/esm/LinearSNPCoverageDisplay/models/model.d.ts +157 -70
- package/esm/LinearSNPCoverageDisplay/models/model.js +48 -35
- package/esm/LinearSNPCoverageDisplay/models/model.js.map +1 -1
- package/esm/MismatchParser/index.d.ts +7 -2
- package/esm/MismatchParser/index.js +41 -4
- package/esm/MismatchParser/index.js.map +1 -1
- package/esm/PileupRPC/methods/GetReducedFeatures.d.ts +15 -2
- package/esm/PileupRPC/methods/GetReducedFeatures.js +2 -9
- package/esm/PileupRPC/methods/GetReducedFeatures.js.map +1 -1
- package/esm/PileupRenderer/PileupLayoutSession.d.ts +1 -1
- package/esm/PileupRenderer/PileupRenderer.d.ts +4 -117
- package/esm/PileupRenderer/PileupRenderer.js +20 -754
- package/esm/PileupRenderer/PileupRenderer.js.map +1 -1
- package/esm/PileupRenderer/colorBy.d.ts +7 -0
- package/esm/PileupRenderer/colorBy.js +61 -0
- package/esm/PileupRenderer/colorBy.js.map +1 -0
- package/esm/PileupRenderer/components/PileupRendering.d.ts +7 -2
- package/esm/PileupRenderer/components/PileupRendering.js +17 -18
- package/esm/PileupRenderer/components/PileupRendering.js.map +1 -1
- package/esm/PileupRenderer/configSchema.d.ts +87 -1
- package/esm/PileupRenderer/getAlignmentShapeColor.d.ts +10 -0
- package/esm/PileupRenderer/getAlignmentShapeColor.js +56 -0
- package/esm/PileupRenderer/getAlignmentShapeColor.js.map +1 -0
- package/esm/PileupRenderer/index.js +1 -1
- package/esm/PileupRenderer/index.js.map +1 -1
- package/esm/PileupRenderer/layoutFeature.d.ts +18 -0
- package/esm/PileupRenderer/layoutFeature.js +37 -0
- package/esm/PileupRenderer/layoutFeature.js.map +1 -0
- package/esm/PileupRenderer/layoutFeatures.d.ts +2 -0
- package/esm/PileupRenderer/layoutFeatures.js +31 -0
- package/esm/PileupRenderer/layoutFeatures.js.map +1 -0
- package/esm/PileupRenderer/makeImageData.d.ts +17 -0
- package/esm/PileupRenderer/makeImageData.js +60 -0
- package/esm/PileupRenderer/makeImageData.js.map +1 -0
- package/esm/PileupRenderer/renderAlignment.d.ts +13 -0
- package/esm/PileupRenderer/renderAlignment.js +68 -0
- package/esm/PileupRenderer/renderAlignment.js.map +1 -0
- package/esm/PileupRenderer/renderAlignmentShape.d.ts +7 -0
- package/esm/PileupRenderer/renderAlignmentShape.js +37 -0
- package/esm/PileupRenderer/renderAlignmentShape.js.map +1 -0
- package/esm/PileupRenderer/renderMethylation.d.ts +11 -0
- package/esm/PileupRenderer/renderMethylation.js +59 -0
- package/esm/PileupRenderer/renderMethylation.js.map +1 -0
- package/esm/PileupRenderer/renderMismatches.d.ts +21 -0
- package/esm/PileupRenderer/renderMismatches.js +131 -0
- package/esm/PileupRenderer/renderMismatches.js.map +1 -0
- package/esm/PileupRenderer/renderModifications.d.ts +11 -0
- package/esm/PileupRenderer/renderModifications.js +50 -0
- package/esm/PileupRenderer/renderModifications.js.map +1 -0
- package/esm/PileupRenderer/renderPerBaseLettering.d.ts +13 -0
- package/esm/PileupRenderer/renderPerBaseLettering.js +43 -0
- package/esm/PileupRenderer/renderPerBaseLettering.js.map +1 -0
- package/esm/PileupRenderer/renderPerBaseQuality.d.ts +9 -0
- package/esm/PileupRenderer/renderPerBaseQuality.js +35 -0
- package/esm/PileupRenderer/renderPerBaseQuality.js.map +1 -0
- package/esm/PileupRenderer/renderSoftClipping.d.ts +13 -0
- package/esm/PileupRenderer/renderSoftClipping.js +44 -0
- package/esm/PileupRenderer/renderSoftClipping.js.map +1 -0
- package/esm/PileupRenderer/sortUtil.js +1 -2
- package/esm/PileupRenderer/sortUtil.js.map +1 -1
- package/esm/PileupRenderer/util.d.ts +24 -0
- package/esm/PileupRenderer/util.js +42 -0
- package/esm/PileupRenderer/util.js.map +1 -0
- package/esm/SNPCoverageAdapter/SNPCoverageAdapter.d.ts +1 -3
- package/esm/SNPCoverageAdapter/SNPCoverageAdapter.js +2 -4
- package/esm/SNPCoverageAdapter/SNPCoverageAdapter.js.map +1 -1
- package/esm/SNPCoverageAdapter/configSchema.d.ts +10 -1
- package/esm/SNPCoverageAdapter/generateCoverageBins.d.ts +3 -43
- package/esm/SNPCoverageAdapter/generateCoverageBins.js +87 -60
- package/esm/SNPCoverageAdapter/generateCoverageBins.js.map +1 -1
- package/esm/SNPCoverageAdapter/index.js +0 -2
- package/esm/SNPCoverageAdapter/index.js.map +1 -1
- package/esm/SNPCoverageAdapter/util.d.ts +29 -0
- package/esm/SNPCoverageAdapter/util.js +2 -0
- package/esm/SNPCoverageAdapter/util.js.map +1 -0
- package/esm/SNPCoverageRenderer/SNPCoverageRenderer.d.ts +1 -1
- package/esm/SNPCoverageRenderer/SNPCoverageRenderer.js +2 -2
- package/esm/SNPCoverageRenderer/SNPCoverageRenderer.js.map +1 -1
- package/esm/SNPCoverageRenderer/configSchema.d.ts +47 -1
- package/esm/SNPCoverageRenderer/configSchema.js +5 -0
- package/esm/SNPCoverageRenderer/configSchema.js.map +1 -1
- package/esm/shared/BaseDisplayComponent.d.ts +8 -0
- package/esm/shared/BaseDisplayComponent.js +44 -0
- package/esm/shared/BaseDisplayComponent.js.map +1 -0
- package/esm/shared/FilterByTag.d.ts +13 -12
- package/esm/shared/FilterByTag.js +8 -13
- package/esm/shared/FilterByTag.js.map +1 -1
- package/esm/shared/afterAttach.d.ts +2 -0
- package/esm/shared/afterAttach.js +40 -0
- package/esm/shared/afterAttach.js.map +1 -0
- package/esm/shared/color.d.ts +44 -6
- package/esm/shared/color.js +54 -20
- package/esm/shared/color.js.map +1 -1
- package/esm/shared/fetchChains.d.ts +3 -2
- package/esm/shared/fetchChains.js +14 -20
- package/esm/shared/fetchChains.js.map +1 -1
- package/esm/shared/renderSvg.d.ts +7 -0
- package/esm/shared/renderSvg.js +39 -0
- package/esm/shared/renderSvg.js.map +1 -0
- package/esm/shared/util.d.ts +2 -0
- package/esm/shared/util.js +9 -0
- package/esm/shared/util.js.map +1 -0
- package/esm/util.d.ts +16 -2
- package/esm/util.js +42 -3
- package/esm/util.js.map +1 -1
- package/package.json +3 -3
- package/src/AlignmentsFeatureDetail/AlignmentsFeatureFlags.tsx +3 -5
- package/src/AlignmentsFeatureDetail/__snapshots__/index.test.tsx.snap +1 -2
- package/src/AlignmentsTrack/configSchemaF.ts +22 -0
- package/src/AlignmentsTrack/index.ts +3 -24
- package/src/BamAdapter/BamAdapter.ts +46 -44
- package/src/CombinationTest.test.ts +2 -2
- package/src/CramAdapter/CramAdapter.ts +70 -56
- package/src/CramAdapter/CramSlightlyLazyFeature.ts +2 -5
- package/src/CramAdapter/CramTestAdapters.ts +2 -2
- package/src/LinearAlignmentsDisplay/models/model.tsx +16 -4
- package/src/LinearPileupDisplay/components/ColorByModifications.tsx +3 -39
- package/src/LinearPileupDisplay/components/ColorByTag.tsx +1 -6
- package/src/LinearPileupDisplay/components/LinearPileupDisplayBlurb.tsx +10 -11
- package/src/LinearPileupDisplay/components/ModificationsTable.tsx +38 -0
- package/src/LinearPileupDisplay/components/SetMaxHeight.tsx +3 -5
- package/src/LinearPileupDisplay/model.ts +235 -186
- package/src/LinearReadArcsDisplay/components/ReactComponent.tsx +23 -61
- package/src/LinearReadArcsDisplay/drawFeats.ts +79 -87
- package/src/LinearReadArcsDisplay/model.tsx +77 -155
- package/src/LinearReadArcsDisplay/util.ts +10 -0
- package/src/LinearReadCloudDisplay/components/ReactComponent.tsx +21 -59
- package/src/LinearReadCloudDisplay/drawFeats.ts +12 -166
- package/src/LinearReadCloudDisplay/drawLongReadChains.ts +85 -0
- package/src/LinearReadCloudDisplay/drawPairChains.ts +139 -0
- package/src/LinearReadCloudDisplay/model.tsx +72 -131
- package/src/LinearReadCloudDisplay/util.ts +47 -0
- package/src/LinearSNPCoverageDisplay/models/model.ts +63 -50
- package/src/MismatchParser/index.ts +46 -4
- package/src/PileupRPC/methods/GetReducedFeatures.ts +2 -10
- package/src/PileupRenderer/PileupLayoutSession.ts +1 -1
- package/src/PileupRenderer/PileupRenderer.ts +23 -1190
- package/src/PileupRenderer/colorBy.ts +74 -0
- package/src/PileupRenderer/components/PileupRendering.tsx +20 -25
- package/src/PileupRenderer/getAlignmentShapeColor.ts +87 -0
- package/src/PileupRenderer/index.ts +1 -1
- package/src/PileupRenderer/layoutFeature.ts +83 -0
- package/src/PileupRenderer/layoutFeatures.ts +44 -0
- package/src/PileupRenderer/makeImageData.ts +93 -0
- package/src/PileupRenderer/renderAlignment.ts +97 -0
- package/src/PileupRenderer/renderAlignmentShape.ts +45 -0
- package/src/PileupRenderer/renderMethylation.ts +75 -0
- package/src/PileupRenderer/renderMismatches.ts +206 -0
- package/src/PileupRenderer/renderModifications.ts +74 -0
- package/src/PileupRenderer/renderPerBaseLettering.ts +67 -0
- package/src/PileupRenderer/renderPerBaseQuality.ts +46 -0
- package/src/PileupRenderer/renderSoftClipping.ts +78 -0
- package/src/PileupRenderer/sortUtil.ts +1 -3
- package/src/PileupRenderer/util.ts +63 -0
- package/src/SNPCoverageAdapter/SNPCoverageAdapter.ts +5 -5
- package/src/SNPCoverageAdapter/generateCoverageBins.ts +105 -91
- package/src/SNPCoverageAdapter/index.ts +0 -2
- package/src/SNPCoverageAdapter/util.ts +33 -0
- package/src/SNPCoverageRenderer/SNPCoverageRenderer.ts +3 -3
- package/src/SNPCoverageRenderer/configSchema.ts +6 -0
- package/src/shared/BaseDisplayComponent.tsx +83 -0
- package/src/shared/FilterByTag.tsx +13 -23
- package/src/shared/afterAttach.tsx +66 -0
- package/src/shared/color.ts +59 -20
- package/src/shared/fetchChains.ts +23 -24
- package/src/shared/renderSvg.tsx +64 -0
- package/src/shared/util.ts +10 -0
- package/src/util.ts +54 -5
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { readConfObject, } from '@jbrowse/core/configuration';
|
|
2
|
+
import { bpSpanPx } from '@jbrowse/core/util';
|
|
3
|
+
import { fillRect, getCharWidthHeight } from './util';
|
|
4
|
+
export function renderSoftClipping({ ctx, feat, renderArgs, config, theme, colorForBase, canvasWidth, }) {
|
|
5
|
+
const { feature, topPx, heightPx } = feat;
|
|
6
|
+
const { regions, bpPerPx } = renderArgs;
|
|
7
|
+
const [region] = regions;
|
|
8
|
+
const minFeatWidth = readConfObject(config, 'minSubfeatureWidth');
|
|
9
|
+
const mismatches = feature.get('mismatches');
|
|
10
|
+
const seq = feature.get('seq');
|
|
11
|
+
const { charWidth, charHeight } = getCharWidthHeight();
|
|
12
|
+
// Display all bases softclipped off in lightened colors
|
|
13
|
+
if (!(seq && mismatches)) {
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
mismatches
|
|
17
|
+
.filter(mismatch => mismatch.type === 'softclip')
|
|
18
|
+
.forEach(mismatch => {
|
|
19
|
+
const len = mismatch.cliplen || 0;
|
|
20
|
+
const s = feature.get('start');
|
|
21
|
+
const start = mismatch.start === 0 ? s - len : s + mismatch.start;
|
|
22
|
+
for (let k = 0; k < len; k += 1) {
|
|
23
|
+
const base = seq.charAt(k + mismatch.start);
|
|
24
|
+
// If softclip length+start is longer than sequence, no need to
|
|
25
|
+
// continue showing base
|
|
26
|
+
if (!base) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
const s0 = start + k;
|
|
30
|
+
const [leftPx, rightPx] = bpSpanPx(s0, s0 + 1, region, bpPerPx);
|
|
31
|
+
const widthPx = Math.max(minFeatWidth, rightPx - leftPx);
|
|
32
|
+
// Black accounts for IUPAC ambiguity code bases such as N that
|
|
33
|
+
// show in soft clipping
|
|
34
|
+
const baseColor = colorForBase[base] || '#000000';
|
|
35
|
+
ctx.fillStyle = baseColor;
|
|
36
|
+
fillRect(ctx, leftPx, topPx, widthPx, heightPx, canvasWidth);
|
|
37
|
+
if (widthPx >= charWidth && heightPx >= charHeight - 5) {
|
|
38
|
+
ctx.fillStyle = theme.palette.getContrastText(baseColor);
|
|
39
|
+
ctx.fillText(base, leftPx + (widthPx - charWidth) / 2 + 1, topPx + heightPx);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=renderSoftClipping.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"renderSoftClipping.js","sourceRoot":"","sources":["../../src/PileupRenderer/renderSoftClipping.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,cAAc,GACf,MAAM,6BAA6B,CAAA;AACpC,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAM7C,OAAO,EAAE,QAAQ,EAAE,kBAAkB,EAAiB,MAAM,QAAQ,CAAA;AAEpE,MAAM,UAAU,kBAAkB,CAAC,EACjC,GAAG,EACH,IAAI,EACJ,UAAU,EACV,MAAM,EACN,KAAK,EACL,YAAY,EACZ,WAAW,GASZ;IACC,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAA;IACzC,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,UAAU,CAAA;IACvC,MAAM,CAAC,MAAM,CAAC,GAAG,OAAO,CAAA;IACxB,MAAM,YAAY,GAAG,cAAc,CAAC,MAAM,EAAE,oBAAoB,CAAC,CAAA;IACjE,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY,CAA2B,CAAA;IACtE,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAuB,CAAA;IACpD,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAEtD,wDAAwD;IACxD,IAAI,CAAC,CAAC,GAAG,IAAI,UAAU,CAAC,EAAE;QACxB,OAAM;KACP;IACD,UAAU;SACP,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,KAAK,UAAU,CAAC;SAChD,OAAO,CAAC,QAAQ,CAAC,EAAE;QAClB,MAAM,GAAG,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAA;QACjC,MAAM,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QAC9B,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAA;QAEjE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE;YAC/B,MAAM,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;YAE3C,+DAA+D;YAC/D,wBAAwB;YACxB,IAAI,CAAC,IAAI,EAAE;gBACT,OAAM;aACP;YAED,MAAM,EAAE,GAAG,KAAK,GAAG,CAAC,CAAA;YACpB,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;YAC/D,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,OAAO,GAAG,MAAM,CAAC,CAAA;YAExD,+DAA+D;YAC/D,wBAAwB;YACxB,MAAM,SAAS,GAAG,YAAY,CAAC,IAAI,CAAC,IAAI,SAAS,CAAA;YACjD,GAAG,CAAC,SAAS,GAAG,SAAS,CAAA;YACzB,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAA;YAE5D,IAAI,OAAO,IAAI,SAAS,IAAI,QAAQ,IAAI,UAAU,GAAG,CAAC,EAAE;gBACtD,GAAG,CAAC,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,SAAS,CAAC,CAAA;gBACxD,GAAG,CAAC,QAAQ,CACV,IAAI,EACJ,MAAM,GAAG,CAAC,OAAO,GAAG,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,EACtC,KAAK,GAAG,QAAQ,CACjB,CAAA;aACF;SACF;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -72,10 +72,9 @@ export const sortFeature = (features, sortedBy) => {
|
|
|
72
72
|
break;
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
|
-
|
|
75
|
+
return new Map([...featuresInCenterLine, ...featuresOutsideCenter].map(feature => [
|
|
76
76
|
feature.id(),
|
|
77
77
|
feature,
|
|
78
78
|
]));
|
|
79
|
-
return sortedMap;
|
|
80
79
|
};
|
|
81
80
|
//# sourceMappingURL=sortUtil.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sortUtil.js","sourceRoot":"","sources":["../../src/PileupRenderer/sortUtil.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"sortUtil.js","sourceRoot":"","sources":["../../src/PileupRenderer/sortUtil.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Feature } from '@jbrowse/core/util';
|
|
2
|
+
import { Theme } from '@mui/material';
|
|
3
|
+
export declare function fillRect(ctx: CanvasRenderingContext2D, l: number, t: number, w: number, h: number, cw: number, color?: string): void;
|
|
4
|
+
export declare function getColorBaseMap(theme: Theme): {
|
|
5
|
+
A: string;
|
|
6
|
+
C: string;
|
|
7
|
+
G: string;
|
|
8
|
+
T: string;
|
|
9
|
+
deletion: string;
|
|
10
|
+
};
|
|
11
|
+
export declare function getContrastBaseMap(theme: Theme): {
|
|
12
|
+
[k: string]: string;
|
|
13
|
+
};
|
|
14
|
+
export declare function shouldDrawSNPsMuted(type?: string): boolean;
|
|
15
|
+
export declare function shouldDrawIndels(): boolean;
|
|
16
|
+
export interface LayoutFeature {
|
|
17
|
+
heightPx: number;
|
|
18
|
+
topPx: number;
|
|
19
|
+
feature: Feature;
|
|
20
|
+
}
|
|
21
|
+
export declare function getCharWidthHeight(): {
|
|
22
|
+
charWidth: number;
|
|
23
|
+
charHeight: number;
|
|
24
|
+
};
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { measureText } from '@jbrowse/core/util';
|
|
2
|
+
export function fillRect(ctx, l, t, w, h, cw, color) {
|
|
3
|
+
if (l + w < 0 || l > cw) {
|
|
4
|
+
return;
|
|
5
|
+
}
|
|
6
|
+
else {
|
|
7
|
+
if (color) {
|
|
8
|
+
ctx.fillStyle = color;
|
|
9
|
+
}
|
|
10
|
+
ctx.fillRect(l, t, w, h);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export function getColorBaseMap(theme) {
|
|
14
|
+
const { bases } = theme.palette;
|
|
15
|
+
return {
|
|
16
|
+
A: bases.A.main,
|
|
17
|
+
C: bases.C.main,
|
|
18
|
+
G: bases.G.main,
|
|
19
|
+
T: bases.T.main,
|
|
20
|
+
deletion: '#808080', // gray
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
export function getContrastBaseMap(theme) {
|
|
24
|
+
return Object.fromEntries(Object.entries(getColorBaseMap(theme)).map(([key, value]) => [
|
|
25
|
+
key,
|
|
26
|
+
theme.palette.getContrastText(value),
|
|
27
|
+
]));
|
|
28
|
+
}
|
|
29
|
+
export function shouldDrawSNPsMuted(type) {
|
|
30
|
+
return ['methylation', 'modifications'].includes(type || '');
|
|
31
|
+
}
|
|
32
|
+
export function shouldDrawIndels() {
|
|
33
|
+
return true;
|
|
34
|
+
}
|
|
35
|
+
// get width and height of chars the height is an approximation: width letter M
|
|
36
|
+
// is approximately the height
|
|
37
|
+
export function getCharWidthHeight() {
|
|
38
|
+
const charWidth = measureText('A');
|
|
39
|
+
const charHeight = measureText('M') - 2;
|
|
40
|
+
return { charWidth, charHeight };
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=util.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/PileupRenderer/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,WAAW,EAAE,MAAM,oBAAoB,CAAA;AAGzD,MAAM,UAAU,QAAQ,CACtB,GAA6B,EAC7B,CAAS,EACT,CAAS,EACT,CAAS,EACT,CAAS,EACT,EAAU,EACV,KAAc;IAEd,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE;QACvB,OAAM;KACP;SAAM;QACL,IAAI,KAAK,EAAE;YACT,GAAG,CAAC,SAAS,GAAG,KAAK,CAAA;SACtB;QACD,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;KACzB;AACH,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,KAAY;IAC1C,MAAM,EAAE,KAAK,EAAE,GAAG,KAAK,CAAC,OAAO,CAAA;IAC/B,OAAO;QACL,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI;QACf,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI;QACf,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI;QACf,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI;QACf,QAAQ,EAAE,SAAS,EAAE,OAAO;KAC7B,CAAA;AACH,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,KAAY;IAC7C,OAAO,MAAM,CAAC,WAAW,CACvB,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC;QAC3D,GAAG;QACH,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC;KACrC,CAAC,CACH,CAAA;AACH,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,IAAa;IAC/C,OAAO,CAAC,aAAa,EAAE,eAAe,CAAC,CAAC,QAAQ,CAAC,IAAI,IAAI,EAAE,CAAC,CAAA;AAC9D,CAAC;AAED,MAAM,UAAU,gBAAgB;IAC9B,OAAO,IAAI,CAAA;AACb,CAAC;AAQD,+EAA+E;AAC/E,8BAA8B;AAC9B,MAAM,UAAU,kBAAkB;IAChC,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,CAAC,CAAA;IAClC,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;IACvC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,CAAA;AAClC,CAAC"}
|
|
@@ -8,9 +8,7 @@ export default class SNPCoverageAdapter extends BaseFeatureDataAdapter {
|
|
|
8
8
|
}>;
|
|
9
9
|
fetchSequence(region: Region): Promise<any>;
|
|
10
10
|
getFeatures(region: Region, opts?: BaseOptions): import("rxjs").Observable<Feature>;
|
|
11
|
-
|
|
11
|
+
getMultiRegionFeatureDensityStats(regions: Region[], opts?: BaseOptions): Promise<import("@jbrowse/core/data_adapters/BaseAdapter").FeatureDensityStats>;
|
|
12
12
|
getRefNames(opts?: BaseOptions): Promise<string[]>;
|
|
13
13
|
freeResources(): void;
|
|
14
14
|
}
|
|
15
|
-
declare const capabilities: string[];
|
|
16
|
-
export { capabilities };
|
|
@@ -65,9 +65,9 @@ export default class SNPCoverageAdapter extends BaseFeatureDataAdapter {
|
|
|
65
65
|
observer.complete();
|
|
66
66
|
}, opts.signal);
|
|
67
67
|
}
|
|
68
|
-
async
|
|
68
|
+
async getMultiRegionFeatureDensityStats(regions, opts) {
|
|
69
69
|
const { subadapter } = await this.configure();
|
|
70
|
-
return subadapter.
|
|
70
|
+
return subadapter.getMultiRegionFeatureDensityStats(regions, opts);
|
|
71
71
|
}
|
|
72
72
|
async getRefNames(opts = {}) {
|
|
73
73
|
const { subadapter } = await this.configure();
|
|
@@ -75,6 +75,4 @@ export default class SNPCoverageAdapter extends BaseFeatureDataAdapter {
|
|
|
75
75
|
}
|
|
76
76
|
freeResources( /* { region } */) { }
|
|
77
77
|
}
|
|
78
|
-
const { capabilities } = SNPCoverageAdapter;
|
|
79
|
-
export { capabilities };
|
|
80
78
|
//# sourceMappingURL=SNPCoverageAdapter.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SNPCoverageAdapter.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/SNPCoverageAdapter.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"SNPCoverageAdapter.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/SNPCoverageAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,11 @@
|
|
|
1
|
-
declare const configSchema: import("@jbrowse/core/configuration").
|
|
1
|
+
declare const configSchema: import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaType<{
|
|
2
|
+
/**
|
|
3
|
+
* #slot
|
|
4
|
+
* normally refers to a BAM or CRAM adapter
|
|
5
|
+
*/
|
|
6
|
+
subadapter: {
|
|
7
|
+
type: string;
|
|
8
|
+
defaultValue: null;
|
|
9
|
+
};
|
|
10
|
+
}, import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaOptions<undefined, undefined>>;
|
|
2
11
|
export default configSchema;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { AugmentedRegion as Region } from '@jbrowse/core/util/types';
|
|
2
2
|
import { Feature } from '@jbrowse/core/util/simpleFeature';
|
|
3
|
+
import { Bin, SkipMap } from './util';
|
|
3
4
|
export default function generateCoverageBins(features: Feature[], region: Region, opts: {
|
|
4
5
|
bpPerPx?: number;
|
|
5
6
|
colorBy?: {
|
|
@@ -7,47 +8,6 @@ export default function generateCoverageBins(features: Feature[], region: Region
|
|
|
7
8
|
tag?: string;
|
|
8
9
|
};
|
|
9
10
|
}, fetchSequence: (arg: Region) => Promise<string>): Promise<{
|
|
10
|
-
bins:
|
|
11
|
-
|
|
12
|
-
total: number;
|
|
13
|
-
all: number;
|
|
14
|
-
ref: number;
|
|
15
|
-
'-1': 0;
|
|
16
|
-
'0': 0;
|
|
17
|
-
'1': 0;
|
|
18
|
-
lowqual: {
|
|
19
|
-
total: number;
|
|
20
|
-
strands: {
|
|
21
|
-
[key: string]: number;
|
|
22
|
-
};
|
|
23
|
-
};
|
|
24
|
-
cov: {
|
|
25
|
-
total: number;
|
|
26
|
-
strands: {
|
|
27
|
-
[key: string]: number;
|
|
28
|
-
};
|
|
29
|
-
};
|
|
30
|
-
delskips: {
|
|
31
|
-
total: number;
|
|
32
|
-
strands: {
|
|
33
|
-
[key: string]: number;
|
|
34
|
-
};
|
|
35
|
-
};
|
|
36
|
-
noncov: {
|
|
37
|
-
total: number;
|
|
38
|
-
strands: {
|
|
39
|
-
[key: string]: number;
|
|
40
|
-
};
|
|
41
|
-
};
|
|
42
|
-
}[];
|
|
43
|
-
skipmap: {
|
|
44
|
-
[key: string]: {
|
|
45
|
-
score: number;
|
|
46
|
-
feature: unknown;
|
|
47
|
-
start: number;
|
|
48
|
-
end: number;
|
|
49
|
-
strand: number;
|
|
50
|
-
xs: string;
|
|
51
|
-
};
|
|
52
|
-
};
|
|
11
|
+
bins: Bin[];
|
|
12
|
+
skipmap: SkipMap;
|
|
53
13
|
}>;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { getTag, getTagAlt, shouldFetchReferenceSequence } from '../util';
|
|
2
|
-
import { parseCigar, getNextRefPos, getModificationPositions, } from '../MismatchParser';
|
|
2
|
+
import { parseCigar, getNextRefPos, getModificationPositions, getMethBins, } from '../MismatchParser';
|
|
3
|
+
import { doesIntersect2 } from '@jbrowse/core/util';
|
|
3
4
|
function mismatchLen(mismatch) {
|
|
4
5
|
return !isInterbase(mismatch.type) ? mismatch.length : 1;
|
|
5
6
|
}
|
|
@@ -21,19 +22,24 @@ function inc(bin, strand, type, field) {
|
|
|
21
22
|
thisBin[strand]++;
|
|
22
23
|
}
|
|
23
24
|
export default async function generateCoverageBins(features, region, opts, fetchSequence) {
|
|
24
|
-
var _a;
|
|
25
|
+
var _a, _b, _c;
|
|
25
26
|
const { colorBy } = opts;
|
|
26
|
-
const
|
|
27
|
+
const extendedRegion = {
|
|
28
|
+
...region,
|
|
29
|
+
start: Math.max(0, region.start - 1),
|
|
30
|
+
end: region.end + 1,
|
|
31
|
+
};
|
|
32
|
+
const binMax = Math.ceil(extendedRegion.end - extendedRegion.start);
|
|
27
33
|
const skipmap = {};
|
|
28
|
-
const
|
|
34
|
+
const regionSequence = features.length && shouldFetchReferenceSequence((_a = opts.colorBy) === null || _a === void 0 ? void 0 : _a.type)
|
|
29
35
|
? await fetchSequence(region)
|
|
30
36
|
: undefined;
|
|
31
37
|
const bins = [];
|
|
32
|
-
for (
|
|
33
|
-
const feature = features[i];
|
|
38
|
+
for (const feature of features) {
|
|
34
39
|
const fstart = feature.get('start');
|
|
35
40
|
const fend = feature.get('end');
|
|
36
41
|
const fstrand = feature.get('strand');
|
|
42
|
+
const mismatches = feature.get('mismatches') || [];
|
|
37
43
|
for (let j = fstart; j < fend + 1; j++) {
|
|
38
44
|
const i = j - region.start;
|
|
39
45
|
if (i >= 0 && i < binMax) {
|
|
@@ -64,77 +70,98 @@ export default async function generateCoverageBins(features, region, opts, fetch
|
|
|
64
70
|
const mm = getTagAlt(feature, 'MM', 'Mm') || '';
|
|
65
71
|
const ops = parseCigar(feature.get('CIGAR'));
|
|
66
72
|
const fend = feature.get('end');
|
|
67
|
-
|
|
68
|
-
const
|
|
69
|
-
for (const
|
|
70
|
-
const
|
|
71
|
-
|
|
72
|
-
const
|
|
73
|
-
if (
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
73
|
+
if (seq) {
|
|
74
|
+
const modifications = getModificationPositions(mm, seq, fstrand);
|
|
75
|
+
for (const { type, positions } of modifications) {
|
|
76
|
+
const mod = `mod_${type}`;
|
|
77
|
+
for (const pos of getNextRefPos(ops, positions)) {
|
|
78
|
+
const epos = pos + fstart - region.start;
|
|
79
|
+
if (epos >= 0 && epos < bins.length && pos + fstart < fend) {
|
|
80
|
+
if (bins[epos] === undefined) {
|
|
81
|
+
bins[epos] = {
|
|
82
|
+
total: 0,
|
|
83
|
+
all: 0,
|
|
84
|
+
ref: 0,
|
|
85
|
+
'-1': 0,
|
|
86
|
+
'0': 0,
|
|
87
|
+
'1': 0,
|
|
88
|
+
lowqual: {},
|
|
89
|
+
cov: {},
|
|
90
|
+
delskips: {},
|
|
91
|
+
noncov: {},
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
const bin = bins[epos];
|
|
95
|
+
if (bin) {
|
|
96
|
+
inc(bin, fstrand, 'cov', mod);
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
console.warn('Undefined position in modifications snpcoverage encountered');
|
|
100
|
+
}
|
|
78
101
|
}
|
|
79
102
|
}
|
|
80
103
|
}
|
|
81
|
-
}
|
|
104
|
+
}
|
|
82
105
|
}
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
else if ((colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) === 'methylation') {
|
|
86
|
-
if (!regionSeq) {
|
|
106
|
+
if ((colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) === 'methylation') {
|
|
107
|
+
if (!regionSequence) {
|
|
87
108
|
throw new Error('no region sequence detected, need sequenceAdapter configuration');
|
|
88
109
|
}
|
|
89
110
|
const seq = feature.get('seq');
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
const
|
|
108
|
-
const l2 = regionSeq[i + 1].toLowerCase();
|
|
109
|
-
const bin = bins[i];
|
|
110
|
-
const bin1 = bins[i + 1];
|
|
111
|
+
if (!seq) {
|
|
112
|
+
continue;
|
|
113
|
+
}
|
|
114
|
+
const { methBins, methProbs } = getMethBins(feature);
|
|
115
|
+
const dels = mismatches.filter(f => f.type === 'deletion');
|
|
116
|
+
// methylation based coloring takes into account both reference sequence
|
|
117
|
+
// CpG detection and reads
|
|
118
|
+
for (let i = 0; i < fend - fstart; i++) {
|
|
119
|
+
const j = i + fstart;
|
|
120
|
+
const l1 = (_b = regionSequence[j - region.start + 1]) === null || _b === void 0 ? void 0 : _b.toLowerCase();
|
|
121
|
+
const l2 = (_c = regionSequence[j - region.start + 2]) === null || _c === void 0 ? void 0 : _c.toLowerCase();
|
|
122
|
+
if (l1 === 'c' && l2 === 'g') {
|
|
123
|
+
const bin0 = bins[j - region.start];
|
|
124
|
+
const bin1 = bins[j - region.start + 1];
|
|
125
|
+
const b0 = methBins[i];
|
|
126
|
+
const b1 = methBins[i + 1];
|
|
127
|
+
const p0 = methProbs[i];
|
|
128
|
+
const p1 = methProbs[i + 1];
|
|
111
129
|
// color
|
|
112
|
-
if (
|
|
113
|
-
|
|
114
|
-
|
|
130
|
+
if ((b0 && (p0 !== undefined ? p0 > 0.5 : true)) ||
|
|
131
|
+
(b1 && (p1 !== undefined ? p1 > 0.5 : true))) {
|
|
132
|
+
if (bin0) {
|
|
133
|
+
inc(bin0, fstrand, 'cov', 'meth');
|
|
134
|
+
bin0.ref--;
|
|
135
|
+
bin0[fstrand]--;
|
|
136
|
+
}
|
|
137
|
+
if (bin1) {
|
|
115
138
|
inc(bin1, fstrand, 'cov', 'meth');
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
bins[i + 1].ref--;
|
|
119
|
-
bins[i + 1][fstrand]--;
|
|
139
|
+
bin1.ref--;
|
|
140
|
+
bin1[fstrand]--;
|
|
120
141
|
}
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
if (bin0) {
|
|
145
|
+
if (!(dels === null || dels === void 0 ? void 0 : dels.some(d => doesIntersect2(j, j + 1, d.start + fstart, d.start + fstart + d.length)))) {
|
|
146
|
+
inc(bin0, fstrand, 'cov', 'unmeth');
|
|
147
|
+
bin0.ref--;
|
|
148
|
+
bin0[fstrand];
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
if (bin1) {
|
|
152
|
+
if (!(dels === null || dels === void 0 ? void 0 : dels.some(d => doesIntersect2(j + 1, j + 2, d.start + fstart, d.start + fstart + d.length)))) {
|
|
153
|
+
inc(bin1, fstrand, 'cov', 'unmeth');
|
|
154
|
+
bin1.ref--;
|
|
155
|
+
bin1[fstrand]--;
|
|
156
|
+
}
|
|
128
157
|
}
|
|
129
158
|
}
|
|
130
159
|
}
|
|
131
160
|
}
|
|
132
161
|
}
|
|
133
162
|
// normal SNP based coloring
|
|
134
|
-
const mismatches = feature.get('mismatches') || [];
|
|
135
163
|
const colorSNPs = (colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) !== 'modifications' && (colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) !== 'methylation';
|
|
136
|
-
for (
|
|
137
|
-
const mismatch = mismatches[i];
|
|
164
|
+
for (const mismatch of mismatches) {
|
|
138
165
|
const mstart = fstart + mismatch.start;
|
|
139
166
|
const mlen = mismatchLen(mismatch);
|
|
140
167
|
const mend = mstart + mlen;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generateCoverageBins.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/generateCoverageBins.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,4BAA4B,EAAE,MAAM,SAAS,CAAA;AACzE,OAAO,EACL,UAAU,EACV,aAAa,EACb,wBAAwB,
|
|
1
|
+
{"version":3,"file":"generateCoverageBins.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/generateCoverageBins.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import AdapterType from '@jbrowse/core/pluggableElementTypes/AdapterType';
|
|
2
2
|
import configSchema from './configSchema';
|
|
3
|
-
import { capabilities } from './SNPCoverageAdapter';
|
|
4
3
|
export default function (pluginManager) {
|
|
5
4
|
pluginManager.addAdapterType(() => {
|
|
6
5
|
return new AdapterType({
|
|
@@ -11,7 +10,6 @@ export default function (pluginManager) {
|
|
|
11
10
|
},
|
|
12
11
|
getAdapterClass: () => import('./SNPCoverageAdapter').then(r => r.default),
|
|
13
12
|
configSchema,
|
|
14
|
-
adapterCapabilities: capabilities,
|
|
15
13
|
});
|
|
16
14
|
});
|
|
17
15
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,WAAW,MAAM,iDAAiD,CAAA;AACzE,OAAO,YAAY,MAAM,gBAAgB,CAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,WAAW,MAAM,iDAAiD,CAAA;AACzE,OAAO,YAAY,MAAM,gBAAgB,CAAA;AAEzC,MAAM,CAAC,OAAO,WAAW,aAA4B;IACnD,aAAa,CAAC,cAAc,CAAC,GAAG,EAAE;QAChC,OAAO,IAAI,WAAW,CAAC;YACrB,IAAI,EAAE,oBAAoB;YAC1B,WAAW,EAAE,qBAAqB;YAClC,eAAe,EAAE;gBACf,aAAa,EAAE,IAAI;aACpB;YACD,eAAe,EAAE,GAAG,EAAE,CACpB,MAAM,CAAC,sBAAsB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YACrD,YAAY;SACb,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export interface SkipMap {
|
|
2
|
+
[key: string]: {
|
|
3
|
+
score: number;
|
|
4
|
+
feature: unknown;
|
|
5
|
+
start: number;
|
|
6
|
+
end: number;
|
|
7
|
+
strand: number;
|
|
8
|
+
xs: string;
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
export interface BinType {
|
|
12
|
+
total?: number;
|
|
13
|
+
strands?: {
|
|
14
|
+
[key: string]: number;
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export interface Bin {
|
|
18
|
+
refbase?: string;
|
|
19
|
+
total: number;
|
|
20
|
+
all: number;
|
|
21
|
+
ref: number;
|
|
22
|
+
'-1': number;
|
|
23
|
+
'0': number;
|
|
24
|
+
'1': number;
|
|
25
|
+
lowqual: BinType;
|
|
26
|
+
cov: BinType;
|
|
27
|
+
delskips: BinType;
|
|
28
|
+
noncov: BinType;
|
|
29
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/util.ts"],"names":[],"mappings":""}
|
|
@@ -13,7 +13,7 @@ export interface RenderArgsDeserializedWithFeatures extends RenderArgsDeserializ
|
|
|
13
13
|
values: number[];
|
|
14
14
|
};
|
|
15
15
|
displayCrossHatches: boolean;
|
|
16
|
-
modificationTagMap?: Record<string, string>;
|
|
16
|
+
modificationTagMap?: Record<string, string | undefined>;
|
|
17
17
|
}
|
|
18
18
|
export default class SNPCoverageRenderer extends WiggleBaseRenderer {
|
|
19
19
|
draw(ctx: CanvasRenderingContext2D, props: RenderArgsDeserializedWithFeatures): Promise<void>;
|
|
@@ -46,10 +46,10 @@ export default class SNPCoverageRenderer extends WiggleBaseRenderer {
|
|
|
46
46
|
C: bases.C.main,
|
|
47
47
|
G: bases.G.main,
|
|
48
48
|
T: bases.T.main,
|
|
49
|
-
total: 'lightgrey',
|
|
50
49
|
insertion: 'purple',
|
|
51
50
|
softclip: 'blue',
|
|
52
51
|
hardclip: 'red',
|
|
52
|
+
total: readConfObject(cfg, 'color'),
|
|
53
53
|
meth: 'red',
|
|
54
54
|
unmeth: 'blue',
|
|
55
55
|
};
|
|
@@ -93,7 +93,7 @@ export default class SNPCoverageRenderer extends WiggleBaseRenderer {
|
|
|
93
93
|
ctx.fillStyle =
|
|
94
94
|
colorForBase[base] ||
|
|
95
95
|
modificationTagMap[base.replace('mod_', '')] ||
|
|
96
|
-
'
|
|
96
|
+
'black';
|
|
97
97
|
const height = toHeight(score);
|
|
98
98
|
const bottom = toY(score) + height;
|
|
99
99
|
ctx.fillRect(Math.round(leftPx), bottom - ((total + curr) / score) * height, w, (total / score) * height);
|