1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import React from 'react';
18 } from '@material-ui/core';
19 import { ArvadosTheme } from 'common/custom-theme';
20 import { WorkflowIcon } from 'components/icon/icon';
21 import { DataTableDefaultView } from 'components/data-table-default-view/data-table-default-view';
22 import { parseWorkflowDefinition, getWorkflowInputs, getInputLabel, stringifyInputType } from 'models/workflow';
23 // import { WorkflowGraph } from "views/workflow-panel/workflow-graph";
25 import { WorkflowDetailsCardDataProps, WorkflowDetailsAttributes } from 'views-components/details-panel/workflow-details';
27 export type CssRules = 'root' | 'tab' | 'inputTab' | 'graphTab' | 'graphTabWithChosenWorkflow' | 'descriptionTab' | 'inputsTable';
29 const styles: StyleRulesCallback<CssRules> = (theme: ArvadosTheme) => ({
39 marginTop: theme.spacing.unit
42 marginTop: theme.spacing.unit,
44 graphTabWithChosenWorkflow: {
47 marginTop: theme.spacing.unit,
52 marginTop: theme.spacing.unit,
59 type WorkflowDetailsCardProps = WorkflowDetailsCardDataProps & WithStyles<CssRules>;
61 export const WorkflowDetailsCard = withStyles(styles)(
62 class extends React.Component<WorkflowDetailsCardProps> {
67 handleChange = (event: React.MouseEvent<HTMLElement>, value: number) => {
68 this.setState({ value });
72 const { classes, workflow } = this.props;
73 const { value } = this.state;
74 return <div className={classes.root}>
75 <Tabs value={value} onChange={this.handleChange} centered={true}>
76 <Tab className={classes.tab} label="Description" />
77 <Tab className={classes.tab} label="Inputs" />
78 <Tab className={classes.tab} label="Details" />
79 {/* <Tab className={classes.tab} label="Graph" /> */}
81 {value === 0 && <CardContent className={classes.descriptionTab}>
83 {workflow.description}
87 messages={['Please select a workflow to see its description.']} />
90 {value === 1 && <CardContent className={classes.inputTab}>
92 ? this.renderInputsTable()
93 : <DataTableDefaultView
95 messages={['Please select a workflow to see its inputs.']} />
98 {/* {value === 2 && <CardContent className={workflow ? classes.graphTabWithChosenWorkflow : classes.graphTab}>
100 ? <WorkflowGraph workflow={workflow} />
101 : <DataTableDefaultView
103 messages={['Please select a workflow to see its visualisation.']} />
106 {value === 2 && <CardContent className={classes.descriptionTab}>
108 ? <WorkflowDetailsAttributes workflow={workflow} />
109 : <DataTableDefaultView
111 messages={['Please select a workflow to see its details.']} />
118 if (this.props.workflow) {
119 const definition = parseWorkflowDefinition(this.props.workflow);
121 return getWorkflowInputs(definition);
127 renderInputsTable() {
128 return <Table className={this.props.classes.inputsTable}>
131 <TableCell>Label</TableCell>
132 <TableCell>Type</TableCell>
133 <TableCell>Description</TableCell>
137 {this.inputs && this.inputs.map(input =>
138 <TableRow key={input.id}>
139 <TableCell>{getInputLabel(input)}</TableCell>
140 <TableCell>{stringifyInputType(input)}</TableCell>
141 <TableCell>{input.doc}</TableCell>