From 8eb5316c9fbae46c0128f201e9d9dd5e2d459b94 Mon Sep 17 00:00:00 2001 From: psychedelicious <4822129+psychedelicious@users.noreply.github.com> Date: Mon, 20 May 2024 18:23:01 +1000 Subject: [PATCH] feat(ui): invalidate cache for queue item on status change This query is only subscribed-to in the `QueueItemDetail` component - when is rendered only when the user clicks on a queue item in the queue. Invalidating this tag instead of optimistically updating it won't cause any meaningful change to network traffic. --- .../socketio/socketQueueItemStatusChanged.ts | 26 +++++-------------- 1 file changed, 7 insertions(+), 19 deletions(-) diff --git a/invokeai/frontend/web/src/app/store/middleware/listenerMiddleware/listeners/socketio/socketQueueItemStatusChanged.ts b/invokeai/frontend/web/src/app/store/middleware/listenerMiddleware/listeners/socketio/socketQueueItemStatusChanged.ts index 5c92e81001..b1befe7417 100644 --- a/invokeai/frontend/web/src/app/store/middleware/listenerMiddleware/listeners/socketio/socketQueueItemStatusChanged.ts +++ b/invokeai/frontend/web/src/app/store/middleware/listenerMiddleware/listeners/socketio/socketQueueItemStatusChanged.ts @@ -14,7 +14,7 @@ export const addSocketQueueItemStatusChangedEventListener = (startAppListening: actionCreator: socketQueueItemStatusChanged, effect: async (action, { dispatch }) => { // we've got new status for the queue item, batch and queue - const { item_id, status, started_at, updated_at, error, completed_at, created_at, batch_status, queue_status } = + const { item_id, status, started_at, updated_at, error, completed_at, batch_status, queue_status } = action.payload.data; log.debug(action.payload, `Queue item ${item_id} status updated: ${status}`); @@ -50,27 +50,15 @@ export const addSocketQueueItemStatusChangedEventListener = (startAppListening: queueApi.util.updateQueryData('getBatchStatus', { batch_id: batch_status.batch_id }, () => batch_status) ); - // Update the queue item status (this is the full queue item, including the session) - dispatch( - queueApi.util.updateQueryData('getQueueItem', item_id, (draft) => { - if (!draft) { - return; - } - Object.assign(draft, { - status, - started_at, - updated_at, - error, - completed_at, - created_at, - }); - }) - ); - // Invalidate caches for things we cannot update // TODO: technically, we could possibly update the current session queue item, but feels safer to just request it again dispatch( - queueApi.util.invalidateTags(['CurrentSessionQueueItem', 'NextSessionQueueItem', 'InvocationCacheStatus']) + queueApi.util.invalidateTags([ + 'CurrentSessionQueueItem', + 'NextSessionQueueItem', + 'InvocationCacheStatus', + { type: 'SessionQueueItem', id: item_id }, + ]) ); if (['in_progress'].includes(action.payload.data.status)) {