'use strict'; import React from 'react'; import { useIntl, defineMessages, FormattedMessage } from 'react-intl'; import { openModal } from 'soapbox/actions/modals'; import { Widget } from 'soapbox/components/ui'; import DropdownMenu from 'soapbox/containers/dropdown-menu-container'; import InstanceRestrictions from 'soapbox/features/federation_restrictions/components/instance_restrictions'; import { useAppSelector, useAppDispatch, useOwnAccount } from 'soapbox/hooks'; import { makeGetRemoteInstance } from 'soapbox/selectors'; const getRemoteInstance = makeGetRemoteInstance(); const messages = defineMessages({ editFederation: { id: 'remote_instance.edit_federation', defaultMessage: 'Edit federation' }, }); interface IInstanceModerationPanel { /** Host (eg "gleasonator.com") of the remote instance to moderate. */ host: string, } /** Widget for moderators to manage a remote instance. */ const InstanceModerationPanel: React.FC = ({ host }) => { const intl = useIntl(); const dispatch = useAppDispatch(); const account = useOwnAccount(); const remoteInstance = useAppSelector(state => getRemoteInstance(state, host)); const handleEditFederation = () => { dispatch(openModal('EDIT_FEDERATION', { host })); }; const makeMenu = () => { return [{ text: intl.formatMessage(messages.editFederation), action: handleEditFederation, icon: require('@tabler/icons/edit.svg'), }]; }; const menu = makeMenu(); return ( } action={account?.admin ? ( ) : undefined} > ); }; export default InstanceModerationPanel;