mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
* Adding TeamMember to system * Fixing all unit tests on the backend * Fixing merge conflicts * Fixing merge conflict * Adding javascript unit tests * Adding TeamMember to system * Fixing all unit tests on the backend * Fixing merge conflicts * Fixing merge conflict * Adding javascript unit tests * Adding client side unit test * Cleaning up the clint side tests * Fixing msg * Adding more client side unit tests * Adding more using tests * Adding last bit of client side unit tests and adding make cmd * Fixing bad merge * Fixing libraries * Updating to new client side API * Fixing borken unit test * Fixing unit tests * ugg...trying to beat gofmt * ugg...trying to beat gofmt * Cleaning up remainder of the server side routes * Adding inital load api * Increased coverage of webhook unit tests (#2660) * Adding loading ... to root html * Fixing bad merge * Removing explicit content type so superagent will guess corectly (#2685) * Fixing merge and unit tests * Adding create team UI * Fixing signup flows * Adding LDAP unit tests and enterprise unit test helper (#2702) * Add the ability to reset MFA from the commandline (#2706) * Fixing compliance unit tests * Fixing client side tests * Adding open server to system console * Moving websocket connection * Fixing unit test * Fixing unit tests * Fixing unit tests * Adding nickname and more LDAP unit tests (#2717) * Adding join open teams * Cleaning up all TODOs in the code * Fixing web sockets * Removing unused webockets file * PLT-2533 Add the ability to reset a user's MFA from the system console (#2715) * Add the ability to reset a user's MFA from the system console * Add client side unit test for adminResetMfa * Reorganizing authentication to fix LDAP error message (#2723) * Fixing failing unit test * Initial upgrade db code * Adding upgrade script * Fixing upgrade script after running on core * Update OAuth and Claim routes to work with user model changes (#2739) * Fixing perminant deletion. Adding ability to delete all user and the entire database (#2740) * Fixing team invite ldap login call (#2741) * Fixing bluebar and some img stuff * Fix all the different file upload web utils (#2743) * Fixing invalid session redirect (#2744) * Redirect on bad channel name (#2746) * Fixing a bunch of issue and removing dead code * Patch to fix error message on leave channel (#2747) * Setting EnableOpenServer to false by default * Fixing config * Fixing upgrade * Fixing reported bugs * Bug fixes for PLT-2057 * PLT-2563 Redo password recovery to use a database table (#2745) * Redo password recovery to use a database table * Update reset password audits * Split out admin and user reset password APIs to be separate * Delete password recovery when user is permanently deleted * Consolidate password resetting into a single function * Removed private channels as an option for outgoing webhooks (#2752) * PLT-2577/PLT-2552 Fixes for backstage (#2753) * Added URL to incoming webhook list * Fixed client functions for adding/removing integrations * Disallowed slash commands without trigger words * Fixed clientside handling of errors on AddCommand page * Minor auth cleanup (#2758) * Changed EditPostModal to just close if you save without making any changes (#2759) * Renamed client -> Client in async_client.jsx and fixed eslint warnings (#2756) * Fixed url in channel info modal (#2755) * Fixing reported issues * Moving to version 3 of the apis * Fixing command unit tests (#2760) * Adding team admins * Fixing DM issue * Fixing eslint error * Properly set EditPostModal's originalText state in all cases (#2762) * Update client config check to assume features is defined if server is licensed (#2772) * Fixing url link * Fixing issue with websocket crashing when sending messages to different teams
256 lines
9.0 KiB
JavaScript
256 lines
9.0 KiB
JavaScript
// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
import * as Utils from 'utils/utils.jsx';
|
|
import Client from 'utils/web_client.jsx';
|
|
import UserStore from 'stores/user_store.jsx';
|
|
|
|
import NewChannelModal from './new_channel_modal.jsx';
|
|
import ChangeURLModal from './change_url_modal.jsx';
|
|
|
|
import {intlShape, injectIntl, defineMessages} from 'react-intl';
|
|
import {browserHistory} from 'react-router';
|
|
|
|
import AppDispatcher from '../dispatcher/app_dispatcher.jsx';
|
|
import Constants from 'utils/constants.jsx';
|
|
const ActionTypes = Constants.ActionTypes;
|
|
|
|
const SHOW_NEW_CHANNEL = 1;
|
|
const SHOW_EDIT_URL = 2;
|
|
const SHOW_EDIT_URL_THEN_COMPLETE = 3;
|
|
const messages = defineMessages({
|
|
channel: {
|
|
id: 'channel_flow.channel',
|
|
defaultMessage: 'Channel'
|
|
},
|
|
group: {
|
|
id: 'channel_flow.group',
|
|
defaultMessage: 'Group'
|
|
},
|
|
change: {
|
|
id: 'channel_flow.changeUrlTitle',
|
|
defaultMessage: 'Change {term} URL'
|
|
},
|
|
set: {
|
|
id: 'channel_flow.set_url_title',
|
|
defaultMessage: 'Set {term} URL'
|
|
},
|
|
create: {
|
|
id: 'channel_flow.create',
|
|
defaultMessage: 'Create {term}'
|
|
},
|
|
changeUrlDescription: {
|
|
id: 'channel_flow.changeUrlDescription',
|
|
defaultMessage: 'Some characters are not allowed in URLs and may be removed.'
|
|
}
|
|
});
|
|
|
|
import React from 'react';
|
|
|
|
class NewChannelFlow extends React.Component {
|
|
constructor(props) {
|
|
super(props);
|
|
|
|
this.doSubmit = this.doSubmit.bind(this);
|
|
this.typeSwitched = this.typeSwitched.bind(this);
|
|
this.urlChangeRequested = this.urlChangeRequested.bind(this);
|
|
this.urlChangeSubmitted = this.urlChangeSubmitted.bind(this);
|
|
this.urlChangeDismissed = this.urlChangeDismissed.bind(this);
|
|
this.channelDataChanged = this.channelDataChanged.bind(this);
|
|
|
|
this.state = {
|
|
serverError: '',
|
|
channelType: 'O',
|
|
flowState: SHOW_NEW_CHANNEL,
|
|
channelDisplayName: '',
|
|
channelName: '',
|
|
channelPurpose: '',
|
|
nameModified: false
|
|
};
|
|
}
|
|
componentWillReceiveProps(nextProps) {
|
|
// If we are being shown, grab channel type from props and clear
|
|
if (nextProps.show === true && this.props.show === false) {
|
|
this.setState({
|
|
serverError: '',
|
|
channelType: nextProps.channelType,
|
|
flowState: SHOW_NEW_CHANNEL,
|
|
channelDisplayName: '',
|
|
channelName: '',
|
|
channelPurpose: '',
|
|
nameModified: false
|
|
});
|
|
}
|
|
}
|
|
doSubmit() {
|
|
if (!this.state.channelDisplayName) {
|
|
this.setState({serverError: Utils.localizeMessage('channel_flow.invalidName', 'Invalid Channel Name')});
|
|
return;
|
|
}
|
|
|
|
if (this.state.channelName < 2) {
|
|
this.setState({flowState: SHOW_EDIT_URL_THEN_COMPLETE});
|
|
return;
|
|
}
|
|
|
|
const cu = UserStore.getCurrentUser();
|
|
const channel = {
|
|
team_id: cu.team_id,
|
|
name: this.state.channelName,
|
|
display_name: this.state.channelDisplayName,
|
|
purpose: this.state.channelPurpose,
|
|
type: this.state.channelType
|
|
};
|
|
Client.createChannel(
|
|
channel,
|
|
(data) => {
|
|
Client.getChannel(
|
|
data.id,
|
|
(data2) => {
|
|
AppDispatcher.handleServerAction({
|
|
type: ActionTypes.RECEIVED_CHANNEL,
|
|
channel: data2.channel,
|
|
member: data2.member
|
|
});
|
|
|
|
this.props.onModalDismissed();
|
|
browserHistory.push(Utils.getTeamURLNoOriginFromAddressBar() + '/channels/' + data2.channel.name);
|
|
}
|
|
);
|
|
},
|
|
(err) => {
|
|
if (err.id === 'model.channel.is_valid.2_or_more.app_error') {
|
|
this.setState({flowState: SHOW_EDIT_URL_THEN_COMPLETE});
|
|
}
|
|
if (err.id === 'store.sql_channel.update.exists.app_error') {
|
|
this.setState({serverError: Utils.localizeMessage('channel_flow.alreadyExist', 'A channel with that URL already exists')});
|
|
return;
|
|
}
|
|
this.setState({serverError: err.message});
|
|
}
|
|
);
|
|
}
|
|
typeSwitched() {
|
|
if (this.state.channelType === 'P') {
|
|
this.setState({channelType: 'O'});
|
|
} else {
|
|
this.setState({channelType: 'P'});
|
|
}
|
|
}
|
|
urlChangeRequested() {
|
|
this.setState({flowState: SHOW_EDIT_URL});
|
|
}
|
|
urlChangeSubmitted(newURL) {
|
|
if (this.state.flowState === SHOW_EDIT_URL_THEN_COMPLETE) {
|
|
this.setState({channelName: newURL, nameModified: true}, this.doSubmit);
|
|
} else {
|
|
this.setState({flowState: SHOW_NEW_CHANNEL, serverError: '', channelName: newURL, nameModified: true});
|
|
}
|
|
}
|
|
urlChangeDismissed() {
|
|
this.setState({flowState: SHOW_NEW_CHANNEL});
|
|
}
|
|
channelDataChanged(data) {
|
|
this.setState({
|
|
channelDisplayName: data.displayName,
|
|
channelPurpose: data.purpose
|
|
});
|
|
if (!this.state.nameModified) {
|
|
this.setState({channelName: Utils.cleanUpUrlable(data.displayName.trim())});
|
|
}
|
|
}
|
|
render() {
|
|
const channelData = {
|
|
name: this.state.channelName,
|
|
displayName: this.state.channelDisplayName,
|
|
purpose: this.state.channelPurpose
|
|
};
|
|
|
|
let showChannelModal = false;
|
|
let showGroupModal = false;
|
|
let showChangeURLModal = false;
|
|
|
|
let changeURLTitle = '';
|
|
let changeURLSubmitButtonText = '';
|
|
let channelTerm = '';
|
|
|
|
const {formatMessage} = this.props.intl;
|
|
|
|
// Only listen to flow state if we are being shown
|
|
if (this.props.show) {
|
|
switch (this.state.flowState) {
|
|
case SHOW_NEW_CHANNEL:
|
|
if (this.state.channelType === 'O') {
|
|
showChannelModal = true;
|
|
channelTerm = formatMessage(messages.channel);
|
|
} else {
|
|
showGroupModal = true;
|
|
channelTerm = formatMessage(messages.group);
|
|
}
|
|
break;
|
|
case SHOW_EDIT_URL:
|
|
showChangeURLModal = true;
|
|
changeURLTitle = formatMessage(messages.change, {term: channelTerm});
|
|
changeURLSubmitButtonText = formatMessage(messages.change, {term: channelTerm});
|
|
break;
|
|
case SHOW_EDIT_URL_THEN_COMPLETE:
|
|
showChangeURLModal = true;
|
|
changeURLTitle = formatMessage(messages.set, {term: channelTerm});
|
|
changeURLSubmitButtonText = formatMessage(messages.create, {term: channelTerm});
|
|
break;
|
|
}
|
|
}
|
|
return (
|
|
<span>
|
|
<NewChannelModal
|
|
show={showChannelModal}
|
|
channelType={'O'}
|
|
channelData={channelData}
|
|
serverError={this.state.serverError}
|
|
onSubmitChannel={this.doSubmit}
|
|
onModalDismissed={this.props.onModalDismissed}
|
|
onTypeSwitched={this.typeSwitched}
|
|
onChangeURLPressed={this.urlChangeRequested}
|
|
onDataChanged={this.channelDataChanged}
|
|
/>
|
|
<NewChannelModal
|
|
show={showGroupModal}
|
|
channelType={'P'}
|
|
channelData={channelData}
|
|
serverError={this.state.serverError}
|
|
onSubmitChannel={this.doSubmit}
|
|
onModalDismissed={this.props.onModalDismissed}
|
|
onTypeSwitched={this.typeSwitched}
|
|
onChangeURLPressed={this.urlChangeRequested}
|
|
onDataChanged={this.channelDataChanged}
|
|
/>
|
|
<ChangeURLModal
|
|
show={showChangeURLModal}
|
|
title={changeURLTitle}
|
|
description={formatMessage(messages.changeUrlDescription)}
|
|
urlLabel={channelTerm + ' URL'}
|
|
submitButtonText={changeURLSubmitButtonText}
|
|
currentURL={this.state.channelName}
|
|
serverError={this.state.serverError}
|
|
onModalSubmit={this.urlChangeSubmitted}
|
|
onModalDismissed={this.urlChangeDismissed}
|
|
/>
|
|
</span>
|
|
);
|
|
}
|
|
}
|
|
|
|
NewChannelFlow.defaultProps = {
|
|
show: false,
|
|
channelType: 'O'
|
|
};
|
|
|
|
NewChannelFlow.propTypes = {
|
|
intl: intlShape.isRequired,
|
|
show: React.PropTypes.bool.isRequired,
|
|
channelType: React.PropTypes.string.isRequired,
|
|
onModalDismissed: React.PropTypes.func.isRequired
|
|
};
|
|
|
|
export default injectIntl(NewChannelFlow);
|