From 0312f1aae9c548bcd0ae5a9d58d12e6d6453b87b Mon Sep 17 00:00:00 2001 From: Claas Augner <495429+caugner@users.noreply.github.com> Date: Thu, 28 Mar 2024 14:01:59 +0100 Subject: [PATCH] fix(contributor-spotlight): show PageNotFound on error (#9759) Previously we just showed an empty page. --- client/src/contributor-spotlight/index.tsx | 60 ++++++++++++---------- 1 file changed, 32 insertions(+), 28 deletions(-) diff --git a/client/src/contributor-spotlight/index.tsx b/client/src/contributor-spotlight/index.tsx index 9abc4bf2fd42..35261fd4a89d 100644 --- a/client/src/contributor-spotlight/index.tsx +++ b/client/src/contributor-spotlight/index.tsx @@ -9,6 +9,8 @@ import { Quote } from "../ui/molecules/quote"; import "./index.scss"; import { useLocale } from "../hooks"; +import { PageNotFound } from "../page-not-found"; +import { Loading } from "../ui/atoms/loading"; type ContributorDetails = { sections: [string]; @@ -31,7 +33,7 @@ export function ContributorSpotlight(props: HydrationData) { const fallbackData = props.hyData ? props : undefined; - const { data: { hyData } = {} } = useSWR( + const { error, data: { hyData } = {} } = useSWR( contributorJSONUrl, async (url) => { const response = await fetch(url); @@ -55,37 +57,39 @@ export function ContributorSpotlight(props: HydrationData) { document.title = pageTitle; }, [hyData]); + if (error) { + return ; + } else if (!hyData) { + return ; + } + return ( <>
- {hyData && ( - <> -

Contributor profile

-
- {hyData.profileImgAlt} - - @{hyData.usernames.github} - -
-
- {hyData.quote} +

Contributor profile

+
+ {hyData.profileImgAlt} + + @{hyData.usernames.github} + +
+
+ {hyData.quote} - {hyData.sections.slice(1).map((section) => { - return
; - })} - - )} + {hyData.sections.slice(1).map((section) => { + return
; + })}