@jbrowse/plugin-variants 3.2.0 → 3.4.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 (239) hide show
  1. package/dist/LinearVariantDisplay/model.d.ts +1 -1
  2. package/dist/MultiLinearVariantDisplay/components/VariantDisplayComponent.js +3 -3
  3. package/dist/MultiLinearVariantDisplay/index.js +1 -1
  4. package/dist/MultiLinearVariantDisplay/model.d.ts +40 -4
  5. package/dist/MultiLinearVariantDisplay/model.js +0 -1
  6. package/dist/MultiLinearVariantDisplay/renderSvg.js +2 -2
  7. package/dist/MultiLinearVariantMatrixDisplay/components/LinesConnectingMatrixToGenomicPosition.js +15 -5
  8. package/dist/MultiLinearVariantMatrixDisplay/components/VariantDisplayComponent.js +3 -3
  9. package/dist/MultiLinearVariantMatrixDisplay/index.js +1 -1
  10. package/dist/MultiLinearVariantMatrixDisplay/model.d.ts +40 -3
  11. package/dist/MultiLinearVariantMatrixDisplay/model.js +1 -0
  12. package/dist/MultiLinearVariantMatrixDisplay/renderSvg.js +2 -2
  13. package/dist/MultiLinearVariantMatrixRenderer/{LinearVariantMatrixRenderer.d.ts → MultiLinearVariantMatrixRenderer.d.ts} +14 -11
  14. package/dist/MultiLinearVariantMatrixRenderer/{LinearVariantMatrixRenderer.js → MultiLinearVariantMatrixRenderer.js} +3 -3
  15. package/dist/MultiLinearVariantMatrixRenderer/components/MultiLinearVariantMatrixRendering.d.ts +8 -0
  16. package/dist/MultiLinearVariantMatrixRenderer/components/MultiLinearVariantMatrixRendering.js +41 -0
  17. package/dist/MultiLinearVariantMatrixRenderer/index.js +4 -4
  18. package/dist/MultiLinearVariantMatrixRenderer/makeImageData.d.ts +3 -3
  19. package/dist/MultiLinearVariantMatrixRenderer/makeImageData.js +71 -17
  20. package/dist/MultiLinearVariantMatrixRenderer/types.d.ts +2 -4
  21. package/dist/MultiLinearVariantRenderer/MultiVariantRenderer.d.ts +34 -5
  22. package/dist/MultiLinearVariantRenderer/MultiVariantRenderer.js +13 -7
  23. package/dist/MultiLinearVariantRenderer/components/{MultiVariantRendering.d.ts → MultiLinearVariantRendering.d.ts} +10 -4
  24. package/dist/MultiLinearVariantRenderer/{MultiVariantRendering.js → components/MultiLinearVariantRendering.js} +25 -7
  25. package/dist/MultiLinearVariantRenderer/components/util.d.ts +1 -0
  26. package/dist/MultiLinearVariantRenderer/components/util.js +15 -0
  27. package/dist/MultiLinearVariantRenderer/index.js +2 -2
  28. package/dist/MultiLinearVariantRenderer/makeImageData.d.ts +9 -0
  29. package/dist/MultiLinearVariantRenderer/makeImageData.js +104 -41
  30. package/dist/MultiLinearVariantRenderer/types.d.ts +2 -0
  31. package/dist/MultiVariantBaseRenderer.d.ts +4 -4
  32. package/dist/SplitVcfTabixAdapter/SplitVcfTabixAdapter.d.ts +0 -1
  33. package/dist/SplitVcfTabixAdapter/SplitVcfTabixAdapter.js +0 -1
  34. package/dist/SplitVcfTabixAdapter/configSchema.js +4 -2
  35. package/dist/VariantFeatureWidget/AltFormatter.d.ts +4 -0
  36. package/dist/VariantFeatureWidget/AltFormatter.js +13 -0
  37. package/dist/VariantFeatureWidget/Checkbox2.js +1 -8
  38. package/dist/VariantFeatureWidget/Formatter.d.ts +3 -0
  39. package/dist/VariantFeatureWidget/Formatter.js +23 -0
  40. package/dist/VariantFeatureWidget/{VariantConsequenceDataGridWrapper.js → VariantConsequence/VariantConsequenceDataGridWrapper.js} +3 -5
  41. package/dist/VariantFeatureWidget/VariantFeatureWidget.js +16 -6
  42. package/dist/VariantFeatureWidget/VariantSampleGrid/VariantGenotypeFrequencyTable.d.ts +4 -0
  43. package/dist/VariantFeatureWidget/VariantSampleGrid/VariantGenotypeFrequencyTable.js +80 -0
  44. package/dist/VariantFeatureWidget/VariantSampleGrid/VariantSampleGrid.d.ts +3 -9
  45. package/dist/VariantFeatureWidget/VariantSampleGrid/VariantSampleGrid.js +41 -20
  46. package/dist/VariantFeatureWidget/VariantSampleGrid/types.d.ts +21 -0
  47. package/dist/VariantFeatureWidget/VariantSampleGrid/util.d.ts +1 -0
  48. package/dist/VariantFeatureWidget/VariantSampleGrid/util.js +14 -0
  49. package/dist/VariantFeatureWidget/stateModelFactory.d.ts +9 -6
  50. package/dist/VariantRPC/MultiVariantClusterGenotypeMatrix.d.ts +2 -16
  51. package/dist/VariantRPC/MultiVariantClusterGenotypeMatrix.js +4 -7
  52. package/dist/VariantRPC/MultiVariantGetGenotypeMatrix.d.ts +2 -15
  53. package/dist/VariantRPC/MultiVariantGetSimplifiedFeatures.d.ts +3 -13
  54. package/dist/VariantRPC/MultiVariantGetSimplifiedFeatures.js +14 -8
  55. package/dist/VariantRPC/getGenotypeMatrix.js +20 -7
  56. package/dist/VariantRPC/types.d.ts +23 -0
  57. package/dist/VcfAdapter/VcfAdapter.d.ts +0 -1
  58. package/dist/VcfAdapter/VcfAdapter.js +0 -1
  59. package/dist/VcfFeature/index.js +0 -1
  60. package/dist/VcfFeature/util.d.ts +2 -0
  61. package/dist/VcfFeature/util.js +123 -25
  62. package/dist/VcfTabixAdapter/VcfTabixAdapter.d.ts +0 -1
  63. package/dist/VcfTabixAdapter/VcfTabixAdapter.js +12 -8
  64. package/dist/getMultiVariantFeaturesAutorun.d.ts +2 -0
  65. package/dist/getMultiVariantFeaturesAutorun.js +9 -2
  66. package/dist/getMultiVariantSourcesAutorun.js +3 -2
  67. package/dist/shared/MultiVariantBaseModel.d.ts +41 -4
  68. package/dist/shared/MultiVariantBaseModel.js +69 -3
  69. package/dist/shared/SharedVariantMixin.d.ts +1 -1
  70. package/dist/shared/components/AddFiltersDialog.d.ts +9 -0
  71. package/dist/shared/components/AddFiltersDialog.js +61 -0
  72. package/dist/shared/components/MultiVariantBaseDisplayComponent.d.ts +5 -0
  73. package/dist/shared/components/MultiVariantBaseDisplayComponent.js +29 -0
  74. package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialog.js +2 -2
  75. package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogAuto.js +8 -3
  76. package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogManual.js +29 -28
  77. package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/types.d.ts +1 -0
  78. package/dist/shared/components/MultiVariantClusterDialog/types.js +2 -0
  79. package/{esm/shared/components/ColorLegend.d.ts → dist/shared/components/MultiVariantColorLegend.d.ts} +2 -2
  80. package/dist/shared/components/{ColorLegend.js → MultiVariantColorLegend.js} +5 -3
  81. package/dist/shared/components/MultiVariantCrosshairs.d.ts +7 -0
  82. package/dist/shared/components/MultiVariantCrosshairs.js +40 -0
  83. package/dist/shared/components/MultiVariantLegendBar.d.ts +7 -0
  84. package/dist/shared/components/{LegendBar.js → MultiVariantLegendBar.js} +2 -2
  85. package/dist/shared/components/MultiVariantTooltip.d.ts +4 -0
  86. package/dist/shared/components/MultiVariantTooltip.js +3 -2
  87. package/dist/shared/components/RectBg.js +4 -2
  88. package/dist/shared/components/SetColorDialog.js +1 -1
  89. package/dist/shared/components/SourcesDataGrid.d.ts +2 -1
  90. package/dist/shared/components/SourcesDataGrid.js +40 -47
  91. package/dist/shared/components/SourcesGrid.js +1 -1
  92. package/dist/shared/components/SourcesGridHeader.d.ts +2 -1
  93. package/dist/shared/drawAlleleCount.d.ts +2 -1
  94. package/dist/shared/drawAlleleCount.js +26 -24
  95. package/dist/shared/drawPhased.d.ts +1 -1
  96. package/dist/shared/drawPhased.js +14 -10
  97. package/dist/shared/minorAlleleFrequencyUtils.d.ts +9 -4
  98. package/dist/shared/minorAlleleFrequencyUtils.js +19 -14
  99. package/dist/shared/sourcesGridUtils.d.ts +3 -2
  100. package/esm/LinearVariantDisplay/model.d.ts +1 -1
  101. package/esm/MultiLinearVariantDisplay/components/VariantDisplayComponent.js +2 -2
  102. package/esm/MultiLinearVariantDisplay/index.js +1 -1
  103. package/esm/MultiLinearVariantDisplay/model.d.ts +40 -4
  104. package/esm/MultiLinearVariantDisplay/model.js +0 -1
  105. package/esm/MultiLinearVariantDisplay/renderSvg.js +1 -1
  106. package/esm/MultiLinearVariantMatrixDisplay/components/LinesConnectingMatrixToGenomicPosition.js +15 -8
  107. package/esm/MultiLinearVariantMatrixDisplay/components/VariantDisplayComponent.js +2 -2
  108. package/esm/MultiLinearVariantMatrixDisplay/index.js +1 -1
  109. package/esm/MultiLinearVariantMatrixDisplay/model.d.ts +40 -3
  110. package/esm/MultiLinearVariantMatrixDisplay/model.js +1 -0
  111. package/esm/MultiLinearVariantMatrixDisplay/renderSvg.js +1 -1
  112. package/esm/MultiLinearVariantMatrixRenderer/{LinearVariantMatrixRenderer.d.ts → MultiLinearVariantMatrixRenderer.d.ts} +14 -11
  113. package/esm/MultiLinearVariantMatrixRenderer/{LinearVariantMatrixRenderer.js → MultiLinearVariantMatrixRenderer.js} +3 -3
  114. package/esm/MultiLinearVariantMatrixRenderer/components/MultiLinearVariantMatrixRendering.d.ts +8 -0
  115. package/esm/MultiLinearVariantMatrixRenderer/components/MultiLinearVariantMatrixRendering.js +39 -0
  116. package/esm/MultiLinearVariantMatrixRenderer/index.js +4 -4
  117. package/esm/MultiLinearVariantMatrixRenderer/makeImageData.d.ts +3 -3
  118. package/esm/MultiLinearVariantMatrixRenderer/makeImageData.js +73 -19
  119. package/esm/MultiLinearVariantMatrixRenderer/types.d.ts +2 -4
  120. package/esm/MultiLinearVariantRenderer/MultiVariantRenderer.d.ts +34 -5
  121. package/esm/MultiLinearVariantRenderer/MultiVariantRenderer.js +13 -7
  122. package/esm/MultiLinearVariantRenderer/components/{MultiVariantRendering.d.ts → MultiLinearVariantRendering.d.ts} +10 -4
  123. package/esm/MultiLinearVariantRenderer/components/{MultiVariantRendering.js → MultiLinearVariantRendering.js} +25 -7
  124. package/esm/MultiLinearVariantRenderer/components/util.d.ts +1 -0
  125. package/esm/MultiLinearVariantRenderer/components/util.js +12 -0
  126. package/esm/MultiLinearVariantRenderer/index.js +1 -1
  127. package/esm/MultiLinearVariantRenderer/makeImageData.d.ts +9 -0
  128. package/esm/MultiLinearVariantRenderer/makeImageData.js +106 -43
  129. package/esm/MultiLinearVariantRenderer/types.d.ts +2 -0
  130. package/esm/MultiVariantBaseRenderer.d.ts +4 -4
  131. package/esm/SplitVcfTabixAdapter/SplitVcfTabixAdapter.d.ts +0 -1
  132. package/esm/SplitVcfTabixAdapter/SplitVcfTabixAdapter.js +0 -1
  133. package/esm/SplitVcfTabixAdapter/configSchema.js +4 -2
  134. package/esm/VariantFeatureWidget/AltFormatter.d.ts +4 -0
  135. package/esm/VariantFeatureWidget/AltFormatter.js +10 -0
  136. package/esm/VariantFeatureWidget/Checkbox2.js +2 -9
  137. package/esm/VariantFeatureWidget/Formatter.d.ts +3 -0
  138. package/esm/VariantFeatureWidget/Formatter.js +17 -0
  139. package/esm/VariantFeatureWidget/{VariantConsequenceDataGridWrapper.js → VariantConsequence/VariantConsequenceDataGridWrapper.js} +4 -6
  140. package/esm/VariantFeatureWidget/VariantFeatureWidget.js +16 -6
  141. package/esm/VariantFeatureWidget/VariantSampleGrid/VariantGenotypeFrequencyTable.d.ts +4 -0
  142. package/esm/VariantFeatureWidget/VariantSampleGrid/VariantGenotypeFrequencyTable.js +74 -0
  143. package/esm/VariantFeatureWidget/VariantSampleGrid/VariantSampleGrid.d.ts +3 -9
  144. package/esm/VariantFeatureWidget/VariantSampleGrid/VariantSampleGrid.js +43 -22
  145. package/esm/VariantFeatureWidget/VariantSampleGrid/types.d.ts +21 -0
  146. package/esm/VariantFeatureWidget/VariantSampleGrid/util.d.ts +1 -0
  147. package/esm/VariantFeatureWidget/VariantSampleGrid/util.js +11 -0
  148. package/esm/VariantFeatureWidget/stateModelFactory.d.ts +9 -6
  149. package/esm/VariantRPC/MultiVariantClusterGenotypeMatrix.d.ts +2 -16
  150. package/esm/VariantRPC/MultiVariantClusterGenotypeMatrix.js +4 -7
  151. package/esm/VariantRPC/MultiVariantGetGenotypeMatrix.d.ts +2 -15
  152. package/esm/VariantRPC/MultiVariantGetSimplifiedFeatures.d.ts +3 -13
  153. package/esm/VariantRPC/MultiVariantGetSimplifiedFeatures.js +14 -8
  154. package/esm/VariantRPC/getGenotypeMatrix.js +20 -7
  155. package/esm/VariantRPC/types.d.ts +23 -0
  156. package/esm/VcfAdapter/VcfAdapter.d.ts +0 -1
  157. package/esm/VcfAdapter/VcfAdapter.js +0 -1
  158. package/esm/VcfFeature/index.js +0 -1
  159. package/esm/VcfFeature/util.d.ts +2 -0
  160. package/esm/VcfFeature/util.js +121 -25
  161. package/esm/VcfTabixAdapter/VcfTabixAdapter.d.ts +0 -1
  162. package/esm/VcfTabixAdapter/VcfTabixAdapter.js +13 -9
  163. package/esm/getMultiVariantFeaturesAutorun.d.ts +2 -0
  164. package/esm/getMultiVariantFeaturesAutorun.js +9 -2
  165. package/esm/getMultiVariantSourcesAutorun.js +3 -2
  166. package/esm/shared/MultiVariantBaseModel.d.ts +41 -4
  167. package/esm/shared/MultiVariantBaseModel.js +71 -5
  168. package/esm/shared/SharedVariantMixin.d.ts +1 -1
  169. package/esm/shared/components/AddFiltersDialog.d.ts +9 -0
  170. package/esm/shared/components/AddFiltersDialog.js +59 -0
  171. package/esm/shared/components/MultiVariantBaseDisplayComponent.d.ts +5 -0
  172. package/esm/shared/components/MultiVariantBaseDisplayComponent.js +24 -0
  173. package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialog.js +2 -2
  174. package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogAuto.js +9 -4
  175. package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogManual.js +29 -28
  176. package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/types.d.ts +1 -0
  177. package/esm/shared/components/MultiVariantClusterDialog/types.js +1 -0
  178. package/{dist/shared/components/ColorLegend.d.ts → esm/shared/components/MultiVariantColorLegend.d.ts} +2 -2
  179. package/esm/shared/components/{ColorLegend.js → MultiVariantColorLegend.js} +6 -4
  180. package/esm/shared/components/MultiVariantCrosshairs.d.ts +7 -0
  181. package/esm/shared/components/MultiVariantCrosshairs.js +35 -0
  182. package/esm/shared/components/MultiVariantLegendBar.d.ts +7 -0
  183. package/esm/shared/components/{LegendBar.js → MultiVariantLegendBar.js} +1 -1
  184. package/esm/shared/components/MultiVariantTooltip.d.ts +4 -0
  185. package/esm/shared/components/MultiVariantTooltip.js +3 -2
  186. package/esm/shared/components/RectBg.js +4 -2
  187. package/esm/shared/components/SetColorDialog.js +1 -1
  188. package/esm/shared/components/SourcesDataGrid.d.ts +2 -1
  189. package/esm/shared/components/SourcesDataGrid.js +40 -47
  190. package/esm/shared/components/SourcesGrid.js +1 -1
  191. package/esm/shared/components/SourcesGridHeader.d.ts +2 -1
  192. package/esm/shared/drawAlleleCount.d.ts +2 -1
  193. package/esm/shared/drawAlleleCount.js +25 -24
  194. package/esm/shared/drawPhased.d.ts +1 -1
  195. package/esm/shared/drawPhased.js +14 -10
  196. package/esm/shared/minorAlleleFrequencyUtils.d.ts +9 -4
  197. package/esm/shared/minorAlleleFrequencyUtils.js +20 -15
  198. package/esm/shared/sourcesGridUtils.d.ts +3 -2
  199. package/package.json +12 -11
  200. package/dist/MultiLinearVariantDisplay/components/Crosshair.d.ts +0 -7
  201. package/dist/MultiLinearVariantDisplay/components/Crosshair.js +0 -35
  202. package/dist/MultiLinearVariantMatrixDisplay/components/Crosshair.d.ts +0 -7
  203. package/dist/MultiLinearVariantMatrixDisplay/components/Crosshair.js +0 -28
  204. package/dist/MultiLinearVariantMatrixRenderer/components/LinearVariantMatrixRendering.d.ts +0 -7
  205. package/dist/MultiLinearVariantMatrixRenderer/components/LinearVariantMatrixRendering.js +0 -38
  206. package/dist/MultiLinearVariantRenderer/MultiVariantRendering.d.ts +0 -22
  207. package/dist/MultiLinearVariantRenderer/components/MultiVariantRendering.js +0 -52
  208. package/dist/VariantFeatureWidget/VariantConsequencePanel.d.ts +0 -5
  209. package/dist/VariantFeatureWidget/VariantConsequencePanel.js +0 -15
  210. package/dist/VariantRPC/cluster.d.ts +0 -17
  211. package/dist/VariantRPC/cluster.js +0 -84
  212. package/dist/shared/components/LegendBar.d.ts +0 -18
  213. package/esm/MultiLinearVariantDisplay/components/Crosshair.d.ts +0 -7
  214. package/esm/MultiLinearVariantDisplay/components/Crosshair.js +0 -30
  215. package/esm/MultiLinearVariantMatrixDisplay/components/Crosshair.d.ts +0 -7
  216. package/esm/MultiLinearVariantMatrixDisplay/components/Crosshair.js +0 -23
  217. package/esm/MultiLinearVariantMatrixRenderer/components/LinearVariantMatrixRendering.d.ts +0 -7
  218. package/esm/MultiLinearVariantMatrixRenderer/components/LinearVariantMatrixRendering.js +0 -36
  219. package/esm/MultiLinearVariantRenderer/MultiVariantRendering.d.ts +0 -22
  220. package/esm/MultiLinearVariantRenderer/MultiVariantRendering.js +0 -47
  221. package/esm/VariantFeatureWidget/VariantConsequencePanel.d.ts +0 -5
  222. package/esm/VariantFeatureWidget/VariantConsequencePanel.js +0 -9
  223. package/esm/VariantRPC/cluster.d.ts +0 -17
  224. package/esm/VariantRPC/cluster.js +0 -79
  225. package/esm/shared/components/LegendBar.d.ts +0 -18
  226. /package/dist/VariantFeatureWidget/{VariantConsequenceDataGrid.d.ts → VariantConsequence/VariantConsequenceDataGrid.d.ts} +0 -0
  227. /package/dist/VariantFeatureWidget/{VariantConsequenceDataGrid.js → VariantConsequence/VariantConsequenceDataGrid.js} +0 -0
  228. /package/dist/VariantFeatureWidget/{VariantConsequenceDataGridWrapper.d.ts → VariantConsequence/VariantConsequenceDataGridWrapper.d.ts} +0 -0
  229. /package/dist/{shared/components/ClusterDialog → VariantFeatureWidget/VariantSampleGrid}/types.js +0 -0
  230. /package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialog.d.ts +0 -0
  231. /package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogAuto.d.ts +0 -0
  232. /package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogManual.d.ts +0 -0
  233. /package/esm/VariantFeatureWidget/{VariantConsequenceDataGrid.d.ts → VariantConsequence/VariantConsequenceDataGrid.d.ts} +0 -0
  234. /package/esm/VariantFeatureWidget/{VariantConsequenceDataGrid.js → VariantConsequence/VariantConsequenceDataGrid.js} +0 -0
  235. /package/esm/VariantFeatureWidget/{VariantConsequenceDataGridWrapper.d.ts → VariantConsequence/VariantConsequenceDataGridWrapper.d.ts} +0 -0
  236. /package/esm/{shared/components/ClusterDialog → VariantFeatureWidget/VariantSampleGrid}/types.js +0 -0
  237. /package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialog.d.ts +0 -0
  238. /package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogAuto.d.ts +0 -0
  239. /package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogManual.d.ts +0 -0
