1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import * as React from 'react';
19 } from '@material-ui/core';
20 import { ArvadosTheme } from '~/common/custom-theme';
21 import { WorkflowIcon } from '~/components/icon/icon';
22 import { DataTableDefaultView } from '~/components/data-table-default-view/data-table-default-view';
23 import { WorkflowResource, parseWorkflowDefinition, getWorkflowInputs, getInputLabel, stringifyInputType } from '~/models/workflow';
24 import { WorkflowGraph } from "~/views/workflow-panel/workflow-graph";
26 export type CssRules = 'root' | 'tab' | 'inputTab';
28 const styles: StyleRulesCallback<CssRules> = (theme: ArvadosTheme) => ({
36 height: 'calc(100% - 48px - 16px * 2)',
40 paddingBottom: theme.spacing.unit / 2,
45 interface WorkflowDetailsCardDataProps {
46 workflow?: WorkflowResource;
49 type WorkflowDetailsCardProps = WorkflowDetailsCardDataProps & WithStyles<CssRules>;
51 export const WorkflowDetailsCard = withStyles(styles)(
52 class extends React.Component<WorkflowDetailsCardProps> {
57 handleChange = (event: React.MouseEvent<HTMLElement>, value: number) => {
58 this.setState({ value });
62 const { classes, workflow } = this.props;
63 const { value } = this.state;
64 return <div className={classes.root}>
65 <Tabs value={value} onChange={this.handleChange} centered={true}>
66 <Tab className={classes.tab} label="Description" />
67 <Tab className={classes.tab} label="Inputs" />
68 <Tab className={classes.tab} label="Graph" />
70 {value === 0 && <CardContent>
72 {workflow.description}
76 messages={['Please select a workflow to see its description.']} />
79 {value === 1 && <CardContent className={classes.inputTab}>
81 ? this.renderInputsTable()
82 : <DataTableDefaultView
84 messages={['Please select a workflow to see its inputs.']} />
87 {value === 2 && <CardContent className={classes.inputTab}>
89 ? <WorkflowGraph workflow={workflow}/>
90 : <DataTableDefaultView
92 messages={['Please select a workflow to see its visualisation.']} />
99 if (this.props.workflow) {
100 const definition = parseWorkflowDefinition(this.props.workflow);
102 return getWorkflowInputs(definition);
108 renderInputsTable() {
112 <TableCell>Label</TableCell>
113 <TableCell>Type</TableCell>
114 <TableCell>Description</TableCell>
118 {this.inputs && this.inputs.map(input =>
119 <TableRow key={input.id}>
120 <TableCell>{getInputLabel(input)}</TableCell>
121 <TableCell>{stringifyInputType(input)}</TableCell>
122 <TableCell>{input.doc}</TableCell>