diff --git a/cors-proxy/src/index.ts b/cors-proxy/src/index.ts index 56125eb8..29d7af25 100644 --- a/cors-proxy/src/index.ts +++ b/cors-proxy/src/index.ts @@ -64,7 +64,10 @@ export default { const apiUrl = url.searchParams.get(QUERYSTRING_KEY); if (apiUrl == null) { - return new Response(`Missing GET parameter: ${QUERYSTRING_KEY}`); + return new Response(`Missing GET parameter: ${QUERYSTRING_KEY}`, { + status: 400, + statusText: `Bad Request: ${QUERYSTRING_KEY} param undefined`, + }); } // Rewrite request to point to API URL. This also makes the request mutable diff --git a/frontend/components/hypercert-create.tsx b/frontend/components/hypercert-create.tsx index 6fe25ff1..a4f0e91c 100644 --- a/frontend/components/hypercert-create.tsx +++ b/frontend/components/hypercert-create.tsx @@ -379,6 +379,12 @@ export function HypercertCreateForm(props: HypercertCreateFormProps) { } const image = await exportAsImage(IMAGE_SELECTOR); + + if (!image) { + setSubmitting(false); + return; + } + const metaData = formatValuesToMetaData( values, // eslint-disable-next-line @typescript-eslint/no-non-null-assertion @@ -516,7 +522,18 @@ const exportAsImage = async (id: string) => { //useCORS: true, proxy: "https://cors-proxy.hypercerts.workers.dev/", imageTimeout: 0, + }).catch((e) => { + toast("Error loading hypercert image . Please contact the team.", { + type: "error", + }); + console.error("Error exporting image: ", e); + return undefined; }); + + if (!canvas) { + return undefined; + } + const image = canvas.toDataURL("image/png", 1.0); return image; };