2022-02-05 13:46:24 +01:00
|
|
|
import { faArrowAltCircleRight as linkIcon } from '@fortawesome/free-regular-svg-icons';
|
2022-02-05 10:46:46 +01:00
|
|
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
2023-03-18 10:17:17 +01:00
|
|
|
import type { FC, PropsWithChildren, ReactNode } from 'react';
|
2023-02-18 11:11:01 +01:00
|
|
|
import { Link } from 'react-router-dom';
|
2023-03-18 10:17:17 +01:00
|
|
|
import { Card, CardText, CardTitle, UncontrolledTooltip } from 'reactstrap';
|
2023-07-29 10:43:15 +02:00
|
|
|
import { useElementRef } from '../../utils/helpers/hooks';
|
2022-02-05 10:04:34 +01:00
|
|
|
import './HighlightCard.scss';
|
|
|
|
|
2022-04-24 10:39:11 +02:00
|
|
|
export type HighlightCardProps = PropsWithChildren<{
|
2022-02-05 10:04:34 +01:00
|
|
|
title: string;
|
2023-07-24 18:10:22 +02:00
|
|
|
link: string;
|
2023-03-18 10:17:17 +01:00
|
|
|
tooltip?: ReactNode;
|
2022-04-24 10:39:11 +02:00
|
|
|
}>;
|
2022-02-05 10:04:34 +01:00
|
|
|
|
2023-07-24 18:10:22 +02:00
|
|
|
const buildExtraProps = (link: string) => ({ tag: Link, to: link });
|
2022-02-05 10:46:46 +01:00
|
|
|
|
2023-03-18 10:17:17 +01:00
|
|
|
export const HighlightCard: FC<HighlightCardProps> = ({ children, title, link, tooltip }) => {
|
|
|
|
const ref = useElementRef<HTMLElement>();
|
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<Card innerRef={ref} className="highlight-card" body {...buildExtraProps(link)}>
|
2023-07-24 18:10:22 +02:00
|
|
|
<FontAwesomeIcon size="3x" className="highlight-card__link-icon" icon={linkIcon} />
|
2023-03-18 10:17:17 +01:00
|
|
|
<CardTitle tag="h5" className="highlight-card__title">{title}</CardTitle>
|
|
|
|
<CardText tag="h2">{children}</CardText>
|
|
|
|
</Card>
|
|
|
|
{tooltip && <UncontrolledTooltip target={ref} placement="bottom">{tooltip}</UncontrolledTooltip>}
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|