From 2c144aa2f390d2be2dac16ce1179543215ae7f4c Mon Sep 17 00:00:00 2001 From: Oleksii Kriuchykhin Date: Fri, 23 Sep 2016 11:56:13 +0200 Subject: [PATCH] Fix issue with unexpected notification windows appearing after report editor exit [fixes SCI-463] --- app/assets/javascripts/reports/new.js | 82 ++++++++++++++------------- 1 file changed, 44 insertions(+), 38 deletions(-) diff --git a/app/assets/javascripts/reports/new.js b/app/assets/javascripts/reports/new.js index 11eff9163..83553349d 100644 --- a/app/assets/javascripts/reports/new.js +++ b/app/assets/javascripts/reports/new.js @@ -435,40 +435,43 @@ function initializeSaveToPdf() { } function initializeUnsavedWorkDialog() { - var dh = $("#data-holder"); - var alertText = dh.attr("data-unsaved-work-text"); + var dh = $('#data-holder'); + var alertText = dh.attr('data-unsaved-work-text'); ignoreUnsavedWorkAlert = false; + if ( ignoreUnsavedWorkAlert ) return; - $(window) - .on("beforeunload", function(ev) { - if (ignoreUnsavedWorkAlert) { - // Remove unload listeners - $(window).off("beforeunload"); - $(document).off("page:before-change"); + $(document).on('page:before-change', beforechange); + $(window).on('beforeunload', beforeunload); - ev.returnValue = undefined; - return undefined; - } else { + function beforeunload(ev) { + //Check if we are actually in report editor + if ( $(REPORT_CONTENT).length ) { return alertText; - } - }); - $(document).on("page:before-change", function(ev) { - var exit; - if (ignoreUnsavedWorkAlert) { - exit = true; } else { + // We are at another page so remove unload handlers if they exists + $(window).off('beforeunload', beforeunload); + $(document).off('page:before-change', beforechange); + } + } + + function beforechange(ev) { + //Check if we are actually in report editor + if ( $(REPORT_CONTENT).length ) { + var exit; exit = confirm(alertText); + if ( exit ) { + // We leave the page so remove all listeners + $(window).off(); + $(document).off(); + } + return exit; + } else { + // We are at another page so remove unload handlers if they exists + $(window).off('beforeunload', beforeunload); + $(document).off('page:before-change', beforechange); } - - if (exit) { - // Remove unload listeners - $(window).off("beforeunload"); - $(document).off("page:before-change"); - } - - return exit; - }); + } } /** @@ -1197,19 +1200,22 @@ $(document).ready(function() { /** * ACTUAL CODE */ - initializeReportElements($(REPORT_CONTENT)); - initializeGlobalReportSort(); - initializePrintPopup(); - initializeSaveToPdf(); - initializeSaveReport(); - initializeAddContentsModal(); - initializeSidebarNavigation(); - initializeUnsavedWorkDialog(); - initializeTutorial(); + //Check if we are actually at new report page + if ( $(REPORT_CONTENT).length ) { + initializeReportElements($(REPORT_CONTENT)); + initializeGlobalReportSort(); + initializePrintPopup(); + initializeSaveToPdf(); + initializeSaveReport(); + initializeAddContentsModal(); + initializeSidebarNavigation(); + initializeUnsavedWorkDialog(); + initializeTutorial(); - $(".report-nav-link").each( function(){ - truncateLongString( $(this), 30); - }); + $(".report-nav-link").each( function(){ + truncateLongString( $(this), 30); + }); + } }) $(document).change(function(){