@jbrowse/plugin-variants 3.2.0 → 3.3.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 (221) hide show
  1. package/dist/MultiLinearVariantDisplay/components/VariantDisplayComponent.js +3 -3
  2. package/dist/MultiLinearVariantDisplay/index.js +1 -1
  3. package/dist/MultiLinearVariantDisplay/model.d.ts +39 -3
  4. package/dist/MultiLinearVariantDisplay/model.js +0 -1
  5. package/dist/MultiLinearVariantDisplay/renderSvg.js +2 -2
  6. package/dist/MultiLinearVariantMatrixDisplay/components/LinesConnectingMatrixToGenomicPosition.js +15 -5
  7. package/dist/MultiLinearVariantMatrixDisplay/components/VariantDisplayComponent.js +3 -3
  8. package/dist/MultiLinearVariantMatrixDisplay/index.js +1 -1
  9. package/dist/MultiLinearVariantMatrixDisplay/model.d.ts +39 -2
  10. package/dist/MultiLinearVariantMatrixDisplay/model.js +1 -0
  11. package/dist/MultiLinearVariantMatrixDisplay/renderSvg.js +2 -2
  12. package/dist/MultiLinearVariantMatrixRenderer/{LinearVariantMatrixRenderer.d.ts → MultiLinearVariantMatrixRenderer.d.ts} +7 -3
  13. package/dist/MultiLinearVariantMatrixRenderer/components/MultiLinearVariantMatrixRendering.d.ts +8 -0
  14. package/dist/MultiLinearVariantMatrixRenderer/components/MultiLinearVariantMatrixRendering.js +41 -0
  15. package/dist/MultiLinearVariantMatrixRenderer/index.js +4 -4
  16. package/dist/MultiLinearVariantMatrixRenderer/makeImageData.d.ts +2 -2
  17. package/dist/MultiLinearVariantMatrixRenderer/makeImageData.js +12 -13
  18. package/dist/MultiLinearVariantMatrixRenderer/types.d.ts +2 -4
  19. package/dist/MultiLinearVariantRenderer/MultiVariantRenderer.d.ts +30 -1
  20. package/dist/MultiLinearVariantRenderer/MultiVariantRenderer.js +11 -5
  21. package/dist/MultiLinearVariantRenderer/components/{MultiVariantRendering.d.ts → MultiLinearVariantRendering.d.ts} +10 -4
  22. package/dist/MultiLinearVariantRenderer/{MultiVariantRendering.js → components/MultiLinearVariantRendering.js} +25 -7
  23. package/dist/MultiLinearVariantRenderer/components/util.d.ts +1 -0
  24. package/dist/MultiLinearVariantRenderer/components/util.js +15 -0
  25. package/dist/MultiLinearVariantRenderer/index.js +2 -2
  26. package/dist/MultiLinearVariantRenderer/makeImageData.d.ts +9 -0
  27. package/dist/MultiLinearVariantRenderer/makeImageData.js +60 -28
  28. package/dist/MultiLinearVariantRenderer/types.d.ts +1 -0
  29. package/dist/SplitVcfTabixAdapter/configSchema.js +4 -2
  30. package/dist/VariantFeatureWidget/AltFormatter.d.ts +4 -0
  31. package/dist/VariantFeatureWidget/AltFormatter.js +13 -0
  32. package/dist/VariantFeatureWidget/Checkbox2.js +1 -8
  33. package/dist/VariantFeatureWidget/Formatter.d.ts +3 -0
  34. package/dist/VariantFeatureWidget/Formatter.js +23 -0
  35. package/dist/VariantFeatureWidget/{VariantConsequenceDataGridWrapper.js → VariantConsequence/VariantConsequenceDataGridWrapper.js} +3 -5
  36. package/dist/VariantFeatureWidget/VariantFeatureWidget.js +7 -2
  37. package/dist/VariantFeatureWidget/VariantSampleGrid/VariantGenotypeFrequencyTable.d.ts +4 -0
  38. package/dist/VariantFeatureWidget/VariantSampleGrid/VariantGenotypeFrequencyTable.js +80 -0
  39. package/dist/VariantFeatureWidget/VariantSampleGrid/VariantSampleGrid.d.ts +3 -9
  40. package/dist/VariantFeatureWidget/VariantSampleGrid/VariantSampleGrid.js +41 -20
  41. package/dist/VariantFeatureWidget/VariantSampleGrid/types.d.ts +21 -0
  42. package/dist/VariantFeatureWidget/VariantSampleGrid/util.d.ts +1 -0
  43. package/dist/VariantFeatureWidget/VariantSampleGrid/util.js +14 -0
  44. package/dist/VariantRPC/MultiVariantClusterGenotypeMatrix.d.ts +2 -16
  45. package/dist/VariantRPC/MultiVariantClusterGenotypeMatrix.js +4 -7
  46. package/dist/VariantRPC/MultiVariantGetGenotypeMatrix.d.ts +2 -15
  47. package/dist/VariantRPC/MultiVariantGetSimplifiedFeatures.d.ts +3 -13
  48. package/dist/VariantRPC/MultiVariantGetSimplifiedFeatures.js +14 -8
  49. package/dist/VariantRPC/getGenotypeMatrix.js +10 -5
  50. package/dist/VariantRPC/types.d.ts +23 -0
  51. package/dist/VcfFeature/index.js +0 -1
  52. package/dist/VcfFeature/util.d.ts +2 -0
  53. package/dist/VcfFeature/util.js +123 -25
  54. package/dist/VcfTabixAdapter/VcfTabixAdapter.js +12 -7
  55. package/dist/getMultiVariantFeaturesAutorun.d.ts +2 -0
  56. package/dist/getMultiVariantFeaturesAutorun.js +9 -2
  57. package/dist/getMultiVariantSourcesAutorun.js +3 -2
  58. package/dist/shared/MultiVariantBaseModel.d.ts +40 -3
  59. package/dist/shared/MultiVariantBaseModel.js +69 -3
  60. package/dist/shared/components/AddFiltersDialog.d.ts +9 -0
  61. package/dist/shared/components/AddFiltersDialog.js +61 -0
  62. package/dist/shared/components/MultiVariantBaseDisplayComponent.d.ts +5 -0
  63. package/dist/shared/components/MultiVariantBaseDisplayComponent.js +29 -0
  64. package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialog.js +2 -2
  65. package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogAuto.js +8 -3
  66. package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogManual.js +29 -28
  67. package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/types.d.ts +1 -0
  68. package/dist/shared/components/MultiVariantClusterDialog/types.js +2 -0
  69. package/{esm/shared/components/ColorLegend.d.ts → dist/shared/components/MultiVariantColorLegend.d.ts} +2 -2
  70. package/dist/shared/components/{ColorLegend.js → MultiVariantColorLegend.js} +5 -3
  71. package/dist/shared/components/MultiVariantCrosshairs.d.ts +7 -0
  72. package/dist/shared/components/MultiVariantCrosshairs.js +40 -0
  73. package/dist/shared/components/MultiVariantLegendBar.d.ts +7 -0
  74. package/dist/shared/components/{LegendBar.js → MultiVariantLegendBar.js} +2 -2
  75. package/dist/shared/components/MultiVariantTooltip.d.ts +4 -0
  76. package/dist/shared/components/MultiVariantTooltip.js +3 -2
  77. package/dist/shared/components/RectBg.js +4 -2
  78. package/dist/shared/components/SetColorDialog.js +1 -1
  79. package/dist/shared/components/SourcesDataGrid.d.ts +2 -1
  80. package/dist/shared/components/SourcesDataGrid.js +40 -47
  81. package/dist/shared/components/SourcesGrid.js +1 -1
  82. package/dist/shared/components/SourcesGridHeader.d.ts +2 -1
  83. package/dist/shared/drawAlleleCount.d.ts +1 -1
  84. package/dist/shared/drawAlleleCount.js +29 -5
  85. package/dist/shared/drawPhased.d.ts +1 -1
  86. package/dist/shared/drawPhased.js +14 -10
  87. package/dist/shared/minorAlleleFrequencyUtils.d.ts +6 -1
  88. package/dist/shared/minorAlleleFrequencyUtils.js +4 -5
  89. package/dist/shared/sourcesGridUtils.d.ts +3 -2
  90. package/esm/MultiLinearVariantDisplay/components/VariantDisplayComponent.js +2 -2
  91. package/esm/MultiLinearVariantDisplay/index.js +1 -1
  92. package/esm/MultiLinearVariantDisplay/model.d.ts +39 -3
  93. package/esm/MultiLinearVariantDisplay/model.js +0 -1
  94. package/esm/MultiLinearVariantDisplay/renderSvg.js +1 -1
  95. package/esm/MultiLinearVariantMatrixDisplay/components/LinesConnectingMatrixToGenomicPosition.js +15 -8
  96. package/esm/MultiLinearVariantMatrixDisplay/components/VariantDisplayComponent.js +2 -2
  97. package/esm/MultiLinearVariantMatrixDisplay/index.js +1 -1
  98. package/esm/MultiLinearVariantMatrixDisplay/model.d.ts +39 -2
  99. package/esm/MultiLinearVariantMatrixDisplay/model.js +1 -0
  100. package/esm/MultiLinearVariantMatrixDisplay/renderSvg.js +1 -1
  101. package/esm/MultiLinearVariantMatrixRenderer/{LinearVariantMatrixRenderer.d.ts → MultiLinearVariantMatrixRenderer.d.ts} +7 -3
  102. package/esm/MultiLinearVariantMatrixRenderer/components/MultiLinearVariantMatrixRendering.d.ts +8 -0
  103. package/esm/MultiLinearVariantMatrixRenderer/components/MultiLinearVariantMatrixRendering.js +39 -0
  104. package/esm/MultiLinearVariantMatrixRenderer/index.js +4 -4
  105. package/esm/MultiLinearVariantMatrixRenderer/makeImageData.d.ts +2 -2
  106. package/esm/MultiLinearVariantMatrixRenderer/makeImageData.js +13 -14
  107. package/esm/MultiLinearVariantMatrixRenderer/types.d.ts +2 -4
  108. package/esm/MultiLinearVariantRenderer/MultiVariantRenderer.d.ts +30 -1
  109. package/esm/MultiLinearVariantRenderer/MultiVariantRenderer.js +11 -5
  110. package/esm/MultiLinearVariantRenderer/components/{MultiVariantRendering.d.ts → MultiLinearVariantRendering.d.ts} +10 -4
  111. package/esm/MultiLinearVariantRenderer/components/{MultiVariantRendering.js → MultiLinearVariantRendering.js} +25 -7
  112. package/esm/MultiLinearVariantRenderer/components/util.d.ts +1 -0
  113. package/esm/MultiLinearVariantRenderer/components/util.js +12 -0
  114. package/esm/MultiLinearVariantRenderer/index.js +1 -1
  115. package/esm/MultiLinearVariantRenderer/makeImageData.d.ts +9 -0
  116. package/esm/MultiLinearVariantRenderer/makeImageData.js +61 -29
  117. package/esm/MultiLinearVariantRenderer/types.d.ts +1 -0
  118. package/esm/SplitVcfTabixAdapter/configSchema.js +4 -2
  119. package/esm/VariantFeatureWidget/AltFormatter.d.ts +4 -0
  120. package/esm/VariantFeatureWidget/AltFormatter.js +10 -0
  121. package/esm/VariantFeatureWidget/Checkbox2.js +2 -9
  122. package/esm/VariantFeatureWidget/Formatter.d.ts +3 -0
  123. package/esm/VariantFeatureWidget/Formatter.js +17 -0
  124. package/esm/VariantFeatureWidget/{VariantConsequenceDataGridWrapper.js → VariantConsequence/VariantConsequenceDataGridWrapper.js} +4 -6
  125. package/esm/VariantFeatureWidget/VariantFeatureWidget.js +7 -2
  126. package/esm/VariantFeatureWidget/VariantSampleGrid/VariantGenotypeFrequencyTable.d.ts +4 -0
  127. package/esm/VariantFeatureWidget/VariantSampleGrid/VariantGenotypeFrequencyTable.js +74 -0
  128. package/esm/VariantFeatureWidget/VariantSampleGrid/VariantSampleGrid.d.ts +3 -9
  129. package/esm/VariantFeatureWidget/VariantSampleGrid/VariantSampleGrid.js +43 -22
  130. package/esm/VariantFeatureWidget/VariantSampleGrid/types.d.ts +21 -0
  131. package/esm/VariantFeatureWidget/VariantSampleGrid/util.d.ts +1 -0
  132. package/esm/VariantFeatureWidget/VariantSampleGrid/util.js +11 -0
  133. package/esm/VariantRPC/MultiVariantClusterGenotypeMatrix.d.ts +2 -16
  134. package/esm/VariantRPC/MultiVariantClusterGenotypeMatrix.js +4 -7
  135. package/esm/VariantRPC/MultiVariantGetGenotypeMatrix.d.ts +2 -15
  136. package/esm/VariantRPC/MultiVariantGetSimplifiedFeatures.d.ts +3 -13
  137. package/esm/VariantRPC/MultiVariantGetSimplifiedFeatures.js +14 -8
  138. package/esm/VariantRPC/getGenotypeMatrix.js +10 -5
  139. package/esm/VariantRPC/types.d.ts +23 -0
  140. package/esm/VcfFeature/index.js +0 -1
  141. package/esm/VcfFeature/util.d.ts +2 -0
  142. package/esm/VcfFeature/util.js +121 -25
  143. package/esm/VcfTabixAdapter/VcfTabixAdapter.js +13 -8
  144. package/esm/getMultiVariantFeaturesAutorun.d.ts +2 -0
  145. package/esm/getMultiVariantFeaturesAutorun.js +9 -2
  146. package/esm/getMultiVariantSourcesAutorun.js +3 -2
  147. package/esm/shared/MultiVariantBaseModel.d.ts +40 -3
  148. package/esm/shared/MultiVariantBaseModel.js +71 -5
  149. package/esm/shared/components/AddFiltersDialog.d.ts +9 -0
  150. package/esm/shared/components/AddFiltersDialog.js +59 -0
  151. package/esm/shared/components/MultiVariantBaseDisplayComponent.d.ts +5 -0
  152. package/esm/shared/components/MultiVariantBaseDisplayComponent.js +24 -0
  153. package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialog.js +2 -2
  154. package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogAuto.js +9 -4
  155. package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogManual.js +29 -28
  156. package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/types.d.ts +1 -0
  157. package/esm/shared/components/MultiVariantClusterDialog/types.js +1 -0
  158. package/{dist/shared/components/ColorLegend.d.ts → esm/shared/components/MultiVariantColorLegend.d.ts} +2 -2
  159. package/esm/shared/components/{ColorLegend.js → MultiVariantColorLegend.js} +6 -4
  160. package/esm/shared/components/MultiVariantCrosshairs.d.ts +7 -0
  161. package/esm/shared/components/MultiVariantCrosshairs.js +35 -0
  162. package/esm/shared/components/MultiVariantLegendBar.d.ts +7 -0
  163. package/esm/shared/components/{LegendBar.js → MultiVariantLegendBar.js} +1 -1
  164. package/esm/shared/components/MultiVariantTooltip.d.ts +4 -0
  165. package/esm/shared/components/MultiVariantTooltip.js +3 -2
  166. package/esm/shared/components/RectBg.js +4 -2
  167. package/esm/shared/components/SetColorDialog.js +1 -1
  168. package/esm/shared/components/SourcesDataGrid.d.ts +2 -1
  169. package/esm/shared/components/SourcesDataGrid.js +40 -47
  170. package/esm/shared/components/SourcesGrid.js +1 -1
  171. package/esm/shared/components/SourcesGridHeader.d.ts +2 -1
  172. package/esm/shared/drawAlleleCount.d.ts +1 -1
  173. package/esm/shared/drawAlleleCount.js +29 -5
  174. package/esm/shared/drawPhased.d.ts +1 -1
  175. package/esm/shared/drawPhased.js +14 -10
  176. package/esm/shared/minorAlleleFrequencyUtils.d.ts +6 -1
  177. package/esm/shared/minorAlleleFrequencyUtils.js +5 -6
  178. package/esm/shared/sourcesGridUtils.d.ts +3 -2
  179. package/package.json +10 -9
  180. package/dist/MultiLinearVariantDisplay/components/Crosshair.d.ts +0 -7
  181. package/dist/MultiLinearVariantDisplay/components/Crosshair.js +0 -35
  182. package/dist/MultiLinearVariantMatrixDisplay/components/Crosshair.d.ts +0 -7
  183. package/dist/MultiLinearVariantMatrixDisplay/components/Crosshair.js +0 -28
  184. package/dist/MultiLinearVariantMatrixRenderer/components/LinearVariantMatrixRendering.d.ts +0 -7
  185. package/dist/MultiLinearVariantMatrixRenderer/components/LinearVariantMatrixRendering.js +0 -38
  186. package/dist/MultiLinearVariantRenderer/MultiVariantRendering.d.ts +0 -22
  187. package/dist/MultiLinearVariantRenderer/components/MultiVariantRendering.js +0 -52
  188. package/dist/VariantFeatureWidget/VariantConsequencePanel.d.ts +0 -5
  189. package/dist/VariantFeatureWidget/VariantConsequencePanel.js +0 -15
  190. package/dist/VariantRPC/cluster.d.ts +0 -17
  191. package/dist/VariantRPC/cluster.js +0 -84
  192. package/dist/shared/components/LegendBar.d.ts +0 -18
  193. package/esm/MultiLinearVariantDisplay/components/Crosshair.d.ts +0 -7
  194. package/esm/MultiLinearVariantDisplay/components/Crosshair.js +0 -30
  195. package/esm/MultiLinearVariantMatrixDisplay/components/Crosshair.d.ts +0 -7
  196. package/esm/MultiLinearVariantMatrixDisplay/components/Crosshair.js +0 -23
  197. package/esm/MultiLinearVariantMatrixRenderer/components/LinearVariantMatrixRendering.d.ts +0 -7
  198. package/esm/MultiLinearVariantMatrixRenderer/components/LinearVariantMatrixRendering.js +0 -36
  199. package/esm/MultiLinearVariantRenderer/MultiVariantRendering.d.ts +0 -22
  200. package/esm/MultiLinearVariantRenderer/MultiVariantRendering.js +0 -47
  201. package/esm/VariantFeatureWidget/VariantConsequencePanel.d.ts +0 -5
  202. package/esm/VariantFeatureWidget/VariantConsequencePanel.js +0 -9
  203. package/esm/VariantRPC/cluster.d.ts +0 -17
  204. package/esm/VariantRPC/cluster.js +0 -79
  205. package/esm/shared/components/LegendBar.d.ts +0 -18
  206. /package/dist/MultiLinearVariantMatrixRenderer/{LinearVariantMatrixRenderer.js → MultiLinearVariantMatrixRenderer.js} +0 -0
  207. /package/dist/VariantFeatureWidget/{VariantConsequenceDataGrid.d.ts → VariantConsequence/VariantConsequenceDataGrid.d.ts} +0 -0
  208. /package/dist/VariantFeatureWidget/{VariantConsequenceDataGrid.js → VariantConsequence/VariantConsequenceDataGrid.js} +0 -0
  209. /package/dist/VariantFeatureWidget/{VariantConsequenceDataGridWrapper.d.ts → VariantConsequence/VariantConsequenceDataGridWrapper.d.ts} +0 -0
  210. /package/dist/{shared/components/ClusterDialog → VariantFeatureWidget/VariantSampleGrid}/types.js +0 -0
  211. /package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialog.d.ts +0 -0
  212. /package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogAuto.d.ts +0 -0
  213. /package/dist/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogManual.d.ts +0 -0
  214. /package/esm/MultiLinearVariantMatrixRenderer/{LinearVariantMatrixRenderer.js → MultiLinearVariantMatrixRenderer.js} +0 -0
  215. /package/esm/VariantFeatureWidget/{VariantConsequenceDataGrid.d.ts → VariantConsequence/VariantConsequenceDataGrid.d.ts} +0 -0
  216. /package/esm/VariantFeatureWidget/{VariantConsequenceDataGrid.js → VariantConsequence/VariantConsequenceDataGrid.js} +0 -0
  217. /package/esm/VariantFeatureWidget/{VariantConsequenceDataGridWrapper.d.ts → VariantConsequence/VariantConsequenceDataGridWrapper.d.ts} +0 -0
  218. /package/esm/{shared/components/ClusterDialog → VariantFeatureWidget/VariantSampleGrid}/types.js +0 -0
  219. /package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialog.d.ts +0 -0
  220. /package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogAuto.d.ts +0 -0
  221. /package/esm/shared/components/{ClusterDialog → MultiVariantClusterDialog}/ClusterDialogManual.d.ts +0 -0