@@ -8,29 +8,29 @@ const drawAlleleCount_1 = require("../shared/drawAlleleCount");
8
8
  const drawPhased_1 = require("../shared/drawPhased");
9
9
  const minorAlleleFrequencyUtils_1 = require("../shared/minorAlleleFrequencyUtils");
10
10
  async function makeImageData({ ctx, canvasWidth, canvasHeight, renderArgs, }) {
11
- const { renderingMode: renderingMode, minorAlleleFrequencyFilter, sources, features, stopToken, } = renderArgs;
11
+ const { renderingMode, minorAlleleFrequencyFilter, sources, features, stopToken, lengthCutoffFilter, } = renderArgs;
12
12
  const { statusCallback = () => { } } = renderArgs;
13
13
  const h = canvasHeight / sources.length;
14
14
  (0, stopToken_1.checkStopToken)(stopToken);
15
- const mafs = (0, minorAlleleFrequencyUtils_1.getFeaturesThatPassMinorAlleleFrequencyFilter)(features.values(), minorAlleleFrequencyFilter);
15
+ const mafs = await (0, util_1.updateStatus)('Calculating stats', statusCallback, () => (0, minorAlleleFrequencyUtils_1.getFeaturesThatPassMinorAlleleFrequencyFilter)({
16
+ stopToken,
17
+ features: features.values(),
18
+ minorAlleleFrequencyFilter,
19
+ lengthCutoffFilter,
20
+ }));
16
21
  (0, stopToken_1.checkStopToken)(stopToken);
17
22
  const arr = [];
18
23
  const m = mafs.length;
19
24
  const w = canvasWidth / m;
20
25
  await (0, util_1.updateStatus)('Drawing variant matrix', statusCallback, () => {
21
- var _a, _b, _c;
22
- let start = performance.now();
23
- for (let i = 0; i < m; i++) {
24
- if (performance.now() - start > 400) {
25
- (0, stopToken_1.checkStopToken)(stopToken);
26
- start = performance.now();
27
- }
26
+ const colorCache = {};
27
+ (0, util_1.forEachWithStopTokenCheck)(mafs, stopToken, ({ feature, mostFrequentAlt }, idx) => {
28
+ var _a, _b, _c;
28
29
  const arr2 = [];
29
- const { feature, mostFrequentAlt } = mafs[i];
30
30
  const hasPhaseSet = (_a = feature.get('FORMAT')) === null || _a === void 0 ? void 0 : _a.includes('PS');
31
31
  if (hasPhaseSet) {
32
32
  const samp = feature.get('samples');
33
- const x = (i / mafs.length) * canvasWidth;
33
+ const x = (idx / mafs.length) * canvasWidth;
34
34
  const sln = sources.length;
35
35
  for (let j = 0; j < sln; j++) {
36
36
  const y = (j / sln) * canvasHeight;
@@ -53,8 +53,35 @@ async function makeImageData({ ctx, canvasWidth, canvasHeight, renderArgs, }) {
53
53
  }
54
54
  }
55
55
  else {
56
- const alleles = genotype.split(/[/|]/);
57
- (0, drawAlleleCount_1.drawColorAlleleCount)(alleles, ctx, x, y, w, h, mostFrequentAlt);
56
+ let c = colorCache[genotype];
57
+ if (c === undefined) {
58
+ let alt = 0;
59
+ let uncalled = 0;
60
+ let alt2 = 0;
61
+ let ref = 0;
62
+ const alleles = genotype.split(/[/|]/);
63
+ const total = alleles.length;
64
+ for (let i = 0; i < total; i++) {
65
+ const allele = alleles[i];
66
+ if (allele === mostFrequentAlt) {
67
+ alt++;
68
+ }
69
+ else if (allele === '0') {
70
+ ref++;
71
+ }
72
+ else if (allele === '.') {
73
+ uncalled++;
74
+ }
75
+ else {
76
+ alt2++;
77
+ }
78
+ }
79
+ c = (0, drawAlleleCount_1.getColorAlleleCount)(ref, alt, alt2, uncalled, total, true);
80
+ colorCache[genotype] = c;
81
+ }
82
+ if (c) {
83
+ (0, drawAlleleCount_1.drawColorAlleleCount)(c, ctx, x, y, w, h);
84
+ }
58
85
  }
59
86
  }
60
87
  }
@@ -62,7 +89,7 @@ async function makeImageData({ ctx, canvasWidth, canvasHeight, renderArgs, }) {
62
89
  }
63
90
  else {
64
91
  const samp = feature.get('genotypes');
65
- const x = (i / mafs.length) * canvasWidth;
92
+ const x = (idx / mafs.length) * canvasWidth;
66
93
  const sln = sources.length;
67
94
  for (let j = 0; j < sln; j++) {
68
95
  const y = (j / sln) * canvasHeight;
@@ -82,14 +109,41 @@ async function makeImageData({ ctx, canvasWidth, canvasHeight, renderArgs, }) {
82
109
  }
83
110
  }
84
111
  else {
85
- const alleles = genotype.split(/[/|]/);
86
- (0, drawAlleleCount_1.drawColorAlleleCount)(alleles, ctx, x, y, w, h, mostFrequentAlt);
112
+ let c = colorCache[genotype];
113
+ if (c === undefined) {
114
+ let alt = 0;
115
+ let uncalled = 0;
116
+ let alt2 = 0;
117
+ let ref = 0;
118
+ const alleles = genotype.split(/[/|]/);
119
+ const total = alleles.length;
120
+ for (let i = 0; i < total; i++) {
121
+ const allele = alleles[i];
122
+ if (allele === mostFrequentAlt) {
123
+ alt++;
124
+ }
125
+ else if (allele === '0') {
126
+ ref++;
127
+ }
128
+ else if (allele === '.') {
129
+ uncalled++;
130
+ }
131
+ else {
132
+ alt2++;
133
+ }
134
+ }
135
+ c = (0, drawAlleleCount_1.getColorAlleleCount)(ref, alt, alt2, uncalled, total, true);
136
+ colorCache[genotype] = c;
137
+ }
138
+ if (c) {
139
+ (0, drawAlleleCount_1.drawColorAlleleCount)(c, ctx, x, y, w, h);
140
+ }
87
141
  }
88
142
  }
89
143
  }
90
144
  }
91
145
  arr.push(arr2);
92
- }
146
+ });
93
147
  });
