From eb8a20b2b77549b5afd530e58208a78ef68e295a Mon Sep 17 00:00:00 2001 From: Jonathan Druart Date: Mon, 13 Jul 2015 17:34:53 +0100 Subject: [PATCH] Bug 13943: Prevent the deletion of items if the user cancels On the edit items page, there is some weird JS code: if the user clicks on the delete link and then cancel, the item is deleted anyway. It's caused by the following JS code in browser.js $('a[href*="biblionumber="]').click(function (ev) { ev.preventDefault(); window.location = $(this).attr('href') + '&searchid=' + me.searchid; }); Test plan: - Do a search with multiple results - Go to the detail page (make sure results browser shows up!) - Use the "Edit items" link from the toolbar - Delete an item (try both way) - Choose "cancel" - Delete an item (try both way) and confirm the deletion You should see the browser after the deletion and the item should have been deleted correctly. - Edit an item (try both way) You should see the browser (did not work before this patch) Note: Before this patch, the 2 first columns didn't contain the edit/delete item links, now it's only the 1st one. Signed-off-by: Nick Clemens Signed-off-by: Katrin Fischer Much better! Signed-off-by: Tomas Cohen Arazi (cherry picked from commit f7214859df15abfe874141bcc1a32b57067f7c54) Signed-off-by: Chris Cormack --- .../prog/en/modules/cataloguing/additem.tt | 52 +++++++++++-------- 1 file changed, 29 insertions(+), 23 deletions(-) diff --git a/koha-tmpl/intranet-tmpl/prog/en/modules/cataloguing/additem.tt b/koha-tmpl/intranet-tmpl/prog/en/modules/cataloguing/additem.tt index ab9621b964..5028251221 100644 --- a/koha-tmpl/intranet-tmpl/prog/en/modules/cataloguing/additem.tt +++ b/koha-tmpl/intranet-tmpl/prog/en/modules/cataloguing/additem.tt @@ -15,23 +15,35 @@ browser.show(); $(document).ready(function(){ + + // Remove the onclick event defined in browser.js, + // otherwise the deletion confirmation will not work correctly + $('a[href*="biblionumber="]').off('click'); + [% IF (popup) %] [% IF (opisadd) %] window.close(); [% END %] [% END %] $("fieldset.rows input, fieldset.rows select").addClass("noEnterSubmit"); - /* Inline edit/delete links */ - var biblionumber = $("input[name='biblionumber']").attr("value"); - $("tr.editable td").click(function(event){ - var $tgt = $(event.target); - if($tgt.is("a")||$tgt.is(":first-child")||$tgt.is(":nth-child(2)")){ return true; } else { - var rowid = $(this).parent().attr("id"); - num_rowid = rowid.replace("row",""); - $(".linktools").remove(); - $(this).append("" + _("Edit item") + " " + _("Delete item") + ""); - } - }); + /* Inline edit/delete links */ + var biblionumber = $("input[name='biblionumber']").attr("value"); + $("tr.editable").each(function(){ + $(this).find("td:not(:first)").on('click', function(){ + var rowid = $(this).parent().attr("id"); + num_rowid = rowid.replace("row",""); + $(".linktools").remove(); + var edit_link = $('' + _("Edit item") + ''); + var delete_link = $('' + _("Delete item") + ''); + $(delete_link).on('click', function(e) { + return confirm_deletion(); + }); + var tools_node = $(''); + $(tools_node).append(edit_link); + $(tools_node).append(delete_link); + $(this).append(tools_node); + }); + }); var itemst = $("#itemst").dataTable($.extend(true, {}, dataTablesDefaults, { "aoColumnDefs": [ @@ -79,16 +91,10 @@ function Dopop(link,i) { newin=window.open(link+"&result="+defaultvalue,"valuebuilder",'width=500,height=400,toolbar=false,scrollbars=yes'); } -function confirm_deletion(biblionumber,itemnumber) { - var original = $("#row"+itemnumber).attr("class"); - $("#row"+itemnumber).attr("class","confirm"); - var is_confirmed = confirm(_("Are you sure you want to delete this item?")); - if (is_confirmed) { - window.location = "additem.pl?op=delitem&biblionumber="+biblionumber+"&itemnumber="+itemnumber; - } else { - $("#row"+itemnumber).attr("class",""); - } +function confirm_deletion() { + return confirm(_("Are you sure you want to delete this item?")); } + //]]> @@ -155,13 +161,13 @@ function confirm_deletion(biblionumber,itemnumber) { [% ELSE %] [% IF ( item_loo.hostitemflag ) %] - Edit in host   Delink + Edit in host   Delink [% ELSE %] - Edit + Edit [% IF ( item_loo.countanalytics ) %] View analytics [% ELSE %] - Delete + Delete [% END %] [% END %] -- 2.39.5