import React from 'react'; import { connect } from 'react-redux'; import PropTypes from 'prop-types'; import ImmutablePropTypes from 'react-immutable-proptypes'; import ImmutablePureComponent from 'react-immutable-pure-component'; import { FormattedMessage } from 'react-intl'; import { List as ImmutableList } from 'immutable'; import { createSelector } from 'reselect'; import { injectIntl, defineMessages } from 'react-intl'; import { shortNumberFormat } from 'soapbox/utils/numbers'; import AudioToggle from 'soapbox/features/chats/components/audio_toggle'; import AccountSearch from 'soapbox/components/account_search'; import { openChat, launchChat, toggleMainWindow } from 'soapbox/actions/chats'; import { getSettings } from 'soapbox/actions/settings'; import ChatWindow from './chat_window'; import ChatList from './chat_list'; const messages = defineMessages({ searchPlaceholder: { id: 'chats.search_placeholder', defaultMessage: 'Start a chat with…' }, }); const getChatsUnreadCount = state => { const chats = state.getIn(['chats', 'items']); return chats.reduce((acc, curr) => acc + Math.min(curr.get('unread', 0), 1), 0); }; // Filter out invalid chats const normalizePanes = (chats, panes = ImmutableList()) => ( panes.filter(pane => chats.get(pane.get('chat_id'))) ); const makeNormalizeChatPanes = () => createSelector([ state => state.getIn(['chats', 'items']), state => getSettings(state).getIn(['chats', 'panes']), ], normalizePanes); const makeMapStateToProps = () => { const mapStateToProps = state => { const normalizeChatPanes = makeNormalizeChatPanes(); return { panes: normalizeChatPanes(state), mainWindowState: getSettings(state).getIn(['chats', 'mainWindow']), unreadCount: getChatsUnreadCount(state), }; }; return mapStateToProps; }; export default @connect(makeMapStateToProps) @injectIntl class ChatPanes extends ImmutablePureComponent { static contextTypes = { router: PropTypes.object, }; static propTypes = { intl: PropTypes.object.isRequired, dispatch: PropTypes.func.isRequired, mainWindowState: PropTypes.string, panes: ImmutablePropTypes.list, } handleClickChat = (chat) => { this.props.dispatch(openChat(chat.get('id'))); } handleSuggestion = accountId => { this.props.dispatch(launchChat(accountId, this.context.router.history)); } handleMainWindowToggle = () => { this.props.dispatch(toggleMainWindow()); } render() { const { intl, panes, mainWindowState, unreadCount } = this.props; const open = mainWindowState === 'open'; const mainWindowPane = (