Skip to content

Commit a0fb889

Browse files
authored
v0.5.29: chat voice mode, opengraph for docs, option to disable auth
2 parents f526c36 + 431f206 commit a0fb889

File tree

115 files changed

+1674
-841
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

115 files changed

+1674
-841
lines changed

apps/docs/app/[lang]/[[...slug]]/page.tsx

Lines changed: 15 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -243,6 +243,9 @@ export async function generateMetadata(props: {
243243
const baseUrl = 'https://docs.sim.ai'
244244
const fullUrl = `${baseUrl}${page.url}`
245245

246+
const description = page.data.description || ''
247+
const ogImageUrl = `${baseUrl}/api/og?title=${encodeURIComponent(page.data.title)}&category=DOCUMENTATION${description ? `&description=${encodeURIComponent(description)}` : ''}`
248+
246249
return {
247250
title: page.data.title,
248251
description:
@@ -272,12 +275,23 @@ export async function generateMetadata(props: {
272275
alternateLocale: ['en', 'es', 'fr', 'de', 'ja', 'zh']
273276
.filter((lang) => lang !== params.lang)
274277
.map((lang) => (lang === 'en' ? 'en_US' : `${lang}_${lang.toUpperCase()}`)),
278+
images: [
279+
{
280+
url: ogImageUrl,
281+
width: 1200,
282+
height: 630,
283+
alt: page.data.title,
284+
},
285+
],
275286
},
276287
twitter: {
277-
card: 'summary',
288+
card: 'summary_large_image',
278289
title: page.data.title,
279290
description:
280291
page.data.description || 'Sim visual workflow builder for AI applications documentation',
292+
images: [ogImageUrl],
293+
creator: '@simdotai',
294+
site: '@simdotai',
281295
},
282296
robots: {
283297
index: true,

apps/docs/app/api/og/route.tsx

Lines changed: 173 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,173 @@
1+
import { ImageResponse } from 'next/og'
2+
import type { NextRequest } from 'next/server'
3+
4+
export const runtime = 'edge'
5+
6+
const TITLE_FONT_SIZE = {
7+
large: 64,
8+
medium: 56,
9+
small: 48,
10+
} as const
11+
12+
function getTitleFontSize(title: string): number {
13+
if (title.length > 45) return TITLE_FONT_SIZE.small
14+
if (title.length > 30) return TITLE_FONT_SIZE.medium
15+
return TITLE_FONT_SIZE.large
16+
}
17+
18+
/**
19+
* Loads a Google Font dynamically by fetching the CSS and extracting the font URL.
20+
*/
21+
async function loadGoogleFont(font: string, weights: string, text: string): Promise<ArrayBuffer> {
22+
const url = `https://fonts.googleapis.com/css2?family=${font}:wght@${weights}&text=${encodeURIComponent(text)}`
23+
const css = await (await fetch(url)).text()
24+
const resource = css.match(/src: url\((.+)\) format\('(opentype|truetype)'\)/)
25+
26+
if (resource) {
27+
const response = await fetch(resource[1])
28+
if (response.status === 200) {
29+
return await response.arrayBuffer()
30+
}
31+
}
32+
33+
throw new Error('Failed to load font data')
34+
}
35+
36+
/**
37+
* Generates dynamic Open Graph images for documentation pages.
38+
*/
39+
export async function GET(request: NextRequest) {
40+
const { searchParams } = new URL(request.url)
41+
const title = searchParams.get('title') || 'Documentation'
42+
const category = searchParams.get('category') || 'DOCUMENTATION'
43+
const description = searchParams.get('description') || ''
44+
45+
const baseUrl = new URL(request.url).origin
46+
const backgroundImageUrl = `${baseUrl}/static/og-background.png`
47+
48+
const allText = `${title}${category}${description}docs.sim.ai`
49+
const fontData = await loadGoogleFont('Geist', '400;500;600', allText)
50+
51+
return new ImageResponse(
52+
<div
53+
style={{
54+
height: '100%',
55+
width: '100%',
56+
display: 'flex',
57+
flexDirection: 'column',
58+
background: 'linear-gradient(315deg, #1e1e3f 0%, #1a1a2e 40%, #0f0f0f 100%)',
59+
position: 'relative',
60+
fontFamily: 'Geist',
61+
}}
62+
>
63+
{/* Background texture */}
64+
<img
65+
src={backgroundImageUrl}
66+
alt=''
67+
style={{
68+
position: 'absolute',
69+
top: 0,
70+
left: 0,
71+
width: '100%',
72+
height: '100%',
73+
objectFit: 'cover',
74+
opacity: 0.04,
75+
}}
76+
/>
77+
78+
{/* Subtle purple glow from bottom right */}
79+
<div
80+
style={{
81+
position: 'absolute',
82+
bottom: 0,
83+
right: 0,
84+
width: '50%',
85+
height: '100%',
86+
background:
87+
'radial-gradient(ellipse at bottom right, rgba(112, 31, 252, 0.1) 0%, transparent 50%)',
88+
display: 'flex',
89+
}}
90+
/>
91+
92+
{/* Content */}
93+
<div
94+
style={{
95+
display: 'flex',
96+
flexDirection: 'column',
97+
padding: '56px 72px',
98+
height: '100%',
99+
justifyContent: 'space-between',
100+
}}
101+
>
102+
{/* Logo */}
103+
<img src={`${baseUrl}/static/logo.png`} alt='sim' height={32} />
104+
105+
{/* Category + Title + Description */}
106+
<div
107+
style={{
108+
display: 'flex',
109+
flexDirection: 'column',
110+
gap: 12,
111+
}}
112+
>
113+
<span
114+
style={{
115+
fontSize: 15,
116+
fontWeight: 600,
117+
color: '#802fff',
118+
letterSpacing: '0.02em',
119+
}}
120+
>
121+
{category}
122+
</span>
123+
<span
124+
style={{
125+
fontSize: getTitleFontSize(title),
126+
fontWeight: 600,
127+
color: '#ffffff',
128+
lineHeight: 1.1,
129+
letterSpacing: '-0.02em',
130+
}}
131+
>
132+
{title}
133+
</span>
134+
{description && (
135+
<span
136+
style={{
137+
fontSize: 18,
138+
fontWeight: 400,
139+
color: '#a1a1aa',
140+
lineHeight: 1.4,
141+
marginTop: 4,
142+
}}
143+
>
144+
{description.length > 100 ? `${description.slice(0, 100)}...` : description}
145+
</span>
146+
)}
147+
</div>
148+
149+
{/* Footer */}
150+
<span
151+
style={{
152+
fontSize: 15,
153+
fontWeight: 500,
154+
color: '#52525b',
155+
}}
156+
>
157+
docs.sim.ai
158+
</span>
159+
</div>
160+
</div>,
161+
{
162+
width: 1200,
163+
height: 630,
164+
fonts: [
165+
{
166+
name: 'Geist',
167+
data: fontData,
168+
style: 'normal',
169+
},
170+
],
171+
}
172+
)
173+
}

apps/docs/app/layout.tsx

Lines changed: 9 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -56,6 +56,14 @@ export const metadata = {
5656
title: 'Sim Documentation - Visual Workflow Builder for AI Applications',
5757
description:
5858
'Comprehensive documentation for Sim - the visual workflow builder for AI applications. Create powerful AI agents, automation workflows, and data processing pipelines.',
59+
images: [
60+
{
61+
url: 'https://docs.sim.ai/api/og?title=Sim%20Documentation&category=DOCUMENTATION',
62+
width: 1200,
63+
height: 630,
64+
alt: 'Sim Documentation',
65+
},
66+
],
5967
},
6068
twitter: {
6169
card: 'summary_large_image',
@@ -64,7 +72,7 @@ export const metadata = {
6472
'Comprehensive documentation for Sim - the visual workflow builder for AI applications.',
6573
creator: '@simdotai',
6674
site: '@simdotai',
67-
images: ['/og-image.png'],
75+
images: ['https://docs.sim.ai/api/og?title=Sim%20Documentation&category=DOCUMENTATION'],
6876
},
6977
robots: {
7078
index: true,

apps/docs/components/icons.tsx

Lines changed: 13 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -4206,12 +4206,20 @@ export function RssIcon(props: SVGProps<SVGSVGElement>) {
42064206

42074207
export function SpotifyIcon(props: SVGProps<SVGSVGElement>) {
42084208
return (
4209-
<svg {...props} viewBox='0 0 496 512' xmlns='http://www.w3.org/2000/svg'>
4210-
<path
4211-
fill='#1ed760'
4212-
d='M248 8C111.1 8 0 119.1 0 256s111.1 248 248 248 248-111.1 248-248S384.9 8 248 8Z'
4209+
<svg
4210+
{...props}
4211+
width='386'
4212+
height='386'
4213+
viewBox='100 100 186 186'
4214+
fill='none'
4215+
xmlns='http://www.w3.org/2000/svg'
4216+
xmlnsXlink='http://www.w3.org/1999/xlink'
4217+
>
4218+
<image
4219+
width='386'
4220+
height='386'
4221+
xlinkHref=''
42134222
/>
4214-
<path d='M406.6 231.1c-5.2 0-8.4-1.3-12.9-3.9-71.2-42.5-198.5-52.7-280.9-29.7-3.6 1-8.1 2.6-12.9 2.6-13.2 0-23.3-10.3-23.3-23.6 0-13.6 8.4-21.3 17.4-23.9 35.2-10.3 74.6-15.2 117.5-15.2 73 0 149.5 15.2 205.4 47.8 7.8 4.5 12.9 10.7 12.9 22.6 0 13.6-11 23.3-23.2 23.3zm-31 76.2c-5.2 0-8.7-2.3-12.3-4.2-62.5-37-155.7-51.9-238.6-29.4-4.8 1.3-7.4 2.6-11.9 2.6-10.7 0-19.4-8.7-19.4-19.4s5.2-17.8 15.5-20.7c27.8-7.8 56.2-13.6 97.8-13.6 64.9 0 127.6 16.1 177 45.5 8.1 4.8 11.3 11 11.3 19.7-.1 10.8-8.5 19.5-19.4 19.5zm-26.9 65.6c-4.2 0-6.8-1.3-10.7-3.6-62.4-37.6-135-39.2-206.7-24.5-3.9 1-9 2.6-11.9 2.6-9.7 0-15.8-7.7-15.8-15.8 0-10.3 6.1-15.2 13.6-16.8 81.9-18.1 165.6-16.5 237 26.2 6.1 3.9 9.7 7.4 9.7 16.5s-7.1 15.4-15.2 15.4z' />
42154223
</svg>
42164224
)
42174225
}

0 commit comments

Comments
 (0)