1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import React, { useEffect } from 'react';
20 } from '@material-ui/core';
21 import classnames from 'classnames';
22 import { DefaultTransformOrigin } from 'components/popover/helpers';
23 import { createTree } from 'models/tree';
24 import { getNodeDescendants } from 'models/tree';
25 import debounce from 'lodash/debounce';
26 import { green, grey } from '@material-ui/core/colors';
28 export type CssRules = 'root' | 'icon' | 'iconButton' | 'active' | 'checkbox';
30 const styles: StyleRulesCallback<CssRules> = (theme: Theme) => ({
32 // border: '1px dashed green',
36 backgroundColor: grey[200],
39 color: theme.palette.text.primary,
43 color: theme.palette.text.primary,
49 // border: '1px solid red',
54 color: theme.palette.text.primary,
58 color: theme.palette.text.primary,
74 export interface DataTableMultiselectProps {
79 interface DataTableFMultiselectPopState {
80 anchorEl?: HTMLElement;
83 export const DataTableMultiselectPopover = withStyles(styles)(
84 class extends React.Component<DataTableMultiselectProps & WithStyles<CssRules>, DataTableFMultiselectPopState> {
85 state: DataTableFMultiselectPopState = {
88 icon = React.createRef<HTMLElement>();
91 const { name, classes, children, options } = this.props;
94 <Tooltip disableFocusListener title='Multiselect Actions'>
95 <ButtonBase className={classnames(classes.root)} component='span' onClick={this.open} disableRipple>
97 <IconButton component='span' classes={{ root: classes.iconButton }} tabIndex={-1}>
98 <i className={classnames(['fas fa-sort-down', classes.icon])} data-fa-transform='shrink-3' ref={this.icon} />
103 anchorEl={this.state.anchorEl}
104 open={!!this.state.anchorEl}
105 anchorOrigin={DefaultTransformOrigin}
106 transformOrigin={DefaultTransformOrigin}
111 <Typography variant='caption'>{'OPTIONS'}</Typography>
113 {options.length && options.map((option, i) => <div key={i}>{option}</div>)}
115 <Button color='primary' variant='outlined' size='small' onClick={this.close}>
121 <this.MountHandler />
127 this.setState({ anchorEl: this.icon.current || undefined });
130 submit = debounce(() => {
131 // const { onChange } = this.props;
133 // onChange(this.state.filters);
137 MountHandler = () => {
140 this.submit.cancel();
147 this.setState((prev) => ({