@@ -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,88 @@ 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
17
  (0, stopToken_1.checkStopToken)(stopToken);
18
- const mafs = (0, minorAlleleFrequencyUtils_1.getFeaturesThatPassMinorAlleleFrequencyFilter)(features.values(), minorAlleleFrequencyFilter);
18
+ const mafs = (0, minorAlleleFrequencyUtils_1.getFeaturesThatPassMinorAlleleFrequencyFilter)({
19
+ stopToken,
20
+ features: features.values(),
21
+ minorAlleleFrequencyFilter,
22
+ lengthCutoffFilter,
23
+ });
19
24
  (0, stopToken_1.checkStopToken)(stopToken);
20
25
  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
- }
26
+ (0, util_1.forEachWithStopTokenCheck)(mafs, stopToken, ({ mostFrequentAlt, feature }) => {
27
27
  const [leftPx, rightPx] = (0, util_1.featureSpanPx)(feature, region, bpPerPx);
28
28
  const w = Math.max(Math.round(rightPx - leftPx), 2);
29
29
  const samp = feature.get('genotypes');
30
30
  let y = -scrollTop;
31
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') {
32
+ if (renderingMode === 'phased') {
33
+ for (let j = 0; j < s; j++) {
34
+ const { name, HP } = sources[j];
35
+ const genotype = samp[name];
36
+ const x = Math.floor(leftPx);
37
+ const h = Math.max(rowHeight, 1);
38
+ if (genotype) {
39
+ const isPhased = genotype.includes('|');
47
40
  if (isPhased) {
48
41
  const alleles = genotype.split('|');
49
- (0, drawPhased_1.drawPhased)(alleles, ctx, x, y, w, h, HP);
42
+ if ((0, drawPhased_1.drawPhased)(alleles, ctx, x, y, w, h, HP, undefined, referenceDrawingMode === 'draw')) {
43
+ rbush.insert({
44
+ minX: x,
45
+ maxX: x + w,
46
+ minY: y,
47
+ maxY: y + h,
48
+ genotype,
49
+ name,
50
+ featureId: feature.id(),
51
+ });
52
+ }
50
53
  }
51
54
  else {
52
55
  ctx.fillStyle = 'black';
53
56
  ctx.fillRect(x - constants_1.f2, y - constants_1.f2, w + constants_1.f2, h + constants_1.f2);
54
57
  }
55
58
  }
56
- else {
59
+ y += rowHeight;
60
+ }
61
+ }
62
+ else {
63
+ for (let j = 0; j < s; j++) {
64
+ const { name } = sources[j];
65
+ const genotype = samp[name];
66
+ const x = Math.floor(leftPx);
67
+ const h = Math.max(rowHeight, 1);
68
+ if (genotype) {
57
69
  const alleles = genotype.split(/[/|]/);
58
- (0, drawAlleleCount_1.drawColorAlleleCount)(alleles, ctx, x, y, w, h, mostFrequentAlt);
70
+ if ((0, drawAlleleCount_1.drawColorAlleleCount)(alleles, ctx, x, y, w, h, mostFrequentAlt, referenceDrawingMode === 'draw', feature.get('type'), feature.get('strand'), 0.75)) {
71
+ rbush.insert({
72
+ minX: x,
73
+ maxX: x + w,
74
+ minY: y,
75
+ maxY: y + h,
76
+ genotype,
77
+ name,
78
+ featureId: feature.id(),
79
+ });
80
+ }
59
81
  }
82
+ y += rowHeight;
60
83
  }
61
- y += rowHeight;
62
84
  }
63
- }
85
+ });
64
86
  return {
65
87
  rbush: rbush.toJSON(),
88
+ featureGenotypeMap: Object.fromEntries(mafs.map(({ feature }) => [
89
+ feature.id(),
90
+ {
91
+ alt: feature.get('ALT'),
92
+ ref: feature.get('REF'),
93
+ name: feature.get('name'),
94
+ description: feature.get('description'),
95
+ length: feature.get('end') - feature.get('start'),
96
+ },
97
+ ])),
66
98
  };
