this is a svelte component for using the openai realtime api (and mostly a direct port to svelte of the openai-realtime-console repository).
it allows you to easily use the openai realtime api in your svelte(kit) project.
work in progress, but it should be functional.
demos here (enter your own api key, as always be careful with stuff like that and e.g. use a 2$ limited api key):
basic chat: https://flo-bit.dev/svelte-openai-realtime-api/
chat with visualizations: https://flo-bit.dev/svelte-openai-realtime-api/visualizations-chat
visualizations only: https://flo-bit.dev/svelte-openai-realtime-api/visualizations-input
https://github.com/user-attachments/assets/81473395-5811-475d-81ac-13c0e7811eff
[!WARNING] this is the setup for the client side only version of the realtime api, you will need to use a relay server to use this in production. see further down for more information on how to use a relay server.
copy the src/lib/realtime/
folder from this repository into your sveltekit projects src/lib/
folder
install the dependency:
$ npm i openai/openai-realtime-api-beta
Realtime
component into your svelte file and use it e.g. like so:<script lang="ts">
import Realtime from '$lib/realtime/realtime.svelte';
import type { ItemType } from '@openai/realtime-api-beta/dist/lib/client';
let startConversation: () => Promise<void>;
let endConversation: () => Promise<void>;
let turnDetection: 'server_vad' | 'none' = 'server_vad';
let items: ItemType[] = [];
let isConnected = false;
let isRecording = false;
let startRecording: () => Promise<void>;
let stopRecording: () => Promise<void>;
// set your api key here
let apiKey = '';
</script>
{#if apiKey}
<Realtime
bind:startConversation
bind:endConversation
bind:isConnected
bind:isRecording
bind:startRecording
bind:stopRecording
bind:items
{turnDetection}
{apiKey}
/>
{/if}
see src/routes/+page.svelte
for a full example.
see src/routes/visulizations-chat/+page.svelte
for an example of how to visualize the audio input and output.
for production use, you will need to use a relay server to use the realtime api.
add OPENAI_API_KEY
to your .env
file
tell the Realtime component to use the relay server:
<Realtime useRelayServer />
then you have two options:
change your vite.config.ts
to this:
import { realtimeWebSocketServer } from './src/lib/realtime/realtime_server';
import { sveltekit } from '@sveltejs/kit/vite';
import { defineConfig } from 'vite';
export default defineConfig({
plugins: [sveltekit(), realtimeWebSocketServer]
});
copy the relay-server/
folder (identical to the code in the
openai-realtime-console repository)
from this repository into your project
install the dependencies:
npm i dotenv openai/openai-realtime-api-beta
$ node relay-server/index.js
<Realtime useRelayServer relayServer="http://localhost:8081" />
MIT