import React, { useCallback } from 'react'; import { defineMessages, useIntl } from 'react-intl'; import { addToAliases } from 'soapbox/actions/aliases'; import Avatar from 'soapbox/components/avatar'; import DisplayName from 'soapbox/components/display-name'; import IconButton from 'soapbox/components/icon-button'; import { useAppDispatch, useAppSelector } from 'soapbox/hooks'; import { makeGetAccount } from 'soapbox/selectors'; import { getFeatures } from 'soapbox/utils/features'; import type { List as ImmutableList } from 'immutable'; const messages = defineMessages({ add: { id: 'aliases.account.add', defaultMessage: 'Create alias' }, }); interface IAccount { accountId: string, aliases: ImmutableList } const Account: React.FC = ({ accountId, aliases }) => { const intl = useIntl(); const dispatch = useAppDispatch(); const getAccount = useCallback(makeGetAccount(), []); const account = useAppSelector((state) => getAccount(state, accountId)); const added = useAppSelector((state) => { const instance = state.instance; const features = getFeatures(instance); const account = getAccount(state, accountId); const apId = account?.pleroma.get('ap_id'); const name = features.accountMoving ? account?.acct : apId; return aliases.includes(name); }); const me = useAppSelector((state) => state.me); const handleOnAdd = () => dispatch(addToAliases(account!)); if (!account) return null; let button; if (!added && accountId !== me) { button = (
); } return (
{button}
); }; export default Account;