2022-04-24 10:39:11 +02:00
|
|
|
import { FC, PropsWithChildren, useRef } from 'react';
|
2021-08-22 11:05:07 +02:00
|
|
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
|
|
import { faInfoCircle as infoIcon } from '@fortawesome/free-solid-svg-icons';
|
|
|
|
import { UncontrolledTooltip } from 'reactstrap';
|
2022-03-11 17:16:24 +01:00
|
|
|
import { Placement } from '@popperjs/core';
|
2022-06-06 20:46:51 +02:00
|
|
|
import { mutableRefToElementRef } from './helpers/components';
|
2021-08-22 11:05:07 +02:00
|
|
|
|
2022-04-24 10:39:11 +02:00
|
|
|
type InfoTooltipProps = PropsWithChildren<{
|
2021-08-22 11:05:07 +02:00
|
|
|
className?: string;
|
2022-03-11 17:16:24 +01:00
|
|
|
placement: Placement;
|
2022-04-24 10:39:11 +02:00
|
|
|
}>;
|
2021-08-22 11:05:07 +02:00
|
|
|
|
|
|
|
export const InfoTooltip: FC<InfoTooltipProps> = ({ className = '', placement, children }) => {
|
2022-06-06 20:46:51 +02:00
|
|
|
const ref = useRef<HTMLSpanElement | undefined>();
|
2021-08-22 11:05:07 +02:00
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
2022-06-06 20:46:51 +02:00
|
|
|
<span className={className} ref={mutableRefToElementRef(ref)}>
|
2021-08-22 11:05:07 +02:00
|
|
|
<FontAwesomeIcon icon={infoIcon} />
|
|
|
|
</span>
|
|
|
|
<UncontrolledTooltip target={(() => ref.current) as any} placement={placement}>{children}</UncontrolledTooltip>
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|