ai 6.0.31 → 6.0.33

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (252) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/index.js +12 -2
  3. package/dist/index.js.map +1 -1
  4. package/dist/index.mjs +12 -2
  5. package/dist/index.mjs.map +1 -1
  6. package/dist/internal/index.js +1 -1
  7. package/dist/internal/index.mjs +1 -1
  8. package/docs/00-introduction/index.mdx +76 -0
  9. package/docs/02-foundations/01-overview.mdx +43 -0
  10. package/docs/02-foundations/02-providers-and-models.mdx +163 -0
  11. package/docs/02-foundations/03-prompts.mdx +620 -0
  12. package/docs/02-foundations/04-tools.mdx +160 -0
  13. package/docs/02-foundations/05-streaming.mdx +62 -0
  14. package/docs/02-foundations/index.mdx +43 -0
  15. package/docs/02-getting-started/00-choosing-a-provider.mdx +110 -0
  16. package/docs/02-getting-started/01-navigating-the-library.mdx +85 -0
  17. package/docs/02-getting-started/02-nextjs-app-router.mdx +556 -0
  18. package/docs/02-getting-started/03-nextjs-pages-router.mdx +542 -0
  19. package/docs/02-getting-started/04-svelte.mdx +627 -0
  20. package/docs/02-getting-started/05-nuxt.mdx +566 -0
  21. package/docs/02-getting-started/06-nodejs.mdx +512 -0
  22. package/docs/02-getting-started/07-expo.mdx +766 -0
  23. package/docs/02-getting-started/08-tanstack-start.mdx +583 -0
  24. package/docs/02-getting-started/index.mdx +44 -0
  25. package/docs/03-agents/01-overview.mdx +96 -0
  26. package/docs/03-agents/02-building-agents.mdx +367 -0
  27. package/docs/03-agents/03-workflows.mdx +370 -0
  28. package/docs/03-agents/04-loop-control.mdx +350 -0
  29. package/docs/03-agents/05-configuring-call-options.mdx +286 -0
  30. package/docs/03-agents/index.mdx +40 -0
  31. package/docs/03-ai-sdk-core/01-overview.mdx +33 -0
  32. package/docs/03-ai-sdk-core/05-generating-text.mdx +600 -0
  33. package/docs/03-ai-sdk-core/10-generating-structured-data.mdx +662 -0
  34. package/docs/03-ai-sdk-core/15-tools-and-tool-calling.mdx +1102 -0
  35. package/docs/03-ai-sdk-core/16-mcp-tools.mdx +375 -0
  36. package/docs/03-ai-sdk-core/20-prompt-engineering.mdx +144 -0
  37. package/docs/03-ai-sdk-core/25-settings.mdx +198 -0
  38. package/docs/03-ai-sdk-core/30-embeddings.mdx +247 -0
  39. package/docs/03-ai-sdk-core/31-reranking.mdx +218 -0
  40. package/docs/03-ai-sdk-core/35-image-generation.mdx +341 -0
  41. package/docs/03-ai-sdk-core/36-transcription.mdx +173 -0
  42. package/docs/03-ai-sdk-core/37-speech.mdx +167 -0
  43. package/docs/03-ai-sdk-core/40-middleware.mdx +480 -0
  44. package/docs/03-ai-sdk-core/45-provider-management.mdx +349 -0
  45. package/docs/03-ai-sdk-core/50-error-handling.mdx +149 -0
  46. package/docs/03-ai-sdk-core/55-testing.mdx +218 -0
  47. package/docs/03-ai-sdk-core/60-telemetry.mdx +313 -0
  48. package/docs/03-ai-sdk-core/65-devtools.mdx +107 -0
  49. package/docs/03-ai-sdk-core/index.mdx +88 -0
  50. package/docs/04-ai-sdk-ui/01-overview.mdx +44 -0
  51. package/docs/04-ai-sdk-ui/02-chatbot.mdx +1313 -0
  52. package/docs/04-ai-sdk-ui/03-chatbot-message-persistence.mdx +535 -0
  53. package/docs/04-ai-sdk-ui/03-chatbot-resume-streams.mdx +263 -0
  54. package/docs/04-ai-sdk-ui/03-chatbot-tool-usage.mdx +682 -0
  55. package/docs/04-ai-sdk-ui/04-generative-user-interfaces.mdx +389 -0
  56. package/docs/04-ai-sdk-ui/05-completion.mdx +186 -0
  57. package/docs/04-ai-sdk-ui/08-object-generation.mdx +344 -0
  58. package/docs/04-ai-sdk-ui/20-streaming-data.mdx +397 -0
  59. package/docs/04-ai-sdk-ui/21-error-handling.mdx +190 -0
  60. package/docs/04-ai-sdk-ui/21-transport.mdx +174 -0
  61. package/docs/04-ai-sdk-ui/24-reading-ui-message-streams.mdx +104 -0
  62. package/docs/04-ai-sdk-ui/25-message-metadata.mdx +152 -0
  63. package/docs/04-ai-sdk-ui/50-stream-protocol.mdx +477 -0
  64. package/docs/04-ai-sdk-ui/index.mdx +64 -0
  65. package/docs/05-ai-sdk-rsc/01-overview.mdx +45 -0
  66. package/docs/05-ai-sdk-rsc/02-streaming-react-components.mdx +209 -0
  67. package/docs/05-ai-sdk-rsc/03-generative-ui-state.mdx +279 -0
  68. package/docs/05-ai-sdk-rsc/03-saving-and-restoring-states.mdx +105 -0
  69. package/docs/05-ai-sdk-rsc/04-multistep-interfaces.mdx +282 -0
  70. package/docs/05-ai-sdk-rsc/05-streaming-values.mdx +158 -0
  71. package/docs/05-ai-sdk-rsc/06-loading-state.mdx +273 -0
  72. package/docs/05-ai-sdk-rsc/08-error-handling.mdx +96 -0
  73. package/docs/05-ai-sdk-rsc/09-authentication.mdx +42 -0
  74. package/docs/05-ai-sdk-rsc/10-migrating-to-ui.mdx +722 -0
  75. package/docs/05-ai-sdk-rsc/index.mdx +58 -0
  76. package/docs/06-advanced/01-prompt-engineering.mdx +96 -0
  77. package/docs/06-advanced/02-stopping-streams.mdx +184 -0
  78. package/docs/06-advanced/03-backpressure.mdx +173 -0
  79. package/docs/06-advanced/04-caching.mdx +169 -0
  80. package/docs/06-advanced/05-multiple-streamables.mdx +68 -0
  81. package/docs/06-advanced/06-rate-limiting.mdx +60 -0
  82. package/docs/06-advanced/07-rendering-ui-with-language-models.mdx +213 -0
  83. package/docs/06-advanced/08-model-as-router.mdx +120 -0
  84. package/docs/06-advanced/09-multistep-interfaces.mdx +115 -0
  85. package/docs/06-advanced/09-sequential-generations.mdx +55 -0
  86. package/docs/06-advanced/10-vercel-deployment-guide.mdx +117 -0
  87. package/docs/06-advanced/index.mdx +11 -0
  88. package/docs/07-reference/01-ai-sdk-core/01-generate-text.mdx +2142 -0
  89. package/docs/07-reference/01-ai-sdk-core/02-stream-text.mdx +3215 -0
  90. package/docs/07-reference/01-ai-sdk-core/03-generate-object.mdx +780 -0
  91. package/docs/07-reference/01-ai-sdk-core/04-stream-object.mdx +1140 -0
  92. package/docs/07-reference/01-ai-sdk-core/05-embed.mdx +190 -0
  93. package/docs/07-reference/01-ai-sdk-core/06-embed-many.mdx +171 -0
  94. package/docs/07-reference/01-ai-sdk-core/06-rerank.mdx +309 -0
  95. package/docs/07-reference/01-ai-sdk-core/10-generate-image.mdx +227 -0
  96. package/docs/07-reference/01-ai-sdk-core/11-transcribe.mdx +138 -0
  97. package/docs/07-reference/01-ai-sdk-core/12-generate-speech.mdx +214 -0
  98. package/docs/07-reference/01-ai-sdk-core/15-agent.mdx +203 -0
  99. package/docs/07-reference/01-ai-sdk-core/16-tool-loop-agent.mdx +449 -0
  100. package/docs/07-reference/01-ai-sdk-core/17-create-agent-ui-stream.mdx +148 -0
  101. package/docs/07-reference/01-ai-sdk-core/18-create-agent-ui-stream-response.mdx +168 -0
  102. package/docs/07-reference/01-ai-sdk-core/18-pipe-agent-ui-stream-to-response.mdx +144 -0
  103. package/docs/07-reference/01-ai-sdk-core/20-tool.mdx +196 -0
  104. package/docs/07-reference/01-ai-sdk-core/22-dynamic-tool.mdx +175 -0
  105. package/docs/07-reference/01-ai-sdk-core/23-create-mcp-client.mdx +410 -0
  106. package/docs/07-reference/01-ai-sdk-core/24-mcp-stdio-transport.mdx +68 -0
  107. package/docs/07-reference/01-ai-sdk-core/25-json-schema.mdx +94 -0
  108. package/docs/07-reference/01-ai-sdk-core/26-zod-schema.mdx +109 -0
  109. package/docs/07-reference/01-ai-sdk-core/27-valibot-schema.mdx +55 -0
  110. package/docs/07-reference/01-ai-sdk-core/28-output.mdx +342 -0
  111. package/docs/07-reference/01-ai-sdk-core/30-model-message.mdx +415 -0
  112. package/docs/07-reference/01-ai-sdk-core/31-ui-message.mdx +246 -0
  113. package/docs/07-reference/01-ai-sdk-core/32-validate-ui-messages.mdx +101 -0
  114. package/docs/07-reference/01-ai-sdk-core/33-safe-validate-ui-messages.mdx +113 -0
  115. package/docs/07-reference/01-ai-sdk-core/40-provider-registry.mdx +182 -0
  116. package/docs/07-reference/01-ai-sdk-core/42-custom-provider.mdx +121 -0
  117. package/docs/07-reference/01-ai-sdk-core/50-cosine-similarity.mdx +52 -0
  118. package/docs/07-reference/01-ai-sdk-core/60-wrap-language-model.mdx +59 -0
  119. package/docs/07-reference/01-ai-sdk-core/61-wrap-image-model.mdx +64 -0
  120. package/docs/07-reference/01-ai-sdk-core/65-language-model-v2-middleware.mdx +46 -0
  121. package/docs/07-reference/01-ai-sdk-core/66-extract-reasoning-middleware.mdx +68 -0
  122. package/docs/07-reference/01-ai-sdk-core/67-simulate-streaming-middleware.mdx +71 -0
  123. package/docs/07-reference/01-ai-sdk-core/68-default-settings-middleware.mdx +80 -0
  124. package/docs/07-reference/01-ai-sdk-core/69-add-tool-input-examples-middleware.mdx +155 -0
  125. package/docs/07-reference/01-ai-sdk-core/70-extract-json-middleware.mdx +147 -0
  126. package/docs/07-reference/01-ai-sdk-core/70-step-count-is.mdx +84 -0
  127. package/docs/07-reference/01-ai-sdk-core/71-has-tool-call.mdx +120 -0
  128. package/docs/07-reference/01-ai-sdk-core/75-simulate-readable-stream.mdx +94 -0
  129. package/docs/07-reference/01-ai-sdk-core/80-smooth-stream.mdx +145 -0
  130. package/docs/07-reference/01-ai-sdk-core/90-generate-id.mdx +43 -0
  131. package/docs/07-reference/01-ai-sdk-core/91-create-id-generator.mdx +89 -0
  132. package/docs/07-reference/01-ai-sdk-core/index.mdx +159 -0
  133. package/docs/07-reference/02-ai-sdk-ui/01-use-chat.mdx +446 -0
  134. package/docs/07-reference/02-ai-sdk-ui/02-use-completion.mdx +179 -0
  135. package/docs/07-reference/02-ai-sdk-ui/03-use-object.mdx +178 -0
  136. package/docs/07-reference/02-ai-sdk-ui/31-convert-to-model-messages.mdx +230 -0
  137. package/docs/07-reference/02-ai-sdk-ui/32-prune-messages.mdx +108 -0
  138. package/docs/07-reference/02-ai-sdk-ui/40-create-ui-message-stream.mdx +151 -0
  139. package/docs/07-reference/02-ai-sdk-ui/41-create-ui-message-stream-response.mdx +113 -0
  140. package/docs/07-reference/02-ai-sdk-ui/42-pipe-ui-message-stream-to-response.mdx +73 -0
  141. package/docs/07-reference/02-ai-sdk-ui/43-read-ui-message-stream.mdx +57 -0
  142. package/docs/07-reference/02-ai-sdk-ui/46-infer-ui-tools.mdx +99 -0
  143. package/docs/07-reference/02-ai-sdk-ui/47-infer-ui-tool.mdx +75 -0
  144. package/docs/07-reference/02-ai-sdk-ui/50-direct-chat-transport.mdx +333 -0
  145. package/docs/07-reference/02-ai-sdk-ui/index.mdx +89 -0
  146. package/docs/07-reference/03-ai-sdk-rsc/01-stream-ui.mdx +767 -0
  147. package/docs/07-reference/03-ai-sdk-rsc/02-create-ai.mdx +90 -0
  148. package/docs/07-reference/03-ai-sdk-rsc/03-create-streamable-ui.mdx +91 -0
  149. package/docs/07-reference/03-ai-sdk-rsc/04-create-streamable-value.mdx +48 -0
  150. package/docs/07-reference/03-ai-sdk-rsc/05-read-streamable-value.mdx +78 -0
  151. package/docs/07-reference/03-ai-sdk-rsc/06-get-ai-state.mdx +50 -0
  152. package/docs/07-reference/03-ai-sdk-rsc/07-get-mutable-ai-state.mdx +70 -0
  153. package/docs/07-reference/03-ai-sdk-rsc/08-use-ai-state.mdx +26 -0
  154. package/docs/07-reference/03-ai-sdk-rsc/09-use-actions.mdx +42 -0
  155. package/docs/07-reference/03-ai-sdk-rsc/10-use-ui-state.mdx +35 -0
  156. package/docs/07-reference/03-ai-sdk-rsc/11-use-streamable-value.mdx +46 -0
  157. package/docs/07-reference/03-ai-sdk-rsc/20-render.mdx +262 -0
  158. package/docs/07-reference/03-ai-sdk-rsc/index.mdx +67 -0
  159. package/docs/07-reference/04-stream-helpers/01-ai-stream.mdx +89 -0
  160. package/docs/07-reference/04-stream-helpers/02-streaming-text-response.mdx +79 -0
  161. package/docs/07-reference/04-stream-helpers/05-stream-to-response.mdx +108 -0
  162. package/docs/07-reference/04-stream-helpers/07-openai-stream.mdx +77 -0
  163. package/docs/07-reference/04-stream-helpers/08-anthropic-stream.mdx +79 -0
  164. package/docs/07-reference/04-stream-helpers/09-aws-bedrock-stream.mdx +91 -0
  165. package/docs/07-reference/04-stream-helpers/10-aws-bedrock-anthropic-stream.mdx +96 -0
  166. package/docs/07-reference/04-stream-helpers/10-aws-bedrock-messages-stream.mdx +96 -0
  167. package/docs/07-reference/04-stream-helpers/11-aws-bedrock-cohere-stream.mdx +93 -0
  168. package/docs/07-reference/04-stream-helpers/12-aws-bedrock-llama-2-stream.mdx +93 -0
  169. package/docs/07-reference/04-stream-helpers/13-cohere-stream.mdx +78 -0
  170. package/docs/07-reference/04-stream-helpers/14-google-generative-ai-stream.mdx +85 -0
  171. package/docs/07-reference/04-stream-helpers/15-hugging-face-stream.mdx +84 -0
  172. package/docs/07-reference/04-stream-helpers/16-langchain-adapter.mdx +98 -0
  173. package/docs/07-reference/04-stream-helpers/16-llamaindex-adapter.mdx +70 -0
  174. package/docs/07-reference/04-stream-helpers/17-mistral-stream.mdx +81 -0
  175. package/docs/07-reference/04-stream-helpers/18-replicate-stream.mdx +83 -0
  176. package/docs/07-reference/04-stream-helpers/19-inkeep-stream.mdx +80 -0
  177. package/docs/07-reference/04-stream-helpers/index.mdx +103 -0
  178. package/docs/07-reference/05-ai-sdk-errors/ai-api-call-error.mdx +30 -0
  179. package/docs/07-reference/05-ai-sdk-errors/ai-download-error.mdx +27 -0
  180. package/docs/07-reference/05-ai-sdk-errors/ai-empty-response-body-error.mdx +24 -0
  181. package/docs/07-reference/05-ai-sdk-errors/ai-invalid-argument-error.mdx +26 -0
  182. package/docs/07-reference/05-ai-sdk-errors/ai-invalid-data-content-error.mdx +25 -0
  183. package/docs/07-reference/05-ai-sdk-errors/ai-invalid-data-content.mdx +26 -0
  184. package/docs/07-reference/05-ai-sdk-errors/ai-invalid-message-role-error.mdx +25 -0
  185. package/docs/07-reference/05-ai-sdk-errors/ai-invalid-prompt-error.mdx +47 -0
  186. package/docs/07-reference/05-ai-sdk-errors/ai-invalid-response-data-error.mdx +25 -0
  187. package/docs/07-reference/05-ai-sdk-errors/ai-invalid-tool-approval-error.mdx +25 -0
  188. package/docs/07-reference/05-ai-sdk-errors/ai-invalid-tool-input-error.mdx +27 -0
  189. package/docs/07-reference/05-ai-sdk-errors/ai-json-parse-error.mdx +25 -0
  190. package/docs/07-reference/05-ai-sdk-errors/ai-load-api-key-error.mdx +24 -0
  191. package/docs/07-reference/05-ai-sdk-errors/ai-load-setting-error.mdx +24 -0
  192. package/docs/07-reference/05-ai-sdk-errors/ai-message-conversion-error.mdx +25 -0
  193. package/docs/07-reference/05-ai-sdk-errors/ai-no-content-generated-error.mdx +24 -0
  194. package/docs/07-reference/05-ai-sdk-errors/ai-no-image-generated-error.mdx +36 -0
  195. package/docs/07-reference/05-ai-sdk-errors/ai-no-object-generated-error.mdx +43 -0
  196. package/docs/07-reference/05-ai-sdk-errors/ai-no-speech-generated-error.mdx +25 -0
  197. package/docs/07-reference/05-ai-sdk-errors/ai-no-such-model-error.mdx +26 -0
  198. package/docs/07-reference/05-ai-sdk-errors/ai-no-such-provider-error.mdx +28 -0
  199. package/docs/07-reference/05-ai-sdk-errors/ai-no-such-tool-error.mdx +26 -0
  200. package/docs/07-reference/05-ai-sdk-errors/ai-no-transcript-generated-error.mdx +25 -0
  201. package/docs/07-reference/05-ai-sdk-errors/ai-retry-error.mdx +27 -0
  202. package/docs/07-reference/05-ai-sdk-errors/ai-too-many-embedding-values-for-call-error.mdx +27 -0
  203. package/docs/07-reference/05-ai-sdk-errors/ai-tool-call-not-found-for-approval-error.mdx +26 -0
  204. package/docs/07-reference/05-ai-sdk-errors/ai-tool-call-repair-error.mdx +28 -0
  205. package/docs/07-reference/05-ai-sdk-errors/ai-type-validation-error.mdx +25 -0
  206. package/docs/07-reference/05-ai-sdk-errors/ai-unsupported-functionality-error.mdx +25 -0
  207. package/docs/07-reference/05-ai-sdk-errors/index.mdx +38 -0
  208. package/docs/07-reference/index.mdx +34 -0
  209. package/docs/08-migration-guides/00-versioning.mdx +46 -0
  210. package/docs/08-migration-guides/24-migration-guide-6-0.mdx +823 -0
  211. package/docs/08-migration-guides/25-migration-guide-5-0-data.mdx +882 -0
  212. package/docs/08-migration-guides/26-migration-guide-5-0.mdx +3427 -0
  213. package/docs/08-migration-guides/27-migration-guide-4-2.mdx +99 -0
  214. package/docs/08-migration-guides/28-migration-guide-4-1.mdx +14 -0
  215. package/docs/08-migration-guides/29-migration-guide-4-0.mdx +1157 -0
  216. package/docs/08-migration-guides/36-migration-guide-3-4.mdx +14 -0
  217. package/docs/08-migration-guides/37-migration-guide-3-3.mdx +64 -0
  218. package/docs/08-migration-guides/38-migration-guide-3-2.mdx +46 -0
  219. package/docs/08-migration-guides/39-migration-guide-3-1.mdx +168 -0
  220. package/docs/08-migration-guides/index.mdx +22 -0
  221. package/docs/09-troubleshooting/01-azure-stream-slow.mdx +33 -0
  222. package/docs/09-troubleshooting/02-client-side-function-calls-not-invoked.mdx +22 -0
  223. package/docs/09-troubleshooting/03-server-actions-in-client-components.mdx +40 -0
  224. package/docs/09-troubleshooting/04-strange-stream-output.mdx +36 -0
  225. package/docs/09-troubleshooting/05-streamable-ui-errors.mdx +16 -0
  226. package/docs/09-troubleshooting/05-tool-invocation-missing-result.mdx +106 -0
  227. package/docs/09-troubleshooting/06-streaming-not-working-when-deployed.mdx +31 -0
  228. package/docs/09-troubleshooting/06-streaming-not-working-when-proxied.mdx +31 -0
  229. package/docs/09-troubleshooting/06-timeout-on-vercel.mdx +60 -0
  230. package/docs/09-troubleshooting/07-unclosed-streams.mdx +34 -0
  231. package/docs/09-troubleshooting/08-use-chat-failed-to-parse-stream.mdx +26 -0
  232. package/docs/09-troubleshooting/09-client-stream-error.mdx +25 -0
  233. package/docs/09-troubleshooting/10-use-chat-tools-no-response.mdx +32 -0
  234. package/docs/09-troubleshooting/11-use-chat-custom-request-options.mdx +149 -0
  235. package/docs/09-troubleshooting/12-typescript-performance-zod.mdx +46 -0
  236. package/docs/09-troubleshooting/12-use-chat-an-error-occurred.mdx +59 -0
  237. package/docs/09-troubleshooting/13-repeated-assistant-messages.mdx +73 -0
  238. package/docs/09-troubleshooting/14-stream-abort-handling.mdx +73 -0
  239. package/docs/09-troubleshooting/14-tool-calling-with-structured-outputs.mdx +48 -0
  240. package/docs/09-troubleshooting/15-abort-breaks-resumable-streams.mdx +55 -0
  241. package/docs/09-troubleshooting/15-stream-text-not-working.mdx +33 -0
  242. package/docs/09-troubleshooting/16-streaming-status-delay.mdx +63 -0
  243. package/docs/09-troubleshooting/17-use-chat-stale-body-data.mdx +141 -0
  244. package/docs/09-troubleshooting/18-ontoolcall-type-narrowing.mdx +66 -0
  245. package/docs/09-troubleshooting/19-unsupported-model-version.mdx +50 -0
  246. package/docs/09-troubleshooting/20-no-object-generated-content-filter.mdx +72 -0
  247. package/docs/09-troubleshooting/30-model-is-not-assignable-to-type.mdx +21 -0
  248. package/docs/09-troubleshooting/40-typescript-cannot-find-namespace-jsx.mdx +24 -0
  249. package/docs/09-troubleshooting/50-react-maximum-update-depth-exceeded.mdx +39 -0
  250. package/docs/09-troubleshooting/60-jest-cannot-find-module-ai-rsc.mdx +22 -0
  251. package/docs/09-troubleshooting/index.mdx +11 -0
  252. package/package.json +8 -4
