From d7878b8b45959bf65ce4de8c05df5a6f86ad87b7 Mon Sep 17 00:00:00 2001 From: bartekch Date: Tue, 31 Jan 2023 11:53:38 +0100 Subject: [PATCH 1/3] Log clicks --- inst/assets/js/loadingbutton.js | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/inst/assets/js/loadingbutton.js b/inst/assets/js/loadingbutton.js index 437d396..1b94713 100644 --- a/inst/assets/js/loadingbutton.js +++ b/inst/assets/js/loadingbutton.js @@ -6,7 +6,8 @@ function LoadingButtons() { } LoadingButtons.prototype.create = function (inputId, options) { - + var id = Math.random(1); + console.log("Creating button with id " + id); var btn_value = null; // find all loading buttons in the dom and remove any loading buttons from // this.buttons that are no longer in the dom. By running this "garbage collection" @@ -34,7 +35,7 @@ LoadingButtons.prototype.create = function (inputId, options) { $(document).on('click', "#" + inputId, function() { // increment the button value by 1. This is consistent with how `shiny::actionButton` // value works. - + console.log("Click button " + id + " with value ", btn_value); if (btn_value === null) { btn_value = 1; } else { From c1f9b71553574fc9fabbecf6ca39892aacba626f Mon Sep 17 00:00:00 2001 From: bartekch Date: Tue, 31 Jan 2023 12:05:21 +0100 Subject: [PATCH 2/3] Multiple listeners fix --- inst/assets/js/loadingbutton.js | 43 +++++++++++++++++++-------------- 1 file changed, 25 insertions(+), 18 deletions(-) diff --git a/inst/assets/js/loadingbutton.js b/inst/assets/js/loadingbutton.js index 1b94713..c1c2b06 100644 --- a/inst/assets/js/loadingbutton.js +++ b/inst/assets/js/loadingbutton.js @@ -14,28 +14,12 @@ LoadingButtons.prototype.create = function (inputId, options) { // each time we add a new loading button to the dom we protect against the this.loadingButtons // object growing out of control as loading buttons are quickly added and removed from the dom var self = this; - $(function() { - var allDOMLoadingButtons = $(document).find(".sf-loading-button"); - var loadingIds = []; - for(var obj of allDOMLoadingButtons) { - loadingIds.push(obj.id); - } - - // if element in this.buttons represents a loadingButton that is no longer in the DOM - // then remove it from this.buttons. Also remove remove it if the button being added already - // exists in this.buttons - self.buttons = self.buttons.filter(obj => { - return loadingIds.includes("sf-loading-button-" + obj.inputId) && (obj.inputId !== inputId); - }); - self.buttons.push({inputId: inputId, options: options}); - }); - - // Disable button & change text - $(document).on('click', "#" + inputId, function() { + click_button = function() { // increment the button value by 1. This is consistent with how `shiny::actionButton` // value works. console.log("Click button " + id + " with value ", btn_value); + if (btn_value === null) { btn_value = 1; } else { @@ -50,7 +34,30 @@ LoadingButtons.prototype.create = function (inputId, options) { loading_button.attr('style', options.loadingStyle); loading_button.removeClass(options["class"]); loading_button.addClass(options.loadingClass); + }; + + $(function() { + var allDOMLoadingButtons = $(document).find(".sf-loading-button"); + var loadingIds = []; + for(var obj of allDOMLoadingButtons) { + loadingIds.push(obj.id); + } + + // if element in this.buttons represents a loadingButton that is no longer in the DOM + // then remove it from this.buttons. Also remove remove it if the button being added already + // exists in this.buttons + self.buttons = self.buttons.filter(obj => { + if (obj.inputId == inputId) { + $(document).off('click', "#" + inputId, obj.handler); + }; + return loadingIds.includes("sf-loading-button-" + obj.inputId) && (obj.inputId !== inputId); + }); + + self.buttons.push({inputId: inputId, options: options, click_handler: click_button}); }); + + // Disable button & change text + $(document).on('click', "#" + inputId, click_button); }; LoadingButtons.prototype.resetLoading = function (inputId) { From ecdac28d0f8e640d8322923458c1ab7784740c63 Mon Sep 17 00:00:00 2001 From: bartekch Date: Tue, 31 Jan 2023 12:08:02 +0100 Subject: [PATCH 3/3] Update loadingbutton.js --- inst/assets/js/loadingbutton.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/inst/assets/js/loadingbutton.js b/inst/assets/js/loadingbutton.js index c1c2b06..984075f 100644 --- a/inst/assets/js/loadingbutton.js +++ b/inst/assets/js/loadingbutton.js @@ -48,7 +48,7 @@ LoadingButtons.prototype.create = function (inputId, options) { // exists in this.buttons self.buttons = self.buttons.filter(obj => { if (obj.inputId == inputId) { - $(document).off('click', "#" + inputId, obj.handler); + $(document).off('click', "#" + inputId, obj.click_handler); }; return loadingIds.includes("sf-loading-button-" + obj.inputId) && (obj.inputId !== inputId); });