67
99
  }
@@ -16,4 +16,5 @@ export interface MultiRenderArgsDeserialized extends RenderArgsDeserializedWithF
16
16
  rowHeight: number;
17
17
  scrollTop: number;
18
18
  minorAlleleFrequencyFilter: number;
19
+ lengthCutoffFilter: number;
19
20
  }
@@ -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
  }
@@ -0,0 +1,3 @@
1
+ export default function Formatter({ value }: {
2
+ value: unknown;
3
+ }): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.default = Formatter;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const react_1 = require("react");
9
+ const copy_to_clipboard_1 = __importDefault(require("copy-to-clipboard"));
10
+ function Formatter({ value }) {
11
+ const [show, setShow] = (0, react_1.useState)(false);
12
+ const [copied, setCopied] = (0, react_1.useState)(false);
13
+ const display = String(value);
14
+ return display.length > 100 ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)("button", { type: "button", onClick: () => {
15
+ (0, copy_to_clipboard_1.default)(display);
16
+ setCopied(true);
17
+ setTimeout(() => {
18
+ setCopied(false);
19
+ }, 700);
20
+ }, children: copied ? 'Copied to clipboard' : 'Copy' }), (0, jsx_runtime_1.jsx)("button", { type: "button", onClick: () => {
21
+ setShow(val => !val);
22
+ }, children: show ? 'Show less' : 'Show more' }), (0, jsx_runtime_1.jsx)("div", { children: show ? display : `${display.slice(0, 100)}...` })] })) : ((0, jsx_runtime_1.jsx)("div", { children: display }));
23
+ }
@@ -9,12 +9,10 @@ const x_data_grid_1 = require("@mui/x-data-grid");
9
9
  function VariantConsequenceDataGridWrapper({ rows, columns, }) {
10
10
  const [checked, setChecked] = (0, react_1.useState)(false);
11
11
  const widths = columns.map(e => (0, util_1.measureGridWidth)(rows.map(r => r[e.field])));
12
- return rows.length ? ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { control: (0, jsx_runtime_1.jsx)(material_1.Checkbox, { checked: checked, onChange: event => {
12
+ return rows.length ? ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { label: (0, jsx_runtime_1.jsx)(material_1.Typography, { variant: "body2", children: "Show options" }), control: (0, jsx_runtime_1.jsx)(material_1.Checkbox, { checked: checked, onChange: event => {
13
13
  setChecked(event.target.checked);
14
- } }), label: (0, jsx_runtime_1.jsx)(material_1.Typography, { variant: "body2", children: "Show options" }) }), (0, jsx_runtime_1.jsx)(x_data_grid_1.DataGrid, { rowHeight: 25, rows: rows, columns: columns.map((c, i) => ({
14
+ } }) }), (0, jsx_runtime_1.jsx)(x_data_grid_1.DataGrid, { rowHeight: 25, hideFooter: rows.length < 100, rows: rows, showToolbar: checked, columns: columns.map((c, i) => ({
15
15
  ...c,
16
16
  width: widths[i],
17
- })), slots: {
18
- toolbar: checked ? x_data_grid_1.GridToolbar : null,
19
- } })] })) : null;
17
+ })) })] })) : null;
20
18
  }
