@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
@@ -1,90 +0,0 @@
1
- import { getConf } from '@jbrowse/core/configuration';
2
- import { max, min } from '@jbrowse/core/util';
3
- import { fillRectCtx, strokeRectCtx } from './util';
4
- import { getPairedInsertSizeAndOrientationColor, getPairedInsertSizeColor, getPairedOrientationColor, } from '../shared/color';
5
- export function drawPairChains({ ctx, self, chainData, view, asm, }) {
6
- var _a, _b, _c, _d, _e, _f, _g;
7
- const coords = [];
8
- const featureHeight = getConf(self, 'featureHeight');
9
- const type = ((_a = self.colorBy) === null || _a === void 0 ? void 0 : _a.type) || 'insertSizeAndOrientation';
10
- const { chains, stats } = chainData;
11
- for (const chain of chains) {
12
- if (chain.length > 1) {
13
- const v0 = chain[0];
14
- const v1 = chain[1];
15
- const ra1 = asm.getCanonicalRefName(v0.refName) || v0.refName;
16
- const ra2 = asm.getCanonicalRefName(v1.refName) || v1.refName;
17
- const r1s = (_b = view.bpToPx({ refName: ra1, coord: v0.start })) === null || _b === void 0 ? void 0 : _b.offsetPx;
18
- const r1e = (_c = view.bpToPx({ refName: ra1, coord: v0.end })) === null || _c === void 0 ? void 0 : _c.offsetPx;
19
- const r2s = (_d = view.bpToPx({ refName: ra2, coord: v1.start })) === null || _d === void 0 ? void 0 : _d.offsetPx;
20
- const r2e = (_e = view.bpToPx({ refName: ra2, coord: v1.end })) === null || _e === void 0 ? void 0 : _e.offsetPx;
21
- let distance = 0;
22
- if (r1s !== undefined &&
23
- r1e !== undefined &&
24
- r2s !== undefined &&
25
- r2e !== undefined) {
26
- if (v0.refName === v1.refName) {
27
- const s = Math.min(v0.start, v1.start);
28
- const e = Math.max(v0.end, v1.end);
29
- distance = Math.abs(e - s);
30
- }
31
- coords.push({
32
- r1s,
33
- r1e,
34
- r2s,
35
- r2e,
36
- v0,
37
- v1,
38
- distance,
39
- });
40
- }
41
- }
42
- else if (self.drawSingletons) {
43
- const v0 = chain[0];
44
- const ra1 = asm.getCanonicalRefName(v0.refName) || v0.refName;
45
- const r1s = (_f = view.bpToPx({ refName: ra1, coord: v0.start })) === null || _f === void 0 ? void 0 : _f.offsetPx;
46
- const r1e = (_g = view.bpToPx({ refName: ra1, coord: v0.end })) === null || _g === void 0 ? void 0 : _g.offsetPx;
47
- if (r1s !== undefined && r1e !== undefined) {
48
- const w1 = Math.max(r1e - r1s, 2);
49
- fillRectCtx(r1s - view.offsetPx, 0, w1, featureHeight, ctx, '#f00');
50
- strokeRectCtx(r1s - view.offsetPx, 0, w1, featureHeight, ctx, '#a00');
51
- }
52
- }
53
- }
54
- const maxD = Math.log(max(coords.map(c => c.distance)));
55
- const minD = Math.max(Math.log(min(coords.map(c => c.distance))) - 1, 0);
56
- const scaler = (self.height - 20) / (maxD - minD);
57
- for (const { r1e, r1s, r2e, r2s, distance, v0, v1 } of coords) {
58
- const w1 = Math.max(r1e - r1s, 2);
59
- const w2 = Math.max(r2e - r2s, 2);
60
- const [fill, stroke] = getPairedColor({ type, v0, v1, stats }) || [];
61
- const top = (Math.log(distance) - minD) * scaler;
62
- const halfHeight = featureHeight / 2 - 0.5;
63
- const w = r2s - r1e;
64
- fillRectCtx(r1e - view.offsetPx, top + halfHeight, w, 1, ctx, 'black');
65
- strokeRectCtx(r1s - view.offsetPx, top, w1, featureHeight, ctx, stroke);
66
- strokeRectCtx(r2s - view.offsetPx, top, w2, featureHeight, ctx, stroke);
67
- fillRectCtx(r1s - view.offsetPx, top, w1, featureHeight, ctx, fill);
68
- fillRectCtx(r2s - view.offsetPx, top, w2, featureHeight, ctx, fill);
69
- }
70
- }
71
- export function getPairedColor({ type, v0, v1, stats, }) {
72
- if (type === 'insertSizeAndOrientation') {
73
- return getPairedInsertSizeAndOrientationColor(v0, v1, stats);
74
- }
75
- if (type === 'orientation') {
76
- return getPairedOrientationColor(v0);
77
- }
78
- if (type === 'insertSize') {
79
- return getPairedInsertSizeColor(v0, v1, stats);
80
- }
81
- if (type === 'gradient') {
82
- const s = Math.min(v0.start, v1.start);
83
- const e = Math.max(v0.end, v1.end);
84
- return [
85
- `hsl(${Math.log10(Math.abs(e - s)) * 10},50%,50%)`,
86
- `hsl(${Math.log10(Math.abs(e - s)) * 10},50%,30%)`,
87
- ];
88
- }
89
- return undefined;
90
- }
@@ -1,2 +0,0 @@
1
- export declare function fillRectCtx(x: number, y: number, width: number, height: number, ctx: CanvasRenderingContext2D, fillColor?: string): void;
2
- export declare function strokeRectCtx(x: number, y: number, width: number, height: number, ctx: CanvasRenderingContext2D, strokeColor?: string): void;
@@ -1,37 +0,0 @@
1
- import PileupBaseRPC from '../base';
2
- import type { Region } from '@jbrowse/core/util';
3
- export default class PileupGetReducedFeatures extends PileupBaseRPC {
4
- name: string;
5
- execute(args: {
6
- adapterConfig: Record<string, unknown>;
7
- stopToken?: string;
8
- headers?: Record<string, string>;
9
- regions: Region[];
10
- sessionId: string;
11
- tag: string;
12
- }, rpcDriver: string): Promise<{
13
- chains: {
14
- id: string;
15
- refName: string;
16
- name: any;
17
- start: number;
18
- strand: any;
19
- end: number;
20
- flags: any;
21
- tlen: any;
22
- pair_orientation: any;
23
- next_ref: any;
24
- next_pos: any;
25
- clipPos: number;
26
- SA: any;
27
- }[][];
28
- stats: {
29
- upper: number;
30
- lower: number;
31
- avg: number;
32
- sd: number;
33
- } | undefined;
34
- hasPaired: boolean;
35
- containsNoTransferables: boolean;
36
- }>;
37
- }
@@ -1,48 +0,0 @@
1
- import { getAdapter } from '@jbrowse/core/data_adapters/dataAdapterCache';
2
- import { dedupe, groupBy } from '@jbrowse/core/util';
3
- import { firstValueFrom } from 'rxjs';
4
- import { toArray } from 'rxjs/operators';
5
- import { getClip } from '../../MismatchParser';
6
- import PileupBaseRPC from '../base';
7
- import { filterForPairs, getInsertSizeStats } from '../util';
8
- export default class PileupGetReducedFeatures extends PileupBaseRPC {
9
- constructor() {
10
- super(...arguments);
11
- this.name = 'PileupGetReducedFeatures';
12
- }
13
- async execute(args, rpcDriver) {
14
- const deserializedArgs = await this.deserializeArguments(args, rpcDriver);
15
- const { adapterConfig, sessionId, regions } = deserializedArgs;
16
- const dataAdapter = (await getAdapter(this.pluginManager, sessionId, adapterConfig)).dataAdapter;
17
- const featuresArray = await firstValueFrom(dataAdapter
18
- .getFeaturesInMultipleRegions(regions, deserializedArgs)
19
- .pipe(toArray()));
20
- const reduced = dedupe(featuresArray.map(f => {
21
- var _a;
22
- return ({
23
- id: f.id(),
24
- refName: f.get('refName'),
25
- name: f.get('name'),
26
- start: f.get('start'),
27
- strand: f.get('strand'),
28
- end: f.get('end'),
29
- flags: f.get('flags'),
30
- tlen: f.get('template_length'),
31
- pair_orientation: f.get('pair_orientation'),
32
- next_ref: f.get('next_ref'),
33
- next_pos: f.get('next_pos'),
34
- clipPos: getClip(f.get('CIGAR'), f.get('strand')),
35
- SA: (_a = f.get('tags')) === null || _a === void 0 ? void 0 : _a.SA,
36
- });
37
- }), f => f.id);
38
- const filtered = filterForPairs(reduced);
39
- const stats = filtered.length ? getInsertSizeStats(filtered) : undefined;
40
- const chains = groupBy(reduced, f => f.name);
41
- return {
42
- chains: Object.values(chains),
43
- stats,
44
- hasPaired: !!stats,
45
- containsNoTransferables: true,
46
- };
47
- }
48
- }
@@ -1,8 +0,0 @@
1
- import type { ReducedFeature } from '../shared/fetchChains';
2
- export declare function getInsertSizeStats(features: ReducedFeature[]): {
3
- upper: number;
4
- lower: number;
5
- avg: number;
6
- sd: number;
7
- };
8
- export declare function filterForPairs(features: ReducedFeature[]): ReducedFeature[];
@@ -1,14 +0,0 @@
1
- export function getInsertSizeStats(features) {
2
- const filtered = features.map(f => Math.abs(f.tlen));
3
- const sum = filtered.reduce((a, b) => a + b, 0);
4
- const sum2 = filtered.map(a => a * a).reduce((a, b) => a + b, 0);
5
- const total = filtered.length;
6
- const avg = sum / total;
7
- const sd = Math.sqrt((total * sum2 - sum * sum) / (total * total));
8
- const upper = avg + 4 * sd;
9
- const lower = avg - 3 * sd;
10
- return { upper, lower, avg, sd };
11
- }
12
- export function filterForPairs(features) {
13
- return features.filter(f => f.flags & 2 && !(f.flags & 256) && !(f.flags & 2048));
14
- }
@@ -1,10 +0,0 @@
1
- import type { AnyConfigurationModel } from '@jbrowse/core/configuration';
2
- import type { Feature } from '@jbrowse/core/util';
3
- export declare function getAlignmentShapeColor({ colorType, tag, feature, config, defaultColor, colorTagMap, }: {
4
- colorType: string;
5
- tag: string;
6
- feature: Feature;
7
- defaultColor: boolean;
8
- config: AnyConfigurationModel;
9
- colorTagMap: Record<string, string>;
10
- }): any;
@@ -1,7 +0,0 @@
1
- import type { ProcessedRenderArgs } from './types';
2
- import type { LayoutFeature } from './util';
3
- export declare function renderAlignmentShape({ ctx, feat, renderArgs, }: {
4
- ctx: CanvasRenderingContext2D;
5
- feat: LayoutFeature;
6
- renderArgs: ProcessedRenderArgs;
7
- }): void;
@@ -1,117 +0,0 @@
1
- import { bpSpanPx } from '@jbrowse/core/util';
2
- import { parseCigar } from '../MismatchParser';
3
- export function renderAlignmentShape({ ctx, feat, renderArgs, }) {
4
- const { regions, bpPerPx } = renderArgs;
5
- const { heightPx, topPx, feature } = feat;
6
- const region = regions[0];
7
- const s = feature.get('start');
8
- const e = feature.get('end');
9
- const CIGAR = feature.get('CIGAR');
10
- const flip = region.reversed ? -1 : 1;
11
- const strand = feature.get('strand') * flip;
12
- const renderChevrons = bpPerPx < 10 && heightPx > 5;
13
- if (CIGAR === null || CIGAR === void 0 ? void 0 : CIGAR.includes('N')) {
14
- const cigarOps = parseCigar(CIGAR);
15
- if (strand === 1) {
16
- let drawLen = 0;
17
- let drawStart = s;
18
- for (let i = 0; i < cigarOps.length; i += 2) {
19
- const opLen = +cigarOps[i];
20
- const op = cigarOps[i + 1];
21
- if (op === 'M' || op === 'X' || op === '=' || op === 'D') {
22
- drawLen += opLen;
23
- }
24
- else if (op === 'N') {
25
- if (drawStart !== drawLen) {
26
- const [leftPx, rightPx] = bpSpanPx(drawStart, drawStart + drawLen, region, bpPerPx);
27
- const w = rightPx - leftPx;
28
- ctx.fillRect(leftPx, topPx, w, heightPx);
29
- }
30
- drawStart += drawLen + opLen;
31
- drawLen = 0;
32
- }
33
- }
34
- if (drawStart !== drawLen) {
35
- const [leftPx, rightPx] = bpSpanPx(drawStart, drawStart + drawLen, region, bpPerPx);
36
- const w = rightPx - leftPx;
37
- if (renderChevrons) {
38
- ctx.beginPath();
39
- ctx.moveTo(leftPx, topPx);
40
- ctx.lineTo(leftPx, topPx + heightPx);
41
- ctx.lineTo(rightPx, topPx + heightPx);
42
- ctx.lineTo(rightPx + 5, topPx + heightPx / 2);
43
- ctx.lineTo(rightPx, topPx);
44
- ctx.closePath();
45
- ctx.fill();
46
- }
47
- else {
48
- ctx.fillRect(leftPx, topPx, w, heightPx);
49
- }
50
- }
51
- }
52
- else if (strand === -1) {
53
- let drawLen = 0;
54
- let drawStart = e;
55
- for (let i = cigarOps.length - 2; i >= 0; i -= 2) {
56
- const opLen = +cigarOps[i];
57
- const op = cigarOps[i + 1];
58
- if (op === 'M' || op === 'X' || op === '=' || op === 'D') {
59
- drawLen += opLen;
60
- }
61
- else if (op === 'N') {
62
- if (drawLen !== 0) {
63
- const [leftPx, rightPx] = bpSpanPx(drawStart - drawLen, drawStart, region, bpPerPx);
64
- ctx.fillRect(leftPx, topPx, rightPx - leftPx, heightPx);
65
- }
66
- drawStart -= drawLen + opLen;
67
- drawLen = 0;
68
- }
69
- }
70
- if (drawLen !== 0) {
71
- const [leftPx, rightPx] = bpSpanPx(drawStart - drawLen, drawStart, region, bpPerPx);
72
- const w = rightPx - leftPx;
73
- if (renderChevrons) {
74
- ctx.beginPath();
75
- ctx.moveTo(leftPx - 5, topPx + heightPx / 2);
76
- ctx.lineTo(leftPx, topPx + heightPx);
77
- ctx.lineTo(rightPx, topPx + heightPx);
78
- ctx.lineTo(rightPx, topPx);
79
- ctx.lineTo(leftPx, topPx);
80
- ctx.closePath();
81
- ctx.fill();
82
- }
83
- else {
84
- ctx.fillRect(leftPx, topPx, w, heightPx);
85
- }
86
- }
87
- }
88
- }
89
- else {
90
- const [leftPx, rightPx] = bpSpanPx(s, e, region, bpPerPx);
91
- if (bpPerPx < 10 && heightPx > 5) {
92
- if (strand === -1) {
93
- ctx.beginPath();
94
- ctx.moveTo(leftPx - 5, topPx + heightPx / 2);
95
- ctx.lineTo(leftPx, topPx + heightPx);
96
- ctx.lineTo(rightPx, topPx + heightPx);
97
- ctx.lineTo(rightPx, topPx);
98
- ctx.lineTo(leftPx, topPx);
99
- ctx.closePath();
100
- ctx.fill();
101
- }
102
- else {
103
- ctx.beginPath();
104
- ctx.moveTo(leftPx, topPx);
105
- ctx.lineTo(leftPx, topPx + heightPx);
106
- ctx.lineTo(rightPx, topPx + heightPx);
107
- ctx.lineTo(rightPx + 5, topPx + heightPx / 2);
108
- ctx.lineTo(rightPx, topPx);
109
- ctx.closePath();
110
- ctx.fill();
111
- }
112
- }
113
- else {
114
- ctx.fillRect(leftPx, topPx, rightPx - leftPx, heightPx);
115
- }
116
- }
117
- }
@@ -1,57 +0,0 @@
1
- import { bpSpanPx } from '@jbrowse/core/util';
2
- import { colord } from '@jbrowse/core/util/colord';
3
- import { fillRect } from './util';
4
- import { getMethBins } from '../ModificationParser/getMethBins';
5
- export function renderMethylation({ ctx, feat, region, bpPerPx, renderArgs, canvasWidth, cigarOps, }) {
6
- const { regionSequence } = renderArgs;
7
- const { feature, topPx, heightPx } = feat;
8
- if (!regionSequence) {
9
- throw new Error('region sequence required for methylation');
10
- }
11
- const seq = feature.get('seq');
12
- if (!seq) {
13
- return;
14
- }
15
- const fstart = feature.get('start');
16
- const fend = feature.get('end');
17
- const { methBins, methProbs, hydroxyMethBins, hydroxyMethProbs } = getMethBins(feature, cigarOps);
18
- function getCol(k) {
19
- if (methBins[k]) {
20
- const p = methProbs[k] || 0;
21
- return (p > 0.5
22
- ? colord('red').alpha((p - 0.5) * 2)
23
- : colord('blue').alpha(1 - p * 2)).toHslString();
24
- }
25
- if (hydroxyMethBins[k]) {
26
- const p = hydroxyMethProbs[k] || 0;
27
- return (p > 0.5
28
- ? colord('pink').alpha((p - 0.5) * 2)
29
- : colord('purple').alpha(1 - p * 2)).toHslString();
30
- }
31
- return undefined;
32
- }
33
- const r = regionSequence.toLowerCase();
34
- for (let i = 0; i < fend - fstart; i++) {
35
- const j = i + fstart;
36
- const l1 = r[j - region.start + 1];
37
- const l2 = r[j - region.start + 2];
38
- if (l1 === 'c' && l2 === 'g') {
39
- if (bpPerPx > 2) {
40
- const [leftPx, rightPx] = bpSpanPx(j, j + 2, region, bpPerPx);
41
- const w = rightPx - leftPx + 0.5;
42
- const c = getCol(i) || getCol(i + 1) || 'blue';
43
- fillRect(ctx, leftPx, topPx, w, heightPx, canvasWidth, c);
44
- }
45
- else {
46
- const [leftPx, rightPx] = bpSpanPx(j, j + 1, region, bpPerPx);
47
- const w = rightPx - leftPx + 0.5;
48
- const c = getCol(i) || 'blue';
49
- fillRect(ctx, leftPx, topPx, w, heightPx, canvasWidth, c);
50
- const [leftPx2, rightPx2] = bpSpanPx(j + 1, j + 2, region, bpPerPx);
51
- const w2 = rightPx2 - leftPx2 + 0.5;
52
- const c2 = getCol(i + 1) || 'blue';
53
- fillRect(ctx, leftPx2, topPx, w2, heightPx, canvasWidth, c2);
54
- }
55
- }
56
- }
57
- }
@@ -1,18 +0,0 @@
1
- import type { ProcessedRenderArgs } from './types';
2
- import type { LayoutFeature } from './util';
3
- export declare function renderMismatches({ ctx, feat, renderArgs, minSubfeatureWidth, largeInsertionIndicatorScale, mismatchAlpha, charWidth, charHeight, colorMap, colorContrastMap, hideSmallIndels, canvasWidth, drawSNPsMuted, drawIndels, }: {
4
- ctx: CanvasRenderingContext2D;
5
- feat: LayoutFeature;
6
- renderArgs: ProcessedRenderArgs;
7
- colorMap: Record<string, string>;
8
- colorContrastMap: Record<string, string>;
9
- mismatchAlpha?: boolean;
10
- drawIndels?: boolean;
11
- drawSNPsMuted?: boolean;
12
- minSubfeatureWidth: number;
13
- largeInsertionIndicatorScale: number;
14
- hideSmallIndels: boolean;
15
- charWidth: number;
16
- charHeight: number;
17
- canvasWidth: number;
18
- }): void;
@@ -1,121 +0,0 @@
1
- import { bpSpanPx, measureText } from '@jbrowse/core/util';
2
- import { colord } from '@jbrowse/core/util/colord';
3
- import { fillRect } from './util';
4
- export function renderMismatches({ ctx, feat, renderArgs, minSubfeatureWidth, largeInsertionIndicatorScale, mismatchAlpha, charWidth, charHeight, colorMap, colorContrastMap, hideSmallIndels, canvasWidth, drawSNPsMuted, drawIndels = true, }) {
5
- const { bpPerPx, regions } = renderArgs;
6
- const { heightPx, topPx, feature } = feat;
7
- const region = regions[0];
8
- const start = feature.get('start');
9
- const pxPerBp = Math.min(1 / bpPerPx, 2);
10
- const mismatches = feature.get('mismatches');
11
- const heightLim = charHeight - 2;
12
- const extraHorizontallyFlippedOffset = region.reversed ? 1 / bpPerPx + 1 : -1;
13
- if (!mismatches) {
14
- return;
15
- }
16
- for (const mismatch of mismatches) {
17
- const mstart = start + mismatch.start;
18
- const mlen = mismatch.length;
19
- const mbase = mismatch.base;
20
- const [leftPx, rightPx] = bpSpanPx(mstart, mstart + mlen, region, bpPerPx);
21
- const widthPx = Math.max(minSubfeatureWidth, rightPx - leftPx);
22
- if (mismatch.type === 'mismatch') {
23
- if (!drawSNPsMuted) {
24
- const baseColor = colorMap[mismatch.base] || '#888';
25
- const c = mismatchAlpha && mismatch.qual !== undefined
26
- ? colord(baseColor)
27
- .alpha(Math.min(1, mismatch.qual / 50))
28
- .toHslString()
29
- : baseColor;
30
- fillRect(ctx, Math.round(leftPx), topPx, widthPx, heightPx, canvasWidth, c);
31
- }
32
- if (widthPx >= charWidth && heightPx >= heightLim) {
33
- const contrastColor = drawSNPsMuted
34
- ? 'black'
35
- : colorContrastMap[mismatch.base] || 'black';
36
- ctx.fillStyle =
37
- mismatchAlpha && mismatch.qual !== undefined
38
- ? colord(contrastColor)
39
- .alpha(Math.min(1, mismatch.qual / 50))
40
- .toHslString()
41
- : contrastColor;
42
- ctx.fillText(mbase, leftPx + (widthPx - charWidth) / 2 + 1, topPx + heightPx);
43
- }
44
- }
45
- else if (mismatch.type === 'deletion' && drawIndels) {
46
- const len = mismatch.length;
47
- if (!hideSmallIndels || len >= 10) {
48
- fillRect(ctx, leftPx, topPx, Math.abs(leftPx - rightPx), heightPx, canvasWidth, colorMap.deletion);
49
- const txt = `${mismatch.length}`;
50
- const rwidth = measureText(txt, 10);
51
- if (widthPx >= rwidth && heightPx >= heightLim) {
52
- ctx.fillStyle = colorContrastMap.deletion;
53
- ctx.fillText(txt, (leftPx + rightPx) / 2 - rwidth / 2, topPx + heightPx);
54
- }
55
- }
56
- }
57
- else if (mismatch.type === 'insertion' && drawIndels) {
58
- const pos = leftPx + extraHorizontallyFlippedOffset;
59
- const len = +mismatch.base || mismatch.length;
60
- const insW = Math.max(0, Math.min(1.2, 1 / bpPerPx));
61
- if (len < 10) {
62
- if (!hideSmallIndels) {
63
- fillRect(ctx, pos, topPx, insW, heightPx, canvasWidth, colorMap.insertion);
64
- if (1 / bpPerPx >= charWidth && heightPx >= heightLim) {
65
- const l = Math.round(pos - insW);
66
- fillRect(ctx, l, topPx, insW * 3, 1, canvasWidth);
67
- fillRect(ctx, l, topPx + heightPx - 1, insW * 3, 1, canvasWidth);
68
- ctx.fillText(`(${mismatch.base})`, pos + 3, topPx + heightPx);
69
- }
70
- }
71
- }
72
- }
73
- else if (mismatch.type === 'hardclip' || mismatch.type === 'softclip') {
74
- const pos = leftPx + extraHorizontallyFlippedOffset;
75
- const c = colorMap[mismatch.type];
76
- const clipW = Math.max(minSubfeatureWidth, pxPerBp);
77
- fillRect(ctx, pos, topPx, clipW, heightPx, canvasWidth, c);
78
- if (1 / bpPerPx >= charWidth && heightPx >= heightLim) {
79
- const l = pos - clipW;
80
- fillRect(ctx, l, topPx, clipW * 3, 1, canvasWidth);
81
- fillRect(ctx, l, topPx + heightPx - 1, clipW * 3, 1, canvasWidth);
82
- ctx.fillText(`(${mismatch.base})`, pos + 3, topPx + heightPx);
83
- }
84
- }
85
- else if (mismatch.type === 'skip') {
86
- if (leftPx + widthPx > 0) {
87
- const adjustPx = widthPx - (bpPerPx > 10 ? 1.5 : 0);
88
- const l = Math.max(0, leftPx);
89
- const t = topPx + heightPx / 2 - 1;
90
- const w = adjustPx + Math.min(leftPx, 0);
91
- const h = 1;
92
- fillRect(ctx, l, t, w, h, canvasWidth, colorMap.skip);
93
- }
94
- }
95
- }
96
- if (drawIndels) {
97
- for (const mismatch of mismatches) {
98
- const mstart = start + mismatch.start;
99
- const mlen = mismatch.length;
100
- const len = +mismatch.base || mismatch.length;
101
- if (mismatch.type === 'insertion' && len >= 10) {
102
- const [leftPx] = bpSpanPx(mstart, mstart + mlen, region, bpPerPx);
103
- const txt = `${len}`;
104
- if (bpPerPx > largeInsertionIndicatorScale) {
105
- fillRect(ctx, leftPx - 1, topPx, 2, heightPx, canvasWidth, colorMap.insertion);
106
- }
107
- else if (heightPx > charHeight) {
108
- const rwidth = measureText(txt);
109
- const padding = 5;
110
- fillRect(ctx, leftPx - rwidth / 2 - padding, topPx, rwidth + 2 * padding, heightPx, canvasWidth, 'purple');
111
- ctx.fillStyle = colorContrastMap.insertion;
112
- ctx.fillText(txt, leftPx - rwidth / 2, topPx + heightPx);
113
- }
114
- else {
115
- const padding = 2;
116
- fillRect(ctx, leftPx - padding, topPx, 2 * padding, heightPx, canvasWidth, colorMap.insertion);
117
- }
118
- }
119
- }
120
- }
121
- }
@@ -1,12 +0,0 @@
1
- import type { ProcessedRenderArgs } from './types';
2
- import type { LayoutFeature } from './util';
3
- import type { Region } from '@jbrowse/core/util';
4
- export declare function renderModifications({ ctx, feat, region, bpPerPx, renderArgs, canvasWidth, cigarOps, }: {
5
- ctx: CanvasRenderingContext2D;
6
- feat: LayoutFeature;
7
- region: Region;
8
- bpPerPx: number;
9
- renderArgs: ProcessedRenderArgs;
10
- canvasWidth: number;
11
- cigarOps: string[];
12
- }): void;
@@ -1,41 +0,0 @@
1
- import { bpSpanPx, max, sum } from '@jbrowse/core/util';
2
- import { fillRect } from './util';
3
- import { getMaxProbModAtEachPosition } from '../shared/getMaximumModificationAtEachPosition';
4
- import { alphaColor } from '../shared/util';
5
- export function renderModifications({ ctx, feat, region, bpPerPx, renderArgs, canvasWidth, cigarOps, }) {
6
- var _a, _b, _c;
7
- const { feature, topPx, heightPx } = feat;
8
- const { colorBy, visibleModifications = {} } = renderArgs;
9
- const seq = feature.get('seq');
10
- if (!seq) {
11
- return;
12
- }
13
- const start = feature.get('start');
14
- const isolatedModification = (_a = colorBy === null || colorBy === void 0 ? void 0 : colorBy.modifications) === null || _a === void 0 ? void 0 : _a.isolatedModification;
15
- const twoColor = (_b = colorBy === null || colorBy === void 0 ? void 0 : colorBy.modifications) === null || _b === void 0 ? void 0 : _b.twoColor;
16
- (_c = getMaxProbModAtEachPosition(feature, cigarOps)) === null || _c === void 0 ? void 0 : _c.forEach(({ allProbs, prob, type }, pos) => {
17
- const r = start + pos;
18
- const [leftPx, rightPx] = bpSpanPx(r, r + 1, region, bpPerPx);
19
- const mod = visibleModifications[type];
20
- if (!mod) {
21
- console.warn(`${type} not known yet`);
22
- return;
23
- }
24
- if (isolatedModification && mod.type !== isolatedModification) {
25
- return;
26
- }
27
- const col = mod.color || 'black';
28
- const s = 1 - sum(allProbs);
29
- if (twoColor && s > max(allProbs)) {
30
- const c = alphaColor('blue', s);
31
- const w = rightPx - leftPx + 0.5;
32
- fillRect(ctx, leftPx, topPx, w, heightPx, canvasWidth, c);
33
- }
34
- else {
35
- const c = alphaColor(col, prob);
36
- const w = rightPx - leftPx + 0.5;
37
- fillRect(ctx, leftPx, topPx, w, heightPx, canvasWidth, c);
38
- }
39
- pos++;
40
- });
41
- }
@@ -1,14 +0,0 @@
1
- import type { LayoutFeature } from './util';
2
- import type { Region } from '@jbrowse/core/util';
3
- export declare function renderPerBaseLettering({ ctx, feat, region, bpPerPx, colorMap, colorContrastMap, charWidth, charHeight, canvasWidth, cigarOps, }: {
4
- ctx: CanvasRenderingContext2D;
5
- feat: LayoutFeature;
6
- region: Region;
7
- bpPerPx: number;
8
- colorMap: Record<string, string>;
9
- colorContrastMap: Record<string, string>;
10
- charWidth: number;
11
- charHeight: number;
12
- canvasWidth: number;
13
- cigarOps: string[];
14
- }): void;
@@ -1,39 +0,0 @@
1
- import { bpSpanPx } from '@jbrowse/core/util';
2
- import { fillRect } from './util';
3
- export function renderPerBaseLettering({ ctx, feat, region, bpPerPx, colorMap, colorContrastMap, charWidth, charHeight, canvasWidth, cigarOps, }) {
4
- const heightLim = charHeight - 2;
5
- const { feature, topPx, heightPx } = feat;
6
- const seq = feature.get('seq');
7
- const w = 1 / bpPerPx;
8
- const start = feature.get('start');
9
- let soffset = 0;
10
- let roffset = 0;
11
- if (!seq) {
12
- return;
13
- }
14
- for (let i = 0; i < cigarOps.length; i += 2) {
15
- const len = +cigarOps[i];
16
- const op = cigarOps[i + 1];
17
- if (op === 'S' || op === 'I') {
18
- soffset += len;
19
- }
20
- else if (op === 'D' || op === 'N') {
21
- roffset += len;
22
- }
23
- else if (op === 'M' || op === 'X' || op === '=') {
24
- for (let m = 0; m < len; m++) {
25
- const letter = seq[soffset + m];
26
- const r = start + roffset + m;
27
- const [leftPx] = bpSpanPx(r, r + 1, region, bpPerPx);
28
- const c = colorMap[letter];
29
- fillRect(ctx, leftPx, topPx, w + 0.5, heightPx, canvasWidth, c);
30
- if (w >= charWidth && heightPx >= heightLim) {
31
- ctx.fillStyle = colorContrastMap[letter];
32
- ctx.fillText(letter, leftPx + (w - charWidth) / 2 + 1, topPx + heightPx);
33
- }
34
- }
35
- soffset += len;
36
- roffset += len;
37
- }
38
- }
39
- }
@@ -1,10 +0,0 @@
1
- import type { LayoutFeature } from './util';
2
- import type { Region } from '@jbrowse/core/util';
3
- export declare function renderPerBaseQuality({ ctx, feat, region, bpPerPx, canvasWidth, cigarOps, }: {
4
- ctx: CanvasRenderingContext2D;
5
- feat: LayoutFeature;
6
- region: Region;
7
- bpPerPx: number;
8
- canvasWidth: number;
9
- cigarOps: string[];
10
- }): void;