@jbrowse/plugin-spreadsheet-view 2.17.0 → 2.18.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 (197) hide show
  1. package/dist/LaunchSpreadsheetView/index.d.ts +1 -1
  2. package/dist/LaunchSpreadsheetView/index.js +1 -3
  3. package/dist/SpreadsheetView/ImportWizard.d.ts +51 -0
  4. package/dist/SpreadsheetView/ImportWizard.js +240 -0
  5. package/dist/SpreadsheetView/SpreadsheetModel.d.ts +79 -0
  6. package/dist/SpreadsheetView/SpreadsheetModel.js +133 -0
  7. package/dist/SpreadsheetView/SpreadsheetViewModel.d.ts +299 -0
  8. package/dist/SpreadsheetView/SpreadsheetViewModel.js +94 -0
  9. package/dist/SpreadsheetView/components/BreakendMultiLevelOptionDialog.d.ts +1 -0
  10. package/dist/SpreadsheetView/components/BreakendMultiLevelOptionDialog.js +5 -0
  11. package/dist/SpreadsheetView/components/BreakendSingleLevelOptionDialog.d.ts +1 -0
  12. package/dist/SpreadsheetView/components/BreakendSingleLevelOptionDialog.js +5 -0
  13. package/dist/SpreadsheetView/components/FeatureMenu.d.ts +8 -0
  14. package/dist/SpreadsheetView/components/FeatureMenu.js +95 -0
  15. package/dist/SpreadsheetView/components/ImportWizard.d.ts +2 -2
  16. package/dist/SpreadsheetView/components/ImportWizard.js +40 -43
  17. package/dist/SpreadsheetView/components/LocationCell.d.ts +8 -0
  18. package/dist/SpreadsheetView/components/LocationCell.js +31 -0
  19. package/dist/SpreadsheetView/components/NumberEditor.d.ts +1 -1
  20. package/dist/SpreadsheetView/components/NumberEditor.js +1 -3
  21. package/dist/SpreadsheetView/components/SpreadsheetDataGrid.d.ts +6 -0
  22. package/dist/SpreadsheetView/components/SpreadsheetDataGrid.js +27 -0
  23. package/dist/SpreadsheetView/components/SpreadsheetView.d.ts +3 -3
  24. package/dist/SpreadsheetView/components/SpreadsheetView.js +23 -44
  25. package/dist/SpreadsheetView/components/TrackSelector.d.ts +7 -0
  26. package/dist/SpreadsheetView/components/TrackSelector.js +49 -0
  27. package/dist/SpreadsheetView/importAdapters/BedImport.d.ts +26 -17
  28. package/dist/SpreadsheetView/importAdapters/BedImport.js +53 -139
  29. package/dist/SpreadsheetView/importAdapters/BedpeImport.d.ts +36 -0
  30. package/dist/SpreadsheetView/importAdapters/BedpeImport.js +79 -0
  31. package/dist/SpreadsheetView/importAdapters/STARFusionImport.d.ts +25 -9
  32. package/dist/SpreadsheetView/importAdapters/STARFusionImport.js +27 -62
  33. package/dist/SpreadsheetView/importAdapters/VcfImport.d.ts +19 -12
  34. package/dist/SpreadsheetView/importAdapters/VcfImport.js +53 -98
  35. package/dist/SpreadsheetView/importAdapters/isNumber.d.ts +1 -0
  36. package/dist/SpreadsheetView/importAdapters/isNumber.js +14 -0
  37. package/dist/SpreadsheetView/importAdapters/util.d.ts +2 -0
  38. package/dist/SpreadsheetView/importAdapters/util.js +22 -0
  39. package/dist/SpreadsheetView/index.d.ts +2 -2
  40. package/dist/SpreadsheetView/index.js +2 -2
  41. package/dist/SpreadsheetView/util.d.ts +7 -0
  42. package/dist/SpreadsheetView/util.js +13 -0
  43. package/dist/index.d.ts +1 -1
  44. package/dist/index.js +1 -3
  45. package/esm/LaunchSpreadsheetView/index.d.ts +1 -1
  46. package/esm/LaunchSpreadsheetView/index.js +1 -3
  47. package/esm/SpreadsheetView/ImportWizard.d.ts +51 -0
  48. package/esm/SpreadsheetView/ImportWizard.js +214 -0
  49. package/esm/SpreadsheetView/SpreadsheetModel.d.ts +79 -0
  50. package/esm/SpreadsheetView/SpreadsheetModel.js +127 -0
  51. package/esm/SpreadsheetView/SpreadsheetViewModel.d.ts +299 -0
  52. package/esm/SpreadsheetView/SpreadsheetViewModel.js +88 -0
  53. package/esm/SpreadsheetView/components/BreakendMultiLevelOptionDialog.d.ts +1 -0
  54. package/esm/SpreadsheetView/components/BreakendMultiLevelOptionDialog.js +1 -0
  55. package/esm/SpreadsheetView/components/BreakendSingleLevelOptionDialog.d.ts +1 -0
  56. package/esm/SpreadsheetView/components/BreakendSingleLevelOptionDialog.js +1 -0
  57. package/esm/SpreadsheetView/components/FeatureMenu.d.ts +8 -0
  58. package/esm/SpreadsheetView/components/FeatureMenu.js +66 -0
  59. package/esm/SpreadsheetView/components/ImportWizard.d.ts +2 -2
  60. package/esm/SpreadsheetView/components/ImportWizard.js +41 -44
  61. package/esm/SpreadsheetView/components/LocationCell.d.ts +8 -0
  62. package/esm/SpreadsheetView/components/LocationCell.js +25 -0
  63. package/esm/SpreadsheetView/components/NumberEditor.d.ts +1 -1
  64. package/esm/SpreadsheetView/components/NumberEditor.js +2 -4
  65. package/esm/SpreadsheetView/components/SpreadsheetDataGrid.d.ts +6 -0
  66. package/esm/SpreadsheetView/components/SpreadsheetDataGrid.js +22 -0
  67. package/esm/SpreadsheetView/components/SpreadsheetView.d.ts +3 -3
  68. package/esm/SpreadsheetView/components/SpreadsheetView.js +24 -45
  69. package/esm/SpreadsheetView/components/TrackSelector.d.ts +7 -0
  70. package/esm/SpreadsheetView/components/TrackSelector.js +24 -0
  71. package/esm/SpreadsheetView/importAdapters/BedImport.d.ts +26 -17
  72. package/esm/SpreadsheetView/importAdapters/BedImport.js +53 -137
  73. package/esm/SpreadsheetView/importAdapters/BedpeImport.d.ts +36 -0
  74. package/esm/SpreadsheetView/importAdapters/BedpeImport.js +76 -0
  75. package/esm/SpreadsheetView/importAdapters/STARFusionImport.d.ts +25 -9
  76. package/esm/SpreadsheetView/importAdapters/STARFusionImport.js +27 -62
  77. package/esm/SpreadsheetView/importAdapters/VcfImport.d.ts +19 -12
  78. package/esm/SpreadsheetView/importAdapters/VcfImport.js +53 -97
  79. package/esm/SpreadsheetView/importAdapters/isNumber.d.ts +1 -0
  80. package/esm/SpreadsheetView/importAdapters/isNumber.js +11 -0
  81. package/esm/SpreadsheetView/importAdapters/util.d.ts +2 -0
  82. package/esm/SpreadsheetView/importAdapters/util.js +18 -0
  83. package/esm/SpreadsheetView/index.d.ts +2 -2
  84. package/esm/SpreadsheetView/index.js +2 -2
  85. package/esm/SpreadsheetView/util.d.ts +7 -0
  86. package/esm/SpreadsheetView/util.js +10 -0
  87. package/esm/index.d.ts +1 -1
  88. package/esm/index.js +1 -3
  89. package/package.json +6 -6
  90. package/dist/SpreadsheetView/components/CellData.d.ts +0 -9
  91. package/dist/SpreadsheetView/components/CellData.js +0 -14
  92. package/dist/SpreadsheetView/components/ColumnFilterControls.d.ts +0 -3
  93. package/dist/SpreadsheetView/components/ColumnFilterControls.js +0 -58
  94. package/dist/SpreadsheetView/components/ColumnMenu.d.ts +0 -16
  95. package/dist/SpreadsheetView/components/ColumnMenu.js +0 -140
  96. package/dist/SpreadsheetView/components/DataRow.d.ts +0 -12
  97. package/dist/SpreadsheetView/components/DataRow.js +0 -81
  98. package/dist/SpreadsheetView/components/DataTable.d.ts +0 -10
  99. package/dist/SpreadsheetView/components/DataTable.js +0 -42
  100. package/dist/SpreadsheetView/components/DataTableHeader.d.ts +0 -6
  101. package/dist/SpreadsheetView/components/DataTableHeader.js +0 -104
  102. package/dist/SpreadsheetView/components/GlobalFilterControls.d.ts +0 -5
  103. package/dist/SpreadsheetView/components/GlobalFilterControls.js +0 -68
  104. package/dist/SpreadsheetView/components/RowCountMessage.d.ts +0 -6
  105. package/dist/SpreadsheetView/components/RowCountMessage.js +0 -33
  106. package/dist/SpreadsheetView/components/RowMenu.d.ts +0 -9
  107. package/dist/SpreadsheetView/components/RowMenu.js +0 -39
  108. package/dist/SpreadsheetView/components/SortIndicator.d.ts +0 -6
  109. package/dist/SpreadsheetView/components/SortIndicator.js +0 -27
  110. package/dist/SpreadsheetView/components/Spreadsheet.d.ts +0 -11
  111. package/dist/SpreadsheetView/components/Spreadsheet.js +0 -25
  112. package/dist/SpreadsheetView/components/StatusBar.d.ts +0 -11
  113. package/dist/SpreadsheetView/components/StatusBar.js +0 -44
  114. package/dist/SpreadsheetView/importAdapters/ImportUtils.d.ts +0 -42
  115. package/dist/SpreadsheetView/importAdapters/ImportUtils.js +0 -123
  116. package/dist/SpreadsheetView/models/ColumnDataTypes/LocEnd.d.ts +0 -12
  117. package/dist/SpreadsheetView/models/ColumnDataTypes/LocEnd.js +0 -20
  118. package/dist/SpreadsheetView/models/ColumnDataTypes/LocRef.d.ts +0 -12
  119. package/dist/SpreadsheetView/models/ColumnDataTypes/LocRef.js +0 -20
  120. package/dist/SpreadsheetView/models/ColumnDataTypes/LocStart.d.ts +0 -12
  121. package/dist/SpreadsheetView/models/ColumnDataTypes/LocStart.js +0 -20
  122. package/dist/SpreadsheetView/models/ColumnDataTypes/LocString.d.ts +0 -13
  123. package/dist/SpreadsheetView/models/ColumnDataTypes/LocString.js +0 -183
  124. package/dist/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.d.ts +0 -19
  125. package/dist/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.js +0 -23
  126. package/dist/SpreadsheetView/models/ColumnDataTypes/Number.d.ts +0 -30
  127. package/dist/SpreadsheetView/models/ColumnDataTypes/Number.js +0 -126
  128. package/dist/SpreadsheetView/models/ColumnDataTypes/Text.d.ts +0 -28
  129. package/dist/SpreadsheetView/models/ColumnDataTypes/Text.js +0 -129
  130. package/dist/SpreadsheetView/models/ColumnDataTypes/index.d.ts +0 -71
  131. package/dist/SpreadsheetView/models/ColumnDataTypes/index.js +0 -37
  132. package/dist/SpreadsheetView/models/FilterControls.d.ts +0 -26
  133. package/dist/SpreadsheetView/models/FilterControls.js +0 -85
  134. package/dist/SpreadsheetView/models/ImportWizard.d.ts +0 -31
  135. package/dist/SpreadsheetView/models/ImportWizard.js +0 -186
  136. package/dist/SpreadsheetView/models/Row.d.ts +0 -17
  137. package/dist/SpreadsheetView/models/Row.js +0 -43
  138. package/dist/SpreadsheetView/models/Spreadsheet.d.ts +0 -260
  139. package/dist/SpreadsheetView/models/Spreadsheet.js +0 -174
  140. package/dist/SpreadsheetView/models/SpreadsheetView.d.ts +0 -482
  141. package/dist/SpreadsheetView/models/SpreadsheetView.js +0 -199
  142. package/dist/SpreadsheetView/models/StaticRowSet.d.ts +0 -163
  143. package/dist/SpreadsheetView/models/StaticRowSet.js +0 -56
  144. package/esm/SpreadsheetView/components/CellData.d.ts +0 -9
  145. package/esm/SpreadsheetView/components/CellData.js +0 -9
  146. package/esm/SpreadsheetView/components/ColumnFilterControls.d.ts +0 -3
  147. package/esm/SpreadsheetView/components/ColumnFilterControls.js +0 -53
  148. package/esm/SpreadsheetView/components/ColumnMenu.d.ts +0 -16
  149. package/esm/SpreadsheetView/components/ColumnMenu.js +0 -135
  150. package/esm/SpreadsheetView/components/DataRow.d.ts +0 -12
  151. package/esm/SpreadsheetView/components/DataRow.js +0 -76
  152. package/esm/SpreadsheetView/components/DataTable.d.ts +0 -10
  153. package/esm/SpreadsheetView/components/DataTable.js +0 -37
  154. package/esm/SpreadsheetView/components/DataTableHeader.d.ts +0 -6
  155. package/esm/SpreadsheetView/components/DataTableHeader.js +0 -76
  156. package/esm/SpreadsheetView/components/GlobalFilterControls.d.ts +0 -5
  157. package/esm/SpreadsheetView/components/GlobalFilterControls.js +0 -40
  158. package/esm/SpreadsheetView/components/RowCountMessage.d.ts +0 -6
  159. package/esm/SpreadsheetView/components/RowCountMessage.js +0 -28
  160. package/esm/SpreadsheetView/components/RowMenu.d.ts +0 -9
  161. package/esm/SpreadsheetView/components/RowMenu.js +0 -34
  162. package/esm/SpreadsheetView/components/SortIndicator.d.ts +0 -6
  163. package/esm/SpreadsheetView/components/SortIndicator.js +0 -21
  164. package/esm/SpreadsheetView/components/Spreadsheet.d.ts +0 -11
  165. package/esm/SpreadsheetView/components/Spreadsheet.js +0 -20
  166. package/esm/SpreadsheetView/components/StatusBar.d.ts +0 -11
  167. package/esm/SpreadsheetView/components/StatusBar.js +0 -39
  168. package/esm/SpreadsheetView/importAdapters/ImportUtils.d.ts +0 -42
  169. package/esm/SpreadsheetView/importAdapters/ImportUtils.js +0 -95
  170. package/esm/SpreadsheetView/models/ColumnDataTypes/LocEnd.d.ts +0 -12
  171. package/esm/SpreadsheetView/models/ColumnDataTypes/LocEnd.js +0 -15
  172. package/esm/SpreadsheetView/models/ColumnDataTypes/LocRef.d.ts +0 -12
  173. package/esm/SpreadsheetView/models/ColumnDataTypes/LocRef.js +0 -15
  174. package/esm/SpreadsheetView/models/ColumnDataTypes/LocStart.d.ts +0 -12
  175. package/esm/SpreadsheetView/models/ColumnDataTypes/LocStart.js +0 -15
  176. package/esm/SpreadsheetView/models/ColumnDataTypes/LocString.d.ts +0 -13
  177. package/esm/SpreadsheetView/models/ColumnDataTypes/LocString.js +0 -178
  178. package/esm/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.d.ts +0 -19
  179. package/esm/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.js +0 -20
  180. package/esm/SpreadsheetView/models/ColumnDataTypes/Number.d.ts +0 -30
  181. package/esm/SpreadsheetView/models/ColumnDataTypes/Number.js +0 -119
  182. package/esm/SpreadsheetView/models/ColumnDataTypes/Text.d.ts +0 -28
  183. package/esm/SpreadsheetView/models/ColumnDataTypes/Text.js +0 -122
  184. package/esm/SpreadsheetView/models/ColumnDataTypes/index.d.ts +0 -71
  185. package/esm/SpreadsheetView/models/ColumnDataTypes/index.js +0 -29
  186. package/esm/SpreadsheetView/models/FilterControls.d.ts +0 -26
  187. package/esm/SpreadsheetView/models/FilterControls.js +0 -83
  188. package/esm/SpreadsheetView/models/ImportWizard.d.ts +0 -31
  189. package/esm/SpreadsheetView/models/ImportWizard.js +0 -161
  190. package/esm/SpreadsheetView/models/Row.d.ts +0 -17
  191. package/esm/SpreadsheetView/models/Row.js +0 -41
  192. package/esm/SpreadsheetView/models/Spreadsheet.d.ts +0 -260
  193. package/esm/SpreadsheetView/models/Spreadsheet.js +0 -169
  194. package/esm/SpreadsheetView/models/SpreadsheetView.d.ts +0 -482
  195. package/esm/SpreadsheetView/models/SpreadsheetView.js +0 -194
  196. package/esm/SpreadsheetView/models/StaticRowSet.d.ts +0 -163
  197. package/esm/SpreadsheetView/models/StaticRowSet.js +0 -51
@@ -1,7 +1,7 @@
1
- import React, { useState, useEffect } from 'react';
1
+ import React, { useEffect, useState } from 'react';
2
2
  import { TextField } from '@mui/material';
3
- import { makeStyles } from 'tss-react/mui';
4
3
  import { observer } from 'mobx-react';
4
+ import { makeStyles } from 'tss-react/mui';
5
5
  const useStyles = makeStyles()({
6
6
  textField: {
7
7
  width: '2rem',
@@ -9,14 +9,12 @@ const useStyles = makeStyles()({
9
9
  },
10
10
  });
11
11
  const NumberEditor = observer(function ({ model, disabled, modelPropName, modelSetterName, }) {
12
- // @ts-expect-error
13
12
  const [val, setVal] = useState(model[modelPropName]);
14
13
  const { classes } = useStyles();
15
14
  useEffect(() => {
16
15
  const num = Number.parseInt(val, 10);
17
16
  if (!Number.isNaN(num)) {
18
17
  if (num > 0) {
19
- // @ts-expect-error
20
18
  model[modelSetterName](num);
21
19
  }
22
20
  else {
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import type { SpreadsheetModel } from '../SpreadsheetModel';
3
+ declare const SpreadsheetDataGrid: ({ model, }: {
4
+ model: SpreadsheetModel;
5
+ }) => React.JSX.Element;
6
+ export default SpreadsheetDataGrid;
@@ -0,0 +1,22 @@
1
+ import React from 'react';
2
+ import { LoadingEllipses } from '@jbrowse/core/ui';
3
+ import { DataGrid, GridToolbar, useGridApiRef } from '@mui/x-data-grid';
4
+ import { observer } from 'mobx-react';
5
+ const SpreadsheetDataGrid = observer(function ({ model, }) {
6
+ const { rows, dataGridColumns, visibleColumns } = model;
7
+ const apiRef = useGridApiRef();
8
+ return rows && dataGridColumns ? (React.createElement(DataGrid, { apiRef: apiRef, checkboxSelection: true, disableRowSelectionOnClick: true, columnHeaderHeight: 35, columnVisibilityModel: visibleColumns, onFilterModelChange: () => {
9
+ setTimeout(() => {
10
+ model.setVisibleRows(apiRef.current.state.visibleRowsLookup);
11
+ });
12
+ }, onColumnVisibilityModelChange: n => {
13
+ model.setVisibleColumns(n);
14
+ }, rowHeight: 25, hideFooter: rows.length < 100, slots: {
15
+ toolbar: GridToolbar,
16
+ }, slotProps: {
17
+ toolbar: {
18
+ showQuickFilter: true,
19
+ },
20
+ }, rows: rows, columns: dataGridColumns })) : (React.createElement(LoadingEllipses, { variant: "h6" }));
21
+ });
22
+ export default SpreadsheetDataGrid;
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
- import { SpreadsheetViewModel } from '../models/SpreadsheetView';
3
- declare const SpreadsheetView: ({ model, }: {
2
+ import type { SpreadsheetViewModel } from '../SpreadsheetViewModel';
3
+ declare const SpreadsheetContainer: ({ model, }: {
4
4
  model: SpreadsheetViewModel;
5
5
  }) => React.JSX.Element;
6
- export default SpreadsheetView;
6
+ export default SpreadsheetContainer;
@@ -1,58 +1,37 @@
1
- import React, { useState } from 'react';
2
- import { Grid } from '@mui/material';
3
- import { makeStyles } from 'tss-react/mui';
4
- import { observer } from 'mobx-react';
1
+ import React, { Suspense, lazy, useState } from 'react';
5
2
  import { ResizeHandle } from '@jbrowse/core/ui';
6
- // locals
7
- import ImportWizard from './ImportWizard';
8
- import Spreadsheet from './Spreadsheet';
9
- import GlobalFilterControls from './GlobalFilterControls';
10
- import ColumnFilterControls from './ColumnFilterControls';
11
- import StatusBar from './StatusBar';
12
- const headerHeight = 52;
13
- const colFilterHeight = 46;
14
- const statusBarHeight = 40;
3
+ import { observer } from 'mobx-react';
4
+ import { makeStyles } from 'tss-react/mui';
5
+ import SpreadsheetDataGrid from './SpreadsheetDataGrid';
6
+ const ImportWizard = lazy(() => import('./ImportWizard'));
15
7
  const useStyles = makeStyles()(theme => ({
16
- header: {
17
- overflow: 'hidden',
18
- whiteSpace: 'nowrap',
19
- boxSizing: 'border-box',
20
- height: headerHeight,
21
- paddingLeft: theme.spacing(1),
22
- },
23
8
  contentArea: {
24
9
  overflow: 'auto',
10
+ position: 'relative',
11
+ marginBottom: theme.spacing(1),
12
+ background: theme.palette.background.paper,
25
13
  },
26
14
  resizeHandle: {
27
- height: 3,
28
- position: 'absolute',
29
- bottom: 0,
30
- left: 0,
31
- background: theme.palette.action.disabled,
15
+ height: 5,
32
16
  boxSizing: 'border-box',
17
+ background: theme.palette.action.disabled,
33
18
  borderTop: '1px solid #fafafa',
34
19
  },
35
20
  }));
36
21
  const SpreadsheetView = observer(function ({ model, }) {
22
+ const [initialHeight, setInitialHeight] = useState(0);
37
23
  const { classes } = useStyles();
38
- const { spreadsheet, filterControls, hideFilterControls, hideVerticalResizeHandle, mode, height, } = model;
39
- const [page, setPage] = useState(0);
40
- const [rowsPerPage, setRowsPerPage] = useState(100);
41
- return (React.createElement("div", null,
42
- mode !== 'display' || hideFilterControls ? null : (React.createElement(React.Fragment, null,
43
- React.createElement(Grid, { container: true, direction: "row", className: classes.header },
44
- React.createElement(Grid, { item: true },
45
- React.createElement(GlobalFilterControls, { model: model }))),
46
- filterControls.columnFilters.map((f, i) => (React.createElement(ColumnFilterControls, { key: `${f.columnNumber}-${i}`, viewModel: model, filterModel: f, columnNumber: f.columnNumber, height: colFilterHeight }))))),
47
- mode === 'import' ? (React.createElement(ImportWizard, { model: model.importWizard })) : (React.createElement("div", { className: classes.contentArea },
48
- React.createElement("div", { style: {
49
- position: 'relative',
50
- display: mode === 'display' ? undefined : 'none',
51
- } }, spreadsheet ? (React.createElement(Spreadsheet, { page: page, rowsPerPage: rowsPerPage, model: spreadsheet, height: height -
52
- headerHeight -
53
- filterControls.columnFilters.length * colFilterHeight -
54
- statusBarHeight })) : null))),
55
- spreadsheet ? (React.createElement(StatusBar, { page: page, setPage: setPage, rowsPerPage: rowsPerPage, setRowsPerPage: setRowsPerPage, mode: mode, spreadsheet: spreadsheet })) : null,
56
- hideVerticalResizeHandle ? null : (React.createElement(ResizeHandle, { onDrag: model.resizeHeight, className: classes.resizeHandle }))));
24
+ const { spreadsheet, hideVerticalResizeHandle, height } = model;
25
+ return spreadsheet ? (React.createElement(React.Fragment, null,
26
+ React.createElement("div", { style: { height }, className: classes.contentArea },
27
+ React.createElement(SpreadsheetDataGrid, { model: spreadsheet })),
28
+ hideVerticalResizeHandle ? null : (React.createElement(ResizeHandle, { onMouseDown: () => {
29
+ setInitialHeight(height);
30
+ }, onDrag: (_, dist) => model.setHeight(initialHeight - dist), className: classes.resizeHandle })))) : (React.createElement("div", null, "Unknown"));
31
+ });
32
+ const SpreadsheetContainer = observer(function ({ model, }) {
33
+ var _a;
34
+ return !((_a = model.spreadsheet) === null || _a === void 0 ? void 0 : _a.initialized) ? (React.createElement(Suspense, { fallback: null },
35
+ React.createElement(ImportWizard, { model: model.importWizard }))) : (React.createElement(SpreadsheetView, { model: model }));
57
36
  });
58
- export default SpreadsheetView;
37
+ export default SpreadsheetContainer;
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ import type { ImportWizardModel } from '../ImportWizard';
3
+ declare const TrackSelector: ({ model, selectedAssembly, }: {
4
+ model: ImportWizardModel;
5
+ selectedAssembly: string;
6
+ }) => React.JSX.Element;
7
+ export default TrackSelector;
@@ -0,0 +1,24 @@
1
+ import React, { useEffect, useState } from 'react';
2
+ import { ErrorMessage } from '@jbrowse/core/ui';
3
+ import { coarseStripHTML } from '@jbrowse/core/util';
4
+ import { MenuItem, TextField } from '@mui/material';
5
+ import { observer } from 'mobx-react';
6
+ const TrackSelector = observer(function ({ model, selectedAssembly, }) {
7
+ var _a;
8
+ const filteredTracks = selectedAssembly
9
+ ? model.tracksForAssembly(selectedAssembly)
10
+ : undefined;
11
+ const resetTrack = ((_a = filteredTracks === null || filteredTracks === void 0 ? void 0 : filteredTracks[0]) === null || _a === void 0 ? void 0 : _a.track.trackId) || '';
12
+ const [selectedTrack, setSelectedTrack] = useState(resetTrack);
13
+ useEffect(() => {
14
+ const entry = filteredTracks === null || filteredTracks === void 0 ? void 0 : filteredTracks.find(f => selectedTrack === f.track.trackId);
15
+ if (entry) {
16
+ model.setFileSource(entry.loc);
17
+ model.setFileType(entry.type);
18
+ }
19
+ }, [model, selectedTrack, filteredTracks]);
20
+ return (React.createElement("div", null, (filteredTracks === null || filteredTracks === void 0 ? void 0 : filteredTracks.length) ? (React.createElement(TextField, { select: true, label: "Tracks", variant: "outlined", value: selectedTrack, onChange: event => {
21
+ setSelectedTrack(event.target.value);
22
+ } }, filteredTracks.map(({ track, label }) => (React.createElement(MenuItem, { key: track.trackId, value: track.trackId }, coarseStripHTML(label)))))) : (React.createElement(ErrorMessage, { error: `No tracks found for ${selectedAssembly}` }))));
23
+ });
24
+ export default TrackSelector;
@@ -1,17 +1,26 @@
1
- import { ParseOptions } from './ImportUtils';
2
- import type { Buffer } from 'buffer';
3
- export declare function removeBedHeaders(buffer: Buffer): Buffer;
4
- export declare function parseBedBuffer(buffer: Buffer, options: ParseOptions): Promise<{
5
- rowSet: import("./ImportUtils").RowSet;
6
- columnDisplayOrder: number[];
7
- hasColumnNames: boolean;
8
- columns: import("./ImportUtils").Column[];
9
- assemblyName: string | undefined;
10
- }>;
11
- export declare function parseBedPEBuffer(buffer: Buffer, options: ParseOptions): Promise<{
12
- rowSet: import("./ImportUtils").RowSet;
13
- columnDisplayOrder: number[];
14
- hasColumnNames: boolean;
15
- columns: import("./ImportUtils").Column[];
16
- assemblyName: string | undefined;
17
- }>;
1
+ export declare function parseBedBuffer(buffer: Uint8Array): {
2
+ columns: {
3
+ name: string;
4
+ }[];
5
+ rowSet: {
6
+ rows: {
7
+ cellData: {
8
+ refName: string | undefined;
9
+ start: number;
10
+ end: number;
11
+ name: string | undefined;
12
+ score: string | undefined;
13
+ strand: string | undefined;
14
+ };
15
+ feature: {
16
+ uniqueId: string;
17
+ refName: string | undefined;
18
+ start: number;
19
+ end: number;
20
+ name: string | undefined;
21
+ score: string | undefined;
22
+ strand: number | undefined;
23
+ };
24
+ }[];
25
+ };
26
+ };
@@ -1,139 +1,55 @@
1
- import { parseTsvBuffer } from './ImportUtils';
2
- const browserBytes = 'browser '.split('').map(c => c.charCodeAt(0));
3
- const trackBytes = 'track '.split('').map(c => c.charCodeAt(0));
4
- const commentBytes = '#'.split('').map(c => c.charCodeAt(0));
5
- function bytesAreFoundAt(position, buffer, bytes) {
6
- let i = 0;
7
- for (; i < bytes.length; i += 1) {
8
- if (buffer[position + i] !== bytes[i]) {
9
- return false;
10
- }
11
- }
12
- return true;
13
- }
14
- export function removeBedHeaders(buffer) {
15
- // slice off the first lines of the buffer if it starts with one or more
16
- // header lines
17
- let i = 0;
18
- for (; i < buffer.length; i += 1) {
19
- if (bytesAreFoundAt(i, buffer, browserBytes) ||
20
- bytesAreFoundAt(i, buffer, trackBytes) ||
21
- bytesAreFoundAt(i, buffer, commentBytes)) {
22
- // consume up to the next newline
23
- do {
24
- i += 1;
25
- } while (buffer[i] !== 10);
26
- }
27
- else {
28
- // end of headers, return
29
- break;
30
- }
31
- }
32
- if (i) {
33
- return buffer.subarray(i);
34
- }
35
- return buffer;
36
- }
37
- export async function parseBedBuffer(buffer, options) {
38
- const b = removeBedHeaders(buffer);
39
- const data = await parseTsvBuffer(b);
40
- const bedColumns = [
41
- { name: 'chrom', dataType: { type: 'LocRef' } },
42
- { name: 'chromStart', dataType: { type: 'LocStart' } },
43
- { name: 'chromEnd', dataType: { type: 'LocEnd' } },
44
- { name: 'name', dataType: { type: 'Text' } },
45
- { name: 'score', dataType: { type: 'Number' } },
46
- { name: 'strand', dataType: { type: 'Text' } },
47
- ];
48
- data.columns.forEach((col, colNumber) => {
49
- const bedColumn = bedColumns[colNumber];
50
- if (bedColumn) {
51
- col.name = bedColumn.name;
52
- col.dataType = bedColumn.dataType;
53
- }
54
- });
55
- data.hasColumnNames = true;
56
- data.assemblyName = options.selectedAssemblyName;
57
- data.columnDisplayOrder.push(data.columnDisplayOrder.length);
58
- data.columns.unshift({
59
- name: 'Location',
60
- dataType: { type: 'LocString' },
61
- isDerived: true,
62
- derivationFunctionText: `jexl:{text:row.cells[0].text+':'+row.cells[1].text+'..'+row.cells[2].text,\n
63
- extendedData: {refName: row.cells.ref.text, start: parseInt(row.cells.start.text,10), end: parseInt(row.cells.end.text,10)}}`,
64
- });
65
- return data;
66
- }
67
- export async function parseBedPEBuffer(buffer, options) {
68
- const b = removeBedHeaders(buffer);
69
- const data = await parseTsvBuffer(b);
70
- const bedColumns = [
71
- { name: 'chrom1', dataType: { type: 'Text' }, featureField: ['refName'] },
72
- { name: 'start1', dataType: { type: 'Number' }, featureField: ['start'] },
73
- { name: 'end1', dataType: { type: 'Number' }, featureField: ['end'] },
74
- {
75
- name: 'chrom2',
76
- dataType: { type: 'Text' },
77
- featureField: ['mate', 'refName'],
78
- },
79
- {
80
- name: 'start2',
81
- dataType: { type: 'Number' },
82
- featureField: ['mate', 'start'],
83
- },
84
- {
85
- name: 'end2',
86
- dataType: { type: 'Number' },
87
- featureField: ['mate', 'end'],
88
- },
89
- { name: 'name', dataType: { type: 'Text' }, featureField: ['name'] },
90
- { name: 'score', dataType: { type: 'Number' }, featureField: ['score'] },
91
- { name: 'strand1', dataType: { type: 'Text' }, featureField: ['strand'] },
92
- {
93
- name: 'strand2',
94
- dataType: { type: 'Text' },
95
- featureField: ['mate', 'strand'],
1
+ import { isNumber } from './isNumber';
2
+ import { bufferToLines, parseStrand } from './util';
3
+ export function parseBedBuffer(buffer) {
4
+ var _a, _b;
5
+ const lines = bufferToLines(buffer);
6
+ const rest = lines.filter(line => !(line.startsWith('#') ||
7
+ line.startsWith('browser') ||
8
+ line.startsWith('track')));
9
+ const lastHeaderLine = lines.findLast(line => line.startsWith('#'));
10
+ const coreColumns = ['refName', 'start', 'end'];
11
+ const numExtraColumns = Math.max(0, (((_b = (_a = rest[0]) === null || _a === void 0 ? void 0 : _a.split('\t')) === null || _b === void 0 ? void 0 : _b.length) || 0) - coreColumns.length);
12
+ const extraNames = (lastHeaderLine === null || lastHeaderLine === void 0 ? void 0 : lastHeaderLine.includes('\t'))
13
+ ? lastHeaderLine
14
+ .slice(1)
15
+ .split('\t')
16
+ .slice(coreColumns.length)
17
+ .map(t => t.trim())
18
+ : Array.from({ length: numExtraColumns }, (_v, i) => `field_${i}`);
19
+ const colNames = [...coreColumns, ...extraNames];
20
+ return {
21
+ columns: colNames.map(c => ({ name: c })),
22
+ rowSet: {
23
+ rows: rest.map((line, idx) => {
24
+ const cols = line.split('\t');
25
+ return {
26
+ cellData: {
27
+ refName: cols[0],
28
+ start: +cols[1],
29
+ end: +cols[2],
30
+ name: cols[3],
31
+ score: cols[4],
32
+ strand: cols[5],
33
+ ...Object.fromEntries(extraNames.map((n, idx) => {
34
+ const r = cols[idx + coreColumns.length];
35
+ return [n, isNumber(r) ? +r : r];
36
+ })),
37
+ },
38
+ feature: {
39
+ uniqueId: `bed-${idx}`,
40
+ refName: cols[0],
41
+ start: +cols[1],
42
+ end: +cols[2],
43
+ name: cols[3],
44
+ score: cols[4],
45
+ strand: parseStrand(cols[5]),
46
+ ...Object.fromEntries(extraNames.map((n, idx) => {
47
+ const r = cols[idx + coreColumns.length];
48
+ return [n, isNumber(r) ? +r : r];
49
+ })),
50
+ },
51
+ };
52
+ }),
96
53
  },
97
- ];
98
- data.columns.forEach((col, colNumber) => {
99
- const bedColumn = bedColumns[colNumber];
100
- if (bedColumn) {
101
- col.name = bedColumn.name;
102
- col.dataType = bedColumn.dataType;
103
- }
104
- });
105
- data.hasColumnNames = true;
106
- // decorate each row with a feature object in its extendedData
107
- data.rowSet.rows.forEach((row, rowNumber) => {
108
- const featureData = {};
109
- row.cells.forEach(({ text }, columnNumber) => {
110
- const bedColumn = bedColumns[columnNumber];
111
- const val = bedColumn && bedColumn.dataType.type === 'Number' && text
112
- ? Number.parseFloat(text)
113
- : text;
114
- if (bedColumn) {
115
- // a predefined column
116
- if (bedColumn.featureField.length === 2) {
117
- if (!featureData[bedColumn.featureField[0]]) {
118
- featureData[bedColumn.featureField[0]] = {};
119
- }
120
- featureData[bedColumn.featureField[0]][bedColumn.featureField[1]] =
121
- val;
122
- }
123
- else {
124
- featureData[bedColumn.featureField[0]] = val;
125
- }
126
- }
127
- else {
128
- // some other column
129
- featureData[`column${columnNumber + 1}`] = val;
130
- }
131
- });
132
- featureData.uniqueId = `bedpe-${rowNumber}`;
133
- row.extendedData = {
134
- feature: featureData,
135
- };
136
- });
137
- data.assemblyName = options.selectedAssemblyName;
138
- return data;
54
+ };
139
55
  }
@@ -0,0 +1,36 @@
1
+ export declare function parseBedPEBuffer(buffer: Uint8Array): {
2
+ columns: {
3
+ name: string;
4
+ }[];
5
+ rowSet: {
6
+ rows: {
7
+ cellData: {
8
+ refName: string | undefined;
9
+ start: string | undefined;
10
+ end: string | undefined;
11
+ mateRefName: string | undefined;
12
+ mateStart: string | undefined;
13
+ mateEnd: string | undefined;
14
+ name: string | undefined;
15
+ score: string | number | undefined;
16
+ strand: string | undefined;
17
+ mateStrand: string | undefined;
18
+ };
19
+ feature: {
20
+ uniqueId: string;
21
+ refName: string | undefined;
22
+ start: number;
23
+ end: number;
24
+ strand: number | undefined;
25
+ mate: {
26
+ refName: string | undefined;
27
+ start: number;
28
+ end: number;
29
+ strand: number | undefined;
30
+ };
31
+ name: string | undefined;
32
+ score: string | undefined;
33
+ };
34
+ }[];
35
+ };
36
+ };
@@ -0,0 +1,76 @@
1
+ import { isNumber } from '@mui/x-data-grid/internals';
2
+ import { bufferToLines, parseStrand } from './util';
3
+ export function parseBedPEBuffer(buffer) {
4
+ var _a, _b;
5
+ const lines = bufferToLines(buffer);
6
+ const rest = lines.filter(line => !(line.startsWith('#') ||
7
+ line.startsWith('browser') ||
8
+ line.startsWith('track')));
9
+ const lastHeaderLine = lines.findLast(line => line.startsWith('#'));
10
+ const coreColumns = [
11
+ 'refName',
12
+ 'start',
13
+ 'end',
14
+ 'mateRef',
15
+ 'mateStart',
16
+ 'mateEnd',
17
+ 'name',
18
+ 'score',
19
+ 'strand',
20
+ 'mateStrand',
21
+ ];
22
+ const numExtraColumns = Math.max(0, (((_b = (_a = rest[0]) === null || _a === void 0 ? void 0 : _a.split('\t')) === null || _b === void 0 ? void 0 : _b.length) || 0) - coreColumns.length);
23
+ const extraNames = (lastHeaderLine === null || lastHeaderLine === void 0 ? void 0 : lastHeaderLine.includes('\t'))
24
+ ? lastHeaderLine
25
+ .slice(1)
26
+ .split('\t')
27
+ .slice(coreColumns.length)
28
+ .map(t => t.trim())
29
+ : Array.from({ length: numExtraColumns }, (_v, i) => `field_${i}`);
30
+ const colNames = [...coreColumns, ...extraNames];
31
+ return {
32
+ columns: colNames.map(c => ({ name: c })),
33
+ rowSet: {
34
+ rows: rest.map((line, idx) => {
35
+ const cols = line.split('\t');
36
+ return {
37
+ cellData: {
38
+ refName: cols[0],
39
+ start: cols[1],
40
+ end: cols[2],
41
+ mateRefName: cols[3],
42
+ mateStart: cols[4],
43
+ mateEnd: cols[5],
44
+ name: cols[6],
45
+ score: +cols[7] || cols[7],
46
+ strand: cols[8],
47
+ mateStrand: cols[9],
48
+ ...Object.fromEntries(extraNames.map((n, idx) => {
49
+ const r = cols[idx + coreColumns.length];
50
+ return [n, isNumber(r) ? +r : r];
51
+ })),
52
+ },
53
+ feature: {
54
+ uniqueId: `bedpe-${idx}`,
55
+ refName: cols[0],
56
+ start: +cols[1],
57
+ end: +cols[2],
58
+ strand: parseStrand(cols[8]),
59
+ mate: {
60
+ refName: cols[3],
61
+ start: +cols[4],
62
+ end: +cols[5],
63
+ strand: parseStrand(cols[9]),
64
+ },
65
+ name: cols[6],
66
+ score: cols[7],
67
+ ...Object.fromEntries(extraNames.map((n, idx) => {
68
+ const r = cols[idx + coreColumns.length];
69
+ return [n, isNumber(r) ? +r : r];
70
+ })),
71
+ },
72
+ };
73
+ }),
74
+ },
75
+ };
76
+ }
@@ -1,9 +1,25 @@
1
- import { ParseOptions } from './ImportUtils';
2
- import type { Buffer } from 'buffer';
3
- export declare function parseSTARFusionBuffer(buffer: Buffer, options: ParseOptions): Promise<{
4
- rowSet: import("./ImportUtils").RowSet;
5
- columnDisplayOrder: number[];
6
- hasColumnNames: boolean;
7
- columns: import("./ImportUtils").Column[];
8
- assemblyName: string | undefined;
9
- }>;
1
+ export declare function parseSTARFusionBuffer(buffer: Uint8Array): {
2
+ columns: {
3
+ name: string;
4
+ }[];
5
+ rowSet: {
6
+ rows: {
7
+ cellData: {
8
+ [k: string]: string | number;
9
+ };
10
+ feature: {
11
+ mate: {
12
+ refName: string | undefined;
13
+ start: number;
14
+ end: number;
15
+ strand: number | undefined;
16
+ };
17
+ refName: string | undefined;
18
+ start: number;
19
+ end: number;
20
+ strand: number | undefined;
21
+ uniqueId: string;
22
+ };
23
+ }[];
24
+ };
25
+ };