// SPDX-License-Identifier: AGPL-3.0
import * as React from 'react';
-import { StyleRulesCallback, WithStyles, withStyles, CardContent, Tab, Tabs, Typography, List, ListItem, Table, TableHead, TableCell, TableBody, TableRow } from '@material-ui/core';
+import {
+ StyleRulesCallback,
+ WithStyles,
+ withStyles,
+ CardContent,
+ Tab,
+ Tabs,
+ Table,
+ TableHead,
+ TableCell,
+ TableBody,
+ TableRow,
+ Divider
+} from '@material-ui/core';
import { ArvadosTheme } from '~/common/custom-theme';
import { WorkflowIcon } from '~/components/icon/icon';
import { DataTableDefaultView } from '~/components/data-table-default-view/data-table-default-view';
import { WorkflowResource, parseWorkflowDefinition, getWorkflowInputs, getInputLabel, stringifyInputType } from '~/models/workflow';
+import { WorkflowGraph } from "~/views/workflow-panel/workflow-graph";
export type CssRules = 'root' | 'tab' | 'inputTab';
height: '100%'
},
tab: {
- minWidth: '50%'
+ minWidth: '33%'
},
inputTab: {
+ height: 'calc(100% - 48px - 16px * 2)',
overflowX: 'auto',
overflowY: 'hidden',
'&:last-child': {
<Tabs value={value} onChange={this.handleChange} centered={true}>
<Tab className={classes.tab} label="Description" />
<Tab className={classes.tab} label="Inputs" />
+ <Tab className={classes.tab} label="Graph" />
</Tabs>
{value === 0 && <CardContent>
- {workflow ? (
- workflow.description
- ) : (
+ {workflow ? <div>
+ {workflow.description}
+ </div> : (
<DataTableDefaultView
icon={WorkflowIcon}
messages={['Please select a workflow to see its description.']} />
messages={['Please select a workflow to see its inputs.']} />
}
</CardContent>}
+ {value === 2 && <CardContent className={classes.inputTab}>
+ {workflow
+ ? <WorkflowGraph workflow={workflow}/>
+ : <DataTableDefaultView
+ icon={WorkflowIcon}
+ messages={['Please select a workflow to see its visualisation.']} />
+ }
+ </CardContent>}
</div>;
}
</TableBody>
</Table>;
}
- });
\ No newline at end of file
+ });