1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import React from 'react';
6 import { CustomStyleRulesCallback } from 'common/custom-theme';
7 import { WithStyles, withStyles, Card, CardContent, Grid, Table, TableHead, TableRow, TableCell, TableBody, Tooltip, IconButton, Checkbox } from '@material-ui/core';
8 import { ArvadosTheme } from 'common/custom-theme';
9 import { MoreVerticalIcon } from 'components/icon/icon';
10 import { KeepServiceResource } from 'models/keep-services';
12 type CssRules = 'root' | 'tableRow';
14 const styles: CustomStyleRulesCallback<CssRules> = (theme: ArvadosTheme) => ({
26 export interface KeepServicePanelRootActionProps {
27 openRowOptions: (event: React.MouseEvent<HTMLElement>, keepService: KeepServiceResource) => void;
30 export interface KeepServicePanelRootDataProps {
31 keepServices: KeepServiceResource[];
32 hasKeepSerices: boolean;
35 type KeepServicePanelRootProps = KeepServicePanelRootActionProps & KeepServicePanelRootDataProps & WithStyles<CssRules>;
37 export const KeepServicePanelRoot = withStyles(styles)(
38 ({ classes, hasKeepSerices, keepServices, openRowOptions }: KeepServicePanelRootProps) =>
39 <Card className={classes.root}>
41 {hasKeepSerices && <Grid container direction="row">
45 <TableRow className={classes.tableRow}>
46 <TableCell>UUID</TableCell>
47 <TableCell>Read only</TableCell>
48 <TableCell>Service host</TableCell>
49 <TableCell>Service port</TableCell>
50 <TableCell>Service SSL flag</TableCell>
51 <TableCell>Service type</TableCell>
56 {keepServices.map((keepService, index) =>
57 <TableRow key={index} className={classes.tableRow}>
58 <TableCell>{keepService.uuid}</TableCell>
63 checked={keepService.readOnly} />
65 <TableCell>{keepService.serviceHost}</TableCell>
66 <TableCell>{keepService.servicePort}</TableCell>
71 checked={keepService.serviceSslFlag} />
73 <TableCell>{keepService.serviceType}</TableCell>
75 <Tooltip title="More options" disableFocusListener>
76 <IconButton onClick={event => openRowOptions(event, keepService)}>