Move validation into the base chooser modal implementation

pull/8931/head
Matt Westcott 2022-07-04 22:36:58 +01:00 zatwierdzone przez Matt Westcott
rodzic 49720cc08f
commit 0b752a81ac
2 zmienionych plików z 33 dodań i 29 usunięć

Wyświetl plik

@ -2,43 +2,20 @@ import $ from 'jquery';
import { initTabs } from '../../includes/tabs'; import { initTabs } from '../../includes/tabs';
import { import {
submitCreationForm, submitCreationForm,
validateCreationForm,
initPrefillTitleFromFilename, initPrefillTitleFromFilename,
SearchController, SearchController,
} from '../../includes/chooserModal'; } from '../../includes/chooserModal';
import { gettext } from '../../utils/gettext';
function ajaxifyImageUploadForm(modal) { function ajaxifyImageUploadForm(modal) {
$('form[data-chooser-modal-creation-form]', modal.body).on( $('form[data-chooser-modal-creation-form]', modal.body).on(
'submit', 'submit',
(event) => { (event) => {
let hasErrors = false; if (validateCreationForm(event.currentTarget)) {
for (const input of event.currentTarget.querySelectorAll(
'input[required]',
)) {
if (!input.value) {
hasErrors = true;
const li = input.closest('li');
if (!li.classList.contains('error')) {
li.classList.add('error');
const container = input.closest('.field-content');
const errorPara = document.createElement('p');
errorPara.className = 'error-message';
container.appendChild(errorPara);
const errorSpan = document.createElement('span');
errorPara.appendChild(errorSpan);
errorSpan.innerText = gettext('This field is required.');
}
}
}
if (hasErrors) {
// eslint-disable-next-line no-undef
setTimeout(cancelSpinner, 500);
} else {
submitCreationForm(modal, event.currentTarget, { submitCreationForm(modal, event.currentTarget, {
errorContainerSelector: '#tab-upload', errorContainerSelector: '#tab-upload',
}); });
} }
return false; return false;
}, },
); );

Wyświetl plik

@ -4,6 +4,31 @@ import { initTabs } from './tabs';
import { initTooltips } from './initTooltips'; import { initTooltips } from './initTooltips';
import { gettext } from '../utils/gettext'; import { gettext } from '../utils/gettext';
const validateCreationForm = (form) => {
let hasErrors = false;
form.querySelectorAll('input[required]').forEach((input) => {
if (!input.value) {
hasErrors = true;
const li = input.closest('li');
if (!li.classList.contains('error')) {
li.classList.add('error');
const container = input.closest('.field-content');
const errorPara = document.createElement('p');
errorPara.className = 'error-message';
container.appendChild(errorPara);
const errorSpan = document.createElement('span');
errorPara.appendChild(errorSpan);
errorSpan.innerText = gettext('This field is required.');
}
}
});
if (hasErrors) {
// eslint-disable-next-line no-undef
setTimeout(cancelSpinner, 500);
}
return !hasErrors;
};
const submitCreationForm = (modal, form, { errorContainerSelector }) => { const submitCreationForm = (modal, form, { errorContainerSelector }) => {
const formdata = new FormData(form); const formdata = new FormData(form);
@ -211,10 +236,11 @@ class ChooserModalOnloadHandlerFactory {
ajaxifyCreationForm(modal) { ajaxifyCreationForm(modal) {
/* Convert the creation form to an AJAX submission */ /* Convert the creation form to an AJAX submission */
$(this.creationFormSelector, modal.body).on('submit', (event) => { $(this.creationFormSelector, modal.body).on('submit', (event) => {
if (validateCreationForm(event.currentTarget)) {
submitCreationForm(modal, event.currentTarget, { submitCreationForm(modal, event.currentTarget, {
errorContainerSelector: this.creationFormTabSelector, errorContainerSelector: this.creationFormTabSelector,
}); });
}
return false; return false;
}); });
@ -287,6 +313,7 @@ const chooserModalOnloadHandlers =
new ChooserModalOnloadHandlerFactory().getOnLoadHandlers(); new ChooserModalOnloadHandlerFactory().getOnLoadHandlers();
export { export {
validateCreationForm,
submitCreationForm, submitCreationForm,
initPrefillTitleFromFilename, initPrefillTitleFromFilename,
SearchController, SearchController,