143 lines
3.9 KiB
JavaScript
143 lines
3.9 KiB
JavaScript
import $ from 'jquery';
|
|
import axios from '../lib/utils/axios_utils';
|
|
import { deprecatedCreateFlash as flash } from '../flash';
|
|
import { __ } from '~/locale';
|
|
import initForm from './edit';
|
|
import eventHub from './edit/event_hub';
|
|
|
|
export default class IntegrationSettingsForm {
|
|
constructor(formSelector) {
|
|
this.$form = $(formSelector);
|
|
this.formActive = false;
|
|
|
|
// Form Metadata
|
|
this.canTestService = this.$form.data('canTest');
|
|
this.testEndPoint = this.$form.data('testUrl');
|
|
|
|
// Form Child Elements
|
|
this.$submitBtn = this.$form.find('button[type="submit"]');
|
|
this.$submitBtnLoader = this.$submitBtn.find('.js-btn-spinner');
|
|
this.$submitBtnLabel = this.$submitBtn.find('.js-btn-label');
|
|
}
|
|
|
|
init() {
|
|
// Init Vue component
|
|
initForm(
|
|
document.querySelector('.js-vue-integration-settings'),
|
|
document.querySelector('.js-vue-admin-integration-settings'),
|
|
);
|
|
eventHub.$on('toggle', active => {
|
|
this.formActive = active;
|
|
this.handleServiceToggle();
|
|
});
|
|
|
|
// Bind Event Listeners
|
|
this.$submitBtn.on('click', e => this.handleSettingsSave(e));
|
|
}
|
|
|
|
handleSettingsSave(e) {
|
|
// Check if Service is marked active, as if not marked active,
|
|
// We can skip testing it and directly go ahead to allow form to
|
|
// be submitted
|
|
if (!this.formActive) {
|
|
return;
|
|
}
|
|
|
|
// Service was marked active so now we check;
|
|
// 1) If form contents are valid
|
|
// 2) If this service can be tested
|
|
// If both conditions are true, we override form submission
|
|
// and test the service using provided configuration.
|
|
if (this.$form.get(0).checkValidity()) {
|
|
if (this.canTestService) {
|
|
e.preventDefault();
|
|
// eslint-disable-next-line no-jquery/no-serialize
|
|
this.testSettings(this.$form.serialize());
|
|
}
|
|
} else {
|
|
e.preventDefault();
|
|
eventHub.$emit('validateForm');
|
|
}
|
|
}
|
|
|
|
handleServiceToggle() {
|
|
this.toggleServiceState();
|
|
}
|
|
|
|
/**
|
|
* Change Form's validation enforcement based on service status (active/inactive)
|
|
*/
|
|
toggleServiceState() {
|
|
this.toggleSubmitBtnLabel();
|
|
if (this.formActive) {
|
|
this.$form.removeAttr('novalidate');
|
|
} else if (!this.$form.attr('novalidate')) {
|
|
this.$form.attr('novalidate', 'novalidate');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Toggle Submit button label based on Integration status and ability to test service
|
|
*/
|
|
toggleSubmitBtnLabel() {
|
|
let btnLabel = __('Save changes');
|
|
|
|
if (this.formActive && this.canTestService) {
|
|
btnLabel = __('Test settings and save changes');
|
|
}
|
|
|
|
this.$submitBtnLabel.text(btnLabel);
|
|
}
|
|
|
|
/**
|
|
* 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');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Test Integration config
|
|
*/
|
|
testSettings(formData) {
|
|
this.toggleSubmitBtnState(true);
|
|
|
|
return axios
|
|
.put(this.testEndPoint, formData)
|
|
.then(({ data }) => {
|
|
if (data.error) {
|
|
let flashActions;
|
|
|
|
if (data.test_failed) {
|
|
flashActions = {
|
|
title: __('Save anyway'),
|
|
clickHandler: e => {
|
|
e.preventDefault();
|
|
this.$form.submit();
|
|
},
|
|
};
|
|
}
|
|
|
|
flash(`${data.message} ${data.service_response}`, 'alert', document, flashActions);
|
|
} else {
|
|
this.$form.submit();
|
|
}
|
|
|
|
this.toggleSubmitBtnState(false);
|
|
})
|
|
.catch(() => {
|
|
flash(__('Something went wrong on our end.'));
|
|
this.toggleSubmitBtnState(false);
|
|
});
|
|
}
|
|
}
|