1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import * as React from 'react';
6 import { StyleRulesCallback, WithStyles, withStyles, CardContent, Tab, Tabs, Typography, List, ListItem, Table, TableHead, TableCell, TableBody, TableRow } from '@material-ui/core';
7 import { ArvadosTheme } from '~/common/custom-theme';
8 import { WorkflowIcon } from '~/components/icon/icon';
9 import { DataTableDefaultView } from '~/components/data-table-default-view/data-table-default-view';
10 import { WorkflowResource, parseWorkflowDefinition, getWorkflowInputs, getInputLabel, stringifyInputType } from '~/models/workflow';
12 export type CssRules = 'root' | 'tab' | 'inputTab';
14 const styles: StyleRulesCallback<CssRules> = (theme: ArvadosTheme) => ({
25 paddingBottom: theme.spacing.unit / 2,
30 interface WorkflowDetailsCardDataProps {
31 workflow?: WorkflowResource;
34 type WorkflowDetailsCardProps = WorkflowDetailsCardDataProps & WithStyles<CssRules>;
36 export const WorkflowDetailsCard = withStyles(styles)(
37 class extends React.Component<WorkflowDetailsCardProps> {
42 handleChange = (event: React.MouseEvent<HTMLElement>, value: number) => {
43 this.setState({ value });
47 const { classes, workflow } = this.props;
48 const { value } = this.state;
49 return <div className={classes.root}>
50 <Tabs value={value} onChange={this.handleChange} centered={true}>
51 <Tab className={classes.tab} label="Description" />
52 <Tab className={classes.tab} label="Inputs" />
54 {value === 0 && <CardContent>
60 messages={['Please select a workflow to see its description.']} />
63 {value === 1 && <CardContent className={classes.inputTab}>
65 ? this.renderInputsTable()
66 : <DataTableDefaultView
68 messages={['Please select a workflow to see its inputs.']} />
75 if (this.props.workflow) {
76 const definition = parseWorkflowDefinition(this.props.workflow);
78 return getWorkflowInputs(definition);
88 <TableCell>Label</TableCell>
89 <TableCell>Type</TableCell>
90 <TableCell>Description</TableCell>
94 {this.inputs && this.inputs.map(input =>
95 <TableRow key={input.id}>
96 <TableCell>{getInputLabel(input)}</TableCell>
97 <TableCell>{stringifyInputType(input)}</TableCell>
98 <TableCell>{input.doc}</TableCell>