From 8687646e9c09c8bea76c2d8a0e52b260e77a8323 Mon Sep 17 00:00:00 2001 From: LASER-Yi Date: Sun, 21 Aug 2022 12:12:19 +0800 Subject: [PATCH] Fix inconsistent issues when backend trying to update episodes --- frontend/src/apis/hooks/episodes.ts | 2 ++ frontend/src/modules/socketio/reducer.ts | 32 ++++++++++++++++++++++-- 2 files changed, 32 insertions(+), 2 deletions(-) diff --git a/frontend/src/apis/hooks/episodes.ts b/frontend/src/apis/hooks/episodes.ts index c4f793047..0dd473c4f 100644 --- a/frontend/src/apis/hooks/episodes.ts +++ b/frontend/src/apis/hooks/episodes.ts @@ -10,6 +10,8 @@ import api from "../raw"; const cacheEpisodes = (client: QueryClient, episodes: Item.Episode[]) => { episodes.forEach((item) => { + client.setQueryData([QueryKeys.Episodes, item.sonarrEpisodeId], item); + client.setQueryData( [ QueryKeys.Series, diff --git a/frontend/src/modules/socketio/reducer.ts b/frontend/src/modules/socketio/reducer.ts index 523c71506..83444f99c 100644 --- a/frontend/src/modules/socketio/reducer.ts +++ b/frontend/src/modules/socketio/reducer.ts @@ -1,5 +1,6 @@ import queryClient from "@/apis/queries"; import { QueryKeys } from "@/apis/queries/keys"; +import { LOG } from "@/utilities/console"; import { setCriticalError, setOnlineStatus } from "@/utilities/event"; import { showNotification } from "@mantine/notifications"; import { notification, task } from "../task"; @@ -36,11 +37,13 @@ export function createDefaultReducer(): SocketIO.Reducer[] { { key: "series", update: (ids) => { + LOG("info", "Invalidating series", ids); ids.forEach((id) => { queryClient.invalidateQueries([QueryKeys.Series, id]); }); }, delete: (ids) => { + LOG("info", "Invalidating series", ids); ids.forEach((id) => { queryClient.invalidateQueries([QueryKeys.Series, id]); }); @@ -49,11 +52,13 @@ export function createDefaultReducer(): SocketIO.Reducer[] { { key: "movie", update: (ids) => { + LOG("info", "Invalidating movies", ids); ids.forEach((id) => { queryClient.invalidateQueries([QueryKeys.Movies, id]); }); }, delete: (ids) => { + LOG("info", "Invalidating movies", ids); ids.forEach((id) => { queryClient.invalidateQueries([QueryKeys.Movies, id]); }); @@ -62,13 +67,36 @@ export function createDefaultReducer(): SocketIO.Reducer[] { { key: "episode", update: (ids) => { + // Currently invalidate episodes is impossible because we don't directly fetch episodes (we fetch episodes by series id) + // So we need to invalidate series instead + // TODO: Make a query for episodes and invalidate that instead + LOG("info", "Invalidating episodes", ids); ids.forEach((id) => { - queryClient.invalidateQueries([QueryKeys.Episodes, id]); + const episode = queryClient.getQueryData([ + QueryKeys.Episodes, + id, + ]); + if (episode !== undefined) { + queryClient.invalidateQueries([ + QueryKeys.Series, + episode.sonarrSeriesId, + ]); + } }); }, delete: (ids) => { + LOG("info", "Invalidating episodes", ids); ids.forEach((id) => { - queryClient.invalidateQueries([QueryKeys.Episodes, id]); + const episode = queryClient.getQueryData([ + QueryKeys.Episodes, + id, + ]); + if (episode !== undefined) { + queryClient.invalidateQueries([ + QueryKeys.Series, + episode.sonarrSeriesId, + ]); + } }); }, },