unarm submit buttons in mass inputs on regular form submits

This commit is contained in:
Felix Hamann 2019-05-05 00:28:50 +02:00
parent cc54609f1f
commit 7f9071ec96

View File

@ -25,6 +25,7 @@
var MASS_INPUT_CELL_SELECTOR = '.massinput__cell';
var MASS_INPUT_ADD_CELL_SELECTOR = '.massinput__cell--add';
var MASS_INPUT_SUBMIT_BUTTON_CLASS = 'massinput__submit-button';
var MASS_INPUT_INITIALIZED_CLASS = 'mass-input--initialized';
var massInputUtil = function(element) {
@ -74,6 +75,12 @@
}
return function(event) {
// "unarm" submit buttons inside this massinput so browser
// uses correct submit button for form submission.
// contents of the massinput will be replaced either way,
// so unarming is no problem
unarmSubmitButtons();
// check if event occured from either a mass input add/delete button or
// from inside one of massinput's inputs (i.e. they are focused/active)
var activeElement = element.querySelector(':focus, :active');
@ -87,7 +94,7 @@
return false;
}
var submitButton = massInputCell.querySelector('button[type="submit"][name][value]');
var submitButton = massInputCell.querySelector('.' + MASS_INPUT_SUBMIT_BUTTON_CLASS);
if (!submitButton) {
return false;
}
@ -122,6 +129,14 @@
};
}
function unarmSubmitButtons() {
var buttons = Array.from(element.querySelectorAll('button[type="submit"][name][value]'));
buttons.forEach(function(button) {
button.setAttribute('type', 'button');
button.classList.add(MASS_INPUT_SUBMIT_BUTTON_CLASS);
});
}
function processResponse(response) {
element.innerHTML = response;