Add props for controlling which checkboxes should be visible
[arvados-workbench2.git] / src / views-components / projects-tree-picker / projects-tree-picker.tsx
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import * as React from 'react';
6 import { Dispatch } from 'redux';
7 import { connect } from 'react-redux';
8 import { HomeTreePicker } from '~/views-components/projects-tree-picker/home-tree-picker';
9 import { SharedTreePicker } from '~/views-components/projects-tree-picker/shared-tree-picker';
10 import { FavoritesTreePicker } from '~/views-components/projects-tree-picker/favorites-tree-picker';
11 import { getProjectsTreePickerIds, treePickerActions } from '~/store/tree-picker/tree-picker-actions';
12 import { TreeItem } from '~/components/tree/tree';
13 import { ProjectsTreePickerItem } from './generic-projects-tree-picker';
14
15 export interface ProjectsTreePickerProps {
16     pickerId: string;
17     includeCollections?: boolean;
18     includeFiles?: boolean;
19     rootItemSelection?: boolean;
20     projectsSelection?: boolean;
21     collectionsSelection?: boolean;
22     filesSelection?: boolean;
23     toggleItemActive?: (event: React.MouseEvent<HTMLElement>, item: TreeItem<ProjectsTreePickerItem>, pickerId: string) => void;
24 }
25
26 export const ProjectsTreePicker = ({ pickerId, ...props }: ProjectsTreePickerProps) => {
27     const { home, shared, favorites } = getProjectsTreePickerIds(pickerId);
28     return <div>
29         <HomeTreePicker pickerId={home} {...props} />
30         <SharedTreePicker pickerId={shared} {...props} />
31         <FavoritesTreePicker pickerId={favorites} {...props} />
32     </div>;
33 };