// Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 import React from "react"; import { Dispatch } from "redux"; import { connect } from "react-redux"; import { TreePicker, TreePickerProps } from "../tree-picker/tree-picker"; import { TreeItem } from "components/tree/tree"; import { ProjectResource } from "models/project"; import { ListItemTextIcon } from "components/list-item-text-icon/list-item-text-icon"; import { ProcessIcon, ProjectIcon, FilterGroupIcon, FavoriteIcon, ProjectsIcon, ShareMeIcon, TrashIcon, PublicFavoriteIcon, GroupsIcon, TerminalIcon, ResourceIcon } from 'components/icon/icon'; import { activateSidePanelTreeItem, toggleSidePanelTreeItemCollapse, SIDE_PANEL_TREE, SidePanelTreeCategory } from 'store/side-panel-tree/side-panel-tree-actions'; import { openSidePanelContextMenu } from 'store/context-menu/context-menu-actions'; import { noop } from 'lodash'; import { ResourceKind } from "models/resource"; import { IllegalNamingWarning } from "components/warning/warning"; import { GroupClass } from "models/group"; import { setSelectedResourceUuid } from "store/selected-resource/selected-resource-actions"; export interface SidePanelTreeProps { onItemActivation: (id: string) => void; sidePanelProgress?: boolean; isCollapsed?: boolean; currentSideWidth?: number; currentRoute?: string; isDetailsPanelTransitioning?: boolean; setCurrentSideWidth: (width: number) => void } type SidePanelTreeActionProps = Pick, 'onContextMenu' | 'toggleItemActive' | 'toggleItemOpen' | 'toggleItemSelection'>; const mapDispatchToProps = (dispatch: Dispatch, props: SidePanelTreeProps): SidePanelTreeActionProps => ({ onContextMenu: (event, { id }) => { dispatch(openSidePanelContextMenu(event, id)); }, toggleItemActive: (_, { id }) => { dispatch(activateSidePanelTreeItem(id)); const isSidePanelCat = Object.values(SidePanelTreeCategory).includes(id as SidePanelTreeCategory); dispatch(setSelectedResourceUuid(isSidePanelCat ? null : id)); props.onItemActivation(id); }, toggleItemOpen: (_, { id }) => { dispatch(toggleSidePanelTreeItemCollapse(id)); }, toggleItemSelection: noop, }); export const SidePanelTree = connect(undefined, mapDispatchToProps)( (props: SidePanelTreeActionProps) =>
); const renderSidePanelItem = (item: TreeItem) => { const name = typeof item.data === 'string' ? item.data : item.data.name; const warn = typeof item.data !== 'string' && item.data.kind === ResourceKind.PROJECT ? : undefined; return ; }; const getProjectPickerIcon = (item: TreeItem) => typeof item.data === 'string' ? getSidePanelIcon(item.data) : (item.data && item.data.groupClass === GroupClass.FILTER) ? FilterGroupIcon : ProjectsIcon; export const getSidePanelIcon = (category: string) => { switch (category) { case SidePanelTreeCategory.FAVORITES: return FavoriteIcon; case SidePanelTreeCategory.PROJECTS: return ProjectsIcon; case SidePanelTreeCategory.SHARED_WITH_ME: return ShareMeIcon; case SidePanelTreeCategory.TRASH: return TrashIcon; case SidePanelTreeCategory.PUBLIC_FAVORITES: return PublicFavoriteIcon; case SidePanelTreeCategory.ALL_PROCESSES: return ProcessIcon; case SidePanelTreeCategory.INSTANCE_TYPES: return ResourceIcon; case SidePanelTreeCategory.GROUPS: return GroupsIcon; case SidePanelTreeCategory.SHELL_ACCESS: return TerminalIcon default: return ProjectIcon; } };