import { FC, useEffect } from 'react'; import { Button, UncontrolledTooltip } from 'reactstrap'; import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; import { faBan as forbiddenIcon, faDotCircle as defaultDomainIcon, faEdit as editIcon, } from '@fortawesome/free-solid-svg-icons'; import { ShlinkDomainRedirects } from '../api/types'; import { useToggle } from '../utils/helpers/hooks'; import { OptionalString } from '../utils/utils'; import { SelectedServer } from '../servers/data'; import { supportsDefaultDomainRedirectsEdition } from '../utils/helpers/features'; import { EditDomainRedirectsModal } from './helpers/EditDomainRedirectsModal'; import { Domain } from './data'; import { DomainStatusIcon } from './helpers/DomainStatusIcon'; interface DomainRowProps { domain: Domain; defaultRedirects?: ShlinkDomainRedirects; editDomainRedirects: (domain: string, redirects: Partial) => Promise; checkDomainHealth: (domain: string) => void; selectedServer: SelectedServer; } const Nr: FC<{ fallback: OptionalString }> = ({ fallback }) => ( {!fallback && No redirect} {fallback && <>{fallback} (as fallback)} ); const DefaultDomain: FC = () => ( <> Default domain ); export const DomainRow: FC = ( { domain, editDomainRedirects, checkDomainHealth, defaultRedirects, selectedServer }, ) => { const [ isOpen, toggle ] = useToggle(); const { domain: authority, isDefault, redirects, status } = domain; const canEditDomain = !isDefault || supportsDefaultDomainRedirectsEdition(selectedServer); useEffect(() => { checkDomainHealth(domain.domain); }, []); return ( {isDefault && } {authority} {redirects?.baseUrlRedirect ?? } {redirects?.regular404Redirect ?? } {redirects?.invalidShortUrlRedirect ?? } {!canEditDomain && ( Redirects for default domain cannot be edited here.
Use config options or env vars directly on the server.
)} ); };