94
148
  return {
95
149
  mafs,
@@ -6,11 +6,9 @@ export interface RenderArgsDeserialized extends BoxRenderArgsDeserialized {
6
6
  minorAlleleFrequencyFilter: number;
7
7
  highResolutionScaling: number;
8
8
  height: number;
9
- renderingMode: string;
10
- }
11
- export interface RenderArgsDeserializedWithFeaturesAndLayout extends RenderArgsDeserialized {
12
- sources: Source[];
13
9
  features: Map<string, Feature>;
14
10
  renderingMode: string;
15
11
  statusCallback?: (arg: string) => void;
12
+ lengthCutoffFilter: number;
13
+ stopToken: string;
16
14
  }
@@ -8,7 +8,17 @@ export default class MultiVariantBaseRenderer extends FeatureRendererType {
8
8
  height: number;
9
9
  width: number;
10
10
  containsNoTransferables: boolean;
11
- canvasRecordedData: any;
11
+ rbush: any;
12
+ featureGenotypeMap: {
13
+ [k: string]: {
14
+ alt: any;
15
+ ref: any;
16
+ name: any;
17
+ description: any;
18
+ length: number;
19
+ };
20
+ };
21
+ canvasRecordedData: Record<string, unknown>;
12
22
  reactElement?: React.ReactElement;
13
23
  html?: string;
14
24
  } | {
@@ -16,16 +26,35 @@ export default class MultiVariantBaseRenderer extends FeatureRendererType {
16
26
  height: number;
17
27
  width: number;
18
28
  containsNoTransferables: boolean;
19
- reactElement: import("react/jsx-runtime").JSX.Element;
29
+ rbush: any;
30
+ featureGenotypeMap: {
31
+ [k: string]: {
32
+ alt: any;
33
+ ref: any;
34
+ name: any;
35
+ description: any;
36
+ length: number;
37
+ };
38
+ };
39
+ imageData: any;
40
+ reactElement?: React.ReactElement;
20
41
  html?: string;
21
42
  } | {
22
43
  features: Map<string, Feature>;
23
44
  height: number;
24
45
  width: number;
25
46
  containsNoTransferables: boolean;
26
- imageData: any;
27
- reactElement?: React.ReactElement;
47
+ rbush: any;
48
+ featureGenotypeMap: {
49
+ [k: string]: {
50
+ alt: any;
51
+ ref: any;
52
+ name: any;
53
+ description: any;
54
+ length: number;
55
+ };
56
+ };
57
+ reactElement: React.ReactElement;
28
58
  html?: string;
29
59
  }>;
30
60
  }
31
- export type { RenderArgsSerialized, RenderResults, ResultsDeserialized, ResultsSerialized, } from '@jbrowse/core/pluggableElementTypes/renderers/FeatureRendererType';
@@ -45,24 +45,30 @@ class MultiVariantBaseRenderer extends FeatureRendererType_1.default {
45
45
  }
46
46
  async render(renderProps) {
47
47
  const features = await this.getFeatures(renderProps);
48
- const { height, regions, bpPerPx } = renderProps;
48
+ const { height, referenceDrawingMode, regions, bpPerPx } = renderProps;
49
49
  const region = regions[0];
50
50
  const width = (region.end - region.start) / bpPerPx;
51
51
  const { makeImageData } = await Promise.resolve().then(() => __importStar(require('./makeImageData')));
52
- const rest = await (0, util_1.renderToAbstractCanvas)(width, height, renderProps, ctx => makeImageData(ctx, {
53
- ...renderProps,
54
- features,
55
- }));
52
+ const ret = await (0, util_1.renderToAbstractCanvas)(width, height, renderProps, ctx => {
53
+ if (referenceDrawingMode === 'skip') {
54
+ ctx.fillStyle = '#ccc';
55
+ ctx.fillRect(0, 0, width, height);
56
+ }
57
+ return makeImageData(ctx, {
58
+ ...renderProps,
59
+ features,
60
+ });
61
+ });
56
62
  const results = await super.render({
57
63
  ...renderProps,
58
- ...rest,
64
+ ...ret,
59
65
  features,
60
66
  height,
61
67
  width,
62
68
  });
63
69
  return {
64
70
  ...results,
65
- ...rest,
71
+ ...ret,
66
72
  features: new Map(),
67
73
  height,
68
74
  width,
@@ -1,7 +1,14 @@
1
- import RBush from 'rbush';
2
1
  import type { Source } from '../../shared/types';
3
2
  import type { Feature } from '@jbrowse/core/util';
4
3
  import type { Region } from '@jbrowse/core/util/types';
4
+ type SerializedRBush = any;
5
+ interface MinimizedVariantRecord {
6
+ alt: string[];
7
+ ref: string;
8
+ name: string;
9
+ description: string;
10
+ length: number;
11
+ }
5
12
  declare const MultiVariantRendering: (props: {
6
13
  regions: Region[];
7
14
  features: Map<string, Feature>;
@@ -10,10 +17,9 @@ declare const MultiVariantRendering: (props: {
10
17
  height: number;
11
18
  sources: Source[];
12
19
  scrollTop: number;
20
+ featureGenotypeMap: Record<string, MinimizedVariantRecord>;
13
21
  totalHeight: number;
14
- rbush: RBush<{
15
- genotype: string;
16
- }>;
22
+ rbush: SerializedRBush;
17
23
  displayModel: any;
18
24
  onMouseLeave?: (event: React.MouseEvent) => void;
19
25
  onMouseMove?: (event: React.MouseEvent, arg?: Feature) => void;
@@ -6,29 +6,47 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const jsx_runtime_1 = require("react/jsx-runtime");
7
7
  const react_1 = require("react");
8
8
  const ui_1 = require("@jbrowse/core/ui");
9
+ const util_1 = require("@jbrowse/core/util");
9
10
  const mobx_react_1 = require("mobx-react");
10
11
  const rbush_1 = __importDefault(require("rbush"));
12
+ const util_2 = require("./util");
13
+ const util_3 = require("../../VcfFeature/util");
11
14
  const MultiVariantRendering = (0, mobx_react_1.observer)(function (props) {
12
- const { totalHeight, scrollTop } = props;
15
+ const { featureGenotypeMap, totalHeight, scrollTop } = props;
13
16
  const { rbush, displayModel } = props;
14
17
  const ref = (0, react_1.useRef)(null);
15
18
  const rbush2 = (0, react_1.useMemo)(() => new rbush_1.default().fromJSON(rbush), [rbush]);
16
19
  function getFeatureUnderMouse(eventClientX, eventClientY) {
17
- var _a;
18
20
  let offsetX = 0;
19
21
  let offsetY = 0;
20
22
  if (ref.current) {
21
23
  const r = ref.current.getBoundingClientRect();
22
24
  offsetX = eventClientX - r.left;
23
- offsetY = eventClientY - r.top;
25
+ offsetY = eventClientY - r.top - ((displayModel === null || displayModel === void 0 ? void 0 : displayModel.scrollTop) || 0);
24
26
  }
25
- const ret = rbush2.search({
27
+ const x = rbush2.search({
26
28
  minX: offsetX,
27
- maxX: offsetX + 3,
29
+ maxX: offsetX + 1,
28
30
  minY: offsetY,
29
- maxY: offsetY + 3,
31
+ maxY: offsetY + 1,
30
32
  });
31
- return (_a = ret[0]) === null || _a === void 0 ? void 0 : _a.genotype;
33
+ if (x.length) {
34
+ const { minX, minY, maxX, maxY, genotype, featureId, ...rest } = (0, util_2.minElt)(x, elt => elt.maxX - elt.minX);
35
+ const ret = featureGenotypeMap[featureId];
36
+ if (ret) {
37
+ const { ref, alt, name, description, length } = ret;
38
+ const alleles = (0, util_3.makeSimpleAltString)(genotype, ref, alt);
39
+ return {
40
+ ...rest,
41
+ genotype,
42
+ alleles,
43
+ featureName: name,
44
+ description: alt.length >= 3 ? 'multiple ALT alleles' : description,
45
+ length: (0, util_1.getBpDisplayStr)(length),
46
+ };
47
+ }
48
+ }
49
+ return undefined;
32
50
  }
33
51
  return ((0, jsx_runtime_1.jsx)("div", { ref: ref, onMouseMove: e => {
34
52
  var _a;
@@ -0,0 +1 @@
1
+ export declare function minElt<T>(arr: Iterable<T>, cb: (arg: T) => number): T | undefined;
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.minElt = minElt;
4
+ function minElt(arr, cb) {
5
+ let min = Infinity;
6
+ let minElement;
7
+ for (const entry of arr) {
8
+ const val = cb(entry);
9
+ if (val < min) {
10
+ min = val;
11
+ minElement = entry;
12
+ }
13
+ }
14
+ return minElement;
15
+ }
@@ -5,13 +5,13 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.default = MultiVariantRendererF;
7
7
  const MultiVariantRenderer_1 = __importDefault(require("./MultiVariantRenderer"));
8
- const MultiVariantRendering_1 = __importDefault(require("./components/MultiVariantRendering"));
8
+ const MultiLinearVariantRendering_1 = __importDefault(require("./components/MultiLinearVariantRendering"));
9
9
  const configSchema_1 = __importDefault(require("./configSchema"));
10
10
  function MultiVariantRendererF(pluginManager) {
11
11
  pluginManager.addRendererType(() => {
12
12
  return new MultiVariantRenderer_1.default({
13
13
  name: 'MultiVariantRenderer',
14
- ReactComponent: MultiVariantRendering_1.default,
14
+ ReactComponent: MultiLinearVariantRendering_1.default,
15
15
  configSchema: configSchema_1.default,
16
16
  pluginManager,
17
17
  });
@@ -1,4 +1,13 @@
1
1
  import type { MultiRenderArgsDeserialized } from './types';
2
2
  export declare function makeImageData(ctx: CanvasRenderingContext2D, props: MultiRenderArgsDeserialized): Promise<{
3
3
  rbush: any;
4
+ featureGenotypeMap: {
5
+ [k: string]: {
6
+ alt: any;
7
+ ref: any;
8
+ name: any;
9
+ description: any;
10
+ length: number;
11
+ };
12
+ };
4
13
  }>;
@@ -12,56 +12,119 @@ const drawAlleleCount_1 = require("../shared/drawAlleleCount");
12
12
  const drawPhased_1 = require("../shared/drawPhased");
13
13
  const minorAlleleFrequencyUtils_1 = require("../shared/minorAlleleFrequencyUtils");
14
14
  async function makeImageData(ctx, props) {
15
- const { scrollTop, minorAlleleFrequencyFilter, sources, rowHeight, features, regions, bpPerPx, renderingMode, stopToken, } = props;
15
+ const { scrollTop, minorAlleleFrequencyFilter, sources, rowHeight, features, regions, bpPerPx, renderingMode, stopToken, lengthCutoffFilter, referenceDrawingMode, } = props;
16
16
  const region = regions[0];
17
+ const { statusCallback = () => { } } = props;
17
18
  (0, stopToken_1.checkStopToken)(stopToken);
18
- const mafs = (0, minorAlleleFrequencyUtils_1.getFeaturesThatPassMinorAlleleFrequencyFilter)(features.values(), minorAlleleFrequencyFilter);
19
+ const mafs = await (0, util_1.updateStatus)('Calculating stats', statusCallback, () => (0, minorAlleleFrequencyUtils_1.getFeaturesThatPassMinorAlleleFrequencyFilter)({
20
+ stopToken,
21
+ features: features.values(),
22
+ minorAlleleFrequencyFilter,
23
+ lengthCutoffFilter,
24
+ }));
19
25
  (0, stopToken_1.checkStopToken)(stopToken);
20
26
  const rbush = new rbush_1.default();
21
- let start = performance.now();
22
- for (const { mostFrequentAlt, feature } of mafs) {
23
- if (performance.now() - start > 400) {
24
- (0, stopToken_1.checkStopToken)(stopToken);
25
- start = performance.now();
26
- }
27
- const [leftPx, rightPx] = (0, util_1.featureSpanPx)(feature, region, bpPerPx);
28
- const w = Math.max(Math.round(rightPx - leftPx), 2);
29
- const samp = feature.get('genotypes');
30
- let y = -scrollTop;
31
- const s = sources.length;
32
- for (let j = 0; j < s; j++) {
33
- const { name, HP } = sources[j];
34
- const genotype = samp[name];
35
- const x = Math.floor(leftPx);
36
- const h = Math.max(rowHeight, 1);
37
- if (genotype) {
38
- rbush.insert({
39
- minX: x - constants_1.f2,
40
- maxX: x + w + constants_1.f2,
41
- minY: y - constants_1.f2,
42
- maxY: y + h + constants_1.f2,
43
- genotype,
44
- });
45
- const isPhased = genotype.includes('|');
46
- if (renderingMode === 'phased') {
47
- if (isPhased) {
48
- const alleles = genotype.split('|');
49
- (0, drawPhased_1.drawPhased)(alleles, ctx, x, y, w, h, HP);
50
- }
51
- else {
52
- ctx.fillStyle = 'black';
53
- ctx.fillRect(x - constants_1.f2, y - constants_1.f2, w + constants_1.f2, h + constants_1.f2);
27
+ await (0, util_1.updateStatus)('Drawing variants', statusCallback, () => {
28
+ (0, util_1.forEachWithStopTokenCheck)(mafs, stopToken, ({ mostFrequentAlt, feature }) => {
29
+ const [leftPx, rightPx] = (0, util_1.featureSpanPx)(feature, region, bpPerPx);
30
+ const flen = feature.get('end') - feature.get('start');
31
+ const w = Math.max(Math.round(rightPx - leftPx), 2);
32
+ const samp = feature.get('genotypes');
33
+ let y = -scrollTop;
34
+ const s = sources.length;
35
+ if (renderingMode === 'phased') {
36
+ for (let j = 0; j < s; j++) {
37
+ const { name, HP } = sources[j];
38
+ const genotype = samp[name];
39
+ const x = Math.floor(leftPx);
40
+ const h = Math.max(rowHeight, 1);
41
+ if (genotype) {
42
+ const isPhased = genotype.includes('|');
43
+ if (isPhased) {
44
+ const alleles = genotype.split('|');
45
+ if ((0, drawPhased_1.drawPhased)(alleles, ctx, x, y, w, h, HP, undefined, referenceDrawingMode === 'draw')) {
46
+ rbush.insert({
47
+ minX: x,
48
+ maxX: x + w,
49
+ minY: y,
50
+ maxY: y + h,
51
+ genotype,
52
+ name,
53
+ featureId: feature.id(),
54
+ });
55
+ }
56
+ }
57
+ else {
58
+ ctx.fillStyle = 'black';
59
+ ctx.fillRect(x - constants_1.f2, y - constants_1.f2, w + constants_1.f2, h + constants_1.f2);
60
+ }
54
61
  }
62
+ y += rowHeight;
55
63
  }
56
- else {
57
- const alleles = genotype.split(/[/|]/);
58
- (0, drawAlleleCount_1.drawColorAlleleCount)(alleles, ctx, x, y, w, h, mostFrequentAlt);
64
+ }
65
+ else {
66
+ const colorCache = {};
67
+ for (let j = 0; j < s; j++) {
68
+ const { name } = sources[j];
69
+ const genotype = samp[name];
70
+ const x = Math.floor(leftPx);
71
+ const h = Math.max(rowHeight, 1);
72
+ if (genotype) {
73
+ let c = colorCache[genotype];
74
+ if (c === undefined) {
75
+ let alt = 0;
76
+ let uncalled = 0;
77
+ let alt2 = 0;
78
+ let ref = 0;
79
+ const alleles = genotype.split(/[/|]/);
80
+ const total = alleles.length;
81
+ for (let i = 0; i < total; i++) {
82
+ const allele = alleles[i];
83
+ if (allele === mostFrequentAlt) {
84
+ alt++;
85
+ }
86
+ else if (allele === '0') {
87
+ ref++;
88
+ }
89
+ else if (allele === '.') {
90
+ uncalled++;
91
+ }
92
+ else {
93
+ alt2++;
94
+ }
95
+ }
96
+ c = (0, drawAlleleCount_1.getColorAlleleCount)(ref, alt, alt2, uncalled, total, referenceDrawingMode === 'draw');
97
+ colorCache[genotype] = c;
98
+ }
99
+ if (c) {
100
+ (0, drawAlleleCount_1.drawColorAlleleCount)(c, ctx, x, y, w, h, feature.get('type'), feature.get('strand'), flen > 5 ? 0.75 : 1);
101
+ rbush.insert({
102
+ minX: x,
103
+ maxX: x + w,
104
+ minY: y,
105
+ maxY: y + h,
106
+ genotype,
107
+ name,
108
+ featureId: feature.id(),
109
+ });
110
+ }
111
+ }
112
+ y += rowHeight;
59
113
  }
60
114
  }
61
- y += rowHeight;
62
- }
63
- }
115
+ });
116
+ });
64
117
  return {
65
118
  rbush: rbush.toJSON(),
119
+ featureGenotypeMap: Object.fromEntries(mafs.map(({ feature }) => [
120
+ feature.id(),
121
+ {
122
+ alt: feature.get('ALT'),
123
+ ref: feature.get('REF'),
124
+ name: feature.get('name'),
125
+ description: feature.get('description'),
126
+ length: feature.get('end') - feature.get('start'),
127
+ },
128
+ ])),
66
129
  };
67
130
  }
@@ -16,4 +16,6 @@ export interface MultiRenderArgsDeserialized extends RenderArgsDeserializedWithF
16
16
  rowHeight: number;
17
17
  scrollTop: number;
18
18
  minorAlleleFrequencyFilter: number;
19
+ lengthCutoffFilter: number;
20
+ statusCallback?: (arg: string) => void;
19
21
  }
@@ -22,7 +22,7 @@ export default abstract class MultiVariantBaseRenderer extends FeatureRendererTy
22
22
  height: number;
23
23
  width: number;
24
24
  containsNoTransferables: boolean;
25
- canvasRecordedData: any;
25
+ canvasRecordedData: Record<string, unknown>;
26
26
  reactElement?: React.ReactElement;
27
27
  html?: string;
28
28
  } | {
@@ -30,15 +30,15 @@ export default abstract class MultiVariantBaseRenderer extends FeatureRendererTy
30
30
  height: number;
31
31
  width: number;
32
32
  containsNoTransferables: boolean;
33
- reactElement: import("react/jsx-runtime").JSX.Element;
33
+ imageData: any;
34
+ reactElement?: React.ReactElement;
34
35
  html?: string;
35
36
  } | {
36
37
  features: Map<string, Feature>;
37
38
  height: number;
38
39
  width: number;
39
40
  containsNoTransferables: boolean;
40
- imageData: any;
41
- reactElement?: React.ReactElement;
41
+ reactElement: React.ReactElement;
42
42
  html?: string;
43
43
  }>;
44
44
  abstract draw<T extends RenderArgsDeserializedWithFeatures>(ctx: CanvasRenderingContext2D, props: T): Promise<Record<string, unknown> | undefined>;
@@ -15,5 +15,4 @@ export default class SplitVcfTabixAdapter extends BaseFeatureDataAdapter {
15
15
  getSources(): Promise<{
16
16
  name: string;
17
17
  }[]>;
18
- freeResources(): void;
19
18
  }
@@ -88,6 +88,5 @@ class SplitVcfTabixAdapter extends BaseAdapter_1.BaseFeatureDataAdapter {
88
88
  .filter(f => s.has(f.name));
89
89
  }
90
90
  }
91
- freeResources() { }
92
91
  }
93
92
  exports.default = SplitVcfTabixAdapter;
@@ -19,9 +19,11 @@ const SplitVcfTabixAdapter = (0, configuration_1.ConfigurationSchema)('SplitVcfT
19
19
  type: 'fileLocation',
20
20
  defaultValue: {
21
21
  uri: '/path/to/samples.tsv',
22
- description: 'tsv with header like name\tpopulation\tetc. where the first column is required, and is the sample names',
22
+ description: 'tsv with header like "name\tpopulation\tetc" where the first column is required, and corresponds to the sample names in the VCF files',
23
23
  locationType: 'UriLocation',
24
24
  },
25
25
  },
26
- }, { explicitlyTyped: true });
26
+ }, {
27
+ explicitlyTyped: true,
28
+ });
27
29
  exports.default = SplitVcfTabixAdapter;
@@ -0,0 +1,4 @@
1
+ export default function AltFormatter({ value, ref, }: {
2
+ value: string;
3
+ ref: string;
4
+ }): string | import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.default = AltFormatter;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const util_1 = require("../VcfFeature/util");
7
+ function AltFormatter({ value, ref, }) {
8
+ const [show, setShow] = (0, react_1.useState)(false);
9
+ const alt = (0, util_1.getMinimalDesc)(ref, value);
10
+ return alt !== value ? ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("button", { onClick: () => {
11
+ setShow(!show);
12
+ }, children: show ? 'Show simplified ALT' : 'Show raw ALT' }), ' ', show ? value : (0, util_1.getMinimalDesc)(ref, value)] })) : (value);
13
+ }
@@ -3,13 +3,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.default = Checkbox2;
4
4
  const jsx_runtime_1 = require("react/jsx-runtime");
5
5
  const material_1 = require("@mui/material");
6
- const mui_1 = require("tss-react/mui");
7
- const useStyles = (0, mui_1.makeStyles)()({
8
- block: {
9
- display: 'block',
10
- },
11
- });
12
6
  function Checkbox2({ checked, disabled, label, onChange, }) {
13
- const { classes } = useStyles();
14
- return ((0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { disabled: disabled, className: classes.block, control: (0, jsx_runtime_1.jsx)(material_1.Checkbox, { checked: checked, onChange: onChange }), label: label }));
7
+ return ((0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { disabled: disabled, control: (0, jsx_runtime_1.jsx)(material_1.Checkbox, { checked: checked, onChange: onChange }), label: (0, jsx_runtime_1.jsx)(material_1.Typography, { variant: "body2", children: label }) }));
15
8
  }