// Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 import React from 'react'; import { CustomStyleRulesCallback } from 'common/custom-theme'; import { Grid, IconButton, Link, Tooltip, Typography } from '@mui/material'; import { WithStyles } from '@mui/styles'; import withStyles from '@mui/styles/withStyles'; import { ApiClientAuthorization } from 'models/api-client-authorization'; import { CopyIcon, CloseIcon } from 'components/icon/icon'; import CopyToClipboard from 'react-copy-to-clipboard'; import { ArvadosTheme } from 'common/custom-theme'; import moment from 'moment'; type CssRules = 'sharingUrlText' | 'sharingUrlButton' | 'sharingUrlList' | 'sharingUrlRow'; const styles: CustomStyleRulesCallback = (theme: ArvadosTheme) => ({ sharingUrlText: { fontSize: '1rem', }, sharingUrlButton: { color: theme.palette.grey["500"], cursor: 'pointer', '& svg': { fontSize: '1rem' }, verticalAlign: 'middle', }, sharingUrlList: { marginTop: '-0.5rem', }, sharingUrlRow: { marginLeft: theme.spacing(1), borderBottom: `1px solid ${theme.palette.grey["300"]}`, }, }); export interface SharingURLsComponentDataProps { collectionUuid: string; sharingTokens: ApiClientAuthorization[]; sharingURLsPrefix: string; } export interface SharingURLsComponentActionProps { onDeleteSharingToken: (uuid: string) => void; onCopy: (message: string) => void; } export type SharingURLsComponentProps = SharingURLsComponentDataProps & SharingURLsComponentActionProps; export const SharingURLsComponent = withStyles(styles)((props: SharingURLsComponentProps & WithStyles) => {props.sharingTokens.length > 0 ? props.sharingTokens .sort((a, b) => (new Date(a.expiresAt).getTime() - new Date(b.expiresAt).getTime())) .map(token => { const url = props.sharingURLsPrefix.includes('*') ? `${props.sharingURLsPrefix.replace('*', props.collectionUuid)}/t=${token.apiToken}/_/` : `${props.sharingURLsPrefix}/c=${props.collectionUuid}/t=${token.apiToken}/_/`; const expDate = new Date(token.expiresAt); const urlLabel = !!token.expiresAt ? `Token ${token.apiToken.slice(0, 8)}... expiring at: ${expDate.toLocaleString()} (${moment(expDate).fromNow()})` : `Token ${token.apiToken.slice(0, 8)}... with no expiration date`; return ( {urlLabel} props.onCopy('Sharing URL copied')}> props.onDeleteSharingToken(token.uuid)} size="large"> ); }) : No sharing URLs} );