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' | 'option';
30 const styles: StyleRulesCallback<CssRules> = (theme: Theme) => ({
34 backgroundColor: grey[200],
37 color: theme.palette.text.primary,
45 color: theme.palette.text.primary,
49 color: theme.palette.text.primary,
55 // border: '1px dashed green',
62 backgroundColor: 'rgba(0, 0, 0, 0.08)',
67 export type DataTableMultiselectOption = {
69 fn: (checkedList) => void;
72 export interface DataTableMultiselectProps {
74 options: DataTableMultiselectOption[];
75 checkedList: Record<string, boolean>;
78 interface DataTableFMultiselectPopState {
79 anchorEl?: HTMLElement;
82 export const DataTableMultiselectPopover = withStyles(styles)(
83 class extends React.Component<DataTableMultiselectProps & WithStyles<CssRules>, DataTableFMultiselectPopState> {
84 state: DataTableFMultiselectPopState = {
87 icon = React.createRef<HTMLElement>();
90 const { name, classes, children, options, checkedList } = this.props;
93 <Tooltip disableFocusListener title='Multiselect Actions'>
94 <ButtonBase className={classnames(classes.root)} component='span' onClick={this.open} disableRipple>
96 <IconButton component='span' classes={{ root: classes.iconButton }} tabIndex={-1}>
97 <i className={classnames(['fas fa-sort-down', classes.icon])} data-fa-transform='shrink-3' ref={this.icon} />
102 anchorEl={this.state.anchorEl}
103 open={!!this.state.anchorEl}
104 anchorOrigin={DefaultTransformOrigin}
105 transformOrigin={DefaultTransformOrigin}
110 <Typography variant='caption'>{'Options'}</Typography>
113 options.map((option, i) => (
114 <div key={i} className={classes.option} onClick={() => option.fn(checkedList)}>
119 <Button color='primary' variant='outlined' size='small' onClick={this.close}>
125 <this.MountHandler />
131 this.setState({ anchorEl: this.icon.current || undefined });
134 submit = debounce(() => {
135 // const { onChange } = this.props;
137 // onChange(this.state.filters);
141 MountHandler = () => {
144 this.submit.cancel();
151 this.setState((prev) => ({