@jbrowse/plugin-alignments 3.6.5 → 4.0.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.
Files changed (640) hide show
  1. package/esm/AlignmentsFeatureDetail/AlignmentsFeatureDetail.d.ts +1 -1
  2. package/esm/AlignmentsFeatureDetail/AlignmentsFeatureDetail.js +9 -9
  3. package/esm/AlignmentsFeatureDetail/BreakpointSplitViewChoiceDialog.d.ts +1 -0
  4. package/esm/AlignmentsFeatureDetail/BreakpointSplitViewChoiceDialog.js +1 -0
  5. package/esm/AlignmentsFeatureDetail/Flags.js +1 -1
  6. package/esm/AlignmentsFeatureDetail/Formatter.js +2 -2
  7. package/esm/AlignmentsFeatureDetail/LaunchPairedEndBreakpointSplitViewPanel.d.ts +2 -2
  8. package/esm/AlignmentsFeatureDetail/LaunchPairedEndBreakpointSplitViewPanel.js +7 -18
  9. package/esm/AlignmentsFeatureDetail/LaunchSupplementaryAlignmentBreakpointSplitViewPanel.d.ts +1 -1
  10. package/esm/AlignmentsFeatureDetail/LaunchSupplementaryAlignmentBreakpointSplitViewPanel.js +19 -37
  11. package/esm/AlignmentsFeatureDetail/LinkedPairedAlignments.d.ts +1 -1
  12. package/esm/AlignmentsFeatureDetail/LinkedPairedAlignments.js +1 -1
  13. package/esm/AlignmentsFeatureDetail/PairLink.d.ts +1 -1
  14. package/esm/AlignmentsFeatureDetail/PairLink.js +1 -1
  15. package/esm/AlignmentsFeatureDetail/SupplementaryAlignments.d.ts +1 -1
  16. package/esm/AlignmentsFeatureDetail/SupplementaryAlignments.js +2 -2
  17. package/esm/AlignmentsFeatureDetail/SupplementaryAlignmentsLocStrings.d.ts +1 -1
  18. package/esm/AlignmentsFeatureDetail/SupplementaryAlignmentsLocStrings.js +5 -4
  19. package/esm/AlignmentsFeatureDetail/configSchema.d.ts +1 -1
  20. package/esm/AlignmentsFeatureDetail/getSAFeatures.d.ts +1 -1
  21. package/esm/AlignmentsFeatureDetail/getSAFeatures.js +18 -17
  22. package/esm/AlignmentsFeatureDetail/index.js +3 -3
  23. package/esm/AlignmentsFeatureDetail/launchBreakpointSplitView.d.ts +6 -7
  24. package/esm/AlignmentsFeatureDetail/launchBreakpointSplitView.js +3 -6
  25. package/esm/AlignmentsFeatureDetail/stateModelFactory.d.ts +41 -41
  26. package/esm/AlignmentsFeatureDetail/stateModelFactory.js +1 -1
  27. package/esm/AlignmentsFeatureDetail/util.d.ts +1 -1
  28. package/esm/AlignmentsFeatureDetail/util.js +1 -2
  29. package/esm/AlignmentsTrack/configSchemaF.d.ts +16 -11
  30. package/esm/AlignmentsTrack/index.js +14 -2
  31. package/esm/BamAdapter/BamAdapter.d.ts +15 -26
  32. package/esm/BamAdapter/BamAdapter.js +84 -124
  33. package/esm/BamAdapter/BamSlightlyLazyFeature.d.ts +17 -10
  34. package/esm/BamAdapter/BamSlightlyLazyFeature.js +162 -45
  35. package/esm/BamAdapter/configSchema.d.ts +5 -10
  36. package/esm/BamAdapter/configSchema.js +2 -7
  37. package/esm/BamAdapter/forEachMismatchNumeric.d.ts +2 -0
  38. package/esm/BamAdapter/forEachMismatchNumeric.js +207 -0
  39. package/esm/BamAdapter/index.js +2 -2
  40. package/esm/CramAdapter/CramAdapter.d.ts +10 -32
  41. package/esm/CramAdapter/CramAdapter.js +93 -144
  42. package/esm/CramAdapter/CramSlightlyLazyFeature.d.ts +6 -2
  43. package/esm/CramAdapter/CramSlightlyLazyFeature.js +140 -18
  44. package/esm/CramAdapter/CramTestAdapters.d.ts +3 -2
  45. package/esm/CramAdapter/CramTestAdapters.js +8 -3
  46. package/esm/CramAdapter/configSchema.d.ts +2 -7
  47. package/esm/CramAdapter/configSchema.js +1 -6
  48. package/esm/CramAdapter/const.d.ts +12 -0
  49. package/esm/CramAdapter/const.js +12 -0
  50. package/esm/CramAdapter/index.js +2 -2
  51. package/esm/CramAdapter/readFeaturesToNumericCIGAR.d.ts +4 -0
  52. package/esm/CramAdapter/readFeaturesToNumericCIGAR.js +112 -0
  53. package/esm/HtsgetBamAdapter/HtsgetBamAdapter.d.ts +5 -9
  54. package/esm/HtsgetBamAdapter/HtsgetBamAdapter.js +13 -15
  55. package/esm/HtsgetBamAdapter/configSchema.d.ts +2 -7
  56. package/esm/HtsgetBamAdapter/configSchema.js +0 -5
  57. package/esm/HtsgetBamAdapter/index.js +2 -2
  58. package/esm/LinearAlignmentsDisplay/alignmentsModel.d.ts +9 -9
  59. package/esm/LinearAlignmentsDisplay/alignmentsModel.js +2 -2
  60. package/esm/LinearAlignmentsDisplay/components/AlignmentsDisplay.d.ts +1 -1
  61. package/esm/LinearAlignmentsDisplay/components/AlignmentsDisplay.js +19 -9
  62. package/esm/LinearAlignmentsDisplay/configSchema.d.ts +3 -3
  63. package/esm/LinearAlignmentsDisplay/index.js +4 -4
  64. package/esm/LinearAlignmentsDisplay/model.d.ts +173 -48
  65. package/esm/LinearAlignmentsDisplay/model.js +60 -62
  66. package/esm/LinearAlignmentsDisplay/renderSvg.d.ts +14 -0
  67. package/esm/LinearAlignmentsDisplay/renderSvg.js +12 -0
  68. package/esm/LinearAlignmentsDisplay/util.js +2 -2
  69. package/esm/LinearPileupDisplay/SharedLinearPileupDisplayMixin.d.ts +1249 -124
  70. package/esm/LinearPileupDisplay/SharedLinearPileupDisplayMixin.js +120 -89
  71. package/esm/LinearPileupDisplay/components/ColorByTagDialog.js +1 -1
  72. package/esm/LinearPileupDisplay/components/GroupByDialog.d.ts +1 -1
  73. package/esm/LinearPileupDisplay/components/GroupByDialog.js +8 -8
  74. package/esm/LinearPileupDisplay/components/LinearPileupDisplayBlurb.d.ts +1 -1
  75. package/esm/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js +2 -3
  76. package/esm/LinearPileupDisplay/components/SetFeatureHeightDialog.js +1 -1
  77. package/esm/LinearPileupDisplay/components/SortByTagDialog.js +1 -1
  78. package/esm/LinearPileupDisplay/configSchema.d.ts +8 -8
  79. package/esm/LinearPileupDisplay/configSchema.js +2 -2
  80. package/esm/LinearPileupDisplay/doAfterAttach.d.ts +5 -3
  81. package/esm/LinearPileupDisplay/doAfterAttach.js +17 -25
  82. package/esm/LinearPileupDisplay/index.d.ts +3 -3
  83. package/esm/LinearPileupDisplay/index.js +6 -5
  84. package/esm/LinearPileupDisplay/model.d.ts +1293 -155
  85. package/esm/LinearPileupDisplay/model.js +74 -122
  86. package/esm/LinearPileupDisplay/sharedDoAfterAttach.d.ts +10 -0
  87. package/esm/LinearPileupDisplay/sharedDoAfterAttach.js +28 -0
  88. package/esm/LinearReadArcsDisplay/afterAttachRPC.d.ts +2 -0
  89. package/esm/LinearReadArcsDisplay/afterAttachRPC.js +21 -0
  90. package/esm/LinearReadArcsDisplay/chainToSimpleFeature.d.ts +3 -0
  91. package/esm/LinearReadArcsDisplay/chainToSimpleFeature.js +40 -0
  92. package/esm/LinearReadArcsDisplay/components/{ReactComponent.d.ts → LinearReadArcsReactComponent.d.ts} +1 -1
  93. package/esm/LinearReadArcsDisplay/components/{ReactComponent.js → LinearReadArcsReactComponent.js} +4 -4
  94. package/esm/LinearReadArcsDisplay/configSchema.d.ts +5 -5
  95. package/esm/LinearReadArcsDisplay/configSchema.js +1 -1
  96. package/esm/LinearReadArcsDisplay/index.js +5 -4
  97. package/esm/LinearReadArcsDisplay/model.d.ts +225 -69
  98. package/esm/LinearReadArcsDisplay/model.js +60 -121
  99. package/esm/LinearReadArcsDisplay/renderSvg.d.ts +3 -0
  100. package/esm/LinearReadArcsDisplay/renderSvg.js +39 -0
  101. package/esm/LinearReadCloudDisplay/afterAttachRPC.d.ts +2 -0
  102. package/esm/LinearReadCloudDisplay/afterAttachRPC.js +56 -0
  103. package/esm/LinearReadCloudDisplay/components/CloudYScaleBar.d.ts +8 -0
  104. package/esm/LinearReadCloudDisplay/components/CloudYScaleBar.js +27 -0
  105. package/{dist/LinearReadCloudDisplay/components/ReactComponent.d.ts → esm/LinearReadCloudDisplay/components/LinearReadCloudReactComponent.d.ts} +1 -1
  106. package/esm/LinearReadCloudDisplay/components/LinearReadCloudReactComponent.js +252 -0
  107. package/esm/LinearReadCloudDisplay/components/SetFeatureHeightDialog.js +24 -0
  108. package/esm/LinearReadCloudDisplay/configSchema.d.ts +28 -5
  109. package/esm/LinearReadCloudDisplay/configSchema.js +21 -0
  110. package/esm/LinearReadCloudDisplay/index.js +9 -5
  111. package/esm/LinearReadCloudDisplay/model.d.ts +343 -61
  112. package/esm/LinearReadCloudDisplay/model.js +237 -76
  113. package/esm/LinearReadCloudDisplay/renderSvg.d.ts +3 -0
  114. package/esm/LinearReadCloudDisplay/renderSvg.js +47 -0
  115. package/esm/LinearSNPCoverageDisplay/components/ArcTooltipContents.d.ts +4 -0
  116. package/esm/LinearSNPCoverageDisplay/components/ArcTooltipContents.js +6 -0
  117. package/esm/LinearSNPCoverageDisplay/components/FilterArcsByScoreDialog.d.ts +7 -0
  118. package/esm/LinearSNPCoverageDisplay/components/FilterArcsByScoreDialog.js +16 -0
  119. package/esm/LinearSNPCoverageDisplay/components/SNPCoverageDisplayComponent.d.ts +5 -0
  120. package/esm/LinearSNPCoverageDisplay/components/SNPCoverageDisplayComponent.js +9 -0
  121. package/esm/LinearSNPCoverageDisplay/components/SashimiArcs.d.ts +10 -0
  122. package/esm/LinearSNPCoverageDisplay/components/SashimiArcs.js +169 -0
  123. package/esm/LinearSNPCoverageDisplay/components/Tooltip.d.ts +9 -3
  124. package/esm/LinearSNPCoverageDisplay/components/Tooltip.js +31 -7
  125. package/esm/LinearSNPCoverageDisplay/components/TooltipContents.d.ts +13 -6
  126. package/esm/LinearSNPCoverageDisplay/components/TooltipContents.js +191 -35
  127. package/esm/LinearSNPCoverageDisplay/components/arcUtils.d.ts +18 -0
  128. package/esm/LinearSNPCoverageDisplay/components/arcUtils.js +42 -0
  129. package/esm/LinearSNPCoverageDisplay/components/renderSvg.d.ts +10 -0
  130. package/esm/LinearSNPCoverageDisplay/components/renderSvg.js +32 -0
  131. package/esm/LinearSNPCoverageDisplay/configSchema.d.ts +7 -7
  132. package/esm/LinearSNPCoverageDisplay/configSchema.js +2 -2
  133. package/esm/LinearSNPCoverageDisplay/index.js +5 -4
  134. package/esm/LinearSNPCoverageDisplay/model.d.ts +302 -59
  135. package/esm/LinearSNPCoverageDisplay/model.js +162 -66
  136. package/esm/MismatchParser/cigarToMismatches.d.ts +1 -1
  137. package/esm/MismatchParser/cigarToMismatches.js +6 -8
  138. package/esm/MismatchParser/cigarToMismatches2.d.ts +2 -0
  139. package/{dist/MismatchParser/cigarToMismatches.js → esm/MismatchParser/cigarToMismatches2.js} +23 -27
  140. package/esm/MismatchParser/getNextRefPos.d.ts +1 -1
  141. package/esm/MismatchParser/getNextRefPos.js +13 -11
  142. package/esm/MismatchParser/index.d.ts +6 -3
  143. package/esm/MismatchParser/index.js +49 -11
  144. package/esm/MismatchParser/mdToMismatches.d.ts +1 -1
  145. package/esm/MismatchParser/mdToMismatches.js +87 -53
  146. package/esm/MismatchParser/mdToMismatches2.d.ts +2 -0
  147. package/esm/MismatchParser/mdToMismatches2.js +96 -0
  148. package/esm/ModificationParser/detectSimplexModifications.d.ts +4 -0
  149. package/esm/ModificationParser/detectSimplexModifications.js +17 -0
  150. package/esm/ModificationParser/getMethBins.d.ts +1 -1
  151. package/esm/ModificationParser/getMethBins.js +5 -5
  152. package/esm/ModificationParser/getModPositions.d.ts +1 -1
  153. package/esm/ModificationParser/getModPositions.js +14 -17
  154. package/esm/ModificationParser/getModProbabilities.js +1 -1
  155. package/esm/ModificationParser/getModTypes.js +1 -1
  156. package/esm/PileupRPC/base.js +1 -2
  157. package/esm/PileupRPC/index.js +1 -2
  158. package/esm/PileupRPC/methods/GetGlobalValueForTag.d.ts +1 -1
  159. package/esm/PileupRPC/methods/GetGlobalValueForTag.js +3 -6
  160. package/esm/PileupRPC/methods/GetVisibleModifications.d.ts +6 -3
  161. package/esm/PileupRPC/methods/GetVisibleModifications.js +20 -10
  162. package/esm/PileupRPC/rpcMethods.d.ts +2 -3
  163. package/esm/PileupRPC/rpcMethods.js +2 -3
  164. package/esm/PileupRenderer/PileupLayoutSession.d.ts +9 -9
  165. package/esm/PileupRenderer/PileupLayoutSession.js +18 -5
  166. package/esm/PileupRenderer/PileupRenderer.d.ts +5 -42
  167. package/esm/PileupRenderer/PileupRenderer.js +25 -70
  168. package/esm/PileupRenderer/colorBy.js +2 -2
  169. package/esm/PileupRenderer/components/PileupRendering.d.ts +9 -16
  170. package/esm/PileupRenderer/components/PileupRendering.js +152 -105
  171. package/esm/PileupRenderer/components/PileupTooltip.d.ts +10 -0
  172. package/esm/PileupRenderer/components/PileupTooltip.js +12 -0
  173. package/esm/PileupRenderer/components/util.d.ts +7 -0
  174. package/esm/PileupRenderer/components/util.js +17 -0
  175. package/esm/PileupRenderer/configSchema.d.ts +14 -4
  176. package/esm/PileupRenderer/configSchema.js +11 -1
  177. package/esm/PileupRenderer/index.js +4 -4
  178. package/esm/PileupRenderer/layoutFeature.d.ts +4 -12
  179. package/esm/PileupRenderer/layoutFeature.js +13 -18
  180. package/esm/PileupRenderer/layoutFeatures.d.ts +2 -2
  181. package/esm/PileupRenderer/layoutFeatures.js +21 -16
  182. package/esm/PileupRenderer/makeImageData.d.ts +20 -14
  183. package/esm/PileupRenderer/makeImageData.js +96 -14
  184. package/esm/PileupRenderer/renderers/cigarUtil.d.ts +18 -0
  185. package/esm/PileupRenderer/renderers/cigarUtil.js +23 -0
  186. package/esm/PileupRenderer/{getAlignmentShapeColor.js → renderers/getAlignmentShapeColor.js} +2 -2
  187. package/esm/PileupRenderer/{renderAlignment.d.ts → renderers/renderAlignment.d.ts} +6 -3
  188. package/esm/PileupRenderer/{renderAlignment.js → renderers/renderAlignment.js} +31 -26
  189. package/esm/PileupRenderer/renderers/renderAlignmentShape.d.ts +10 -0
  190. package/esm/PileupRenderer/renderers/renderAlignmentShape.js +165 -0
  191. package/esm/PileupRenderer/{renderMethylation.d.ts → renderers/renderMethylation.d.ts} +8 -6
  192. package/esm/PileupRenderer/renderers/renderMethylation.js +97 -0
  193. package/esm/PileupRenderer/renderers/renderMismatchesCallback.d.ts +32 -0
  194. package/esm/PileupRenderer/renderers/renderMismatchesCallback.js +304 -0
  195. package/esm/PileupRenderer/renderers/renderModifications.d.ts +20 -0
  196. package/esm/PileupRenderer/renderers/renderModifications.js +99 -0
  197. package/{dist/PileupRenderer → esm/PileupRenderer/renderers}/renderPerBaseLettering.d.ts +2 -2
  198. package/esm/PileupRenderer/renderers/renderPerBaseLettering.js +59 -0
  199. package/{dist/PileupRenderer → esm/PileupRenderer/renderers}/renderPerBaseQuality.d.ts +3 -4
  200. package/esm/PileupRenderer/renderers/renderPerBaseQuality.js +48 -0
  201. package/{dist/PileupRenderer → esm/PileupRenderer/renderers}/renderSoftClipping.d.ts +2 -2
  202. package/esm/PileupRenderer/renderers/renderSoftClipping.js +75 -0
  203. package/esm/PileupRenderer/sortUtil.d.ts +2 -2
  204. package/esm/PileupRenderer/sortUtil.js +34 -22
  205. package/esm/PileupRenderer/types.d.ts +32 -1
  206. package/esm/PileupRenderer/types.js +71 -1
  207. package/esm/PileupRenderer/util.d.ts +1 -22
  208. package/esm/PileupRenderer/util.js +12 -38
  209. package/esm/RenderLinearReadArcsDisplayRPC/RenderLinearReadArcsDisplay.d.ts +34 -0
  210. package/esm/RenderLinearReadArcsDisplayRPC/RenderLinearReadArcsDisplay.js +49 -0
  211. package/esm/RenderLinearReadArcsDisplayRPC/drawFeatsRPC.d.ts +24 -0
  212. package/esm/RenderLinearReadArcsDisplayRPC/drawFeatsRPC.js +156 -0
  213. package/esm/RenderLinearReadArcsDisplayRPC/executeRenderLinearReadArcsDisplay.d.ts +6 -0
  214. package/esm/RenderLinearReadArcsDisplayRPC/executeRenderLinearReadArcsDisplay.js +105 -0
  215. package/{dist/GuessAlignmentsTypes → esm/RenderLinearReadArcsDisplayRPC}/index.d.ts +1 -1
  216. package/esm/RenderLinearReadArcsDisplayRPC/index.js +4 -0
  217. package/esm/RenderLinearReadCloudDisplayRPC/RenderLinearReadCloudDisplay.d.ts +43 -0
  218. package/esm/RenderLinearReadCloudDisplayRPC/RenderLinearReadCloudDisplay.js +49 -0
  219. package/esm/RenderLinearReadCloudDisplayRPC/drawChainsUtil.d.ts +82 -0
  220. package/esm/RenderLinearReadCloudDisplayRPC/drawChainsUtil.js +164 -0
  221. package/esm/RenderLinearReadCloudDisplayRPC/drawFeatsCloud.d.ts +17 -0
  222. package/esm/RenderLinearReadCloudDisplayRPC/drawFeatsCloud.js +53 -0
  223. package/esm/RenderLinearReadCloudDisplayRPC/drawFeatsCommon.d.ts +72 -0
  224. package/esm/RenderLinearReadCloudDisplayRPC/drawFeatsCommon.js +277 -0
  225. package/esm/RenderLinearReadCloudDisplayRPC/drawFeatsStack.d.ts +5 -0
  226. package/esm/RenderLinearReadCloudDisplayRPC/drawFeatsStack.js +16 -0
  227. package/esm/RenderLinearReadCloudDisplayRPC/drawLongReadChains.d.ts +27 -0
  228. package/esm/RenderLinearReadCloudDisplayRPC/drawLongReadChains.js +101 -0
  229. package/esm/RenderLinearReadCloudDisplayRPC/drawPairChains.d.ts +27 -0
  230. package/esm/RenderLinearReadCloudDisplayRPC/drawPairChains.js +95 -0
  231. package/esm/RenderLinearReadCloudDisplayRPC/executeRenderLinearReadCloudDisplay.d.ts +6 -0
  232. package/esm/RenderLinearReadCloudDisplayRPC/executeRenderLinearReadCloudDisplay.js +142 -0
  233. package/esm/RenderLinearReadCloudDisplayRPC/index.d.ts +2 -0
  234. package/esm/RenderLinearReadCloudDisplayRPC/index.js +4 -0
  235. package/esm/SNPCoverageAdapter/SNPCoverageAdapter.d.ts +18 -3
  236. package/esm/SNPCoverageAdapter/SNPCoverageAdapter.js +205 -37
  237. package/esm/SNPCoverageAdapter/configSchema.d.ts +6 -2
  238. package/esm/SNPCoverageAdapter/configSchema.js +4 -0
  239. package/esm/SNPCoverageAdapter/generateCoverageBinsPrefixSum.d.ts +26 -0
  240. package/esm/SNPCoverageAdapter/generateCoverageBinsPrefixSum.js +438 -0
  241. package/esm/SNPCoverageAdapter/index.js +2 -2
  242. package/esm/SNPCoverageAdapter/processDepthPrefixSum.d.ts +10 -0
  243. package/esm/SNPCoverageAdapter/processDepthPrefixSum.js +55 -0
  244. package/esm/SNPCoverageAdapter/processModifications.d.ts +1 -1
  245. package/esm/SNPCoverageAdapter/processModifications.js +34 -36
  246. package/esm/SNPCoverageAdapter/processReferenceCpGs.d.ts +2 -3
  247. package/esm/SNPCoverageAdapter/processReferenceCpGs.js +46 -44
  248. package/esm/SNPCoverageAdapter/util.d.ts +9 -5
  249. package/esm/SNPCoverageAdapter/util.js +48 -28
  250. package/esm/SNPCoverageRenderer/SNPCoverageRenderer.d.ts +14 -4
  251. package/esm/SNPCoverageRenderer/SNPCoverageRenderer.js +29 -8
  252. package/esm/SNPCoverageRenderer/WiggleRendering.d.ts +14 -0
  253. package/esm/SNPCoverageRenderer/WiggleRendering.js +33 -0
  254. package/esm/SNPCoverageRenderer/calculateModificationCounts.d.ts +20 -0
  255. package/esm/SNPCoverageRenderer/calculateModificationCounts.js +22 -0
  256. package/esm/SNPCoverageRenderer/components/SNPCoverageRendering.d.ts +18 -0
  257. package/esm/SNPCoverageRenderer/components/SNPCoverageRendering.js +114 -0
  258. package/esm/SNPCoverageRenderer/configSchema.d.ts +2 -2
  259. package/esm/SNPCoverageRenderer/index.js +4 -4
  260. package/esm/SNPCoverageRenderer/makeImage.d.ts +2 -2
  261. package/esm/SNPCoverageRenderer/makeImage.js +384 -201
  262. package/esm/SNPCoverageRenderer/types.d.ts +55 -5
  263. package/esm/SNPCoverageRenderer/types.js +103 -1
  264. package/esm/SVGErrorBox.d.ts +5 -0
  265. package/esm/SVGErrorBox.js +4 -0
  266. package/esm/index.d.ts +3 -3
  267. package/esm/index.js +23 -21
  268. package/esm/saveTrackFormats/sam.d.ts +6 -0
  269. package/esm/saveTrackFormats/sam.js +42 -0
  270. package/esm/shared/LinearReadArcsDisplaySettingsMixin.d.ts +14 -0
  271. package/esm/shared/LinearReadArcsDisplaySettingsMixin.js +33 -0
  272. package/esm/shared/LinearReadDisplayBaseMixin.d.ts +33 -0
  273. package/esm/shared/LinearReadDisplayBaseMixin.js +31 -0
  274. package/esm/shared/LinearReadDisplayWithLayoutMixin.d.ts +16 -0
  275. package/esm/shared/LinearReadDisplayWithLayoutMixin.js +29 -0
  276. package/esm/shared/LinearReadDisplayWithPairFiltersMixin.d.ts +11 -0
  277. package/esm/shared/LinearReadDisplayWithPairFiltersMixin.js +24 -0
  278. package/esm/shared/SharedModificationsMixin.d.ts +12 -0
  279. package/esm/shared/SharedModificationsMixin.js +40 -0
  280. package/esm/shared/afterAttach.d.ts +1 -1
  281. package/esm/shared/afterAttach.js +4 -7
  282. package/esm/shared/arcUtils.d.ts +20 -0
  283. package/esm/shared/arcUtils.js +73 -0
  284. package/{dist/LinearReadCloudDisplay/util.d.ts → esm/shared/canvasUtils.d.ts} +1 -1
  285. package/esm/{LinearReadCloudDisplay/util.js → shared/canvasUtils.js} +9 -14
  286. package/esm/shared/chevron.d.ts +1 -0
  287. package/esm/shared/chevron.js +24 -0
  288. package/esm/shared/color.d.ts +54 -11
  289. package/esm/shared/color.js +121 -25
  290. package/esm/shared/components/FilterByTagDialog.d.ts +1 -1
  291. package/esm/shared/components/FilterByTagDialog.js +4 -5
  292. package/esm/shared/components/SetFeatureHeightDialog.d.ts +10 -0
  293. package/esm/shared/components/SetFeatureHeightDialog.js +24 -0
  294. package/esm/{LinearPileupDisplay → shared}/components/SetMaxHeightDialog.js +3 -3
  295. package/esm/shared/components/SetModificationThresholdDialog.d.ts +10 -0
  296. package/esm/shared/components/SetModificationThresholdDialog.js +37 -0
  297. package/esm/shared/createRPCRenderingSetup.d.ts +37 -0
  298. package/esm/shared/createRPCRenderingSetup.js +82 -0
  299. package/esm/shared/decodeSeq.d.ts +2 -0
  300. package/esm/shared/decodeSeq.js +26 -0
  301. package/esm/shared/flatbushType.d.ts +25 -0
  302. package/esm/shared/flatbushType.js +1 -0
  303. package/esm/shared/forEachMismatchTypes.d.ts +18 -0
  304. package/esm/shared/forEachMismatchTypes.js +24 -0
  305. package/esm/shared/getMaximumModificationAtEachPosition.d.ts +1 -1
  306. package/esm/shared/getMaximumModificationAtEachPosition.js +6 -7
  307. package/esm/shared/getUniqueModifications.d.ts +9 -4
  308. package/esm/shared/getUniqueModifications.js +3 -2
  309. package/esm/shared/getUniqueTags.d.ts +2 -2
  310. package/esm/shared/getUniqueTags.js +2 -1
  311. package/{dist/PileupRPC/util.d.ts → esm/shared/insertSizeStats.d.ts} +2 -2
  312. package/esm/shared/insertSizeStats.js +23 -0
  313. package/esm/shared/legendUtils.d.ts +8 -0
  314. package/esm/shared/legendUtils.js +123 -0
  315. package/esm/shared/menuItems.d.ts +119 -0
  316. package/esm/shared/menuItems.js +252 -0
  317. package/esm/shared/modificationData.d.ts +6 -0
  318. package/esm/shared/modificationData.js +17 -0
  319. package/esm/shared/primaryStrand.d.ts +3 -0
  320. package/esm/shared/primaryStrand.js +22 -0
  321. package/esm/shared/samFlags.d.ts +12 -0
  322. package/esm/shared/samFlags.js +12 -0
  323. package/esm/shared/setupModificationsAutorun.d.ts +11 -0
  324. package/esm/shared/setupModificationsAutorun.js +27 -0
  325. package/esm/shared/types.d.ts +69 -6
  326. package/esm/shared/util.d.ts +54 -1
  327. package/esm/shared/util.js +122 -1
  328. package/esm/svgExportUtil.d.ts +9 -0
  329. package/esm/svgExportUtil.js +6 -0
  330. package/esm/util.d.ts +3 -8
  331. package/esm/util.js +8 -23
  332. package/package.json +33 -38
  333. package/dist/AlignmentsFeatureDetail/AlignmentsFeatureDetail.d.ts +0 -5
  334. package/dist/AlignmentsFeatureDetail/AlignmentsFeatureDetail.js +0 -63
  335. package/dist/AlignmentsFeatureDetail/BreakendMultiLevelOptionDialog.d.ts +0 -1
  336. package/dist/AlignmentsFeatureDetail/BreakendMultiLevelOptionDialog.js +0 -5
  337. package/dist/AlignmentsFeatureDetail/BreakendSingleLevelOptionDialog.d.ts +0 -1
  338. package/dist/AlignmentsFeatureDetail/BreakendSingleLevelOptionDialog.js +0 -5
  339. package/dist/AlignmentsFeatureDetail/Flags.d.ts +0 -3
  340. package/dist/AlignmentsFeatureDetail/Flags.js +0 -41
  341. package/dist/AlignmentsFeatureDetail/Formatter.d.ts +0 -3
  342. package/dist/AlignmentsFeatureDetail/Formatter.js +0 -23
  343. package/dist/AlignmentsFeatureDetail/LaunchPairedEndBreakpointSplitViewPanel.d.ts +0 -6
  344. package/dist/AlignmentsFeatureDetail/LaunchPairedEndBreakpointSplitViewPanel.js +0 -84
  345. package/dist/AlignmentsFeatureDetail/LaunchSupplementaryAlignmentBreakpointSplitViewPanel.d.ts +0 -6
  346. package/dist/AlignmentsFeatureDetail/LaunchSupplementaryAlignmentBreakpointSplitViewPanel.js +0 -107
  347. package/dist/AlignmentsFeatureDetail/LinkedPairedAlignments.d.ts +0 -6
  348. package/dist/AlignmentsFeatureDetail/LinkedPairedAlignments.js +0 -22
  349. package/dist/AlignmentsFeatureDetail/PairLink.d.ts +0 -5
  350. package/dist/AlignmentsFeatureDetail/PairLink.js +0 -12
  351. package/dist/AlignmentsFeatureDetail/SupplementaryAlignments.d.ts +0 -7
  352. package/dist/AlignmentsFeatureDetail/SupplementaryAlignments.js +0 -23
  353. package/dist/AlignmentsFeatureDetail/SupplementaryAlignmentsLocStrings.d.ts +0 -5
  354. package/dist/AlignmentsFeatureDetail/SupplementaryAlignmentsLocStrings.js +0 -29
  355. package/dist/AlignmentsFeatureDetail/configSchema.d.ts +0 -1
  356. package/dist/AlignmentsFeatureDetail/configSchema.js +0 -5
  357. package/dist/AlignmentsFeatureDetail/getSAFeatures.d.ts +0 -23
  358. package/dist/AlignmentsFeatureDetail/getSAFeatures.js +0 -36
  359. package/dist/AlignmentsFeatureDetail/index.d.ts +0 -2
  360. package/dist/AlignmentsFeatureDetail/index.js +0 -52
  361. package/dist/AlignmentsFeatureDetail/launchBreakpointSplitView.d.ts +0 -22
  362. package/dist/AlignmentsFeatureDetail/launchBreakpointSplitView.js +0 -49
  363. package/dist/AlignmentsFeatureDetail/stateModelFactory.d.ts +0 -103
  364. package/dist/AlignmentsFeatureDetail/stateModelFactory.js +0 -10
  365. package/dist/AlignmentsFeatureDetail/tagInfo.d.ts +0 -63
  366. package/dist/AlignmentsFeatureDetail/tagInfo.js +0 -66
  367. package/dist/AlignmentsFeatureDetail/util.d.ts +0 -6
  368. package/dist/AlignmentsFeatureDetail/util.js +0 -25
  369. package/dist/AlignmentsTrack/configSchemaF.d.ts +0 -79
  370. package/dist/AlignmentsTrack/configSchemaF.js +0 -11
  371. package/dist/AlignmentsTrack/index.d.ts +0 -2
  372. package/dist/AlignmentsTrack/index.js +0 -23
  373. package/dist/BamAdapter/BamAdapter.d.ts +0 -44
  374. package/dist/BamAdapter/BamAdapter.js +0 -181
  375. package/dist/BamAdapter/BamSlightlyLazyFeature.d.ts +0 -17
  376. package/dist/BamAdapter/BamSlightlyLazyFeature.js +0 -69
  377. package/dist/BamAdapter/configSchema.d.ts +0 -34
  378. package/dist/BamAdapter/configSchema.js +0 -58
  379. package/dist/BamAdapter/index.d.ts +0 -2
  380. package/dist/BamAdapter/index.js +0 -51
  381. package/dist/CramAdapter/CramAdapter.d.ts +0 -53
  382. package/dist/CramAdapter/CramAdapter.js +0 -228
  383. package/dist/CramAdapter/CramSlightlyLazyFeature.d.ts +0 -33
  384. package/dist/CramAdapter/CramSlightlyLazyFeature.js +0 -124
  385. package/dist/CramAdapter/CramTestAdapters.d.ts +0 -28
  386. package/dist/CramAdapter/CramTestAdapters.js +0 -85
  387. package/dist/CramAdapter/configSchema.d.ts +0 -27
  388. package/dist/CramAdapter/configSchema.js +0 -48
  389. package/dist/CramAdapter/index.d.ts +0 -2
  390. package/dist/CramAdapter/index.js +0 -51
  391. package/dist/CramAdapter/util.d.ts +0 -9
  392. package/dist/CramAdapter/util.js +0 -213
  393. package/dist/GuessAlignmentsTypes/index.js +0 -41
  394. package/dist/HtsgetBamAdapter/HtsgetBamAdapter.d.ts +0 -12
  395. package/dist/HtsgetBamAdapter/HtsgetBamAdapter.js +0 -27
  396. package/dist/HtsgetBamAdapter/configSchema.d.ts +0 -18
  397. package/dist/HtsgetBamAdapter/configSchema.js +0 -22
  398. package/dist/HtsgetBamAdapter/index.d.ts +0 -2
  399. package/dist/HtsgetBamAdapter/index.js +0 -54
  400. package/dist/LinearAlignmentsDisplay/alignmentsModel.d.ts +0 -12
  401. package/dist/LinearAlignmentsDisplay/alignmentsModel.js +0 -18
  402. package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.d.ts +0 -5
  403. package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.js +0 -31
  404. package/dist/LinearAlignmentsDisplay/configSchema.d.ts +0 -36
  405. package/dist/LinearAlignmentsDisplay/configSchema.js +0 -19
  406. package/dist/LinearAlignmentsDisplay/index.d.ts +0 -2
  407. package/dist/LinearAlignmentsDisplay/index.js +0 -24
  408. package/dist/LinearAlignmentsDisplay/model.d.ts +0 -126
  409. package/dist/LinearAlignmentsDisplay/model.js +0 -222
  410. package/dist/LinearAlignmentsDisplay/util.d.ts +0 -2
  411. package/dist/LinearAlignmentsDisplay/util.js +0 -9
  412. package/dist/LinearPileupDisplay/SharedLinearPileupDisplayMixin.d.ts +0 -394
  413. package/dist/LinearPileupDisplay/SharedLinearPileupDisplayMixin.js +0 -524
  414. package/dist/LinearPileupDisplay/components/ColorByTagDialog.d.ts +0 -11
  415. package/dist/LinearPileupDisplay/components/ColorByTagDialog.js +0 -20
  416. package/dist/LinearPileupDisplay/components/GroupByDialog.d.ts +0 -10
  417. package/dist/LinearPileupDisplay/components/GroupByDialog.js +0 -145
  418. package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.d.ts +0 -7
  419. package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js +0 -11
  420. package/dist/LinearPileupDisplay/components/SetFeatureHeightDialog.js +0 -26
  421. package/dist/LinearPileupDisplay/components/SetMaxHeightDialog.js +0 -28
  422. package/dist/LinearPileupDisplay/components/SortByTagDialog.d.ts +0 -7
  423. package/dist/LinearPileupDisplay/components/SortByTagDialog.js +0 -26
  424. package/dist/LinearPileupDisplay/configSchema.d.ts +0 -61
  425. package/dist/LinearPileupDisplay/configSchema.js +0 -40
  426. package/dist/LinearPileupDisplay/doAfterAttach.d.ts +0 -20
  427. package/dist/LinearPileupDisplay/doAfterAttach.js +0 -71
  428. package/dist/LinearPileupDisplay/index.d.ts +0 -5
  429. package/dist/LinearPileupDisplay/index.js +0 -32
  430. package/dist/LinearPileupDisplay/model.d.ts +0 -497
  431. package/dist/LinearPileupDisplay/model.js +0 -364
  432. package/dist/LinearReadArcsDisplay/components/ReactComponent.d.ts +0 -5
  433. package/dist/LinearReadArcsDisplay/components/ReactComponent.js +0 -23
  434. package/dist/LinearReadArcsDisplay/configSchema.d.ts +0 -61
  435. package/dist/LinearReadArcsDisplay/configSchema.js +0 -36
  436. package/dist/LinearReadArcsDisplay/drawFeats.d.ts +0 -2
  437. package/dist/LinearReadArcsDisplay/drawFeats.js +0 -152
  438. package/dist/LinearReadArcsDisplay/index.d.ts +0 -2
  439. package/dist/LinearReadArcsDisplay/index.js +0 -58
  440. package/dist/LinearReadArcsDisplay/model.d.ts +0 -196
  441. package/dist/LinearReadArcsDisplay/model.js +0 -280
  442. package/dist/LinearReadArcsDisplay/util.d.ts +0 -2
  443. package/dist/LinearReadArcsDisplay/util.js +0 -11
  444. package/dist/LinearReadCloudDisplay/components/ReactComponent.js +0 -23
  445. package/dist/LinearReadCloudDisplay/configSchema.d.ts +0 -48
  446. package/dist/LinearReadCloudDisplay/configSchema.js +0 -25
  447. package/dist/LinearReadCloudDisplay/drawFeats.d.ts +0 -2
  448. package/dist/LinearReadCloudDisplay/drawFeats.js +0 -27
  449. package/dist/LinearReadCloudDisplay/drawLongReadChains.d.ts +0 -11
  450. package/dist/LinearReadCloudDisplay/drawLongReadChains.js +0 -64
  451. package/dist/LinearReadCloudDisplay/drawPairChains.d.ts +0 -17
  452. package/dist/LinearReadCloudDisplay/drawPairChains.js +0 -94
  453. package/dist/LinearReadCloudDisplay/index.d.ts +0 -2
  454. package/dist/LinearReadCloudDisplay/index.js +0 -58
  455. package/dist/LinearReadCloudDisplay/model.d.ts +0 -175
  456. package/dist/LinearReadCloudDisplay/model.js +0 -198
  457. package/dist/LinearReadCloudDisplay/util.js +0 -32
  458. package/dist/LinearSNPCoverageDisplay/components/Tooltip.d.ts +0 -12
  459. package/dist/LinearSNPCoverageDisplay/components/Tooltip.js +0 -15
  460. package/dist/LinearSNPCoverageDisplay/components/TooltipContents.d.ts +0 -11
  461. package/dist/LinearSNPCoverageDisplay/components/TooltipContents.js +0 -48
  462. package/dist/LinearSNPCoverageDisplay/configSchema.d.ts +0 -80
  463. package/dist/LinearSNPCoverageDisplay/configSchema.js +0 -62
  464. package/dist/LinearSNPCoverageDisplay/index.d.ts +0 -2
  465. package/dist/LinearSNPCoverageDisplay/index.js +0 -24
  466. package/dist/LinearSNPCoverageDisplay/model.d.ts +0 -111
  467. package/dist/LinearSNPCoverageDisplay/model.js +0 -262
  468. package/dist/MismatchParser/cigarToMismatches.d.ts +0 -2
  469. package/dist/MismatchParser/getNextRefPos.d.ts +0 -4
  470. package/dist/MismatchParser/getNextRefPos.js +0 -38
  471. package/dist/MismatchParser/index.d.ts +0 -27
  472. package/dist/MismatchParser/index.js +0 -145
  473. package/dist/MismatchParser/mdToMismatches.d.ts +0 -2
  474. package/dist/MismatchParser/mdToMismatches.js +0 -74
  475. package/dist/ModificationParser/consts.d.ts +0 -1
  476. package/dist/ModificationParser/consts.js +0 -4
  477. package/dist/ModificationParser/getMethBins.d.ts +0 -7
  478. package/dist/ModificationParser/getMethBins.js +0 -49
  479. package/dist/ModificationParser/getModPositions.d.ts +0 -6
  480. package/dist/ModificationParser/getModPositions.js +0 -64
  481. package/dist/ModificationParser/getModProbabilities.d.ts +0 -2
  482. package/dist/ModificationParser/getModProbabilities.js +0 -34
  483. package/dist/ModificationParser/getModTypes.d.ts +0 -5
  484. package/dist/ModificationParser/getModTypes.js +0 -35
  485. package/dist/PileupRPC/base.d.ts +0 -8
  486. package/dist/PileupRPC/base.js +0 -20
  487. package/dist/PileupRPC/index.d.ts +0 -2
  488. package/dist/PileupRPC/index.js +0 -9
  489. package/dist/PileupRPC/methods/GetGlobalValueForTag.d.ts +0 -13
  490. package/dist/PileupRPC/methods/GetGlobalValueForTag.js +0 -29
  491. package/dist/PileupRPC/methods/GetReducedFeatures.d.ts +0 -37
  492. package/dist/PileupRPC/methods/GetReducedFeatures.js +0 -54
  493. package/dist/PileupRPC/methods/GetVisibleModifications.d.ts +0 -14
  494. package/dist/PileupRPC/methods/GetVisibleModifications.js +0 -36
  495. package/dist/PileupRPC/rpcMethods.d.ts +0 -3
  496. package/dist/PileupRPC/rpcMethods.js +0 -12
  497. package/dist/PileupRPC/util.js +0 -18
  498. package/dist/PileupRenderer/PileupLayoutSession.d.ts +0 -23
  499. package/dist/PileupRenderer/PileupLayoutSession.js +0 -35
  500. package/dist/PileupRenderer/PileupRenderer.d.ts +0 -48
  501. package/dist/PileupRenderer/PileupRenderer.js +0 -129
  502. package/dist/PileupRenderer/colorBy.d.ts +0 -7
  503. package/dist/PileupRenderer/colorBy.js +0 -61
  504. package/dist/PileupRenderer/components/PileupRendering.d.ts +0 -26
  505. package/dist/PileupRenderer/components/PileupRendering.js +0 -136
  506. package/dist/PileupRenderer/configSchema.d.ts +0 -62
  507. package/dist/PileupRenderer/configSchema.js +0 -71
  508. package/dist/PileupRenderer/getAlignmentShapeColor.js +0 -61
  509. package/dist/PileupRenderer/index.d.ts +0 -2
  510. package/dist/PileupRenderer/index.js +0 -20
  511. package/dist/PileupRenderer/layoutFeature.d.ts +0 -18
  512. package/dist/PileupRenderer/layoutFeature.js +0 -42
  513. package/dist/PileupRenderer/layoutFeatures.d.ts +0 -5
  514. package/dist/PileupRenderer/layoutFeatures.js +0 -29
  515. package/dist/PileupRenderer/makeImageData.d.ts +0 -14
  516. package/dist/PileupRenderer/makeImageData.js +0 -66
  517. package/dist/PileupRenderer/renderAlignment.d.ts +0 -13
  518. package/dist/PileupRenderer/renderAlignment.js +0 -81
  519. package/dist/PileupRenderer/renderAlignmentShape.d.ts +0 -7
  520. package/dist/PileupRenderer/renderAlignmentShape.js +0 -120
  521. package/dist/PileupRenderer/renderMethylation.d.ts +0 -12
  522. package/dist/PileupRenderer/renderMethylation.js +0 -60
  523. package/dist/PileupRenderer/renderMismatches.d.ts +0 -18
  524. package/dist/PileupRenderer/renderMismatches.js +0 -124
  525. package/dist/PileupRenderer/renderModifications.d.ts +0 -12
  526. package/dist/PileupRenderer/renderModifications.js +0 -44
  527. package/dist/PileupRenderer/renderPerBaseLettering.js +0 -42
  528. package/dist/PileupRenderer/renderPerBaseQuality.js +0 -35
  529. package/dist/PileupRenderer/renderSoftClipping.js +0 -59
  530. package/dist/PileupRenderer/sortUtil.d.ts +0 -3
  531. package/dist/PileupRenderer/sortUtil.js +0 -80
  532. package/dist/PileupRenderer/types.d.ts +0 -27
  533. package/dist/PileupRenderer/types.js +0 -2
  534. package/dist/PileupRenderer/util.d.ts +0 -28
  535. package/dist/PileupRenderer/util.js +0 -49
  536. package/dist/SNPCoverageAdapter/SNPCoverageAdapter.d.ts +0 -14
  537. package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js +0 -89
  538. package/dist/SNPCoverageAdapter/configSchema.d.ts +0 -7
  539. package/dist/SNPCoverageAdapter/configSchema.js +0 -11
  540. package/dist/SNPCoverageAdapter/generateCoverageBins.d.ts +0 -13
  541. package/dist/SNPCoverageAdapter/generateCoverageBins.js +0 -86
  542. package/dist/SNPCoverageAdapter/index.d.ts +0 -2
  543. package/dist/SNPCoverageAdapter/index.js +0 -54
  544. package/dist/SNPCoverageAdapter/processDepth.d.ts +0 -8
  545. package/dist/SNPCoverageAdapter/processDepth.js +0 -38
  546. package/dist/SNPCoverageAdapter/processMismatches.d.ts +0 -9
  547. package/dist/SNPCoverageAdapter/processMismatches.js +0 -58
  548. package/dist/SNPCoverageAdapter/processModifications.d.ts +0 -10
  549. package/dist/SNPCoverageAdapter/processModifications.js +0 -50
  550. package/dist/SNPCoverageAdapter/processReferenceCpGs.d.ts +0 -9
  551. package/dist/SNPCoverageAdapter/processReferenceCpGs.js +0 -63
  552. package/dist/SNPCoverageAdapter/util.d.ts +0 -10
  553. package/dist/SNPCoverageAdapter/util.js +0 -41
  554. package/dist/SNPCoverageRenderer/SNPCoverageRenderer.d.ts +0 -5
  555. package/dist/SNPCoverageRenderer/SNPCoverageRenderer.js +0 -46
  556. package/dist/SNPCoverageRenderer/configSchema.d.ts +0 -33
  557. package/dist/SNPCoverageRenderer/configSchema.js +0 -37
  558. package/dist/SNPCoverageRenderer/index.d.ts +0 -2
  559. package/dist/SNPCoverageRenderer/index.js +0 -17
  560. package/dist/SNPCoverageRenderer/makeImage.d.ts +0 -2
  561. package/dist/SNPCoverageRenderer/makeImage.js +0 -259
  562. package/dist/SNPCoverageRenderer/types.d.ts +0 -20
  563. package/dist/SNPCoverageRenderer/types.js +0 -2
  564. package/dist/index.d.ts +0 -9
  565. package/dist/index.js +0 -89
  566. package/dist/shared/afterAttach.d.ts +0 -2
  567. package/dist/shared/afterAttach.js +0 -40
  568. package/dist/shared/color.d.ts +0 -58
  569. package/dist/shared/color.js +0 -79
  570. package/dist/shared/components/BaseDisplayComponent.d.ts +0 -7
  571. package/dist/shared/components/BaseDisplayComponent.js +0 -44
  572. package/dist/shared/components/FilterByTagDialog.d.ts +0 -9
  573. package/dist/shared/components/FilterByTagDialog.js +0 -88
  574. package/dist/shared/fetchChains.d.ts +0 -28
  575. package/dist/shared/fetchChains.js +0 -22
  576. package/dist/shared/getMaximumModificationAtEachPosition.d.ts +0 -8
  577. package/dist/shared/getMaximumModificationAtEachPosition.js +0 -42
  578. package/dist/shared/getUniqueModifications.d.ts +0 -15
  579. package/dist/shared/getUniqueModifications.js +0 -22
  580. package/dist/shared/getUniqueTags.d.ts +0 -15
  581. package/dist/shared/getUniqueTags.js +0 -18
  582. package/dist/shared/renderSvgUtil.d.ts +0 -6
  583. package/dist/shared/renderSvgUtil.js +0 -66
  584. package/dist/shared/types.d.ts +0 -94
  585. package/dist/shared/types.js +0 -2
  586. package/dist/shared/util.d.ts +0 -20
  587. package/dist/shared/util.js +0 -63
  588. package/dist/util.d.ts +0 -30
  589. package/dist/util.js +0 -125
  590. package/esm/AlignmentsFeatureDetail/BreakendMultiLevelOptionDialog.d.ts +0 -1
  591. package/esm/AlignmentsFeatureDetail/BreakendMultiLevelOptionDialog.js +0 -1
  592. package/esm/AlignmentsFeatureDetail/BreakendSingleLevelOptionDialog.d.ts +0 -1
  593. package/esm/AlignmentsFeatureDetail/BreakendSingleLevelOptionDialog.js +0 -1
  594. package/esm/CramAdapter/util.d.ts +0 -9
  595. package/esm/CramAdapter/util.js +0 -209
  596. package/esm/LinearPileupDisplay/components/SetMaxHeightDialog.d.ts +0 -8
  597. package/esm/LinearReadArcsDisplay/drawFeats.d.ts +0 -2
  598. package/esm/LinearReadArcsDisplay/drawFeats.js +0 -149
  599. package/esm/LinearReadArcsDisplay/util.d.ts +0 -2
  600. package/esm/LinearReadArcsDisplay/util.js +0 -8
  601. package/esm/LinearReadCloudDisplay/components/ReactComponent.d.ts +0 -5
  602. package/esm/LinearReadCloudDisplay/components/ReactComponent.js +0 -18
  603. package/esm/LinearReadCloudDisplay/drawFeats.d.ts +0 -2
  604. package/esm/LinearReadCloudDisplay/drawFeats.js +0 -24
  605. package/esm/LinearReadCloudDisplay/drawLongReadChains.d.ts +0 -11
  606. package/esm/LinearReadCloudDisplay/drawLongReadChains.js +0 -61
  607. package/esm/LinearReadCloudDisplay/drawPairChains.d.ts +0 -17
  608. package/esm/LinearReadCloudDisplay/drawPairChains.js +0 -90
  609. package/esm/LinearReadCloudDisplay/util.d.ts +0 -2
  610. package/esm/PileupRPC/methods/GetReducedFeatures.d.ts +0 -37
  611. package/esm/PileupRPC/methods/GetReducedFeatures.js +0 -48
  612. package/esm/PileupRPC/util.d.ts +0 -8
  613. package/esm/PileupRPC/util.js +0 -14
  614. package/esm/PileupRenderer/getAlignmentShapeColor.d.ts +0 -10
  615. package/esm/PileupRenderer/renderAlignmentShape.d.ts +0 -7
  616. package/esm/PileupRenderer/renderAlignmentShape.js +0 -117
  617. package/esm/PileupRenderer/renderMethylation.js +0 -57
  618. package/esm/PileupRenderer/renderMismatches.d.ts +0 -18
  619. package/esm/PileupRenderer/renderMismatches.js +0 -121
  620. package/esm/PileupRenderer/renderModifications.d.ts +0 -12
  621. package/esm/PileupRenderer/renderModifications.js +0 -41
  622. package/esm/PileupRenderer/renderPerBaseLettering.d.ts +0 -14
  623. package/esm/PileupRenderer/renderPerBaseLettering.js +0 -39
  624. package/esm/PileupRenderer/renderPerBaseQuality.d.ts +0 -10
  625. package/esm/PileupRenderer/renderPerBaseQuality.js +0 -32
  626. package/esm/PileupRenderer/renderSoftClipping.d.ts +0 -13
  627. package/esm/PileupRenderer/renderSoftClipping.js +0 -56
  628. package/esm/SNPCoverageAdapter/generateCoverageBins.d.ts +0 -13
  629. package/esm/SNPCoverageAdapter/generateCoverageBins.js +0 -83
  630. package/esm/SNPCoverageAdapter/processDepth.d.ts +0 -8
  631. package/esm/SNPCoverageAdapter/processDepth.js +0 -35
  632. package/esm/SNPCoverageAdapter/processMismatches.d.ts +0 -9
  633. package/esm/SNPCoverageAdapter/processMismatches.js +0 -55
  634. package/esm/shared/components/BaseDisplayComponent.d.ts +0 -7
  635. package/esm/shared/components/BaseDisplayComponent.js +0 -42
  636. package/esm/shared/fetchChains.d.ts +0 -28
  637. package/esm/shared/fetchChains.js +0 -19
  638. /package/{dist/LinearPileupDisplay → esm/LinearReadCloudDisplay}/components/SetFeatureHeightDialog.d.ts +0 -0
  639. /package/{dist/PileupRenderer → esm/PileupRenderer/renderers}/getAlignmentShapeColor.d.ts +0 -0
  640. /package/{dist/LinearPileupDisplay → esm/shared}/components/SetMaxHeightDialog.d.ts +0 -0
