Skip to content

Commit

Permalink
Converts to Opengraph Image file convention. (vercel#1043)
Browse files Browse the repository at this point in the history
  • Loading branch information
manovotny authored Jun 8, 2023
1 parent e4fcf19 commit 87c385f
Show file tree
Hide file tree
Showing 9 changed files with 75 additions and 77 deletions.
11 changes: 11 additions & 0 deletions app/[page]/opengraph-image.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import OpengraphImage from 'components/opengraph-image';
import { getPage } from 'lib/shopify';

export const runtime = 'edge';

export default async function Image({ params }: { params: { page: string } }) {
const page = await getPage(params.page);
const title = page.seo?.title || page.title;

return await OpengraphImage({ title });
}
Binary file removed app/api/og/Inter-Regular.ttf
Binary file not shown.
67 changes: 0 additions & 67 deletions app/api/og/route.tsx

This file was deleted.

7 changes: 7 additions & 0 deletions app/opengraph-image.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
import OpengraphImage from 'components/opengraph-image';

export const runtime = 'edge';

export default async function Image() {
return await OpengraphImage();
}
11 changes: 11 additions & 0 deletions app/search/[collection]/opengraph-image.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import OpengraphImage from 'components/opengraph-image';
import { getCollection } from 'lib/shopify';

export const runtime = 'edge';

export default async function Image({ params }: { params: { collection: string } }) {
const collection = await getCollection(params.collection);
const title = collection?.seo?.title || collection?.title;

return await OpengraphImage({ title });
}
11 changes: 1 addition & 10 deletions app/search/[collection]/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,16 +20,7 @@ export async function generateMetadata({
return {
title: collection.seo?.title || collection.title,
description:
collection.seo?.description || collection.description || `${collection.title} products`,
openGraph: {
images: [
{
url: `/api/og?title=${encodeURIComponent(collection.title)}`,
width: 1200,
height: 630
}
]
}
collection.seo?.description || collection.description || `${collection.title} products`
};
}

Expand Down
45 changes: 45 additions & 0 deletions components/opengraph-image.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
import { ImageResponse } from '@vercel/og';

export type Props = {
title?: string;
};

export default async function OpengraphImage(props?: Props): Promise<ImageResponse> {
const { title } = {
...{
title: process.env.SITE_NAME
},
...props
};

return new ImageResponse(
(
<div tw="flex h-full w-full flex-col items-center justify-center bg-black">
<svg viewBox="0 0 32 32" width="140">
<rect width="100%" height="100%" rx="16" fill="white" />
<path
fillRule="evenodd"
clipRule="evenodd"
fill="black"
d="M17.6482 10.1305L15.8785 7.02583L7.02979 22.5499H10.5278L17.6482 10.1305ZM19.8798 14.0457L18.11 17.1983L19.394 19.4511H16.8453L15.1056 22.5499H24.7272L19.8798 14.0457Z"
/>
</svg>
<p tw="mt-12 text-6xl font-bold text-white">{title}</p>
</div>
),
{
width: 1200,
height: 630,
fonts: [
{
name: 'Inter',
data: await fetch(new URL('../fonts/Inter-Bold.ttf', import.meta.url)).then((res) =>
res.arrayBuffer()
),
style: 'normal',
weight: 700
}
]
}
);
}
File renamed without changes.
File renamed without changes.

0 comments on commit 87c385f

Please sign in to comment.