tweak chat emoji (#1019)
This commit is contained in:
parent
e84dfbaa33
commit
e9e6b1dc09
2 changed files with 19 additions and 11 deletions
|
@ -1,5 +1,5 @@
|
||||||
import React, { PropTypes, Component } from 'react'
|
import React, { PropTypes, Component } from 'react'
|
||||||
import { Picker } from 'emoji-mart'
|
import { Emoji, Picker } from 'emoji-mart'
|
||||||
import Util from '../../Metamaps/Util'
|
import Util from '../../Metamaps/Util'
|
||||||
|
|
||||||
class NewMessage extends Component {
|
class NewMessage extends Component {
|
||||||
|
@ -26,6 +26,7 @@ class NewMessage extends Component {
|
||||||
}})
|
}})
|
||||||
|
|
||||||
this.setState({ showEmojiPicker: false })
|
this.setState({ showEmojiPicker: false })
|
||||||
|
this.props.focusMessageInput()
|
||||||
}
|
}
|
||||||
|
|
||||||
render = () => {
|
render = () => {
|
||||||
|
@ -41,7 +42,7 @@ class NewMessage extends Component {
|
||||||
title="Emoji"
|
title="Emoji"
|
||||||
/>
|
/>
|
||||||
<div className="extra-message-options">
|
<div className="extra-message-options">
|
||||||
<span className="emoji-picker-button" onClick={this.toggleEmojiPicker}>🙃</span>
|
<span className="emoji-picker-button" onClick={this.toggleEmojiPicker}><Emoji size={24} emoji="upside_down_face" /></span>
|
||||||
</div>
|
</div>
|
||||||
<textarea value={this.textAreaValue()}
|
<textarea value={this.textAreaValue()}
|
||||||
onChange={this.props.handleChange}
|
onChange={this.props.handleChange}
|
||||||
|
@ -55,6 +56,7 @@ class NewMessage extends Component {
|
||||||
NewMessage.propTypes = {
|
NewMessage.propTypes = {
|
||||||
messageText: PropTypes.string,
|
messageText: PropTypes.string,
|
||||||
handleChange: PropTypes.func,
|
handleChange: PropTypes.func,
|
||||||
|
focusMessageInput: PropTypes.func,
|
||||||
textAreaProps: PropTypes.shape({
|
textAreaProps: PropTypes.shape({
|
||||||
className: PropTypes.string,
|
className: PropTypes.string,
|
||||||
ref: PropTypes.func,
|
ref: PropTypes.func,
|
||||||
|
|
|
@ -102,6 +102,11 @@ class MapChat extends Component {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
focusMessageInput = () => {
|
||||||
|
if (!this.messageInput) return
|
||||||
|
this.messageInput.focus()
|
||||||
|
}
|
||||||
|
|
||||||
render = () => {
|
render = () => {
|
||||||
const rightOffset = this.state.open ? '0' : '-300px'
|
const rightOffset = this.state.open ? '0' : '-300px'
|
||||||
const { conversationLive, isParticipating, participants, messages, inviteACall, inviteToJoin } = this.props
|
const { conversationLive, isParticipating, participants, messages, inviteACall, inviteToJoin } = this.props
|
||||||
|
@ -145,16 +150,17 @@ class MapChat extends Component {
|
||||||
<div className="chat-messages" ref={div => { this.messagesDiv = div }}>
|
<div className="chat-messages" ref={div => { this.messagesDiv = div }}>
|
||||||
{makeList(messages)}
|
{makeList(messages)}
|
||||||
</div>
|
</div>
|
||||||
<NewMessage textAreaProps={{
|
<NewMessage messageText={this.state.messageText}
|
||||||
className: 'chat-input',
|
focusMessageInput={this.focusMessageInput}
|
||||||
ref: textarea => { this.messageInput = textarea },
|
|
||||||
placeholder: 'Send a message...',
|
|
||||||
onKeyUp: this.handleTextareaKeyUp,
|
|
||||||
onFocus: this.props.inputFocus,
|
|
||||||
onBlur: this.props.inputBlur
|
|
||||||
}}
|
|
||||||
handleChange={this.handleChange('messageText')}
|
handleChange={this.handleChange('messageText')}
|
||||||
messageText={this.state.messageText}
|
textAreaProps={{
|
||||||
|
className: 'chat-input',
|
||||||
|
ref: textarea => { this.messageInput = textarea },
|
||||||
|
placeholder: 'Send a message...',
|
||||||
|
onKeyUp: this.handleTextareaKeyUp,
|
||||||
|
onFocus: this.props.inputFocus,
|
||||||
|
onBlur: this.props.inputBlur
|
||||||
|
}}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in a new issue