@jbrowse/plugin-alignments 2.4.2 → 2.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (443) hide show
  1. package/dist/AlignmentsFeatureDetail/AlignmentsFeatureDetail.d.ts +2 -2
  2. package/dist/AlignmentsFeatureDetail/AlignmentsFeatureFlags.d.ts +2 -2
  3. package/dist/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js +2 -1
  4. package/dist/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js.map +1 -1
  5. package/dist/AlignmentsFeatureDetail/AlignmentsFeatureSuppAligns.d.ts +2 -2
  6. package/dist/AlignmentsFeatureDetail/index.d.ts +4 -1
  7. package/dist/AlignmentsTrack/configSchemaF.d.ts +74 -0
  8. package/dist/AlignmentsTrack/configSchemaF.js +19 -0
  9. package/dist/AlignmentsTrack/configSchemaF.js.map +1 -0
  10. package/dist/AlignmentsTrack/index.js +2 -15
  11. package/dist/AlignmentsTrack/index.js.map +1 -1
  12. package/dist/BamAdapter/BamAdapter.d.ts +2 -2
  13. package/dist/BamAdapter/BamAdapter.js +27 -32
  14. package/dist/BamAdapter/BamAdapter.js.map +1 -1
  15. package/dist/BamAdapter/BamSlightlyLazyFeature.d.ts +1 -1
  16. package/dist/BamAdapter/configSchema.d.ts +50 -1
  17. package/dist/CramAdapter/CramAdapter.d.ts +1 -1
  18. package/dist/CramAdapter/CramAdapter.js +49 -47
  19. package/dist/CramAdapter/CramAdapter.js.map +1 -1
  20. package/dist/CramAdapter/CramSlightlyLazyFeature.js +3 -5
  21. package/dist/CramAdapter/CramSlightlyLazyFeature.js.map +1 -1
  22. package/dist/CramAdapter/CramTestAdapters.js +3 -3
  23. package/dist/CramAdapter/CramTestAdapters.js.map +1 -1
  24. package/dist/CramAdapter/configSchema.d.ts +40 -1
  25. package/dist/HtsgetBamAdapter/configSchema.d.ts +26 -1
  26. package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.d.ts +2 -2
  27. package/dist/LinearAlignmentsDisplay/models/configSchema.d.ts +39 -1
  28. package/dist/LinearAlignmentsDisplay/models/model.d.ts +20 -6
  29. package/dist/LinearAlignmentsDisplay/models/model.js +9 -4
  30. package/dist/LinearAlignmentsDisplay/models/model.js.map +1 -1
  31. package/dist/LinearPileupDisplay/components/ColorByModifications.d.ts +2 -2
  32. package/dist/LinearPileupDisplay/components/ColorByModifications.js +3 -23
  33. package/dist/LinearPileupDisplay/components/ColorByModifications.js.map +1 -1
  34. package/dist/LinearPileupDisplay/components/ColorByTag.d.ts +2 -2
  35. package/dist/LinearPileupDisplay/components/ColorByTag.js +2 -6
  36. package/dist/LinearPileupDisplay/components/ColorByTag.js.map +1 -1
  37. package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.d.ts +3 -3
  38. package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js +6 -6
  39. package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js.map +1 -1
  40. package/dist/LinearPileupDisplay/components/ModificationsTable.d.ts +4 -0
  41. package/dist/LinearPileupDisplay/components/ModificationsTable.js +29 -0
  42. package/dist/LinearPileupDisplay/components/ModificationsTable.js.map +1 -0
  43. package/dist/LinearPileupDisplay/components/SetFeatureHeight.d.ts +2 -2
  44. package/dist/LinearPileupDisplay/components/SetMaxHeight.d.ts +2 -2
  45. package/dist/LinearPileupDisplay/components/SetMaxHeight.js +3 -5
  46. package/dist/LinearPileupDisplay/components/SetMaxHeight.js.map +1 -1
  47. package/dist/LinearPileupDisplay/components/SortByTag.d.ts +2 -2
  48. package/dist/LinearPileupDisplay/configSchema.d.ts +57 -1
  49. package/dist/LinearPileupDisplay/model.d.ts +160 -80
  50. package/dist/LinearPileupDisplay/model.js +181 -138
  51. package/dist/LinearPileupDisplay/model.js.map +1 -1
  52. package/dist/LinearReadArcsDisplay/components/ReactComponent.d.ts +2 -2
  53. package/dist/LinearReadArcsDisplay/components/ReactComponent.js +36 -39
  54. package/dist/LinearReadArcsDisplay/components/ReactComponent.js.map +1 -1
  55. package/dist/LinearReadArcsDisplay/configSchema.d.ts +59 -1
  56. package/dist/LinearReadArcsDisplay/drawFeats.d.ts +2 -15
  57. package/dist/LinearReadArcsDisplay/drawFeats.js +58 -66
  58. package/dist/LinearReadArcsDisplay/drawFeats.js.map +1 -1
  59. package/dist/LinearReadArcsDisplay/model.d.ts +58 -193
  60. package/dist/LinearReadArcsDisplay/model.js +65 -115
  61. package/dist/LinearReadArcsDisplay/model.js.map +1 -1
  62. package/dist/LinearReadArcsDisplay/util.d.ts +2 -0
  63. package/dist/LinearReadArcsDisplay/util.js +13 -0
  64. package/dist/LinearReadArcsDisplay/util.js.map +1 -0
  65. package/dist/LinearReadCloudDisplay/components/ReactComponent.d.ts +2 -2
  66. package/dist/LinearReadCloudDisplay/components/ReactComponent.js +34 -36
  67. package/dist/LinearReadCloudDisplay/components/ReactComponent.js.map +1 -1
  68. package/dist/LinearReadCloudDisplay/configSchema.d.ts +52 -1
  69. package/dist/LinearReadCloudDisplay/drawFeats.d.ts +2 -10
  70. package/dist/LinearReadCloudDisplay/drawFeats.js +11 -127
  71. package/dist/LinearReadCloudDisplay/drawFeats.js.map +1 -1
  72. package/dist/LinearReadCloudDisplay/drawLongReadChains.d.ts +11 -0
  73. package/dist/LinearReadCloudDisplay/drawLongReadChains.js +69 -0
  74. package/dist/LinearReadCloudDisplay/drawLongReadChains.js.map +1 -0
  75. package/dist/LinearReadCloudDisplay/drawPairChains.d.ts +17 -0
  76. package/dist/LinearReadCloudDisplay/drawPairChains.js +100 -0
  77. package/dist/LinearReadCloudDisplay/drawPairChains.js.map +1 -0
  78. package/dist/LinearReadCloudDisplay/model.d.ts +65 -196
  79. package/dist/LinearReadCloudDisplay/model.js +55 -92
  80. package/dist/LinearReadCloudDisplay/model.js.map +1 -1
  81. package/dist/LinearReadCloudDisplay/util.d.ts +2 -0
  82. package/dist/LinearReadCloudDisplay/util.js +35 -0
  83. package/dist/LinearReadCloudDisplay/util.js.map +1 -0
  84. package/dist/LinearSNPCoverageDisplay/components/Tooltip.d.ts +2 -2
  85. package/dist/LinearSNPCoverageDisplay/models/configSchema.d.ts +79 -1
  86. package/dist/LinearSNPCoverageDisplay/models/model.d.ts +157 -70
  87. package/dist/LinearSNPCoverageDisplay/models/model.js +46 -33
  88. package/dist/LinearSNPCoverageDisplay/models/model.js.map +1 -1
  89. package/dist/MismatchParser/index.d.ts +7 -2
  90. package/dist/MismatchParser/index.js +44 -5
  91. package/dist/MismatchParser/index.js.map +1 -1
  92. package/dist/PileupRPC/methods/GetReducedFeatures.d.ts +15 -2
  93. package/dist/PileupRPC/methods/GetReducedFeatures.js +1 -8
  94. package/dist/PileupRPC/methods/GetReducedFeatures.js.map +1 -1
  95. package/dist/PileupRenderer/PileupLayoutSession.d.ts +1 -1
  96. package/dist/PileupRenderer/PileupRenderer.d.ts +4 -117
  97. package/dist/PileupRenderer/PileupRenderer.js +18 -752
  98. package/dist/PileupRenderer/PileupRenderer.js.map +1 -1
  99. package/dist/PileupRenderer/colorBy.d.ts +7 -0
  100. package/dist/PileupRenderer/colorBy.js +69 -0
  101. package/dist/PileupRenderer/colorBy.js.map +1 -0
  102. package/dist/PileupRenderer/components/PileupRendering.d.ts +7 -2
  103. package/dist/PileupRenderer/components/PileupRendering.js +17 -18
  104. package/dist/PileupRenderer/components/PileupRendering.js.map +1 -1
  105. package/dist/PileupRenderer/configSchema.d.ts +87 -1
  106. package/dist/PileupRenderer/getAlignmentShapeColor.d.ts +10 -0
  107. package/dist/PileupRenderer/getAlignmentShapeColor.js +60 -0
  108. package/dist/PileupRenderer/getAlignmentShapeColor.js.map +1 -0
  109. package/dist/PileupRenderer/index.js +1 -1
  110. package/dist/PileupRenderer/index.js.map +1 -1
  111. package/dist/PileupRenderer/layoutFeature.d.ts +18 -0
  112. package/dist/PileupRenderer/layoutFeature.js +41 -0
  113. package/dist/PileupRenderer/layoutFeature.js.map +1 -0
  114. package/dist/PileupRenderer/layoutFeatures.d.ts +2 -0
  115. package/dist/PileupRenderer/layoutFeatures.js +35 -0
  116. package/dist/PileupRenderer/layoutFeatures.js.map +1 -0
  117. package/dist/PileupRenderer/makeImageData.d.ts +17 -0
  118. package/dist/PileupRenderer/makeImageData.js +64 -0
  119. package/dist/PileupRenderer/makeImageData.js.map +1 -0
  120. package/dist/PileupRenderer/renderAlignment.d.ts +13 -0
  121. package/dist/PileupRenderer/renderAlignment.js +72 -0
  122. package/dist/PileupRenderer/renderAlignment.js.map +1 -0
  123. package/dist/PileupRenderer/renderAlignmentShape.d.ts +7 -0
  124. package/dist/PileupRenderer/renderAlignmentShape.js +41 -0
  125. package/dist/PileupRenderer/renderAlignmentShape.js.map +1 -0
  126. package/dist/PileupRenderer/renderMethylation.d.ts +11 -0
  127. package/dist/PileupRenderer/renderMethylation.js +63 -0
  128. package/dist/PileupRenderer/renderMethylation.js.map +1 -0
  129. package/dist/PileupRenderer/renderMismatches.d.ts +21 -0
  130. package/dist/PileupRenderer/renderMismatches.js +135 -0
  131. package/dist/PileupRenderer/renderMismatches.js.map +1 -0
  132. package/dist/PileupRenderer/renderModifications.d.ts +11 -0
  133. package/dist/PileupRenderer/renderModifications.js +54 -0
  134. package/dist/PileupRenderer/renderModifications.js.map +1 -0
  135. package/dist/PileupRenderer/renderPerBaseLettering.d.ts +13 -0
  136. package/dist/PileupRenderer/renderPerBaseLettering.js +47 -0
  137. package/dist/PileupRenderer/renderPerBaseLettering.js.map +1 -0
  138. package/dist/PileupRenderer/renderPerBaseQuality.d.ts +9 -0
  139. package/dist/PileupRenderer/renderPerBaseQuality.js +39 -0
  140. package/dist/PileupRenderer/renderPerBaseQuality.js.map +1 -0
  141. package/dist/PileupRenderer/renderSoftClipping.d.ts +13 -0
  142. package/dist/PileupRenderer/renderSoftClipping.js +48 -0
  143. package/dist/PileupRenderer/renderSoftClipping.js.map +1 -0
  144. package/dist/PileupRenderer/sortUtil.js +1 -2
  145. package/dist/PileupRenderer/sortUtil.js.map +1 -1
  146. package/dist/PileupRenderer/util.d.ts +24 -0
  147. package/dist/PileupRenderer/util.js +51 -0
  148. package/dist/PileupRenderer/util.js.map +1 -0
  149. package/dist/SNPCoverageAdapter/SNPCoverageAdapter.d.ts +1 -3
  150. package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js +2 -5
  151. package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js.map +1 -1
  152. package/dist/SNPCoverageAdapter/configSchema.d.ts +10 -1
  153. package/dist/SNPCoverageAdapter/generateCoverageBins.d.ts +3 -43
  154. package/dist/SNPCoverageAdapter/generateCoverageBins.js +86 -59
  155. package/dist/SNPCoverageAdapter/generateCoverageBins.js.map +1 -1
  156. package/dist/SNPCoverageAdapter/index.js +0 -2
  157. package/dist/SNPCoverageAdapter/index.js.map +1 -1
  158. package/dist/SNPCoverageAdapter/util.d.ts +29 -0
  159. package/dist/SNPCoverageAdapter/util.js +3 -0
  160. package/dist/SNPCoverageAdapter/util.js.map +1 -0
  161. package/dist/SNPCoverageRenderer/SNPCoverageRenderer.d.ts +1 -1
  162. package/dist/SNPCoverageRenderer/SNPCoverageRenderer.js +2 -2
  163. package/dist/SNPCoverageRenderer/SNPCoverageRenderer.js.map +1 -1
  164. package/dist/SNPCoverageRenderer/configSchema.d.ts +47 -1
  165. package/dist/SNPCoverageRenderer/configSchema.js +5 -0
  166. package/dist/SNPCoverageRenderer/configSchema.js.map +1 -1
  167. package/dist/shared/BaseDisplayComponent.d.ts +8 -0
  168. package/dist/shared/BaseDisplayComponent.js +49 -0
  169. package/dist/shared/BaseDisplayComponent.js.map +1 -0
  170. package/dist/shared/FilterByTag.d.ts +13 -12
  171. package/dist/shared/FilterByTag.js +8 -13
  172. package/dist/shared/FilterByTag.js.map +1 -1
  173. package/dist/shared/afterAttach.d.ts +2 -0
  174. package/dist/shared/afterAttach.js +44 -0
  175. package/dist/shared/afterAttach.js.map +1 -0
  176. package/dist/shared/color.d.ts +44 -6
  177. package/dist/shared/color.js +57 -23
  178. package/dist/shared/color.js.map +1 -1
  179. package/dist/shared/fetchChains.d.ts +3 -2
  180. package/dist/shared/fetchChains.js +14 -20
  181. package/dist/shared/fetchChains.js.map +1 -1
  182. package/dist/shared/renderSvg.d.ts +7 -0
  183. package/dist/shared/renderSvg.js +69 -0
  184. package/dist/shared/renderSvg.js.map +1 -0
  185. package/dist/shared/util.d.ts +2 -0
  186. package/dist/shared/util.js +13 -0
  187. package/dist/shared/util.js.map +1 -0
  188. package/dist/util.d.ts +16 -2
  189. package/dist/util.js +45 -4
  190. package/dist/util.js.map +1 -1
  191. package/esm/AlignmentsFeatureDetail/AlignmentsFeatureDetail.d.ts +2 -2
  192. package/esm/AlignmentsFeatureDetail/AlignmentsFeatureFlags.d.ts +2 -2
  193. package/esm/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js +3 -2
  194. package/esm/AlignmentsFeatureDetail/AlignmentsFeatureFlags.js.map +1 -1
  195. package/esm/AlignmentsFeatureDetail/AlignmentsFeatureSuppAligns.d.ts +2 -2
  196. package/esm/AlignmentsFeatureDetail/index.d.ts +4 -1
  197. package/esm/AlignmentsTrack/configSchemaF.d.ts +74 -0
  198. package/esm/AlignmentsTrack/configSchemaF.js +16 -0
  199. package/esm/AlignmentsTrack/configSchemaF.js.map +1 -0
  200. package/esm/AlignmentsTrack/index.js +3 -16
  201. package/esm/AlignmentsTrack/index.js.map +1 -1
  202. package/esm/BamAdapter/BamAdapter.d.ts +2 -2
  203. package/esm/BamAdapter/BamAdapter.js +27 -32
  204. package/esm/BamAdapter/BamAdapter.js.map +1 -1
  205. package/esm/BamAdapter/BamSlightlyLazyFeature.d.ts +1 -1
  206. package/esm/BamAdapter/configSchema.d.ts +50 -1
  207. package/esm/CramAdapter/CramAdapter.d.ts +1 -1
  208. package/esm/CramAdapter/CramAdapter.js +50 -48
  209. package/esm/CramAdapter/CramAdapter.js.map +1 -1
  210. package/esm/CramAdapter/CramSlightlyLazyFeature.js +3 -5
  211. package/esm/CramAdapter/CramSlightlyLazyFeature.js.map +1 -1
  212. package/esm/CramAdapter/CramTestAdapters.js +2 -2
  213. package/esm/CramAdapter/CramTestAdapters.js.map +1 -1
  214. package/esm/CramAdapter/configSchema.d.ts +40 -1
  215. package/esm/HtsgetBamAdapter/configSchema.d.ts +26 -1
  216. package/esm/LinearAlignmentsDisplay/components/AlignmentsDisplay.d.ts +2 -2
  217. package/esm/LinearAlignmentsDisplay/models/configSchema.d.ts +39 -1
  218. package/esm/LinearAlignmentsDisplay/models/model.d.ts +20 -6
  219. package/esm/LinearAlignmentsDisplay/models/model.js +9 -4
  220. package/esm/LinearAlignmentsDisplay/models/model.js.map +1 -1
  221. package/esm/LinearPileupDisplay/components/ColorByModifications.d.ts +2 -2
  222. package/esm/LinearPileupDisplay/components/ColorByModifications.js +2 -22
  223. package/esm/LinearPileupDisplay/components/ColorByModifications.js.map +1 -1
  224. package/esm/LinearPileupDisplay/components/ColorByTag.d.ts +2 -2
  225. package/esm/LinearPileupDisplay/components/ColorByTag.js +2 -6
  226. package/esm/LinearPileupDisplay/components/ColorByTag.js.map +1 -1
  227. package/esm/LinearPileupDisplay/components/LinearPileupDisplayBlurb.d.ts +3 -3
  228. package/esm/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js +6 -6
  229. package/esm/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js.map +1 -1
  230. package/esm/LinearPileupDisplay/components/ModificationsTable.d.ts +4 -0
  231. package/esm/LinearPileupDisplay/components/ModificationsTable.js +23 -0
  232. package/esm/LinearPileupDisplay/components/ModificationsTable.js.map +1 -0
  233. package/esm/LinearPileupDisplay/components/SetFeatureHeight.d.ts +2 -2
  234. package/esm/LinearPileupDisplay/components/SetMaxHeight.d.ts +2 -2
  235. package/esm/LinearPileupDisplay/components/SetMaxHeight.js +3 -5
  236. package/esm/LinearPileupDisplay/components/SetMaxHeight.js.map +1 -1
  237. package/esm/LinearPileupDisplay/components/SortByTag.d.ts +2 -2
  238. package/esm/LinearPileupDisplay/configSchema.d.ts +57 -1
  239. package/esm/LinearPileupDisplay/model.d.ts +160 -80
  240. package/esm/LinearPileupDisplay/model.js +182 -139
  241. package/esm/LinearPileupDisplay/model.js.map +1 -1
  242. package/esm/LinearReadArcsDisplay/components/ReactComponent.d.ts +2 -2
  243. package/esm/LinearReadArcsDisplay/components/ReactComponent.js +13 -39
  244. package/esm/LinearReadArcsDisplay/components/ReactComponent.js.map +1 -1
  245. package/esm/LinearReadArcsDisplay/configSchema.d.ts +59 -1
  246. package/esm/LinearReadArcsDisplay/drawFeats.d.ts +2 -15
  247. package/esm/LinearReadArcsDisplay/drawFeats.js +56 -63
  248. package/esm/LinearReadArcsDisplay/drawFeats.js.map +1 -1
  249. package/esm/LinearReadArcsDisplay/model.d.ts +58 -193
  250. package/esm/LinearReadArcsDisplay/model.js +69 -119
  251. package/esm/LinearReadArcsDisplay/model.js.map +1 -1
  252. package/esm/LinearReadArcsDisplay/util.d.ts +2 -0
  253. package/esm/LinearReadArcsDisplay/util.js +9 -0
  254. package/esm/LinearReadArcsDisplay/util.js.map +1 -0
  255. package/esm/LinearReadCloudDisplay/components/ReactComponent.d.ts +2 -2
  256. package/esm/LinearReadCloudDisplay/components/ReactComponent.js +11 -36
  257. package/esm/LinearReadCloudDisplay/components/ReactComponent.js.map +1 -1
  258. package/esm/LinearReadCloudDisplay/configSchema.d.ts +52 -1
  259. package/esm/LinearReadCloudDisplay/drawFeats.d.ts +2 -10
  260. package/esm/LinearReadCloudDisplay/drawFeats.js +9 -126
  261. package/esm/LinearReadCloudDisplay/drawFeats.js.map +1 -1
  262. package/esm/LinearReadCloudDisplay/drawLongReadChains.d.ts +11 -0
  263. package/esm/LinearReadCloudDisplay/drawLongReadChains.js +65 -0
  264. package/esm/LinearReadCloudDisplay/drawLongReadChains.js.map +1 -0
  265. package/esm/LinearReadCloudDisplay/drawPairChains.d.ts +17 -0
  266. package/esm/LinearReadCloudDisplay/drawPairChains.js +95 -0
  267. package/esm/LinearReadCloudDisplay/drawPairChains.js.map +1 -0
  268. package/esm/LinearReadCloudDisplay/model.d.ts +65 -196
  269. package/esm/LinearReadCloudDisplay/model.js +59 -96
  270. package/esm/LinearReadCloudDisplay/model.js.map +1 -1
  271. package/esm/LinearReadCloudDisplay/util.d.ts +2 -0
  272. package/esm/LinearReadCloudDisplay/util.js +30 -0
  273. package/esm/LinearReadCloudDisplay/util.js.map +1 -0
  274. package/esm/LinearSNPCoverageDisplay/components/Tooltip.d.ts +2 -2
  275. package/esm/LinearSNPCoverageDisplay/models/configSchema.d.ts +79 -1
  276. package/esm/LinearSNPCoverageDisplay/models/model.d.ts +157 -70
  277. package/esm/LinearSNPCoverageDisplay/models/model.js +48 -35
  278. package/esm/LinearSNPCoverageDisplay/models/model.js.map +1 -1
  279. package/esm/MismatchParser/index.d.ts +7 -2
  280. package/esm/MismatchParser/index.js +41 -4
  281. package/esm/MismatchParser/index.js.map +1 -1
  282. package/esm/PileupRPC/methods/GetReducedFeatures.d.ts +15 -2
  283. package/esm/PileupRPC/methods/GetReducedFeatures.js +2 -9
  284. package/esm/PileupRPC/methods/GetReducedFeatures.js.map +1 -1
  285. package/esm/PileupRenderer/PileupLayoutSession.d.ts +1 -1
  286. package/esm/PileupRenderer/PileupRenderer.d.ts +4 -117
  287. package/esm/PileupRenderer/PileupRenderer.js +20 -754
  288. package/esm/PileupRenderer/PileupRenderer.js.map +1 -1
  289. package/esm/PileupRenderer/colorBy.d.ts +7 -0
  290. package/esm/PileupRenderer/colorBy.js +61 -0
  291. package/esm/PileupRenderer/colorBy.js.map +1 -0
  292. package/esm/PileupRenderer/components/PileupRendering.d.ts +7 -2
  293. package/esm/PileupRenderer/components/PileupRendering.js +17 -18
  294. package/esm/PileupRenderer/components/PileupRendering.js.map +1 -1
  295. package/esm/PileupRenderer/configSchema.d.ts +87 -1
  296. package/esm/PileupRenderer/getAlignmentShapeColor.d.ts +10 -0
  297. package/esm/PileupRenderer/getAlignmentShapeColor.js +56 -0
  298. package/esm/PileupRenderer/getAlignmentShapeColor.js.map +1 -0
  299. package/esm/PileupRenderer/index.js +1 -1
  300. package/esm/PileupRenderer/index.js.map +1 -1
  301. package/esm/PileupRenderer/layoutFeature.d.ts +18 -0
  302. package/esm/PileupRenderer/layoutFeature.js +37 -0
  303. package/esm/PileupRenderer/layoutFeature.js.map +1 -0
  304. package/esm/PileupRenderer/layoutFeatures.d.ts +2 -0
  305. package/esm/PileupRenderer/layoutFeatures.js +31 -0
  306. package/esm/PileupRenderer/layoutFeatures.js.map +1 -0
  307. package/esm/PileupRenderer/makeImageData.d.ts +17 -0
  308. package/esm/PileupRenderer/makeImageData.js +60 -0
  309. package/esm/PileupRenderer/makeImageData.js.map +1 -0
  310. package/esm/PileupRenderer/renderAlignment.d.ts +13 -0
  311. package/esm/PileupRenderer/renderAlignment.js +68 -0
  312. package/esm/PileupRenderer/renderAlignment.js.map +1 -0
  313. package/esm/PileupRenderer/renderAlignmentShape.d.ts +7 -0
  314. package/esm/PileupRenderer/renderAlignmentShape.js +37 -0
  315. package/esm/PileupRenderer/renderAlignmentShape.js.map +1 -0
  316. package/esm/PileupRenderer/renderMethylation.d.ts +11 -0
  317. package/esm/PileupRenderer/renderMethylation.js +59 -0
  318. package/esm/PileupRenderer/renderMethylation.js.map +1 -0
  319. package/esm/PileupRenderer/renderMismatches.d.ts +21 -0
  320. package/esm/PileupRenderer/renderMismatches.js +131 -0
  321. package/esm/PileupRenderer/renderMismatches.js.map +1 -0
  322. package/esm/PileupRenderer/renderModifications.d.ts +11 -0
  323. package/esm/PileupRenderer/renderModifications.js +50 -0
  324. package/esm/PileupRenderer/renderModifications.js.map +1 -0
  325. package/esm/PileupRenderer/renderPerBaseLettering.d.ts +13 -0
  326. package/esm/PileupRenderer/renderPerBaseLettering.js +43 -0
  327. package/esm/PileupRenderer/renderPerBaseLettering.js.map +1 -0
  328. package/esm/PileupRenderer/renderPerBaseQuality.d.ts +9 -0
  329. package/esm/PileupRenderer/renderPerBaseQuality.js +35 -0
  330. package/esm/PileupRenderer/renderPerBaseQuality.js.map +1 -0
  331. package/esm/PileupRenderer/renderSoftClipping.d.ts +13 -0
  332. package/esm/PileupRenderer/renderSoftClipping.js +44 -0
  333. package/esm/PileupRenderer/renderSoftClipping.js.map +1 -0
  334. package/esm/PileupRenderer/sortUtil.js +1 -2
  335. package/esm/PileupRenderer/sortUtil.js.map +1 -1
  336. package/esm/PileupRenderer/util.d.ts +24 -0
  337. package/esm/PileupRenderer/util.js +42 -0
  338. package/esm/PileupRenderer/util.js.map +1 -0
  339. package/esm/SNPCoverageAdapter/SNPCoverageAdapter.d.ts +1 -3
  340. package/esm/SNPCoverageAdapter/SNPCoverageAdapter.js +2 -4
  341. package/esm/SNPCoverageAdapter/SNPCoverageAdapter.js.map +1 -1
  342. package/esm/SNPCoverageAdapter/configSchema.d.ts +10 -1
  343. package/esm/SNPCoverageAdapter/generateCoverageBins.d.ts +3 -43
  344. package/esm/SNPCoverageAdapter/generateCoverageBins.js +87 -60
  345. package/esm/SNPCoverageAdapter/generateCoverageBins.js.map +1 -1
  346. package/esm/SNPCoverageAdapter/index.js +0 -2
  347. package/esm/SNPCoverageAdapter/index.js.map +1 -1
  348. package/esm/SNPCoverageAdapter/util.d.ts +29 -0
  349. package/esm/SNPCoverageAdapter/util.js +2 -0
  350. package/esm/SNPCoverageAdapter/util.js.map +1 -0
  351. package/esm/SNPCoverageRenderer/SNPCoverageRenderer.d.ts +1 -1
  352. package/esm/SNPCoverageRenderer/SNPCoverageRenderer.js +2 -2
  353. package/esm/SNPCoverageRenderer/SNPCoverageRenderer.js.map +1 -1
  354. package/esm/SNPCoverageRenderer/configSchema.d.ts +47 -1
  355. package/esm/SNPCoverageRenderer/configSchema.js +5 -0
  356. package/esm/SNPCoverageRenderer/configSchema.js.map +1 -1
  357. package/esm/shared/BaseDisplayComponent.d.ts +8 -0
  358. package/esm/shared/BaseDisplayComponent.js +44 -0
  359. package/esm/shared/BaseDisplayComponent.js.map +1 -0
  360. package/esm/shared/FilterByTag.d.ts +13 -12
  361. package/esm/shared/FilterByTag.js +8 -13
  362. package/esm/shared/FilterByTag.js.map +1 -1
  363. package/esm/shared/afterAttach.d.ts +2 -0
  364. package/esm/shared/afterAttach.js +40 -0
  365. package/esm/shared/afterAttach.js.map +1 -0
  366. package/esm/shared/color.d.ts +44 -6
  367. package/esm/shared/color.js +54 -20
  368. package/esm/shared/color.js.map +1 -1
  369. package/esm/shared/fetchChains.d.ts +3 -2
  370. package/esm/shared/fetchChains.js +14 -20
  371. package/esm/shared/fetchChains.js.map +1 -1
  372. package/esm/shared/renderSvg.d.ts +7 -0
  373. package/esm/shared/renderSvg.js +39 -0
  374. package/esm/shared/renderSvg.js.map +1 -0
  375. package/esm/shared/util.d.ts +2 -0
  376. package/esm/shared/util.js +9 -0
  377. package/esm/shared/util.js.map +1 -0
  378. package/esm/util.d.ts +16 -2
  379. package/esm/util.js +42 -3
  380. package/esm/util.js.map +1 -1
  381. package/package.json +3 -3
  382. package/src/AlignmentsFeatureDetail/AlignmentsFeatureFlags.tsx +3 -5
  383. package/src/AlignmentsFeatureDetail/__snapshots__/index.test.tsx.snap +1 -2
  384. package/src/AlignmentsTrack/configSchemaF.ts +22 -0
  385. package/src/AlignmentsTrack/index.ts +3 -24
  386. package/src/BamAdapter/BamAdapter.ts +46 -44
  387. package/src/CombinationTest.test.ts +2 -2
  388. package/src/CramAdapter/CramAdapter.ts +70 -56
  389. package/src/CramAdapter/CramSlightlyLazyFeature.ts +2 -5
  390. package/src/CramAdapter/CramTestAdapters.ts +2 -2
  391. package/src/LinearAlignmentsDisplay/models/model.tsx +16 -4
  392. package/src/LinearPileupDisplay/components/ColorByModifications.tsx +3 -39
  393. package/src/LinearPileupDisplay/components/ColorByTag.tsx +1 -6
  394. package/src/LinearPileupDisplay/components/LinearPileupDisplayBlurb.tsx +10 -11
  395. package/src/LinearPileupDisplay/components/ModificationsTable.tsx +38 -0
  396. package/src/LinearPileupDisplay/components/SetMaxHeight.tsx +3 -5
  397. package/src/LinearPileupDisplay/model.ts +235 -186
  398. package/src/LinearReadArcsDisplay/components/ReactComponent.tsx +23 -61
  399. package/src/LinearReadArcsDisplay/drawFeats.ts +79 -87
  400. package/src/LinearReadArcsDisplay/model.tsx +77 -155
  401. package/src/LinearReadArcsDisplay/util.ts +10 -0
  402. package/src/LinearReadCloudDisplay/components/ReactComponent.tsx +21 -59
  403. package/src/LinearReadCloudDisplay/drawFeats.ts +12 -166
  404. package/src/LinearReadCloudDisplay/drawLongReadChains.ts +85 -0
  405. package/src/LinearReadCloudDisplay/drawPairChains.ts +139 -0
  406. package/src/LinearReadCloudDisplay/model.tsx +72 -131
  407. package/src/LinearReadCloudDisplay/util.ts +47 -0
  408. package/src/LinearSNPCoverageDisplay/models/model.ts +63 -50
  409. package/src/MismatchParser/index.ts +46 -4
  410. package/src/PileupRPC/methods/GetReducedFeatures.ts +2 -10
  411. package/src/PileupRenderer/PileupLayoutSession.ts +1 -1
  412. package/src/PileupRenderer/PileupRenderer.ts +23 -1190
  413. package/src/PileupRenderer/colorBy.ts +74 -0
  414. package/src/PileupRenderer/components/PileupRendering.tsx +20 -25
  415. package/src/PileupRenderer/getAlignmentShapeColor.ts +87 -0
  416. package/src/PileupRenderer/index.ts +1 -1
  417. package/src/PileupRenderer/layoutFeature.ts +83 -0
  418. package/src/PileupRenderer/layoutFeatures.ts +44 -0
  419. package/src/PileupRenderer/makeImageData.ts +93 -0
  420. package/src/PileupRenderer/renderAlignment.ts +97 -0
  421. package/src/PileupRenderer/renderAlignmentShape.ts +45 -0
  422. package/src/PileupRenderer/renderMethylation.ts +75 -0
  423. package/src/PileupRenderer/renderMismatches.ts +206 -0
  424. package/src/PileupRenderer/renderModifications.ts +74 -0
  425. package/src/PileupRenderer/renderPerBaseLettering.ts +67 -0
  426. package/src/PileupRenderer/renderPerBaseQuality.ts +46 -0
  427. package/src/PileupRenderer/renderSoftClipping.ts +78 -0
  428. package/src/PileupRenderer/sortUtil.ts +1 -3
  429. package/src/PileupRenderer/util.ts +63 -0
  430. package/src/SNPCoverageAdapter/SNPCoverageAdapter.ts +5 -5
  431. package/src/SNPCoverageAdapter/generateCoverageBins.ts +105 -91
  432. package/src/SNPCoverageAdapter/index.ts +0 -2
  433. package/src/SNPCoverageAdapter/util.ts +33 -0
  434. package/src/SNPCoverageRenderer/SNPCoverageRenderer.ts +3 -3
  435. package/src/SNPCoverageRenderer/configSchema.ts +6 -0
  436. package/src/shared/BaseDisplayComponent.tsx +83 -0
  437. package/src/shared/FilterByTag.tsx +13 -23
  438. package/src/shared/afterAttach.tsx +66 -0
  439. package/src/shared/color.ts +59 -20
  440. package/src/shared/fetchChains.ts +23 -24
  441. package/src/shared/renderSvg.tsx +64 -0
  442. package/src/shared/util.ts +10 -0
  443. package/src/util.ts +54 -5
