@jbrowse/plugin-data-management 2.0.0 → 2.1.2

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 (140) hide show
  1. package/dist/AddConnectionWidget/components/AddConnectionWidget.js +23 -40
  2. package/dist/AddConnectionWidget/components/AddConnectionWidget.js.map +1 -1
  3. package/dist/AddConnectionWidget/components/ConfigureConnection.js +6 -6
  4. package/dist/AddConnectionWidget/components/ConfigureConnection.js.map +1 -1
  5. package/dist/AddConnectionWidget/components/ConnectionTypeSelect.js +7 -9
  6. package/dist/AddConnectionWidget/components/ConnectionTypeSelect.js.map +1 -1
  7. package/dist/AddConnectionWidget/index.js +1 -1
  8. package/dist/AddConnectionWidget/index.js.map +1 -1
  9. package/dist/AddConnectionWidget/model.js +2 -2
  10. package/dist/AddConnectionWidget/model.js.map +1 -1
  11. package/dist/AddTrackWidget/components/AddTrackWidget.d.ts +2 -2
  12. package/dist/AddTrackWidget/components/AddTrackWidget.js +24 -220
  13. package/dist/AddTrackWidget/components/AddTrackWidget.js.map +1 -1
  14. package/dist/AddTrackWidget/components/ConfirmTrack.js +72 -99
  15. package/dist/AddTrackWidget/components/ConfirmTrack.js.map +1 -1
  16. package/dist/AddTrackWidget/components/DefaultAddTrackWorkflow.d.ts +7 -0
  17. package/dist/AddTrackWidget/components/DefaultAddTrackWorkflow.js +162 -0
  18. package/dist/AddTrackWidget/components/DefaultAddTrackWorkflow.js.map +1 -0
  19. package/dist/AddTrackWidget/components/TrackSourceSelect.js +11 -12
  20. package/dist/AddTrackWidget/components/TrackSourceSelect.js.map +1 -1
  21. package/dist/AddTrackWidget/index.js +1 -1
  22. package/dist/AddTrackWidget/index.js.map +1 -1
  23. package/dist/AddTrackWidget/model.js +34 -30
  24. package/dist/AddTrackWidget/model.js.map +1 -1
  25. package/dist/AssemblyManager/AssemblyAddForm.js +42 -61
  26. package/dist/AssemblyManager/AssemblyAddForm.js.map +1 -1
  27. package/dist/AssemblyManager/AssemblyEditor.js +4 -5
  28. package/dist/AssemblyManager/AssemblyEditor.js.map +1 -1
  29. package/dist/AssemblyManager/AssemblyManager.js +24 -41
  30. package/dist/AssemblyManager/AssemblyManager.js.map +1 -1
  31. package/dist/AssemblyManager/AssemblyTable.js +17 -18
  32. package/dist/AssemblyManager/AssemblyTable.js.map +1 -1
  33. package/dist/HierarchicalTrackSelectorWidget/components/CloseConnectionDialog.js +9 -29
  34. package/dist/HierarchicalTrackSelectorWidget/components/CloseConnectionDialog.js.map +1 -1
  35. package/dist/HierarchicalTrackSelectorWidget/components/DeleteConnectionDialog.js +7 -8
  36. package/dist/HierarchicalTrackSelectorWidget/components/DeleteConnectionDialog.js.map +1 -1
  37. package/dist/HierarchicalTrackSelectorWidget/components/Header.d.ts +10 -0
  38. package/dist/HierarchicalTrackSelectorWidget/components/Header.js +177 -0
  39. package/dist/HierarchicalTrackSelectorWidget/components/Header.js.map +1 -0
  40. package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js +79 -365
  41. package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js.map +1 -1
  42. package/dist/HierarchicalTrackSelectorWidget/components/ManageConnectionsDialog.js +17 -18
  43. package/dist/HierarchicalTrackSelectorWidget/components/ManageConnectionsDialog.js.map +1 -1
  44. package/dist/HierarchicalTrackSelectorWidget/components/Node.d.ts +29 -0
  45. package/dist/HierarchicalTrackSelectorWidget/components/Node.js +173 -0
  46. package/dist/HierarchicalTrackSelectorWidget/components/Node.js.map +1 -0
  47. package/dist/HierarchicalTrackSelectorWidget/components/ToggleConnectionsDialog.js +19 -20
  48. package/dist/HierarchicalTrackSelectorWidget/components/ToggleConnectionsDialog.js.map +1 -1
  49. package/dist/HierarchicalTrackSelectorWidget/components/util.d.ts +3 -0
  50. package/dist/HierarchicalTrackSelectorWidget/components/util.js +9 -0
  51. package/dist/HierarchicalTrackSelectorWidget/components/util.js.map +1 -0
  52. package/dist/HierarchicalTrackSelectorWidget/configSchema.d.ts +2 -0
  53. package/dist/HierarchicalTrackSelectorWidget/configSchema.js +6 -0
  54. package/dist/HierarchicalTrackSelectorWidget/configSchema.js.map +1 -0
  55. package/dist/HierarchicalTrackSelectorWidget/index.d.ts +4 -2
  56. package/dist/HierarchicalTrackSelectorWidget/index.js +4 -4
  57. package/dist/HierarchicalTrackSelectorWidget/index.js.map +1 -1
  58. package/dist/HierarchicalTrackSelectorWidget/model.d.ts +10 -2
  59. package/dist/HierarchicalTrackSelectorWidget/model.js +102 -153
  60. package/dist/HierarchicalTrackSelectorWidget/model.js.map +1 -1
  61. package/dist/PluginStoreWidget/components/CustomPluginForm.js +25 -43
  62. package/dist/PluginStoreWidget/components/CustomPluginForm.js.map +1 -1
  63. package/dist/PluginStoreWidget/components/InstalledPlugin.js +29 -47
  64. package/dist/PluginStoreWidget/components/InstalledPlugin.js.map +1 -1
  65. package/dist/PluginStoreWidget/components/InstalledPluginsList.js +12 -15
  66. package/dist/PluginStoreWidget/components/InstalledPluginsList.js.map +1 -1
  67. package/dist/PluginStoreWidget/components/PluginCard.js +23 -40
  68. package/dist/PluginStoreWidget/components/PluginCard.js.map +1 -1
  69. package/dist/PluginStoreWidget/components/PluginStoreWidget.js +49 -117
  70. package/dist/PluginStoreWidget/components/PluginStoreWidget.js.map +1 -1
  71. package/dist/PluginStoreWidget/index.js +1 -1
  72. package/dist/PluginStoreWidget/index.js.map +1 -1
  73. package/dist/PluginStoreWidget/model.js +6 -6
  74. package/dist/PluginStoreWidget/model.js.map +1 -1
  75. package/dist/SetDefaultSession/SetDefaultSession.js +9 -10
  76. package/dist/SetDefaultSession/SetDefaultSession.js.map +1 -1
  77. package/dist/index.d.ts +4 -1
  78. package/dist/index.js +38 -60
  79. package/dist/index.js.map +1 -1
  80. package/dist/ucsc-trackhub/configSchema.js +2 -2
  81. package/dist/ucsc-trackhub/configSchema.js.map +1 -1
  82. package/dist/ucsc-trackhub/model.js +33 -97
  83. package/dist/ucsc-trackhub/model.js.map +1 -1
  84. package/dist/ucsc-trackhub/ucscAssemblies.js +197 -1
  85. package/dist/ucsc-trackhub/ucscAssemblies.js.map +1 -1
  86. package/dist/ucsc-trackhub/ucscTrackHub.js +43 -132
  87. package/dist/ucsc-trackhub/ucscTrackHub.js.map +1 -1
  88. package/esm/AddTrackWidget/components/AddTrackWidget.d.ts +2 -2
  89. package/esm/AddTrackWidget/components/AddTrackWidget.js +22 -135
  90. package/esm/AddTrackWidget/components/AddTrackWidget.js.map +1 -1
  91. package/esm/AddTrackWidget/components/ConfirmTrack.js +5 -6
  92. package/esm/AddTrackWidget/components/ConfirmTrack.js.map +1 -1
  93. package/esm/AddTrackWidget/components/DefaultAddTrackWorkflow.d.ts +7 -0
  94. package/esm/AddTrackWidget/components/DefaultAddTrackWorkflow.js +134 -0
  95. package/esm/AddTrackWidget/components/DefaultAddTrackWorkflow.js.map +1 -0
  96. package/esm/HierarchicalTrackSelectorWidget/components/Header.d.ts +10 -0
  97. package/esm/HierarchicalTrackSelectorWidget/components/Header.js +149 -0
  98. package/esm/HierarchicalTrackSelectorWidget/components/Header.js.map +1 -0
  99. package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js +24 -223
  100. package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js.map +1 -1
  101. package/esm/HierarchicalTrackSelectorWidget/components/Node.d.ts +29 -0
  102. package/esm/HierarchicalTrackSelectorWidget/components/Node.js +144 -0
  103. package/esm/HierarchicalTrackSelectorWidget/components/Node.js.map +1 -0
  104. package/esm/HierarchicalTrackSelectorWidget/components/util.d.ts +3 -0
  105. package/esm/HierarchicalTrackSelectorWidget/components/util.js +5 -0
  106. package/esm/HierarchicalTrackSelectorWidget/components/util.js.map +1 -0
  107. package/esm/HierarchicalTrackSelectorWidget/configSchema.d.ts +2 -0
  108. package/esm/HierarchicalTrackSelectorWidget/configSchema.js +4 -0
  109. package/esm/HierarchicalTrackSelectorWidget/configSchema.js.map +1 -0
  110. package/esm/HierarchicalTrackSelectorWidget/index.d.ts +4 -2
  111. package/esm/HierarchicalTrackSelectorWidget/index.js +3 -3
  112. package/esm/HierarchicalTrackSelectorWidget/index.js.map +1 -1
  113. package/esm/HierarchicalTrackSelectorWidget/model.d.ts +10 -2
  114. package/esm/HierarchicalTrackSelectorWidget/model.js +36 -32
  115. package/esm/HierarchicalTrackSelectorWidget/model.js.map +1 -1
  116. package/esm/PluginStoreWidget/components/PluginStoreWidget.js +1 -2
  117. package/esm/PluginStoreWidget/components/PluginStoreWidget.js.map +1 -1
  118. package/esm/index.d.ts +4 -1
  119. package/esm/index.js +1 -1
  120. package/esm/index.js.map +1 -1
  121. package/package.json +4 -5
  122. package/src/AddConnectionWidget/components/__snapshots__/AddConnectionWidget.test.js.snap +7 -7
  123. package/src/AddTrackWidget/components/{AddTrackWidget.test.js → AddTrackWidget.test.tsx} +17 -32
  124. package/src/AddTrackWidget/components/AddTrackWidget.tsx +36 -200
  125. package/src/AddTrackWidget/components/ConfirmTrack.tsx +10 -10
  126. package/src/AddTrackWidget/components/DefaultAddTrackWorkflow.tsx +205 -0
  127. package/src/HierarchicalTrackSelectorWidget/components/Header.tsx +287 -0
  128. package/src/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.test.js +5 -4
  129. package/src/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.tsx +19 -438
  130. package/src/HierarchicalTrackSelectorWidget/components/Node.tsx +282 -0
  131. package/src/HierarchicalTrackSelectorWidget/components/__snapshots__/HierarchicalTrackSelector.test.js.snap +24 -48
  132. package/src/HierarchicalTrackSelectorWidget/components/util.ts +11 -0
  133. package/src/HierarchicalTrackSelectorWidget/configSchema.ts +3 -0
  134. package/src/HierarchicalTrackSelectorWidget/index.ts +4 -6
  135. package/src/HierarchicalTrackSelectorWidget/model.ts +45 -41
  136. package/src/PluginStoreWidget/components/PluginStoreWidget.test.js +16 -4
  137. package/src/PluginStoreWidget/components/PluginStoreWidget.tsx +1 -2
  138. package/src/PluginStoreWidget/components/__snapshots__/PluginStoreWidget.test.js.snap +111 -123
  139. package/src/index.ts +4 -1
  140. package/src/AddTrackWidget/components/__snapshots__/AddTrackWidget.test.js.snap +0 -331
