diff options
author | Harrison Healey <harrisonmhealey@gmail.com> | 2016-03-28 09:41:03 -0400 |
---|---|---|
committer | Harrison Healey <harrisonmhealey@gmail.com> | 2016-03-29 15:18:26 -0400 |
commit | 3246d97d5ea00320f9d051318321e156eb0130a0 (patch) | |
tree | 6bca338fe860c76ef00f540f5848cfb3010f93f1 /webapp/components/backstage | |
parent | dcdea9f30b419eeb8d55ed9be3f824aaf27de50c (diff) | |
download | chat-3246d97d5ea00320f9d051318321e156eb0130a0.tar.gz chat-3246d97d5ea00320f9d051318321e156eb0130a0.tar.bz2 chat-3246d97d5ea00320f9d051318321e156eb0130a0.zip |
Added basic screen to add incoming webhooks
Diffstat (limited to 'webapp/components/backstage')
-rw-r--r-- | webapp/components/backstage/add_incoming_webhook.jsx | 214 |
1 files changed, 214 insertions, 0 deletions
diff --git a/webapp/components/backstage/add_incoming_webhook.jsx b/webapp/components/backstage/add_incoming_webhook.jsx new file mode 100644 index 000000000..962792ed0 --- /dev/null +++ b/webapp/components/backstage/add_incoming_webhook.jsx @@ -0,0 +1,214 @@ +// Copyright (c) 2016 Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +import React from 'react'; + +import * as AsyncClient from 'utils/async_client.jsx'; +import {browserHistory} from 'react-router'; +import ChannelStore from 'stores/channel_store.jsx'; +import TeamStore from 'stores/team_store.jsx'; + +import {FormattedMessage} from 'react-intl'; +import FormError from 'components/form_error.jsx'; +import {Link} from 'react-router'; +import SpinnerButton from 'components/spinner_button.jsx'; + +export default class AddIncomingWebhook extends React.Component { + constructor(props) { + super(props); + + this.handleChange = this.handleChange.bind(this); + this.handleSubmit = this.handleSubmit.bind(this); + + this.updateName = this.updateName.bind(this); + this.updateDescription = this.updateDescription.bind(this); + this.updateChannelName = this.updateChannelName.bind(this); + + this.state = { + team: TeamStore.getCurrent(), + name: '', + description: '', + channelName: '', + saving: false, + serverError: '', + clientError: null + }; + } + + componentDidMount() { + TeamStore.addChangeListener(this.handleChange); + } + + componentWillUnmount() { + TeamStore.removeChangeListener(this.handleChange); + } + + handleChange() { + this.setState({ + team: TeamStore.getCurrent() + }); + } + + handleSubmit(e) { + e.preventDefault(); + + if (this.state.saving) { + return; + } + + this.setState({ + saving: true, + serverError: '', + clientError: '' + }); + + const channel = ChannelStore.getByName(this.state.channelName); + + if (!channel) { + this.setState({ + saving: false, + clientError: ( + <FormattedMessage + id='add_incoming_webhook.channel_name_required' + defaultMessage='A valid channel name (eg. town-square) is required' + /> + ) + }); + + return; + } + + const hook = { + channel_id: channel.id + }; + + AsyncClient.addIncomingHook( + hook, + () => { + browserHistory.push(`/${this.state.team.name}/integrations/installed`); + }, + (err) => { + this.setState({ + serverError: err.message + }); + } + ); + } + + updateName(e) { + this.setState({ + name: e.target.value + }); + } + + updateDescription(e) { + this.setState({ + description: e.target.value + }); + } + + updateChannelName(e) { + this.setState({ + channelName: e.target.value + }); + } + + render() { + const team = TeamStore.getCurrent(); + + if (!team) { + return null; + } + + return ( + <div className='backstage row'> + <div className='add-incoming-webhook'> + <div className='backstage__header'> + <h1 className='text'> + <FormattedMessage + id='add-incoming-webhook.header' + defaultMessage='Add Incoming Webhook' + /> + </h1> + </div> + </div> + <form className='add-incoming-webhook__body'> + <div className='add-integration__row'> + <label + className='add-integration__label' + htmlFor='name' + > + <FormattedMessage + id='add-incoming-webhook.name' + defaultMessage='Name' + /> + </label> + <input + id='name' + type='text' + value={this.state.name} + onChange={this.updateName} + /> + </div> + <div className='add-integration__row'> + <label + className='add-integration__label' + htmlFor='description' + > + <FormattedMessage + id='add-incoming-webhook.description' + defaultMessage='Description' + /> + </label> + <input + id='description' + type='text' + value={this.state.description} + onChange={this.updateDescription} + /> + </div> + <div className='add-integration__row'> + <label + className='add-integration__label' + htmlFor='channelName' + > + <FormattedMessage + id='add-incoming-webhook.channelName' + defaultMessage='Channel Name' + /> + </label> + <input + id='channelName' + type='text' + value={this.state.channelName} + onChange={this.updateChannelName} + /> + </div> + <div className='add-integration__submit-row'> + <Link + className='btn btn-sm' + to={`/${team.name}/integrations/add`} + > + <FormattedMessage + id='add-incoming-webhook.cancel' + defaultMessage='Cancel' + /> + </Link> + <SpinnerButton + className='btn btn-primary' + type='submit' + spinning={this.state.saving} + onClick={this.handleSubmit} + > + <FormattedMessage + id='add-incoming-webhook.save' + defaultMessage='Save' + /> + </SpinnerButton> + </div> + <FormError errors={[this.state.serverError, this.state.clientError]}/> + </form> + </div> + ); + } +} |