@@ -0,0 +1,44 @@
1
+ import { readConfObject, } from '@jbrowse/core/configuration';
2
+ import { bpSpanPx } from '@jbrowse/core/util';
3
+ import { fillRect, getCharWidthHeight } from './util';
4
+ export function renderSoftClipping({ ctx, feat, renderArgs, config, theme, colorForBase, canvasWidth, }) {
5
+ const { feature, topPx, heightPx } = feat;
6
+ const { regions, bpPerPx } = renderArgs;
7
+ const [region] = regions;
8
+ const minFeatWidth = readConfObject(config, 'minSubfeatureWidth');
9
+ const mismatches = feature.get('mismatches');
10
+ const seq = feature.get('seq');
11
+ const { charWidth, charHeight } = getCharWidthHeight();
12
+ // Display all bases softclipped off in lightened colors
13
+ if (!(seq && mismatches)) {
14
+ return;
15
+ }
16
+ mismatches
17
+ .filter(mismatch => mismatch.type === 'softclip')
18
+ .forEach(mismatch => {
19
+ const len = mismatch.cliplen || 0;
20
+ const s = feature.get('start');
21
+ const start = mismatch.start === 0 ? s - len : s + mismatch.start;
22
+ for (let k = 0; k < len; k += 1) {
23
+ const base = seq.charAt(k + mismatch.start);
24
+ // If softclip length+start is longer than sequence, no need to
25
+ // continue showing base
26
+ if (!base) {
27
+ return;
28
+ }
29
+ const s0 = start + k;
30
+ const [leftPx, rightPx] = bpSpanPx(s0, s0 + 1, region, bpPerPx);
31
+ const widthPx = Math.max(minFeatWidth, rightPx - leftPx);
32
+ // Black accounts for IUPAC ambiguity code bases such as N that
33
+ // show in soft clipping
34
+ const baseColor = colorForBase[base] || '#000000';
35
+ ctx.fillStyle = baseColor;
36
+ fillRect(ctx, leftPx, topPx, widthPx, heightPx, canvasWidth);
37
+ if (widthPx >= charWidth && heightPx >= charHeight - 5) {
38
+ ctx.fillStyle = theme.palette.getContrastText(baseColor);
39
+ ctx.fillText(base, leftPx + (widthPx - charWidth) / 2 + 1, topPx + heightPx);
40
+ }
41
+ }
42
+ });
43
+ }
44
+ //# sourceMappingURL=renderSoftClipping.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"renderSoftClipping.js","sourceRoot":"","sources":["../../src/PileupRenderer/renderSoftClipping.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,cAAc,GACf,MAAM,6BAA6B,CAAA;AACpC,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAM7C,OAAO,EAAE,QAAQ,EAAE,kBAAkB,EAAiB,MAAM,QAAQ,CAAA;AAEpE,MAAM,UAAU,kBAAkB,CAAC,EACjC,GAAG,EACH,IAAI,EACJ,UAAU,EACV,MAAM,EACN,KAAK,EACL,YAAY,EACZ,WAAW,GASZ;IACC,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAA;IACzC,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,UAAU,CAAA;IACvC,MAAM,CAAC,MAAM,CAAC,GAAG,OAAO,CAAA;IACxB,MAAM,YAAY,GAAG,cAAc,CAAC,MAAM,EAAE,oBAAoB,CAAC,CAAA;IACjE,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY,CAA2B,CAAA;IACtE,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAuB,CAAA;IACpD,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAEtD,wDAAwD;IACxD,IAAI,CAAC,CAAC,GAAG,IAAI,UAAU,CAAC,EAAE;QACxB,OAAM;KACP;IACD,UAAU;SACP,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,KAAK,UAAU,CAAC;SAChD,OAAO,CAAC,QAAQ,CAAC,EAAE;QAClB,MAAM,GAAG,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAA;QACjC,MAAM,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QAC9B,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAA;QAEjE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE;YAC/B,MAAM,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;YAE3C,+DAA+D;YAC/D,wBAAwB;YACxB,IAAI,CAAC,IAAI,EAAE;gBACT,OAAM;aACP;YAED,MAAM,EAAE,GAAG,KAAK,GAAG,CAAC,CAAA;YACpB,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;YAC/D,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,OAAO,GAAG,MAAM,CAAC,CAAA;YAExD,+DAA+D;YAC/D,wBAAwB;YACxB,MAAM,SAAS,GAAG,YAAY,CAAC,IAAI,CAAC,IAAI,SAAS,CAAA;YACjD,GAAG,CAAC,SAAS,GAAG,SAAS,CAAA;YACzB,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAA;YAE5D,IAAI,OAAO,IAAI,SAAS,IAAI,QAAQ,IAAI,UAAU,GAAG,CAAC,EAAE;gBACtD,GAAG,CAAC,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,SAAS,CAAC,CAAA;gBACxD,GAAG,CAAC,QAAQ,CACV,IAAI,EACJ,MAAM,GAAG,CAAC,OAAO,GAAG,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,EACtC,KAAK,GAAG,QAAQ,CACjB,CAAA;aACF;SACF;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
@@ -72,10 +72,9 @@ export const sortFeature = (features, sortedBy) => {
72
72
  break;
73
73
  }
