2019-03-17 17:48:05 +01:00
|
|
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
|
|
import { faInfoCircle as infoIcon } from '@fortawesome/free-solid-svg-icons';
|
2021-02-20 13:22:45 +01:00
|
|
|
import { ModalBody, ModalHeader } from 'reactstrap';
|
2020-03-28 17:33:23 +01:00
|
|
|
import { useToggle } from '../utils/helpers/hooks';
|
2021-02-20 13:22:45 +01:00
|
|
|
import { BlurredModal } from '../utils/BlurredModal';
|
|
|
|
import './UseExistingIfFoundInfoIcon.scss';
|
2019-03-17 17:48:05 +01:00
|
|
|
|
2020-08-30 19:45:17 +02:00
|
|
|
const InfoModal = ({ isOpen, toggle }: { isOpen: boolean; toggle: () => void }) => (
|
2021-02-20 13:22:45 +01:00
|
|
|
<BlurredModal isOpen={isOpen} toggle={toggle} centered size="lg">
|
2019-03-17 17:48:05 +01:00
|
|
|
<ModalHeader toggle={toggle}>Info</ModalHeader>
|
|
|
|
<ModalBody>
|
|
|
|
<p>
|
|
|
|
When the
|
|
|
|
<b><i>"Use existing URL if found"</i></b>
|
|
|
|
checkbox is checked, the server will return an existing short URL if it matches provided params.
|
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
These are the checks performed by Shlink in order to determine if an existing short URL should be returned:
|
|
|
|
</p>
|
|
|
|
<ul>
|
|
|
|
<li>
|
|
|
|
When only the long URL is provided: The most recent match will be returned, or a new short URL will be created
|
2019-10-05 09:02:02 +02:00
|
|
|
if none is found.
|
2019-03-17 17:48:05 +01:00
|
|
|
</li>
|
|
|
|
<li>
|
2019-10-05 10:20:33 +02:00
|
|
|
When long URL and custom slug and/or domain are provided: Same as in previous case, but it will try to match
|
|
|
|
the short URL using both the long URL and the slug, the long URL and the domain, or the three of them.
|
2019-03-17 17:48:05 +01:00
|
|
|
<br />
|
|
|
|
If the slug is being used by another long URL, an error will be returned.
|
|
|
|
</li>
|
|
|
|
<li>
|
|
|
|
When other params are provided: Same as in previous cases, but it will try to match existing short URLs with
|
|
|
|
all provided data. If any of them does not match, a new short URL will be created
|
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
</ModalBody>
|
2021-02-20 13:22:45 +01:00
|
|
|
</BlurredModal>
|
2019-03-17 17:48:05 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
const UseExistingIfFoundInfoIcon = () => {
|
2020-04-05 12:18:41 +02:00
|
|
|
const [ isModalOpen, toggleModal ] = useToggle();
|
2019-03-17 17:48:05 +01:00
|
|
|
|
|
|
|
return (
|
2020-11-13 22:44:26 +01:00
|
|
|
<>
|
2019-03-17 17:48:05 +01:00
|
|
|
<span title="What does this mean?">
|
|
|
|
<FontAwesomeIcon icon={infoIcon} style={{ cursor: 'pointer' }} onClick={toggleModal} />
|
|
|
|
</span>
|
2020-08-30 19:45:17 +02:00
|
|
|
<InfoModal isOpen={isModalOpen} toggle={toggleModal} />
|
2020-11-13 22:44:26 +01:00
|
|
|
</>
|
2019-03-17 17:48:05 +01:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default UseExistingIfFoundInfoIcon;
|