- Demo deployed at
/demos/declarative-json-render. - Railway backend healthy (
showcase-langgraph-python-production.up.railway.app). OPENAI_API_KEYandLANGGRAPH_DEPLOYMENT_URLconfigured on the Next.js app.@json-render/core+@json-render/reactpresent inpackage.json(pinned to0.18.0).byoc_json_rendergraph registered inlanggraph.json.
- Navigate to
/demos/declarative-json-render. - Chat composer is visible.
- Three suggestion pills appear with titles: "Sales dashboard", "Revenue by category", "Expense trend".
- No console errors.
- Click the "Sales dashboard" suggestion.
- Within 60 seconds, a
data-testid="json-render-root"wrapper appears in the assistant bubble. - A
data-testid="metric-card"renders inside the wrapper. - A chart (
data-testid="bar-chart"ordata-testid="pie-chart") renders inside the wrapper. - No raw JSON text is shown once rendering finishes — the streaming JSON is replaced by components.
- Click the "Revenue by category" suggestion.
- Within 60 seconds, a
data-testid="pie-chart"renders with multiple category slices + legend.
- Click the "Expense trend" suggestion.
- Within 60 seconds, a
data-testid="bar-chart"renders with month labels.
- Type "Show me a metric for quarterly revenue" and send.
- Verify at least one
metric-cardrenders; no console errors.
- After a previous render is visible, send a follow-up prompt ("Now break that down by region").
- A new assistant message appears with a new json-render rendering — prior renders stay in the transcript.
- If the agent ever replies with non-JSON text (force it by asking "tell me a joke"), the chat falls back to rendering that raw text via the default assistant bubble. No crash, no stuck spinner.
- Suggestion renders land within 60 seconds. Budget is slightly higher than the hashbrown demo because a JSON
{ root, elements }spec is more verbose than hashbrown's token stream. - No uncaught errors in the console.
- Streaming falls back to plain text until the JSON parses, then swaps to rendered components.