mirror of
https://github.com/freedombox/FreedomBox.git
synced 2026-01-28 08:03:36 +00:00
Closes: #2484 Tests: - Functional tests for users app works. - When updating the user if the delete user is not checked, delete confirmation dialog is not shown. - When updating the user if the delete user is checked, delete confirmation dialog is shown. It can be dismissed and re-shown many times. When confirm button is clicked, the form is submitted and user is deleted. Signed-off-by: Sunil Mohan Adapa <sunil@medhas.org> Reviewed-by: James Valleroy <jvalleroy@mailbox.org>
62 lines
2.1 KiB
JavaScript
62 lines
2.1 KiB
JavaScript
// SPDX-License-Identifier: AGPL-3.0-or-later
|
|
/**
|
|
* @licstart The following is the entire license notice for the JavaScript
|
|
* code in this page.
|
|
*
|
|
* This file is part of FreedomBox.
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* @licend The above is the entire license notice for the JavaScript code
|
|
* in this page.
|
|
*/
|
|
|
|
document.addEventListener('DOMContentLoaded', (event) => {
|
|
const form = document.querySelector('form.form-update');
|
|
form.addEventListener('submit', onUserUpdateSubmit);
|
|
|
|
const confirmDeleteButton = document.querySelector(
|
|
'#user-delete-confirm-dialog button.confirm');
|
|
confirmDeleteButton.addEventListener('click', () => {
|
|
onUserDeleteConfirmed(form);
|
|
});
|
|
|
|
var deleteConfirmed = false;
|
|
const modal = new bootstrap.Modal('#user-delete-confirm-dialog');
|
|
|
|
// Show the confirmation dialog if the delete checkbox is selected
|
|
function onUserUpdateSubmit(event) {
|
|
const deleteUserCheckbox = document.getElementById('id_delete');
|
|
if (!deleteUserCheckbox.checked) {
|
|
return;
|
|
}
|
|
|
|
if (deleteConfirmed) { // Deletion is already confirmed
|
|
deleteConfirmed = false;
|
|
return;
|
|
}
|
|
|
|
event.preventDefault();
|
|
modal.show();
|
|
};
|
|
|
|
// Submit the user edit form
|
|
function onUserDeleteConfirmed(form) {
|
|
deleteConfirmed = true;
|
|
modal.hide();
|
|
// Click instead of submit to disable the submission button
|
|
form.querySelector('input[type=submit]').click();
|
|
};
|
|
});
|