From ff808727f73869de0d7b10e16d7de65146d5c32d Mon Sep 17 00:00:00 2001 From: Andrew Thornton Date: Sat, 4 Jul 2020 18:19:32 +0100 Subject: [PATCH] Re-fix #12095 again Unfortunately some of the suggested changes to #12095 introduced bugs which due to caching behaviour of sharedworkers were not caught on simple tests. These are as follows: * Changing from simple for loop to use includes here: ```js register(port) { if (!this.clients.includes(port)) return; this.clients.push(port); port.postMessage({ type: 'status', message: `registered to ${this.url}`, }); } ``` The additional `!` prevents any clients from being added and should read: ```js if (this.clients.includes(port)) return; ``` * Dropping the use of jQuery `$(...)` selection and using DOM `querySelector` here: ```js async function receiveUpdateCount(event) { try { const data = JSON.parse(event.data); const notificationCount = document.querySelector('.notification_count'); if (data.Count > 0) { notificationCount.classList.remove('hidden'); } else { notificationCount.classList.add('hidden'); } notificationCount.text() = `${data.Count}`; await updateNotificationTable(); } catch (error) { console.error(error, event); } } ``` Requires that `notificationCount.text()` be changed to use `textContent` instead. Signed-off-by: Andrew Thornton --- web_src/js/features/eventsource.sharedworker.js | 2 +- web_src/js/features/notification.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/web_src/js/features/eventsource.sharedworker.js b/web_src/js/features/eventsource.sharedworker.js index e3c60ce0db181..bb4f628f6cb47 100644 --- a/web_src/js/features/eventsource.sharedworker.js +++ b/web_src/js/features/eventsource.sharedworker.js @@ -16,7 +16,7 @@ class Source { } register(port) { - if (!this.clients.includes(port)) return; + if (this.clients.includes(port)) return; this.clients.push(port); diff --git a/web_src/js/features/notification.js b/web_src/js/features/notification.js index aa1b48d183739..b0cc1cda4470e 100644 --- a/web_src/js/features/notification.js +++ b/web_src/js/features/notification.js @@ -29,7 +29,7 @@ async function receiveUpdateCount(event) { notificationCount.classList.add('hidden'); } - notificationCount.text(`${data.Count}`); + notificationCount.textContent = `${data.Count}`; await updateNotificationTable(); } catch (error) { console.error(error, event);