// Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 import * as React from "react"; import { compose } from 'redux'; import { withStyles, Dialog, DialogTitle, DialogContent, DialogActions, Button, StyleRulesCallback, WithStyles, Grid } from '@material-ui/core'; import { WithDialogProps, withDialog } from "~/store/dialog/with-dialog"; import { API_CLIENT_AUTHORIZATION_ATTRIBUTES_DIALOG } from '~/store/api-client-authorizations/api-client-authorizations-actions'; import { ArvadosTheme } from '~/common/custom-theme'; import { ApiClientAuthorization } from '~/models/api-client-authorization'; import { formatDate } from '~/common/formatters'; type CssRules = 'root'; const styles: StyleRulesCallback<CssRules> = (theme: ArvadosTheme) => ({ root: { fontSize: '0.875rem', '& div:nth-child(odd)': { textAlign: 'right', color: theme.palette.grey["500"] } } }); interface AttributesKeepServiceDialogDataProps { apiClientAuthorization: ApiClientAuthorization; } export const AttributesApiClientAuthorizationDialog = compose( withDialog(API_CLIENT_AUTHORIZATION_ATTRIBUTES_DIALOG), withStyles(styles))( ({ open, closeDialog, data, classes }: WithDialogProps<AttributesKeepServiceDialogDataProps> & WithStyles<CssRules>) => <Dialog open={open} onClose={closeDialog} fullWidth maxWidth='sm'> <DialogTitle>Attributes</DialogTitle> <DialogContent> {data.apiClientAuthorization && <Grid container direction="row" spacing={16} className={classes.root}> <Grid item xs={5}>UUID</Grid> <Grid item xs={7}>{data.apiClientAuthorization.uuid}</Grid> <Grid item xs={5}>Owner uuid</Grid> <Grid item xs={7}>{data.apiClientAuthorization.ownerUuid}</Grid> <Grid item xs={5}>API Client ID</Grid> <Grid item xs={7}>{data.apiClientAuthorization.apiClientId}</Grid> <Grid item xs={5}>API Token</Grid> <Grid item xs={7}>{data.apiClientAuthorization.apiToken}</Grid> <Grid item xs={5}>Created by IP address</Grid> <Grid item xs={7}>{data.apiClientAuthorization.createdByIpAddress || '(none)'}</Grid> <Grid item xs={5}>Default owner</Grid> <Grid item xs={7}>{data.apiClientAuthorization.defaultOwnerUuid || '(none)'}</Grid> <Grid item xs={5}>Expires at</Grid> <Grid item xs={7}>{formatDate(data.apiClientAuthorization.expiresAt) || '(none)'}</Grid> <Grid item xs={5}>Last used at</Grid> <Grid item xs={7}>{formatDate(data.apiClientAuthorization.lastUsedAt) || '(none)'}</Grid> <Grid item xs={5}>Last used by IP address</Grid> <Grid item xs={7}>{data.apiClientAuthorization.lastUsedByIpAddress || '(none)'}</Grid> <Grid item xs={5}>Scopes</Grid> <Grid item xs={7}>{JSON.stringify(data.apiClientAuthorization.scopes || '(none)')}</Grid> <Grid item xs={5}>User ID</Grid> <Grid item xs={7}>{data.apiClientAuthorization.userId || '(none)'}</Grid> <Grid item xs={5}>Created at</Grid> <Grid item xs={7}>{formatDate(data.apiClientAuthorization.createdAt) || '(none)'}</Grid> <Grid item xs={5}>Updated at</Grid> <Grid item xs={7}>{formatDate(data.apiClientAuthorization.updatedAt) || '(none)'}</Grid> </Grid>} </DialogContent> <DialogActions> <Button variant='text' color='primary' onClick={closeDialog}> Close </Button> </DialogActions> </Dialog> );