2021-12-27 22:27:13 +01:00
|
|
|
import {
|
|
|
|
faCheck as checkIcon,
|
|
|
|
faCircleNotch as loadingStatusIcon,
|
2023-02-18 11:11:01 +01:00
|
|
|
faTimes as invalidIcon,
|
2021-12-27 22:27:13 +01:00
|
|
|
} from '@fortawesome/free-solid-svg-icons';
|
2023-02-18 11:11:01 +01:00
|
|
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
|
|
import type { FC } from 'react';
|
|
|
|
import { useEffect, useState } from 'react';
|
|
|
|
import { ExternalLink } from 'react-external-link';
|
|
|
|
import { UncontrolledTooltip } from 'reactstrap';
|
2023-07-29 10:43:15 +02:00
|
|
|
import { useElementRef } from '../../utils/helpers/hooks';
|
|
|
|
import type { MediaMatcher } from '../../utils/types';
|
2023-02-18 10:40:37 +01:00
|
|
|
import type { DomainStatus } from '../data';
|
2021-12-27 22:27:13 +01:00
|
|
|
|
2021-12-28 23:14:55 +01:00
|
|
|
interface DomainStatusIconProps {
|
|
|
|
status: DomainStatus;
|
|
|
|
matchMedia?: MediaMatcher;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const DomainStatusIcon: FC<DomainStatusIconProps> = ({ status, matchMedia = window.matchMedia }) => {
|
2023-01-10 20:04:47 +01:00
|
|
|
const ref = useElementRef<HTMLSpanElement>();
|
2021-12-28 23:14:55 +01:00
|
|
|
const matchesMobile = () => matchMedia('(max-width: 991px)').matches;
|
2022-03-26 12:17:42 +01:00
|
|
|
const [isMobile, setIsMobile] = useState<boolean>(matchesMobile());
|
2021-12-28 23:14:55 +01:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
const listener = () => setIsMobile(matchesMobile());
|
|
|
|
|
|
|
|
window.addEventListener('resize', listener);
|
|
|
|
|
|
|
|
return () => window.removeEventListener('resize', listener);
|
|
|
|
}, []);
|
2021-12-27 22:27:13 +01:00
|
|
|
|
|
|
|
if (status === 'validating') {
|
|
|
|
return <FontAwesomeIcon fixedWidth icon={loadingStatusIcon} spin />;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
2023-01-10 20:04:47 +01:00
|
|
|
<span ref={ref}>
|
2021-12-27 22:27:13 +01:00
|
|
|
{status === 'valid'
|
|
|
|
? <FontAwesomeIcon fixedWidth icon={checkIcon} className="text-muted" />
|
2021-12-28 22:54:17 +01:00
|
|
|
: <FontAwesomeIcon fixedWidth icon={invalidIcon} className="text-danger" />}
|
2021-12-27 22:27:13 +01:00
|
|
|
</span>
|
2021-12-28 23:14:55 +01:00
|
|
|
<UncontrolledTooltip
|
2023-01-10 20:04:47 +01:00
|
|
|
target={ref}
|
2021-12-28 23:14:55 +01:00
|
|
|
placement={isMobile ? 'top-start' : 'left'}
|
|
|
|
autohide={status === 'valid'}
|
|
|
|
>
|
2021-12-27 22:27:13 +01:00
|
|
|
{status === 'valid' ? 'Congratulations! This domain is properly configured.' : (
|
2021-12-28 22:48:35 +01:00
|
|
|
<span>
|
2021-12-27 22:27:13 +01:00
|
|
|
Oops! There is some missing configuration, and short URLs shared with this domain will not work.
|
|
|
|
<br />
|
2021-12-28 22:54:17 +01:00
|
|
|
Check the <ExternalLink href="https://slnk.to/multi-domain-docs">documentation</ExternalLink> in order to
|
2021-12-27 22:27:13 +01:00
|
|
|
find out what is missing.
|
2021-12-28 22:48:35 +01:00
|
|
|
</span>
|
2021-12-27 22:27:13 +01:00
|
|
|
)}
|
|
|
|
</UncontrolledTooltip>
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|