74
74
  }
75
- const sortedMap = new Map([...featuresInCenterLine, ...featuresOutsideCenter].map(feature => [
75
+ return new Map([...featuresInCenterLine, ...featuresOutsideCenter].map(feature => [
76
76
  feature.id(),
77
77
  feature,
78
78
  ]));
79
- return sortedMap;
80
79
  };
81
80
  //# sourceMappingURL=sortUtil.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"sortUtil.js","sourceRoot":"","sources":["../../src/PileupRenderer/sortUtil.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"sortUtil.js","sourceRoot":"","sources":["../../src/PileupRenderer/sortUtil.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import { Feature } from '@jbrowse/core/util';
2
+ import { Theme } from '@mui/material';
3
+ export declare function fillRect(ctx: CanvasRenderingContext2D, l: number, t: number, w: number, h: number, cw: number, color?: string): void;
4
+ export declare function getColorBaseMap(theme: Theme): {
5
+ A: string;
6
+ C: string;
7
+ G: string;
8
+ T: string;
9
+ deletion: string;
10
+ };
11
+ export declare function getContrastBaseMap(theme: Theme): {
12
+ [k: string]: string;
13
+ };
14
+ export declare function shouldDrawSNPsMuted(type?: string): boolean;
15
+ export declare function shouldDrawIndels(): boolean;
16
+ export interface LayoutFeature {
17
+ heightPx: number;
18
+ topPx: number;
19
+ feature: Feature;
20
+ }
21
+ export declare function getCharWidthHeight(): {
22
+ charWidth: number;
23
+ charHeight: number;
24
+ };
@@ -0,0 +1,42 @@
1
+ import { measureText } from '@jbrowse/core/util';
2
+ export function fillRect(ctx, l, t, w, h, cw, color) {
3
+ if (l + w < 0 || l > cw) {
4
+ return;
5
+ }
6
+ else {
7
+ if (color) {
8
+ ctx.fillStyle = color;
9
+ }
10
+ ctx.fillRect(l, t, w, h);
11
+ }
12
+ }
13
+ export function getColorBaseMap(theme) {
14
+ const { bases } = theme.palette;
15
+ return {
16
+ A: bases.A.main,
17
+ C: bases.C.main,
18
+ G: bases.G.main,
19
+ T: bases.T.main,
20
+ deletion: '#808080', // gray
21
+ };
22
+ }
23
+ export function getContrastBaseMap(theme) {
24
+ return Object.fromEntries(Object.entries(getColorBaseMap(theme)).map(([key, value]) => [
25
+ key,
26
+ theme.palette.getContrastText(value),
27
+ ]));
28
+ }
29
+ export function shouldDrawSNPsMuted(type) {
30
+ return ['methylation', 'modifications'].includes(type || '');
31
+ }
32
+ export function shouldDrawIndels() {
33
+ return true;
34
+ }
35
+ // get width and height of chars the height is an approximation: width letter M
36
+ // is approximately the height
37
+ export function getCharWidthHeight() {
38
+ const charWidth = measureText('A');
39
+ const charHeight = measureText('M') - 2;
40
+ return { charWidth, charHeight };
41
+ }
42
+ //# sourceMappingURL=util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/PileupRenderer/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,WAAW,EAAE,MAAM,oBAAoB,CAAA;AAGzD,MAAM,UAAU,QAAQ,CACtB,GAA6B,EAC7B,CAAS,EACT,CAAS,EACT,CAAS,EACT,CAAS,EACT,EAAU,EACV,KAAc;IAEd,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE;QACvB,OAAM;KACP;SAAM;QACL,IAAI,KAAK,EAAE;YACT,GAAG,CAAC,SAAS,GAAG,KAAK,CAAA;SACtB;QACD,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;KACzB;AACH,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,KAAY;IAC1C,MAAM,EAAE,KAAK,EAAE,GAAG,KAAK,CAAC,OAAO,CAAA;IAC/B,OAAO;QACL,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI;QACf,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI;QACf,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI;QACf,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI;QACf,QAAQ,EAAE,SAAS,EAAE,OAAO;KAC7B,CAAA;AACH,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,KAAY;IAC7C,OAAO,MAAM,CAAC,WAAW,CACvB,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC;QAC3D,GAAG;QACH,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC;KACrC,CAAC,CACH,CAAA;AACH,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,IAAa;IAC/C,OAAO,CAAC,aAAa,EAAE,eAAe,CAAC,CAAC,QAAQ,CAAC,IAAI,IAAI,EAAE,CAAC,CAAA;AAC9D,CAAC;AAED,MAAM,UAAU,gBAAgB;IAC9B,OAAO,IAAI,CAAA;AACb,CAAC;AAQD,+EAA+E;AAC/E,8BAA8B;AAC9B,MAAM,UAAU,kBAAkB;IAChC,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,CAAC,CAAA;IAClC,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;IACvC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,CAAA;AAClC,CAAC"}
@@ -8,9 +8,7 @@ export default class SNPCoverageAdapter extends BaseFeatureDataAdapter {
8
8
  }>;
9
9
  fetchSequence(region: Region): Promise<any>;
10
10
  getFeatures(region: Region, opts?: BaseOptions): import("rxjs").Observable<Feature>;
11
- estimateRegionsStats(regions: Region[], opts?: BaseOptions): Promise<import("@jbrowse/core/data_adapters/BaseAdapter").Stats>;
11
+ getMultiRegionFeatureDensityStats(regions: Region[], opts?: BaseOptions): Promise<import("@jbrowse/core/data_adapters/BaseAdapter").FeatureDensityStats>;
12
12
  getRefNames(opts?: BaseOptions): Promise<string[]>;
13
13
  freeResources(): void;
14
14
  }
15
- declare const capabilities: string[];
16
- export { capabilities };
@@ -65,9 +65,9 @@ export default class SNPCoverageAdapter extends BaseFeatureDataAdapter {
65
65
  observer.complete();
66
66
  }, opts.signal);
