1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import * as React from 'react';
6 import { values, memoize, pipe, pick } from 'lodash/fp';
7 import { HomeTreePicker } from '~/views-components/projects-tree-picker/home-tree-picker';
8 import { SharedTreePicker } from '~/views-components/projects-tree-picker/shared-tree-picker';
9 import { FavoritesTreePicker } from '~/views-components/projects-tree-picker/favorites-tree-picker';
10 import { getProjectsTreePickerIds, SHARED_PROJECT_ID, FAVORITES_PROJECT_ID } from '~/store/tree-picker/tree-picker-actions';
11 import { TreeItem } from '~/components/tree/tree';
12 import { ProjectsTreePickerItem } from './generic-projects-tree-picker';
13 import { PublicFavoritesTreePicker } from './public-favorites-tree-picker';
15 export interface ProjectsTreePickerProps {
17 includeCollections?: boolean;
18 includeFiles?: boolean;
19 showSelection?: boolean;
20 toggleItemActive?: (event: React.MouseEvent<HTMLElement>, item: TreeItem<ProjectsTreePickerItem>, pickerId: string) => void;
21 toggleItemSelection?: (event: React.MouseEvent<HTMLElement>, item: TreeItem<ProjectsTreePickerItem>, pickerId: string) => void;
24 export const ProjectsTreePicker = ({ pickerId, ...props }: ProjectsTreePickerProps) => {
25 const { home, shared, favorites, publicFavorites } = getProjectsTreePickerIds(pickerId);
26 const relatedTreePickers = getRelatedTreePickers(pickerId);
33 <HomeTreePicker pickerId={home} {...p} />
34 <SharedTreePicker pickerId={shared} {...p} />
35 <PublicFavoritesTreePicker pickerId={publicFavorites} {...p} />
36 <FavoritesTreePicker pickerId={favorites} {...p} />
40 const getRelatedTreePickers = memoize(pipe(getProjectsTreePickerIds, values));
41 const disableActivation = [SHARED_PROJECT_ID, FAVORITES_PROJECT_ID];