import React from 'react'; import ImmutablePureComponent from 'react-immutable-pure-component'; import { defineMessages, injectIntl, FormattedMessage } from 'react-intl'; import { connect } from 'react-redux'; import Icon from 'soapbox/components/icon'; import { makeGetAccount } from 'soapbox/selectors'; import { removeFromAliases } from '../../actions/aliases'; import ScrollableList from '../../components/scrollable_list'; import Column from '../ui/components/column'; import ColumnSubheading from '../ui/components/column_subheading'; import Account from './components/account'; import Search from './components/search'; const messages = defineMessages({ heading: { id: 'column.aliases', defaultMessage: 'Account aliases' }, subheading_add_new: { id: 'column.aliases.subheading_add_new', defaultMessage: 'Add New Alias' }, create_error: { id: 'column.aliases.create_error', defaultMessage: 'Error creating alias' }, delete_error: { id: 'column.aliases.delete_error', defaultMessage: 'Error deleting alias' }, subheading_aliases: { id: 'column.aliases.subheading_aliases', defaultMessage: 'Current aliases' }, delete: { id: 'column.aliases.delete', defaultMessage: 'Delete' }, }); const makeMapStateToProps = () => { const getAccount = makeGetAccount(); const mapStateToProps = state => { const me = state.get('me'); const account = getAccount(state, me); return { aliases: account.getIn(['pleroma', 'also_known_as']), searchAccountIds: state.getIn(['aliases', 'suggestions', 'items']), loaded: state.getIn(['aliases', 'suggestions', 'loaded']), }; }; return mapStateToProps; }; export default @connect(makeMapStateToProps) @injectIntl class Aliases extends ImmutablePureComponent { handleFilterDelete = e => { const { dispatch, intl } = this.props; dispatch(removeFromAliases(intl, e.currentTarget.dataset.value)); } render() { const { intl, aliases, searchAccountIds, loaded } = this.props; const emptyMessage = ; return ( { loaded && searchAccountIds.size === 0 ? ( ) : ( {searchAccountIds.map(accountId => )} ) } {aliases.map((alias, i) => ( {alias} ))} ); } }