@@ -0,0 +1,169 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useEffect, useMemo, useRef, useState } from 'react';
3
+ import BaseTooltip from '@jbrowse/core/ui/BaseTooltip';
4
+ import { getContainingTrack, getContainingView, getSession, isSessionModelWithWidgets, notEmpty, } from '@jbrowse/core/util';
5
+ import { observer } from 'mobx-react';
6
+ import ArcTooltipContents from "./ArcTooltipContents.js";
7
+ import { featureToArcData, getArcSelectedColor } from "./arcUtils.js";
8
+ const YSCALEBAR_LABEL_OFFSET = 5;
9
+ const SVGNS = 'http://www.w3.org/2000/svg';
10
+ const SashimiArcs = observer(function SashimiArcs({ model, }) {
11
+ const { showArcsSetting, height, skipFeatures } = model;
12
+ const view = getContainingView(model);
13
+ const { assemblyManager } = getSession(model);
14
+ const [hoverInfo, setHoverInfo] = useState(null);
15
+ const [selectedArcId, setSelectedArcId] = useState(null);
16
+ const svgRef = useRef(null);
17
+ const arcMapRef = useRef(new Map());
18
+ const pathMapRef = useRef(new Map());
19
+ const selectedArcIdRef = useRef(null);
20
+ selectedArcIdRef.current = selectedArcId;
21
+ const width = Math.round(view.dynamicBlocks.totalWidthPx);
22
+ const effectiveHeight = height - YSCALEBAR_LABEL_OFFSET * 2;
23
+ const { arcs, drawnAtBpPerPx, drawnAtOffsetPx } = useMemo(() => {
24
+ const currentOffsetPx = view.offsetPx;
25
+ const assembly = assemblyManager.get(view.assemblyNames[0]);
26
+ return {
27
+ arcs: assembly
28
+ ? skipFeatures
29
+ .map(f => featureToArcData(f, view, effectiveHeight, currentOffsetPx, assembly))
30
+ .filter(notEmpty)
31
+ : [],
32
+ drawnAtBpPerPx: view.bpPerPx,
33
+ drawnAtOffsetPx: currentOffsetPx,
34
+ };
35
+ }, [skipFeatures, view.bpPerPx, effectiveHeight]);
36
+ useEffect(() => {
37
+ const svg = svgRef.current;
38
+ if (!svg) {
39
+ return;
40
+ }
41
+ while (svg.firstChild) {
42
+ svg.firstChild.remove();
43
+ }
44
+ const arcMap = new Map();
45
+ const pathMap = new Map();
46
+ const handleMouseEnter = (event) => {
47
+ const target = event.currentTarget;
48
+ const id = target.dataset.id;
49
+ if (id) {
50
+ const arc = arcMap.get(id);
51
+ if (arc) {
52
+ setHoverInfo({ arc, x: event.clientX, y: event.clientY });
53
+ const isSelected = id === selectedArcIdRef.current;
54
+ target.setAttribute('opacity', '1');
55
+ target.setAttribute('stroke-width', String(arc.strokeWidth + (isSelected ? 4 : 2)));
56
+ }
57
+ }
58
+ };
59
+ const handleMouseLeave = (event) => {
60
+ const target = event.currentTarget;
61
+ const id = target.dataset.id;
62
+ if (id) {
63
+ const arc = arcMap.get(id);
64
+ if (arc) {
65
+ const isSelected = id === selectedArcIdRef.current;
66
+ target.setAttribute('opacity', '0.7');
67
+ if (isSelected) {
68
+ target.setAttribute('stroke', getArcSelectedColor(arc.strand));
69
+ target.setAttribute('stroke-width', String(arc.strokeWidth + 3));
70
+ }
71
+ else {
72
+ target.setAttribute('stroke', arc.stroke);
73
+ target.setAttribute('stroke-width', String(arc.strokeWidth));
74
+ }
75
+ }
76
+ }
77
+ setHoverInfo(null);
78
+ };
79
+ const handleClick = (event) => {
80
+ const target = event.currentTarget;
81
+ const id = target.dataset.id;
82
+ if (id) {
83
+ setSelectedArcId(prev => (prev === id ? null : id));
84
+ const arc = arcMap.get(id);
85
+ if (arc) {
86
+ const session = getSession(model);
87
+ if (isSessionModelWithWidgets(session)) {
88
+ const featureWidget = session.addWidget('BaseFeatureWidget', 'baseFeature', {
89
+ featureData: {
90
+ uniqueId: arc.id,
91
+ refName: arc.refName,
92
+ start: arc.start,
93
+ end: arc.end,
94
+ type: 'junction',
95
+ strand: arc.strand,
96
+ score: arc.score,
97
+ length: arc.end - arc.start,
98
+ },
99
+ view: getContainingView(model),
100
+ track: getContainingTrack(model),
101
+ });
102
+ session.showWidget(featureWidget);
103
+ }
104
+ }
105
+ }
106
+ };
107
+ const sortedArcs = [...arcs].sort((a, b) => a.score - b.score);
108
+ for (const arc of sortedArcs) {
109
+ arcMap.set(arc.id, arc);
110
+ const path = document.createElementNS(SVGNS, 'path');
111
+ path.setAttribute('d', arc.path);
112
+ path.setAttribute('stroke', arc.stroke);
113
+ path.setAttribute('stroke-width', String(arc.strokeWidth));
114
+ path.setAttribute('fill', 'none');
115
+ path.setAttribute('opacity', '0.7');
116
+ path.setAttribute('pointer-events', 'stroke');
117
+ path.setAttribute('cursor', 'pointer');
118
+ path.dataset.id = arc.id;
119
+ path.addEventListener('mouseenter', handleMouseEnter);
120
+ path.addEventListener('mouseleave', handleMouseLeave);
121
+ path.addEventListener('click', handleClick);
122
+ pathMap.set(arc.id, path);
123
+ svg.append(path);
124
+ }
125
+ arcMapRef.current = arcMap;
126
+ pathMapRef.current = pathMap;
127
+ return () => {
128
+ while (svg.firstChild) {
129
+ const child = svg.firstChild;
130
+ child.removeEventListener('mouseenter', handleMouseEnter);
131
+ child.removeEventListener('mouseleave', handleMouseLeave);
132
+ child.removeEventListener('click', handleClick);
133
+ child.remove();
134
+ }
135
+ };
136
+ }, [arcs, model]);
137
+ useEffect(() => {
138
+ const pathMap = pathMapRef.current;
139
+ const arcMap = arcMapRef.current;
140
+ for (const [id, path] of pathMap) {
141
+ const arc = arcMap.get(id);
142
+ if (arc) {
143
+ if (id === selectedArcId) {
144
+ path.setAttribute('stroke', getArcSelectedColor(arc.strand));
145
+ path.setAttribute('stroke-width', String(arc.strokeWidth + 3));
146
+ }
147
+ else {
148
+ path.setAttribute('stroke', arc.stroke);
149
+ path.setAttribute('stroke-width', String(arc.strokeWidth));
150
+ }
151
+ }
152
+ }
153
+ }, [selectedArcId]);
154
+ if (!showArcsSetting ||
155
+ !view.initialized ||
156
+ drawnAtBpPerPx !== view.bpPerPx) {
157
+ return null;
158
+ }
159
+ const left = drawnAtOffsetPx - view.offsetPx;
160
+ return (_jsxs(_Fragment, { children: [_jsx("svg", { ref: svgRef, style: {
161
+ position: 'absolute',
162
+ top: YSCALEBAR_LABEL_OFFSET,
163
+ left,
164
+ pointerEvents: 'none',
165
+ height: effectiveHeight,
166
+ width,
167
+ } }), hoverInfo ? (_jsx(BaseTooltip, { clientPoint: { x: hoverInfo.x + 5, y: hoverInfo.y }, children: _jsx(ArcTooltipContents, { arc: hoverInfo.arc }) })) : null] }));
168
+ });
169
+ export default SashimiArcs;
@@ -1,12 +1,18 @@
1
1
  import type { Feature } from '@jbrowse/core/util';
