summaryrefslogtreecommitdiffstats
path: root/webapp/components/integrations/components/installed_outgoing_webhook.jsx
diff options
context:
space:
mode:
Diffstat (limited to 'webapp/components/integrations/components/installed_outgoing_webhook.jsx')
-rw-r--r--webapp/components/integrations/components/installed_outgoing_webhook.jsx200
1 files changed, 200 insertions, 0 deletions
diff --git a/webapp/components/integrations/components/installed_outgoing_webhook.jsx b/webapp/components/integrations/components/installed_outgoing_webhook.jsx
new file mode 100644
index 000000000..852231823
--- /dev/null
+++ b/webapp/components/integrations/components/installed_outgoing_webhook.jsx
@@ -0,0 +1,200 @@
+// Copyright (c) 2016 Mattermost, Inc. All Rights Reserved.
+// See License.txt for license information.
+
+import React from 'react';
+
+import ChannelStore from 'stores/channel_store.jsx';
+import * as Utils from 'utils/utils.jsx';
+
+import {FormattedMessage} from 'react-intl';
+
+export default class InstalledOutgoingWebhook extends React.Component {
+ static get propTypes() {
+ return {
+ outgoingWebhook: React.PropTypes.object.isRequired,
+ onRegenToken: React.PropTypes.func.isRequired,
+ onDelete: React.PropTypes.func.isRequired,
+ filter: React.PropTypes.string
+ };
+ }
+
+ constructor(props) {
+ super(props);
+
+ this.handleRegenToken = this.handleRegenToken.bind(this);
+ this.handleDelete = this.handleDelete.bind(this);
+ }
+
+ handleRegenToken(e) {
+ e.preventDefault();
+
+ this.props.onRegenToken(this.props.outgoingWebhook);
+ }
+
+ handleDelete(e) {
+ e.preventDefault();
+
+ this.props.onDelete(this.props.outgoingWebhook);
+ }
+
+ matchesFilter(outgoingWebhook, channel, filter) {
+ if (!filter) {
+ return true;
+ }
+
+ if (outgoingWebhook.display_name.toLowerCase().indexOf(filter) !== -1 ||
+ outgoingWebhook.description.toLowerCase().indexOf(filter) !== -1) {
+ return true;
+ }
+
+ for (const trigger of outgoingWebhook.trigger_words) {
+ if (trigger.toLowerCase().indexOf(filter) !== -1) {
+ return true;
+ }
+ }
+
+ if (channel) {
+ if (channel && channel.name.toLowerCase().indexOf(filter) !== -1) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ render() {
+ const outgoingWebhook = this.props.outgoingWebhook;
+ const channel = ChannelStore.get(outgoingWebhook.channel_id);
+ const filter = this.props.filter ? this.props.filter.toLowerCase() : '';
+
+ if (!this.matchesFilter(outgoingWebhook, channel, filter)) {
+ return null;
+ }
+
+ let displayName;
+ if (outgoingWebhook.display_name) {
+ displayName = outgoingWebhook.display_name;
+ } else if (channel) {
+ displayName = channel.display_name;
+ } else {
+ displayName = (
+ <FormattedMessage
+ id='installed_outgoing_webhooks.unknown_channel'
+ defaultMessage='A Private Webhook'
+ />
+ );
+ }
+
+ let description = null;
+ if (outgoingWebhook.description) {
+ description = (
+ <div className='item-details__row'>
+ <span className='item-details__description'>
+ {outgoingWebhook.description}
+ </span>
+ </div>
+ );
+ }
+
+ let triggerWords = null;
+ if (outgoingWebhook.trigger_words && outgoingWebhook.trigger_words.length > 0) {
+ triggerWords = (
+ <div className='item-details__row'>
+ <span className='item-details__trigger-words'>
+ <FormattedMessage
+ id='installed_integrations.triggerWords'
+ defaultMessage='Trigger Words: {triggerWords}'
+ values={{
+ triggerWords: outgoingWebhook.trigger_words.join(', ')
+ }}
+ />
+ </span>
+ </div>
+ );
+ }
+
+ let urls = (
+ <div className='item-details__row'>
+ <span className='item-details__url'>
+ <FormattedMessage
+ id='installed_integrations.callback_urls'
+ defaultMessage='Callback URLs: {urls}'
+ values={{
+ urls: outgoingWebhook.callback_urls.join(', ')
+ }}
+ />
+ </span>
+ </div>
+ );
+
+ return (
+ <div className='backstage-list__item'>
+ <div className='item-details'>
+ <div className='item-details__row'>
+ <span className='item-details__name'>
+ {displayName}
+ </span>
+ </div>
+ {description}
+ <div className='item-details__row'>
+ <span className='item-details__content_type'>
+ <FormattedMessage
+ id='installed_integrations.content_type'
+ defaultMessage='Content-Type: {contentType}'
+ values={{
+ contentType: outgoingWebhook.content_type || 'application/x-www-form-urlencoded'
+ }}
+ />
+ </span>
+ </div>
+ {triggerWords}
+ <div className='item-details__row'>
+ <span className='item-details__token'>
+ <FormattedMessage
+ id='installed_integrations.token'
+ defaultMessage='Token: {token}'
+ values={{
+ token: outgoingWebhook.token
+ }}
+ />
+ </span>
+ </div>
+ <div className='item-details__row'>
+ <span className='item-details__creation'>
+ <FormattedMessage
+ id='installed_integrations.creation'
+ defaultMessage='Created by {creator} on {createAt, date, full}'
+ values={{
+ creator: Utils.displayUsername(outgoingWebhook.creator_id),
+ createAt: outgoingWebhook.create_at
+ }}
+ />
+ </span>
+ </div>
+ {urls}
+ </div>
+ <div className='item-actions'>
+ <a
+ href='#'
+ onClick={this.handleRegenToken}
+ >
+ <FormattedMessage
+ id='installed_integrations.regenToken'
+ defaultMessage='Regen Token'
+ />
+ </a>
+ {' - '}
+ <a
+ href='#'
+ onClick={this.handleDelete}
+ >
+ <FormattedMessage
+ id='installed_integrations.delete'
+ defaultMessage='Delete'
+ />
+ </a>
+ </div>
+ </div>
+ );
+ }
+}