67
67
  }
68
- async estimateRegionsStats(regions, opts) {
68
+ async getMultiRegionFeatureDensityStats(regions, opts) {
69
69
  const { subadapter } = await this.configure();
70
- return subadapter.estimateRegionsStats(regions, opts);
70
+ return subadapter.getMultiRegionFeatureDensityStats(regions, opts);
71
71
  }
72
72
  async getRefNames(opts = {}) {
73
73
  const { subadapter } = await this.configure();
@@ -75,6 +75,4 @@ export default class SNPCoverageAdapter extends BaseFeatureDataAdapter {
75
75
  }
76
76
  freeResources( /* { region } */) { }
77
77
  }
78
- const { capabilities } = SNPCoverageAdapter;
79
- export { capabilities };
80
78
  //# sourceMappingURL=SNPCoverageAdapter.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SNPCoverageAdapter.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/SNPCoverageAdapter.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"SNPCoverageAdapter.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/SNPCoverageAdapter.ts"],"names":[],"mappings":"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"}
@@ -1,2 +1,11 @@
1
- declare const configSchema: import("@jbrowse/core/configuration").AnyConfigurationSchemaType;
1
+ declare const configSchema: import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaType<{
2
+ /**
3
+ * #slot
4
+ * normally refers to a BAM or CRAM adapter
5
+ */
6
+ subadapter: {
7
+ type: string;
8
+ defaultValue: null;
9
+ };
10
+ }, import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaOptions<undefined, undefined>>;
2
11
  export default configSchema;
@@ -1,5 +1,6 @@
1
1
  import { AugmentedRegion as Region } from '@jbrowse/core/util/types';
2
2
  import { Feature } from '@jbrowse/core/util/simpleFeature';
3
+ import { Bin, SkipMap } from './util';
3
4
  export default function generateCoverageBins(features: Feature[], region: Region, opts: {
4
5
  bpPerPx?: number;
5
6
  colorBy?: {
@@ -7,47 +8,6 @@ export default function generateCoverageBins(features: Feature[], region: Region
7
8
  tag?: string;
8
9
  };
9
10
  }, fetchSequence: (arg: Region) => Promise<string>): Promise<{
10
- bins: {
11
- refbase?: string | undefined;
12
- total: number;
13
- all: number;
14
- ref: number;
15
- '-1': 0;
16
- '0': 0;
17
- '1': 0;
18
- lowqual: {
19
- total: number;
20
- strands: {
21
- [key: string]: number;
22
- };
23
- };
24
- cov: {
25
- total: number;
26
- strands: {
27
- [key: string]: number;
28
- };
29
- };
30
- delskips: {
31
- total: number;
32
- strands: {
33
- [key: string]: number;
34
- };
35
- };
36
- noncov: {
37
- total: number;
38
- strands: {
39
- [key: string]: number;
40
- };
41
- };
42
- }[];
43
- skipmap: {
44
- [key: string]: {
45
- score: number;
46
- feature: unknown;
47
- start: number;
48
- end: number;
49
- strand: number;
50
- xs: string;
51
- };
52
- };
11
+ bins: Bin[];
12
+ skipmap: SkipMap;
53
13
  }>;
@@ -1,5 +1,6 @@
1
1
  import { getTag, getTagAlt, shouldFetchReferenceSequence } from '../util';
2
- import { parseCigar, getNextRefPos, getModificationPositions, } from '../MismatchParser';
2
+ import { parseCigar, getNextRefPos, getModificationPositions, getMethBins, } from '../MismatchParser';
3
+ import { doesIntersect2 } from '@jbrowse/core/util';
3
4
  function mismatchLen(mismatch) {
4
5
  return !isInterbase(mismatch.type) ? mismatch.length : 1;
5
6
  }
@@ -21,19 +22,24 @@ function inc(bin, strand, type, field) {
21
22
  thisBin[strand]++;
22
23
  }
23
24
  export default async function generateCoverageBins(features, region, opts, fetchSequence) {
24
- var _a;
25
+ var _a, _b, _c;
25
26
  const { colorBy } = opts;
26
- const binMax = Math.ceil(region.end - region.start);
27
+ const extendedRegion = {
28
+ ...region,
29
+ start: Math.max(0, region.start - 1),
30
+ end: region.end + 1,
31
+ };
32
+ const binMax = Math.ceil(extendedRegion.end - extendedRegion.start);
27
33
  const skipmap = {};
28
- const regionSeq = features.length && shouldFetchReferenceSequence((_a = opts.colorBy) === null || _a === void 0 ? void 0 : _a.type)
34
+ const regionSequence = features.length && shouldFetchReferenceSequence((_a = opts.colorBy) === null || _a === void 0 ? void 0 : _a.type)
29
35
  ? await fetchSequence(region)
30
36
  : undefined;
31
37
  const bins = [];
32
- for (let i = 0; i < features.length; i++) {
33
- const feature = features[i];
38
+ for (const feature of features) {
34
39
  const fstart = feature.get('start');
35
40
  const fend = feature.get('end');
36
41
  const fstrand = feature.get('strand');
42
+ const mismatches = feature.get('mismatches') || [];
37
43
  for (let j = fstart; j < fend + 1; j++) {
38
44
  const i = j - region.start;
39
45
  if (i >= 0 && i < binMax) {
@@ -64,77 +70,98 @@ export default async function generateCoverageBins(features, region, opts, fetch
64
70
  const mm = getTagAlt(feature, 'MM', 'Mm') || '';
65
71
  const ops = parseCigar(feature.get('CIGAR'));
66
72
  const fend = feature.get('end');
67
- getModificationPositions(mm, seq, fstrand).forEach(({ type, positions }) => {
68
- const mod = `mod_${type}`;
69
- for (const pos of getNextRefPos(ops, positions)) {
70
- const epos = pos + fstart - region.start;
71
- if (epos >= 0 && epos < bins.length && pos + fstart < fend) {
72
- const bin = bins[epos];
73
- if (bin) {
74
- inc(bin, fstrand, 'cov', mod);
75
- }
76
- else {
77
- console.warn('Undefined position in modifications snpcoverage encountered');
73
+ if (seq) {
74
+ const modifications = getModificationPositions(mm, seq, fstrand);
75
+ for (const { type, positions } of modifications) {
76
+ const mod = `mod_${type}`;
77
+ for (const pos of getNextRefPos(ops, positions)) {
78
+ const epos = pos + fstart - region.start;
79
+ if (epos >= 0 && epos < bins.length && pos + fstart < fend) {
80
+ if (bins[epos] === undefined) {
81
+ bins[epos] = {
82
+ total: 0,
83
+ all: 0,
84
+ ref: 0,
85
+ '-1': 0,
86
+ '0': 0,
87
+ '1': 0,
88
+ lowqual: {},
89
+ cov: {},
90
+ delskips: {},
91
+ noncov: {},
92
+ };
93
+ }
94
+ const bin = bins[epos];
95
+ if (bin) {
96
+ inc(bin, fstrand, 'cov', mod);
97
+ }
98
+ else {
99
+ console.warn('Undefined position in modifications snpcoverage encountered');
100
+ }
78
101
  }
79
102
  }
80
103
  }
81
- });
104
+ }
82
105
  }
83
- // methylation based coloring takes into account both reference
84
- // sequence CpG detection and reads
85
- else if ((colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) === 'methylation') {
86
- if (!regionSeq) {
106
+ if ((colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) === 'methylation') {
107
+ if (!regionSequence) {
87
108
  throw new Error('no region sequence detected, need sequenceAdapter configuration');
88
109
  }
89
110
  const seq = feature.get('seq');
90
- const mm = getTagAlt(feature, 'MM', 'Mm') || '';
91
- const methBins = new Array(region.end - region.start).fill(0);
92
- const ops = parseCigar(feature.get('CIGAR'));
93
- getModificationPositions(mm, seq, fstrand).forEach(({ type, positions }) => {
94
- // we are processing methylation
95
- if (type === 'm') {
96
- for (const pos of getNextRefPos(ops, positions)) {
97
- const epos = pos + fstart - region.start;
98
- if (epos >= 0 && epos < methBins.length) {
99
- methBins[epos] = 1;
100
- }
101
- }
102
- }
103
- });
104
- for (let j = fstart; j < fend; j++) {
105
- const i = j - region.start;
106
- if (i >= 0 && i < bins.length - 1) {
107
- const l1 = regionSeq[i].toLowerCase();
108
- const l2 = regionSeq[i + 1].toLowerCase();
109
- const bin = bins[i];
110
- const bin1 = bins[i + 1];
111
+ if (!seq) {
112
+ continue;
113
+ }
114
+ const { methBins, methProbs } = getMethBins(feature);
115
+ const dels = mismatches.filter(f => f.type === 'deletion');
116
+ // methylation based coloring takes into account both reference sequence
117
+ // CpG detection and reads
118
+ for (let i = 0; i < fend - fstart; i++) {
119
+ const j = i + fstart;
120
+ const l1 = (_b = regionSequence[j - region.start + 1]) === null || _b === void 0 ? void 0 : _b.toLowerCase();
121
+ const l2 = (_c = regionSequence[j - region.start + 2]) === null || _c === void 0 ? void 0 : _c.toLowerCase();
122
+ if (l1 === 'c' && l2 === 'g') {
123
+ const bin0 = bins[j - region.start];
124
+ const bin1 = bins[j - region.start + 1];
125
+ const b0 = methBins[i];
126
+ const b1 = methBins[i + 1];
127
+ const p0 = methProbs[i];
128
+ const p1 = methProbs[i + 1];
111
129
  // color
112
- if (l1 === 'c' && l2 === 'g') {
113
- if (methBins[i] || methBins[i + 1]) {
114
- inc(bin, fstrand, 'cov', 'meth');
130
+ if ((b0 && (p0 !== undefined ? p0 > 0.5 : true)) ||
131
+ (b1 && (p1 !== undefined ? p1 > 0.5 : true))) {
132
+ if (bin0) {
133
+ inc(bin0, fstrand, 'cov', 'meth');
134
+ bin0.ref--;
135
+ bin0[fstrand]--;
136
+ }
137
+ if (bin1) {
115
138
  inc(bin1, fstrand, 'cov', 'meth');
116
- bins[i].ref--;
117
- bins[i][fstrand]--;
118
- bins[i + 1].ref--;
119
- bins[i + 1][fstrand]--;
139
+ bin1.ref--;
140
+ bin1[fstrand]--;
120
141
  }
121
- else {
122
- inc(bin, fstrand, 'cov', 'unmeth');
123
- inc(bin1, fstrand, 'cov', 'unmeth');
124
- bins[i].ref--;
125
- bins[i][fstrand]--;
126
- bins[i + 1].ref--;
127
- bins[i + 1][fstrand]--;
142
+ }
143
+ else {
144
+ if (bin0) {
145
+ if (!(dels === null || dels === void 0 ? void 0 : dels.some(d => doesIntersect2(j, j + 1, d.start + fstart, d.start + fstart + d.length)))) {
146
+ inc(bin0, fstrand, 'cov', 'unmeth');
147
+ bin0.ref--;
148
+ bin0[fstrand];
149
+ }
150
+ }
151
+ if (bin1) {
152
+ if (!(dels === null || dels === void 0 ? void 0 : dels.some(d => doesIntersect2(j + 1, j + 2, d.start + fstart, d.start + fstart + d.length)))) {
153
+ inc(bin1, fstrand, 'cov', 'unmeth');
154
+ bin1.ref--;
155
+ bin1[fstrand]--;
156
+ }
128
157
  }
129
158
  }
130
159
  }
131
160
  }
132
161
  }
133
162
  // normal SNP based coloring
134
- const mismatches = feature.get('mismatches') || [];
135
163
  const colorSNPs = (colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) !== 'modifications' && (colorBy === null || colorBy === void 0 ? void 0 : colorBy.type) !== 'methylation';
136
- for (let i = 0; i < mismatches.length; i++) {
137
- const mismatch = mismatches[i];
164
+ for (const mismatch of mismatches) {
138
165
  const mstart = fstart + mismatch.start;
139
166
  const mlen = mismatchLen(mismatch);
140
167
  const mend = mstart + mlen;
@@ -1 +1 @@
1
- {"version":3,"file":"generateCoverageBins.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/generateCoverageBins.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"generateCoverageBins.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/generateCoverageBins.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,5 @@
1
1
  import AdapterType from '@jbrowse/core/pluggableElementTypes/AdapterType';
2
2
  import configSchema from './configSchema';
3
- import { capabilities } from './SNPCoverageAdapter';
4
3
  export default function (pluginManager) {
5
4
  pluginManager.addAdapterType(() => {
6
5
  return new AdapterType({
@@ -11,7 +10,6 @@ export default function (pluginManager) {
11
10
  },
12
11
  getAdapterClass: () => import('./SNPCoverageAdapter').then(r => r.default),
13
12
  configSchema,
14
- adapterCapabilities: capabilities,
15
13
  });
16
14
  });
17
15
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,WAAW,MAAM,iDAAiD,CAAA;AACzE,OAAO,YAAY,MAAM,gBAAgB,CAAA;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAEnD,MAAM,CAAC,OAAO,WAAW,aAA4B;IACnD,aAAa,CAAC,cAAc,CAAC,GAAG,EAAE;QAChC,OAAO,IAAI,WAAW,CAAC;YACrB,IAAI,EAAE,oBAAoB;YAC1B,WAAW,EAAE,qBAAqB;YAClC,eAAe,EAAE;gBACf,aAAa,EAAE,IAAI;aACpB;YACD,eAAe,EAAE,GAAG,EAAE,CACpB,MAAM,CAAC,sBAAsB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YACrD,YAAY;YACZ,mBAAmB,EAAE,YAAY;SAClC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,WAAW,MAAM,iDAAiD,CAAA;AACzE,OAAO,YAAY,MAAM,gBAAgB,CAAA;AAEzC,MAAM,CAAC,OAAO,WAAW,aAA4B;IACnD,aAAa,CAAC,cAAc,CAAC,GAAG,EAAE;QAChC,OAAO,IAAI,WAAW,CAAC;YACrB,IAAI,EAAE,oBAAoB;YAC1B,WAAW,EAAE,qBAAqB;YAClC,eAAe,EAAE;gBACf,aAAa,EAAE,IAAI;aACpB;YACD,eAAe,EAAE,GAAG,EAAE,CACpB,MAAM,CAAC,sBAAsB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YACrD,YAAY;SACb,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC"}
@@ -0,0 +1,29 @@
1
+ export interface SkipMap {
2
+ [key: string]: {
3
+ score: number;
4
+ feature: unknown;
5
+ start: number;
6
+ end: number;
7
+ strand: number;
8
+ xs: string;
9
+ };
10
+ }
11
+ export interface BinType {
12
+ total?: number;
13
+ strands?: {
14
+ [key: string]: number;
15
+ };
16
+ }
17
+ export interface Bin {
18
+ refbase?: string;
19
+ total: number;
20
+ all: number;
21
+ ref: number;
22
+ '-1': number;
23
+ '0': number;
24
+ '1': number;
25
+ lowqual: BinType;
26
+ cov: BinType;
27
+ delskips: BinType;
28
+ noncov: BinType;
29
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/SNPCoverageAdapter/util.ts"],"names":[],"mappings":""}
@@ -13,7 +13,7 @@ export interface RenderArgsDeserializedWithFeatures extends RenderArgsDeserializ
13
13
  values: number[];
14
14
  };
15
15
  displayCrossHatches: boolean;
16
- modificationTagMap?: Record<string, string>;
16
+ modificationTagMap?: Record<string, string | undefined>;
17
17
  }
18
18
  export default class SNPCoverageRenderer extends WiggleBaseRenderer {
19
19
  draw(ctx: CanvasRenderingContext2D, props: RenderArgsDeserializedWithFeatures): Promise<void>;
@@ -46,10 +46,10 @@ export default class SNPCoverageRenderer extends WiggleBaseRenderer {
46
46
  C: bases.C.main,
47
47
  G: bases.G.main,
48
48
  T: bases.T.main,
49
- total: 'lightgrey',
50
49
  insertion: 'purple',
51
50
  softclip: 'blue',
52
51
  hardclip: 'red',
52
+ total: readConfObject(cfg, 'color'),
53
53
  meth: 'red',
54
54
  unmeth: 'blue',
55
55
  };
@@ -93,7 +93,7 @@ export default class SNPCoverageRenderer extends WiggleBaseRenderer {
93
93
  ctx.fillStyle =
94
94
  colorForBase[base] ||
95
95
  modificationTagMap[base.replace('mod_', '')] ||
96
- '#888';
96
+ 'black';
97
97
  const height = toHeight(score);
98
98
  const bottom = toY(score) + height;
99
99
  ctx.fillRect(Math.round(leftPx), bottom - ((total + curr) / score) * height, w, (total / score) * height);