import React, { Component } from 'react'; import { bindActionCreators } from 'redux'; import { connect } from 'react-redux'; import { createSelector, createStructuredSelector } from 'reselect'; import { List, Map } from 'immutable'; import pure from 'pure-render-decorator'; import ChatTitle from '../components/ChatTitle'; import Search from '../components/Search'; import MessageBox from '../components/MessageBox'; import MessageInput from '../components/MessageInput'; import UserList from '../components/UserList'; import { part } from '../actions/channel'; import { openPrivateChat, closePrivateChat } from '../actions/privateChat'; import { searchMessages, toggleSearch } from '../actions/search'; import { select, setSelectedChannel, setSelectedUser } from '../actions/tab'; import { runCommand, sendMessage, updateMessageHeight } from '../actions/message'; import { disconnect } from '../actions/server'; import { setWrapWidth, setCharWidth } from '../actions/environment'; import { stringWidth } from '../util'; import { toggleUserList } from '../actions/ui'; import * as inputHistoryActions from '../actions/inputHistory'; function updateSelected({ params, dispatch }) { if (params.channel) { dispatch(setSelectedChannel(params.server, params.channel)); } else if (params.user) { dispatch(setSelectedUser(params.server, params.user)); } else if (params.server) { dispatch(setSelectedChannel(params.server)); } } function updateCharWidth() { const charWidth = stringWidth(' ', '16px Roboto Mono'); window.messageIndent = 6 * charWidth; return setCharWidth(charWidth); } @pure class Chat extends Component { componentWillMount() { const { dispatch } = this.props; dispatch(updateCharWidth()); setTimeout(() => dispatch(updateCharWidth()), 1000); } componentDidMount() { updateSelected(this.props); } componentWillReceiveProps(nextProps) { if (nextProps.params.server !== this.props.params.server || nextProps.params.channel !== this.props.params.channel || nextProps.params.user !== this.props.params.user) { updateSelected(nextProps); } } handleSearch = phrase => { const { dispatch, tab } = this.props; if (tab.channel) { dispatch(searchMessages(tab.server, tab.channel, phrase)); } }; render() { const { title, tab, channel, search, history, messages, users, showUserList, inputActions } = this.props; let chatClass; if (tab.channel) { chatClass = 'chat-channel'; } else if (tab.user) { chatClass = 'chat-private'; } else { chatClass = 'chat-server'; } return (