import React from 'react'; import { connect } from 'react-redux'; import { defineMessages, injectIntl, FormattedMessage } from 'react-intl'; import ImmutablePureComponent from 'react-immutable-pure-component'; import Column from '../ui/components/column'; import ColumnSubheading from '../ui/components/column_subheading'; import ScrollableList from '../../components/scrollable_list'; import Icon from 'soapbox/components/icon'; import Search from './components/search'; import Account from './components/account'; import { removeFromAliases } from '../../actions/aliases'; 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 mapStateToProps = state => ({ aliases: state.getIn(['meta', 'pleroma', 'also_known_as']), searchAccountIds: state.getIn(['aliases', 'suggestions', 'items']), loaded: state.getIn(['aliases', 'suggestions', 'loaded']), }); export default @connect(mapStateToProps) @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}
))}
); } }