// Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 import * as React from "react"; import { Dispatch } from "redux"; import { connect } from "react-redux"; import { Typography } from "@material-ui/core"; import { TreePicker } from "../tree-picker/tree-picker"; import { TreeProps, TreeItem, TreeItemStatus } from "../../components/tree/tree"; import { ProjectResource } from "../../models/project"; import { treePickerActions } from "../../store/tree-picker/tree-picker-actions"; import { ListItemTextIcon } from "../../components/list-item-text-icon/list-item-text-icon"; import { ProjectIcon } from "../../components/icon/icon"; import { createTreePickerNode } from "../../store/tree-picker/tree-picker"; import { RootState } from "../../store/store"; import { ServiceRepository } from "../../services/services"; import { FilterBuilder } from "../../common/api/filter-builder"; type ProjectTreePickerProps = Pick, 'toggleItemActive' | 'toggleItemOpen'>; const mapDispatchToProps = (dispatch: Dispatch): ProjectTreePickerProps => ({ toggleItemActive: id => { dispatch(treePickerActions.TOGGLE_TREE_PICKER_NODE_SELECT({ id })); }, toggleItemOpen: (id, status) => { status === TreeItemStatus.INITIAL ? dispatch(loadProjectTreePickerProjects(id)) : dispatch(treePickerActions.TOGGLE_TREE_PICKER_NODE_COLLAPSE({ id })); } }); export const ProjectTreePicker = connect(undefined, mapDispatchToProps)((props: ProjectTreePickerProps) =>
Select a project
); // TODO: move action creator to store directory export const loadProjectTreePickerProjects = (id: string) => async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { dispatch(treePickerActions.LOAD_TREE_PICKER_NODE({ id })); const ownerUuid = id.length === 0 ? services.authService.getUuid() || '' : id; const filters = FilterBuilder .create() .addEqual('ownerUuid', ownerUuid); const { items } = await services.projectService.list({ filters }); dispatch(receiveProjectTreePickerData(id, items)); }; const renderTreeItem = (item: TreeItem) => ; // TODO: move action creator to store directory const receiveProjectTreePickerData = (id: string, projects: ProjectResource[]) => (dispatch: Dispatch) => { dispatch(treePickerActions.LOAD_TREE_PICKER_NODE_SUCCESS({ id, nodes: projects.map(project => createTreePickerNode({ id: project.uuid, value: project })) })); dispatch(treePickerActions.TOGGLE_TREE_PICKER_NODE_COLLAPSE({ id })); };