import React, { useState } from 'react'; import { defineMessages, useIntl } from 'react-intl'; import ScrollableList from 'soapbox/components/scrollable_list'; import Accordion from 'soapbox/features/ui/components/accordion'; import { useAppSelector } from 'soapbox/hooks'; import { makeGetHosts } from 'soapbox/selectors'; import { federationRestrictionsDisclosed } from 'soapbox/utils/state'; import Column from '../ui/components/column'; import RestrictedInstance from './components/restricted_instance'; import type { OrderedSet as ImmutableOrderedSet } from 'immutable'; const messages = defineMessages({ heading: { id: 'column.federation_restrictions', defaultMessage: 'Federation Restrictions' }, boxTitle: { id: 'federation_restrictions.explanation_box.title', defaultMessage: 'Instance-specific policies' }, boxMessage: { id: 'federation_restrictions.explanation_box.message', defaultMessage: 'Normally servers on the Fediverse can communicate freely. {siteTitle} has imposed restrictions on the following servers.' }, emptyMessage: { id: 'federation_restrictions.empty_message', defaultMessage: '{siteTitle} has not restricted any instances.' }, notDisclosed: { id: 'federation_restrictions.not_disclosed_message', defaultMessage: '{siteTitle} does not disclose federation restrictions through the API.' }, }); const getHosts = makeGetHosts(); const FederationRestrictions = () => { const intl = useIntl(); const siteTitle = useAppSelector((state) => state.instance.get('title')); const hosts = useAppSelector((state) => getHosts(state)) as ImmutableOrderedSet; const disclosed = useAppSelector((state) => federationRestrictionsDisclosed(state)); const [explanationBoxExpanded, setExplanationBoxExpanded] = useState(true); const toggleExplanationBox = (setting: boolean) => { setExplanationBoxExpanded(setting); }; const emptyMessage = disclosed ? messages.emptyMessage : messages.notDisclosed; return ( {intl.formatMessage(messages.boxMessage, { siteTitle })}
{hosts.map((host) => )}
); }; export default FederationRestrictions;