2023-02-18 12:40:37 +03:00
|
|
|
import type { FC } from 'react';
|
|
|
|
import { useEffect } from 'react';
|
2023-07-16 09:47:10 +03:00
|
|
|
import { ShlinkApiError } from '../../api/ShlinkApiError';
|
|
|
|
import type { SelectedServer } from '../../servers/data';
|
|
|
|
import { Message } from '../../utils/Message';
|
|
|
|
import { Result } from '../../utils/Result';
|
|
|
|
import { SearchField } from '../../utils/SearchField';
|
|
|
|
import { SimpleCard } from '../../utils/SimpleCard';
|
2023-02-18 13:11:01 +03:00
|
|
|
import { DomainRow } from './DomainRow';
|
2023-02-18 12:40:37 +03:00
|
|
|
import type { EditDomainRedirects } from './reducers/domainRedirects';
|
|
|
|
import type { DomainsList } from './reducers/domainsList';
|
2021-08-20 18:30:07 +03:00
|
|
|
|
|
|
|
interface ManageDomainsProps {
|
|
|
|
listDomains: Function;
|
2021-08-21 18:53:06 +03:00
|
|
|
filterDomains: (searchTerm: string) => void;
|
2022-11-04 19:10:02 +03:00
|
|
|
editDomainRedirects: (redirects: EditDomainRedirects) => Promise<void>;
|
2021-12-26 15:53:17 +03:00
|
|
|
checkDomainHealth: (domain: string) => void;
|
2021-08-20 18:30:07 +03:00
|
|
|
domainsList: DomainsList;
|
2021-12-09 15:44:29 +03:00
|
|
|
selectedServer: SelectedServer;
|
2021-08-20 18:30:07 +03:00
|
|
|
}
|
|
|
|
|
2022-03-26 14:17:42 +03:00
|
|
|
const headers = ['', 'Domain', 'Base path redirect', 'Regular 404 redirect', 'Invalid short URL redirect', '', ''];
|
2021-08-20 18:30:07 +03:00
|
|
|
|
2021-08-21 18:53:06 +03:00
|
|
|
export const ManageDomains: FC<ManageDomainsProps> = (
|
2021-12-26 15:53:17 +03:00
|
|
|
{ listDomains, domainsList, filterDomains, editDomainRedirects, checkDomainHealth, selectedServer },
|
2021-08-21 18:53:06 +03:00
|
|
|
) => {
|
2021-12-09 15:44:29 +03:00
|
|
|
const { filteredDomains: domains, defaultRedirects, loading, error, errorData } = domainsList;
|
|
|
|
const resolvedDefaultRedirects = defaultRedirects ?? domains.find(({ isDefault }) => isDefault)?.redirects;
|
2021-08-20 18:30:07 +03:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
listDomains();
|
|
|
|
}, []);
|
|
|
|
|
2021-08-21 18:53:06 +03:00
|
|
|
if (loading) {
|
|
|
|
return <Message loading />;
|
|
|
|
}
|
2021-08-20 18:30:07 +03:00
|
|
|
|
2021-08-21 18:53:06 +03:00
|
|
|
const renderContent = () => {
|
2021-08-20 18:30:07 +03:00
|
|
|
if (error) {
|
|
|
|
return (
|
|
|
|
<Result type="error">
|
2021-08-21 18:53:06 +03:00
|
|
|
<ShlinkApiError errorData={errorData} fallbackMessage="Error loading domains :(" />
|
2021-08-20 18:30:07 +03:00
|
|
|
</Result>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<SimpleCard>
|
2022-03-07 11:09:30 +03:00
|
|
|
<table className="table table-hover responsive-table mb-0">
|
2021-08-22 11:46:47 +03:00
|
|
|
<thead className="responsive-table__header">
|
2021-08-21 18:53:06 +03:00
|
|
|
<tr>{headers.map((column, index) => <th key={index}>{column}</th>)}</tr>
|
2021-08-20 18:30:07 +03:00
|
|
|
</thead>
|
|
|
|
<tbody>
|
2021-08-21 18:53:06 +03:00
|
|
|
{domains.length < 1 && <tr><td colSpan={headers.length} className="text-center">No results found</td></tr>}
|
2021-08-20 18:30:07 +03:00
|
|
|
{domains.map((domain) => (
|
2021-08-21 18:53:06 +03:00
|
|
|
<DomainRow
|
|
|
|
key={domain.domain}
|
|
|
|
domain={domain}
|
|
|
|
editDomainRedirects={editDomainRedirects}
|
2021-12-26 15:53:17 +03:00
|
|
|
checkDomainHealth={checkDomainHealth}
|
2021-12-09 15:44:29 +03:00
|
|
|
defaultRedirects={resolvedDefaultRedirects}
|
|
|
|
selectedServer={selectedServer}
|
2021-08-21 18:53:06 +03:00
|
|
|
/>
|
2021-08-20 18:30:07 +03:00
|
|
|
))}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</SimpleCard>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
2021-08-21 18:53:06 +03:00
|
|
|
<SearchField className="mb-3" onChange={filterDomains} />
|
2021-08-20 18:30:07 +03:00
|
|
|
{renderContent()}
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|