dispatch/client/src/js/components/MessageInput.js

53 lines
1.3 KiB
JavaScript
Raw Normal View History

import React, { PureComponent } from 'react';
2015-12-28 23:34:32 +00:00
export default class MessageInput extends PureComponent {
2015-12-28 23:34:32 +00:00
state = {
value: ''
};
2015-12-28 23:34:32 +00:00
handleKey = e => {
const { tab, runCommand, sendMessage,
add, reset, increment, decrement, currentHistoryEntry } = this.props;
2015-12-28 23:34:32 +00:00
2017-05-21 21:23:21 +00:00
if (e.key === 'Enter' && e.target.value) {
2015-12-28 23:34:32 +00:00
if (e.target.value[0] === '/') {
runCommand(e.target.value, tab.name, tab.server);
} else if (tab.name) {
sendMessage(e.target.value, tab.name, tab.server);
2015-12-28 23:34:32 +00:00
}
add(e.target.value);
reset();
2015-12-28 23:34:32 +00:00
this.setState({ value: '' });
2017-05-21 21:23:21 +00:00
} else if (e.key === 'ArrowUp') {
2015-12-28 23:34:32 +00:00
e.preventDefault();
increment();
2017-05-21 21:23:21 +00:00
} else if (e.key === 'ArrowDown') {
decrement();
} else if (currentHistoryEntry) {
2015-12-28 23:34:32 +00:00
this.setState({ value: e.target.value });
reset();
2015-12-28 23:34:32 +00:00
}
};
2015-12-28 23:34:32 +00:00
handleChange = e => {
this.setState({ value: e.target.value });
};
2015-12-28 23:34:32 +00:00
render() {
const { nick, currentHistoryEntry } = this.props;
2015-12-28 23:34:32 +00:00
return (
<div className="message-input-wrap">
2017-05-15 20:51:21 +00:00
<span className="message-input-nick">{nick}</span>
2015-12-28 23:34:32 +00:00
<input
className="message-input"
type="text"
value={currentHistoryEntry || this.state.value}
2015-12-28 23:34:32 +00:00
onKeyDown={this.handleKey}
onChange={this.handleChange}
/>
</div>
);
}
}