@@ -0,0 +1,134 @@
1
+ import React, { useState } from 'react';
2
+ import { Alert, Button, Step, StepContent, StepLabel, Stepper, Typography, } from '@mui/material';
3
+ import { makeStyles } from 'tss-react/mui';
4
+ import { getSession, isElectron, supportedIndexingAdapters, } from '@jbrowse/core/util';
5
+ import { getConf } from '@jbrowse/core/configuration';
6
+ import { observer } from 'mobx-react';
7
+ import { getEnv } from 'mobx-state-tree';
8
+ // locals
9
+ import ConfirmTrack from './ConfirmTrack';
10
+ import TrackSourceSelect from './TrackSourceSelect';
11
+ const useStyles = makeStyles()(theme => ({
12
+ root: {
13
+ marginTop: theme.spacing(1),
14
+ },
15
+ stepper: {
16
+ backgroundColor: theme.palette.background.default,
17
+ },
18
+ button: {
19
+ marginTop: theme.spacing(1),
20
+ marginRight: theme.spacing(1),
21
+ },
22
+ actionsContainer: {
23
+ marginBottom: theme.spacing(2),
24
+ },
25
+ stepContent: {
26
+ margin: theme.spacing(1),
27
+ },
28
+ alertContainer: {
29
+ padding: `${theme.spacing(2)}px 0px ${theme.spacing(2)}px 0px`,
30
+ },
31
+ }));
32
+ const steps = ['Enter track data', 'Confirm track type'];
33
+ function AddTrackWorkflow({ model }) {
34
+ const [activeStep, setActiveStep] = useState(0);
35
+ const { classes } = useStyles();
36
+ const { pluginManager } = getEnv(model);
37
+ const { rootModel } = pluginManager;
38
+ const { jobsManager } = rootModel;
39
+ const session = getSession(model);
40
+ const { assembly, trackAdapter, trackData, trackName, trackType, textIndexTrack, textIndexingConf, } = model;
41
+ const [trackErrorMessage, setTrackErrorMessage] = useState();
42
+ function getStepContent(step) {
43
+ switch (step) {
44
+ case 0:
45
+ return React.createElement(TrackSourceSelect, { model: model });
46
+ case 1:
47
+ return React.createElement(ConfirmTrack, { model: model });
48
+ default:
49
+ return React.createElement(Typography, null, "Unknown step");
50
+ }
51
+ }
52
+ async function handleNext() {
53
+ if (activeStep !== steps.length - 1) {
54
+ setActiveStep(activeStep + 1);
55
+ return;
56
+ }
57
+ const trackId = [
58
+ `${trackName.toLowerCase().replace(/ /g, '_')}-${Date.now()}`,
59
+ `${session.adminMode ? '' : '-sessionTrack'}`,
60
+ ].join('');
61
+ const assemblyInstance = session.assemblyManager.get(assembly);
62
+ if (trackAdapter && trackAdapter.type !== 'UNKNOWN') {
63
+ session.addTrackConf({
64
+ trackId,
65
+ type: trackType,
66
+ name: trackName,
67
+ assemblyNames: [assembly],
68
+ adapter: {
69
+ ...trackAdapter,
70
+ sequenceAdapter: getConf(assemblyInstance, ['sequence', 'adapter']),
71
+ },
72
+ });
73
+ if (model.view) {
74
+ model.view.showTrack(trackId);
75
+ if (isElectron &&
76
+ textIndexTrack &&
77
+ supportedIndexingAdapters(trackAdapter.type)) {
78
+ const attr = textIndexingConf || {
79
+ attributes: ['Name', 'ID'],
80
+ exclude: ['CDS', 'exon'],
81
+ };
82
+ const indexName = trackName + '-index';
83
+ const newEntry = {
84
+ indexingParams: {
85
+ ...attr,
86
+ assemblies: [assembly],
87
+ tracks: [trackId],
88
+ indexType: 'perTrack',
89
+ name: indexName,
90
+ timestamp: new Date().toISOString(),
91
+ },
92
+ name: indexName,
93
+ cancelCallback: () => jobsManager.abortJob(),
94
+ };
95
+ jobsManager.queueJob(newEntry);
96
+ }
97
+ }
98
+ else {
99
+ session.notify('Open a new view, or use the track selector in an existing view, to view this track', 'info');
100
+ }
101
+ model.clearData();
102
+ session.hideWidget(model);
103
+ }
104
+ else {
105
+ setTrackErrorMessage('Failed to add track.\nThe configuration of this file is not currently supported.');
106
+ }
107
+ }
108
+ function handleBack() {
109
+ setTrackErrorMessage(undefined);
110
+ setActiveStep(activeStep - 1);
111
+ }
112
+ function isNextDisabled() {
113
+ switch (activeStep) {
114
+ case 0:
115
+ return !trackData;
116
+ case 1:
117
+ return !(trackName && trackType && (trackAdapter === null || trackAdapter === void 0 ? void 0 : trackAdapter.type) && assembly);
118
+ default:
119
+ return true;
120
+ }
121
+ }
122
+ return (React.createElement("div", { className: classes.root },
123
+ React.createElement(Stepper, { className: classes.stepper, activeStep: activeStep, orientation: "vertical" }, steps.map((label, idx) => (React.createElement(Step, { key: label },
124
+ React.createElement(StepLabel, null, label),
125
+ React.createElement(StepContent, null,
126
+ getStepContent(idx),
127
+ React.createElement("div", { className: classes.actionsContainer },
128
+ React.createElement(Button, { disabled: activeStep === 0, onClick: handleBack, className: classes.button }, "Back"),
129
+ React.createElement(Button, { disabled: isNextDisabled(), variant: "contained", color: "primary", onClick: handleNext, className: classes.button, "data-testid": "addTrackNextButton" }, activeStep === steps.length - 1 ? 'Add' : 'Next')),
130
+ trackErrorMessage ? (React.createElement("div", { className: classes.alertContainer },
131
+ React.createElement(Alert, { severity: "error" }, trackErrorMessage))) : null)))))));
132
+ }
133
+ export default observer(AddTrackWorkflow);
134
+ //# sourceMappingURL=DefaultAddTrackWorkflow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DefaultAddTrackWorkflow.js","sourceRoot":"","sources":["../../../src/AddTrackWidget/components/DefaultAddTrackWorkflow.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ /// <reference types="react" />
2
+ import { HierarchicalTrackSelectorModel } from '../model';
3
+ declare function HierarchicalTrackSelectorHeader({ model, setHeaderHeight, setAssemblyIdx, assemblyIdx, }: {
4
+ model: HierarchicalTrackSelectorModel;
5
+ setHeaderHeight: (n: number) => void;
6
+ setAssemblyIdx: (n: number) => void;
7
+ assemblyIdx: number;
8
+ }): JSX.Element;
9
+ declare const _default: typeof HierarchicalTrackSelectorHeader;
10
+ export default _default;
@@ -0,0 +1,149 @@
1
+ import React, { Suspense, lazy, useState } from 'react';
2
+ import { makeStyles } from 'tss-react/mui';
3
+ import { Badge, IconButton, InputAdornment, TextField } from '@mui/material';
4
+ // icons
5
+ import ClearIcon from '@mui/icons-material/Clear';
6
+ import MenuIcon from '@mui/icons-material/Menu';
7
+ import ShoppingCartIcon from '@mui/icons-material/ShoppingCart';
8
+ import { Cable } from '@jbrowse/core/ui/Icons';
9
+ // other
10
+ import JBrowseMenu from '@jbrowse/core/ui/Menu';
11
+ import { getSession, isSessionModelWithWidgets, isSessionModelWithConnections, isSessionWithAddTracks, } from '@jbrowse/core/util';
12
+ import { readConfObject, } from '@jbrowse/core/configuration';
13
+ import { observer } from 'mobx-react';
14
+ import { getEnv } from 'mobx-state-tree';
15
+ // lazy components
16
+ const CloseConnectionDialog = lazy(() => import('./CloseConnectionDialog'));
17
+ const DeleteConnectionDialog = lazy(() => import('./DeleteConnectionDialog'));
18
+ const ManageConnectionsDialog = lazy(() => import('./ManageConnectionsDialog'));
19
+ const ToggleConnectionsDialog = lazy(() => import('./ToggleConnectionsDialog'));
20
+ const useStyles = makeStyles()(theme => ({
21
+ searchBox: {
22
+ margin: theme.spacing(2),
23
+ },
24
+ menuIcon: {
25
+ marginRight: theme.spacing(1),
26
+ marginBottom: 0,
27
+ },
28
+ }));
29
+ function HierarchicalTrackSelectorHeader({ model, setHeaderHeight, setAssemblyIdx, assemblyIdx, }) {
30
+ const { classes } = useStyles();
31
+ const session = getSession(model);
32
+ const [connectionEl, setConnectionEl] = useState();
33
+ const [selectionEl, setSelectionEl] = useState();
34
+ const [menuEl, setMenuEl] = useState();
35
+ const [modalInfo, setModalInfo] = useState();
36
+ const [deleteDlgDetails, setDeleteDlgDetails] = useState();
37
+ const [connectionManagerOpen, setConnectionManagerOpen] = useState(false);
38
+ const [connectionToggleOpen, setConnectionToggleOpen] = useState(false);
39
+ const { assemblyNames } = model;
40
+ const assemblyName = assemblyNames[assemblyIdx];
41
+ function breakConnection(connectionConf, deletingConnection) {
42
+ const name = readConfObject(connectionConf, 'name');
43
+ // @ts-ignore
44
+ const result = session.prepareToBreakConnection(connectionConf);
45
+ if (result) {
46
+ const [safelyBreakConnection, dereferenceTypeCount] = result;
47
+ if (Object.keys(dereferenceTypeCount).length > 0) {
48
+ setModalInfo({
49
+ connectionConf,
50
+ safelyBreakConnection,
51
+ dereferenceTypeCount,
52
+ name,
53
+ });
54
+ }
55
+ else {
56
+ safelyBreakConnection();
57
+ }
58
+ }
59
+ if (deletingConnection) {
60
+ setDeleteDlgDetails({ name, connectionConf });
61
+ }
62
+ }
63
+ const connectionMenuItems = [
64
+ {
65
+ label: 'Turn on/off connections...',
66
+ onClick: () => setConnectionToggleOpen(true),
67
+ },
68
+ ];
69
+ if (isSessionModelWithConnections(session)) {
70
+ connectionMenuItems.unshift({
71
+ label: 'Add connection',
72
+ onClick: () => {
73
+ if (isSessionModelWithWidgets(session)) {
74
+ session.showWidget(session.addWidget('AddConnectionWidget', 'addConnectionWidget'));
75
+ }
76
+ },
77
+ });
78
+ connectionMenuItems.push({
79
+ label: 'Delete connections...',
80
+ onClick: () => setConnectionManagerOpen(true),
81
+ });
82
+ }
83
+ const assemblyMenuItems = assemblyNames.length > 1
84
+ ? [
85
+ {
86
+ label: 'Select assembly...',
87
+ subMenu: assemblyNames.map((name, idx) => ({
88
+ label: name,
89
+ onClick: () => setAssemblyIdx(idx),
90
+ })),
91
+ },
92
+ ]
93
+ : [];
94
+ const menuItems = [
95
+ {
96
+ label: 'Add track...',
97
+ onClick: () => {
98
+ if (isSessionModelWithWidgets(session)) {
99
+ session.showWidget(session.addWidget('AddTrackWidget', 'addTrackWidget', {
100
+ view: model.view.id,
101
+ }));
102
+ }
103
+ },
104
+ },
105
+ ...assemblyMenuItems,
106
+ ];
107
+ const items = getEnv(model).pluginManager.evaluateExtensionPoint('TrackSelector-multiTrackMenuItems');
108
+ return (React.createElement("div", { ref: ref => setHeaderHeight((ref === null || ref === void 0 ? void 0 : ref.getBoundingClientRect().height) || 0), "data-testid": "hierarchical_track_selector" },
109
+ React.createElement("div", { style: { display: 'flex' } },
110
+ isSessionWithAddTracks(session) && (React.createElement(IconButton, { className: classes.menuIcon, onClick: event => setMenuEl(event.currentTarget) },
111
+ React.createElement(MenuIcon, null))),
112
+ session.makeConnection && (React.createElement(IconButton, { className: classes.menuIcon, onClick: event => setConnectionEl(event.currentTarget) },
113
+ React.createElement(Cable, null))),
114
+ model.selection.length ? (React.createElement(IconButton, { className: classes.menuIcon, onClick: event => setSelectionEl(event.currentTarget) },
115
+ React.createElement(Badge, { badgeContent: model.selection.length, color: "primary" },
116
+ React.createElement(ShoppingCartIcon, null)))) : null,
117
+ React.createElement(TextField, { className: classes.searchBox, label: "Filter tracks", value: model.filterText, onChange: event => model.setFilterText(event.target.value), fullWidth: true, InputProps: {
118
+ endAdornment: (React.createElement(InputAdornment, { position: "end" },
119
+ React.createElement(IconButton, { color: "secondary", onClick: model.clearFilterText },
120
+ React.createElement(ClearIcon, null)))),
121
+ } })),
122
+ React.createElement(JBrowseMenu, { anchorEl: connectionEl, open: Boolean(connectionEl), onMenuItemClick: (_, callback) => {
123
+ callback();
124
+ setConnectionEl(undefined);
125
+ }, onClose: () => setConnectionEl(undefined), menuItems: connectionMenuItems }),
126
+ React.createElement(JBrowseMenu, { anchorEl: menuEl, open: Boolean(menuEl), onMenuItemClick: (_, callback) => {
127
+ callback();
128
+ setMenuEl(undefined);
129
+ }, onClose: () => setMenuEl(undefined), menuItems: menuItems }),
130
+ React.createElement(JBrowseMenu, { anchorEl: selectionEl, open: Boolean(selectionEl), onMenuItemClick: (_, callback) => {
131
+ callback();
132
+ setSelectionEl(undefined);
133
+ }, onClose: () => setSelectionEl(undefined), menuItems: [
134
+ { label: 'Clear', onClick: () => model.clearSelection() },
135
+ ...items.map(item => ({
136
+ ...item,
137
+ ...('onClick' in item
138
+ ? { onClick: () => item.onClick(model) }
139
+ : {}),
140
+ })),
141
+ ] }),
142
+ React.createElement(Suspense, { fallback: React.createElement("div", null) },
143
+ modalInfo ? (React.createElement(CloseConnectionDialog, { modalInfo: modalInfo, setModalInfo: setModalInfo })) : null,
144
+ deleteDlgDetails ? (React.createElement(DeleteConnectionDialog, { handleClose: () => setDeleteDlgDetails(undefined), deleteDialogDetails: deleteDlgDetails, session: session })) : null,
145
+ connectionManagerOpen ? (React.createElement(ManageConnectionsDialog, { handleClose: () => setConnectionManagerOpen(false), breakConnection: breakConnection, session: session })) : null,
146
+ connectionToggleOpen ? (React.createElement(ToggleConnectionsDialog, { handleClose: () => setConnectionToggleOpen(false), session: session, breakConnection: breakConnection, assemblyName: assemblyName })) : null)));
147
+ }
148
+ export default observer(HierarchicalTrackSelectorHeader);
149
+ //# sourceMappingURL=Header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Header.js","sourceRoot":"","sources":["../../../src/HierarchicalTrackSelectorWidget/components/Header.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAC1C,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAC5E,QAAQ;AACR,OAAO,SAAS,MAAM,2BAA2B,CAAA;AACjD,OAAO,QAAQ,MAAM,0BAA0B,CAAA;AAC/C,OAAO,gBAAgB,MAAM,kCAAkC,CAAA;AAC/D,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAA;AAE9C,QAAQ;AACR,OAAO,WAAyB,MAAM,uBAAuB,CAAA;AAC7D,OAAO,EACL,UAAU,EACV,yBAAyB,EACzB,6BAA6B,EAC7B,sBAAsB,GACvB,MAAM,oBAAoB,CAAA;AAC3B,OAAO,EAEL,cAAc,GACf,MAAM,6BAA6B,CAAA;AACpC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AAKxC,kBAAkB;AAClB,MAAM,qBAAqB,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,yBAAyB,CAAC,CAAC,CAAA;AAC3E,MAAM,sBAAsB,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,0BAA0B,CAAC,CAAC,CAAA;AAC7E,MAAM,uBAAuB,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,2BAA2B,CAAC,CAAC,CAAA;AAC/E,MAAM,uBAAuB,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,2BAA2B,CAAC,CAAC,CAAA;AAE/E,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACvC,SAAS,EAAE;QACT,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;KACzB;IACD,QAAQ,EAAE;QACR,WAAW,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;QAC7B,YAAY,EAAE,CAAC;KAChB;CACF,CAAC,CAAC,CAAA;AAcH,SAAS,+BAA+B,CAAC,EACvC,KAAK,EACL,eAAe,EACf,cAAc,EACd,WAAW,GAMZ;IACC,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAA;IAC/B,MAAM,OAAO,GAAG,UAAU,CAAC,KAAK,CAAC,CAAA;IACjC,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,EAAqB,CAAA;IACrE,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,EAAqB,CAAA;IACnE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,EAAqB,CAAA;IACzD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,EAAa,CAAA;IACvD,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,QAAQ,EAAiB,CAAA;IACzE,MAAM,CAAC,qBAAqB,EAAE,wBAAwB,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACzE,MAAM,CAAC,oBAAoB,EAAE,uBAAuB,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACvE,MAAM,EAAE,aAAa,EAAE,GAAG,KAAK,CAAA;IAC/B,MAAM,YAAY,GAAG,aAAa,CAAC,WAAW,CAAC,CAAA;IAE/C,SAAS,eAAe,CACtB,cAAqC,EACrC,kBAA4B;QAE5B,MAAM,IAAI,GAAG,cAAc,CAAC,cAAc,EAAE,MAAM,CAAC,CAAA;QAEnD,aAAa;QACb,MAAM,MAAM,GAAG,OAAO,CAAC,wBAAwB,CAAC,cAAc,CAAC,CAAA;QAC/D,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,qBAAqB,EAAE,oBAAoB,CAAC,GAAG,MAAM,CAAA;YAC5D,IAAI,MAAM,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;gBAChD,YAAY,CAAC;oBACX,cAAc;oBACd,qBAAqB;oBACrB,oBAAoB;oBACpB,IAAI;iBACL,CAAC,CAAA;aACH;iBAAM;gBACL,qBAAqB,EAAE,CAAA;aACxB;SACF;QACD,IAAI,kBAAkB,EAAE;YACtB,mBAAmB,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,CAAC,CAAA;SAC9C;IACH,CAAC;IAED,MAAM,mBAAmB,GAAG;QAC1B;YACE,KAAK,EAAE,4BAA4B;YACnC,OAAO,EAAE,GAAG,EAAE,CAAC,uBAAuB,CAAC,IAAI,CAAC;SAC7C;KACF,CAAA;IAED,IAAI,6BAA6B,CAAC,OAAO,CAAC,EAAE;QAC1C,mBAAmB,CAAC,OAAO,CAAC;YAC1B,KAAK,EAAE,gBAAgB;YACvB,OAAO,EAAE,GAAG,EAAE;gBACZ,IAAI,yBAAyB,CAAC,OAAO,CAAC,EAAE;oBACtC,OAAO,CAAC,UAAU,CAChB,OAAO,CAAC,SAAS,CAAC,qBAAqB,EAAE,qBAAqB,CAAC,CAChE,CAAA;iBACF;YACH,CAAC;SACF,CAAC,CAAA;QAEF,mBAAmB,CAAC,IAAI,CAAC;YACvB,KAAK,EAAE,uBAAuB;YAC9B,OAAO,EAAE,GAAG,EAAE,CAAC,wBAAwB,CAAC,IAAI,CAAC;SAC9C,CAAC,CAAA;KACH;IAED,MAAM,iBAAiB,GACrB,aAAa,CAAC,MAAM,GAAG,CAAC;QACtB,CAAC,CAAC;YACE;gBACE,KAAK,EAAE,oBAAoB;gBAC3B,OAAO,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;oBACzC,KAAK,EAAE,IAAI;oBACX,OAAO,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC;iBACnC,CAAC,CAAC;aACJ;SACF;QACH,CAAC,CAAC,EAAE,CAAA;IAER,MAAM,SAAS,GAAG;QAChB;YACE,KAAK,EAAE,cAAc;YACrB,OAAO,EAAE,GAAG,EAAE;gBACZ,IAAI,yBAAyB,CAAC,OAAO,CAAC,EAAE;oBACtC,OAAO,CAAC,UAAU,CAChB,OAAO,CAAC,SAAS,CAAC,gBAAgB,EAAE,gBAAgB,EAAE;wBACpD,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,EAAE;qBACpB,CAAC,CACH,CAAA;iBACF;YACH,CAAC;SACF;QAED,GAAG,iBAAiB;KACrB,CAAA;IAED,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC,sBAAsB,CAC9D,mCAAmC,CACtB,CAAA;IACf,OAAO,CACL,6BACE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,eAAe,CAAC,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,qBAAqB,GAAG,MAAM,KAAI,CAAC,CAAC,iBACzD,6BAA6B;QAEzC,6BAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE;YAC5B,sBAAsB,CAAC,OAAO,CAAC,IAAI,CAClC,oBAAC,UAAU,IACT,SAAS,EAAE,OAAO,CAAC,QAAQ,EAC3B,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,aAAa,CAAC;gBAEhD,oBAAC,QAAQ,OAAG,CACD,CACd;YAEA,OAAO,CAAC,cAAc,IAAI,CACzB,oBAAC,UAAU,IACT,SAAS,EAAE,OAAO,CAAC,QAAQ,EAC3B,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAAC,KAAK,CAAC,aAAa,CAAC;gBAEtD,oBAAC,KAAK,OAAG,CACE,CACd;YAEA,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CACxB,oBAAC,UAAU,IACT,SAAS,EAAE,OAAO,CAAC,QAAQ,EAC3B,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,KAAK,CAAC,aAAa,CAAC;gBAErD,oBAAC,KAAK,IAAC,YAAY,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,KAAK,EAAC,SAAS;oBAC1D,oBAAC,gBAAgB,OAAG,CACd,CACG,CACd,CAAC,CAAC,CAAC,IAAI;YAER,oBAAC,SAAS,IACR,SAAS,EAAE,OAAO,CAAC,SAAS,EAC5B,KAAK,EAAC,eAAe,EACrB,KAAK,EAAE,KAAK,CAAC,UAAU,EACvB,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,EAC1D,SAAS,QACT,UAAU,EAAE;oBACV,YAAY,EAAE,CACZ,oBAAC,cAAc,IAAC,QAAQ,EAAC,KAAK;wBAC5B,oBAAC,UAAU,IAAC,KAAK,EAAC,WAAW,EAAC,OAAO,EAAE,KAAK,CAAC,eAAe;4BAC1D,oBAAC,SAAS,OAAG,CACF,CACE,CAClB;iBACF,GACD,CACE;QACN,oBAAC,WAAW,IACV,QAAQ,EAAE,YAAY,EACtB,IAAI,EAAE,OAAO,CAAC,YAAY,CAAC,EAC3B,eAAe,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE;gBAC/B,QAAQ,EAAE,CAAA;gBACV,eAAe,CAAC,SAAS,CAAC,CAAA;YAC5B,CAAC,EACD,OAAO,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,SAAS,CAAC,EACzC,SAAS,EAAE,mBAAmB,GAC9B;QACF,oBAAC,WAAW,IACV,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,OAAO,CAAC,MAAM,CAAC,EACrB,eAAe,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE;gBAC/B,QAAQ,EAAE,CAAA;gBACV,SAAS,CAAC,SAAS,CAAC,CAAA;YACtB,CAAC,EACD,OAAO,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,EACnC,SAAS,EAAE,SAAS,GACpB;QACF,oBAAC,WAAW,IACV,QAAQ,EAAE,WAAW,EACrB,IAAI,EAAE,OAAO,CAAC,WAAW,CAAC,EAC1B,eAAe,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE;gBAC/B,QAAQ,EAAE,CAAA;gBACV,cAAc,CAAC,SAAS,CAAC,CAAA;YAC3B,CAAC,EACD,OAAO,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,SAAS,CAAC,EACxC,SAAS,EAAE;gBACT,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,cAAc,EAAE,EAAE;gBACzD,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;oBACpB,GAAG,IAAI;oBACP,GAAG,CAAC,SAAS,IAAI,IAAI;wBACnB,CAAC,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;wBACxC,CAAC,CAAC,EAAE,CAAC;iBACR,CAAC,CAAC;aACJ,GACD;QACF,oBAAC,QAAQ,IAAC,QAAQ,EAAE,gCAAO;YACxB,SAAS,CAAC,CAAC,CAAC,CACX,oBAAC,qBAAqB,IACpB,SAAS,EAAE,SAAS,EACpB,YAAY,EAAE,YAAY,GAC1B,CACH,CAAC,CAAC,CAAC,IAAI;YACP,gBAAgB,CAAC,CAAC,CAAC,CAClB,oBAAC,sBAAsB,IACrB,WAAW,EAAE,GAAG,EAAE,CAAC,mBAAmB,CAAC,SAAS,CAAC,EACjD,mBAAmB,EAAE,gBAAgB,EACrC,OAAO,EAAE,OAAO,GAChB,CACH,CAAC,CAAC,CAAC,IAAI;YACP,qBAAqB,CAAC,CAAC,CAAC,CACvB,oBAAC,uBAAuB,IACtB,WAAW,EAAE,GAAG,EAAE,CAAC,wBAAwB,CAAC,KAAK,CAAC,EAClD,eAAe,EAAE,eAAe,EAChC,OAAO,EAAE,OAAO,GAChB,CACH,CAAC,CAAC,CAAC,IAAI;YACP,oBAAoB,CAAC,CAAC,CAAC,CACtB,oBAAC,uBAAuB,IACtB,WAAW,EAAE,GAAG,EAAE,CAAC,uBAAuB,CAAC,KAAK,CAAC,EACjD,OAAO,EAAE,OAAO,EAChB,eAAe,EAAE,eAAe,EAChC,YAAY,EAAE,YAAY,GAC1B,CACH,CAAC,CAAC,CAAC,IAAI,CACC,CACP,CACP,CAAA;AACH,CAAC;AAED,eAAe,QAAQ,CAAC,+BAA+B,CAAC,CAAA"}
@@ -1,122 +1,32 @@
1
- import React, { Suspense, lazy, useCallback, useMemo, useState, useRef, useEffect, } from 'react';
2
- import { Checkbox, Fab, FormControlLabel, IconButton, InputAdornment, Menu, MenuItem, TextField, Tooltip, Typography, } from '@mui/material';
1
+ import React, { useCallback, useMemo, useState, useRef, useEffect } from 'react';
2
+ import { Fab, Menu, MenuItem } from '@mui/material';
3
3
  import { makeStyles } from 'tss-react/mui';
