diff --git a/apps/dashboard/src/components/OgEditor.tsx b/apps/dashboard/src/components/OgEditor.tsx index d93a07a..9f67131 100644 --- a/apps/dashboard/src/components/OgEditor.tsx +++ b/apps/dashboard/src/components/OgEditor.tsx @@ -1,6 +1,7 @@ "use client"; import { useEffect, useRef } from "react"; import { Box, Flex } from "@radix-ui/themes"; +import { useRouter } from "next/navigation"; import type { OGElement } from "../lib/types"; import { createElementId } from "../lib/elements"; import { useZoomStore } from "../stores/zoomStore"; @@ -21,6 +22,7 @@ interface OgProviderProps { let elementIdToCopy: string | undefined; export function OgEditor({ imageId, width, height }: OgProviderProps) { + const router = useRouter(); const rootRef = useRef(null); const zoom = useZoomStore((state) => state.zoom); const { @@ -42,7 +44,11 @@ export function OgEditor({ imageId, width, height }: OgProviderProps) { * state, and load the elements and fonts. */ useEffect(() => { - loadImage(imageId); + // If the image doesn't exist, redirect to the images page + if (!loadImage(imageId)) { + router.push("/my-images"); + return; + } if (useImagesStore.persist.hasHydrated()) { setSelectedImageId(imageId); @@ -51,7 +57,7 @@ export function OgEditor({ imageId, width, height }: OgProviderProps) { useImagesStore.persist.onFinishHydration(() => { setSelectedImageId(imageId); }); - }, [imageId, loadImage, setSelectedImageId]); + }, [imageId, loadImage, router, setSelectedImageId]); useEffect(() => { function onClick(event: MouseEvent) { diff --git a/apps/dashboard/src/lib/__tests__/__snapshots__/export.test.ts.snap b/apps/dashboard/src/lib/__tests__/__snapshots__/export.test.ts.snap index 9ffb8ce..c126b5b 100644 --- a/apps/dashboard/src/lib/__tests__/__snapshots__/export.test.ts.snap +++ b/apps/dashboard/src/lib/__tests__/__snapshots__/export.test.ts.snap @@ -4609,4 +4609,4 @@ Uint8Array [ ] `; -exports[`renderToImg > should render to a base64 data url 1`] = `""`; +exports[`renderToImg > should render to a base64 data url 1`] = `""`; diff --git a/apps/dashboard/src/stores/elementsStore.ts b/apps/dashboard/src/stores/elementsStore.ts index 6fd9ffb..74de8ca 100644 --- a/apps/dashboard/src/stores/elementsStore.ts +++ b/apps/dashboard/src/stores/elementsStore.ts @@ -7,7 +7,7 @@ interface ElementsState { imageId: string; elements: OGElement[]; setElements: (elements: OGElement[]) => void; - loadImage: (imageId: string) => void; + loadImage: (imageId: string) => boolean; selectedElementId: string | null; setSelectedElementId: (id: string | null) => void; addElement: (element: OGElement) => void; @@ -24,10 +24,12 @@ export const useElementsStore = create()( set({ elements }); }, loadImage: (imageId) => { - const elements = JSON.parse( - localStorage.getItem(imageId) ?? "[]", - ) as OGElement[]; + const item = localStorage.getItem(imageId); + if (!item && imageId !== "splash") { + return false; + } + const elements = JSON.parse(item ?? "[]") as OGElement[]; set({ imageId, elements, selectedElementId: null }); // Immediately load fonts for elements that will be visible on the page. @@ -38,6 +40,7 @@ export const useElementsStore = create()( }); useElementsStore.temporal.getState().clear(); + return true; }, selectedElementId: null, setSelectedElementId: (id) => {