From 27a2edcb7925f7c82a50d2df983ba4c51d2cb2c1 Mon Sep 17 00:00:00 2001 From: Claire Date: Thu, 13 Oct 2022 08:55:00 +0200 Subject: [PATCH 1/2] Fix issues with notification cleaning mode when there is a disconnection gap (#1867) --- .../flavours/glitch/reducers/notifications.js | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/app/javascript/flavours/glitch/reducers/notifications.js b/app/javascript/flavours/glitch/reducers/notifications.js index 1b593b1281..0da5ac457d 100644 --- a/app/javascript/flavours/glitch/reducers/notifications.js +++ b/app/javascript/flavours/glitch/reducers/notifications.js @@ -162,7 +162,9 @@ const deleteByStatus = (state, statusId) => { const markForDelete = (state, notificationId, yes) => { return state.update('items', list => list.map(item => { - if(item.get('id') === notificationId) { + if (item === null) { + return null; + } else if(item.get('id') === notificationId) { return item.set('markedForDelete', yes); } else { return item; @@ -172,7 +174,9 @@ const markForDelete = (state, notificationId, yes) => { const markAllForDelete = (state, yes) => { return state.update('items', list => list.map(item => { - if(yes !== null) { + if (item === null) { + return null; + } else if(yes !== null) { return item.set('markedForDelete', yes); } else { return item.set('markedForDelete', !item.get('markedForDelete')); @@ -181,11 +185,11 @@ const markAllForDelete = (state, yes) => { }; const unmarkAllForDelete = (state) => { - return state.update('items', list => list.map(item => item.set('markedForDelete', false))); + return state.update('items', list => list.map(item => item === null ? item : item.set('markedForDelete', false))); }; const deleteMarkedNotifs = (state) => { - return state.update('items', list => list.filterNot(item => item.get('markedForDelete'))); + return state.update('items', list => list.filterNot(item => item === null ? item : item.get('markedForDelete'))); }; const updateMounted = (state) => { From 7e62688a0e656d71b0358fa55d5f6e8f8103c297 Mon Sep 17 00:00:00 2001 From: Claire Date: Thu, 13 Oct 2022 20:00:20 +0200 Subject: [PATCH 2/2] Fix notification cleaning mode causing notifications to get stuck (#1868) --- app/javascript/flavours/glitch/reducers/notifications.js | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/app/javascript/flavours/glitch/reducers/notifications.js b/app/javascript/flavours/glitch/reducers/notifications.js index 0da5ac457d..4adb0a3ba6 100644 --- a/app/javascript/flavours/glitch/reducers/notifications.js +++ b/app/javascript/flavours/glitch/reducers/notifications.js @@ -253,10 +253,10 @@ export default function notifications(state = initialState, action) { return state.update('items', list => state.get('pendingItems').concat(list.take(40))).set('pendingItems', ImmutableList()).set('unread', 0); case NOTIFICATIONS_EXPAND_REQUEST: case NOTIFICATIONS_DELETE_MARKED_REQUEST: - return state.set('isLoading', (nbLoading) => nbLoading + 1); + return state.update('isLoading', (nbLoading) => nbLoading + 1); case NOTIFICATIONS_DELETE_MARKED_FAIL: case NOTIFICATIONS_EXPAND_FAIL: - return state.set('isLoading', (nbLoading) => nbLoading - 1); + return state.update('isLoading', (nbLoading) => nbLoading - 1); case NOTIFICATIONS_FILTER_SET: return state.set('items', ImmutableList()).set('hasMore', true); case NOTIFICATIONS_SCROLL_TOP: @@ -291,7 +291,7 @@ export default function notifications(state = initialState, action) { return markForDelete(state, action.id, action.yes); case NOTIFICATIONS_DELETE_MARKED_SUCCESS: - return deleteMarkedNotifs(state).set('isLoading', (nbLoading) => nbLoading - 1); + return deleteMarkedNotifs(state).update('isLoading', (nbLoading) => nbLoading - 1); case NOTIFICATIONS_ENTER_CLEARING_MODE: st = state.set('cleaningMode', action.yes);