4
4
  // icons
5
- import ClearIcon from '@mui/icons-material/Clear';
6
5
  import AddIcon from '@mui/icons-material/Add';
7
- import ArrowDropDownIcon from '@mui/icons-material/ArrowDropDown';
8
- import ArrowRightIcon from '@mui/icons-material/ArrowRight';
9
- import MenuIcon from '@mui/icons-material/Menu';
10
- import MoreIcon from '@mui/icons-material/MoreHoriz';
11
- import { Cable } from '@jbrowse/core/ui/Icons';
12
6
  // other
13
7
  import AutoSizer from 'react-virtualized-auto-sizer';
14
- import JBrowseMenu from '@jbrowse/core/ui/Menu';
15
8
  import { getSession, isSessionModelWithWidgets, isSessionModelWithConnections, isSessionWithAddTracks, } from '@jbrowse/core/util';
16
- import { readConfObject, } from '@jbrowse/core/configuration';
17
9
  import { observer } from 'mobx-react';
18
10
  import { VariableSizeTree } from 'react-vtree';
19
- // lazy components
20
- const CloseConnectionDialog = lazy(() => import('./CloseConnectionDialog'));
21
- const DeleteConnectionDialog = lazy(() => import('./DeleteConnectionDialog'));
22
- const ManageConnectionsDialog = lazy(() => import('./ManageConnectionsDialog'));
23
- const ToggleConnectionsDialog = lazy(() => import('./ToggleConnectionsDialog'));
24
- const useStyles = makeStyles()(theme => {
25
- var _a, _b;
26
- return ({
27
- searchBox: {
28
- margin: theme.spacing(2),
29
- },
30
- menuIcon: {
31
- marginRight: theme.spacing(1),
32
- marginBottom: 0,
33
- },
34
- fab: {
35
- position: 'absolute',
36
- bottom: theme.spacing(6),
37
- right: theme.spacing(6),
38
- },
39
- compactCheckbox: {
40
- padding: 0,
41
- },
42
- checkboxLabel: {
43
- marginRight: 0,
44
- '&:hover': {
45
- backgroundColor: '#eee',
46
- },
47
- },
48
- // this accordionBase element's small padding is used to give a margin to
49
- // accordionColor it a "margin" because the virtualized elements can't really
50
- // use margin in a conventional way (it doesn't affect layout)
51
- accordionBase: {
52
- display: 'flex',
53
- },
54
- accordionCard: {
55
- padding: 3,
56
- cursor: 'pointer',
57
- display: 'flex',
58
- },
59
- nestingLevelMarker: {
60
- position: 'absolute',
61
- borderLeft: '1.5px solid #555',
62
- },
63
- // accordionColor set's display:flex so that the child accordionText use
64
- // vertically centered text
65
- accordionColor: {
66
- // @ts-ignore
67
- background: (_a = theme.palette.tertiary) === null || _a === void 0 ? void 0 : _a.main,
68
- // @ts-ignore
69
- color: (_b = theme.palette.tertiary) === null || _b === void 0 ? void 0 : _b.contrastText,
70
- width: '100%',
71
- display: 'flex',
72
- paddingLeft: 5,
73
- },
74
- // margin:auto 0 to center text vertically
75
- accordionText: {
76
- margin: 'auto 0',
77
- },
78
- });
79
- });
80
- // An individual node in the track selector. Note: manually sets cursor:
81
- // pointer improves usability for what can be clicked
82
- function Node(props) {
83
- const { data, isOpen, style, setOpen } = props;
84
- const { isLeaf, nestingLevel, checked, id, name, onChange, toggleCollapse, conf, onMoreInfo, drawerPosition, } = data;
85
- const { classes } = useStyles();
86
- const width = 10;
87
- const marginLeft = nestingLevel * width + (isLeaf ? width : 0);
88
- const unsupported = (name === null || name === void 0 ? void 0 : name.endsWith('(Unsupported)')) || (name === null || name === void 0 ? void 0 : name.endsWith('(Unknown)'));
89
- const description = (conf && readConfObject(conf, ['description'])) || '';
90
- return (React.createElement("div", { style: style, className: !isLeaf ? classes.accordionBase : undefined },
91
- new Array(nestingLevel).fill(0).map((_, idx) => (React.createElement("div", { key: `mark-${idx}`, style: { left: idx * width + 4, height: style === null || style === void 0 ? void 0 : style.height }, className: classes.nestingLevelMarker }))),
92
- React.createElement("div", { className: !isLeaf ? classes.accordionCard : undefined, onClick: () => {
93
- toggleCollapse(id);
94
- setOpen(!isOpen);
95
- }, style: {
96
- marginLeft,
97
- whiteSpace: 'nowrap',
98
- width: '100%',
99
- } },
100
- React.createElement("div", { className: !isLeaf ? classes.accordionColor : undefined }, !isLeaf ? (React.createElement("div", { className: classes.accordionText },
101
- React.createElement(Typography, null,
102
- isOpen ? React.createElement(ArrowDropDownIcon, null) : React.createElement(ArrowRightIcon, null),
103
- name))) : (React.createElement(React.Fragment, null,
104
- React.createElement(Tooltip, { title: description, placement: drawerPosition === 'left' ? 'right' : 'left' },
105
- React.createElement(FormControlLabel, { className: classes.checkboxLabel, control: React.createElement(Checkbox, { className: classes.compactCheckbox, checked: checked, onChange: () => onChange(id), color: "primary", disabled: unsupported, inputProps: {
106
- // @ts-ignore
107
- 'data-testid': `htsTrackEntry-${id}`,
108
- } }), label: name })),
109
- React.createElement(IconButton, { onClick: e => onMoreInfo({ target: e.currentTarget, id, conf }), style: { padding: 0 }, color: "secondary", "data-testid": `htsTrackEntryMenu-${id}` },
110
- React.createElement(MoreIcon, null))))))));
111
- }
112
- function getNodeData(node, nestingLevel, extra) {
11
+ import Header from './Header';
12
+ import Node from './Node';
13
+ const useStyles = makeStyles()(theme => ({
14
+ fab: {
15
+ position: 'absolute',
16
+ bottom: theme.spacing(6),
17
+ right: theme.spacing(6),
18
+ },
19
+ }));
20
+ function getNodeData(node, nestingLevel, extra, selection) {
113
21
  const isLeaf = !!node.conf;
22
+ const selected = !!selection[node.id];
114
23
  return {
115
24
  data: {
116
25
  defaultHeight: isLeaf ? 22 : 40,
117
26
  isLeaf,
118
27
  isOpenByDefault: true,
119
28
  nestingLevel,
29
+ selected,
120
30
  ...node,
121
31
  ...extra,
122
32
  },
@@ -128,34 +38,32 @@ function getNodeData(node, nestingLevel, extra) {
128
38
  // in jbrowse-web the toolbar is position="sticky" which means the autosizer
129
39
  // includes the height of the toolbar, so we subtract the given offsets
130
40
  const HierarchicalTree = observer(({ height, tree, model, }) => {
131
- var _a;
132
- const { filterText, view } = model;
41
+ const { filterText, selection, view } = model;
133
42
  const treeRef = useRef(null);
134
- const [info, setMoreInfo] = useState();
135
43
  const session = getSession(model);
136
44
  const { drawerPosition } = session;
45
+ const obj = useMemo(() => Object.fromEntries(selection.map(s => [s.trackId, s])), [selection]);
137
46
  const extra = useMemo(() => ({
138
47
  onChange: (trackId) => view.toggleTrack(trackId),
139
48
  toggleCollapse: (pathName) => model.toggleCategory(pathName),
140
- onMoreInfo: setMoreInfo,
49
+ tree,
50
+ model,
141
51
  drawerPosition,
142
- }), [view, model, drawerPosition]);
52
+ }), [view, model, drawerPosition, tree]);
143
53
  const treeWalker = useCallback(function* treeWalker() {
144
54
  for (let i = 0; i < tree.children.length; i++) {
145
55
  const r = tree.children[i];
146
- yield getNodeData(r, 0, extra);
56
+ yield getNodeData(r, 0, extra, obj);
147
57
  }
148
58
  while (true) {
149
59
  // @ts-ignore
150
60
  const parentMeta = yield;
151
61
  for (let i = 0; i < parentMeta.node.children.length; i++) {
152
62
  const curr = parentMeta.node.children[i];
153
- yield getNodeData(curr, parentMeta.nestingLevel + 1, extra);
63
+ yield getNodeData(curr, parentMeta.nestingLevel + 1, extra, obj);
154
64
  }
155
65
  }
156
- }, [tree, extra]);
157
- const conf = info === null || info === void 0 ? void 0 : info.conf;
158
- const menuItems = (conf && ((_a = session.getTrackActionMenuItems) === null || _a === void 0 ? void 0 : _a.call(session, conf))) || [];
66
+ }, [tree, extra, obj]);
159
67
  useEffect(() => {
160
68
  // @ts-ignore
161
69
  treeRef.current.recomputeTree({
@@ -164,11 +72,7 @@ const HierarchicalTree = observer(({ height, tree, model, }) => {
164
72
  });
165
73
  }, [tree, filterText]);
166
74
  return (React.createElement(React.Fragment, null,
167
- React.createElement(VariableSizeTree, { ref: treeRef, treeWalker: treeWalker, height: height }, Node),
168
- React.createElement(JBrowseMenu, { anchorEl: info === null || info === void 0 ? void 0 : info.target, menuItems: menuItems, onMenuItemClick: (_event, callback) => {
169
- callback();
170
- setMoreInfo(undefined);
171
- }, open: Boolean(info), onClose: () => setMoreInfo(undefined) })));
75
+ React.createElement(VariableSizeTree, { ref: treeRef, treeWalker: treeWalker, height: height }, Node)));
172
76
  });
