@jbrowse/plugin-data-management 2.18.0 → 3.0.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.
- package/dist/AddConnectionWidget/components/AddConnectionWidget.d.ts +1 -2
- package/dist/AddConnectionWidget/components/AddConnectionWidget.js +28 -57
- package/dist/AddConnectionWidget/components/ConfigureConnection.d.ts +1 -2
- package/dist/AddConnectionWidget/components/ConfigureConnection.js +3 -26
- package/dist/AddConnectionWidget/components/ConnectionTypeSelect.d.ts +1 -2
- package/dist/AddConnectionWidget/components/ConnectionTypeSelect.js +5 -30
- package/dist/AddConnectionWidget/index.js +17 -7
- package/dist/AddTrackWidget/components/AddTrackStatusMessage.d.ts +9 -0
- package/dist/AddTrackWidget/components/AddTrackStatusMessage.js +16 -0
- package/dist/AddTrackWidget/components/AddTrackUnknownAdapterPrompt.d.ts +4 -0
- package/dist/AddTrackWidget/components/AddTrackUnknownAdapterPrompt.js +19 -0
- package/dist/AddTrackWidget/components/AddTrackWidget.d.ts +1 -2
- package/dist/AddTrackWidget/components/AddTrackWidget.js +5 -32
- package/dist/AddTrackWidget/components/ConfirmTrack.d.ts +1 -2
- package/dist/AddTrackWidget/components/ConfirmTrack.js +33 -91
- package/dist/AddTrackWidget/components/DefaultAddTrackWorkflow.d.ts +1 -2
- package/dist/AddTrackWidget/components/DefaultAddTrackWorkflow.js +22 -104
- package/dist/AddTrackWidget/components/PasteConfigWorkflow.d.ts +1 -2
- package/dist/AddTrackWidget/components/PasteConfigWorkflow.js +29 -49
- package/dist/AddTrackWidget/components/TextIndexingConfig.d.ts +1 -2
- package/dist/AddTrackWidget/components/TextIndexingConfig.js +35 -70
- package/dist/AddTrackWidget/components/TrackAdapterSelector.d.ts +1 -2
- package/dist/AddTrackWidget/components/TrackAdapterSelector.js +12 -33
- package/dist/AddTrackWidget/components/TrackSourceSelect.d.ts +1 -2
- package/dist/AddTrackWidget/components/TrackSourceSelect.js +2 -8
- package/dist/AddTrackWidget/components/TrackTypeSelector.d.ts +2 -3
- package/dist/AddTrackWidget/components/TrackTypeSelector.js +7 -15
- package/dist/AddTrackWidget/components/Unsupported.d.ts +1 -0
- package/dist/AddTrackWidget/components/Unsupported.js +15 -0
- package/dist/AddTrackWidget/components/doSubmit.d.ts +4 -0
- package/dist/AddTrackWidget/components/doSubmit.js +50 -0
- package/dist/AddTrackWidget/components/util.d.ts +2 -0
- package/dist/AddTrackWidget/components/util.js +15 -0
- package/dist/AddTrackWidget/index.js +17 -7
- package/dist/AddTrackWidget/model.d.ts +13 -0
- package/dist/AddTrackWidget/model.js +43 -3
- package/dist/AssemblyManager/AssemblyAddForm.d.ts +1 -2
- package/dist/AssemblyManager/AssemblyAddForm.js +73 -120
- package/dist/AssemblyManager/AssemblyEditor.d.ts +1 -2
- package/dist/AssemblyManager/AssemblyEditor.js +4 -11
- package/dist/AssemblyManager/AssemblyManager.d.ts +1 -2
- package/dist/AssemblyManager/AssemblyManager.js +14 -36
- package/dist/AssemblyManager/AssemblyTable.d.ts +1 -2
- package/dist/AssemblyManager/AssemblyTable.js +31 -43
- package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalFab.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalFab.js +19 -46
- package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js +6 -32
- package/dist/HierarchicalTrackSelectorWidget/components/ShoppingCart.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/ShoppingCart.js +18 -7
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/CloseConnectionDialog.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/CloseConnectionDialog.js +7 -18
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/DeleteConnectionDialog.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/DeleteConnectionDialog.js +8 -16
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/ManageConnectionsDialog.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/ManageConnectionsDialog.js +10 -22
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/ToggleConnectionsDialog.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/ToggleConnectionsDialog.js +7 -16
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetFilter.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetFilter.js +17 -51
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetFilters.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetFilters.js +22 -20
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedDataGrid.d.ts +9 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedDataGrid.js +71 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.js +2 -4
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.js +46 -79
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.js +15 -107
- package/dist/HierarchicalTrackSelectorWidget/components/tree/DropdownTrackSelector.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/tree/DropdownTrackSelector.js +5 -30
- package/dist/HierarchicalTrackSelectorWidget/components/tree/FavoriteTracks.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/tree/FavoriteTracks.js +4 -7
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.js +122 -119
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HierarchicalHeader.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HierarchicalHeader.js +6 -14
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.js +3 -26
- package/dist/HierarchicalTrackSelectorWidget/components/tree/RecentlyUsedTracks.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/tree/RecentlyUsedTracks.js +4 -7
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackCategory.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackCategory.js +44 -72
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackLabel.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackLabel.js +17 -11
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackLabelMenu.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackLabelMenu.js +3 -4
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackListNode.d.ts +1 -2
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackListNode.js +6 -9
- package/dist/HierarchicalTrackSelectorWidget/components/util.js +1 -3
- package/dist/HierarchicalTrackSelectorWidget/facetedModel.d.ts +1 -0
- package/dist/HierarchicalTrackSelectorWidget/facetedModel.js +6 -6
- package/dist/HierarchicalTrackSelectorWidget/index.js +17 -7
- package/dist/PluginStoreWidget/components/AddCustomPluginDialog.d.ts +1 -2
- package/dist/PluginStoreWidget/components/AddCustomPluginDialog.js +15 -54
- package/dist/PluginStoreWidget/components/DeletePluginDialog.d.ts +1 -2
- package/dist/PluginStoreWidget/components/DeletePluginDialog.js +9 -21
- package/dist/PluginStoreWidget/components/InstalledPlugin.d.ts +1 -2
- package/dist/PluginStoreWidget/components/InstalledPlugin.js +38 -31
- package/dist/PluginStoreWidget/components/InstalledPluginsList.d.ts +1 -2
- package/dist/PluginStoreWidget/components/InstalledPluginsList.js +4 -4
- package/dist/PluginStoreWidget/components/PluginCard.d.ts +1 -2
- package/dist/PluginStoreWidget/components/PluginCard.js +14 -46
- package/dist/PluginStoreWidget/components/PluginStoreWidget.d.ts +1 -2
- package/dist/PluginStoreWidget/components/PluginStoreWidget.js +40 -52
- package/dist/PluginStoreWidget/index.js +17 -7
- package/dist/UCSCTrackHub/doConnect.js +18 -10
- package/dist/UCSCTrackHub/model.js +17 -7
- package/dist/UCSCTrackHub/ucscTrackHub.d.ts +53 -36
- package/dist/UCSCTrackHub/ucscTrackHub.js +141 -165
- package/dist/UCSCTrackHub/util.d.ts +22 -0
- package/dist/UCSCTrackHub/util.js +41 -0
- package/dist/index.d.ts +2 -2
- package/dist/index.js +17 -7
- package/esm/AddConnectionWidget/components/AddConnectionWidget.d.ts +1 -2
- package/esm/AddConnectionWidget/components/AddConnectionWidget.js +28 -34
- package/esm/AddConnectionWidget/components/ConfigureConnection.d.ts +1 -2
- package/esm/AddConnectionWidget/components/ConfigureConnection.js +3 -3
- package/esm/AddConnectionWidget/components/ConnectionTypeSelect.d.ts +1 -2
- package/esm/AddConnectionWidget/components/ConnectionTypeSelect.js +5 -7
- package/esm/AddTrackWidget/components/AddTrackStatusMessage.d.ts +9 -0
- package/esm/AddTrackWidget/components/AddTrackStatusMessage.js +13 -0
- package/esm/AddTrackWidget/components/AddTrackUnknownAdapterPrompt.d.ts +4 -0
- package/esm/AddTrackWidget/components/AddTrackUnknownAdapterPrompt.js +13 -0
- package/esm/AddTrackWidget/components/AddTrackWidget.d.ts +1 -2
- package/esm/AddTrackWidget/components/AddTrackWidget.js +5 -9
- package/esm/AddTrackWidget/components/ConfirmTrack.d.ts +1 -2
- package/esm/AddTrackWidget/components/ConfirmTrack.js +35 -70
- package/esm/AddTrackWidget/components/DefaultAddTrackWorkflow.d.ts +1 -2
- package/esm/AddTrackWidget/components/DefaultAddTrackWorkflow.js +24 -83
- package/esm/AddTrackWidget/components/PasteConfigWorkflow.d.ts +1 -2
- package/esm/AddTrackWidget/components/PasteConfigWorkflow.js +29 -26
- package/esm/AddTrackWidget/components/TextIndexingConfig.d.ts +1 -2
- package/esm/AddTrackWidget/components/TextIndexingConfig.js +35 -47
- package/esm/AddTrackWidget/components/TrackAdapterSelector.d.ts +1 -2
- package/esm/AddTrackWidget/components/TrackAdapterSelector.js +12 -30
- package/esm/AddTrackWidget/components/TrackSourceSelect.d.ts +1 -2
- package/esm/AddTrackWidget/components/TrackSourceSelect.js +2 -5
- package/esm/AddTrackWidget/components/TrackTypeSelector.d.ts +2 -3
- package/esm/AddTrackWidget/components/TrackTypeSelector.js +7 -12
- package/esm/AddTrackWidget/components/Unsupported.d.ts +1 -0
- package/esm/AddTrackWidget/components/Unsupported.js +12 -0
- package/esm/AddTrackWidget/components/doSubmit.d.ts +4 -0
- package/esm/AddTrackWidget/components/doSubmit.js +47 -0
- package/esm/AddTrackWidget/components/util.d.ts +2 -0
- package/esm/AddTrackWidget/components/util.js +12 -0
- package/esm/AddTrackWidget/model.d.ts +13 -0
- package/esm/AddTrackWidget/model.js +40 -3
- package/esm/AssemblyManager/AssemblyAddForm.d.ts +1 -2
- package/esm/AssemblyManager/AssemblyAddForm.js +73 -97
- package/esm/AssemblyManager/AssemblyEditor.d.ts +1 -2
- package/esm/AssemblyManager/AssemblyEditor.js +4 -8
- package/esm/AssemblyManager/AssemblyManager.d.ts +1 -2
- package/esm/AssemblyManager/AssemblyManager.js +14 -13
- package/esm/AssemblyManager/AssemblyTable.d.ts +1 -2
- package/esm/AssemblyManager/AssemblyTable.js +31 -43
- package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalFab.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalFab.js +19 -23
- package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js +6 -9
- package/esm/HierarchicalTrackSelectorWidget/components/ShoppingCart.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/ShoppingCart.js +18 -7
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/CloseConnectionDialog.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/CloseConnectionDialog.js +7 -15
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/DeleteConnectionDialog.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/DeleteConnectionDialog.js +8 -13
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/ManageConnectionsDialog.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/ManageConnectionsDialog.js +10 -22
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/ToggleConnectionsDialog.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/ToggleConnectionsDialog.js +7 -13
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetFilter.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetFilter.js +17 -28
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetFilters.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetFilters.js +22 -20
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedDataGrid.d.ts +9 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedDataGrid.js +69 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.js +2 -4
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.js +46 -56
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.js +15 -84
- package/esm/HierarchicalTrackSelectorWidget/components/tree/DropdownTrackSelector.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/tree/DropdownTrackSelector.js +5 -7
- package/esm/HierarchicalTrackSelectorWidget/components/tree/FavoriteTracks.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/tree/FavoriteTracks.js +4 -7
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.js +105 -112
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HierarchicalHeader.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HierarchicalHeader.js +6 -14
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.js +3 -3
- package/esm/HierarchicalTrackSelectorWidget/components/tree/RecentlyUsedTracks.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/tree/RecentlyUsedTracks.js +4 -7
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackCategory.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackCategory.js +44 -49
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackLabel.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackLabel.js +17 -11
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackLabelMenu.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackLabelMenu.js +3 -4
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackListNode.d.ts +1 -2
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackListNode.js +6 -9
- package/esm/HierarchicalTrackSelectorWidget/components/util.js +1 -3
- package/esm/HierarchicalTrackSelectorWidget/facetedModel.d.ts +1 -0
- package/esm/HierarchicalTrackSelectorWidget/facetedModel.js +7 -7
- package/esm/PluginStoreWidget/components/AddCustomPluginDialog.d.ts +1 -2
- package/esm/PluginStoreWidget/components/AddCustomPluginDialog.js +15 -31
- package/esm/PluginStoreWidget/components/DeletePluginDialog.d.ts +1 -2
- package/esm/PluginStoreWidget/components/DeletePluginDialog.js +9 -18
- package/esm/PluginStoreWidget/components/InstalledPlugin.d.ts +1 -2
- package/esm/PluginStoreWidget/components/InstalledPlugin.js +21 -24
- package/esm/PluginStoreWidget/components/InstalledPluginsList.d.ts +1 -2
- package/esm/PluginStoreWidget/components/InstalledPluginsList.js +4 -4
- package/esm/PluginStoreWidget/components/PluginCard.d.ts +1 -2
- package/esm/PluginStoreWidget/components/PluginCard.js +14 -23
- package/esm/PluginStoreWidget/components/PluginStoreWidget.d.ts +1 -2
- package/esm/PluginStoreWidget/components/PluginStoreWidget.js +23 -45
- package/esm/UCSCTrackHub/doConnect.js +12 -4
- package/esm/UCSCTrackHub/ucscTrackHub.d.ts +53 -36
- package/esm/UCSCTrackHub/ucscTrackHub.js +139 -158
- package/esm/UCSCTrackHub/util.d.ts +22 -0
- package/esm/UCSCTrackHub/util.js +33 -0
- package/esm/index.d.ts +2 -2
- package/package.json +4 -3
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { Suspense, useState } from 'react';
|
|
2
3
|
import { getEnv } from '@jbrowse/core/util';
|
|
3
4
|
import { FormControl, FormHelperText, MenuItem, Select } from '@mui/material';
|
|
4
5
|
import { observer } from 'mobx-react';
|
|
@@ -15,13 +16,8 @@ const AddTrackSelector = observer(function ({ model, }) {
|
|
|
15
16
|
};
|
|
16
17
|
const val2 = ComponentMap[val] ? val : 'Default add track workflow';
|
|
17
18
|
const Component = ComponentMap[val2];
|
|
18
|
-
return (
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
setVal(event.target.value);
|
|
22
|
-
} }, Object.keys(ComponentMap).map(e => (React.createElement(MenuItem, { key: e, value: e }, e)))),
|
|
23
|
-
React.createElement(FormHelperText, null, "Type of add track workflow")),
|
|
24
|
-
React.createElement(Suspense, { fallback: null },
|
|
25
|
-
React.createElement(Component, { model: model }))));
|
|
19
|
+
return (_jsxs(_Fragment, { children: [_jsxs(FormControl, { children: [_jsx(Select, { value: val2, onChange: event => {
|
|
20
|
+
setVal(event.target.value);
|
|
21
|
+
}, children: Object.keys(ComponentMap).map(e => (_jsx(MenuItem, { value: e, children: e }, e))) }), _jsx(FormHelperText, { children: "Type of add track workflow" })] }), _jsx(Suspense, { fallback: null, children: _jsx(Component, { model: model }) })] }));
|
|
26
22
|
});
|
|
27
23
|
export default AddTrackSelector;
|
|
@@ -1,51 +1,22 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Suspense, useEffect, useState } from 'react';
|
|
2
3
|
import { AssemblySelector } from '@jbrowse/core/ui';
|
|
3
|
-
import { getSession, isElectron, isSupportedIndexingAdapter, } from '@jbrowse/core/util';
|
|
4
|
+
import { getEnv, getSession, isElectron, isSupportedIndexingAdapter, } from '@jbrowse/core/util';
|
|
4
5
|
import { UNKNOWN } from '@jbrowse/core/util/tracks';
|
|
5
|
-
import { Checkbox, FormControl, FormControlLabel,
|
|
6
|
+
import { Checkbox, FormControl, FormControlLabel, TextField, Typography, } from '@mui/material';
|
|
6
7
|
import { observer } from 'mobx-react';
|
|
7
8
|
import { makeStyles } from 'tss-react/mui';
|
|
9
|
+
import StatusMessage from './AddTrackStatusMessage';
|
|
10
|
+
import UnknownAdapterPrompt from './AddTrackUnknownAdapterPrompt';
|
|
8
11
|
import TextIndexingConfig from './TextIndexingConfig';
|
|
9
12
|
import TrackAdapterSelector from './TrackAdapterSelector';
|
|
10
13
|
import TrackTypeSelector from './TrackTypeSelector';
|
|
14
|
+
import Unsupported from './Unsupported';
|
|
11
15
|
const useStyles = makeStyles()(theme => ({
|
|
12
16
|
spacing: {
|
|
13
17
|
marginBottom: theme.spacing(3),
|
|
14
18
|
},
|
|
15
19
|
}));
|
|
16
|
-
function StatusMessage({ trackAdapter, trackType, }) {
|
|
17
|
-
const { classes } = useStyles();
|
|
18
|
-
const { type, subadapter } = trackAdapter;
|
|
19
|
-
return type === 'SNPCoverageAdapter' ? (React.createElement(Typography, { className: classes.spacing },
|
|
20
|
-
"Selected ",
|
|
21
|
-
React.createElement("code", null, trackType),
|
|
22
|
-
". Using adapter ",
|
|
23
|
-
React.createElement("code", null, type),
|
|
24
|
-
" with subadapter ",
|
|
25
|
-
React.createElement("code", null, subadapter === null || subadapter === void 0 ? void 0 : subadapter.type),
|
|
26
|
-
". Please enter a track name and, if necessary, update the track type.")) : (React.createElement(Typography, { className: classes.spacing },
|
|
27
|
-
"Using adapter ",
|
|
28
|
-
React.createElement("code", null, type),
|
|
29
|
-
" and guessing track type",
|
|
30
|
-
' ',
|
|
31
|
-
React.createElement("code", null, trackType),
|
|
32
|
-
". Please enter a track name and, if necessary, update the track type."));
|
|
33
|
-
}
|
|
34
|
-
function UnknownAdapterPrompt({ model }) {
|
|
35
|
-
const { classes } = useStyles();
|
|
36
|
-
return (React.createElement(React.Fragment, null,
|
|
37
|
-
React.createElement(Typography, { className: classes.spacing },
|
|
38
|
-
"JBrowse was not able to guess the adapter type for this data, but it may be in the list below. If not, you can",
|
|
39
|
-
' ',
|
|
40
|
-
React.createElement(Link, { href: "https://github.com/GMOD/jbrowse-components/releases", target: "_blank", rel: "noopener noreferrer" }, "check for new releases"),
|
|
41
|
-
' ',
|
|
42
|
-
"of JBrowse to see if they support this data type or",
|
|
43
|
-
' ',
|
|
44
|
-
React.createElement(Link, { href: "https://github.com/GMOD/jbrowse-components/issues/new", target: "_blank", rel: "noopener noreferrer" }, "file an issue"),
|
|
45
|
-
' ',
|
|
46
|
-
"and add a feature request for this data type."),
|
|
47
|
-
React.createElement(TrackAdapterSelector, { model: model })));
|
|
48
|
-
}
|
|
49
20
|
const ConfirmTrack = observer(function ConfirmTrack({ model, }) {
|
|
50
21
|
const { classes } = useStyles();
|
|
51
22
|
const [check, setCheck] = useState(true);
|
|
@@ -57,47 +28,41 @@ const ConfirmTrack = observer(function ConfirmTrack({ model, }) {
|
|
|
57
28
|
}
|
|
58
29
|
}, [adapterHint, trackAdapter, trackAdapter === null || trackAdapter === void 0 ? void 0 : trackAdapter.type, model]);
|
|
59
30
|
if (unsupported) {
|
|
60
|
-
return (
|
|
61
|
-
"This version of JBrowse cannot display data of this type. It is possible, however, that there is a newer version that can display them. You can",
|
|
62
|
-
' ',
|
|
63
|
-
React.createElement(Link, { href: "https://github.com/GMOD/jbrowse-components/releases", target: "_blank", rel: "noopener noreferrer" }, "check for new releases"),
|
|
64
|
-
' ',
|
|
65
|
-
"of JBrowse or",
|
|
66
|
-
' ',
|
|
67
|
-
React.createElement(Link, { href: "https://github.com/GMOD/jbrowse-components/issues/new", target: "_blank", rel: "noopener noreferrer" }, "file an issue"),
|
|
68
|
-
' ',
|
|
69
|
-
"and add a feature request for this data type."));
|
|
31
|
+
return _jsx(Unsupported, {});
|
|
70
32
|
}
|
|
71
|
-
if ((trackAdapter === null || trackAdapter === void 0 ? void 0 : trackAdapter.type) === UNKNOWN) {
|
|
72
|
-
return
|
|
33
|
+
else if ((trackAdapter === null || trackAdapter === void 0 ? void 0 : trackAdapter.type) === UNKNOWN) {
|
|
34
|
+
return _jsx(UnknownAdapterPrompt, { model: model });
|
|
73
35
|
}
|
|
74
|
-
if (!(trackAdapter === null || trackAdapter === void 0 ? void 0 : trackAdapter.type)) {
|
|
75
|
-
return
|
|
36
|
+
else if (!(trackAdapter === null || trackAdapter === void 0 ? void 0 : trackAdapter.type)) {
|
|
37
|
+
return _jsx(Typography, { children: "Could not recognize this data type." });
|
|
76
38
|
}
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
React.createElement(TextField, { className: classes.spacing, label: "trackName", helperText: "A name for this track", fullWidth: true, value: trackName, onChange: event => {
|
|
82
|
-
model.setTrackName(event.target.value);
|
|
83
|
-
}, slotProps: {
|
|
84
|
-
htmlInput: { 'data-testid': 'trackNameInput' },
|
|
85
|
-
} }),
|
|
86
|
-
React.createElement(TrackAdapterSelector, { model: model }),
|
|
87
|
-
React.createElement(TrackTypeSelector, { model: model }),
|
|
88
|
-
React.createElement(AssemblySelector, { session: session, helperText: "Select assembly to add track to", selected: model.assembly, onChange: asm => {
|
|
39
|
+
else {
|
|
40
|
+
const supportedForIndexing = isSupportedIndexingAdapter(trackAdapter.type);
|
|
41
|
+
const { pluginManager } = getEnv(model);
|
|
42
|
+
const Component = pluginManager.evaluateExtensionPoint('Core-addTrackComponent', ({ model }) => (_jsx(AssemblySelector, { session: session, helperText: "Select assembly to add track to", selected: model.assembly, onChange: asm => {
|
|
89
43
|
model.setAssembly(asm);
|
|
90
44
|
}, TextFieldProps: {
|
|
91
45
|
fullWidth: true,
|
|
92
46
|
SelectProps: {
|
|
93
|
-
SelectDisplayProps: {
|
|
47
|
+
SelectDisplayProps: {
|
|
48
|
+
'data-testid': 'assemblyNameSelect',
|
|
49
|
+
},
|
|
94
50
|
},
|
|
95
|
-
} }),
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
51
|
+
} })), { model });
|
|
52
|
+
return (_jsxs("div", { children: [_jsx(StatusMessage, { trackAdapter: trackAdapter, trackType: trackType }), warningMessage ? (_jsx(Typography, { color: "warning", children: warningMessage })) : null, _jsx(TextField, { className: classes.spacing, label: "trackName", helperText: "A name for this track", fullWidth: true, value: trackName, onChange: event => {
|
|
53
|
+
model.setTrackName(event.target.value);
|
|
54
|
+
}, slotProps: {
|
|
55
|
+
htmlInput: {
|
|
56
|
+
'data-testid': 'trackNameInput',
|
|
57
|
+
},
|
|
58
|
+
} }), _jsxs("div", { style: {
|
|
59
|
+
display: 'flex',
|
|
60
|
+
flexDirection: 'column',
|
|
61
|
+
gap: 10,
|
|
62
|
+
}, children: [_jsx(TrackAdapterSelector, { model: model }), _jsx(TrackTypeSelector, { model: model }), _jsx(Suspense, { fallback: null, children: _jsx(Component, { model: model }) })] }), isElectron && supportedForIndexing && (_jsx(FormControl, { children: _jsx(FormControlLabel, { label: "Index track for text searching?", control: _jsx(Checkbox, { checked: check, onChange: e => {
|
|
63
|
+
setCheck(e.target.checked);
|
|
64
|
+
model.setTextIndexTrack(e.target.checked);
|
|
65
|
+
} }) }) })), isElectron && check && supportedForIndexing ? (_jsx(TextIndexingConfig, { model: model })) : null] }));
|
|
66
|
+
}
|
|
102
67
|
});
|
|
103
68
|
export default ConfirmTrack;
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
1
|
import type { AddTrackModel } from '../model';
|
|
3
2
|
declare const DefaultAddTrackWorkflow: ({ model, }: {
|
|
4
3
|
model: AddTrackModel;
|
|
5
|
-
}) =>
|
|
4
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
6
5
|
export default DefaultAddTrackWorkflow;
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
import { getSession
|
|
4
|
-
import {
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState } from 'react';
|
|
3
|
+
import { getSession } from '@jbrowse/core/util';
|
|
4
|
+
import { Button, Step, StepContent, StepLabel, Stepper, Typography, } from '@mui/material';
|
|
5
5
|
import { observer } from 'mobx-react';
|
|
6
|
-
import { getRoot } from 'mobx-state-tree';
|
|
7
6
|
import { makeStyles } from 'tss-react/mui';
|
|
8
7
|
import ConfirmTrack from './ConfirmTrack';
|
|
9
8
|
import TrackSourceSelect from './TrackSourceSelect';
|
|
9
|
+
import { doSubmit } from './doSubmit';
|
|
10
10
|
const useStyles = makeStyles()(theme => ({
|
|
11
11
|
root: {
|
|
12
12
|
marginTop: theme.spacing(1),
|
|
@@ -29,76 +29,15 @@ const steps = ['Enter track data', 'Confirm track type'];
|
|
|
29
29
|
const DefaultAddTrackWorkflow = observer(function ({ model, }) {
|
|
30
30
|
const [activeStep, setActiveStep] = useState(0);
|
|
31
31
|
const { classes } = useStyles();
|
|
32
|
-
const {
|
|
33
|
-
const session = getSession(model);
|
|
34
|
-
const { assembly, trackAdapter, trackData, trackName, trackType, textIndexTrack, textIndexingConf, } = model;
|
|
35
|
-
const [trackErrorMessage, setTrackErrorMessage] = useState();
|
|
32
|
+
const { assembly, trackAdapter, trackData, trackName, trackType } = model;
|
|
36
33
|
function getStepContent(step) {
|
|
37
34
|
switch (step) {
|
|
38
35
|
case 0:
|
|
39
|
-
return
|
|
36
|
+
return _jsx(TrackSourceSelect, { model: model });
|
|
40
37
|
case 1:
|
|
41
|
-
return
|
|
38
|
+
return _jsx(ConfirmTrack, { model: model });
|
|
42
39
|
default:
|
|
43
|
-
return
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
async function handleNext() {
|
|
47
|
-
var _a, _b;
|
|
48
|
-
if (activeStep !== steps.length - 1) {
|
|
49
|
-
setActiveStep(activeStep + 1);
|
|
50
|
-
return;
|
|
51
|
-
}
|
|
52
|
-
const trackId = [
|
|
53
|
-
`${trackName.toLowerCase().replaceAll(' ', '_')}-${Date.now()}`,
|
|
54
|
-
session.adminMode ? '' : '-sessionTrack',
|
|
55
|
-
].join('');
|
|
56
|
-
const assemblyInstance = session.assemblyManager.get(assembly);
|
|
57
|
-
if (!isSessionWithAddTracks(session)) {
|
|
58
|
-
setTrackErrorMessage('Unable to add tracks to this model');
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
if (assemblyInstance && trackAdapter && trackAdapter.type !== 'UNKNOWN') {
|
|
62
|
-
session.addTrackConf({
|
|
63
|
-
trackId,
|
|
64
|
-
type: trackType,
|
|
65
|
-
name: trackName,
|
|
66
|
-
assemblyNames: [assembly],
|
|
67
|
-
adapter: {
|
|
68
|
-
...trackAdapter,
|
|
69
|
-
sequenceAdapter: getConf(assemblyInstance, ['sequence', 'adapter']),
|
|
70
|
-
},
|
|
71
|
-
});
|
|
72
|
-
(_b = (_a = model.view).showTrack) === null || _b === void 0 ? void 0 : _b.call(_a, trackId);
|
|
73
|
-
if (isElectron &&
|
|
74
|
-
textIndexTrack &&
|
|
75
|
-
isSupportedIndexingAdapter(trackAdapter.type)) {
|
|
76
|
-
const attr = textIndexingConf || {
|
|
77
|
-
attributes: ['Name', 'ID'],
|
|
78
|
-
exclude: ['CDS', 'exon'],
|
|
79
|
-
};
|
|
80
|
-
const indexName = `${trackName}-index`;
|
|
81
|
-
const newEntry = {
|
|
82
|
-
indexingParams: {
|
|
83
|
-
...attr,
|
|
84
|
-
assemblies: [assembly],
|
|
85
|
-
tracks: [trackId],
|
|
86
|
-
indexType: 'perTrack',
|
|
87
|
-
name: indexName,
|
|
88
|
-
timestamp: new Date().toISOString(),
|
|
89
|
-
},
|
|
90
|
-
name: indexName,
|
|
91
|
-
cancelCallback: () => jobsManager.abortJob(),
|
|
92
|
-
};
|
|
93
|
-
jobsManager.queueJob(newEntry);
|
|
94
|
-
}
|
|
95
|
-
model.clearData();
|
|
96
|
-
if (isSessionModelWithWidgets(session)) {
|
|
97
|
-
session.hideWidget(model);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
else {
|
|
101
|
-
setTrackErrorMessage('Failed to add track.\nThe configuration of this file is not currently supported.');
|
|
40
|
+
return _jsx(Typography, { children: "Unknown step" });
|
|
102
41
|
}
|
|
103
42
|
}
|
|
104
43
|
function isNextDisabled() {
|
|
@@ -111,18 +50,20 @@ const DefaultAddTrackWorkflow = observer(function ({ model, }) {
|
|
|
111
50
|
return true;
|
|
112
51
|
}
|
|
113
52
|
}
|
|
114
|
-
return (
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
53
|
+
return (_jsx("div", { className: classes.root, children: _jsx(Stepper, { className: classes.stepper, activeStep: activeStep, orientation: "vertical", children: steps.map((label, idx) => (_jsxs(Step, { children: [_jsx(StepLabel, { children: label }), _jsxs(StepContent, { children: [getStepContent(idx), _jsxs("div", { className: classes.actionsContainer, children: [_jsx(Button, { disabled: activeStep === 0, className: classes.button, onClick: () => {
|
|
54
|
+
setActiveStep(activeStep - 1);
|
|
55
|
+
}, children: "Back" }), _jsx(Button, { disabled: isNextDisabled(), variant: "contained", color: "primary", onClick: () => {
|
|
56
|
+
if (activeStep !== steps.length - 1) {
|
|
57
|
+
setActiveStep(activeStep + 1);
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
try {
|
|
61
|
+
doSubmit({ model });
|
|
62
|
+
}
|
|
63
|
+
catch (e) {
|
|
64
|
+
getSession(model).notifyError(`${e}`, e);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}, className: classes.button, "data-testid": "addTrackNextButton", children: activeStep === steps.length - 1 ? 'Add' : 'Next' })] })] })] }, label))) }) }));
|
|
127
68
|
});
|
|
128
69
|
export default DefaultAddTrackWorkflow;
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
1
|
import type { AddTrackModel } from '../model';
|
|
3
2
|
declare const PasteConfigAddTrackWorkflow: ({ model, }: {
|
|
4
3
|
model: AddTrackModel;
|
|
5
|
-
}) =>
|
|
4
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
6
5
|
export default PasteConfigAddTrackWorkflow;
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState } from 'react';
|
|
2
3
|
import { ErrorMessage } from '@jbrowse/core/ui';
|
|
3
4
|
import { getSession, isSessionModelWithWidgets, isSessionWithAddTracks, } from '@jbrowse/core/util';
|
|
4
5
|
import { Button, TextField } from '@mui/material';
|
|
6
|
+
import { transaction } from 'mobx';
|
|
5
7
|
import { observer } from 'mobx-react';
|
|
6
8
|
import { makeStyles } from 'tss-react/mui';
|
|
7
9
|
const useStyles = makeStyles()({
|
|
@@ -18,31 +20,32 @@ const PasteConfigAddTrackWorkflow = observer(function ({ model, }) {
|
|
|
18
20
|
const { classes } = useStyles();
|
|
19
21
|
const [val, setVal] = useState('');
|
|
20
22
|
const [error, setError] = useState();
|
|
21
|
-
return (
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
23
|
+
return (_jsxs("div", { children: [error ? _jsx(ErrorMessage, { error: error }) : null, _jsx(TextField, { multiline: true, rows: 10, value: val, placeholder: "Paste track config or array of track configs in JSON format", variant: "outlined", className: classes.textbox, onChange: event => {
|
|
24
|
+
setVal(event.target.value);
|
|
25
|
+
} }), _jsx(Button, { variant: "contained", className: classes.submit, onClick: () => {
|
|
26
|
+
try {
|
|
27
|
+
setError(undefined);
|
|
28
|
+
const session = getSession(model);
|
|
29
|
+
const conf = JSON.parse(val);
|
|
30
|
+
const confs = Array.isArray(conf) ? conf : [conf];
|
|
31
|
+
if (isSessionWithAddTracks(session) &&
|
|
32
|
+
isSessionModelWithWidgets(session)) {
|
|
33
|
+
transaction(() => {
|
|
34
|
+
confs.forEach(c => {
|
|
35
|
+
session.addTrackConf(c);
|
|
36
|
+
});
|
|
37
|
+
confs.forEach(c => {
|
|
38
|
+
model.view.showTrack(c.trackId);
|
|
39
|
+
});
|
|
40
|
+
model.clearData();
|
|
41
|
+
});
|
|
42
|
+
session.hideWidget(model);
|
|
43
|
+
}
|
|
40
44
|
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
}
|
|
46
|
-
} }, "Submit")));
|
|
45
|
+
catch (e) {
|
|
46
|
+
console.error(e);
|
|
47
|
+
setError(e);
|
|
48
|
+
}
|
|
49
|
+
}, children: "Submit" })] }));
|
|
47
50
|
});
|
|
48
51
|
export default PasteConfigAddTrackWorkflow;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useState } from 'react';
|
|
2
3
|
import AddIcon from '@mui/icons-material/Add';
|
|
3
4
|
import DeleteIcon from '@mui/icons-material/Delete';
|
|
4
5
|
import { Card, CardContent, IconButton, InputAdornment, InputLabel, List, ListItem, Paper, TextField, } from '@mui/material';
|
|
@@ -33,51 +34,38 @@ const TextIndexingConfig = observer(function ({ model, }) {
|
|
|
33
34
|
useEffect(() => {
|
|
34
35
|
model.setTextIndexingConf({ attributes, exclude });
|
|
35
36
|
}, [model, attributes, exclude]);
|
|
36
|
-
return (
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
React.createElement(IconButton, { onClick: () => {
|
|
70
|
-
if (index === 0) {
|
|
71
|
-
setAttributes([...attributes, value1]);
|
|
72
|
-
setValue1('');
|
|
73
|
-
}
|
|
74
|
-
else {
|
|
75
|
-
setExclude([...exclude, value2]);
|
|
76
|
-
setValue2('');
|
|
77
|
-
}
|
|
78
|
-
}, disabled: index === 0 ? value1 === '' : value2 === '', "data-testid": "stringArrayAdd-Feat" },
|
|
79
|
-
React.createElement(AddIcon, null)))),
|
|
80
|
-
},
|
|
81
|
-
} })))))))));
|
|
37
|
+
return (_jsxs(Paper, { className: classes.paper, children: [_jsx(InputLabel, { children: "Indexing configuration" }), sections.map((section, index) => (_jsx(Card, { raised: true, className: classes.card, children: _jsxs(CardContent, { children: [_jsx(InputLabel, { children: section.label }), _jsxs(List, { disablePadding: true, children: [section.values.map((val, idx) => (_jsx(ListItem, { disableGutters: true, children: _jsx(TextField, { value: val, slotProps: {
|
|
38
|
+
input: {
|
|
39
|
+
endAdornment: (_jsx(InputAdornment, { position: "end", children: _jsx(IconButton, { onClick: () => {
|
|
40
|
+
const newAttr = section.values.filter((_, i) => i !== idx);
|
|
41
|
+
if (index === 0) {
|
|
42
|
+
setAttributes(newAttr);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
setExclude(newAttr);
|
|
46
|
+
}
|
|
47
|
+
}, children: _jsx(DeleteIcon, {}) }) })),
|
|
48
|
+
},
|
|
49
|
+
} }) }, `${val}-${idx}`))), _jsx(ListItem, { disableGutters: true, children: _jsx(TextField, { value: index === 0 ? value1 : value2, placeholder: "add new", onChange: event => {
|
|
50
|
+
if (index === 0) {
|
|
51
|
+
setValue1(event.target.value);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
setValue2(event.target.value);
|
|
55
|
+
}
|
|
56
|
+
}, slotProps: {
|
|
57
|
+
input: {
|
|
58
|
+
endAdornment: (_jsx(InputAdornment, { position: "end", children: _jsx(IconButton, { onClick: () => {
|
|
59
|
+
if (index === 0) {
|
|
60
|
+
setAttributes([...attributes, value1]);
|
|
61
|
+
setValue1('');
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
setExclude([...exclude, value2]);
|
|
65
|
+
setValue2('');
|
|
66
|
+
}
|
|
67
|
+
}, disabled: index === 0 ? value1 === '' : value2 === '', "data-testid": "stringArrayAdd-Feat", children: _jsx(AddIcon, {}) }) })),
|
|
68
|
+
},
|
|
69
|
+
} }) })] })] }) }, section.label)))] }));
|
|
82
70
|
});
|
|
83
71
|
export default TextIndexingConfig;
|
|
@@ -1,42 +1,24 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
2
|
import { getEnv } from '@jbrowse/core/util';
|
|
3
3
|
import { ListSubheader, MenuItem, TextField } from '@mui/material';
|
|
4
4
|
import { observer } from 'mobx-react';
|
|
5
|
-
import {
|
|
6
|
-
const useStyles = makeStyles()(theme => ({
|
|
7
|
-
spacing: {
|
|
8
|
-
marginBottom: theme.spacing(3),
|
|
9
|
-
},
|
|
10
|
-
}));
|
|
11
|
-
function categorizeAdapters(adaptersList) {
|
|
12
|
-
const map = {};
|
|
13
|
-
adaptersList.forEach(adapter => {
|
|
14
|
-
var _a;
|
|
15
|
-
const key = ((_a = adapter.adapterMetadata) === null || _a === void 0 ? void 0 : _a.category) || 'Default';
|
|
16
|
-
if (!map[key]) {
|
|
17
|
-
map[key] = [];
|
|
18
|
-
}
|
|
19
|
-
map[key].push(adapter);
|
|
20
|
-
});
|
|
21
|
-
return map;
|
|
22
|
-
}
|
|
5
|
+
import { categorizeAdapters } from './util';
|
|
23
6
|
const TrackAdapterSelector = observer(({ model }) => {
|
|
24
|
-
const { classes } = useStyles();
|
|
25
7
|
const { trackAdapter } = model;
|
|
26
8
|
const { pluginManager } = getEnv(model);
|
|
27
|
-
return (
|
|
9
|
+
return (_jsx(TextField, { value: (trackAdapter === null || trackAdapter === void 0 ? void 0 : trackAdapter.type) !== 'UNKNOWN' ? trackAdapter === null || trackAdapter === void 0 ? void 0 : trackAdapter.type : '', label: "Adapter type", variant: "outlined", select: true, fullWidth: true, onChange: event => {
|
|
28
10
|
model.setAdapterHint(event.target.value);
|
|
29
11
|
}, slotProps: {
|
|
30
12
|
select: {
|
|
31
|
-
SelectDisplayProps: {
|
|
13
|
+
SelectDisplayProps: {
|
|
14
|
+
'data-testid': 'adapterTypeSelect',
|
|
15
|
+
},
|
|
32
16
|
},
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
];
|
|
40
|
-
})));
|
|
17
|
+
}, children: Object.entries(categorizeAdapters(pluginManager
|
|
18
|
+
.getAdapterElements()
|
|
19
|
+
.filter(e => { var _a; return !((_a = e.adapterMetadata) === null || _a === void 0 ? void 0 : _a.hiddenFromGUI); }))).map(([key, val]) => [
|
|
20
|
+
_jsx(ListSubheader, { children: key }, key),
|
|
21
|
+
val.map(elt => (_jsx(MenuItem, { value: elt.name, children: elt.displayName }, elt.name))),
|
|
22
|
+
]) }));
|
|
41
23
|
});
|
|
42
24
|
export default TrackAdapterSelector;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { FileSelector } from '@jbrowse/core/ui';
|
|
3
3
|
import { Paper } from '@mui/material';
|
|
4
4
|
import { observer } from 'mobx-react';
|
|
@@ -15,9 +15,6 @@ const useStyles = makeStyles()(theme => ({
|
|
|
15
15
|
const TrackSourceSelect = observer(function ({ model, }) {
|
|
16
16
|
const { classes } = useStyles();
|
|
17
17
|
const rootModel = getRoot(model);
|
|
18
|
-
return (
|
|
19
|
-
React.createElement(FileSelector, { name: "Main file", description: "", location: model.trackData, setLocation: model.setTrackData, setName: model.setTrackName, rootModel: rootModel }),
|
|
20
|
-
React.createElement("div", { className: classes.spacer }),
|
|
21
|
-
React.createElement(FileSelector, { name: "Index file", description: "(Optional) The URL of the index file is automatically inferred from the URL of the main file if it is not supplied.", location: model.indexTrackData, setLocation: model.setIndexTrackData, setName: model.setTrackName, rootModel: rootModel })));
|
|
18
|
+
return (_jsxs(Paper, { className: classes.paper, children: [_jsx(FileSelector, { name: "Main file", description: "", location: model.trackData, setLocation: model.setTrackData, setName: model.setTrackName, rootModel: rootModel }), _jsx("div", { className: classes.spacer }), _jsx(FileSelector, { name: "Index file", description: "(Optional) The URL of the index file is automatically inferred from the URL of the main file if it is not supplied.", location: model.indexTrackData, setLocation: model.setIndexTrackData, setName: model.setTrackName, rootModel: rootModel })] }));
|
|
22
19
|
});
|
|
23
20
|
export default TrackSourceSelect;
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
1
|
import type { AddTrackModel } from '../model';
|
|
3
|
-
declare const TrackTypeSelector: ({ model }: {
|
|
2
|
+
declare const TrackTypeSelector: ({ model, }: {
|
|
4
3
|
model: AddTrackModel;
|
|
5
|
-
}) =>
|
|
4
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
6
5
|
export default TrackTypeSelector;
|