2023-02-18 13:11:01 +03:00
|
|
|
import { faArrowLeft } from '@fortawesome/free-solid-svg-icons';
|
|
|
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
2023-02-18 12:40:37 +03:00
|
|
|
import type { FC } from 'react';
|
|
|
|
import { useEffect, useMemo } from 'react';
|
2021-03-27 19:56:46 +03:00
|
|
|
import { ExternalLink } from 'react-external-link';
|
2022-02-06 22:07:18 +03:00
|
|
|
import { useLocation, useParams } from 'react-router-dom';
|
2023-02-18 13:11:01 +03:00
|
|
|
import { Button, Card } from 'reactstrap';
|
2023-07-24 21:14:59 +03:00
|
|
|
import { ShlinkApiError } from '../../src/api/ShlinkApiError';
|
|
|
|
import { useGoBack } from '../../src/utils/helpers/hooks';
|
|
|
|
import { parseQuery } from '../../src/utils/helpers/query';
|
|
|
|
import { Message } from '../../src/utils/Message';
|
|
|
|
import { Result } from '../../src/utils/Result';
|
2023-07-23 19:30:59 +03:00
|
|
|
import { useSetting } from '../utils/settings';
|
2023-02-18 13:11:01 +03:00
|
|
|
import type { ShortUrlIdentifier } from './data';
|
|
|
|
import { shortUrlDataFromShortUrl, urlDecodeShortCode } from './helpers';
|
2023-02-18 12:40:37 +03:00
|
|
|
import type { ShortUrlDetail } from './reducers/shortUrlDetail';
|
|
|
|
import type { EditShortUrl as EditShortUrlInfo, ShortUrlEdition } from './reducers/shortUrlEdition';
|
2023-02-18 13:11:01 +03:00
|
|
|
import type { ShortUrlFormProps } from './ShortUrlForm';
|
2021-03-20 18:32:12 +03:00
|
|
|
|
2022-02-06 22:07:18 +03:00
|
|
|
interface EditShortUrlConnectProps {
|
2021-03-20 18:32:12 +03:00
|
|
|
shortUrlDetail: ShortUrlDetail;
|
2021-03-27 12:27:46 +03:00
|
|
|
shortUrlEdition: ShortUrlEdition;
|
2022-11-06 21:16:51 +03:00
|
|
|
getShortUrlDetail: (shortUrl: ShortUrlIdentifier) => void;
|
2022-11-06 14:32:55 +03:00
|
|
|
editShortUrl: (editShortUrl: EditShortUrlInfo) => void;
|
2021-03-20 18:32:12 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
export const EditShortUrl = (ShortUrlForm: FC<ShortUrlFormProps>) => ({
|
|
|
|
shortUrlDetail,
|
|
|
|
getShortUrlDetail,
|
2021-03-27 12:27:46 +03:00
|
|
|
shortUrlEdition,
|
2021-03-27 11:49:47 +03:00
|
|
|
editShortUrl,
|
2021-03-20 18:32:12 +03:00
|
|
|
}: EditShortUrlConnectProps) => {
|
2022-02-06 22:07:18 +03:00
|
|
|
const { search } = useLocation();
|
|
|
|
const params = useParams<{ shortCode: string }>();
|
|
|
|
const goBack = useGoBack();
|
2021-03-20 18:32:12 +03:00
|
|
|
const { loading, error, errorData, shortUrl } = shortUrlDetail;
|
2022-11-06 14:32:55 +03:00
|
|
|
const { saving, saved, error: savingError, errorData: savingErrorData } = shortUrlEdition;
|
2021-03-20 18:32:12 +03:00
|
|
|
const { domain } = parseQuery<{ domain?: string }>(search);
|
2023-07-23 19:30:59 +03:00
|
|
|
const shortUrlCreationSettings = useSetting('shortUrlCreation');
|
2021-03-27 20:56:24 +03:00
|
|
|
const initialState = useMemo(
|
2022-06-12 21:41:40 +03:00
|
|
|
() => shortUrlDataFromShortUrl(shortUrl, shortUrlCreationSettings),
|
2022-03-26 14:17:42 +03:00
|
|
|
[shortUrl, shortUrlCreationSettings],
|
2021-03-27 20:56:24 +03:00
|
|
|
);
|
2021-03-20 18:32:12 +03:00
|
|
|
|
|
|
|
useEffect(() => {
|
2022-11-06 21:16:51 +03:00
|
|
|
params.shortCode && getShortUrlDetail({ shortCode: urlDecodeShortCode(params.shortCode), domain });
|
2021-03-20 18:32:12 +03:00
|
|
|
}, []);
|
|
|
|
|
|
|
|
if (loading) {
|
|
|
|
return <Message loading />;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
return (
|
|
|
|
<Result type="error">
|
|
|
|
<ShlinkApiError errorData={errorData} fallbackMessage="An error occurred while loading short URL detail :(" />
|
|
|
|
</Result>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2021-03-27 12:41:13 +03:00
|
|
|
<>
|
2021-03-27 19:56:46 +03:00
|
|
|
<header className="mb-3">
|
|
|
|
<Card body>
|
|
|
|
<h2 className="d-sm-flex justify-content-between align-items-center mb-0">
|
2022-03-05 15:26:28 +03:00
|
|
|
<Button color="link" size="lg" className="p-0 me-3" onClick={goBack}>
|
2021-03-27 19:56:46 +03:00
|
|
|
<FontAwesomeIcon icon={faArrowLeft} />
|
|
|
|
</Button>
|
2021-05-08 11:56:20 +03:00
|
|
|
<span className="text-center">
|
|
|
|
<small>Edit <ExternalLink href={shortUrl?.shortUrl ?? ''} /></small>
|
|
|
|
</span>
|
2021-03-27 19:56:46 +03:00
|
|
|
<span />
|
|
|
|
</h2>
|
|
|
|
</Card>
|
|
|
|
</header>
|
2021-03-27 12:41:13 +03:00
|
|
|
<ShortUrlForm
|
2021-03-27 20:56:24 +03:00
|
|
|
initialState={initialState}
|
2021-03-27 12:41:13 +03:00
|
|
|
saving={saving}
|
|
|
|
mode="edit"
|
2021-05-08 11:56:20 +03:00
|
|
|
onSave={async (shortUrlData) => {
|
|
|
|
if (!shortUrl) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2022-11-06 14:32:55 +03:00
|
|
|
editShortUrl({ ...shortUrl, data: shortUrlData });
|
2021-05-08 11:56:20 +03:00
|
|
|
}}
|
2021-03-27 12:41:13 +03:00
|
|
|
/>
|
2022-11-06 14:32:55 +03:00
|
|
|
{saved && savingError && (
|
2021-03-27 12:27:46 +03:00
|
|
|
<Result type="error" className="mt-3">
|
|
|
|
<ShlinkApiError errorData={savingErrorData} fallbackMessage="An error occurred while updating short URL :(" />
|
|
|
|
</Result>
|
|
|
|
)}
|
2022-11-06 14:32:55 +03:00
|
|
|
{saved && !savingError && <Result type="success" className="mt-3">Short URL properly edited.</Result>}
|
2021-03-27 12:41:13 +03:00
|
|
|
</>
|
2021-03-20 18:32:12 +03:00
|
|
|
);
|
|
|
|
};
|