From ccb652ec6d0fbc462b27d3bd3d3833cb84b9418b Mon Sep 17 00:00:00 2001 From: Armin Kirchner Date: Tue, 20 May 2025 16:06:53 +0200 Subject: [PATCH] Fixes #259 Reflect file deletion by removing the whole entry Remove the whole file element from the exercise form when a file is deleted. --- app/assets/javascripts/exercises.js | 10 +++++----- app/views/exercises/_file_form.html.slim | 2 +- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/app/assets/javascripts/exercises.js b/app/assets/javascripts/exercises.js index ba5225829..8ebcc88a1 100644 --- a/app/assets/javascripts/exercises.js +++ b/app/assets/javascripts/exercises.js @@ -87,12 +87,12 @@ $(document).on('turbolinks:load', function () { // validate fileUrl const matches = fileUrl.match(/files\/(\d+)/); if (matches) { - // select the file form based on the delete button - const fileForm = $(`*[data-file-url="${fileUrl}"]`).parent().parent().parent(); - fileForm.remove(); - - // now remove the hidden input representing the file const fileId = matches[1]; + + $(`#file-form-${fileId}`).remove(); + + // The remaining hidden input field associated with the + // deleted file needs to be removed. const input = $(`input[type="hidden"][value="${fileId}"]`) input.remove() } diff --git a/app/views/exercises/_file_form.html.slim b/app/views/exercises/_file_form.html.slim index 00a24021d..b32acc290 100644 --- a/app/views/exercises/_file_form.html.slim +++ b/app/views/exercises/_file_form.html.slim @@ -1,6 +1,6 @@ - id = f.object.id -li.card.mt-2 +li.card.mt-2 id="file-form-#{id}" .card-header#heading role='tab' - collapsed_class = f.index == 'index' ? nil : 'collapsed' - aria_expanded = f.index == 'index' ? 'true' : 'false'