summaryrefslogtreecommitdiffstats
path: root/webapp/components/status_dropdown/status_dropdown.jsx
diff options
context:
space:
mode:
authorDavid Rojas Camaggi <drojascamaggi@gmail.com>2017-06-06 09:45:36 -0400
committerHarrison Healey <harrisonmhealey@gmail.com>2017-06-06 09:45:36 -0400
commit46fc47e520efeff328db9b125c5339baac7b88e5 (patch)
tree99482c33de3b18dbbb0f0964b67ba0f898afe153 /webapp/components/status_dropdown/status_dropdown.jsx
parent382ba0b0d18f67d473ad677f9b5151bc5e468e14 (diff)
downloadchat-46fc47e520efeff328db9b125c5339baac7b88e5.tar.gz
chat-46fc47e520efeff328db9b125c5339baac7b88e5.tar.bz2
chat-46fc47e520efeff328db9b125c5339baac7b88e5.zip
PLT 6416 Add StatusDropdown to profile picture in top left (#6327) (#6418)
* PLT-6416 the profile picture is always shown in the top left (#6327) * PLT-6416 Add status icon to profile picture in left sidebar (#6327) * PLT-6416 Add StatusDropdown to profile picture in top left (#6327) * Fixing theme stuff for status picker * PLT-6416 Automatically close status dropdown after selection (#6327) * PLT-6416 Avoid render status dropdown in sidebar if isMobile (#6327) * PLT-6416 Change icon for status change to caret-down (#6327) * PLT-6416 Update visibility of status dropdown after window size (#6327) * PLT-6416 Refactor status dropdown for better mouse usability (#6327) * PLT-6416 Change status dropdown to the redux way (#6327) * PLT-6416 Fix header style of admin sidebar (#6327)
Diffstat (limited to 'webapp/components/status_dropdown/status_dropdown.jsx')
-rw-r--r--webapp/components/status_dropdown/status_dropdown.jsx158
1 files changed, 158 insertions, 0 deletions
diff --git a/webapp/components/status_dropdown/status_dropdown.jsx b/webapp/components/status_dropdown/status_dropdown.jsx
new file mode 100644
index 000000000..4b173a0ea
--- /dev/null
+++ b/webapp/components/status_dropdown/status_dropdown.jsx
@@ -0,0 +1,158 @@
+// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
+// See License.txt for license information.
+
+import React from 'react';
+import {Dropdown} from 'react-bootstrap';
+import StatusIcon from 'components/status_icon.jsx';
+import PropTypes from 'prop-types';
+import {FormattedMessage} from 'react-intl';
+import {UserStatuses} from 'utils/constants.jsx';
+import BootstrapSpan from 'components/bootstrap_span.jsx';
+
+export default class StatusDropdown extends React.Component {
+
+ static propTypes = {
+ style: PropTypes.object,
+ status: PropTypes.string,
+ userId: PropTypes.string.isRequired,
+ profilePicture: PropTypes.string,
+ actions: PropTypes.shape({
+ setStatus: PropTypes.func.isRequired
+ }).isRequired
+ }
+
+ state = {
+ showDropdown: false,
+ mouseOver: false
+ }
+
+ onMouseEnter = () => {
+ this.setState({mouseOver: true});
+ }
+
+ onMouseLeave = () => {
+ this.setState({mouseOver: false});
+ }
+
+ onToggle = (showDropdown) => {
+ this.setState({showDropdown});
+ }
+
+ closeDropdown = () => {
+ this.setState({showDropdown: false});
+ }
+
+ setStatus = (status) => {
+ this.props.actions.setStatus({
+ user_id: this.props.userId,
+ status
+ });
+ this.closeDropdown();
+ }
+
+ setOnline = (event) => {
+ event.preventDefault();
+ this.setStatus(UserStatuses.ONLINE);
+ }
+
+ setOffline = (event) => {
+ event.preventDefault();
+ this.setStatus(UserStatuses.OFFLINE);
+ }
+
+ setAway = (event) => {
+ event.preventDefault();
+ this.setStatus(UserStatuses.AWAY);
+ }
+
+ renderStatusOnlineAction = () => {
+ return this.renderStatusAction(UserStatuses.ONLINE, this.setOnline);
+ }
+
+ renderStatusAwayAction = () => {
+ return this.renderStatusAction(UserStatuses.AWAY, this.setAway);
+ }
+
+ renderStatusOfflineAction = () => {
+ return this.renderStatusAction(UserStatuses.OFFLINE, this.setOffline);
+ }
+
+ renderProfilePicture = () => {
+ if (!this.props.profilePicture) {
+ return null;
+ }
+ return (
+ <img
+ className='user__picture'
+ src={this.props.profilePicture}
+ />
+ );
+ }
+
+ renderStatusAction = (status, onClick) => {
+ return (
+ <li key={status}>
+ <a
+ href={'#'}
+ onClick={onClick}
+ >
+ <FormattedMessage
+ id={`status_dropdown.set_${status}`}
+ defaultMessage={status}
+ />
+ </a>
+ </li>
+ );
+ }
+
+ renderStatusIcon = () => {
+ if (this.state.mouseOver) {
+ return (
+ <span className={'status status-edit'}>
+ <i
+ className={'fa fa-caret-down'}
+ />
+ </span>
+ );
+ }
+ return (
+ <StatusIcon
+ status={this.props.status}
+ />
+ );
+ }
+
+ render() {
+ const statusIcon = this.renderStatusIcon();
+ const profilePicture = this.renderProfilePicture();
+ const actions = [
+ this.renderStatusOnlineAction(),
+ this.renderStatusAwayAction(),
+ this.renderStatusOfflineAction()
+ ];
+ return (
+ <Dropdown
+ id={'status-dropdown'}
+ open={this.state.showDropdown}
+ onToggle={this.onToggle}
+ style={this.props.style}
+ >
+ <BootstrapSpan
+ bsRole={'toggle'}
+ onMouseEnter={this.onMouseEnter}
+ onMouseLeave={this.onMouseLeave}
+ >
+ <div className='status-wrapper'>
+ {profilePicture}
+ <div className='status_dropdown__toggle'>
+ {statusIcon}
+ </div>
+ </div>
+ </BootstrapSpan>
+ <Dropdown.Menu>
+ {actions}
+ </Dropdown.Menu>
+ </Dropdown>
+ );
+ }
+}