@jbrowse/plugin-data-management 2.3.3 → 2.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AddConnectionWidget/components/ConnectionTypeSelect.js +1 -1
- package/dist/AddConnectionWidget/components/ConnectionTypeSelect.js.map +1 -1
- package/dist/AddTrackWidget/components/DefaultAddTrackWorkflow.js +1 -4
- package/dist/AddTrackWidget/components/DefaultAddTrackWorkflow.js.map +1 -1
- package/dist/AddTrackWidget/components/TextIndexingConfig.js +2 -2
- package/dist/AddTrackWidget/components/TextIndexingConfig.js.map +1 -1
- package/dist/AddTrackWidget/components/TrackSourceSelect.js +1 -4
- package/dist/AddTrackWidget/components/TrackSourceSelect.js.map +1 -1
- package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalFab.d.ts +6 -0
- package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalFab.js +71 -0
- package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalFab.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js +10 -104
- package/dist/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js.map +1 -1
- package/dist/HierarchicalTrackSelectorWidget/components/ShoppingCart.d.ts +6 -0
- package/dist/HierarchicalTrackSelectorWidget/components/ShoppingCart.js +70 -0
- package/dist/HierarchicalTrackSelectorWidget/components/ShoppingCart.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/CloseConnectionDialog.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/DeleteConnectionDialog.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/ManageConnectionsDialog.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/dialogs/ToggleConnectionsDialog.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetFilters.d.ts +13 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetFilters.js +99 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetFilters.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.d.ts +8 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.js +18 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.d.ts +11 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.js +71 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.d.ts +12 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.js +211 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/util.d.ts +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/util.js +10 -0
- package/dist/HierarchicalTrackSelectorWidget/components/faceted/util.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.d.ts +7 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.js +136 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/{Header.d.ts → tree/HierarchicalHeader.d.ts} +2 -3
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HierarchicalHeader.js +65 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HierarchicalHeader.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.d.ts +8 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.js +91 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackCategory.d.ts +7 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackCategory.js +89 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackCategory.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackLabel.d.ts +11 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackLabel.js +86 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackLabel.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackListNode.d.ts +10 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackListNode.js +54 -0
- package/dist/HierarchicalTrackSelectorWidget/components/tree/TrackListNode.js.map +1 -0
- package/dist/HierarchicalTrackSelectorWidget/components/util.d.ts +17 -1
- package/dist/HierarchicalTrackSelectorWidget/components/util.js +16 -1
- package/dist/HierarchicalTrackSelectorWidget/components/util.js.map +1 -1
- package/dist/HierarchicalTrackSelectorWidget/model.d.ts +4 -1
- package/dist/HierarchicalTrackSelectorWidget/model.js +12 -8
- package/dist/HierarchicalTrackSelectorWidget/model.js.map +1 -1
- package/dist/PluginStoreWidget/components/InstalledPluginsList.js.map +1 -1
- package/dist/PluginStoreWidget/components/PluginCard.d.ts +2 -3
- package/dist/PluginStoreWidget/components/PluginCard.js +5 -6
- package/dist/PluginStoreWidget/components/PluginCard.js.map +1 -1
- package/dist/PluginStoreWidget/components/PluginStoreWidget.js +3 -3
- package/dist/PluginStoreWidget/components/PluginStoreWidget.js.map +1 -1
- package/dist/ucsc-trackhub/ucscTrackHub.js.map +1 -1
- package/esm/AddConnectionWidget/components/ConnectionTypeSelect.js +1 -1
- package/esm/AddConnectionWidget/components/ConnectionTypeSelect.js.map +1 -1
- package/esm/AddTrackWidget/components/DefaultAddTrackWorkflow.js +1 -4
- package/esm/AddTrackWidget/components/DefaultAddTrackWorkflow.js.map +1 -1
- package/esm/AddTrackWidget/components/TextIndexingConfig.js +2 -2
- package/esm/AddTrackWidget/components/TextIndexingConfig.js.map +1 -1
- package/esm/AddTrackWidget/components/TrackSourceSelect.js +1 -4
- package/esm/AddTrackWidget/components/TrackSourceSelect.js.map +1 -1
- package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalFab.d.ts +6 -0
- package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalFab.js +43 -0
- package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalFab.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js +9 -103
- package/esm/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.js.map +1 -1
- package/esm/HierarchicalTrackSelectorWidget/components/ShoppingCart.d.ts +6 -0
- package/esm/HierarchicalTrackSelectorWidget/components/ShoppingCart.js +42 -0
- package/esm/HierarchicalTrackSelectorWidget/components/ShoppingCart.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/CloseConnectionDialog.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/DeleteConnectionDialog.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/ManageConnectionsDialog.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/dialogs/ToggleConnectionsDialog.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetFilters.d.ts +13 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetFilters.js +70 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetFilters.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.d.ts +8 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.js +13 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.d.ts +11 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.js +42 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.d.ts +12 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.js +183 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/util.d.ts +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/util.js +6 -0
- package/esm/HierarchicalTrackSelectorWidget/components/faceted/util.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.d.ts +7 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.js +108 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/{Header.d.ts → tree/HierarchicalHeader.d.ts} +2 -3
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HierarchicalHeader.js +37 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HierarchicalHeader.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.d.ts +8 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.js +63 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackCategory.d.ts +7 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackCategory.js +60 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackCategory.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackLabel.d.ts +11 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackLabel.js +57 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackLabel.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackListNode.d.ts +10 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackListNode.js +48 -0
- package/esm/HierarchicalTrackSelectorWidget/components/tree/TrackListNode.js.map +1 -0
- package/esm/HierarchicalTrackSelectorWidget/components/util.d.ts +17 -1
- package/esm/HierarchicalTrackSelectorWidget/components/util.js +13 -0
- package/esm/HierarchicalTrackSelectorWidget/components/util.js.map +1 -1
- package/esm/HierarchicalTrackSelectorWidget/model.d.ts +4 -1
- package/esm/HierarchicalTrackSelectorWidget/model.js +10 -7
- package/esm/HierarchicalTrackSelectorWidget/model.js.map +1 -1
- package/esm/PluginStoreWidget/components/InstalledPluginsList.js.map +1 -1
- package/esm/PluginStoreWidget/components/PluginCard.d.ts +2 -3
- package/esm/PluginStoreWidget/components/PluginCard.js +5 -6
- package/esm/PluginStoreWidget/components/PluginCard.js.map +1 -1
- package/esm/PluginStoreWidget/components/PluginStoreWidget.js +3 -3
- package/esm/PluginStoreWidget/components/PluginStoreWidget.js.map +1 -1
- package/esm/ucsc-trackhub/ucscTrackHub.js.map +1 -1
- package/package.json +3 -2
- package/src/AddConnectionWidget/components/ConnectionTypeSelect.tsx +0 -1
- package/src/AddConnectionWidget/components/__snapshots__/AddConnectionWidget.test.tsx.snap +1 -1
- package/src/AddTrackWidget/components/DefaultAddTrackWorkflow.tsx +1 -4
- package/src/AddTrackWidget/components/TextIndexingConfig.tsx +0 -2
- package/src/AddTrackWidget/components/TrackSourceSelect.tsx +3 -5
- package/src/HierarchicalTrackSelectorWidget/components/HierarchicalFab.tsx +94 -0
- package/src/HierarchicalTrackSelectorWidget/components/HierarchicalTrackSelector.tsx +47 -228
- package/src/HierarchicalTrackSelectorWidget/components/ShoppingCart.tsx +73 -0
- package/src/HierarchicalTrackSelectorWidget/components/__snapshots__/HierarchicalTrackSelector.test.tsx.snap +24 -42
- package/src/HierarchicalTrackSelectorWidget/components/faceted/FacetFilters.tsx +138 -0
- package/src/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.tsx +29 -0
- package/src/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.tsx +86 -0
- package/src/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.tsx +339 -0
- package/src/HierarchicalTrackSelectorWidget/components/faceted/util.ts +5 -0
- package/src/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.tsx +197 -0
- package/src/HierarchicalTrackSelectorWidget/components/tree/HierarchicalHeader.tsx +85 -0
- package/src/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.tsx +101 -0
- package/src/HierarchicalTrackSelectorWidget/components/tree/TrackCategory.tsx +92 -0
- package/src/HierarchicalTrackSelectorWidget/components/tree/TrackLabel.tsx +106 -0
- package/src/HierarchicalTrackSelectorWidget/components/tree/TrackListNode.tsx +84 -0
- package/src/HierarchicalTrackSelectorWidget/components/util.ts +31 -1
- package/src/HierarchicalTrackSelectorWidget/model.ts +12 -9
- package/src/PluginStoreWidget/components/InstalledPluginsList.tsx +1 -1
- package/src/PluginStoreWidget/components/PluginCard.tsx +6 -7
- package/src/PluginStoreWidget/components/PluginStoreWidget.tsx +3 -7
- package/src/PluginStoreWidget/components/__snapshots__/PluginStoreWidget.test.tsx.snap +1 -1
- package/src/ucsc-trackhub/ucscTrackHub.ts +1 -1
- package/dist/HierarchicalTrackSelectorWidget/components/CloseConnectionDialog.js.map +0 -1
- package/dist/HierarchicalTrackSelectorWidget/components/DeleteConnectionDialog.js.map +0 -1
- package/dist/HierarchicalTrackSelectorWidget/components/Header.js +0 -174
- package/dist/HierarchicalTrackSelectorWidget/components/Header.js.map +0 -1
- package/dist/HierarchicalTrackSelectorWidget/components/ManageConnectionsDialog.js.map +0 -1
- package/dist/HierarchicalTrackSelectorWidget/components/Node.d.ts +0 -29
- package/dist/HierarchicalTrackSelectorWidget/components/Node.js +0 -173
- package/dist/HierarchicalTrackSelectorWidget/components/Node.js.map +0 -1
- package/dist/HierarchicalTrackSelectorWidget/components/ToggleConnectionsDialog.js.map +0 -1
- package/esm/HierarchicalTrackSelectorWidget/components/CloseConnectionDialog.js.map +0 -1
- package/esm/HierarchicalTrackSelectorWidget/components/DeleteConnectionDialog.js.map +0 -1
- package/esm/HierarchicalTrackSelectorWidget/components/Header.js +0 -146
- package/esm/HierarchicalTrackSelectorWidget/components/Header.js.map +0 -1
- package/esm/HierarchicalTrackSelectorWidget/components/ManageConnectionsDialog.js.map +0 -1
- package/esm/HierarchicalTrackSelectorWidget/components/Node.d.ts +0 -29
- package/esm/HierarchicalTrackSelectorWidget/components/Node.js +0 -144
- package/esm/HierarchicalTrackSelectorWidget/components/Node.js.map +0 -1
- package/esm/HierarchicalTrackSelectorWidget/components/ToggleConnectionsDialog.js.map +0 -1
- package/src/HierarchicalTrackSelectorWidget/components/Header.tsx +0 -286
- package/src/HierarchicalTrackSelectorWidget/components/Node.tsx +0 -282
- /package/dist/HierarchicalTrackSelectorWidget/components/{CloseConnectionDialog.d.ts → dialogs/CloseConnectionDialog.d.ts} +0 -0
- /package/dist/HierarchicalTrackSelectorWidget/components/{CloseConnectionDialog.js → dialogs/CloseConnectionDialog.js} +0 -0
- /package/dist/HierarchicalTrackSelectorWidget/components/{DeleteConnectionDialog.d.ts → dialogs/DeleteConnectionDialog.d.ts} +0 -0
- /package/dist/HierarchicalTrackSelectorWidget/components/{DeleteConnectionDialog.js → dialogs/DeleteConnectionDialog.js} +0 -0
- /package/dist/HierarchicalTrackSelectorWidget/components/{ManageConnectionsDialog.d.ts → dialogs/ManageConnectionsDialog.d.ts} +0 -0
- /package/dist/HierarchicalTrackSelectorWidget/components/{ManageConnectionsDialog.js → dialogs/ManageConnectionsDialog.js} +0 -0
- /package/dist/HierarchicalTrackSelectorWidget/components/{ToggleConnectionsDialog.d.ts → dialogs/ToggleConnectionsDialog.d.ts} +0 -0
- /package/dist/HierarchicalTrackSelectorWidget/components/{ToggleConnectionsDialog.js → dialogs/ToggleConnectionsDialog.js} +0 -0
- /package/esm/HierarchicalTrackSelectorWidget/components/{CloseConnectionDialog.d.ts → dialogs/CloseConnectionDialog.d.ts} +0 -0
- /package/esm/HierarchicalTrackSelectorWidget/components/{CloseConnectionDialog.js → dialogs/CloseConnectionDialog.js} +0 -0
- /package/esm/HierarchicalTrackSelectorWidget/components/{DeleteConnectionDialog.d.ts → dialogs/DeleteConnectionDialog.d.ts} +0 -0
- /package/esm/HierarchicalTrackSelectorWidget/components/{DeleteConnectionDialog.js → dialogs/DeleteConnectionDialog.js} +0 -0
- /package/esm/HierarchicalTrackSelectorWidget/components/{ManageConnectionsDialog.d.ts → dialogs/ManageConnectionsDialog.d.ts} +0 -0
- /package/esm/HierarchicalTrackSelectorWidget/components/{ManageConnectionsDialog.js → dialogs/ManageConnectionsDialog.js} +0 -0
- /package/esm/HierarchicalTrackSelectorWidget/components/{ToggleConnectionsDialog.d.ts → dialogs/ToggleConnectionsDialog.d.ts} +0 -0
- /package/esm/HierarchicalTrackSelectorWidget/components/{ToggleConnectionsDialog.js → dialogs/ToggleConnectionsDialog.js} +0 -0
- /package/src/HierarchicalTrackSelectorWidget/components/{CloseConnectionDialog.tsx → dialogs/CloseConnectionDialog.tsx} +0 -0
- /package/src/HierarchicalTrackSelectorWidget/components/{DeleteConnectionDialog.tsx → dialogs/DeleteConnectionDialog.tsx} +0 -0
- /package/src/HierarchicalTrackSelectorWidget/components/{ManageConnectionsDialog.tsx → dialogs/ManageConnectionsDialog.tsx} +0 -0
- /package/src/HierarchicalTrackSelectorWidget/components/{ToggleConnectionsDialog.tsx → dialogs/ToggleConnectionsDialog.tsx} +0 -0
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { HierarchicalTrackSelectorModel } from '../../model';
|
|
3
|
+
declare function FacetedDlg(props: {
|
|
4
|
+
handleClose: () => void;
|
|
5
|
+
model: HierarchicalTrackSelectorModel;
|
|
6
|
+
}): JSX.Element;
|
|
7
|
+
declare const _default: typeof FacetedDlg;
|
|
8
|
+
export default _default;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { DialogContent } from '@mui/material';
|
|
3
|
+
import { Dialog } from '@jbrowse/core/ui';
|
|
4
|
+
import { observer } from 'mobx-react';
|
|
5
|
+
import FacetedSelector from './FacetedSelector';
|
|
6
|
+
function FacetedDlg(props) {
|
|
7
|
+
const { handleClose } = props;
|
|
8
|
+
return (React.createElement(Dialog, { open: true, onClose: handleClose, maxWidth: "xl", title: "Faceted track selector" },
|
|
9
|
+
React.createElement(DialogContent, null,
|
|
10
|
+
React.createElement(FacetedSelector, { ...props }))));
|
|
11
|
+
}
|
|
12
|
+
export default observer(FacetedDlg);
|
|
13
|
+
//# sourceMappingURL=FacetedDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FacetedDialog.js","sourceRoot":"","sources":["../../../../src/HierarchicalTrackSelectorWidget/components/faceted/FacetedDialog.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAA;AAC7C,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAIrC,OAAO,eAAe,MAAM,mBAAmB,CAAA;AAE/C,SAAS,UAAU,CAAC,KAGnB;IACC,MAAM,EAAE,WAAW,EAAE,GAAG,KAAK,CAAA;IAC7B,OAAO,CACL,oBAAC,MAAM,IACL,IAAI,QACJ,OAAO,EAAE,WAAW,EACpB,QAAQ,EAAC,IAAI,EACb,KAAK,EAAC,wBAAwB;QAE9B,oBAAC,aAAa;YACZ,oBAAC,eAAe,OAAK,KAAK,GAAI,CAChB,CACT,CACV,CAAA;AACH,CAAC;AAED,eAAe,QAAQ,CAAC,UAAU,CAAC,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { HierarchicalTrackSelectorModel } from '../../model';
|
|
3
|
+
export default function FacetedHeader({ setFilterText, setUseShoppingCart, setHideSparse, hideSparse, useShoppingCart, filterText, model, }: {
|
|
4
|
+
setFilterText: (arg: string) => void;
|
|
5
|
+
setUseShoppingCart: (arg: boolean) => void;
|
|
6
|
+
setHideSparse: (arg: boolean) => void;
|
|
7
|
+
filterText: string;
|
|
8
|
+
useShoppingCart: boolean;
|
|
9
|
+
hideSparse: boolean;
|
|
10
|
+
model: HierarchicalTrackSelectorModel;
|
|
11
|
+
}): JSX.Element;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { Grid, IconButton, InputAdornment, TextField } from '@mui/material';
|
|
3
|
+
import { Menu } from '@jbrowse/core/ui';
|
|
4
|
+
// icons
|
|
5
|
+
import ClearIcon from '@mui/icons-material/Clear';
|
|
6
|
+
import MoreVert from '@mui/icons-material/MoreVert';
|
|
7
|
+
// locals
|
|
8
|
+
import ShoppingCart from '../ShoppingCart';
|
|
9
|
+
export default function FacetedHeader({ setFilterText, setUseShoppingCart, setHideSparse, hideSparse, useShoppingCart, filterText, model, }) {
|
|
10
|
+
const [anchorEl, setAnchorEl] = useState(null);
|
|
11
|
+
return (React.createElement(React.Fragment, null,
|
|
12
|
+
React.createElement(Grid, { container: true, spacing: 4, alignItems: "center" },
|
|
13
|
+
React.createElement(Grid, { item: true },
|
|
14
|
+
React.createElement(TextField, { label: "Search...", value: filterText, onChange: event => setFilterText(event.target.value), InputProps: {
|
|
15
|
+
endAdornment: (React.createElement(InputAdornment, { position: "end" },
|
|
16
|
+
React.createElement(IconButton, { onClick: () => setFilterText('') },
|
|
17
|
+
React.createElement(ClearIcon, null)))),
|
|
18
|
+
} })),
|
|
19
|
+
React.createElement(Grid, { item: true },
|
|
20
|
+
React.createElement(IconButton, { onClick: event => setAnchorEl(event.currentTarget) },
|
|
21
|
+
React.createElement(MoreVert, null))),
|
|
22
|
+
React.createElement(Grid, { item: true },
|
|
23
|
+
React.createElement(ShoppingCart, { model: model }))),
|
|
24
|
+
React.createElement(Menu, { anchorEl: anchorEl, open: !!anchorEl, onClose: () => setAnchorEl(null), onMenuItemClick: (_event, callback) => {
|
|
25
|
+
callback();
|
|
26
|
+
setAnchorEl(null);
|
|
27
|
+
}, menuItems: [
|
|
28
|
+
{
|
|
29
|
+
label: 'Add tracks to selection instead of turning them on/off',
|
|
30
|
+
onClick: () => setUseShoppingCart(!useShoppingCart),
|
|
31
|
+
type: 'checkbox',
|
|
32
|
+
checked: useShoppingCart,
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
label: 'Hide sparse metadata columns',
|
|
36
|
+
onClick: () => setHideSparse(!hideSparse),
|
|
37
|
+
checked: hideSparse,
|
|
38
|
+
type: 'checkbox',
|
|
39
|
+
},
|
|
40
|
+
] })));
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=FacetedHeader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FacetedHeader.js","sourceRoot":"","sources":["../../../../src/HierarchicalTrackSelectorWidget/components/faceted/FacetedHeader.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACvC,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAC3E,OAAO,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAA;AAEvC,QAAQ;AACR,OAAO,SAAS,MAAM,2BAA2B,CAAA;AACjD,OAAO,QAAQ,MAAM,8BAA8B,CAAA;AAEnD,SAAS;AACT,OAAO,YAAY,MAAM,iBAAiB,CAAA;AAG1C,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,EACpC,aAAa,EACb,kBAAkB,EAClB,aAAa,EACb,UAAU,EACV,eAAe,EACf,UAAU,EACV,KAAK,GASN;IACC,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAqB,IAAI,CAAC,CAAA;IAElE,OAAO,CACL;QACE,oBAAC,IAAI,IAAC,SAAS,QAAC,OAAO,EAAE,CAAC,EAAE,UAAU,EAAC,QAAQ;YAC7C,oBAAC,IAAI,IAAC,IAAI;gBACR,oBAAC,SAAS,IACR,KAAK,EAAC,WAAW,EACjB,KAAK,EAAE,UAAU,EACjB,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,EACpD,UAAU,EAAE;wBACV,YAAY,EAAE,CACZ,oBAAC,cAAc,IAAC,QAAQ,EAAC,KAAK;4BAC5B,oBAAC,UAAU,IAAC,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC;gCAC1C,oBAAC,SAAS,OAAG,CACF,CACE,CAClB;qBACF,GACD,CACG;YAEP,oBAAC,IAAI,IAAC,IAAI;gBACR,oBAAC,UAAU,IAAC,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,aAAa,CAAC;oBAC5D,oBAAC,QAAQ,OAAG,CACD,CACR;YACP,oBAAC,IAAI,IAAC,IAAI;gBACR,oBAAC,YAAY,IAAC,KAAK,EAAE,KAAK,GAAI,CACzB,CACF;QACP,oBAAC,IAAI,IACH,QAAQ,EAAE,QAAQ,EAClB,IAAI,EAAE,CAAC,CAAC,QAAQ,EAChB,OAAO,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,EAChC,eAAe,EAAE,CAAC,MAAM,EAAE,QAAQ,EAAE,EAAE;gBACpC,QAAQ,EAAE,CAAA;gBACV,WAAW,CAAC,IAAI,CAAC,CAAA;YACnB,CAAC,EACD,SAAS,EAAE;gBACT;oBACE,KAAK,EAAE,wDAAwD;oBAC/D,OAAO,EAAE,GAAG,EAAE,CAAC,kBAAkB,CAAC,CAAC,eAAe,CAAC;oBACnD,IAAI,EAAE,UAAU;oBAChB,OAAO,EAAE,eAAe;iBACzB;gBACD;oBACE,KAAK,EAAE,8BAA8B;oBACrC,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,CAAC,UAAU,CAAC;oBACzC,OAAO,EAAE,UAAU;oBACnB,IAAI,EAAE,UAAU;iBACjB;aACF,GACD,CACD,CACJ,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { AnyConfigurationModel } from '@jbrowse/core/configuration';
|
|
3
|
+
import { HierarchicalTrackSelectorModel } from '../../model';
|
|
4
|
+
export interface InfoArgs {
|
|
5
|
+
target: HTMLElement;
|
|
6
|
+
id: string;
|
|
7
|
+
conf: AnyConfigurationModel;
|
|
8
|
+
}
|
|
9
|
+
declare const _default: ({ model, }: {
|
|
10
|
+
model: HierarchicalTrackSelectorModel;
|
|
11
|
+
}) => JSX.Element;
|
|
12
|
+
export default _default;
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import React, { useMemo, useState, useEffect, useReducer } from 'react';
|
|
2
|
+
import { IconButton } from '@mui/material';
|
|
3
|
+
import { transaction } from 'mobx';
|
|
4
|
+
import { observer } from 'mobx-react';
|
|
5
|
+
import { getRoot, resolveIdentifier } from 'mobx-state-tree';
|
|
6
|
+
import { DataGrid } from '@mui/x-data-grid';
|
|
7
|
+
// jbrowse
|
|
8
|
+
import { getTrackName } from '@jbrowse/core/util/tracks';
|
|
9
|
+
import { ResizeHandle, SanitizedHTML } from '@jbrowse/core/ui';
|
|
10
|
+
import JBrowseMenu from '@jbrowse/core/ui/Menu';
|
|
11
|
+
import ResizeBar, { useResizeBar } from '@jbrowse/core/ui/ResizeBar';
|
|
12
|
+
import { getEnv, getSession, measureGridWidth, useDebounce, } from '@jbrowse/core/util';
|
|
13
|
+
import { readConfObject, } from '@jbrowse/core/configuration';
|
|
14
|
+
// icons
|
|
15
|
+
import MoreHoriz from '@mui/icons-material/MoreHoriz';
|
|
16
|
+
// locals
|
|
17
|
+
import { matches } from '../../model';
|
|
18
|
+
import FacetedHeader from './FacetedHeader';
|
|
19
|
+
import FacetFilters from './FacetFilters';
|
|
20
|
+
import { getRootKeys } from './util';
|
|
21
|
+
const nonMetadataKeys = ['category', 'adapter', 'description'];
|
|
22
|
+
const frac = 0.75;
|
|
23
|
+
export default observer(function FacetedSelector({ model, }) {
|
|
24
|
+
var _a;
|
|
25
|
+
const { assemblyNames, view, selection } = model;
|
|
26
|
+
const { pluginManager } = getEnv(model);
|
|
27
|
+
const { ref, scrollLeft } = useResizeBar();
|
|
28
|
+
const [filterText, setFilterText] = useState('');
|
|
29
|
+
const [info, setInfo] = useState();
|
|
30
|
+
const [useShoppingCart, setUseShoppingCart] = useState(false);
|
|
31
|
+
const [hideSparse, setHideSparse] = useState(true);
|
|
32
|
+
const [panelWidth, setPanelWidth] = useState(400);
|
|
33
|
+
const assemblyName = assemblyNames[0];
|
|
34
|
+
const session = getSession(model);
|
|
35
|
+
const filterDebounced = useDebounce(filterText, 400);
|
|
36
|
+
const [filters, dispatch] = useReducer((state, update) => {
|
|
37
|
+
return { ...state, [update.key]: update.val };
|
|
38
|
+
}, {});
|
|
39
|
+
const rows = useMemo(() => {
|
|
40
|
+
// metadata is spread onto the object for easier access and sorting
|
|
41
|
+
// by the mui data grid (it's unable to sort by nested objects)
|
|
42
|
+
return model
|
|
43
|
+
.trackConfigurations(assemblyName)
|
|
44
|
+
.filter(conf => matches(filterDebounced, conf, session))
|
|
45
|
+
.map(track => {
|
|
46
|
+
var _a, _b;
|
|
47
|
+
const metadata = readConfObject(track, 'metadata');
|
|
48
|
+
return {
|
|
49
|
+
id: track.trackId,
|
|
50
|
+
conf: track,
|
|
51
|
+
name: getTrackName(track, session),
|
|
52
|
+
category: (_a = readConfObject(track, 'category')) === null || _a === void 0 ? void 0 : _a.join(', '),
|
|
53
|
+
adapter: (_b = readConfObject(track, 'adapter')) === null || _b === void 0 ? void 0 : _b.type,
|
|
54
|
+
description: readConfObject(track, 'description'),
|
|
55
|
+
metadata,
|
|
56
|
+
...metadata,
|
|
57
|
+
};
|
|
58
|
+
});
|
|
59
|
+
}, [assemblyName, model, filterDebounced, session]);
|
|
60
|
+
const filteredNonMetadataKeys = useMemo(() => nonMetadataKeys.filter(f => !hideSparse ? true : rows.map(r => r[f]).filter(f => !!f).length > 5), [hideSparse, rows]);
|
|
61
|
+
const filteredMetadataKeys = useMemo(() => [...new Set(rows.map(row => getRootKeys(row.metadata)).flat())].filter(f => !hideSparse
|
|
62
|
+
? true
|
|
63
|
+
: rows.map(r => r.metadata[f]).filter(f => !!f).length > 5), [hideSparse, rows]);
|
|
64
|
+
const fields = useMemo(() => {
|
|
65
|
+
return ['name', ...filteredNonMetadataKeys, ...filteredMetadataKeys];
|
|
66
|
+
}, [filteredNonMetadataKeys, filteredMetadataKeys]);
|
|
67
|
+
const [widths, setWidths] = useState({
|
|
68
|
+
name: measureGridWidth(rows.map(r => r.name), { maxWidth: 500, stripHTML: true }) + 15,
|
|
69
|
+
...Object.fromEntries(filteredNonMetadataKeys.map(e => [
|
|
70
|
+
e,
|
|
71
|
+
measureGridWidth(rows.map(r => r[e]), { maxWidth: 400, stripHTML: true }),
|
|
72
|
+
])),
|
|
73
|
+
...Object.fromEntries(filteredMetadataKeys.map(e => [
|
|
74
|
+
e,
|
|
75
|
+
measureGridWidth(rows.map(r => r.metadata[e]), { maxWidth: 400, stripHTML: true }),
|
|
76
|
+
])),
|
|
77
|
+
});
|
|
78
|
+
const [visible, setVisible] = useState(Object.fromEntries(fields.map(c => [c, true])));
|
|
79
|
+
useEffect(() => {
|
|
80
|
+
setVisible(visible => ({
|
|
81
|
+
...Object.fromEntries(fields.map(c => [c, true])),
|
|
82
|
+
...visible,
|
|
83
|
+
}));
|
|
84
|
+
}, [fields]);
|
|
85
|
+
useEffect(() => {
|
|
86
|
+
setWidths(widths => ({
|
|
87
|
+
name: widths.name,
|
|
88
|
+
...Object.fromEntries(filteredNonMetadataKeys
|
|
89
|
+
.filter(f => visible[f])
|
|
90
|
+
.map(e => [
|
|
91
|
+
e,
|
|
92
|
+
measureGridWidth(rows.map(r => r[e]), { stripHTML: true, maxWidth: 400 }),
|
|
93
|
+
])),
|
|
94
|
+
...Object.fromEntries(filteredMetadataKeys
|
|
95
|
+
.filter(f => visible[f])
|
|
96
|
+
.map(e => [
|
|
97
|
+
e,
|
|
98
|
+
measureGridWidth(rows.map(r => r.metadata[e]), { stripHTML: true, maxWidth: 400 }),
|
|
99
|
+
])),
|
|
100
|
+
}));
|
|
101
|
+
}, [filteredMetadataKeys, visible, filteredNonMetadataKeys, hideSparse, rows]);
|
|
102
|
+
const widthsDebounced = useDebounce(widths, 400);
|
|
103
|
+
const columns = [
|
|
104
|
+
{
|
|
105
|
+
field: 'name',
|
|
106
|
+
hideable: false,
|
|
107
|
+
renderCell: (params) => {
|
|
108
|
+
const { value, id, row } = params;
|
|
109
|
+
return (React.createElement(React.Fragment, null,
|
|
110
|
+
React.createElement(SanitizedHTML, { html: value }),
|
|
111
|
+
React.createElement(IconButton, { onClick: e => setInfo({
|
|
112
|
+
target: e.currentTarget,
|
|
113
|
+
id: id,
|
|
114
|
+
conf: row.conf,
|
|
115
|
+
}) },
|
|
116
|
+
React.createElement(MoreHoriz, null))));
|
|
117
|
+
},
|
|
118
|
+
width: widthsDebounced.name || 100, // can be undefined before useEffect update
|
|
119
|
+
},
|
|
120
|
+
...filteredNonMetadataKeys.map(e => ({
|
|
121
|
+
field: e,
|
|
122
|
+
width: widthsDebounced[e] || 100,
|
|
123
|
+
renderCell: (params) => {
|
|
124
|
+
const { value } = params;
|
|
125
|
+
return value ? React.createElement(SanitizedHTML, { html: value }) : '';
|
|
126
|
+
},
|
|
127
|
+
})),
|
|
128
|
+
...filteredMetadataKeys.map(e => ({
|
|
129
|
+
field: e,
|
|
130
|
+
width: widthsDebounced[e] || 100,
|
|
131
|
+
renderCell: (params) => {
|
|
132
|
+
const { value } = params;
|
|
133
|
+
return value ? React.createElement(SanitizedHTML, { html: value }) : '';
|
|
134
|
+
},
|
|
135
|
+
})),
|
|
136
|
+
];
|
|
137
|
+
const shownTrackIds = view.tracks.map(
|
|
138
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
139
|
+
(t) => t.configuration.trackId);
|
|
140
|
+
const arrFilters = Object.entries(filters).filter(f => f[1].length > 0);
|
|
141
|
+
return (React.createElement(React.Fragment, null,
|
|
142
|
+
info ? (React.createElement(JBrowseMenu, { anchorEl: info === null || info === void 0 ? void 0 : info.target, menuItems: ((_a = session.getTrackActionMenuItems) === null || _a === void 0 ? void 0 : _a.call(session, info.conf)) || [], onMenuItemClick: (_event, callback) => {
|
|
143
|
+
callback();
|
|
144
|
+
setInfo(undefined);
|
|
145
|
+
}, open: !!info, onClose: () => setInfo(undefined) })) : null,
|
|
146
|
+
React.createElement(FacetedHeader, { setHideSparse: setHideSparse, setFilterText: setFilterText, setUseShoppingCart: setUseShoppingCart, hideSparse: hideSparse, filterText: filterText, useShoppingCart: useShoppingCart, model: model }),
|
|
147
|
+
React.createElement("div", { ref: ref, style: {
|
|
148
|
+
display: 'flex',
|
|
149
|
+
overflow: 'hidden',
|
|
150
|
+
height: window.innerHeight * frac,
|
|
151
|
+
width: window.innerWidth * frac,
|
|
152
|
+
} },
|
|
153
|
+
React.createElement("div", { style: {
|
|
154
|
+
height: window.innerHeight * frac,
|
|
155
|
+
width: window.innerWidth * frac - panelWidth,
|
|
156
|
+
} },
|
|
157
|
+
React.createElement(ResizeBar, { checkbox: true, widths: Object.values(widths), setWidths: newWidths => setWidths(Object.fromEntries(Object.entries(widths).map((entry, idx) => [
|
|
158
|
+
entry[0],
|
|
159
|
+
newWidths[idx],
|
|
160
|
+
]))), scrollLeft: scrollLeft }),
|
|
161
|
+
React.createElement(DataGrid, { rows: rows.filter(row => arrFilters.every(([key, val]) => val.includes(row[key]))), columnVisibilityModel: visible, onColumnVisibilityModelChange: newModel => setVisible(newModel), headerHeight: 35, checkboxSelection: true, disableSelectionOnClick: true, keepNonExistentRowsSelected: true, onSelectionModelChange: userSelectedIds => {
|
|
162
|
+
if (!useShoppingCart) {
|
|
163
|
+
const a1 = shownTrackIds;
|
|
164
|
+
const a2 = userSelectedIds;
|
|
165
|
+
// synchronize the user selection with the view
|
|
166
|
+
// see share https://stackoverflow.com/a/33034768/2129219
|
|
167
|
+
transaction(() => {
|
|
168
|
+
a1.filter(x => !a2.includes(x)).map(t => view.hideTrack(t));
|
|
169
|
+
a2.filter(x => !a1.includes(x)).map(t => view.showTrack(t));
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
else {
|
|
173
|
+
const root = getRoot(model);
|
|
174
|
+
const schema = pluginManager.pluggableConfigSchemaType('track');
|
|
175
|
+
const tracks = userSelectedIds.map(id => resolveIdentifier(schema, root, id));
|
|
176
|
+
model.setSelection(tracks);
|
|
177
|
+
}
|
|
178
|
+
}, selectionModel: useShoppingCart ? selection.map(s => s.trackId) : shownTrackIds, columns: columns, rowHeight: 25 })),
|
|
179
|
+
React.createElement(ResizeHandle, { vertical: true, onDrag: dist => setPanelWidth(panelWidth - dist), style: { background: 'grey', width: 5 } }),
|
|
180
|
+
React.createElement("div", { style: { width: panelWidth, overflowY: 'auto', overflowX: 'hidden' } },
|
|
181
|
+
React.createElement(FacetFilters, { width: panelWidth - 10, rows: rows, columns: columns, dispatch: dispatch, filters: filters })))));
|
|
182
|
+
});
|
|
183
|
+
//# sourceMappingURL=FacetedSelector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FacetedSelector.js","sourceRoot":"","sources":["../../../../src/HierarchicalTrackSelectorWidget/components/faceted/FacetedSelector.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function getRootKeys(obj: Record<string, unknown>): string[];
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../src/HierarchicalTrackSelectorWidget/components/faceted/util.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,WAAW,CAAC,GAA4B;IACtD,OAAO,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC;SACvB,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;SACzD,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;AACrB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { HierarchicalTrackSelectorModel } from '../../model';
|
|
3
|
+
declare const _default: ({ model, setAssemblyIdx, }: {
|
|
4
|
+
model: HierarchicalTrackSelectorModel;
|
|
5
|
+
setAssemblyIdx: Function;
|
|
6
|
+
}) => JSX.Element;
|
|
7
|
+
export default _default;
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import React, { Suspense, lazy, useState } from 'react';
|
|
2
|
+
import { IconButton } from '@mui/material';
|
|
3
|
+
import { makeStyles } from 'tss-react/mui';
|
|
4
|
+
import { observer } from 'mobx-react';
|
|
5
|
+
import JBrowseMenu from '@jbrowse/core/ui/Menu';
|
|
6
|
+
import { getSession, isSessionModelWithWidgets, isSessionModelWithConnections, } from '@jbrowse/core/util';
|
|
7
|
+
import { readConfObject, } from '@jbrowse/core/configuration';
|
|
8
|
+
// icons
|
|
9
|
+
import MenuIcon from '@mui/icons-material/Menu';
|
|
10
|
+
// lazy components
|
|
11
|
+
const CloseConnectionDlg = lazy(() => import('../dialogs/CloseConnectionDialog'));
|
|
12
|
+
const DeleteConnectionDlg = lazy(() => import('../dialogs/DeleteConnectionDialog'));
|
|
13
|
+
const ManageConnectionsDlg = lazy(() => import('../dialogs/ManageConnectionsDialog'));
|
|
14
|
+
const ToggleConnectionsDlg = lazy(() => import('../dialogs/ToggleConnectionsDialog'));
|
|
15
|
+
const useStyles = makeStyles()(theme => ({
|
|
16
|
+
menuIcon: {
|
|
17
|
+
marginRight: theme.spacing(1),
|
|
18
|
+
marginBottom: 0,
|
|
19
|
+
},
|
|
20
|
+
}));
|
|
21
|
+
export default observer(function HamburgerMenu({ model, setAssemblyIdx, }) {
|
|
22
|
+
const session = getSession(model);
|
|
23
|
+
const [menuEl, setMenuEl] = useState();
|
|
24
|
+
const [modalInfo, setModalInfo] = useState();
|
|
25
|
+
const [deleteDlgDetails, setDeleteDlgDetails] = useState();
|
|
26
|
+
const [connectionToggleOpen, setConnectionToggleOpen] = useState(false);
|
|
27
|
+
const [connectionManagerOpen, setConnectionManagerOpen] = useState(false);
|
|
28
|
+
const { classes } = useStyles();
|
|
29
|
+
const { assemblyNames } = model;
|
|
30
|
+
function breakConnection(connectionConf, deletingConnection) {
|
|
31
|
+
const name = readConfObject(connectionConf, 'name');
|
|
32
|
+
// @ts-ignore
|
|
33
|
+
const result = session.prepareToBreakConnection(connectionConf);
|
|
34
|
+
if (result) {
|
|
35
|
+
const [safelyBreakConnection, dereferenceTypeCount] = result;
|
|
36
|
+
if (Object.keys(dereferenceTypeCount).length > 0) {
|
|
37
|
+
setModalInfo({
|
|
38
|
+
connectionConf,
|
|
39
|
+
safelyBreakConnection,
|
|
40
|
+
dereferenceTypeCount,
|
|
41
|
+
name,
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
safelyBreakConnection();
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
if (deletingConnection) {
|
|
49
|
+
setDeleteDlgDetails({ name, connectionConf });
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
const connectionMenuItems = [
|
|
53
|
+
{
|
|
54
|
+
label: 'Turn on/off connections...',
|
|
55
|
+
onClick: () => setConnectionToggleOpen(true),
|
|
56
|
+
},
|
|
57
|
+
];
|
|
58
|
+
if (isSessionModelWithConnections(session)) {
|
|
59
|
+
connectionMenuItems.unshift({
|
|
60
|
+
label: 'Add connection...',
|
|
61
|
+
onClick: () => {
|
|
62
|
+
if (isSessionModelWithWidgets(session)) {
|
|
63
|
+
session.showWidget(session.addWidget('AddConnectionWidget', 'addConnectionWidget'));
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
});
|
|
67
|
+
connectionMenuItems.push({
|
|
68
|
+
label: 'Delete connections...',
|
|
69
|
+
onClick: () => setConnectionManagerOpen(true),
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
return (React.createElement(React.Fragment, null,
|
|
73
|
+
React.createElement(IconButton, { className: classes.menuIcon, onClick: event => setMenuEl(event.currentTarget) },
|
|
74
|
+
React.createElement(MenuIcon, null)),
|
|
75
|
+
React.createElement(JBrowseMenu, { anchorEl: menuEl, open: Boolean(menuEl), onMenuItemClick: (_, callback) => {
|
|
76
|
+
callback();
|
|
77
|
+
setMenuEl(undefined);
|
|
78
|
+
}, onClose: () => setMenuEl(undefined), menuItems: [
|
|
79
|
+
{
|
|
80
|
+
label: 'Add track...',
|
|
81
|
+
onClick: () => {
|
|
82
|
+
if (isSessionModelWithWidgets(session)) {
|
|
83
|
+
session.showWidget(session.addWidget('AddTrackWidget', 'addTrackWidget', {
|
|
84
|
+
view: model.view.id,
|
|
85
|
+
}));
|
|
86
|
+
}
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
...(session.makeConnection ? connectionMenuItems : []),
|
|
90
|
+
...(assemblyNames.length > 1
|
|
91
|
+
? [
|
|
92
|
+
{
|
|
93
|
+
label: 'Select assembly...',
|
|
94
|
+
subMenu: assemblyNames.map((name, idx) => ({
|
|
95
|
+
label: name,
|
|
96
|
+
onClick: () => setAssemblyIdx(idx),
|
|
97
|
+
})),
|
|
98
|
+
},
|
|
99
|
+
]
|
|
100
|
+
: []),
|
|
101
|
+
] }),
|
|
102
|
+
React.createElement(Suspense, { fallback: React.createElement("div", null) },
|
|
103
|
+
modalInfo ? (React.createElement(CloseConnectionDlg, { modalInfo: modalInfo, setModalInfo: setModalInfo })) : null,
|
|
104
|
+
deleteDlgDetails ? (React.createElement(DeleteConnectionDlg, { handleClose: () => setDeleteDlgDetails(undefined), deleteDialogDetails: deleteDlgDetails, session: session })) : null,
|
|
105
|
+
connectionManagerOpen ? (React.createElement(ManageConnectionsDlg, { handleClose: () => setConnectionManagerOpen(false), breakConnection: breakConnection, session: session })) : null,
|
|
106
|
+
connectionToggleOpen ? (React.createElement(ToggleConnectionsDlg, { handleClose: () => setConnectionToggleOpen(false), session: session, breakConnection: breakConnection })) : null)));
|
|
107
|
+
});
|
|
108
|
+
//# sourceMappingURL=HamburgerMenu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HamburgerMenu.js","sourceRoot":"","sources":["../../../../src/HierarchicalTrackSelectorWidget/components/tree/HamburgerMenu.tsx"],"names":[],"mappings":"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"}
|
package/esm/HierarchicalTrackSelectorWidget/components/{Header.d.ts → tree/HierarchicalHeader.d.ts}
RENAMED
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
import { HierarchicalTrackSelectorModel } from '
|
|
3
|
-
declare function HierarchicalTrackSelectorHeader({ model, setHeaderHeight, setAssemblyIdx,
|
|
2
|
+
import { HierarchicalTrackSelectorModel } from '../../model';
|
|
3
|
+
declare function HierarchicalTrackSelectorHeader({ model, setHeaderHeight, setAssemblyIdx, }: {
|
|
4
4
|
model: HierarchicalTrackSelectorModel;
|
|
5
5
|
setHeaderHeight: (n: number) => void;
|
|
6
6
|
setAssemblyIdx: (n: number) => void;
|
|
7
|
-
assemblyIdx: number;
|
|
8
7
|
}): JSX.Element;
|
|
9
8
|
declare const _default: typeof HierarchicalTrackSelectorHeader;
|
|
10
9
|
export default _default;
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import React, { Suspense, lazy, useState } from 'react';
|
|
2
|
+
import { Button, IconButton, InputAdornment, TextField } from '@mui/material';
|
|
3
|
+
import { makeStyles } from 'tss-react/mui';
|
|
4
|
+
import { observer } from 'mobx-react';
|
|
5
|
+
// icons
|
|
6
|
+
import ClearIcon from '@mui/icons-material/Clear';
|
|
7
|
+
import HamburgerMenu from './HamburgerMenu';
|
|
8
|
+
import ShoppingCart from '../ShoppingCart';
|
|
9
|
+
// lazies
|
|
10
|
+
const FacetedDialog = lazy(() => import('../faceted/FacetedDialog'));
|
|
11
|
+
const useStyles = makeStyles()(theme => ({
|
|
12
|
+
searchBox: {
|
|
13
|
+
margin: theme.spacing(2),
|
|
14
|
+
},
|
|
15
|
+
menuIcon: {
|
|
16
|
+
marginRight: theme.spacing(1),
|
|
17
|
+
marginBottom: 0,
|
|
18
|
+
},
|
|
19
|
+
}));
|
|
20
|
+
function HierarchicalTrackSelectorHeader({ model, setHeaderHeight, setAssemblyIdx, }) {
|
|
21
|
+
const { classes } = useStyles();
|
|
22
|
+
const [facetedOpen, setFacetedOpen] = useState(false);
|
|
23
|
+
const { filterText } = model;
|
|
24
|
+
return (React.createElement("div", { ref: ref => setHeaderHeight((ref === null || ref === void 0 ? void 0 : ref.getBoundingClientRect().height) || 0), "data-testid": "hierarchical_track_selector" },
|
|
25
|
+
React.createElement("div", { style: { display: 'flex' } },
|
|
26
|
+
React.createElement(HamburgerMenu, { model: model, setAssemblyIdx: setAssemblyIdx }),
|
|
27
|
+
React.createElement(ShoppingCart, { model: model }),
|
|
28
|
+
React.createElement(TextField, { className: classes.searchBox, label: "Filter tracks", value: filterText, onChange: event => model.setFilterText(event.target.value), fullWidth: true, InputProps: {
|
|
29
|
+
endAdornment: (React.createElement(InputAdornment, { position: "end" },
|
|
30
|
+
React.createElement(IconButton, { onClick: () => model.clearFilterText() },
|
|
31
|
+
React.createElement(ClearIcon, null)))),
|
|
32
|
+
} }),
|
|
33
|
+
React.createElement(Button, { className: classes.menuIcon, onClick: () => setFacetedOpen(true) }, "Open faceted selector")),
|
|
34
|
+
React.createElement(Suspense, { fallback: React.createElement("div", null) }, facetedOpen ? (React.createElement(FacetedDialog, { handleClose: () => setFacetedOpen(false), model: model })) : null)));
|
|
35
|
+
}
|
|
36
|
+
export default observer(HierarchicalTrackSelectorHeader);
|
|
37
|
+
//# sourceMappingURL=HierarchicalHeader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HierarchicalHeader.js","sourceRoot":"","sources":["../../../../src/HierarchicalTrackSelectorWidget/components/tree/HierarchicalHeader.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACvD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAC7E,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,QAAQ;AACR,OAAO,SAAS,MAAM,2BAA2B,CAAA;AAIjD,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAC3C,OAAO,YAAY,MAAM,iBAAiB,CAAA;AAE1C,SAAS;AACT,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,0BAA0B,CAAC,CAAC,CAAA;AAEpE,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;AAEH,SAAS,+BAA+B,CAAC,EACvC,KAAK,EACL,eAAe,EACf,cAAc,GAKf;IACC,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAA;IAC/B,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACrD,MAAM,EAAE,UAAU,EAAE,GAAG,KAAK,CAAA;IAE5B,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;YAC7B,oBAAC,aAAa,IAAC,KAAK,EAAE,KAAK,EAAE,cAAc,EAAE,cAAc,GAAI;YAC/D,oBAAC,YAAY,IAAC,KAAK,EAAE,KAAK,GAAI;YAE9B,oBAAC,SAAS,IACR,SAAS,EAAE,OAAO,CAAC,SAAS,EAC5B,KAAK,EAAC,eAAe,EACrB,KAAK,EAAE,UAAU,EACjB,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,OAAO,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,eAAe,EAAE;4BAChD,oBAAC,SAAS,OAAG,CACF,CACE,CAClB;iBACF,GACD;YACF,oBAAC,MAAM,IACL,SAAS,EAAE,OAAO,CAAC,QAAQ,EAC3B,OAAO,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,4BAG5B,CACL;QAEN,oBAAC,QAAQ,IAAC,QAAQ,EAAE,gCAAO,IACxB,WAAW,CAAC,CAAC,CAAC,CACb,oBAAC,aAAa,IACZ,WAAW,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,KAAK,CAAC,EACxC,KAAK,EAAE,KAAK,GACZ,CACH,CAAC,CAAC,CAAC,IAAI,CACC,CACP,CACP,CAAA;AACH,CAAC;AAED,eAAe,QAAQ,CAAC,+BAA+B,CAAC,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { TreeNode, HierarchicalTrackSelectorModel } from '../../model';
|
|
3
|
+
declare const _default: ({ height, tree, model, }: {
|
|
4
|
+
height: number;
|
|
5
|
+
tree: TreeNode;
|
|
6
|
+
model: HierarchicalTrackSelectorModel;
|
|
7
|
+
}) => JSX.Element;
|
|
8
|
+
export default _default;
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import React, { useCallback, useMemo, useRef, useEffect } from 'react';
|
|
2
|
+
import { observer } from 'mobx-react';
|
|
3
|
+
import { VariableSizeTree } from 'react-vtree';
|
|
4
|
+
import { getSession } from '@jbrowse/core/util';
|
|
5
|
+
import Node from './TrackListNode';
|
|
6
|
+
function getNodeData(node, nestingLevel, extra, selection) {
|
|
7
|
+
const isLeaf = !!node.conf;
|
|
8
|
+
const selected = !!selection[node.id];
|
|
9
|
+
return {
|
|
10
|
+
data: {
|
|
11
|
+
defaultHeight: isLeaf ? 22 : 40,
|
|
12
|
+
isLeaf,
|
|
13
|
+
isOpenByDefault: true,
|
|
14
|
+
nestingLevel,
|
|
15
|
+
selected,
|
|
16
|
+
...node,
|
|
17
|
+
...extra,
|
|
18
|
+
},
|
|
19
|
+
nestingLevel,
|
|
20
|
+
node,
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
// this is the main tree component for the hierarchical track selector in note:
|
|
24
|
+
// in jbrowse-web the toolbar is position="sticky" which means the autosizer
|
|
25
|
+
// includes the height of the toolbar, so we subtract the given offsets
|
|
26
|
+
export default observer(function HierarchicalTree({ height, tree, model, }) {
|
|
27
|
+
const { filterText, selection, view } = model;
|
|
28
|
+
const treeRef = useRef(null);
|
|
29
|
+
const session = getSession(model);
|
|
30
|
+
const { drawerPosition } = session;
|
|
31
|
+
const obj = useMemo(() => Object.fromEntries(selection.map(s => [s.trackId, s])), [selection]);
|
|
32
|
+
const extra = useMemo(() => ({
|
|
33
|
+
onChange: (trackId) => view.toggleTrack(trackId),
|
|
34
|
+
toggleCollapse: (pathName) => model.toggleCategory(pathName),
|
|
35
|
+
tree,
|
|
36
|
+
model,
|
|
37
|
+
drawerPosition,
|
|
38
|
+
}), [view, model, drawerPosition, tree]);
|
|
39
|
+
const treeWalker = useCallback(function* treeWalker() {
|
|
40
|
+
for (let i = 0; i < tree.children.length; i++) {
|
|
41
|
+
const r = tree.children[i];
|
|
42
|
+
yield getNodeData(r, 0, extra, obj);
|
|
43
|
+
}
|
|
44
|
+
while (true) {
|
|
45
|
+
// @ts-ignore
|
|
46
|
+
const parentMeta = yield;
|
|
47
|
+
for (let i = 0; i < parentMeta.node.children.length; i++) {
|
|
48
|
+
const curr = parentMeta.node.children[i];
|
|
49
|
+
yield getNodeData(curr, parentMeta.nestingLevel + 1, extra, obj);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}, [tree, extra, obj]);
|
|
53
|
+
useEffect(() => {
|
|
54
|
+
// @ts-ignore
|
|
55
|
+
treeRef.current.recomputeTree({
|
|
56
|
+
refreshNodes: true,
|
|
57
|
+
useDefaultHeight: true,
|
|
58
|
+
});
|
|
59
|
+
}, [tree, filterText]);
|
|
60
|
+
return (React.createElement(React.Fragment, null,
|
|
61
|
+
React.createElement(VariableSizeTree, { ref: treeRef, treeWalker: treeWalker, height: height }, Node)));
|
|
62
|
+
});
|
|
63
|
+
//# sourceMappingURL=HierarchicalTree.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HierarchicalTree.js","sourceRoot":"","sources":["../../../../src/HierarchicalTrackSelectorWidget/components/tree/HierarchicalTree.tsx"],"names":[],"mappings":"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"}
|