overleaf-cep/services/web/frontend/js/features/group-management/components/request-status.tsx
Tim Down 5c4cb50628 Merge pull request #24988 from overleaf/td-bs5-upgrade-and-rename
Apply minor upgrades to Bootstrap 5 and react-bootstrap

GitOrigin-RevId: eb013f38515ebd4b9572d139f00841aca344e3c6
2025-05-16 08:05:28 +00:00

64 lines
2 KiB
TypeScript

import { useTranslation } from 'react-i18next'
import { Card, CardBody, Row, Col } from 'react-bootstrap'
import Button from '@/features/ui/components/bootstrap-5/button'
import MaterialIcon from '@/shared/components/material-icon'
import getMeta from '@/utils/meta'
import IconButton from '@/features/ui/components/bootstrap-5/icon-button'
import classnames from 'classnames'
type RequestStatusProps = {
icon: string
title: string
content?: React.ReactNode
variant?: 'primary' | 'danger'
}
function RequestStatus({ icon, title, content, variant }: RequestStatusProps) {
const { t } = useTranslation()
const groupName = getMeta('ol-groupName')
return (
<div className="container">
<Row>
<Col xxl={5} xl={6} lg={7} md={9} className="mx-auto">
<div className="group-heading" data-testid="group-heading">
<IconButton
variant="ghost"
href="/user/subscription"
size="lg"
icon="arrow_back"
accessibilityLabel={t('back_to_subscription')}
/>
<h2>{groupName || t('group_subscription')}</h2>
</div>
<Card>
<CardBody className="d-grid gap-3">
<div
className={classnames('card-icon', {
[`text-${variant}`]: variant,
})}
>
<MaterialIcon type={icon} />
</div>
<div className="d-grid gap-2 text-center">
<h3 className="mb-0 fw-bold" data-testid="title">
{title}
</h3>
{content && (
<div className="card-description-secondary">{content}</div>
)}
</div>
<div className="text-center">
<Button variant="secondary" href="/user/subscription">
{t('go_to_subscriptions')}
</Button>
</div>
</CardBody>
</Card>
</Col>
</Row>
</div>
)
}
export default RequestStatus