1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00
unleash.unleash/frontend/src/component/project/Project/ProjectInfo/MetaWidget.tsx

70 lines
2.4 KiB
TypeScript
Raw Normal View History

2023-01-27 13:00:23 +01:00
import { FC } from 'react';
import { Link as RouterLink } from 'react-router-dom';
import { Box, styled, Typography, Link } from '@mui/material';
import {
StyledProjectInfoWidgetContainer,
StyledWidgetTitle,
} from './ProjectInfo.styles';
import { ConditionallyRender } from 'component/common/ConditionallyRender/ConditionallyRender';
interface IMetaWidgetProps {
id?: string;
description?: string;
}
const StyledIDContainer = styled('div')(({ theme }) => ({
textAlign: 'left',
borderRadius: `${theme.shape.borderRadius}px`,
backgroundColor: `${theme.palette.secondaryContainer}`,
padding: theme.spacing(0.5, 2),
fontSize: theme.typography.body2.fontSize,
}));
export const MetaWidget: FC<IMetaWidgetProps> = ({ id, description }) => {
return (
<StyledProjectInfoWidgetContainer>
<StyledWidgetTitle>Project Meta</StyledWidgetTitle>
<StyledIDContainer>
<Typography
component="span"
variant="body2"
color="text.secondary"
>
ID:
</Typography>{' '}
<code data-loading>{id || '__________'}</code>
</StyledIDContainer>
<Typography mt={1.5} textAlign="left">
<ConditionallyRender
condition={Boolean(description)}
show={
<>
<Typography
component="span"
variant="body2"
color="text.secondary"
>
Description:{' '}
</Typography>
<Typography component="span" variant="body2">
{description}
</Typography>
</>
}
elseShow={
<Typography variant="body2" textAlign="center">
<Link
component={RouterLink}
to={`/projects/${id}/edit`}
>
Add description
</Link>
</Typography>
}
/>
</Typography>
</StyledProjectInfoWidgetContainer>
);
};