@@ -42,10 +42,12 @@ const vcf_1 = require("@gmod/vcf");
42
42
  const FeatureDetails_1 = __importDefault(require("@jbrowse/core/BaseFeatureWidget/BaseFeatureDetail/FeatureDetails"));
43
43
  const material_1 = require("@mui/material");
44
44
  const mobx_react_1 = require("mobx-react");
45
+ const AltFormatter_1 = __importDefault(require("./AltFormatter"));
46
+ const Formatter_1 = __importDefault(require("./Formatter"));
45
47
  const VariantSampleGrid_1 = __importDefault(require("./VariantSampleGrid/VariantSampleGrid"));
46
48
  const variantFieldDescriptions_1 = require("./variantFieldDescriptions");
47
49
  const LaunchBreakendPanel = (0, react_1.lazy)(() => Promise.resolve().then(() => __importStar(require('./LaunchBreakendPanel/LaunchBreakendPanel'))));
48
- const VariantConsequenceDataGrid = (0, react_1.lazy)(() => Promise.resolve().then(() => __importStar(require('./VariantConsequenceDataGrid'))));
50
+ const VariantConsequenceDataGrid = (0, react_1.lazy)(() => Promise.resolve().then(() => __importStar(require('./VariantConsequence/VariantConsequenceDataGrid'))));
49
51
  function AnnPanel({ descriptions, feature, }) {
50
52
  var _a, _b, _c, _d, _e;
51
53
  const annDesc = (_b = (_a = descriptions === null || descriptions === void 0 ? void 0 : descriptions.INFO) === null || _a === void 0 ? void 0 : _a.ANN) === null || _b === void 0 ? void 0 : _b.Description;
@@ -84,10 +86,13 @@ const VariantFeatureWidget = (0, mobx_react_1.observer)(function (props) {
84
86
  const { model } = props;
85
87
  const { featureData, descriptions } = model;
86
88
  const feat = JSON.parse(JSON.stringify(featureData));
87
- const { samples, ALT, ...rest } = feat;
89
+ const { samples, ...rest } = feat;
90
+ const { REF } = rest;
88
91
  return ((0, jsx_runtime_1.jsxs)(material_1.Paper, { "data-testid": "variant-side-drawer", children: [(0, jsx_runtime_1.jsx)(FeatureDetails_1.default, { feature: rest, descriptions: {
89
92
  ...variantFieldDescriptions_1.variantFieldDescriptions,
90
93
  ...descriptions,
94
+ }, formatter: (value, key) => {
95
+ return key === 'ALT' ? ((0, jsx_runtime_1.jsx)(AltFormatter_1.default, { value: `${value}`, ref: REF })) : ((0, jsx_runtime_1.jsx)(Formatter_1.default, { value: value }));
91
96
  }, ...props }), (0, jsx_runtime_1.jsxs)(react_1.Suspense, { fallback: null, children: [(0, jsx_runtime_1.jsx)(CsqPanel, { feature: rest, descriptions: descriptions }), (0, jsx_runtime_1.jsx)(AnnPanel, { feature: rest, descriptions: descriptions }), (0, jsx_runtime_1.jsx)(LaunchBreakendWidgetArea, { model: model })] }), (0, jsx_runtime_1.jsx)(VariantSampleGrid_1.default, { feature: feat, ...props, descriptions: descriptions })] }));
92
97
  });
93
98
  exports.default = VariantFeatureWidget;
@@ -0,0 +1,4 @@
1
+ import type { VariantSampleGridRow } from './types';
2
+ export default function VariantGenotypeFrequencyTable({ rows, }: {
3
+ rows: VariantSampleGridRow[];
4
+ }): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.default = VariantGenotypeFrequencyTable;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const react_1 = require("react");
9
+ const DataGridFlexContainer_1 = __importDefault(require("@jbrowse/core/ui/DataGridFlexContainer"));
10
+ const util_1 = require("@jbrowse/core/util");
11
+ const material_1 = require("@mui/material");
12
+ const x_data_grid_1 = require("@mui/x-data-grid");
13
+ function toP(n) {
14
+ return n.toPrecision(3);
15
+ }
16
+ function VariantGenotypeFrequencyTable({ rows, }) {
17
+ const [useCounts, setUseCounts] = (0, react_1.useState)(false);
18
+ const summary = {};
19
+ if (!useCounts) {
20
+ for (const row of rows) {
21
+ const gt = row.GT;
22
+ if (!summary[gt]) {
23
+ summary[gt] = {
24
+ count: 0,
25
+ GT: row.GT,
26
+ genotype: row.genotype,
27
+ };
28
+ }
29
+ summary[gt].count++;
30
+ }
31
+ }
32
+ else {
33
+ for (const row of rows) {
34
+ const alleleCounts = {};
35
+ const alleles = row.GT.split(/[/|]/);
36
+ for (const allele of alleles) {
37
+ alleleCounts[allele] = (alleleCounts[allele] || 0) + 1;
38
+ }
39
+ const key = Object.entries(alleleCounts)
40
+ .map(([key, val]) => `${key}:${val}`)
41
+ .join(';');
42
+ if (!summary[key]) {
43
+ summary[key] = {
44
+ count: 0,
45
+ GT: key,
46
+ genotype: row.genotype,
47
+ };
48
+ }
49
+ summary[key].count++;
50
+ }
51
+ }
52
+ const gridRows = Object.entries(summary).map(([key, val]) => ({
53
+ id: key,
54
+ ...val,
55
+ count: `${val.count} / ${rows.length}`,
56
+ frequency: `${toP((val.count / rows.length) * 100)}%`,
57
+ }));
58
+ const keys = gridRows[0] ? Object.keys(gridRows[0]) : [];
59
+ const widths = keys.map(e => (0, util_1.measureGridWidth)(gridRows.map(r => `${r[e]}`)));
60
+ return ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { control: (0, jsx_runtime_1.jsx)(material_1.Checkbox, { checked: useCounts }), label: (0, jsx_runtime_1.jsx)(material_1.Typography, { variant: "body2", children: "Use allele counts instead of exact GT" }), onChange: (_, checked) => {
61
+ setUseCounts(checked);
62
+ } }), (0, jsx_runtime_1.jsx)(DataGridFlexContainer_1.default, { children: (0, jsx_runtime_1.jsx)(x_data_grid_1.DataGrid, { rows: gridRows, hideFooter: true, rowHeight: 25, columnHeaderHeight: 35, columns: [
63
+ {
64
+ field: 'GT',
65
+ width: widths[0],
66
+ },
67
+ {
68
+ field: 'count',
69
+ width: widths[1],
70
+ },
71
+ {
72
+ field: 'frequency',
73
+ width: widths[2],
74
+ },
75
+ {
76
+ field: 'genotype',
77
+ width: widths[3],
78
+ },
79
+ ] }) })] }));
80
+ }
@@ -1,12 +1,6 @@
1
+ import type { VariantFieldDescriptions } from './types';
1
2
  import type { SimpleFeatureSerialized } from '@jbrowse/core/util';
