mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-12-12 23:59:10 -06:00
62 lines
1.7 KiB
TypeScript
62 lines
1.7 KiB
TypeScript
import { faCopy as copyIcon } from '@fortawesome/free-regular-svg-icons';
|
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
import { isNil } from 'ramda';
|
|
import React, { useEffect } from 'react';
|
|
import CopyToClipboard from 'react-copy-to-clipboard';
|
|
import { Card, CardBody, Tooltip } from 'reactstrap';
|
|
import { ShortUrlCreation } from '../reducers/shortUrlCreation';
|
|
import './CreateShortUrlResult.scss';
|
|
import { StateFlagTimeout } from '../../utils/helpers/hooks';
|
|
|
|
interface CreateShortUrlResultProps extends ShortUrlCreation {
|
|
resetCreateShortUrl: Function;
|
|
}
|
|
|
|
const CreateShortUrlResult = (useStateFlagTimeout: StateFlagTimeout) => (
|
|
{ error, result, resetCreateShortUrl }: CreateShortUrlResultProps,
|
|
) => {
|
|
const [ showCopyTooltip, setShowCopyTooltip ] = useStateFlagTimeout();
|
|
|
|
useEffect(() => {
|
|
resetCreateShortUrl();
|
|
}, []);
|
|
|
|
if (error) {
|
|
return (
|
|
<Card body color="danger" inverse className="bg-danger mt-3">
|
|
An error occurred while creating the URL :(
|
|
</Card>
|
|
);
|
|
}
|
|
|
|
if (isNil(result)) {
|
|
return null;
|
|
}
|
|
|
|
const { shortUrl } = result;
|
|
|
|
return (
|
|
<Card inverse className="bg-main mt-3">
|
|
<CardBody>
|
|
<b>Great!</b> The short URL is <b>{shortUrl}</b>
|
|
|
|
<CopyToClipboard text={shortUrl} onCopy={setShowCopyTooltip}>
|
|
<button
|
|
className="btn btn-light btn-sm create-short-url-result__copy-btn"
|
|
id="copyBtn"
|
|
type="button"
|
|
>
|
|
<FontAwesomeIcon icon={copyIcon} /> Copy
|
|
</button>
|
|
</CopyToClipboard>
|
|
|
|
<Tooltip placement="left" isOpen={showCopyTooltip} target="copyBtn">
|
|
Copied!
|
|
</Tooltip>
|
|
</CardBody>
|
|
</Card>
|
|
);
|
|
};
|
|
|
|
export default CreateShortUrlResult;
|