import { FC, useEffect } from 'react'; import Message from '../utils/Message'; import { Result } from '../utils/Result'; import { ShlinkApiError } from '../api/ShlinkApiError'; import { SimpleCard } from '../utils/SimpleCard'; import SearchField from '../utils/SearchField'; import { ShlinkDomainRedirects } from '../api/types'; import { SelectedServer } from '../servers/data'; import { DomainsList } from './reducers/domainsList'; import { DomainRow } from './DomainRow'; interface ManageDomainsProps { listDomains: Function; filterDomains: (searchTerm: string) => void; editDomainRedirects: (domain: string, redirects: Partial) => Promise; checkDomainHealth: (domain: string) => void; domainsList: DomainsList; selectedServer: SelectedServer; } const headers = ['', 'Domain', 'Base path redirect', 'Regular 404 redirect', 'Invalid short URL redirect', '', '']; export const ManageDomains: FC = ( { listDomains, domainsList, filterDomains, editDomainRedirects, checkDomainHealth, selectedServer }, ) => { const { filteredDomains: domains, defaultRedirects, loading, error, errorData } = domainsList; const resolvedDefaultRedirects = defaultRedirects ?? domains.find(({ isDefault }) => isDefault)?.redirects; useEffect(() => { listDomains(); }, []); if (loading) { return ; } const renderContent = () => { if (error) { return ( ); } return ( {headers.map((column, index) => )} {domains.length < 1 && } {domains.map((domain) => ( ))}
{column}
No results found
); }; return ( <> {renderContent()} ); };