diff --git a/src/app/_components/album-image.tsx b/src/app/_components/album-image.tsx index c96e086..af9bd45 100644 --- a/src/app/_components/album-image.tsx +++ b/src/app/_components/album-image.tsx @@ -48,6 +48,9 @@ export function AlbumImage({ error, }: AlbumImageProps) { const [spookyImageLoaded, setSpookyImageLoaded] = useState(false); + const [loadError, setLoadError] = useState(false); + + const errorValue = error || loadError; const handleSaveImage = async () => { if (!entry.data && !entry.isLoading) { @@ -87,7 +90,7 @@ export function AlbumImage({ src={imageSource} alt={album.name} /> - {loadGeneratedImage && spookyImageSource && !error && ( + {loadGeneratedImage && spookyImageSource && !errorValue && ( { onImageLoad(); + setLoadError(true); }} /> )} - {showSpookyImage && !spookyImageLoaded && !error && ( + {showSpookyImage && !spookyImageLoaded && !errorValue && (
{(() => { if (generateSpookyImageData) { @@ -130,7 +134,7 @@ export function AlbumImage({ })()}
)} - {error && showSpookyImage && ( + {errorValue && showSpookyImage && (
diff --git a/src/app/_components/album-showcase.tsx b/src/app/_components/album-showcase.tsx index 126b8dd..eeb32ce 100644 --- a/src/app/_components/album-showcase.tsx +++ b/src/app/_components/album-showcase.tsx @@ -9,6 +9,7 @@ import { pulsar } from "ldrs"; import Swiper from "./swiper"; import { SwiperSlide } from "swiper/react"; import AlbumImage from "./album-image"; +import ScrollFadeIn from "./scroll-fade-in"; pulsar.register(); ring2.register(); @@ -112,13 +113,17 @@ export default function AlbumShowcase({ handleSecondGenerateSpookyImage(); }, [secondEntry.data, entry.data]); - const secondSpookyImageMatch = ( - (secondEntry.data?.value || generateSecondSpookyImage?.data || "") as string - ).match(/]*>/); - const secondSpookyImageSource = - secondSpookyImageMatch && secondSpookyImageMatch[1] + const secondSpookyImageSource = useMemo(() => { + const secondSpookyImageMatch = ( + (secondEntry.data?.value || + generateSecondSpookyImage?.data || + "") as string + )?.match(/]*>/); + + return secondSpookyImageMatch && secondSpookyImageMatch[1] ? secondSpookyImageMatch[1] : ""; + }, [secondEntry.data, generateSecondSpookyImage.data]); const firstPlace = places[0] || 0; const secondPlace = places[1] || 0; @@ -129,10 +134,11 @@ export default function AlbumShowcase({ ); return ( -
+ + {/*
*/}
setShowSpookyImage(!showSpookyImage)} className="mr-2 cursor-pointer *:select-none *:drag-none" @@ -233,6 +239,7 @@ export default function AlbumShowcase({ ))} -
+ {/*
*/} +
); } diff --git a/src/server/api/routers/entry.ts b/src/server/api/routers/entry.ts index c3f663f..2834b9e 100644 --- a/src/server/api/routers/entry.ts +++ b/src/server/api/routers/entry.ts @@ -6,6 +6,7 @@ import { makeImageSpooky, uploadImage, } from "@/server/utils"; +import { TRPCError } from "@trpc/server"; export type Entry = { type: "artist" | "album"; @@ -50,11 +51,17 @@ export const entryRouter = createTRPCRouter({ try { const uploadedImage = await uploadImage(input.entry.image); if (!uploadedImage || typeof uploadedImage !== "string") { - throw new Error("Failed to upload image"); + throw new TRPCError({ + code: "INTERNAL_SERVER_ERROR", + message: "Failed to upload image", + }); } const spookyImage = makeImageSpooky(uploadedImage, input.entry.number); if (!spookyImage || typeof spookyImage !== "string") { - throw new Error("Failed to make image spooky"); + throw new TRPCError({ + code: "INTERNAL_SERVER_ERROR", + message: "Failed to make image spooky", + }); } await ctx.db.generatedImage.upsert({ where: { @@ -69,6 +76,9 @@ export const entryRouter = createTRPCRouter({ return spookyImage; } catch (error) { console.error(error); + if (error instanceof TRPCError) { + throw error; + } return error; } }), @@ -93,7 +103,10 @@ export const entryRouter = createTRPCRouter({ }, }); if (!generatedImage) { - throw new Error("No generated image found"); + throw new TRPCError({ + code: "NOT_FOUND", + message: "No generated image found", + }); } const entry = await ctx.db.spookyImage.create({ data: { @@ -104,6 +117,9 @@ export const entryRouter = createTRPCRouter({ return entry; } catch (error) { console.error(error); + if (error instanceof TRPCError) { + throw error; + } return error; } }),