@@ -0,0 +1,627 @@
1
+ ---
2
+ title: Svelte
3
+ description: Learn how to build your first agent with the AI SDK and Svelte.
4
+ ---
5
+
6
+ # Svelte Quickstart
7
+
8
+ The AI SDK is a powerful Typescript library designed to help developers build AI-powered applications.
9
+
10
+ In this quickstart tutorial, you'll build a simple agent with a streaming chat user interface. Along the way, you'll learn key concepts and techniques that are fundamental to using the SDK in your own projects.
11
+
12
+ If you are unfamiliar with the concepts of [Prompt Engineering](/docs/advanced/prompt-engineering) and [HTTP Streaming](/docs/advanced/why-streaming), you can optionally read these documents first.
13
+
14
+ ## Prerequisites
15
+
16
+ To follow this quickstart, you'll need:
17
+
18
+ - Node.js 18+ and pnpm installed on your local development machine.
19
+ - A [ Vercel AI Gateway ](https://vercel.com/ai-gateway) API key.
20
+
21
+ If you haven't obtained your Vercel AI Gateway API key, you can do so by [signing up](https://vercel.com/d?to=%2F%5Bteam%5D%2F%7E%2Fai&title=Go+to+AI+Gateway) on the Vercel website.
22
+
23
+ ## Set Up Your Application
24
+
25
+ Start by creating a new SvelteKit application. This command will create a new directory named `my-ai-app` and set up a basic SvelteKit application inside it.
26
+
27
+ <Snippet text="npx sv create my-ai-app" />
28
+
29
+ Navigate to the newly created directory:
30
+
31
+ <Snippet text="cd my-ai-app" />
32
+
33
+ ### Install Dependencies
34
+
35
+ Install `ai` and `@ai-sdk/svelte`, the AI package and AI SDK's Svelte bindings. The AI SDK's [ Vercel AI Gateway provider ](/providers/ai-sdk-providers/ai-gateway) ships with the `ai` package. You'll also install `zod`, a schema validation library used for defining tool inputs.
36
+
37
+ <Note>
38
+ This guide uses the Vercel AI Gateway provider so you can access hundreds of
39
+ models from different providers with one API key, but you can switch to any
40
+ provider or model by installing its package. Check out available [AI SDK
41
+ providers](/providers/ai-sdk-providers) for more information.
42
+ </Note>
43
+ <div className="my-4">
44
+ <Tabs items={['pnpm', 'npm', 'yarn', 'bun']}>
45
+ <Tab>
46
+ <Snippet text="pnpm add -D ai @ai-sdk/svelte zod" dark />
47
+ </Tab>
48
+ <Tab>
49
+ <Snippet text="npm install -D ai @ai-sdk/svelte zod" dark />
50
+ </Tab>
51
+ <Tab>
52
+ <Snippet text="yarn add -D ai @ai-sdk/svelte zod" dark />
53
+ </Tab>
54
+ <Tab>
55
+ <Snippet text="bun add -d ai @ai-sdk/svelte zod" dark />
56
+ </Tab>
57
+ </Tabs>
58
+ </div>
59
+
60
+ ### Configure your AI Gateway API key
61
+
62
+ Create a `.env.local` file in your project root and add your AI Gateway API key. This key authenticates your application with the Vercel AI Gateway.
63
+
64
+ <Snippet text="touch .env.local" />
65
+
66
+ Edit the `.env.local` file:
67
+
68
+ ```env filename=".env.local"
69
+ AI_GATEWAY_API_KEY=xxxxxxxxx
70
+ ```
71
+
72
+ Replace `xxxxxxxxx` with your actual Vercel AI Gateway API key.
73
+
74
+ <Note className="mb-4">
75
+ The AI SDK's Vercel AI Gateway Provider will default to using the
76
+ `AI_GATEWAY_API_KEY` environment variable. Vite does not automatically load
77
+ environment variables onto `process.env`, so you'll need to import
78
+ `AI_GATEWAY_API_KEY` from `$env/static/private` in your code (see below).
79
+ </Note>
80
+
81
+ ## Create an API route
82
+
83
+ Create a SvelteKit Endpoint, `src/routes/api/chat/+server.ts` and add the following code:
84
+
85
+ ```tsx filename="src/routes/api/chat/+server.ts"
86
+ import {
87
+ streamText,
88
+ type UIMessage,
89
+ convertToModelMessages,
90
+ createGateway,
91
+ } from 'ai';
92
+
93
+ import { AI_GATEWAY_API_KEY } from '$env/static/private';
94
+
95
+ const gateway = createGateway({
96
+ apiKey: AI_GATEWAY_API_KEY,
97
+ });
98
+
99
+ export async function POST({ request }) {
100
+ const { messages }: { messages: UIMessage[] } = await request.json();
101
+
102
+ const result = streamText({
103
+ model: gateway('anthropic/claude-sonnet-4.5'),
104
+ messages: await convertToModelMessages(messages),
105
+ });
106
+
107
+ return result.toUIMessageStreamResponse();
108
+ }
109
+ ```
110
+
111
+ <Note>
112
+ If you see type errors with `AI_GATEWAY_API_KEY` or your `POST` function, run
113
+ the dev server.
114
+ </Note>
115
+
116
+ Let's take a look at what is happening in this code:
117
+
118
+ 1. Create a gateway provider instance with the `createGateway` function from the `ai` package.
119
+ 2. Define a `POST` request handler and extract `messages` from the body of the request. The `messages` variable contains a history of the conversation between you and the chatbot and provides the chatbot with the necessary context to make the next generation. The `messages` are of UIMessage type, which are designed for use in application UI - they contain the entire message history and associated metadata like timestamps.
120
+ 3. Call [`streamText`](/docs/reference/ai-sdk-core/stream-text), which is imported from the `ai` package. This function accepts a configuration object that contains a `model` provider (defined in step 1) and `messages` (defined in step 2). You can pass additional [settings](/docs/ai-sdk-core/settings) to further customise the model's behaviour. The `messages` key expects a `ModelMessage[]` array. This type is different from `UIMessage` in that it does not include metadata, such as timestamps or sender information. To convert between these types, we use the `convertToModelMessages` function, which strips the UI-specific metadata and transforms the `UIMessage[]` array into the `ModelMessage[]` format that the model expects.
121
+ 4. The `streamText` function returns a [`StreamTextResult`](/docs/reference/ai-sdk-core/stream-text#result-object). This result object contains the [ `toUIMessageStreamResponse` ](/docs/reference/ai-sdk-core/stream-text#to-ui-message-stream-response) function which converts the result to a streamed response object.
122
+ 5. Return the result to the client to stream the response.
123
+
124
+ ## Choosing a Provider
125
+
126
+ The AI SDK supports dozens of model providers through [first-party](/providers/ai-sdk-providers), [OpenAI-compatible](/providers/openai-compatible-providers), and [ community ](/providers/community-providers) packages.
127
+
128
+ This quickstart uses the [Vercel AI Gateway](https://vercel.com/ai-gateway) provider, which is the default [global provider](/docs/ai-sdk-core/provider-management#global-provider-configuration). This means you can access models using a simple string in the model configuration:
129
+
130
+ ```ts
131
+ model: __MODEL__;
132
+ ```
133
+
134
+ You can also explicitly import and use the gateway provider in two other equivalent ways:
135
+
136
+ ```ts
137
+ // Option 1: Import from 'ai' package (included by default)
138
+ import { gateway } from 'ai';
139
+ model: gateway('anthropic/claude-sonnet-4.5');
140
+
141
+ // Option 2: Install and import from '@ai-sdk/gateway' package
142
+ import { gateway } from '@ai-sdk/gateway';
143
+ model: gateway('anthropic/claude-sonnet-4.5');
144
+ ```
145
+
146
+ ### Using other providers
147
+
148
+ To use a different provider, install its package and create a provider instance. For example, to use OpenAI directly:
149
+
150
+ <div className="my-4">
151
+ <Tabs items={['pnpm', 'npm', 'yarn', 'bun']}>
152
+ <Tab>
153
+ <Snippet text="pnpm add @ai-sdk/openai" dark />
154
+ </Tab>
155
+ <Tab>
156
+ <Snippet text="npm install @ai-sdk/openai" dark />
157
+ </Tab>
158
+ <Tab>
159
+ <Snippet text="yarn add @ai-sdk/openai" dark />
160
+ </Tab>
161
+
162
+ <Tab>
163
+ <Snippet text="bun add @ai-sdk/openai" dark />
164
+ </Tab>
165
+
166
+ </Tabs>
167
+ </div>
168
+
169
+ ```ts
170
+ import { openai } from '@ai-sdk/openai';
171
+
172
+ model: openai('gpt-5.1');
173
+ ```
174
+
175
+ #### Updating the global provider
176
+
177
+ You can change the default global provider so string model references use your preferred provider everywhere in your application. Learn more about [provider management](/docs/ai-sdk-core/provider-management#global-provider-configuration).
178
+
179
+ Pick the approach that best matches how you want to manage providers across your application.
180
+
181
+ ## Wire up the UI
182
+
183
+ Now that you have an API route that can query an LLM, it's time to set up your frontend. The AI SDK's [UI](/docs/ai-sdk-ui) package abstracts the complexity of a chat interface into one class, `Chat`.
184
+ Its properties and API are largely the same as React's [`useChat`](/docs/reference/ai-sdk-ui/use-chat).
185
+
186
+ Update your root page (`src/routes/+page.svelte`) with the following code to show a list of chat messages and provide a user message input:
187
+
188
+ ```svelte filename="src/routes/+page.svelte"
189
+ <script lang="ts">
190
+ import { Chat } from '@ai-sdk/svelte';
191
+
192
+ let input = '';
193
+ const chat = new Chat({});
194
+
195
+ function handleSubmit(event: SubmitEvent) {
196
+ event.preventDefault();
197
+ chat.sendMessage({ text: input });
198
+ input = '';
199
+ }
200
+ </script>
201
+
202
+ <main>
203
+ <ul>
204
+ {#each chat.messages as message, messageIndex (messageIndex)}
205
+ <li>
206
+ <div>{message.role}</div>
207
+ <div>
208
+ {#each message.parts as part, partIndex (partIndex)}
209
+ {#if part.type === 'text'}
210
+ <div>{part.text}</div>
211
+ {/if}
212
+ {/each}
213
+ </div>
214
+ </li>
215
+ {/each}
216
+ </ul>
217
+ <form onsubmit={handleSubmit}>
218
+ <input bind:value={input} />
219
+ <button type="submit">Send</button>
220
+ </form>
221
+ </main>
222
+ ```
223
+
224
+ This page utilizes the `Chat` class, which will, by default, use the `POST` route handler you created earlier. The class provides functions and state for handling user input and form submission. The `Chat` class provides multiple utility functions and state variables:
225
+
226
+ - `messages` - the current chat messages (an array of objects with `id`, `role`, and `parts` properties).
227
+ - `sendMessage` - a function to send a message to the chat API.
228
+
229
+ The component uses local state to manage the input field value, and handles form submission by calling `sendMessage` with the input text and then clearing the input field.
230
+
231
+ The LLM's response is accessed through the message `parts` array. Each message contains an ordered array of `parts` that represents everything the model generated in its response. These parts can include plain text, reasoning tokens, and more that you will see later. The `parts` array preserves the sequence of the model's outputs, allowing you to display or process each component in the order it was generated.
232
+
233
+ ## Running Your Application
234
+
235
+ With that, you have built everything you need for your chatbot! To start your application, use the command:
236
+
237
+ <Snippet text="pnpm run dev" />
238
+
239
+ Head to your browser and open http://localhost:5173. You should see an input field. Test it out by entering a message and see the AI chatbot respond in real-time! The AI SDK makes it fast and easy to build AI chat interfaces with Svelte.
240
+
241
+ ## Enhance Your Chatbot with Tools
242
+
243
+ While large language models (LLMs) have incredible generation capabilities, they struggle with discrete tasks (e.g. mathematics) and interacting with the outside world (e.g. getting the weather). This is where [tools](/docs/ai-sdk-core/tools-and-tool-calling) come in.
244
+
245
+ Tools are actions that an LLM can invoke. The results of these actions can be reported back to the LLM to be considered in the next response.
246
+
247
+ For example, if a user asks about the current weather, without tools, the model would only be able to provide general information based on its training data. But with a weather tool, it can fetch and provide up-to-date, location-specific weather information.
248
+
249
+ Let's enhance your chatbot by adding a simple weather tool.
250
+
251
+ ### Update Your API Route
252
+
253
+ Modify your `src/routes/api/chat/+server.ts` file to include the new weather tool:
254
+
255
+ ```tsx filename="src/routes/api/chat/+server.ts" highlight="2,3,17-31"
256
+ import {
257
+ createGateway,
258
+ streamText,
259
+ type UIMessage,
260
+ convertToModelMessages,
261
+ tool,
262
+ stepCountIs,
263
+ } from 'ai';
264
+ import { z } from 'zod';
265
+
266
+ import { AI_GATEWAY_API_KEY } from '$env/static/private';
267
+
268
+ const gateway = createGateway({
269
+ apiKey: AI_GATEWAY_API_KEY,
270
+ });
271
+
272
+ export async function POST({ request }) {
273
+ const { messages }: { messages: UIMessage[] } = await request.json();
274
+
275
+ const result = streamText({
276
+ model: gateway('anthropic/claude-sonnet-4.5'),
277
+ messages: await convertToModelMessages(messages),
278
+ tools: {
279
+ weather: tool({
280
+ description: 'Get the weather in a location (fahrenheit)',
281
+ inputSchema: z.object({
282
+ location: z.string().describe('The location to get the weather for'),
283
+ }),
284
+ execute: async ({ location }) => {
285
+ const temperature = Math.round(Math.random() * (90 - 32) + 32);
286
+ return {
287
+ location,
288
+ temperature,
289
+ };
290
+ },
291
+ }),
292
+ },
293
+ });
294
+
295
+ return result.toUIMessageStreamResponse();
296
+ }
297
+ ```
298
+
299
+ In this updated code:
300
+
301
+ 1. You import the `tool` function from the `ai` package and `z` from `zod` for schema validation.
302
+ 2. You define a `tools` object with a `weather` tool. This tool:
303
+
304
+ - Has a description that helps the model understand when to use it.
305
+ - Defines `inputSchema` using a Zod schema, specifying that it requires a `location` string to execute this tool. The model will attempt to extract this input from the context of the conversation. If it can't, it will ask the user for the missing information.
306
+ - Defines an `execute` function that simulates getting weather data (in this case, it returns a random temperature). This is an asynchronous function running on the server so you can fetch real data from an external API.
307
+
308
+ Now your chatbot can "fetch" weather information for any location the user asks about. When the model determines it needs to use the weather tool, it will generate a tool call with the necessary input. The `execute` function will then be automatically run, and the tool output will be added to the `messages` as a `tool` message.
309
+
310
+ Try asking something like "What's the weather in New York?" and see how the model uses the new tool.
311
+
312
+ Notice the blank response in the UI? This is because instead of generating a text response, the model generated a tool call. You can access the tool call and subsequent tool result on the client via the `tool-weather` part of the `message.parts` array.
313
+
314
+ <Note>
315
+ Tool parts are always named `tool-{toolName}`, where `{toolName}` is the key
316
+ you used when defining the tool. In this case, since we defined the tool as
317
+ `weather`, the part type is `tool-weather`.
318
+ </Note>
319
+
320
+ ### Update the UI
321
+
322
+ To display the tool invocation in your UI, update your `src/routes/+page.svelte` file:
323
+
324
+ ```svelte filename="src/routes/+page.svelte"
325
+ <script lang="ts">
326
+ import { Chat } from '@ai-sdk/svelte';
327
+
328
+ let input = '';
329
+ const chat = new Chat({});
330
+
331
+ function handleSubmit(event: SubmitEvent) {
332
+ event.preventDefault();
333
+ chat.sendMessage({ text: input });
334
+ input = '';
335
+ }
336
+ </script>
337
+
338
+ <main>
339
+ <ul>
340
+ {#each chat.messages as message, messageIndex (messageIndex)}
341
+ <li>
342
+ <div>{message.role}</div>
343
+ <div>
344
+ {#each message.parts as part, partIndex (partIndex)}
345
+ {#if part.type === 'text'}
346
+ <div>{part.text}</div>
347
+ {:else if part.type === 'tool-weather'}
348
+ <pre>{JSON.stringify(part, null, 2)}</pre>
349
+ {/if}
350
+ {/each}
351
+ </div>
352
+ </li>
353
+ {/each}
354
+ </ul>
355
+ <form onsubmit={handleSubmit}>
356
+ <input bind:value={input} />
357
+ <button type="submit">Send</button>
358
+ </form>
359
+ </main>
360
+ ```
361
+
362
+ With this change, you're updating the UI to handle different message parts. For text parts, you display the text content as before. For weather tool invocations, you display a JSON representation of the tool call and its result.
363
+
364
+ Now, when you ask about the weather, you'll see the tool call and its result displayed in your chat interface.
365
+
366
+ ## Enabling Multi-Step Tool Calls
367
+
368
+ You may have noticed that while the tool is now visible in the chat interface, the model isn't using this information to answer your original query. This is because once the model generates a tool call, it has technically completed its generation.
369
+
370
+ To solve this, you can enable multi-step tool calls using `stopWhen`. By default, `stopWhen` is set to `stepCountIs(1)`, which means generation stops after the first step when there are tool results. By changing this condition, you can allow the model to automatically send tool results back to itself to trigger additional generations until your specified stopping condition is met. In this case, you want the model to continue generating so it can use the weather tool results to answer your original question.
371
+
372
+ ### Update Your API Route
373
+
374
+ Modify your `src/routes/api/chat/+server.ts` file to include the `stopWhen` condition:
375
+
376
+ ```ts filename="src/routes/api/chat/+server.ts" highlight="15"
377
+ import {
378
+ createGateway,
379
+ streamText,
380
+ type UIMessage,
381
+ convertToModelMessages,
382
+ tool,
383
+ stepCountIs,
384
+ } from 'ai';
385
+ import { z } from 'zod';
386
+
387
+ import { AI_GATEWAY_API_KEY } from '$env/static/private';
388
+
389
+ const gateway = createGateway({
390
+ apiKey: AI_GATEWAY_API_KEY,
391
+ });
392
+
393
+ export async function POST({ request }) {
394
+ const { messages }: { messages: UIMessage[] } = await request.json();
395
+
396
+ const result = streamText({
397
+ model: gateway('anthropic/claude-sonnet-4.5'),
398
+ messages: await convertToModelMessages(messages),
399
+ stopWhen: stepCountIs(5),
400
+ tools: {
401
+ weather: tool({
402
+ description: 'Get the weather in a location (fahrenheit)',
403
+ inputSchema: z.object({
404
+ location: z.string().describe('The location to get the weather for'),
405
+ }),
406
+ execute: async ({ location }) => {
407
+ const temperature = Math.round(Math.random() * (90 - 32) + 32);
408
+ return {
409
+ location,
410
+ temperature,
411
+ };
412
+ },
413
+ }),
414
+ },
415
+ });
416
+
417
+ return result.toUIMessageStreamResponse();
418
+ }
419
+ ```
420
+
421
+ Head back to the browser and ask about the weather in a location. You should now see the model using the weather tool results to answer your question.
422
+
423
+ By setting `stopWhen: stepCountIs(5)`, you're allowing the model to use up to 5 "steps" for any given generation. This enables more complex interactions and allows the model to gather and process information over several steps if needed. You can see this in action by adding another tool to convert the temperature from Fahrenheit to Celsius.
424
+
425
+ ### Add another tool
426
+
427
+ Update your `src/routes/api/chat/+server.ts` file to add a new tool to convert the temperature from Fahrenheit to Celsius:
428
+
429
+ ```tsx filename="src/routes/api/chat/+server.ts" highlight="32-45"
430
+ import {
431
+ createGateway,
432
+ streamText,
433
+ type UIMessage,
434
+ convertToModelMessages,
435
+ tool,
436
+ stepCountIs,
437
+ } from 'ai';
438
+ import { z } from 'zod';
439
+
440
+ import { AI_GATEWAY_API_KEY } from '$env/static/private';
441
+
442
+ const gateway = createGateway({
443
+ apiKey: AI_GATEWAY_API_KEY,
444
+ });
445
+
446
+ export async function POST({ request }) {
447
+ const { messages }: { messages: UIMessage[] } = await request.json();
448
+
449
+ const result = streamText({
450
+ model: gateway('anthropic/claude-sonnet-4.5'),
451
+ messages: await convertToModelMessages(messages),
452
+ stopWhen: stepCountIs(5),
453
+ tools: {
454
+ weather: tool({
455
+ description: 'Get the weather in a location (fahrenheit)',
456
+ inputSchema: z.object({
457
+ location: z.string().describe('The location to get the weather for'),
458
+ }),
459
+ execute: async ({ location }) => {
460
+ const temperature = Math.round(Math.random() * (90 - 32) + 32);
461
+ return {
462
+ location,
463
+ temperature,
464
+ };
465
+ },
466
+ }),
467
+ convertFahrenheitToCelsius: tool({
468
+ description: 'Convert a temperature in fahrenheit to celsius',
469
+ inputSchema: z.object({
470
+ temperature: z
471
+ .number()
472
+ .describe('The temperature in fahrenheit to convert'),
473
+ }),
474
+ execute: async ({ temperature }) => {
475
+ const celsius = Math.round((temperature - 32) * (5 / 9));
476
+ return {
477
+ celsius,
478
+ };
479
+ },
480
+ }),
481
+ },
482
+ });
483
+
484
+ return result.toUIMessageStreamResponse();
485
+ }
486
+ ```
487
+
488
+ ### Update Your Frontend
489
+
490
+ Update your UI to handle the new temperature conversion tool by modifying the tool part handling:
491
+
492
+ ```svelte filename="src/routes/+page.svelte" highlight="17"
493
+ <script lang="ts">
494
+ import { Chat } from '@ai-sdk/svelte';
495
+
496
+ let input = '';
497
+ const chat = new Chat({});
498
+
499
+ function handleSubmit(event: SubmitEvent) {
500
+ event.preventDefault();
501
+ chat.sendMessage({ text: input });
502
+ input = '';
503
+ }
504
+ </script>
505
+
506
+ <main>
507
+ <ul>
508
+ {#each chat.messages as message, messageIndex (messageIndex)}
509
+ <li>
510
+ <div>{message.role}</div>
511
+ <div>
512
+ {#each message.parts as part, partIndex (partIndex)}
513
+ {#if part.type === 'text'}
514
+ <div>{part.text}</div>
515
+ {:else if part.type === 'tool-weather' || part.type === 'tool-convertFahrenheitToCelsius'}
516
+ <pre>{JSON.stringify(part, null, 2)}</pre>
517
+ {/if}
518
+ {/each}
519
+ </div>
520
+ </li>
521
+ {/each}
522
+ </ul>
523
+ <form onsubmit={handleSubmit}>
524
+ <input bind:value={input} />
525
+ <button type="submit">Send</button>
526
+ </form>
527
+ </main>
528
+ ```
529
+
530
+ This update handles the new `tool-convertFahrenheitToCelsius` part type, displaying the temperature conversion tool calls and results in the UI.
531
+
532
+ Now, when you ask "What's the weather in New York in celsius?", you should see a more complete interaction:
533
+
534
+ 1. The model will call the weather tool for New York.
535
+ 2. You'll see the tool output displayed.
536
+ 3. It will then call the temperature conversion tool to convert the temperature from Fahrenheit to Celsius.
537
+ 4. The model will then use that information to provide a natural language response about the weather in New York.
538
+
539
+ This multi-step approach allows the model to gather information and use it to provide more accurate and contextual responses, making your chatbot considerably more useful.
540
+
541
+ This simple example demonstrates how tools can expand your model's capabilities. You can create more complex tools to integrate with real APIs, databases, or any other external systems, allowing the model to access and process real-world data in real-time. Tools bridge the gap between the model's knowledge cutoff and current information.
542
+
543
+ ## How does `@ai-sdk/svelte` differ from `@ai-sdk/react`?
544
+
545
+ The surface-level difference is that Svelte uses classes to manage state, whereas React uses hooks, so `useChat` in React is `Chat` in Svelte. Other than that, there are a few things to keep in mind:
546
+
547
+ ### 1. Arguments to classes aren't reactive by default
548
+
549
+ Unlike in React, where hooks are rerun any time their containing component is invalidated, code in the `script` block of a Svelte component is only run once when the component is created.
550
+ This means that, if you want arguments to your class to be reactive, you need to make sure you pass a _reference_ into the class, rather than a value:
551
+
552
+ ```svelte
553
+ <script>
554
+ import { Chat } from '@ai-sdk/svelte';
555
+
556
+ let { id } = $props();
557
+
558
+ // won't work; the class instance will be created once, `id` will be copied by value, and won't update when $props.id changes
559
+ let chat = new Chat({ id });
560
+
561
+ // will work; passes `id` by reference, so `Chat` always has the latest value
562
+ let chat = new Chat({
563
+ get id() {
564
+ return id;
565
+ },
566
+ });
567
+ </script>
568
+ ```
569
+
570
+ Keep in mind that this normally doesn't matter; most parameters you'll pass into the Chat class are static (for example, you typically wouldn't expect your `onError` handler to change).
571
+
572
+ ### 2. You can't destructure class properties
573
+
574
+ In vanilla JavaScript, destructuring class properties copies them by value and "disconnects" them from their class instance:
575
+
576
+ ```js
577
+ const classInstance = new Whatever();
578
+ classInstance.foo = 'bar';
579
+ const { foo } = classInstance;
580
+ classInstance.foo = 'baz';
581
+
582
+ console.log(foo); // 'bar'
583
+ ```
584
+
585
+ The same is true of classes in Svelte:
586
+
587
+ ```svelte
588
+ <script>
589
+ import { Chat } from '@ai-sdk/svelte';
590
+
591
+ const chat = new Chat({});
592
+ let { messages } = chat;
593
+
594
+ chat.append({ content: 'Hello, world!', role: 'user' }).then(() => {
595
+ console.log(messages); // []
596
+ console.log(chat.messages); // [{ content: 'Hello, world!', role: 'user' }] (plus some other stuff)
597
+ });
598
+ </script>
599
+ ```
600
+
601
+ ### 3. Instance synchronization requires context
602
+
603
+ In React, hook instances with the same `id` are synchronized -- so two instances of `useChat` will have the same `messages`, `status`, etc. if they have the same `id`.
604
+ For most use cases, you probably don't need this behavior -- but if you do, you can create a context in your root layout file using `createAIContext`:
605
+
606
+ ```svelte
607
+ <script>
608
+ import { createAIContext } from '@ai-sdk/svelte';
609
+
610
+ let { children } = $props();
611
+
612
+ createAIContext();
613
+ // all hooks created after this or in components that are children of this component
614
+ // will have synchronized state
615
+ </script>
616
+
617
+ {@render children()}
618
+ ```
619
+
620
+ ## Where to Next?
621
+
622
+ You've built an AI chatbot using the AI SDK! From here, you have several paths to explore:
623
+
624
+ - To learn more about the AI SDK, read through the [documentation](/docs).
625
+ - If you're interested in diving deeper with guides, check out the [RAG (retrieval-augmented generation)](/docs/guides/rag-chatbot) and [multi-modal chatbot](/docs/guides/multi-modal-chatbot) guides.
626
+ - To jumpstart your first AI project, explore available [templates](https://vercel.com/templates?type=ai).
627
+ - To learn more about Svelte, check out the [official documentation](https://svelte.dev/docs/svelte).