import React from 'react'; import { connect } from 'react-redux'; import PropTypes from 'prop-types'; import ImmutablePropTypes from 'react-immutable-proptypes'; import { injectIntl } from 'react-intl'; import { Link } from 'react-router-dom'; import ImmutablePureComponent from 'react-immutable-pure-component'; import Avatar from 'soapbox/components/avatar'; import { acctFull } from 'soapbox/utils/accounts'; import IconButton from 'soapbox/components/icon_button'; import { closeChat, toggleChat, } from 'soapbox/actions/chats'; import ChatBox from './chat_box'; import { shortNumberFormat } from 'soapbox/utils/numbers'; import HoverRefWrapper from 'soapbox/components/hover_ref_wrapper'; const mapStateToProps = (state, { pane }) => ({ me: state.get('me'), chat: state.getIn(['chats', pane.get('chat_id')]), }); export default @connect(mapStateToProps) @injectIntl class ChatWindow extends ImmutablePureComponent { static propTypes = { dispatch: PropTypes.func.isRequired, intl: PropTypes.object.isRequired, pane: ImmutablePropTypes.map.isRequired, idx: PropTypes.number, chat: ImmutablePropTypes.map, me: PropTypes.node, } state = { content: '', } handleChatClose = (chatId) => { return (e) => { this.props.dispatch(closeChat(chatId)); }; } handleChatToggle = (chatId) => { return (e) => { this.props.dispatch(toggleChat(chatId)); }; } handleContentChange = (e) => { this.setState({ content: e.target.value }); } handleInputRef = (el) => { this.inputElem = el; this.focusInput(); }; focusInput = () => { if (!this.inputElem) return; this.inputElem.focus(); } componentDidUpdate(prevProps) { const oldState = prevProps.pane.get('state'); const newState = this.props.pane.get('state'); if (oldState !== newState && newState === 'open') this.focusInput(); } render() { const { pane, idx, chat } = this.props; const account = pane.getIn(['chat', 'account']); if (!chat || !account) return null; const right = (285 * (idx + 1)) + 20; const unreadCount = chat.get('unread'); const unreadIcon = ( {shortNumberFormat(unreadCount)} ); const avatar = ( ); return (
{unreadCount > 0 ? unreadIcon : avatar }
); } }