aboutsummaryrefslogtreecommitdiffstats
path: root/src/utils/hooks/use-thematic/use-thematic.ts
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2023-12-01 13:26:44 +0100
committerArmand Philippot <git@armandphilippot.com>2023-12-01 17:23:19 +0100
commitdfdbf6cac1fe3719dc71e130129d28e04ba4e225 (patch)
treef865bdad53cef95bdfb10fc04174a0173ab36f15 /src/utils/hooks/use-thematic/use-thematic.ts
parent5b762b1b669454a89899c4bdf6008027d9615acf (diff)
refactor(pages): refine Thematic pages
* add a table of contents (however posts heading are not included) * rename posts list section title * add a useThematic hook to refresh thematic contents * add a useThematicLists hook to refresh thematics list * add a `notIn` filter in thematics list fetcher to directly remove unwanted thematics * add Cypress tests
Diffstat (limited to 'src/utils/hooks/use-thematic/use-thematic.ts')
-rw-r--r--src/utils/hooks/use-thematic/use-thematic.ts31
1 files changed, 31 insertions, 0 deletions
diff --git a/src/utils/hooks/use-thematic/use-thematic.ts b/src/utils/hooks/use-thematic/use-thematic.ts
new file mode 100644
index 0000000..68127d2
--- /dev/null
+++ b/src/utils/hooks/use-thematic/use-thematic.ts
@@ -0,0 +1,31 @@
+import useSWR from 'swr';
+import {
+ convertWPThematicToThematic,
+ fetchThematic,
+} from '../../../services/graphql';
+import type { Maybe, Thematic, WPThematic } from '../../../types';
+
+export type UseThematicReturn<T extends Maybe<WPThematic>> = {
+ isError: boolean;
+ isLoading: boolean;
+ isValidating: boolean;
+ thematic: T extends undefined ? Maybe<Thematic> : Thematic;
+};
+
+export const useThematic = <T extends Maybe<WPThematic>>(
+ slug: string,
+ fallback?: T
+): UseThematicReturn<T> => {
+ const { data, error, isLoading, isValidating } = useSWR(slug, fetchThematic, {
+ fallbackData: fallback,
+ });
+
+ if (error) console.error(error);
+
+ return {
+ isError: !!error,
+ isLoading,
+ isValidating,
+ thematic: data ? convertWPThematicToThematic(data) : undefined,
+ } as UseThematicReturn<T>;
+};