Integrations Bundle
This commit is contained in:
parent
338a73ec03
commit
f5f20274fa
2 changed files with 106 additions and 0 deletions
6
app/assets/javascripts/integrations/index.js
Normal file
6
app/assets/javascripts/integrations/index.js
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
/* eslint-disable no-new */
|
||||||
|
import IntegrationSettingsForm from './integration_settings_form';
|
||||||
|
|
||||||
|
$(() => {
|
||||||
|
new IntegrationSettingsForm('.js-integration-settings-from');
|
||||||
|
});
|
100
app/assets/javascripts/integrations/integration_settings_form.js
Normal file
100
app/assets/javascripts/integrations/integration_settings_form.js
Normal file
|
@ -0,0 +1,100 @@
|
||||||
|
/* global Flash */
|
||||||
|
|
||||||
|
export default class IntegrationSettingsForm {
|
||||||
|
constructor(formSelector) {
|
||||||
|
this.$form = $(formSelector);
|
||||||
|
|
||||||
|
// Form Metadata
|
||||||
|
this.endPoint = this.$form.attr('action');
|
||||||
|
|
||||||
|
// Form Child Elements
|
||||||
|
this.$serviceToggle = this.$form.find('#service_active');
|
||||||
|
this.$submitBtn = this.$form.find('button[type="submit"]');
|
||||||
|
this.$submitBtnLoader = this.$submitBtn.find('.js-btn-spinner');
|
||||||
|
this.$submitBtnLabel = this.$submitBtn.find('.js-btn-label');
|
||||||
|
|
||||||
|
// Class Member methods
|
||||||
|
this.handleServiceToggle = this.handleServiceToggle.bind(this);
|
||||||
|
this.handleSettingsSave = this.handleSettingsSave.bind(this);
|
||||||
|
|
||||||
|
this.init();
|
||||||
|
}
|
||||||
|
|
||||||
|
init() {
|
||||||
|
// Initialize View
|
||||||
|
this.toggleSubmitBtnLabel(this.$serviceToggle.is(':checked'));
|
||||||
|
|
||||||
|
// Bind Event Listeners
|
||||||
|
this.$serviceToggle.on('change', this.handleServiceToggle);
|
||||||
|
this.$submitBtn.on('click', this.handleSettingsSave);
|
||||||
|
}
|
||||||
|
|
||||||
|
handleSettingsSave(e) {
|
||||||
|
if (this.$serviceToggle.is(':checked')) {
|
||||||
|
e.preventDefault();
|
||||||
|
this.testSettings(this.$form.serialize());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
handleServiceToggle(e) {
|
||||||
|
this.toggleSubmitBtnLabel($(e.currentTarget).is(':checked'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Toggle Submit button label based on Integration status
|
||||||
|
*/
|
||||||
|
toggleSubmitBtnLabel(serviceActive) {
|
||||||
|
this.$submitBtnLabel.text(
|
||||||
|
serviceActive ?
|
||||||
|
'Test settings and save changes' :
|
||||||
|
'Save changes');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Toggle Submit button state based on provided boolean value of `saveTestActive`
|
||||||
|
* When enabled, it does two things, and reverts back when disabled
|
||||||
|
*
|
||||||
|
* 1. It shows load spinner on submit button
|
||||||
|
* 2. Makes submit button disabled
|
||||||
|
*/
|
||||||
|
toggleSubmitBtnState(saveTestActive) {
|
||||||
|
if (saveTestActive) {
|
||||||
|
this.$submitBtn.disable();
|
||||||
|
this.$submitBtnLoader.removeClass('hidden');
|
||||||
|
} else {
|
||||||
|
this.$submitBtn.enable();
|
||||||
|
this.$submitBtnLoader.addClass('hidden');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* eslint-disable promise/catch-or-return, no-new */
|
||||||
|
/**
|
||||||
|
* Test Integration config
|
||||||
|
*/
|
||||||
|
testSettings(formData) {
|
||||||
|
this.toggleSubmitBtnState(true);
|
||||||
|
$.ajax({
|
||||||
|
type: 'PUT',
|
||||||
|
url: `${this.endPoint}/test`,
|
||||||
|
data: formData,
|
||||||
|
})
|
||||||
|
.done((res) => {
|
||||||
|
if (res.error) {
|
||||||
|
new Flash(`${res.message}.`, null, null, {
|
||||||
|
title: 'Save anyway',
|
||||||
|
clickHandler: () => {
|
||||||
|
this.$form.submit();
|
||||||
|
},
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
this.$form.submit();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.fail(() => {
|
||||||
|
new Flash('Something went wrong on our end.');
|
||||||
|
})
|
||||||
|
.always(() => {
|
||||||
|
this.toggleSubmitBtnState(false);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue