Initail_Commit
This commit is contained in:
100
src/app/og/route.tsx
Normal file
100
src/app/og/route.tsx
Normal file
@@ -0,0 +1,100 @@
|
||||
import { ImageResponse } from 'next/og'
|
||||
import { baseURL } from '@/app/resources';
|
||||
import { person } from '@/app/resources';
|
||||
|
||||
export const runtime = 'edge';
|
||||
|
||||
export async function GET(request: Request) {
|
||||
let url = new URL(request.url)
|
||||
let title = url.searchParams.get('title') || 'Portfolio'
|
||||
const font = fetch(
|
||||
new URL('../../../public/fonts/Inter.ttf', import.meta.url)
|
||||
).then((res) => res.arrayBuffer());
|
||||
const fontData = await font;
|
||||
|
||||
return new ImageResponse(
|
||||
(
|
||||
<div
|
||||
style={{
|
||||
display: 'flex',
|
||||
width: '100%',
|
||||
height: '100%',
|
||||
padding: '8rem',
|
||||
background: '#151515',
|
||||
}}>
|
||||
<div
|
||||
style={{
|
||||
display: 'flex',
|
||||
flexDirection: 'column',
|
||||
justifyContent: 'center',
|
||||
gap: '4rem',
|
||||
fontFamily: 'Inter',
|
||||
fontStyle: 'normal',
|
||||
color: 'white',
|
||||
}}>
|
||||
<span
|
||||
style={{
|
||||
fontSize: '8rem',
|
||||
lineHeight: '8rem',
|
||||
letterSpacing: '-0.05em',
|
||||
whiteSpace: 'pre-wrap',
|
||||
textWrap: 'balance',
|
||||
}}>
|
||||
{title}
|
||||
</span>
|
||||
<div
|
||||
style={{
|
||||
display: 'flex',
|
||||
alignItems: 'center',
|
||||
gap: '5rem'
|
||||
}}>
|
||||
<img src={'https://' + baseURL + person.avatar}
|
||||
style={{
|
||||
width: '12rem',
|
||||
height: '12rem',
|
||||
objectFit: 'cover',
|
||||
borderRadius: '100%',
|
||||
}}/>
|
||||
<div
|
||||
style={{
|
||||
display: 'flex',
|
||||
flexDirection: 'column',
|
||||
gap: '0.75rem'
|
||||
}}>
|
||||
<span
|
||||
style={{
|
||||
fontSize: '4.5rem',
|
||||
lineHeight: '4.5rem',
|
||||
whiteSpace: 'pre-wrap',
|
||||
textWrap: 'balance',
|
||||
}}>
|
||||
{person.name}
|
||||
</span>
|
||||
<span
|
||||
style={{
|
||||
fontSize: '2.5rem',
|
||||
lineHeight: '2.5rem',
|
||||
whiteSpace: 'pre-wrap',
|
||||
textWrap: 'balance',
|
||||
opacity: '0.6'
|
||||
}}>
|
||||
{person.role}
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
),
|
||||
{
|
||||
width: 1920,
|
||||
height: 1080,
|
||||
fonts: [
|
||||
{
|
||||
name: 'Inter',
|
||||
data: fontData,
|
||||
style: 'normal',
|
||||
},
|
||||
],
|
||||
}
|
||||
)
|
||||
}
|
||||
Reference in New Issue
Block a user