2
- type Coord = [number, number];
3
2
  declare const SNPCoverageTooltip: (props: {
4
3
  model: {
5
4
  featureUnderMouse?: Feature;
5
+ mouseoverExtraInformation?: string;
6
+ visibleModifications: Map<string, {
7
+ color: string;
8
+ base: string;
9
+ strand: string;
10
+ }>;
11
+ simplexModifications?: Set<string>;
6
12
  };
7
13
  height: number;
8
- offsetMouseCoord: Coord;
9
- clientMouseCoord: Coord;
14
+ offsetMouseCoord: [number, number];
15
+ clientMouseCoord: [number, number];
10
16
  clientRect?: DOMRect;
11
17
  }) => import("react/jsx-runtime").JSX.Element | null;
12
18
  export default SNPCoverageTooltip;
@@ -1,10 +1,34 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { Tooltip } from '@jbrowse/plugin-wiggle';
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import BaseTooltip from '@jbrowse/core/ui/BaseTooltip';
3
+ import { makeStyles } from '@jbrowse/core/util/tss-react';
4
+ import { Tooltip, YSCALEBAR_LABEL_OFFSET } from '@jbrowse/plugin-wiggle';
3
5
  import { observer } from 'mobx-react';
4
- import TooltipContents from './TooltipContents';
5
- const SNPCoverageTooltip = observer(function (props) {
6
- const { model } = props;
7
- const { featureUnderMouse: feat } = model;
8
- return feat && feat.get('type') === 'skip' ? null : (_jsx(Tooltip, { TooltipContents: TooltipContents, ...props }));
6
+ import TooltipContents from "./TooltipContents.js";
7
+ const useStyles = makeStyles()(theme => ({
8
+ hoverVertical: {
9
+ background: theme.palette.text.primary,
10
+ border: 'none',
11
+ width: 1,
12
+ height: '100%',
13
+ top: YSCALEBAR_LABEL_OFFSET,
14
+ cursor: 'default',
15
+ position: 'absolute',
16
+ pointerEvents: 'none',
17
+ },
18
+ }));
19
+ const SNPCoverageTooltip = observer(function SNPCoverageTooltip(props) {
20
+ const { model, height, clientMouseCoord, offsetMouseCoord } = props;
21
+ const { featureUnderMouse: feat, mouseoverExtraInformation } = model;
22
+ const { classes } = useStyles();
23
+ if (mouseoverExtraInformation && !feat) {
24
+ const x = clientMouseCoord[0] + 5;
25
+ const y = clientMouseCoord[1];
26
+ const { item, refName } = JSON.parse(mouseoverExtraInformation);
27
+ return (_jsxs(_Fragment, { children: [_jsx(BaseTooltip, { clientPoint: { x, y }, children: _jsx(TooltipContents, { item: item, refName: refName, model: model }) }), _jsx("div", { className: classes.hoverVertical, style: {
28
+ left: offsetMouseCoord[0],
29
+ height: height - YSCALEBAR_LABEL_OFFSET * 2,
30
+ } })] }));
31
+ }
32
+ return feat?.get('type') === 'skip' ? null : (_jsx(Tooltip, { TooltipContents: TooltipContents, ...props }));
9
33
  });
10
34
  export default SNPCoverageTooltip;
@@ -1,11 +1,18 @@
1
+ import type { ClickMapItem } from '../../SNPCoverageRenderer/types.ts';
1
2
  import type { Feature } from '@jbrowse/core/util';
3
+ interface Model {
4
+ visibleModifications: Map<string, {
5
+ color: string;
6
+ base: string;
7
+ strand: string;
8
+ }>;
9
+ simplexModifications?: Set<string>;
10
+ }
2
11
  interface Props {
3
- feature: Feature;
4
- model: {
5
- visibleModifications: Map<string, {
6
- color: string;
7
- }>;
8
- };
12
+ feature?: Feature;
13
+ item?: ClickMapItem;
14
+ refName?: string;
15
+ model: Model;
9
16
  }
10
17
  declare const TooltipContents: import("react").ForwardRefExoticComponent<Props & import("react").RefAttributes<HTMLDivElement>>;
11
18
  export default TooltipContents;
@@ -1,46 +1,202 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
2
  import { forwardRef } from 'react';
3
- import { toLocale } from '@jbrowse/core/util';
4
- import { makeStyles } from 'tss-react/mui';
3
+ import { reducePrecision, toLocale } from '@jbrowse/core/util';
4
+ import { makeStyles } from '@jbrowse/core/util/tss-react';
5
+ import { getInterbaseTypeLabel } from "../../SNPCoverageRenderer/types.js";
6
+ import { getModificationName } from "../../shared/modificationData.js";
5
7
  const useStyles = makeStyles()(() => ({
6
8
  td: {
7
9
  whiteSpace: 'nowrap',
8
10
  },
9
11
  }));
10
- const toP = (s = 0) => +(+s).toFixed(1);
11
- const pct = (n, total = 1) => `${toP((n / (total || 1)) * 100)}%`;
12
- function ColorSquare({ base, model, }) {
13
- var _a;
14
- const { visibleModifications } = model;
15
- return base.startsWith('mod_') ? (_jsx("div", { style: {
16
- width: 10,
17
- height: 10,
18
- background: (_a = visibleModifications.get(base.replace('mod_', ''))) === null || _a === void 0 ? void 0 : _a.color,
19
- } })) : null;
12
+ function pct(n, total = 1) {
13
+ return `${((n / (total || 1)) * 100).toFixed(1)}%`;
14
+ }
15
+ function formatStrandCounts(entry) {
16
+ const neg = entry['-1'] ? `${entry['-1']}(-)` : '';
17
+ const pos = entry['1'] ? `${entry['1']}(+)` : '';
18
+ return neg + pos || '-';
19
+ }
20
+ function getModificationColor(base, model) {
21
+ if (!base.startsWith('mod_') && !base.startsWith('nonmod_')) {
22
+ return undefined;
23
+ }
24
+ if (base.startsWith('nonmod_')) {
25
+ return 'blue';
26
+ }
27
+ return model.visibleModifications.get(base.replace(/^mod_/, ''))?.color;
28
+ }
29
+ function isModification(base) {
30
+ return base.startsWith('mod_') || base.startsWith('nonmod_');
31
+ }
32
+ function getModificationType(base) {
33
+ return base.replace(/^(mod_|nonmod_)/, '');
34
+ }
35
+ function shouldShowPercentage(base) {
36
+ return base !== 'depth' && base !== 'skip';
37
+ }
38
+ function getModificationLabel(base, model) {
39
+ if (base.startsWith('nonmod_')) {
40
+ return `Unmodified ${base.replace('nonmod_', '')}`;
41
+ }
42
+ const modType = getModificationType(base);
43
+ const mod = model.visibleModifications.get(modType);
44
+ return mod ? getModificationName(modType) : base.toUpperCase();
45
+ }
46
+ function ColorSquare({ base, model }) {
47
+ const color = getModificationColor(base, model);
48
+ if (!color) {
49
+ return null;
50
+ }
51
+ return _jsx("div", { style: { width: 10, height: 10, background: color } });
52
+ }
53
+ function TableHeader() {
54
+ return (_jsx("thead", { children: _jsxs("tr", { children: [_jsx("th", {}), _jsx("th", { children: "Base" }), _jsx("th", { children: "# of Reads" }), _jsx("th", { children: "% of Reads" }), _jsx("th", { children: "Strands" }), _jsx("th", { children: "Avg Prob" })] }) }));
55
+ }
56
+ function TotalRow({ readsCounted }) {
57
+ return (_jsxs("tr", { children: [_jsx("td", {}), _jsx("td", { children: "Total" }), _jsx("td", { children: readsCounted }), _jsx("td", {}), _jsx("td", {}), _jsx("td", {})] }));
58
+ }
59
+ function RefRow({ referenceBase, reference, readsCounted, }) {
60
+ return (_jsxs("tr", { children: [_jsx("td", {}), _jsxs("td", { children: ["REF ", referenceBase ? `(${referenceBase.toUpperCase()})` : ''] }), _jsx("td", { children: reference.entryDepth }), _jsx("td", { children: pct(reference.entryDepth, readsCounted) }), _jsx("td", { children: formatStrandCounts(reference) }), _jsx("td", {})] }));
61
+ }
62
+ function DuplexModificationRow({ base, score, readsCounted, model, tdClass, rowKey, }) {
63
+ return (_jsxs("tr", { children: [_jsx("td", { children: _jsx(ColorSquare, { model: model, base: base }) }), _jsx("td", { children: getModificationLabel(base, model) }), _jsx("td", { className: tdClass, children: score.entryDepth }), _jsx("td", { children: shouldShowPercentage(base)
64
+ ? pct(score.entryDepth, readsCounted)
65
+ : '---' }), _jsx("td", { children: formatStrandCounts(score) }), _jsx("td", { children: score.avgProbability !== undefined ? pct(score.avgProbability) : '' })] }, rowKey));
66
+ }
67
+ function SimplexOrRegularRow({ base, score, isMod, readsCounted, model, tdClass, rowKey, }) {
68
+ return (_jsxs("tr", { children: [_jsx("td", { children: _jsx(ColorSquare, { model: model, base: base }) }), _jsx("td", { children: isMod ? getModificationLabel(base, model) : base.toUpperCase() }), _jsx("td", { className: tdClass, children: score.entryDepth }), _jsx("td", { children: shouldShowPercentage(base)
69
+ ? pct(score.entryDepth, readsCounted)
70
+ : '---' }), _jsx("td", { children: formatStrandCounts(score) }), _jsx("td", { children: score.avgProbability !== undefined ? pct(score.avgProbability) : '' })] }, rowKey));
71
+ }
72
+ function ModificationRows({ info, readsCounted, model, tdClass, }) {
73
+ const consolidatedEntries = {};
74
+ for (const [key, entry] of Object.entries(info)) {
75
+ for (const [base, score] of Object.entries(entry)) {
76
+ const isNonmod = base.startsWith('nonmod_');
77
+ if (isNonmod) {
78
+ const modType = getModificationType(base);
79
+ const mod = model.visibleModifications.get(modType);
80
+ const genomicBase = mod?.base || 'X';
81
+ const consolidatedKey = `${key}_nonmod_${genomicBase}`;
82
+ if (!consolidatedEntries[consolidatedKey]) {
83
+ consolidatedEntries[consolidatedKey] = {
84
+ base: `nonmod_${genomicBase}`,
85
+ score: {
86
+ entryDepth: 0,
87
+ '1': 0,
88
+ '-1': 0,
89
+ avgProbability: 0,
90
+ },
91
+ isNonmod: true,
92
+ };
93
+ }
94
+ const consolidated = consolidatedEntries[consolidatedKey];
95
+ consolidated.score.entryDepth += score.entryDepth;
96
+ consolidated.score['1'] += score['1'];
97
+ consolidated.score['-1'] += score['-1'];
98
+ if (score.avgProbability !== undefined) {
99
+ const prevAvg = consolidated.score.avgProbability || 0;
100
+ const prevCount = consolidated.score.entryDepth - score.entryDepth;
101
+ consolidated.score.avgProbability =
102
+ prevCount > 0
103
+ ? (prevAvg * prevCount +
104
+ score.avgProbability * score.entryDepth) /
105
+ consolidated.score.entryDepth
106
+ : score.avgProbability;
107
+ }
108
+ }
109
+ else {
110
+ consolidatedEntries[`${key}_${base}`] = {
111
+ base,
112
+ score: { ...score },
113
+ isNonmod: false,
114
+ };
115
+ }
116
+ }
117
+ }
118
+ return (_jsx(_Fragment, { children: Object.entries(consolidatedEntries).map(([rowKey, { base, score, isNonmod }]) => {
119
+ const modType = getModificationType(base);
120
+ const isMod = isModification(base) || isNonmod;
121
+ const isSimplex = !isNonmod && isMod && model.simplexModifications?.has(modType);
122
+ const posStrandCount = score['1'] || 0;
123
+ const negStrandCount = score['-1'] || 0;
124
+ if (isNonmod) {
125
+ return (_jsx(SimplexOrRegularRow, { base: base, score: score, isMod: true, isSimplex: false, readsCounted: readsCounted, model: model, tdClass: tdClass, rowKey: rowKey }, rowKey));
126
+ }
127
+ if (isMod &&
128
+ !isSimplex &&
129
+ (posStrandCount > 0 || negStrandCount > 0)) {
130
+ return (_jsx(DuplexModificationRow, { base: base, score: score, posStrandCount: posStrandCount, negStrandCount: negStrandCount, readsCounted: readsCounted, model: model, tdClass: tdClass, rowKey: rowKey }, rowKey));
131
+ }
132
+ return (_jsx(SimplexOrRegularRow, { base: base, score: score, isMod: isMod, isSimplex: isSimplex, readsCounted: readsCounted, model: model, tdClass: tdClass, rowKey: rowKey }, rowKey));
133
+ }) }));
134
+ }
135
+ function formatLocation(refName, start, end) {
136
+ if (start === undefined) {
137
+ return refName || '';
138
+ }
139
+ const pos = end === undefined || start === end - 1
140
+ ? toLocale(start + 1)
141
+ : `${toLocale(start + 1)}..${toLocale(end)}`;
142
+ return refName ? `${refName}:${pos}` : pos;
143
+ }
144
+ function BinTooltip({ bin, location, model, tdClass, reactRef, }) {
145
+ const { refbase, readsCounted, ref, snps, mods, nonmods, delskips, noncov } = bin;
146
+ return (_jsx("div", { ref: reactRef, children: _jsxs("table", { children: [_jsx("caption", { children: location }), _jsx(TableHeader, {}), _jsxs("tbody", { children: [_jsx(TotalRow, { readsCounted: readsCounted }), _jsx(RefRow, { referenceBase: refbase, reference: ref, readsCounted: readsCounted }), _jsx(ModificationRows, { info: { snps, mods, nonmods, delskips, noncov }, readsCounted: readsCounted, model: model, tdClass: tdClass })] })] }) }));
147
+ }
148
+ function SimpleSNPTooltip({ item, location, tdClass, reactRef, }) {
149
+ const { base, count, total, refbase, avgQual, fwdCount, revCount } = item;
150
+ const mutation = refbase ? `${refbase}→${base}` : base;
151
+ return (_jsx("div", { ref: reactRef, children: _jsxs("table", { children: [_jsx("caption", { children: location }), _jsx("thead", { children: _jsxs("tr", { children: [_jsx("th", { children: "Base" }), _jsx("th", { children: "Count" }), _jsx("th", { children: "% of Reads" }), _jsx("th", { children: "Strands" }), _jsx("th", { children: "Qual" })] }) }), _jsx("tbody", { children: _jsxs("tr", { children: [_jsx("td", { children: mutation.toUpperCase() }), _jsx("td", { className: tdClass, children: count }), _jsx("td", { children: pct(count, total) }), _jsx("td", { children: `${fwdCount}(+) ${revCount}(-)` }), _jsx("td", { children: avgQual !== undefined ? reducePrecision(avgQual) : '' })] }) })] }) }));
152
+ }
153
+ function ModificationTooltip({ item, location, model, tdClass, reactRef, }) {
154
+ const { modType, base, count, total, avgProb, fwdCount, revCount, isUnmodified, } = item;
155
+ const color = isUnmodified
156
+ ? 'blue'
157
+ : model.visibleModifications.get(modType)?.color;
158
+ const label = isUnmodified
159
+ ? `Unmodified ${base}`
160
+ : getModificationName(modType) || `${modType} (${base})`;
161
+ return (_jsx("div", { ref: reactRef, children: _jsxs("table", { children: [_jsx("caption", { children: location }), _jsx("thead", { children: _jsxs("tr", { children: [_jsx("th", {}), _jsx("th", { children: "Modification" }), _jsx("th", { children: "Count" }), _jsx("th", { children: "% of Reads" }), _jsx("th", { children: "Strands" }), _jsx("th", { children: "Avg Prob" })] }) }), _jsx("tbody", { children: _jsxs("tr", { children: [_jsx("td", { children: color ? (_jsx("div", { style: { width: 10, height: 10, background: color } })) : null }), _jsx("td", { children: label }), _jsx("td", { className: tdClass, children: count }), _jsx("td", { children: pct(count, total) }), _jsx("td", { children: `${fwdCount}(+) ${revCount}(-)` }), _jsx("td", { children: avgProb !== undefined ? `${(avgProb * 100).toFixed(1)}%` : '' })] }) })] }) }));
162
+ }
163
+ function InterbaseTooltip({ item, location, tdClass, reactRef, }) {
164
+ const { type, count, total, avgLength, minLength, maxLength, topSequence } = item;
165
+ const sizeStr = minLength !== undefined && maxLength !== undefined
166
+ ? minLength === maxLength
167
+ ? `${minLength}bp`
168
+ : `${minLength}-${maxLength}bp (avg ${avgLength?.toFixed(1)}bp)`
169
+ : avgLength !== undefined
170
+ ? `avg ${avgLength.toFixed(1)}bp`
171
+ : '';
172
+ return (_jsx("div", { ref: reactRef, children: _jsxs("table", { children: [_jsx("caption", { children: location }), _jsx("thead", { children: _jsxs("tr", { children: [_jsx("th", { children: "Type" }), _jsx("th", { children: "Count" }), _jsx("th", { children: "% of Reads" }), _jsx("th", { children: "Size" })] }) }), _jsxs("tbody", { children: [_jsxs("tr", { children: [_jsx("td", { children: getInterbaseTypeLabel(type) }), _jsx("td", { className: tdClass, children: count }), _jsx("td", { children: pct(count, total) }), _jsx("td", { children: sizeStr })] }), topSequence ? (_jsx("tr", { children: _jsxs("td", { colSpan: 4, children: ["Most common sequence:", ' ', topSequence.length > 20
173
+ ? `${topSequence.slice(0, 20)}...`
174
+ : topSequence] }) })) : null] })] }) }));
20
175
  }
21
176
  const TooltipContents = forwardRef(function TooltipContents2(props, reactRef) {
22
- const { feature, model } = props;
177
+ const { feature, item, refName, model } = props;
23
178
  const { classes } = useStyles();
24
- const start = feature.get('start') + 1;
25
- const end = feature.get('end');
26
- const name = feature.get('refName');
27
- const { refbase, readsCounted, depth, ref, ...info } = feature.get('snpinfo');
28
- return (_jsx("div", { ref: reactRef, children: _jsxs("table", { children: [_jsx("caption", { children: [
29
- name,
30
- start === end
31
- ? toLocale(start)
32
- : `${toLocale(start)}..${toLocale(end)}`,
33
- ]
34
- .filter(f => !!f)
35
- .join(':') }), _jsx("thead", { children: _jsxs("tr", { children: [_jsx("th", {}), _jsx("th", { children: "Base" }), _jsx("th", { children: "Count" }), _jsx("th", { children: "% of Total" }), _jsx("th", { children: "Strands" })] }) }), _jsxs("tbody", { children: [_jsxs("tr", { children: [_jsx("td", {}), _jsx("td", { children: "Total" }), _jsx("td", { children: readsCounted }), _jsx("td", { children: " " }), _jsx("td", { children: " " })] }), _jsxs("tr", { children: [_jsx("td", {}), _jsxs("td", { children: ["REF ", refbase ? `(${refbase.toUpperCase()})` : ''] }), _jsx("td", { children: ref.entryDepth }), _jsx("td", { children: pct(ref.entryDepth, readsCounted) }), _jsxs("td", { children: [ref['-1'] ? `${ref['-1']}(-)` : '', ref['1'] ? `${ref['1']}(+)` : ''] })] }), Object.entries(info).map(([key, entry]) => Object.entries(entry).map(([base, score]) => (_jsxs("tr", { children: [_jsx("td", { children: _jsx(ColorSquare, { model: model, base: base }) }), _jsxs("td", { children: [base.toUpperCase(), " "] }), _jsx("td", { className: classes.td, children: [
36
- score.entryDepth,
37
- score.avgProbability !== undefined
38
- ? `(avg. ${pct(score.avgProbability)} prob.)`
39
- : '',
40
- ]
41
- .filter(f => !!f)
42
- .join(' ') }), _jsx("td", { children: base === 'depth' || base === 'skip'
43
- ? '---'
44
- : pct(score.entryDepth, readsCounted) }), _jsxs("td", { children: [score['-1'] ? `${score['-1']}(-)` : '', score['1'] ? `${score['1']}(+)` : ''] })] }, `${key}_${base}`))))] })] }) }));
179
+ if (item) {
180
+ const location = formatLocation(refName, item.start, 'end' in item ? item.end : undefined);
181
+ if (item.type === 'snp' && item.bin) {
182
+ return (_jsx(BinTooltip, { bin: item.bin, location: location, model: model, tdClass: classes.td, reactRef: reactRef }));
183
+ }
184
+ if (item.type === 'snp') {
185
+ return (_jsx(SimpleSNPTooltip, { item: item, location: location, tdClass: classes.td, reactRef: reactRef }));
186
+ }
187
+ if (item.type === 'modification') {
188
+ return (_jsx(ModificationTooltip, { item: item, location: location, model: model, tdClass: classes.td, reactRef: reactRef }));
189
+ }
190
+ return (_jsx(InterbaseTooltip, { item: item, location: location, tdClass: classes.td, reactRef: reactRef }));
191
+ }
192
+ if (feature) {
193
+ const start = feature.get('start');
194
+ const end = feature.get('end');
195
+ const name = feature.get('refName');
196
+ const snpinfo = feature.get('snpinfo');
197
+ const location = formatLocation(name, start, end);
198
+ return (_jsx(BinTooltip, { bin: snpinfo, location: location, model: model, tdClass: classes.td, reactRef: reactRef }));
199
+ }
200
+ return null;
45
201
  });
46
202
  export default TooltipContents;
@@ -0,0 +1,18 @@
1
+ import type { Assembly } from '@jbrowse/core/assemblyManager/assembly';
2
+ import type { Feature } from '@jbrowse/core/util';
3
+ import type { LinearGenomeViewModel } from '@jbrowse/plugin-linear-genome-view';
4
+ export interface ArcData {
5
+ id: string;
6
+ path: string;
7
+ stroke: string;
8
+ strokeWidth: number;
9
+ start: number;
10
+ end: number;
11
+ refName: string;
12
+ score: number;
13
+ strand: number;
14
+ }
15
+ export declare function getArcColor(strand: number): "rgba(255,170,170,0.7)" | "rgba(160,160,255,0.7)" | "rgba(200,200,200,0.7)";
16
+ export declare function getArcSelectedColor(strand: number): "rgba(255,100,100,1)" | "rgba(100,100,255,1)" | "rgba(120,120,120,1)";
17
+ export declare function getStrandLabel(strand: number): "-" | "+" | "unknown";
18
+ export declare function featureToArcData(feature: Feature, view: LinearGenomeViewModel, effectiveHeight: number, offsetPx: number, assembly: Assembly): ArcData | undefined;
@@ -0,0 +1,42 @@
1
+ export function getArcColor(strand) {
2
+ return strand === 1
3
+ ? 'rgba(255,170,170,0.7)'
4
+ : strand === -1
5
+ ? 'rgba(160,160,255,0.7)'
6
+ : 'rgba(200,200,200,0.7)';
7
+ }
8
+ export function getArcSelectedColor(strand) {
9
+ return strand === 1
10
+ ? 'rgba(255,100,100,1)'
11
+ : strand === -1
12
+ ? 'rgba(100,100,255,1)'
13
+ : 'rgba(120,120,120,1)';
14
+ }
15
+ export function getStrandLabel(strand) {
16
+ return strand === 1 ? '+' : strand === -1 ? '-' : 'unknown';
17
+ }
18
+ export function featureToArcData(feature, view, effectiveHeight, offsetPx, assembly) {
19
+ const start = feature.get('start');
20
+ const end = feature.get('end');
21
+ const refName = assembly.getCanonicalRefName2(feature.get('refName'));
22
+ const startPx = view.bpToPx({ refName, coord: start });
23
+ const endPx = view.bpToPx({ refName, coord: end });
24
+ if (startPx === undefined || endPx === undefined) {
25
+ return undefined;
26
+ }
27
+ const left = startPx.offsetPx - offsetPx;
28
+ const right = endPx.offsetPx - offsetPx;
29
+ const strand = feature.get('effectiveStrand') ?? 0;
30
+ const score = feature.get('score') ?? 1;
31
+ return {
32
+ id: feature.id(),
33
+ path: `M ${left} ${effectiveHeight * 0.9} C ${left} ${effectiveHeight * 0.1}, ${right} ${effectiveHeight * 0.1}, ${right} ${effectiveHeight * 0.9}`,
34
+ stroke: getArcColor(strand),
35
+ strokeWidth: Math.log(score + 1),
36
+ start,
37
+ end,
38
+ refName,
39
+ score,
40
+ strand,
41
+ };
42
+ }
@@ -0,0 +1,10 @@
1
+ import type { Feature } from '@jbrowse/core/util';
2
+ import type { ExportSvgDisplayOptions } from '@jbrowse/plugin-linear-genome-view';
3
+ interface SNPCoverageDisplayModel {
4
+ id: string;
5
+ skipFeatures: Feature[];
6
+ height: number;
7
+ showArcsSetting: boolean;
8
+ }
9
+ export declare function renderSNPCoverageSvg(self: SNPCoverageDisplayModel, opts: ExportSvgDisplayOptions, superRenderSvg: (opts: ExportSvgDisplayOptions) => Promise<React.ReactNode>): Promise<import("react/jsx-runtime").JSX.Element>;
10
+ export {};
@@ -0,0 +1,32 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { getContainingView, getSession } from '@jbrowse/core/util';
3
+ import { featureToArcData } from "./arcUtils.js";
4
+ const YSCALEBAR_LABEL_OFFSET = 5;
5
+ function renderSashimiArcsSvg(self, view) {
6
+ const { id, skipFeatures, height, showArcsSetting } = self;
7
+ if (!showArcsSetting || skipFeatures.length === 0) {
8
+ return null;
9
+ }
10
+ const { assemblyManager } = getSession(self);
11
+ const assembly = assemblyManager.get(view.assemblyNames[0]);
12
+ if (!assembly) {
13
+ return null;
14
+ }
15
+ const effectiveHeight = height - YSCALEBAR_LABEL_OFFSET * 2;
16
+ const currentOffsetPx = view.offsetPx;
17
+ const width = view.dynamicBlocks.totalWidthPx;
18
+ const arcs = skipFeatures
19
+ .map(f => featureToArcData(f, view, effectiveHeight, currentOffsetPx, assembly))
20
+ .filter((arc) => arc !== undefined);
21
+ if (arcs.length === 0) {
22
+ return null;
23
+ }
24
+ const clipId = `sashimi-arcs-clip-${id}`;
25
+ return (_jsxs(_Fragment, { children: [_jsx("defs", { children: _jsx("clipPath", { id: clipId, children: _jsx("rect", { x: 0, y: 0, width: width, height: height }) }) }), _jsx("g", { clipPath: `url(#${clipId})`, children: _jsx("g", { transform: `translate(0, ${YSCALEBAR_LABEL_OFFSET})`, children: arcs.map(arc => (_jsx("path", { d: arc.path, stroke: arc.stroke, strokeWidth: arc.strokeWidth, fill: "none" }, arc.id))) }) })] }));
26
+ }
27
+ export async function renderSNPCoverageSvg(self, opts, superRenderSvg) {
28
+ const view = getContainingView(self);
29
+ const baseRendering = await superRenderSvg(opts);
30
+ const arcsRendering = renderSashimiArcsSvg(self, view);
31
+ return (_jsxs(_Fragment, { children: [baseRendering, arcsRendering] }));
32
+ }