-
Notifications
You must be signed in to change notification settings - Fork 0
/
liveblocks.config.ts
57 lines (49 loc) · 1.43 KB
/
liveblocks.config.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
// Define Liveblocks types for your application
// https://liveblocks.io/docs/api-reference/liveblocks-react#Typing-your-data
import {
LiveList,
LiveMap,
LiveObject
} from "@liveblocks/client"
import { Layer, Color } from "@/types/canvas"
declare global {
interface Liveblocks {
// Each user's Presence, for useMyPresence, useOthers, etc.
Presence: {
// Example, real-time cursor coordinates
cursor: { x: number; y: number } | null;
selection: string[]
};
// The Storage tree for the room, for useMutation, useStorage, etc.
Storage: {
layers: LiveMap<string, LiveObject<Layer>>;
layerIds: LiveList<string>;
};
// Custom user info set when authenticating with a secret key
UserMeta: {
id?: string;
info: {
name?: string;
picture?: string;
};
};
// Custom events, for useBroadcastEvent, useEventListener
RoomEvent: {};
// Example has two events, using a union
// | { type: "PLAY" }
// | { type: "REACTION"; emoji: "🔥" };
// Custom metadata set on threads, for useThreads, useCreateThread, etc.
ThreadMetadata: {
// Example, attaching coordinates to a thread
// x: number;
// y: number;
};
// Custom room info set with resolveRoomsInfo, for useRoomInfo
RoomInfo: {
// Example, rooms with a title and url
// title: string;
// url: string;
};
}
}
export {};