@jbrowse/plugin-alignments 2.5.0 → 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 -1
- package/dist/AlignmentsFeatureDetail/AlignmentsFeatureFlags.d.ts +2 -1
- package/dist/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js +2 -1
- package/dist/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js.map +1 -1
- package/dist/AlignmentsFeatureDetail/AlignmentsFeatureSuppAligns.d.ts +2 -1
- package/dist/BamAdapter/BamAdapter.d.ts +1 -1
- package/dist/BamAdapter/BamAdapter.js +25 -30
- package/dist/BamAdapter/BamAdapter.js.map +1 -1
- package/dist/BamAdapter/BamSlightlyLazyFeature.d.ts +1 -1
- package/dist/CramAdapter/CramAdapter.js +48 -46
- 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 +1 -1
- package/dist/CramAdapter/CramTestAdapters.js.map +1 -1
- package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.d.ts +2 -1
- package/dist/LinearAlignmentsDisplay/models/model.d.ts +16 -6
- package/dist/LinearAlignmentsDisplay/models/model.js +2 -1
- package/dist/LinearAlignmentsDisplay/models/model.js.map +1 -1
- package/dist/LinearPileupDisplay/components/ColorByModifications.d.ts +2 -1
- 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 -1
- 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 -2
- 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 -1
- package/dist/LinearPileupDisplay/components/SetMaxHeight.d.ts +2 -1
- package/dist/LinearPileupDisplay/components/SortByTag.d.ts +2 -1
- package/dist/LinearPileupDisplay/model.d.ts +101 -78
- package/dist/LinearPileupDisplay/model.js +161 -115
- package/dist/LinearPileupDisplay/model.js.map +1 -1
- package/dist/LinearReadArcsDisplay/components/ReactComponent.d.ts +2 -1
- package/dist/LinearReadArcsDisplay/components/ReactComponent.js +36 -39
- package/dist/LinearReadArcsDisplay/components/ReactComponent.js.map +1 -1
- package/dist/LinearReadArcsDisplay/configSchema.d.ts +0 -3
- package/dist/LinearReadArcsDisplay/drawFeats.d.ts +2 -15
- package/dist/LinearReadArcsDisplay/drawFeats.js +56 -64
- package/dist/LinearReadArcsDisplay/drawFeats.js.map +1 -1
- package/dist/LinearReadArcsDisplay/model.d.ts +52 -244
- 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 -1
- package/dist/LinearReadCloudDisplay/components/ReactComponent.js +34 -36
- package/dist/LinearReadCloudDisplay/components/ReactComponent.js.map +1 -1
- package/dist/LinearReadCloudDisplay/configSchema.d.ts +3 -1
- package/dist/LinearReadCloudDisplay/drawFeats.d.ts +2 -12
- 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 +60 -238
- 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 -1
- package/dist/LinearSNPCoverageDisplay/models/model.d.ts +134 -74
- 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/PileupRenderer.d.ts +4 -117
- package/dist/PileupRenderer/PileupRenderer.js +18 -761
- 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/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 +0 -2
- package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js +0 -3
- package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js.map +1 -1
- package/dist/SNPCoverageAdapter/generateCoverageBins.d.ts +3 -43
- package/dist/SNPCoverageAdapter/generateCoverageBins.js +72 -49
- 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 +5 -0
- 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 -11
- 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 -1
- package/esm/AlignmentsFeatureDetail/AlignmentsFeatureFlags.d.ts +2 -1
- package/esm/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js +3 -2
- package/esm/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js.map +1 -1
- package/esm/AlignmentsFeatureDetail/AlignmentsFeatureSuppAligns.d.ts +2 -1
- package/esm/BamAdapter/BamAdapter.d.ts +1 -1
- package/esm/BamAdapter/BamAdapter.js +25 -30
- package/esm/BamAdapter/BamAdapter.js.map +1 -1
- package/esm/BamAdapter/BamSlightlyLazyFeature.d.ts +1 -1
- package/esm/CramAdapter/CramAdapter.js +49 -47
- 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 +1 -1
- package/esm/CramAdapter/CramTestAdapters.js.map +1 -1
- package/esm/LinearAlignmentsDisplay/components/AlignmentsDisplay.d.ts +2 -1
- package/esm/LinearAlignmentsDisplay/models/model.d.ts +16 -6
- package/esm/LinearAlignmentsDisplay/models/model.js +2 -1
- package/esm/LinearAlignmentsDisplay/models/model.js.map +1 -1
- package/esm/LinearPileupDisplay/components/ColorByModifications.d.ts +2 -1
- 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 -1
- 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 -2
- 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 -1
- package/esm/LinearPileupDisplay/components/SetMaxHeight.d.ts +2 -1
- package/esm/LinearPileupDisplay/components/SortByTag.d.ts +2 -1
- package/esm/LinearPileupDisplay/model.d.ts +101 -78
- package/esm/LinearPileupDisplay/model.js +162 -116
- package/esm/LinearPileupDisplay/model.js.map +1 -1
- package/esm/LinearReadArcsDisplay/components/ReactComponent.d.ts +2 -1
- package/esm/LinearReadArcsDisplay/components/ReactComponent.js +13 -39
- package/esm/LinearReadArcsDisplay/components/ReactComponent.js.map +1 -1
- package/esm/LinearReadArcsDisplay/configSchema.d.ts +0 -3
- package/esm/LinearReadArcsDisplay/drawFeats.d.ts +2 -15
- package/esm/LinearReadArcsDisplay/drawFeats.js +54 -61
- package/esm/LinearReadArcsDisplay/drawFeats.js.map +1 -1
- package/esm/LinearReadArcsDisplay/model.d.ts +52 -244
- 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 -1
- package/esm/LinearReadCloudDisplay/components/ReactComponent.js +11 -36
- package/esm/LinearReadCloudDisplay/components/ReactComponent.js.map +1 -1
- package/esm/LinearReadCloudDisplay/configSchema.d.ts +3 -1
- package/esm/LinearReadCloudDisplay/drawFeats.d.ts +2 -12
- 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 +60 -238
- 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 -1
- package/esm/LinearSNPCoverageDisplay/models/model.d.ts +134 -74
- 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/PileupRenderer.d.ts +4 -117
- package/esm/PileupRenderer/PileupRenderer.js +20 -763
- 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/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 +0 -2
- package/esm/SNPCoverageAdapter/SNPCoverageAdapter.js +0 -2
- package/esm/SNPCoverageAdapter/SNPCoverageAdapter.js.map +1 -1
- package/esm/SNPCoverageAdapter/generateCoverageBins.d.ts +3 -43
- package/esm/SNPCoverageAdapter/generateCoverageBins.js +73 -50
- 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 +5 -0
- 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 -11
- 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/BamAdapter/BamAdapter.ts +41 -42
- package/src/CombinationTest.test.ts +2 -2
- package/src/CramAdapter/CramAdapter.ts +66 -55
- package/src/CramAdapter/CramSlightlyLazyFeature.ts +2 -5
- package/src/CramAdapter/CramTestAdapters.ts +1 -1
- package/src/LinearAlignmentsDisplay/models/model.tsx +5 -1
- 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/model.ts +199 -152
- package/src/LinearReadArcsDisplay/components/ReactComponent.tsx +23 -61
- package/src/LinearReadArcsDisplay/drawFeats.ts +77 -85
- 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 -167
- 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/PileupRenderer.ts +23 -1200
- 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 +0 -3
- package/src/SNPCoverageAdapter/generateCoverageBins.ts +111 -100
- 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
|
@@ -50,11 +50,11 @@ function FilterByTagDlg(props) {
|
|
|
50
50
|
const { model, handleClose } = props;
|
|
51
51
|
const { classes } = useStyles();
|
|
52
52
|
const { filterBy } = model;
|
|
53
|
-
const [flagInclude, setFlagInclude] = useState(filterBy
|
|
54
|
-
const [flagExclude, setFlagExclude] = useState(filterBy
|
|
55
|
-
const [tag, setTag] = useState(((_a = filterBy
|
|
56
|
-
const [tagValue, setTagValue] = useState(((_b = filterBy
|
|
57
|
-
const [readName, setReadName] = useState(
|
|
53
|
+
const [flagInclude, setFlagInclude] = useState(filterBy.flagInclude);
|
|
54
|
+
const [flagExclude, setFlagExclude] = useState(filterBy.flagExclude);
|
|
55
|
+
const [tag, setTag] = useState(((_a = filterBy.tagFilter) === null || _a === void 0 ? void 0 : _a.tag) || '');
|
|
56
|
+
const [tagValue, setTagValue] = useState(((_b = filterBy.tagFilter) === null || _b === void 0 ? void 0 : _b.value) || '');
|
|
57
|
+
const [readName, setReadName] = useState(filterBy.readName || '');
|
|
58
58
|
const validTag = tag.match(/^[A-Za-z][A-Za-z0-9]$/);
|
|
59
59
|
const site = 'https://broadinstitute.github.io/picard/explain-flags.html';
|
|
60
60
|
return (React.createElement(Dialog, { open: true, onClose: handleClose, title: "Filter options" },
|
|
@@ -76,16 +76,11 @@ function FilterByTagDlg(props) {
|
|
|
76
76
|
React.createElement(Typography, null, "Filter by tag name and value. Use * in the value field to get all reads containing any value for that tag. Example: filter tag name SA with value * to get all split/supplementary reads. Other examples include HP for haplotype, or RG for read group"),
|
|
77
77
|
React.createElement(TextField, { className: classes.field, value: tag, onChange: event => setTag(event.target.value), placeholder: "Enter tag name", inputProps: {
|
|
78
78
|
maxLength: 2,
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
React.createElement(TextField, { className: classes.field, value: tagValue, onChange: event => setTagValue(event.target.value), placeholder: "Enter tag value", inputProps: {
|
|
82
|
-
'data-testid': 'color-tag-name-input',
|
|
83
|
-
}, "data-testid": "color-tag-value" })),
|
|
79
|
+
}, error: tag.length === 2 && !validTag, helperText: tag.length === 2 && !validTag ? 'Not a valid tag' : '' }),
|
|
80
|
+
React.createElement(TextField, { className: classes.field, value: tagValue, onChange: event => setTagValue(event.target.value), placeholder: "Enter tag value" })),
|
|
84
81
|
React.createElement(Paper, { className: classes.paper, variant: "outlined" },
|
|
85
82
|
React.createElement(Typography, null, "Filter by read name"),
|
|
86
|
-
React.createElement(TextField, { className: classes.field, value: readName, onChange: event => setReadName(event.target.value), placeholder: "Enter read name",
|
|
87
|
-
'data-testid': 'color-tag-readname-input',
|
|
88
|
-
}, "data-testid": "color-tag-readname" })),
|
|
83
|
+
React.createElement(TextField, { className: classes.field, value: readName, onChange: event => setReadName(event.target.value), placeholder: "Enter read name" })),
|
|
89
84
|
React.createElement(DialogActions, null,
|
|
90
85
|
React.createElement(Button, { variant: "contained", color: "primary", autoFocus: true, type: "submit", onClick: () => {
|
|
91
86
|
model.setFilterBy({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FilterByTag.js","sourceRoot":"","sources":["../../src/shared/FilterByTag.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AACrC,OAAO,EACL,MAAM,EACN,aAAa,EACb,aAAa,EACb,IAAI,EACJ,KAAK,EACL,SAAS,EACT,UAAU,GACX,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACvC,KAAK,EAAE;QACL,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;QACzB,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;KACzB;IACD,KAAK,EAAE;QACL,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;KACzB;CACF,CAAC,CAAC,CAAA;AAEH,MAAM,SAAS,GAAG;IAChB,aAAa;IACb,4BAA4B;IAC5B,eAAe;IACf,eAAe;IACf,qBAAqB;IACrB,qBAAqB;IACrB,eAAe;IACf,gBAAgB;IAChB,uBAAuB;IACvB,2CAA2C;IAC3C,kCAAkC;IAClC,yBAAyB;CAC1B,CAAA;AAED,SAAS,OAAO,CAAC,KAA2C;IAC1D,MAAM,EAAE,IAAI,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,KAAK,CAAA;IACnC,OAAO,CACL;QACE,oBAAC,SAAS,IACR,IAAI,EAAC,QAAQ,EACb,KAAK,EAAE,IAAI,EACX,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,GAC/C;QACD,SAAS,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YAC7B,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,CAAC,IAAI,KAAK,CAAC,CAAA;YAC/B,MAAM,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,EAAE,CAAA;YAC5B,OAAO,CACL,6BAAK,GAAG,EAAE,GAAG;gBACX,+BACE,IAAI,EAAC,UAAU,EACf,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,EACrB,QAAQ,EAAE,KAAK,CAAC,EAAE;wBAChB,IAAI,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE;4BACxB,OAAO,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,CAAA;yBAC7B;6BAAM;4BACL,OAAO,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,CAAA;yBAC9B;oBACH,CAAC,GACD;gBACF,+BAAO,OAAO,EAAE,GAAG,IAAG,IAAI,CAAS,CAC/B,CACP,CAAA;QACH,CAAC,CAAC,CACD,CACJ,CAAA;AACH,CAAC;
|
|
1
|
+
{"version":3,"file":"FilterByTag.js","sourceRoot":"","sources":["../../src/shared/FilterByTag.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { getContainingView } from '@jbrowse/core/util';
|
|
2
|
+
import { createAutorun } from '../util';
|
|
3
|
+
import { fetchChains } from './fetchChains';
|
|
4
|
+
export function doAfterAttach(self, cb) {
|
|
5
|
+
createAutorun(self, async () => {
|
|
6
|
+
await fetchChains(self);
|
|
7
|
+
}, { delay: 1000 });
|
|
8
|
+
function draw(view) {
|
|
9
|
+
const canvas = self.ref;
|
|
10
|
+
if (!canvas) {
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
const ctx = canvas.getContext('2d');
|
|
14
|
+
if (!ctx) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
if (!self.chainData) {
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
ctx.clearRect(0, 0, canvas.width, self.height * 2);
|
|
21
|
+
ctx.resetTransform();
|
|
22
|
+
ctx.scale(2, 2);
|
|
23
|
+
cb(self, ctx, canvas.width, self.height);
|
|
24
|
+
self.setLastDrawnOffsetPx(view.offsetPx);
|
|
25
|
+
self.setLastDrawnBpPerPx(view.bpPerPx);
|
|
26
|
+
}
|
|
27
|
+
// first autorun instantly draws if bpPerPx changes
|
|
28
|
+
createAutorun(self, async () => {
|
|
29
|
+
const view = getContainingView(self);
|
|
30
|
+
if (view.bpPerPx !== self.lastDrawnBpPerPx) {
|
|
31
|
+
draw(view);
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
// second autorun draws after delay 1000 e.g. if offsetPx changes
|
|
35
|
+
createAutorun(self, async () => {
|
|
36
|
+
const view = getContainingView(self);
|
|
37
|
+
draw(view);
|
|
38
|
+
}, { delay: 1000 });
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=afterAttach.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"afterAttach.js","sourceRoot":"","sources":["../../src/shared/afterAttach.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAM3C,MAAM,UAAU,aAAa,CAC3B,IAAO,EACP,EAKS;IAET,aAAa,CACX,IAAI,EACJ,KAAK,IAAI,EAAE;QACT,MAAM,WAAW,CAAC,IAAI,CAAC,CAAA;IACzB,CAAC,EACD,EAAE,KAAK,EAAE,IAAI,EAAE,CAChB,CAAA;IAED,SAAS,IAAI,CAAC,IAAS;QACrB,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAA;QACvB,IAAI,CAAC,MAAM,EAAE;YACX,OAAM;SACP;QAED,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;QACnC,IAAI,CAAC,GAAG,EAAE;YACR,OAAM;SACP;QAED,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,OAAM;SACP;QAED,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QAClD,GAAG,CAAC,cAAc,EAAE,CAAA;QACpB,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;QACf,EAAE,CAAC,IAAI,EAAE,GAAG,EAAE,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;QACxC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QACxC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;IACxC,CAAC;IAED,mDAAmD;IACnD,aAAa,CAAC,IAAI,EAAE,KAAK,IAAI,EAAE;QAC7B,MAAM,IAAI,GAAG,iBAAiB,CAAC,IAAI,CAAQ,CAAA;QAC3C,IAAI,IAAI,CAAC,OAAO,KAAK,IAAI,CAAC,gBAAgB,EAAE;YAC1C,IAAI,CAAC,IAAI,CAAC,CAAA;SACX;IACH,CAAC,CAAC,CAAA;IAEF,iEAAiE;IACjE,aAAa,CACX,IAAI,EACJ,KAAK,IAAI,EAAE;QACT,MAAM,IAAI,GAAG,iBAAiB,CAAC,IAAI,CAAQ,CAAA;QAC3C,IAAI,CAAC,IAAI,CAAC,CAAA;IACZ,CAAC,EACD,EAAE,KAAK,EAAE,IAAI,EAAE,CAChB,CAAA;AACH,CAAC"}
|
package/esm/shared/color.d.ts
CHANGED
|
@@ -1,17 +1,55 @@
|
|
|
1
1
|
import { ChainStats } from './fetchChains';
|
|
2
|
-
export declare
|
|
2
|
+
export declare const fillColor: {
|
|
3
|
+
color_fwd_strand_not_proper: string;
|
|
4
|
+
color_rev_strand_not_proper: string;
|
|
5
|
+
color_fwd_strand: string;
|
|
6
|
+
color_rev_strand: string;
|
|
7
|
+
color_fwd_missing_mate: string;
|
|
8
|
+
color_rev_missing_mate: string;
|
|
9
|
+
color_fwd_diff_chr: string;
|
|
10
|
+
color_rev_diff_chr: string;
|
|
11
|
+
color_pair_lr: string;
|
|
12
|
+
color_pair_rr: string;
|
|
13
|
+
color_pair_rl: string;
|
|
14
|
+
color_pair_ll: string;
|
|
15
|
+
color_nostrand: string;
|
|
16
|
+
color_interchrom: string;
|
|
17
|
+
color_longinsert: string;
|
|
18
|
+
color_shortinsert: string;
|
|
19
|
+
color_unknown: string;
|
|
20
|
+
};
|
|
21
|
+
export declare const strokeColor: {
|
|
22
|
+
color_fwd_strand_not_proper: string;
|
|
23
|
+
color_rev_strand_not_proper: string;
|
|
24
|
+
color_fwd_strand: string;
|
|
25
|
+
color_rev_strand: string;
|
|
26
|
+
color_fwd_missing_mate: string;
|
|
27
|
+
color_rev_missing_mate: string;
|
|
28
|
+
color_fwd_diff_chr: string;
|
|
29
|
+
color_rev_diff_chr: string;
|
|
30
|
+
color_pair_lr: string;
|
|
31
|
+
color_pair_rr: string;
|
|
32
|
+
color_pair_rl: string;
|
|
33
|
+
color_pair_ll: string;
|
|
34
|
+
color_nostrand: string;
|
|
35
|
+
color_interchrom: string;
|
|
36
|
+
color_longinsert: string;
|
|
37
|
+
color_shortinsert: string;
|
|
38
|
+
color_unknown: string;
|
|
39
|
+
};
|
|
40
|
+
export declare function getPairedInsertSizeColor(f1: {
|
|
3
41
|
refName: string;
|
|
4
42
|
tlen?: number;
|
|
5
43
|
}, f2: {
|
|
6
44
|
refName: string;
|
|
7
|
-
}, stats?: ChainStats):
|
|
8
|
-
export declare function
|
|
45
|
+
}, stats?: ChainStats): readonly [string, string] | undefined;
|
|
46
|
+
export declare function getPairedInsertSizeAndOrientationColor(f1: {
|
|
9
47
|
refName: string;
|
|
10
48
|
pair_orientation?: string;
|
|
11
49
|
tlen?: number;
|
|
12
50
|
}, f2: {
|
|
13
51
|
refName: string;
|
|
14
|
-
}, stats?: ChainStats): string;
|
|
15
|
-
export declare function
|
|
52
|
+
}, stats?: ChainStats): readonly [string, string];
|
|
53
|
+
export declare function getPairedOrientationColor(f: {
|
|
16
54
|
pair_orientation?: string;
|
|
17
|
-
}): string;
|
|
55
|
+
}): readonly [string, string];
|
package/esm/shared/color.js
CHANGED
|
@@ -1,37 +1,71 @@
|
|
|
1
|
-
import { orientationTypes } from '../util';
|
|
2
|
-
const
|
|
1
|
+
import { orientationTypes, pairMap } from '../util';
|
|
2
|
+
export const fillColor = {
|
|
3
|
+
color_fwd_strand_not_proper: '#ECC8C8',
|
|
4
|
+
color_rev_strand_not_proper: '#BEBED8',
|
|
5
|
+
color_fwd_strand: '#EC8B8B',
|
|
6
|
+
color_rev_strand: '#8F8FD8',
|
|
7
|
+
color_fwd_missing_mate: '#D11919',
|
|
8
|
+
color_rev_missing_mate: '#1919D1',
|
|
9
|
+
color_fwd_diff_chr: '#000',
|
|
10
|
+
color_rev_diff_chr: '#969696',
|
|
3
11
|
color_pair_lr: '#c8c8c8',
|
|
4
12
|
color_pair_rr: 'navy',
|
|
5
13
|
color_pair_rl: 'teal',
|
|
6
14
|
color_pair_ll: 'green',
|
|
15
|
+
color_nostrand: '#c8c8c8',
|
|
16
|
+
color_interchrom: 'purple',
|
|
17
|
+
color_longinsert: 'red',
|
|
18
|
+
color_shortinsert: 'pink',
|
|
19
|
+
color_unknown: 'grey',
|
|
7
20
|
};
|
|
8
|
-
|
|
21
|
+
// manually calculated by running
|
|
22
|
+
// const color = require('color')
|
|
23
|
+
// Object.fromEntries(Object.entries(fillColor).map(([key,val])=>{
|
|
24
|
+
// return [key, color(val).darken('0.3').hex()]
|
|
25
|
+
// }))
|
|
26
|
+
// this avoids (expensive) use of Color module at runtime
|
|
27
|
+
export const strokeColor = {
|
|
28
|
+
color_fwd_strand_not_proper: '#CA6767',
|
|
29
|
+
color_rev_strand_not_proper: '#7272AA',
|
|
30
|
+
color_fwd_strand: '#DC2A2A',
|
|
31
|
+
color_rev_strand: '#4141BA',
|
|
32
|
+
color_fwd_missing_mate: '#921111',
|
|
33
|
+
color_rev_missing_mate: '#111192',
|
|
34
|
+
color_fwd_diff_chr: '#000000',
|
|
35
|
+
color_rev_diff_chr: '#696969',
|
|
36
|
+
color_pair_lr: '#8C8C8C',
|
|
37
|
+
color_pair_rr: '#00005A',
|
|
38
|
+
color_pair_rl: '#005A5A',
|
|
39
|
+
color_pair_ll: '#005A00',
|
|
40
|
+
color_nostrand: '#8C8C8C',
|
|
41
|
+
color_interchrom: '#5A005A',
|
|
42
|
+
color_longinsert: '#B30000',
|
|
43
|
+
color_shortinsert: '#FF3A5C',
|
|
44
|
+
color_unknown: 'grey',
|
|
45
|
+
};
|
|
46
|
+
export function getPairedInsertSizeColor(f1, f2, stats) {
|
|
9
47
|
const sameRef = f1.refName === f2.refName;
|
|
10
48
|
const tlen = Math.abs(f1.tlen || 0);
|
|
11
49
|
if (sameRef && tlen > ((stats === null || stats === void 0 ? void 0 : stats.upper) || 0)) {
|
|
12
|
-
return
|
|
50
|
+
return [fillColor.color_longinsert, strokeColor.color_longinsert];
|
|
13
51
|
}
|
|
14
52
|
else if (sameRef && tlen < ((stats === null || stats === void 0 ? void 0 : stats.lower) || 0)) {
|
|
15
|
-
return
|
|
53
|
+
return [fillColor.color_shortinsert, strokeColor.color_shortinsert];
|
|
16
54
|
}
|
|
17
55
|
else if (!sameRef) {
|
|
18
|
-
return
|
|
56
|
+
return [fillColor.color_interchrom, strokeColor.color_interchrom];
|
|
19
57
|
}
|
|
20
|
-
return
|
|
58
|
+
return undefined;
|
|
21
59
|
}
|
|
22
|
-
export function
|
|
23
|
-
return
|
|
60
|
+
export function getPairedInsertSizeAndOrientationColor(f1, f2, stats) {
|
|
61
|
+
return (getPairedInsertSizeColor(f1, f2, stats) || getPairedOrientationColor(f1));
|
|
24
62
|
}
|
|
25
|
-
export function
|
|
26
|
-
const type = orientationTypes
|
|
27
|
-
const
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
LL: 'color_pair_ll',
|
|
33
|
-
};
|
|
34
|
-
const val = map[orientation];
|
|
35
|
-
return alignmentColoring[val] || 'grey';
|
|
63
|
+
export function getPairedOrientationColor(f) {
|
|
64
|
+
const type = orientationTypes.fr;
|
|
65
|
+
const type2 = pairMap[type[f.pair_orientation || '']];
|
|
66
|
+
return [
|
|
67
|
+
fillColor[type2] || fillColor.color_unknown,
|
|
68
|
+
strokeColor[type2] || strokeColor.color_unknown,
|
|
69
|
+
];
|
|
36
70
|
}
|
|
37
71
|
//# sourceMappingURL=color.js.map
|
package/esm/shared/color.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"color.js","sourceRoot":"","sources":["../../src/shared/color.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"color.js","sourceRoot":"","sources":["../../src/shared/color.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { LinearReadArcsDisplayModel } from '../LinearReadArcsDisplay/model';
|
|
2
|
+
import { LinearReadCloudDisplayModel } from '../LinearReadCloudDisplay/model';
|
|
2
3
|
export interface ReducedFeature {
|
|
3
4
|
name: string;
|
|
4
5
|
strand: number;
|
|
@@ -24,4 +25,4 @@ export interface ChainData {
|
|
|
24
25
|
chains: ReducedFeature[][];
|
|
25
26
|
stats?: ChainStats;
|
|
26
27
|
}
|
|
27
|
-
export declare function fetchChains(self:
|
|
28
|
+
export declare function fetchChains(self: LinearReadArcsDisplayModel | LinearReadCloudDisplayModel): Promise<void>;
|
|
@@ -1,26 +1,20 @@
|
|
|
1
1
|
import { getContainingTrack, getContainingView, getSession, } from '@jbrowse/core/util';
|
|
2
2
|
import { getSnapshot } from 'mobx-state-tree';
|
|
3
3
|
export async function fetchChains(self) {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
return;
|
|
10
|
-
}
|
|
11
|
-
self.setLoading(true);
|
|
12
|
-
const ret = (await rpcManager.call(sessionId, 'PileupGetReducedFeatures', {
|
|
13
|
-
sessionId,
|
|
14
|
-
regions: view.staticBlocks.contentBlocks,
|
|
15
|
-
filterBy: getSnapshot(self.filterBy),
|
|
16
|
-
adapterConfig: self.adapterConfig,
|
|
17
|
-
}));
|
|
18
|
-
self.setChainData(ret);
|
|
19
|
-
self.setLoading(false);
|
|
20
|
-
}
|
|
21
|
-
catch (e) {
|
|
22
|
-
console.error(e);
|
|
23
|
-
self.setError(e);
|
|
4
|
+
const { rpcSessionId: sessionId } = getContainingTrack(self);
|
|
5
|
+
const { rpcManager } = getSession(self);
|
|
6
|
+
const view = getContainingView(self);
|
|
7
|
+
if (!view.initialized || self.error || self.regionTooLarge) {
|
|
8
|
+
return;
|
|
24
9
|
}
|
|
10
|
+
self.setLoading(true);
|
|
11
|
+
const ret = (await rpcManager.call(sessionId, 'PileupGetReducedFeatures', {
|
|
12
|
+
sessionId,
|
|
13
|
+
regions: view.staticBlocks.contentBlocks,
|
|
14
|
+
filterBy: getSnapshot(self.filterBy),
|
|
15
|
+
adapterConfig: self.adapterConfig,
|
|
16
|
+
}));
|
|
17
|
+
self.setChainData(ret);
|
|
18
|
+
self.setLoading(false);
|
|
25
19
|
}
|
|
26
20
|
//# sourceMappingURL=fetchChains.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetchChains.js","sourceRoot":"","sources":["../../src/shared/fetchChains.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,iBAAiB,EACjB,UAAU,GACX,MAAM,oBAAoB,CAAA;AAC3B,OAAO,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"fetchChains.js","sourceRoot":"","sources":["../../src/shared/fetchChains.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,iBAAiB,EACjB,UAAU,GACX,MAAM,oBAAoB,CAAA;AAC3B,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAA;AAmC7C,MAAM,CAAC,KAAK,UAAU,WAAW,CAC/B,IAA8D;IAE9D,MAAM,EAAE,YAAY,EAAE,SAAS,EAAE,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAA;IAC5D,MAAM,EAAE,UAAU,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,CAAA;IACvC,MAAM,IAAI,GAAG,iBAAiB,CAAC,IAAI,CAAQ,CAAA;IAE3C,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,cAAc,EAAE;QAC1D,OAAM;KACP;IAED,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;IACrB,MAAM,GAAG,GAAG,CAAC,MAAM,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,0BAA0B,EAAE;QACxE,SAAS;QACT,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa;QACxC,QAAQ,EAAE,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC;QACpC,aAAa,EAAE,IAAI,CAAC,aAAa;KAClC,CAAC,CAAc,CAAA;IAEhB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAA;IACtB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAA;AACxB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export declare function renderSvg<T extends {
|
|
3
|
+
id: string;
|
|
4
|
+
height: number;
|
|
5
|
+
}>(self: T, opts: {
|
|
6
|
+
rasterizeLayers?: boolean;
|
|
7
|
+
}, cb: (model: T, ctx: CanvasRenderingContext2D, width: number, height: number) => void): Promise<React.JSX.Element | undefined>;
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { getContainingView } from '@jbrowse/core/util';
|
|
3
|
+
// stabilize clipid under test for snapshot
|
|
4
|
+
function getId(id) {
|
|
5
|
+
const isJest = typeof jest === 'undefined';
|
|
6
|
+
return `arc-clip-${isJest ? id : 'jest'}`;
|
|
7
|
+
}
|
|
8
|
+
export async function renderSvg(self, opts, cb) {
|
|
9
|
+
const view = getContainingView(self);
|
|
10
|
+
const width = view.dynamicBlocks.totalWidthPx;
|
|
11
|
+
const height = self.height;
|
|
12
|
+
if (opts.rasterizeLayers) {
|
|
13
|
+
const canvas = document.createElement('canvas');
|
|
14
|
+
canvas.width = width * 2;
|
|
15
|
+
canvas.height = height * 2;
|
|
16
|
+
const ctx = canvas.getContext('2d');
|
|
17
|
+
if (!ctx) {
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
ctx.scale(2, 2);
|
|
21
|
+
cb(self, ctx, width, height);
|
|
22
|
+
return (React.createElement("image", { width: width, height: height, xlinkHref: canvas.toDataURL('image/png') }));
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
// @ts-ignore
|
|
26
|
+
const C2S = await import('canvas2svg');
|
|
27
|
+
const ctx = new C2S.default(width, height);
|
|
28
|
+
cb(self, ctx, width, height);
|
|
29
|
+
const clipid = getId(self.id);
|
|
30
|
+
return (React.createElement(React.Fragment, null,
|
|
31
|
+
React.createElement("defs", null,
|
|
32
|
+
React.createElement("clipPath", { id: clipid },
|
|
33
|
+
React.createElement("rect", { x: 0, y: 0, width: width, height: height }))),
|
|
34
|
+
React.createElement("g", {
|
|
35
|
+
/* eslint-disable-next-line react/no-danger */
|
|
36
|
+
dangerouslySetInnerHTML: { __html: ctx.getSvg().innerHTML }, clipPath: `url(#${clipid})` })));
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=renderSvg.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"renderSvg.js","sourceRoot":"","sources":["../../src/shared/renderSvg.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAA;AAGtD,2CAA2C;AAC3C,SAAS,KAAK,CAAC,EAAU;IACvB,MAAM,MAAM,GAAG,OAAO,IAAI,KAAK,WAAW,CAAA;IAC1C,OAAO,YAAY,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAA;AAC3C,CAAC;AAID,MAAM,CAAC,KAAK,UAAU,SAAS,CAC7B,IAAO,EACP,IAAmC,EACnC,EAKS;IAET,MAAM,IAAI,GAAG,iBAAiB,CAAC,IAAI,CAAQ,CAAA;IAC3C,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,CAAA;IAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAA;IAC1B,IAAI,IAAI,CAAC,eAAe,EAAE;QACxB,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;QAC/C,MAAM,CAAC,KAAK,GAAG,KAAK,GAAG,CAAC,CAAA;QACxB,MAAM,CAAC,MAAM,GAAG,MAAM,GAAG,CAAC,CAAA;QAC1B,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;QACnC,IAAI,CAAC,GAAG,EAAE;YACR,OAAM;SACP;QACD,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;QACf,EAAE,CAAC,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,CAAC,CAAA;QAC5B,OAAO,CACL,+BACE,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,MAAM,CAAC,SAAS,CAAC,WAAW,CAAC,GACxC,CACH,CAAA;KACF;SAAM;QACL,aAAa;QACb,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,YAAY,CAAC,CAAA;QACtC,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAA;QAC1C,EAAE,CAAC,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,CAAC,CAAA;QAC5B,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAC7B,OAAO,CACL;YACE;gBACE,kCAAU,EAAE,EAAE,MAAM;oBAClB,8BAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,GAAI,CACzC,CACN;YACP;gBACE,8CAA8C;gBAC9C,uBAAuB,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,CAAC,SAAS,EAAE,EAC3D,QAAQ,EAAE,QAAQ,MAAM,GAAG,GAC3B,CACD,CACJ,CAAA;KACF;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/shared/util.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,cAAc,CAAC,QAAmB;IAChD,KAAK,MAAM,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE;QACxC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,EAAE;YAClB,OAAO,IAAI,CAAA;SACZ;KACF;IACD,OAAO,KAAK,CAAA;AACd,CAAC"}
|
package/esm/util.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { BaseFeatureDataAdapter } from '@jbrowse/core/data_adapters/BaseAdapter';
|
|
2
|
-
import { Feature } from '@jbrowse/core/util
|
|
3
|
-
import {
|
|
2
|
+
import { Feature, AugmentedRegion } from '@jbrowse/core/util';
|
|
3
|
+
import { IAnyStateTreeNode } from 'mobx-state-tree';
|
|
4
|
+
import { IAutorunOptions } from 'mobx';
|
|
4
5
|
export declare function getTag(feature: Feature, tag: string): any;
|
|
5
6
|
export declare function getTagAlt(feature: Feature, tag: string, alt: string): any;
|
|
6
7
|
export declare const orientationTypes: {
|
|
@@ -14,6 +15,19 @@ export declare const orientationTypes: {
|
|
|
14
15
|
[key: string]: string;
|
|
15
16
|
};
|
|
16
17
|
};
|
|
18
|
+
export declare const pairMap: {
|
|
19
|
+
readonly LR: "color_pair_lr";
|
|
20
|
+
readonly LL: "color_pair_ll";
|
|
21
|
+
readonly RR: "color_pair_rr";
|
|
22
|
+
readonly RL: "color_pair_rl";
|
|
23
|
+
};
|
|
17
24
|
export declare function getColorWGBS(strand: number, base: string): "#f00" | "#00f" | "#888";
|
|
18
25
|
export declare function fetchSequence(region: AugmentedRegion, adapter: BaseFeatureDataAdapter): Promise<any>;
|
|
19
26
|
export declare function shouldFetchReferenceSequence(type?: string): boolean;
|
|
27
|
+
export declare const modificationColors: Record<string, string | undefined>;
|
|
28
|
+
type DisplayModel = IAnyStateTreeNode & {
|
|
29
|
+
setError: (arg: unknown) => void;
|
|
30
|
+
};
|
|
31
|
+
export declare function createAutorun(self: DisplayModel, cb: () => Promise<void>, opts?: IAutorunOptions): void;
|
|
32
|
+
export declare function randomColor(): string;
|
|
33
|
+
export {};
|
package/esm/util.js
CHANGED
|
@@ -1,15 +1,18 @@
|
|
|
1
1
|
import { toArray } from 'rxjs/operators';
|
|
2
2
|
import { firstValueFrom } from 'rxjs';
|
|
3
|
+
import { addDisposer, isAlive } from 'mobx-state-tree';
|
|
4
|
+
import { autorun } from 'mobx';
|
|
3
5
|
// get tag from BAM or CRAM feature, where CRAM uses feature.get('tags') and
|
|
4
6
|
// BAM does not
|
|
5
7
|
export function getTag(feature, tag) {
|
|
6
8
|
const tags = feature.get('tags');
|
|
7
|
-
return tags ? tags[tag] : feature.get(tag);
|
|
9
|
+
return tags !== undefined ? tags[tag] : feature.get(tag);
|
|
8
10
|
}
|
|
9
11
|
// use fallback alt tag, used in situations where upper case/lower case tags
|
|
10
12
|
// exist e.g. Mm/MM for base modifications
|
|
11
13
|
export function getTagAlt(feature, tag, alt) {
|
|
12
|
-
|
|
14
|
+
var _a;
|
|
15
|
+
return (_a = getTag(feature, tag)) !== null && _a !== void 0 ? _a : getTag(feature, alt);
|
|
13
16
|
}
|
|
14
17
|
// orientation definitions from igv.js, see also
|
|
15
18
|
// https://software.broadinstitute.org/software/igv/interpreting_pair_orientations
|
|
@@ -45,6 +48,12 @@ export const orientationTypes = {
|
|
|
45
48
|
F1F2: 'RL',
|
|
46
49
|
},
|
|
47
50
|
};
|
|
51
|
+
export const pairMap = {
|
|
52
|
+
LR: 'color_pair_lr',
|
|
53
|
+
LL: 'color_pair_ll',
|
|
54
|
+
RR: 'color_pair_rr',
|
|
55
|
+
RL: 'color_pair_rl',
|
|
56
|
+
};
|
|
48
57
|
export function getColorWGBS(strand, base) {
|
|
49
58
|
if (strand === 1) {
|
|
50
59
|
if (base === 'C') {
|
|
@@ -64,14 +73,17 @@ export function getColorWGBS(strand, base) {
|
|
|
64
73
|
}
|
|
65
74
|
return '#888';
|
|
66
75
|
}
|
|
76
|
+
// fetches region sequence augmenting by +/- 1bp for CpG on either side of
|
|
77
|
+
// requested region
|
|
67
78
|
export async function fetchSequence(region, adapter) {
|
|
68
79
|
var _a;
|
|
69
|
-
const { end, originalRefName, refName } = region;
|
|
80
|
+
const { start, end, originalRefName, refName } = region;
|
|
70
81
|
const feats = await firstValueFrom(adapter
|
|
71
82
|
.getFeatures({
|
|
72
83
|
...region,
|
|
73
84
|
refName: originalRefName || refName,
|
|
74
85
|
end: end + 1,
|
|
86
|
+
start: Math.max(0, start - 1),
|
|
75
87
|
})
|
|
76
88
|
.pipe(toArray()));
|
|
77
89
|
return (_a = feats[0]) === null || _a === void 0 ? void 0 : _a.get('seq');
|
|
@@ -80,4 +92,31 @@ export async function fetchSequence(region, adapter) {
|
|
|
80
92
|
export function shouldFetchReferenceSequence(type) {
|
|
81
93
|
return type === 'methylation';
|
|
82
94
|
}
|
|
95
|
+
// adapted from IGV
|
|
96
|
+
// https://github.com/igvteam/igv/blob/e803e3af2d8c9ea049961dfd4628146bdde9a574/src/main/java/org/broad/igv/sam/mods/BaseModificationColors.java#L27
|
|
97
|
+
export const modificationColors = {
|
|
98
|
+
m: 'rgb(255,0,0)',
|
|
99
|
+
h: 'rgb(11, 132, 165)',
|
|
100
|
+
o: 'rgb(111, 78, 129)',
|
|
101
|
+
f: 'rgb(246, 200, 95)',
|
|
102
|
+
c: 'rgb(157, 216, 102)',
|
|
103
|
+
g: 'rgb(255, 160, 86)',
|
|
104
|
+
e: 'rgb(141, 221, 208)',
|
|
105
|
+
b: 'rgb(202, 71, 47)',
|
|
106
|
+
};
|
|
107
|
+
export function createAutorun(self, cb, opts) {
|
|
108
|
+
addDisposer(self, autorun(async () => {
|
|
109
|
+
try {
|
|
110
|
+
await cb();
|
|
111
|
+
}
|
|
112
|
+
catch (e) {
|
|
113
|
+
if (isAlive(self)) {
|
|
114
|
+
self.setError(e);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}, opts));
|
|
118
|
+
}
|
|
119
|
+
export function randomColor() {
|
|
120
|
+
return `hsl(${Math.random() * 200}, 50%, 50%)`;
|
|
121
|
+
}
|
|
83
122
|
//# sourceMappingURL=util.js.map
|
package/esm/util.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.js","sourceRoot":"","sources":["../src/util.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../src/util.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@jbrowse/plugin-alignments",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.6.0",
|
|
4
4
|
"description": "JBrowse 2 alignments adapters, tracks, etc.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"jbrowse",
|
|
@@ -37,7 +37,7 @@
|
|
|
37
37
|
"clean": "rimraf dist esm *.tsbuildinfo"
|
|
38
38
|
},
|
|
39
39
|
"dependencies": {
|
|
40
|
-
"@gmod/bam": "^
|
|
40
|
+
"@gmod/bam": "^2.0.0",
|
|
41
41
|
"@gmod/cram": "^1.7.1",
|
|
42
42
|
"@mui/icons-material": "^5.0.1",
|
|
43
43
|
"canvas2svg": "^1.0.16",
|
|
@@ -65,5 +65,5 @@
|
|
|
65
65
|
"distModule": "esm/index.js",
|
|
66
66
|
"srcModule": "src/index.ts",
|
|
67
67
|
"module": "esm/index.js",
|
|
68
|
-
"gitHead": "
|
|
68
|
+
"gitHead": "9962c94711dd3386dcb76c16f3646937d9c4751a"
|
|
69
69
|
}
|
|
@@ -1,10 +1,8 @@
|
|
|
1
1
|
import React from 'react'
|
|
2
2
|
import { Checkbox, FormControlLabel, FormGroup } from '@mui/material'
|
|
3
3
|
import { makeStyles } from 'tss-react/mui'
|
|
4
|
-
import {
|
|
5
|
-
|
|
6
|
-
SimpleValue,
|
|
7
|
-
} from '@jbrowse/core/BaseFeatureWidget/BaseFeatureDetail'
|
|
4
|
+
import { BaseCard } from '@jbrowse/core/BaseFeatureWidget/BaseFeatureDetail'
|
|
5
|
+
import SimpleField from '@jbrowse/core/BaseFeatureWidget/BaseFeatureDetail/SimpleField'
|
|
8
6
|
|
|
9
7
|
const useStyles = makeStyles()({
|
|
10
8
|
compact: {
|
|
@@ -36,7 +34,7 @@ export default function AlignmentFlags(props: { feature: { flags: number } }) {
|
|
|
36
34
|
|
|
37
35
|
return (
|
|
38
36
|
<BaseCard {...props} title="Flags">
|
|
39
|
-
<
|
|
37
|
+
<SimpleField name="Flag" value={flags} />
|
|
40
38
|
<FormGroup>
|
|
41
39
|
{flagNames.map((name, idx) => {
|
|
42
40
|
const val = flags & (1 << idx)
|