summaryrefslogtreecommitdiffstats
path: root/webapp/components/rhs_root_post.jsx
diff options
context:
space:
mode:
authorbonespiked <dngreene@gmail.com>2017-04-01 17:00:30 -0400
committerJoram Wilander <jwawilander@gmail.com>2017-04-01 17:00:30 -0400
commitc3d095b465ed87c086409992ef78b62a06c09909 (patch)
treefc762abfae4b80451fbefb58b5abbd68481f6d29 /webapp/components/rhs_root_post.jsx
parent95da05a8c97332d8eff90c7587ed17a41966c5f0 (diff)
downloadchat-c3d095b465ed87c086409992ef78b62a06c09909.tar.gz
chat-c3d095b465ed87c086409992ef78b62a06c09909.tar.bz2
chat-c3d095b465ed87c086409992ef78b62a06c09909.zip
Add reaction picker (#5904)
Diffstat (limited to 'webapp/components/rhs_root_post.jsx')
-rw-r--r--webapp/components/rhs_root_post.jsx73
1 files changed, 69 insertions, 4 deletions
diff --git a/webapp/components/rhs_root_post.jsx b/webapp/components/rhs_root_post.jsx
index f07826d63..b298853d8 100644
--- a/webapp/components/rhs_root_post.jsx
+++ b/webapp/components/rhs_root_post.jsx
@@ -14,14 +14,17 @@ import UserStore from 'stores/user_store.jsx';
import TeamStore from 'stores/team_store.jsx';
import * as GlobalActions from 'actions/global_actions.jsx';
-import {flagPost, unflagPost, pinPost, unpinPost} from 'actions/post_actions.jsx';
+import {flagPost, unflagPost, pinPost, unpinPost, addReaction} from 'actions/post_actions.jsx';
import * as Utils from 'utils/utils.jsx';
import * as PostUtils from 'utils/post_utils.jsx';
+import EmojiPicker from 'components/emoji_picker/emoji_picker.jsx';
+import ReactDOM from 'react-dom';
+
import Constants from 'utils/constants.jsx';
import DelayedAction from 'utils/delayed_action.jsx';
-import {Tooltip, OverlayTrigger} from 'react-bootstrap';
+import {Tooltip, OverlayTrigger, Overlay} from 'react-bootstrap';
import {FormattedMessage} from 'react-intl';
@@ -37,6 +40,8 @@ export default class RhsRootPost extends React.Component {
this.unflagPost = this.unflagPost.bind(this);
this.pinPost = this.pinPost.bind(this);
this.unpinPost = this.unpinPost.bind(this);
+ this.reactEmojiClick = this.reactEmojiClick.bind(this);
+ this.emojiPickerClick = this.emojiPickerClick.bind(this);
this.canEdit = false;
this.canDelete = false;
@@ -45,7 +50,9 @@ export default class RhsRootPost extends React.Component {
this.state = {
currentTeamDisplayName: TeamStore.getCurrent().name,
width: '',
- height: ''
+ height: '',
+ showRHSEmojiPicker: false,
+ testStateObj: true
};
}
@@ -70,7 +77,7 @@ export default class RhsRootPost extends React.Component {
this.canEdit = false;
}
- shouldComponentUpdate(nextProps) {
+ shouldComponentUpdate(nextProps, nextState) {
if (nextProps.status !== this.props.status) {
return true;
}
@@ -107,6 +114,10 @@ export default class RhsRootPost extends React.Component {
return true;
}
+ if (this.state.showRHSEmojiPicker !== nextState.showRHSEmojiPicker) {
+ return true;
+ }
+
return false;
}
@@ -155,13 +166,30 @@ export default class RhsRootPost extends React.Component {
unpinPost(this.props.post.channel_id, this.props.post.id);
}
+ emojiPickerClick() {
+ this.setState({showRHSEmojiPicker: !this.state.showRHSEmojiPicker});
+ }
+
+ reactEmojiClick(emoji) {
+ const emojiName = emoji.name || emoji.aliases[0];
+ addReaction(this.props.post.channel_id, this.props.post.id, emojiName);
+ this.setState({showRHSEmojiPicker: false});
+ }
+
render() {
const post = this.props.post;
const user = this.props.user;
const mattermostLogo = Constants.MATTERMOST_ICON_SVG;
var timestamp = user ? user.last_picture_update : 0;
var channel = ChannelStore.get(post.channel_id);
+ let canReact = false;
const flagIcon = Constants.FLAG_ICON_SVG;
+ if (post.state !== Constants.POST_FAILED &&
+ post.state !== Constants.POST_LOADING &&
+ !Utils.isPostEphemeral(post) &&
+ Utils.isFeatureEnabled(Constants.PRE_RELEASE_FEATURES.EMOJI_PICKER_PREVIEW)) {
+ canReact = true;
+ }
this.canDelete = PostUtils.canDeletePost(post);
this.canEdit = PostUtils.canEditPost(post, this.editDisableAction);
@@ -195,6 +223,41 @@ export default class RhsRootPost extends React.Component {
}
}
+ let react;
+ let reactOverlay;
+
+ if (canReact) {
+ react = (
+ <span>
+ <a
+ href='#'
+ className='reacticon__container reaction'
+ onClick={this.emojiPickerClick}
+ ref='rhs_root_reacticon'
+ ><i className='fa fa-smile-o'/>
+ </a>
+ </span>
+
+ );
+ reactOverlay = (
+ <Overlay
+ id='rhs_react_overlay'
+ show={this.state.showRHSEmojiPicker}
+ placement='bottom'
+ rootClose={true}
+ container={this}
+ onHide={() => this.setState({showRHSEmojiPicker: false})}
+ target={() => ReactDOM.findDOMNode(this.refs.rhs_root_reacticon)}
+
+ >
+ <EmojiPicker
+ onEmojiClick={this.reactEmojiClick}
+ pickerLocation='react'
+ />
+ </Overlay>
+ );
+ }
+
var dropdownContents = [];
if (Utils.isMobile()) {
@@ -547,7 +610,9 @@ export default class RhsRootPost extends React.Component {
</OverlayTrigger>
</li>
<li className='col col__reply'>
+ {reactOverlay}
{rootOptions}
+ {react}
</li>
</ul>
<div className='post__body'>