ejfox's picture
Duplicate from huggingface-projects/stable-diffusion-multiplayer
bb88c4d
<!--
Works similarly to `liveblocks-react` RoomProvider
https://liveblocks.io/docs/api-reference/liveblocks-react#RoomProvider
-->
<script lang="ts">
// @ts-nocheck
import { clientSymbol, roomSymbol } from './symbols';
import type { Client, Room } from '@liveblocks/client';
import { getContext, onDestroy, setContext } from 'svelte';
import type { Presence } from '$lib/types';
export let id: string;
export let initialPresence: Presence = {};
if (!id) {
throw new Error('RoomProvider requires an id');
}
const client = getContext<Client>(clientSymbol);
if (client) {
const room = client.enter(id, { initialPresence });
setContext<Room>(roomSymbol, room);
onDestroy(() => {
client.leave(id);
});
}
</script>
<slot />