// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved. // See License.txt for license information. import ConfirmModal from './confirm_modal.jsx'; import TeamStore from 'stores/team_store.jsx'; import UserStore from 'stores/user_store.jsx'; import ChannelStore from 'stores/channel_store.jsx'; import {removeUserFromTeam, updateTeamMemberRoles} from 'actions/team_actions.jsx'; import {updateActive} from 'actions/user_actions.jsx'; import * as AsyncClient from 'utils/async_client.jsx'; import * as Utils from 'utils/utils.jsx'; import React from 'react'; import {FormattedMessage} from 'react-intl'; import {browserHistory} from 'react-router/es6'; export default class TeamMembersDropdown extends React.Component { constructor(props) { super(props); this.handleMakeMember = this.handleMakeMember.bind(this); this.handleRemoveFromTeam = this.handleRemoveFromTeam.bind(this); this.handleMakeActive = this.handleMakeActive.bind(this); this.handleMakeNotActive = this.handleMakeNotActive.bind(this); this.handleMakeAdmin = this.handleMakeAdmin.bind(this); this.handleDemote = this.handleDemote.bind(this); this.handleDemoteSubmit = this.handleDemoteSubmit.bind(this); this.handleDemoteCancel = this.handleDemoteCancel.bind(this); this.state = { serverError: null, showDemoteModal: false, user: null, role: null }; } handleMakeMember() { const me = UserStore.getCurrentUser(); if (this.props.user.id === me.id && me.roles.includes('system_admin')) { this.handleDemote(this.props.user, 'team_user'); } else { updateTeamMemberRoles( this.props.teamMember.team_id, this.props.user.id, 'team_user', () => { AsyncClient.getUser(this.props.user.id); }, (err) => { this.setState({serverError: err.message}); } ); } } handleRemoveFromTeam() { removeUserFromTeam( this.props.teamMember.team_id, this.props.user.id, () => { UserStore.removeProfileFromTeam(this.props.teamMember.team_id, this.props.user.id); UserStore.emitInTeamChange(); AsyncClient.getTeamStats(this.props.teamMember.team_id); }, (err) => { this.setState({serverError: err.message}); } ); } handleMakeActive() { updateActive(this.props.user.id, true, () => { AsyncClient.getChannelStats(ChannelStore.getCurrentId()); AsyncClient.getTeamStats(this.props.teamMember.team_id); }, (err) => { this.setState({serverError: err.message}); } ); } handleMakeNotActive() { updateActive(this.props.user.id, false, () => { AsyncClient.getChannelStats(ChannelStore.getCurrentId()); AsyncClient.getTeamStats(this.props.teamMember.team_id); }, (err) => { this.setState({serverError: err.message}); } ); } handleMakeAdmin() { const me = UserStore.getCurrentUser(); if (this.props.user.id === me.id && me.roles.includes('system_admin')) { this.handleDemote(this.props.user, 'team_user team_admin'); } else { updateTeamMemberRoles( this.props.teamMember.team_id, this.props.user.id, 'team_user team_admin', () => { AsyncClient.getUser(this.props.user.id); }, (err) => { this.setState({serverError: err.message}); } ); } } handleDemote(user, role, newRole) { this.setState({ serverError: this.state.serverError, showDemoteModal: true, user, role, newRole }); } handleDemoteCancel() { this.setState({ serverError: null, showDemoteModal: false, user: null, role: null, newRole: null }); } handleDemoteSubmit() { updateTeamMemberRoles( this.props.teamMember.team_id, this.props.user.id, this.state.newRole, () => { AsyncClient.getUser(this.props.user.id); const teamUrl = TeamStore.getCurrentTeamUrl(); if (teamUrl) { browserHistory.push(teamUrl); } else { browserHistory.push('/'); } }, (err) => { this.setState({serverError: err.message}); } ); } render() { let serverError = null; if (this.state.serverError) { serverError = (
); } const teamMember = this.props.teamMember; const user = this.props.user; let currentRoles = ( ); if (teamMember.roles.length > 0 && Utils.isAdmin(teamMember.roles)) { currentRoles = ( ); } if (user.roles.length > 0 && Utils.isSystemAdmin(user.roles)) { currentRoles = ( ); } const me = UserStore.getCurrentUser(); let showMakeMember = Utils.isAdmin(teamMember.roles) && !Utils.isSystemAdmin(user.roles); let showMakeAdmin = !Utils.isAdmin(teamMember.roles) && !Utils.isSystemAdmin(user.roles); let showMakeActive = false; let showMakeNotActive = Utils.isSystemAdmin(user.roles); if (user.delete_at > 0) { currentRoles = ( ); showMakeMember = false; showMakeAdmin = false; showMakeActive = true; showMakeNotActive = false; } let makeAdmin = null; if (showMakeAdmin) { makeAdmin = (
  • ); } let makeMember = null; if (showMakeMember) { makeMember = (
  • ); } let removeFromTeam = null; if (this.props.user.id !== me.id) { removeFromTeam = (
  • ); } const makeActive = null; if (showMakeActive) { // makeActive = ( //
  • // // // //
  • // ); } const makeNotActive = null; if (showMakeNotActive) { // makeNotActive = ( //
  • // // // //
  • // ); } let makeDemoteModal = null; if (this.props.user.id === me.id) { const title = ( ); const message = (


    {serverError}
    ); const confirmButton = ( ); makeDemoteModal = ( ); } if (!removeFromTeam && !makeAdmin && !makeMember && !makeActive && !makeNotActive) { return
    {currentRoles}
    ; } return (
    {currentRoles}
      {removeFromTeam} {makeAdmin} {makeMember} {makeActive} {makeNotActive}
    {makeDemoteModal} {serverError}
    ); } } TeamMembersDropdown.propTypes = { user: React.PropTypes.object.isRequired, teamMember: React.PropTypes.object.isRequired };