1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-23 08:16:18 +01:00
onion/js/components/ascribe_settings/webhook_settings.js

167 lines
5.9 KiB
JavaScript
Raw Normal View History

2015-11-27 03:24:37 +01:00
'use strict';
import React from 'react';
import WebhookStore from '../../stores/webhook_store';
import WebhookActions from '../../actions/webhook_actions';
import GlobalNotificationModel from '../../models/global_notification_model';
import GlobalNotificationActions from '../../actions/global_notification_actions';
import Form from '../ascribe_forms/form';
import Property from '../ascribe_forms/property';
import AclProxy from '../acl_proxy';
2015-11-27 03:24:37 +01:00
import ActionPanel from '../ascribe_panel/action_panel';
import CollapsibleParagraph from '../ascribe_collapsible/collapsible_paragraph';
import AscribeSpinner from '../ascribe_spinner';
import { getLangText } from '../../utils/lang';
import { resolveUrl } from '../../utils/url_resolver';
2015-11-27 03:24:37 +01:00
let WebhookSettings = React.createClass({
propTypes: {
defaultExpanded: React.PropTypes.bool
},
getInitialState() {
return WebhookStore.getState();
},
componentDidMount() {
WebhookStore.listen(this.onChange);
WebhookActions.fetchWebhooks();
},
componentWillUnmount() {
WebhookStore.unlisten(this.onChange);
},
onChange(state) {
this.setState(state);
},
onRemoveWebhook(webhookId) {
return (event) => {
WebhookActions.removeWebhook(webhookId);
2015-11-27 03:24:37 +01:00
2016-01-15 13:59:41 +01:00
const notification = new GlobalNotificationModel(getLangText('Webhook deleted'), 'success', 2000);
GlobalNotificationActions.appendGlobalNotification(notification);
};
2015-11-27 03:24:37 +01:00
},
handleCreateSuccess() {
this.refs.webhookCreateForm.reset();
WebhookActions.fetchWebhooks(true);
2016-01-15 13:59:41 +01:00
const notification = new GlobalNotificationModel(getLangText('Webhook successfully created'), 'success', 5000);
2015-11-27 03:24:37 +01:00
GlobalNotificationActions.appendGlobalNotification(notification);
},
2016-01-15 13:59:41 +01:00
getWebhooks() {
if (this.state.webhooks) {
2016-01-15 13:59:41 +01:00
return this.state.webhooks.map(function(webhook, i) {
2015-11-27 03:24:37 +01:00
const event = webhook.event.split('.')[0];
2016-01-15 13:59:41 +01:00
2015-11-27 03:24:37 +01:00
return (
<ActionPanel
name={webhook.event}
key={i}
content={
<div>
<div className='ascribe-panel-title'>
{event.toUpperCase()}
</div>
<div className="ascribe-panel-subtitle">
{webhook.target}
</div>
</div>
}
buttons={
<div className="pull-right">
<div className="pull-right">
<button
className="pull-right btn btn-tertiary btn-sm"
onClick={this.onRemoveWebhook(webhook.id)}>
2015-11-27 03:24:37 +01:00
{getLangText('DELETE')}
</button>
</div>
</div>
2016-01-15 13:59:41 +01:00
} />
2015-11-27 03:24:37 +01:00
);
}, this);
2016-01-15 13:59:41 +01:00
} else {
return (
<AscribeSpinner color='dark-blue' size='lg'/>
);
2015-11-27 03:24:37 +01:00
}
},
getEvents() {
if (this.state.webhookEvents && this.state.webhookEvents.length) {
2015-11-27 03:24:37 +01:00
return (
<Property
name='event'
label={getLangText('Select the event to trigger a webhook', '...')}>
<select name="events">
{this.state.webhookEvents.map((event, i) => {
2015-11-27 03:24:37 +01:00
return (
<option
name={i}
key={i}
2016-01-15 13:59:41 +01:00
value={event + '.webhook'}>
{event.toUpperCase()}
2015-11-27 03:24:37 +01:00
</option>
);
})}
</select>
</Property>);
2016-01-15 13:59:41 +01:00
} else {
return null;
2015-11-27 03:24:37 +01:00
}
},
render() {
return (
<CollapsibleParagraph
title={getLangText('Webhooks')}
defaultExpanded={this.props.defaultExpanded}>
2015-11-27 18:02:25 +01:00
<div>
<p>
2016-02-08 14:50:24 +01:00
{getLangText('Webhooks allow external services to receive notifications from ascribe. ' +
'Currently we support webhook notifications when someone transfers, consigns, ' +
'loans or shares (by email) a work to you.')}
2015-11-27 18:02:25 +01:00
</p>
<p>
2016-02-08 14:50:24 +01:00
{getLangText('To get started, simply choose the prefered action that you want to be ' +
'notified upon and supply a target url.')}
2015-11-27 18:02:25 +01:00
</p>
</div>
<AclProxy show={this.state.webhookEvents && this.state.webhookEvents.length > 0}>
<Form
ref="webhookCreateForm"
url={resolveUrl('webhooks')}
handleSuccess={this.handleCreateSuccess}>
2016-01-15 13:59:41 +01:00
{this.getEvents()}
<Property
name='target'
label={getLangText('Redirect Url')}>
<input
type="text"
placeholder={getLangText('Enter the url to be triggered')}
2016-01-15 13:59:41 +01:00
required />
</Property>
<hr />
</Form>
</AclProxy>
2015-11-27 03:24:37 +01:00
{this.getWebhooks()}
</CollapsibleParagraph>
);
}
});
2016-01-15 13:59:41 +01:00
export default WebhookSettings;