173
77
  // Don't use autosizer in jest and instead hardcode a height, otherwise fails
174
78
  // jest tests
@@ -210,116 +114,13 @@ const HierarchicalTrackSelectorContainer = observer(({ model, toolbarHeight, ove
210
114
  }
211
115
  } }, "Add track")) : null))) : null));
212
116
  });
213
- const HierarchicalTrackSelectorHeader = observer(({ model, setHeaderHeight, setAssemblyIdx, assemblyIdx, }) => {
214
- const { classes } = useStyles();
215
- const session = getSession(model);
216
- const [connectionAnchorEl, setConnectionAnchorEl] = useState();
217
- const [menuAnchorEl, setMenuAnchorEl] = useState();
218
- const [modalInfo, setModalInfo] = useState();
219
- const [deleteDialogDetails, setDeleteDialogDetails] = useState();
220
- const [connectionManagerOpen, setConnectionManagerOpen] = useState(false);
221
- const [connectionToggleOpen, setConnectionToggleOpen] = useState(false);
222
- const { assemblyNames } = model;
223
- const assemblyName = assemblyNames[assemblyIdx];
224
- function breakConnection(connectionConf, deletingConnection) {
225
- const name = readConfObject(connectionConf, 'name');
226
- // @ts-ignore
227
- const result = session.prepareToBreakConnection(connectionConf);
228
- if (result) {
229
- const [safelyBreakConnection, dereferenceTypeCount] = result;
230
- if (Object.keys(dereferenceTypeCount).length > 0) {
231
- setModalInfo({
232
- connectionConf,
233
- safelyBreakConnection,
234
- dereferenceTypeCount,
235
- name,
236
- });
237
- }
238
- else {
239
- safelyBreakConnection();
240
- }
241
- }
242
- if (deletingConnection) {
243
- setDeleteDialogDetails({ name, connectionConf });
244
- }
245
- }
246
- const connectionMenuItems = [
247
- {
248
- label: 'Turn on/off connections...',
249
- onClick: () => setConnectionToggleOpen(true),
250
- },
251
- ];
252
- if (isSessionModelWithConnections(session)) {
253
- connectionMenuItems.unshift({
254
- label: 'Add connection',
255
- onClick: () => {
256
- if (isSessionModelWithWidgets(session)) {
257
- const widget = session.addWidget('AddConnectionWidget', 'addConnectionWidget');
258
- session.showWidget(widget);
259
- }
260
- },
261
- });
262
- connectionMenuItems.push({
263
- label: 'Delete connections...',
264
- onClick: () => setConnectionManagerOpen(true),
265
- });
266
- }
267
- const assemblyMenuItems = assemblyNames.length > 1
268
- ? [
269
- {
270
- label: 'Select assembly...',
271
- subMenu: assemblyNames.map((name, idx) => ({
272
- label: name,
273
- onClick: () => setAssemblyIdx(idx),
274
- })),
275
- },
276
- ]
277
- : [];
278
- const menuItems = [
279
- {
280
- label: 'Add track...',
281
- onClick: () => {
282
- if (isSessionModelWithWidgets(session)) {
283
- const widget = session.addWidget('AddTrackWidget', 'addTrackWidget', {
284
- view: model.view.id,
285
- });
286
- session.showWidget(widget);
287
- }
288
- },
289
- },
290
- ...assemblyMenuItems,
291
- ];
292
- return (React.createElement("div", { ref: ref => setHeaderHeight((ref === null || ref === void 0 ? void 0 : ref.getBoundingClientRect().height) || 0), "data-testid": "hierarchical_track_selector" },
293
- React.createElement("div", { style: { display: 'flex' } },
294
- isSessionWithAddTracks(session) && (React.createElement(IconButton, { className: classes.menuIcon, onClick: event => setMenuAnchorEl(event.currentTarget) },
295
- React.createElement(MenuIcon, null))),
296
- session.makeConnection && (React.createElement(IconButton, { className: classes.menuIcon, onClick: event => setConnectionAnchorEl(event.currentTarget) },
297
- React.createElement(Cable, null))),
298
- React.createElement(TextField, { className: classes.searchBox, label: "Filter tracks", value: model.filterText, onChange: event => model.setFilterText(event.target.value), fullWidth: true, InputProps: {
299
- endAdornment: (React.createElement(InputAdornment, { position: "end" },
300
- React.createElement(IconButton, { color: "secondary", onClick: model.clearFilterText },
301
- React.createElement(ClearIcon, null)))),
302
- } })),
303
- React.createElement(JBrowseMenu, { anchorEl: connectionAnchorEl, open: Boolean(connectionAnchorEl), onMenuItemClick: (_, callback) => {
304
- callback();
305
- setConnectionAnchorEl(undefined);
306
- }, onClose: () => setConnectionAnchorEl(undefined), menuItems: connectionMenuItems }),
307
- React.createElement(JBrowseMenu, { anchorEl: menuAnchorEl, open: Boolean(menuAnchorEl), onMenuItemClick: (_, callback) => {
308
- callback();
309
- setMenuAnchorEl(undefined);
310
- }, onClose: () => setMenuAnchorEl(undefined), menuItems: menuItems }),
311
- React.createElement(Suspense, { fallback: React.createElement("div", null) },
312
- modalInfo ? (React.createElement(CloseConnectionDialog, { modalInfo: modalInfo, setModalInfo: setModalInfo })) : deleteDialogDetails ? (React.createElement(DeleteConnectionDialog, { handleClose: () => setDeleteDialogDetails(undefined), deleteDialogDetails: deleteDialogDetails, session: session })) : null,
313
- connectionManagerOpen ? (React.createElement(ManageConnectionsDialog, { handleClose: () => setConnectionManagerOpen(false), breakConnection: breakConnection, session: session })) : null,
314
- connectionToggleOpen ? (React.createElement(ToggleConnectionsDialog, { handleClose: () => setConnectionToggleOpen(false), session: session, breakConnection: breakConnection, assemblyName: assemblyName })) : null)));
315
- });
316
117
  const HierarchicalTrackSelector = observer(({ model, toolbarHeight = 0, }) => {
317
118
  const [assemblyIdx, setAssemblyIdx] = useState(0);
318
119
  const [headerHeight, setHeaderHeight] = useState(0);
319
120
  const { assemblyNames } = model;
320
121
  const assemblyName = assemblyNames[assemblyIdx];
321
122
  return assemblyName ? (React.createElement(React.Fragment, null,
322
- React.createElement(HierarchicalTrackSelectorHeader, { model: model, setHeaderHeight: setHeaderHeight, setAssemblyIdx: setAssemblyIdx, assemblyIdx: assemblyIdx }),
123
+ React.createElement(Header, { model: model, setHeaderHeight: setHeaderHeight, setAssemblyIdx: setAssemblyIdx, assemblyIdx: assemblyIdx }),
323
124
  React.createElement(AutoSizedHierarchicalTree, { tree: model.hierarchy(assemblyName), model: model, offset: toolbarHeight + headerHeight }))) : null;
324
125
  });
325
126
  export default HierarchicalTrackSelectorContainer;