2
- interface FormatRecord {
3
- Description?: string;
4
- }
5
- interface Descriptions {
6
- FORMAT?: Record<string, FormatRecord>;
7
- }
8
- export default function VariantSamples(props: {
3
+ export default function VariantSampleGrid(props: {
9
4
  feature: SimpleFeatureSerialized;
10
- descriptions?: Descriptions | null;
5
+ descriptions?: VariantFieldDescriptions | null;
11
6
  }): import("react/jsx-runtime").JSX.Element | null;
12
- export {};
@@ -3,30 +3,54 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.default = VariantSamples;
6
+ exports.default = VariantSampleGrid;
7
7
  const jsx_runtime_1 = require("react/jsx-runtime");
8
8
  const react_1 = require("react");
9
9
  const BaseCard_1 = __importDefault(require("@jbrowse/core/BaseFeatureWidget/BaseFeatureDetail/BaseCard"));
10
+ const ui_1 = require("@jbrowse/core/ui");
11
+ const DataGridFlexContainer_1 = __importDefault(require("@jbrowse/core/ui/DataGridFlexContainer"));
12
+ const ErrorBoundary_1 = require("@jbrowse/core/ui/ErrorBoundary");
10
13
  const util_1 = require("@jbrowse/core/util");
11
14
  const material_1 = require("@mui/material");
12
15
  const x_data_grid_1 = require("@mui/x-data-grid");
16
+ const Checkbox2_1 = __importDefault(require("../Checkbox2"));
17
+ const VariantGenotypeFrequencyTable_1 = __importDefault(require("./VariantGenotypeFrequencyTable"));
13
18
  const VariantSampleFilters_1 = __importDefault(require("./VariantSampleFilters"));
14
- function VariantSamples(props) {
19
+ const util_2 = require("./util");
20
+ const util_3 = require("../../VcfFeature/util");
21
+ function VariantSampleGrid(props) {
15
22
  var _a;
16
23
  const { feature, descriptions = {} } = props;
17
24
  const [filter, setFilter] = (0, react_1.useState)({});
25
+ const [showOnlyGenotypeColumns, setShowOnlyGenotypeColumns] = (0, react_1.useState)(true);
26
+ const [showFilters, setShowFilters] = (0, react_1.useState)(false);
18
27
  const samples = (feature.samples || {});
19
- const preFilteredRows = Object.entries(samples);
28
+ const ALT = feature.ALT;
29
+ const REF = feature.REF;
30
+ const preFilteredRows = Object.entries(samples).map(([key, val]) => {
31
+ var _a, _b;
32
+ return [
33
+ key,
34
+ {
35
+ ...val,
36
+ GT: `${(_a = val.GT) === null || _a === void 0 ? void 0 : _a[0]}`,
37
+ genotype: (0, util_3.makeSimpleAltString)(`${(_b = val.GT) === null || _b === void 0 ? void 0 : _b[0]}`, REF, ALT),
38
+ },
39
+ ];
40
+ });
20
41
  let error;
21
42
  let rows = [];
22
43
  const filters = Object.keys(filter);
23
44
  try {
24
45
  rows = preFilteredRows
25
- .map(row => {
46
+ .map(([key, val]) => {
26
47
  return {
27
- ...Object.fromEntries(Object.entries(row[1]).map(e => [e[0], `${e[1]}`])),
28
- sample: row[0],
29
- id: row[0],
48
+ ...Object.fromEntries(Object.entries(val).map(([formatField, formatValue]) => [
49
+ formatField,
50
+ formatValue,
51
+ ])),
52
+ sample: key,
53
+ id: key,
30
54
  };
31
55
  })
32
56
  .filter(row => filters.length
@@ -39,9 +63,9 @@ function VariantSamples(props) {
39
63
  : true);
40
64
  }
41
65
  catch (e) {
66
+ console.error(e);
42
67
  error = e;
43
68
  }
44
- const [checked, setChecked] = (0, react_1.useState)(false);
45
69
  const keys = ['sample', ...Object.keys(((_a = preFilteredRows[0]) === null || _a === void 0 ? void 0 : _a[1]) || {})];
46
70
  const widths = keys.map(e => (0, util_1.measureGridWidth)(rows.map(r => r[e])));
47
71
  const columns = keys.map((field, index) => {
@@ -52,16 +76,13 @@ function VariantSamples(props) {
52
76
  width: widths[index],
53
77
  });
54
78
  });
55
- return !preFilteredRows.length ? null : ((0, jsx_runtime_1.jsxs)(BaseCard_1.default, { ...props, title: "Samples", children: [error ? (0, jsx_runtime_1.jsx)(material_1.Typography, { color: "error", children: `${error}` }) : null, (0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { control: (0, jsx_runtime_1.jsx)(material_1.Checkbox, { checked: checked, onChange: event => {
56
- setChecked(event.target.checked);
57
- } }), label: (0, jsx_runtime_1.jsx)(material_1.Typography, { variant: "body2", children: "Show options" }) }), checked ? ((0, jsx_runtime_1.jsx)(VariantSampleFilters_1.default, { setFilter: setFilter, columns: columns, filter: filter })) : null, (0, jsx_runtime_1.jsx)("div", { style: {
58
- display: 'flex',
59
- flexDirection: 'column',
60
- }, children: (0, jsx_runtime_1.jsx)(x_data_grid_1.DataGrid, { rows: rows, hideFooter: rows.length < 100, columns: columns, disableRowSelectionOnClick: true, rowHeight: 25, columnHeaderHeight: 35, disableColumnMenu: true, slots: { toolbar: checked ? x_data_grid_1.GridToolbar : null }, slotProps: {
61
- toolbar: {
62
- printOptions: {
63
- disableToolbarButton: true,
64
- },
65
- },
66
- } }) })] }));
79
+ const s1 = new Set(['sample', 'GT', 'genotype']);
80
+ const s2 = new Set(keys);
81
+ return !preFilteredRows.length ? null : ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(BaseCard_1.default, { ...props, title: "Genotype frequencies", children: (0, jsx_runtime_1.jsx)(ErrorBoundary_1.ErrorBoundary, { FallbackComponent: ui_1.ErrorMessage, children: (0, jsx_runtime_1.jsx)(VariantGenotypeFrequencyTable_1.default, { rows: rows }) }) }), (0, jsx_runtime_1.jsxs)(BaseCard_1.default, { ...props, title: "Samples", children: [error ? (0, jsx_runtime_1.jsx)(material_1.Typography, { color: "error", children: `${error}` }) : null, (0, jsx_runtime_1.jsx)(Checkbox2_1.default, { label: "Show filters", checked: showFilters, onChange: event => {
82
+ setShowFilters(event.target.checked);
83
+ } }), (0, util_2.areSetsEqual)(s1, s2) ? null : ((0, jsx_runtime_1.jsx)(Checkbox2_1.default, { label: "Show only genotype columns", checked: showOnlyGenotypeColumns, onChange: event => {
84
+ setShowOnlyGenotypeColumns(event.target.checked);
85
+ } })), showFilters ? ((0, jsx_runtime_1.jsx)(VariantSampleFilters_1.default, { setFilter: setFilter, columns: columns, filter: filter })) : null, (0, jsx_runtime_1.jsx)(DataGridFlexContainer_1.default, { children: (0, jsx_runtime_1.jsx)(x_data_grid_1.DataGrid, { rows: rows, hideFooter: rows.length < 100, columns: showOnlyGenotypeColumns
86
+ ? columns.filter(f => s1.has(f.field))
87
+ : columns, rowHeight: 25, columnHeaderHeight: 35, showToolbar: true }) })] })] }));
67
88
  }
@@ -0,0 +1,21 @@
1
+ export interface FrequencyTableEntry {
2
+ count: number;
3
+ GT: string;
4
+ genotype: string | undefined;
5
+ }
6
+ export type FrequencyTable = Record<string, FrequencyTableEntry>;
7
+ export interface VariantSampleGridRow {
8
+ sample: string;
9
+ id: string;
10
+ GT: string;
11
+ [key: string]: string;
12
+ }
13
+ export type InfoFields = Record<string, unknown[]>;
14
+ export type Filters = Record<string, string>;
15
+ interface FormatRecord {
16
+ Description?: string;
17
+ }
18
+ export interface VariantFieldDescriptions {
19
+ FORMAT?: Record<string, FormatRecord>;
20
+ }
21
+ export {};
@@ -0,0 +1 @@
1
+ export declare function areSetsEqual<T>(set1: Set<T>, set2: Set<T>): boolean;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.areSetsEqual = areSetsEqual;
4
+ function areSetsEqual(set1, set2) {
5
+ if (set1.size !== set2.size) {
6
+ return false;
7
+ }
8
+ for (const item of set1) {
9
+ if (!set2.has(item)) {
10
+ return false;
11
+ }
12
+ }
13
+ return true;
14
+ }
@@ -1,21 +1,8 @@
1
1
  import RpcMethodTypeWithFiltersAndRenameRegions from '@jbrowse/core/pluggableElementTypes/RpcMethodTypeWithFiltersAndRenameRegions';
2
- import type { Source } from '../shared/types';
3
- import type { AnyConfigurationModel } from '@jbrowse/core/configuration';
4
- import type { Region } from '@jbrowse/core/util';
5
- interface Args {
6
- adapterConfig: AnyConfigurationModel;
7
- stopToken?: string;
8
- statusCallback: (arg: string) => void;
9
- sessionId: string;
10
- headers?: Record<string, string>;
11
- regions: Region[];
12
- bpPerPx: number;
13
- sources: Source[];
14
- minorAlleleFrequencyFilter: number;
15
- }
2
+ import type { ClusterGenotypeMatrixArgs } from './types';
16
3
  export declare class MultiVariantClusterGenotypeMatrix extends RpcMethodTypeWithFiltersAndRenameRegions {
17
4
  name: string;
18
- execute(args: Args, rpcDriverClassName: string): Promise<{
5
+ execute(args: ClusterGenotypeMatrixArgs, rpcDriverClassName: string): Promise<{
19
6
  clusters: {
20
7
  height: number;
21
8
  indexes: number[];
@@ -25,4 +12,3 @@ export declare class MultiVariantClusterGenotypeMatrix extends RpcMethodTypeWith
25
12
  clustersGivenK: number[][][];
26
13
  }>;
27
14
  }
28
- export {};