@liveblocks/react 1.2.4 → 1.3.1
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.
- package/dist/index.d.mts +1018 -401
- package/dist/index.d.ts +1018 -401
- package/dist/index.js +686 -30
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +688 -32
- package/dist/index.mjs.map +1 -1
- package/package.json +6 -7
package/dist/index.d.mts
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
|
+
import * as React$1 from 'react';
|
|
1
2
|
import { ReactElement, ReactNode } from 'react';
|
|
3
|
+
import * as _liveblocks_core from '@liveblocks/core';
|
|
4
|
+
import { CommentBody, BaseMetadata, ThreadData, Resolve, ToImmutable, CommentData, RoomInitializers } from '@liveblocks/core';
|
|
2
5
|
import { JsonObject, LsonObject, BaseUserMeta, LiveObject, User, Others, Json, Room, Status, BroadcastOptions, LostConnectionEvent, History, Client } from '@liveblocks/client';
|
|
3
6
|
export { Json, JsonObject, shallow } from '@liveblocks/client';
|
|
4
|
-
import { ToImmutable, Resolve, RoomInitializers } from '@liveblocks/core';
|
|
5
7
|
|
|
6
8
|
declare type Props = {
|
|
7
9
|
fallback: NonNullable<ReactNode> | null;
|
|
@@ -26,6 +28,73 @@ declare type Props = {
|
|
|
26
28
|
*/
|
|
27
29
|
declare function ClientSideSuspense(props: Props): ReactElement;
|
|
28
30
|
|
|
31
|
+
declare type CreateThreadOptions<TMetadata extends BaseMetadata> = [
|
|
32
|
+
TMetadata
|
|
33
|
+
] extends [never] ? {
|
|
34
|
+
body: CommentBody;
|
|
35
|
+
} : {
|
|
36
|
+
body: CommentBody;
|
|
37
|
+
metadata: TMetadata;
|
|
38
|
+
};
|
|
39
|
+
declare type EditThreadMetadataOptions<TMetadata extends BaseMetadata> = [
|
|
40
|
+
TMetadata
|
|
41
|
+
] extends [never] ? {
|
|
42
|
+
threadId: string;
|
|
43
|
+
} : {
|
|
44
|
+
threadId: string;
|
|
45
|
+
metadata: Partial<TMetadata>;
|
|
46
|
+
};
|
|
47
|
+
declare type CreateCommentOptions = {
|
|
48
|
+
threadId: string;
|
|
49
|
+
body: CommentBody;
|
|
50
|
+
};
|
|
51
|
+
declare type EditCommentOptions = {
|
|
52
|
+
threadId: string;
|
|
53
|
+
commentId: string;
|
|
54
|
+
body: CommentBody;
|
|
55
|
+
};
|
|
56
|
+
declare type DeleteCommentOptions = {
|
|
57
|
+
threadId: string;
|
|
58
|
+
commentId: string;
|
|
59
|
+
};
|
|
60
|
+
declare type RoomThreads<TThreadMetadata extends BaseMetadata> = {
|
|
61
|
+
isLoading: true;
|
|
62
|
+
threads?: never;
|
|
63
|
+
error?: never;
|
|
64
|
+
} | {
|
|
65
|
+
isLoading: false;
|
|
66
|
+
threads?: never;
|
|
67
|
+
error: Error;
|
|
68
|
+
} | {
|
|
69
|
+
isLoading: false;
|
|
70
|
+
threads: ThreadData<TThreadMetadata>[];
|
|
71
|
+
error?: never;
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
declare type ResolveUserOptions = {
|
|
75
|
+
userId: string;
|
|
76
|
+
};
|
|
77
|
+
declare type ResolveMentionSuggestionsOptions = {
|
|
78
|
+
roomId: string;
|
|
79
|
+
text: string;
|
|
80
|
+
};
|
|
81
|
+
declare type UserState<T> = {
|
|
82
|
+
user?: never;
|
|
83
|
+
isLoading: true;
|
|
84
|
+
error?: never;
|
|
85
|
+
} | {
|
|
86
|
+
user?: T;
|
|
87
|
+
isLoading: false;
|
|
88
|
+
error?: never;
|
|
89
|
+
} | {
|
|
90
|
+
user?: never;
|
|
91
|
+
isLoading: false;
|
|
92
|
+
error: Error;
|
|
93
|
+
};
|
|
94
|
+
declare type UserStateSuspense<T> = Resolve<Extract<UserState<T>, {
|
|
95
|
+
isLoading: false;
|
|
96
|
+
error?: never;
|
|
97
|
+
}>>;
|
|
29
98
|
declare type RoomProviderProps<TPresence extends JsonObject, TStorage extends LsonObject> = Resolve<{
|
|
30
99
|
/**
|
|
31
100
|
* The id of the room you want to connect to
|
|
@@ -70,7 +139,7 @@ declare type MutationContext<TPresence extends JsonObject, TStorage extends Lson
|
|
|
70
139
|
addToHistory: boolean;
|
|
71
140
|
}) => void;
|
|
72
141
|
};
|
|
73
|
-
declare type
|
|
142
|
+
declare type RoomContextBundleShared<TPresence extends JsonObject, TStorage extends LsonObject, TUserMeta extends BaseUserMeta, TRoomEvent extends Json, TThreadMetadata extends BaseMetadata> = {
|
|
74
143
|
/**
|
|
75
144
|
* You normally don't need to directly interact with the RoomContext, but
|
|
76
145
|
* it can be necessary if you're building an advanced app where you need to
|
|
@@ -175,39 +244,6 @@ declare type RoomContextBundle<TPresence extends JsonObject, TStorage extends Ls
|
|
|
175
244
|
* Returns whether there are any operations to redo.
|
|
176
245
|
*/
|
|
177
246
|
useCanRedo(): boolean;
|
|
178
|
-
/**
|
|
179
|
-
* Returns the LiveList associated with the provided key.
|
|
180
|
-
* The hook triggers a re-render if the LiveList is updated, however it does not triggers a re-render if a nested CRDT is updated.
|
|
181
|
-
*
|
|
182
|
-
* @param key The storage key associated with the LiveList
|
|
183
|
-
* @returns null while the storage is loading, otherwise, returns the LiveList associated to the storage
|
|
184
|
-
*
|
|
185
|
-
* @example
|
|
186
|
-
* const animals = useList("animals"); // e.g. [] or ["🦁", "🐍", "🦍"]
|
|
187
|
-
*/
|
|
188
|
-
useList<TKey extends Extract<keyof TStorage, string>>(key: TKey): TStorage[TKey] | null;
|
|
189
|
-
/**
|
|
190
|
-
* Returns the LiveMap associated with the provided key. If the LiveMap does not exist, a new empty LiveMap will be created.
|
|
191
|
-
* The hook triggers a re-render if the LiveMap is updated, however it does not triggers a re-render if a nested CRDT is updated.
|
|
192
|
-
*
|
|
193
|
-
* @param key The storage key associated with the LiveMap
|
|
194
|
-
* @returns null while the storage is loading, otherwise, returns the LiveMap associated to the storage
|
|
195
|
-
*
|
|
196
|
-
* @example
|
|
197
|
-
* const shapesById = useMap("shapes");
|
|
198
|
-
*/
|
|
199
|
-
useMap<TKey extends Extract<keyof TStorage, string>>(key: TKey): TStorage[TKey] | null;
|
|
200
|
-
/**
|
|
201
|
-
* Returns the LiveObject associated with the provided key.
|
|
202
|
-
* The hook triggers a re-render if the LiveObject is updated, however it does not triggers a re-render if a nested CRDT is updated.
|
|
203
|
-
*
|
|
204
|
-
* @param key The storage key associated with the LiveObject
|
|
205
|
-
* @returns null while the storage is loading, otherwise, returns the LveObject associated to the storage
|
|
206
|
-
*
|
|
207
|
-
* @example
|
|
208
|
-
* const object = useObject("obj");
|
|
209
|
-
*/
|
|
210
|
-
useObject<TKey extends Extract<keyof TStorage, string>>(key: TKey): TStorage[TKey] | null;
|
|
211
247
|
/**
|
|
212
248
|
* Returns the mutable (!) Storage root. This hook exists for
|
|
213
249
|
* backward-compatible reasons.
|
|
@@ -217,75 +253,82 @@ declare type RoomContextBundle<TPresence extends JsonObject, TStorage extends Ls
|
|
|
217
253
|
*/
|
|
218
254
|
useStorageRoot(): [root: LiveObject<TStorage> | null];
|
|
219
255
|
/**
|
|
220
|
-
*
|
|
221
|
-
*
|
|
222
|
-
*
|
|
223
|
-
* The selector function will get re-evaluated any time something changes in
|
|
224
|
-
* Storage. The value returned by your selector function will also be the
|
|
225
|
-
* value returned by the hook.
|
|
226
|
-
*
|
|
227
|
-
* The `root` value that gets passed to your selector function is
|
|
228
|
-
* a immutable/readonly version of your Liveblocks storage root.
|
|
256
|
+
* Returns the presence of the current user of the current room, and a function to update it.
|
|
257
|
+
* It is different from the setState function returned by the useState hook from React.
|
|
258
|
+
* You don't need to pass the full presence object to update it.
|
|
229
259
|
*
|
|
230
|
-
*
|
|
231
|
-
*
|
|
260
|
+
* @example
|
|
261
|
+
* const [myPresence, updateMyPresence] = useMyPresence();
|
|
262
|
+
* updateMyPresence({ x: 0 });
|
|
263
|
+
* updateMyPresence({ y: 0 });
|
|
232
264
|
*
|
|
233
|
-
*
|
|
234
|
-
* extra care when returning a computed object or list, for example when you
|
|
235
|
-
* return the result of a .map() or .filter() call from the selector. In
|
|
236
|
-
* those cases, you'll probably want to use a `shallow` comparison check.
|
|
265
|
+
* // At the next render, "myPresence" will be equal to "{ x: 0, y: 0 }"
|
|
237
266
|
*/
|
|
238
|
-
|
|
267
|
+
useMyPresence(): [
|
|
268
|
+
TPresence,
|
|
269
|
+
(patch: Partial<TPresence>, options?: {
|
|
270
|
+
addToHistory: boolean;
|
|
271
|
+
}) => void
|
|
272
|
+
];
|
|
239
273
|
/**
|
|
240
|
-
*
|
|
274
|
+
* useUpdateMyPresence is similar to useMyPresence but it only returns the function to update the current user presence.
|
|
275
|
+
* If you don't use the current user presence in your component, but you need to update it (e.g. live cursor), it's better to use useUpdateMyPresence to avoid unnecessary renders.
|
|
241
276
|
*
|
|
242
277
|
* @example
|
|
243
|
-
* const
|
|
244
|
-
*
|
|
278
|
+
* const updateMyPresence = useUpdateMyPresence();
|
|
279
|
+
* updateMyPresence({ x: 0 });
|
|
280
|
+
* updateMyPresence({ y: 0 });
|
|
281
|
+
*
|
|
282
|
+
* // At the next render, the presence of the current user will be equal to "{ x: 0, y: 0 }"
|
|
245
283
|
*/
|
|
246
|
-
|
|
284
|
+
useUpdateMyPresence(): (patch: Partial<TPresence>, options?: {
|
|
285
|
+
addToHistory: boolean;
|
|
286
|
+
}) => void;
|
|
247
287
|
/**
|
|
248
|
-
*
|
|
288
|
+
* Create a callback function that lets you mutate Liveblocks state.
|
|
249
289
|
*
|
|
250
|
-
* The
|
|
251
|
-
*
|
|
290
|
+
* The first argument that gets passed into your callback will be
|
|
291
|
+
* a "mutation context", which exposes the following:
|
|
252
292
|
*
|
|
253
|
-
*
|
|
254
|
-
*
|
|
293
|
+
* - `root` - The mutable Storage root.
|
|
294
|
+
* You can normal mutation on Live structures with this, for
|
|
295
|
+
* example: root.get('layers').get('layer1').set('fill',
|
|
296
|
+
* 'red')
|
|
255
297
|
*
|
|
256
|
-
*
|
|
257
|
-
* care when returning a computed object or list, for example when you return
|
|
258
|
-
* the result of a .map() or .filter() call from the selector. In those
|
|
259
|
-
* cases, you'll probably want to use a `shallow` comparison check.
|
|
298
|
+
* - `setMyPresence` - Call this with a new (partial) Presence value.
|
|
260
299
|
*
|
|
261
|
-
*
|
|
300
|
+
* - `self` - A read-only version of the latest self, if you need it to
|
|
301
|
+
* compute the next state.
|
|
262
302
|
*
|
|
263
|
-
*
|
|
264
|
-
*
|
|
265
|
-
* if (cursor !== null) {
|
|
266
|
-
* const { x, y } = cursor;
|
|
267
|
-
* }
|
|
303
|
+
* - `others` - A read-only version of the latest others list, if you
|
|
304
|
+
* need it to compute the next state.
|
|
268
305
|
*
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
*
|
|
273
|
-
*
|
|
274
|
-
* You don't need to pass the full presence object to update it.
|
|
306
|
+
* useMutation is like React's useCallback, except that the first argument
|
|
307
|
+
* that gets passed into your callback will be a "mutation context".
|
|
308
|
+
*
|
|
309
|
+
* If you want get access to the immutable root somewhere in your mutation,
|
|
310
|
+
* you can use `root.ToImmutable()`.
|
|
275
311
|
*
|
|
276
312
|
* @example
|
|
277
|
-
* const
|
|
278
|
-
*
|
|
279
|
-
*
|
|
313
|
+
* const fillLayers = useMutation(
|
|
314
|
+
* ({ root }, color: Color) => {
|
|
315
|
+
* ...
|
|
316
|
+
* },
|
|
317
|
+
* [],
|
|
318
|
+
* );
|
|
280
319
|
*
|
|
281
|
-
*
|
|
320
|
+
* fillLayers('red');
|
|
321
|
+
*
|
|
322
|
+
* const deleteLayers = useMutation(
|
|
323
|
+
* ({ root }) => {
|
|
324
|
+
* ...
|
|
325
|
+
* },
|
|
326
|
+
* [],
|
|
327
|
+
* );
|
|
328
|
+
*
|
|
329
|
+
* deleteLayers();
|
|
282
330
|
*/
|
|
283
|
-
|
|
284
|
-
TPresence,
|
|
285
|
-
(patch: Partial<TPresence>, options?: {
|
|
286
|
-
addToHistory: boolean;
|
|
287
|
-
}) => void
|
|
288
|
-
];
|
|
331
|
+
useMutation<F extends (context: MutationContext<TPresence, TStorage, TUserMeta>, ...args: any[]) => any>(callback: F, deps: readonly unknown[]): OmitFirstArg<F>;
|
|
289
332
|
/**
|
|
290
333
|
* Returns an object that lets you get information about all the users
|
|
291
334
|
* currently connected in the room.
|
|
@@ -379,176 +422,165 @@ declare type RoomContextBundle<TPresence extends JsonObject, TStorage extends Ls
|
|
|
379
422
|
*/
|
|
380
423
|
useOther<T>(connectionId: number, selector: (other: User<TPresence, TUserMeta>) => T, isEqual?: (prev: T, curr: T) => boolean): T;
|
|
381
424
|
/**
|
|
382
|
-
*
|
|
383
|
-
*
|
|
425
|
+
* @beta
|
|
426
|
+
*
|
|
427
|
+
* Returns a function that creates a thread with an initial comment, and optionally some metadata.
|
|
384
428
|
*
|
|
385
429
|
* @example
|
|
386
|
-
* const
|
|
387
|
-
*
|
|
388
|
-
|
|
430
|
+
* const createThread = useCreateThread();
|
|
431
|
+
* createThread({ body: {}, metadata: {} });
|
|
432
|
+
*/
|
|
433
|
+
useCreateThread(): (options: CreateThreadOptions<TThreadMetadata>) => ThreadData<TThreadMetadata>;
|
|
434
|
+
/**
|
|
435
|
+
* @beta
|
|
389
436
|
*
|
|
390
|
-
*
|
|
437
|
+
* Returns a function that edits a thread's metadata.
|
|
438
|
+
*
|
|
439
|
+
* @example
|
|
440
|
+
* const editThreadMetadata = useEditThreadMetadata();
|
|
441
|
+
* editThreadMetadata({ threadId: "th_xxx", metadata: {} } })
|
|
391
442
|
*/
|
|
392
|
-
|
|
393
|
-
addToHistory: boolean;
|
|
394
|
-
}) => void;
|
|
443
|
+
useEditThreadMetadata(): (options: EditThreadMetadataOptions<TThreadMetadata>) => void;
|
|
395
444
|
/**
|
|
396
|
-
*
|
|
445
|
+
* @beta
|
|
397
446
|
*
|
|
398
|
-
*
|
|
399
|
-
* context", which exposes the following:
|
|
447
|
+
* Returns a function that adds a comment to a thread.
|
|
400
448
|
*
|
|
401
|
-
*
|
|
402
|
-
*
|
|
403
|
-
*
|
|
449
|
+
* @example
|
|
450
|
+
* const createComment = useCreateComment();
|
|
451
|
+
* createComment({ threadId: "th_xxx", body: { {} } });
|
|
452
|
+
*/
|
|
453
|
+
useCreateComment(): (options: CreateCommentOptions) => CommentData;
|
|
454
|
+
/**
|
|
455
|
+
* @beta
|
|
404
456
|
*
|
|
405
|
-
*
|
|
457
|
+
* Returns a function that edits a comment's body.
|
|
406
458
|
*
|
|
407
|
-
*
|
|
408
|
-
*
|
|
459
|
+
* @example
|
|
460
|
+
* const editComment = useEditComment()
|
|
461
|
+
* editComment({ threadId: "th_xxx", commentId: "cm_xxx", body: {} })
|
|
462
|
+
*/
|
|
463
|
+
useEditComment(): (options: EditCommentOptions) => void;
|
|
464
|
+
/**
|
|
465
|
+
* @beta
|
|
409
466
|
*
|
|
410
|
-
*
|
|
411
|
-
*
|
|
467
|
+
* Returns a function that deletes a comment.
|
|
468
|
+
* If it is the last non-deleted comment, the thread also gets deleted.
|
|
412
469
|
*
|
|
413
|
-
*
|
|
414
|
-
*
|
|
470
|
+
* @example
|
|
471
|
+
* const deleteComment = useDeleteComment();
|
|
472
|
+
* deleteComment({ threadId: "th_xxx", commentId: "cm_xxx" })
|
|
473
|
+
*/
|
|
474
|
+
useDeleteComment(): (options: DeleteCommentOptions) => void;
|
|
475
|
+
};
|
|
476
|
+
declare type RoomContextBundle<TPresence extends JsonObject, TStorage extends LsonObject, TUserMeta extends BaseUserMeta, TRoomEvent extends Json, TThreadMetadata extends BaseMetadata> = Resolve<RoomContextBundleShared<TPresence, TStorage, TUserMeta, TRoomEvent, TThreadMetadata> & {
|
|
477
|
+
/**
|
|
478
|
+
* Extract arbitrary data from the Liveblocks Storage state, using an
|
|
479
|
+
* arbitrary selector function.
|
|
415
480
|
*
|
|
416
|
-
*
|
|
417
|
-
*
|
|
481
|
+
* The selector function will get re-evaluated any time something changes in
|
|
482
|
+
* Storage. The value returned by your selector function will also be the
|
|
483
|
+
* value returned by the hook.
|
|
484
|
+
*
|
|
485
|
+
* The `root` value that gets passed to your selector function is
|
|
486
|
+
* a immutable/readonly version of your Liveblocks storage root.
|
|
487
|
+
*
|
|
488
|
+
* The component that uses this hook will automatically re-render if the
|
|
489
|
+
* returned value changes.
|
|
490
|
+
*
|
|
491
|
+
* By default `useStorage()` uses strict `===` to check for equality. Take
|
|
492
|
+
* extra care when returning a computed object or list, for example when you
|
|
493
|
+
* return the result of a .map() or .filter() call from the selector. In
|
|
494
|
+
* those cases, you'll probably want to use a `shallow` comparison check.
|
|
495
|
+
*/
|
|
496
|
+
useStorage<T>(selector: (root: ToImmutable<TStorage>) => T, isEqual?: (prev: T | null, curr: T | null) => boolean): T | null;
|
|
497
|
+
/**
|
|
498
|
+
* Gets the current user once it is connected to the room.
|
|
418
499
|
*
|
|
419
500
|
* @example
|
|
420
|
-
* const
|
|
421
|
-
*
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
*
|
|
501
|
+
* const me = useSelf();
|
|
502
|
+
* const { x, y } = me.presence.cursor;
|
|
503
|
+
*/
|
|
504
|
+
useSelf(): User<TPresence, TUserMeta> | null;
|
|
505
|
+
/**
|
|
506
|
+
* Extract arbitrary data based on the current user.
|
|
426
507
|
*
|
|
427
|
-
*
|
|
508
|
+
* The selector function will get re-evaluated any time your presence data
|
|
509
|
+
* changes.
|
|
428
510
|
*
|
|
429
|
-
*
|
|
430
|
-
*
|
|
431
|
-
*
|
|
432
|
-
*
|
|
433
|
-
*
|
|
434
|
-
* )
|
|
511
|
+
* The component that uses this hook will automatically re-render if your
|
|
512
|
+
* selector function returns a different value from its previous run.
|
|
513
|
+
*
|
|
514
|
+
* By default `useSelf()` uses strict `===` to check for equality. Take extra
|
|
515
|
+
* care when returning a computed object or list, for example when you return
|
|
516
|
+
* the result of a .map() or .filter() call from the selector. In those
|
|
517
|
+
* cases, you'll probably want to use a `shallow` comparison check.
|
|
518
|
+
*
|
|
519
|
+
* Will return `null` while Liveblocks isn't connected to a room yet.
|
|
520
|
+
*
|
|
521
|
+
* @example
|
|
522
|
+
* const cursor = useSelf(me => me.presence.cursor);
|
|
523
|
+
* if (cursor !== null) {
|
|
524
|
+
* const { x, y } = cursor;
|
|
525
|
+
* }
|
|
435
526
|
*
|
|
436
|
-
* deleteLayers();
|
|
437
527
|
*/
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
* toast.clear();
|
|
495
|
-
* }
|
|
496
|
-
* })
|
|
497
|
-
*/
|
|
498
|
-
useLostConnectionListener(callback: (event: LostConnectionEvent) => void): void;
|
|
499
|
-
/**
|
|
500
|
-
* useErrorListener is a react hook that lets you react to potential room connection errors.
|
|
501
|
-
*
|
|
502
|
-
* @example
|
|
503
|
-
* useErrorListener(er => {
|
|
504
|
-
* console.error(er);
|
|
505
|
-
* })
|
|
506
|
-
*/
|
|
507
|
-
useErrorListener(callback: (err: Error) => void): void;
|
|
508
|
-
/**
|
|
509
|
-
* useEventListener is a react hook that lets you react to event broadcasted by other users in the room.
|
|
510
|
-
*
|
|
511
|
-
* @example
|
|
512
|
-
* useEventListener(({ connectionId, event }) => {
|
|
513
|
-
* if (event.type === "CUSTOM_EVENT") {
|
|
514
|
-
* // Do something
|
|
515
|
-
* }
|
|
516
|
-
* });
|
|
517
|
-
*/
|
|
518
|
-
useEventListener(callback: (eventData: {
|
|
519
|
-
connectionId: number;
|
|
520
|
-
event: TRoomEvent;
|
|
521
|
-
}) => void): void;
|
|
522
|
-
/**
|
|
523
|
-
* Returns the room.history
|
|
524
|
-
*/
|
|
525
|
-
useHistory(): History;
|
|
526
|
-
/**
|
|
527
|
-
* Returns a function that undoes the last operation executed by the current client.
|
|
528
|
-
* It does not impact operations made by other clients.
|
|
529
|
-
*/
|
|
530
|
-
useUndo(): () => void;
|
|
531
|
-
/**
|
|
532
|
-
* Returns a function that redoes the last operation executed by the current client.
|
|
533
|
-
* It does not impact operations made by other clients.
|
|
534
|
-
*/
|
|
535
|
-
useRedo(): () => void;
|
|
536
|
-
/**
|
|
537
|
-
* Returns whether there are any operations to undo.
|
|
538
|
-
*/
|
|
539
|
-
useCanUndo(): boolean;
|
|
540
|
-
/**
|
|
541
|
-
* Returns whether there are any operations to redo.
|
|
542
|
-
*/
|
|
543
|
-
useCanRedo(): boolean;
|
|
544
|
-
/**
|
|
545
|
-
* Returns the mutable (!) Storage root. This hook exists for
|
|
546
|
-
* backward-compatible reasons.
|
|
547
|
-
*
|
|
548
|
-
* @example
|
|
549
|
-
* const [root] = useStorageRoot();
|
|
550
|
-
*/
|
|
551
|
-
useStorageRoot(): [root: LiveObject<TStorage> | null];
|
|
528
|
+
useSelf<T>(selector: (me: User<TPresence, TUserMeta>) => T, isEqual?: (prev: T, curr: T) => boolean): T | null;
|
|
529
|
+
/**
|
|
530
|
+
* @beta
|
|
531
|
+
*
|
|
532
|
+
* Returns the threads within the current room.
|
|
533
|
+
*
|
|
534
|
+
* @example
|
|
535
|
+
* const { threads, error, isLoading } = useThreads();
|
|
536
|
+
*/
|
|
537
|
+
useThreads(): RoomThreads<TThreadMetadata>;
|
|
538
|
+
/**
|
|
539
|
+
* @beta
|
|
540
|
+
*
|
|
541
|
+
* Returns user info from a given user ID.
|
|
542
|
+
*
|
|
543
|
+
* @example
|
|
544
|
+
* const { user, error, isLoading } = useUser("user-id");
|
|
545
|
+
*/
|
|
546
|
+
useUser(userId: string): UserState<TUserMeta["info"]>;
|
|
547
|
+
/**
|
|
548
|
+
* Returns the LiveList associated with the provided key. The hook triggers
|
|
549
|
+
* a re-render if the LiveList is updated, however it does not triggers
|
|
550
|
+
* a re-render if a nested CRDT is updated.
|
|
551
|
+
*
|
|
552
|
+
* @param key The storage key associated with the LiveList
|
|
553
|
+
* @returns null while the storage is loading, otherwise, returns the LiveList associated to the storage
|
|
554
|
+
*
|
|
555
|
+
* @example
|
|
556
|
+
* const animals = useList("animals"); // e.g. [] or ["🦁", "🐍", "🦍"]
|
|
557
|
+
*/
|
|
558
|
+
useList<TKey extends Extract<keyof TStorage, string>>(key: TKey): TStorage[TKey] | null;
|
|
559
|
+
/**
|
|
560
|
+
* Returns the LiveMap associated with the provided key. If the LiveMap
|
|
561
|
+
* does not exist, a new empty LiveMap will be created. The hook triggers
|
|
562
|
+
* a re-render if the LiveMap is updated, however it does not triggers
|
|
563
|
+
* a re-render if a nested CRDT is updated.
|
|
564
|
+
*
|
|
565
|
+
* @param key The storage key associated with the LiveMap
|
|
566
|
+
* @returns null while the storage is loading, otherwise, returns the LiveMap associated to the storage
|
|
567
|
+
*
|
|
568
|
+
* @example
|
|
569
|
+
* const shapesById = useMap("shapes");
|
|
570
|
+
*/
|
|
571
|
+
useMap<TKey extends Extract<keyof TStorage, string>>(key: TKey): TStorage[TKey] | null;
|
|
572
|
+
/**
|
|
573
|
+
* Returns the LiveObject associated with the provided key.
|
|
574
|
+
* The hook triggers a re-render if the LiveObject is updated, however it does not triggers a re-render if a nested CRDT is updated.
|
|
575
|
+
*
|
|
576
|
+
* @param key The storage key associated with the LiveObject
|
|
577
|
+
* @returns null while the storage is loading, otherwise, returns the LveObject associated to the storage
|
|
578
|
+
*
|
|
579
|
+
* @example
|
|
580
|
+
* const object = useObject("obj");
|
|
581
|
+
*/
|
|
582
|
+
useObject<TKey extends Extract<keyof TStorage, string>>(key: TKey): TStorage[TKey] | null;
|
|
583
|
+
suspense: Resolve<RoomContextBundleShared<TPresence, TStorage, TUserMeta, TRoomEvent, TThreadMetadata> & {
|
|
552
584
|
/**
|
|
553
585
|
* Extract arbitrary data from the Liveblocks Storage state, using an
|
|
554
586
|
* arbitrary selector function.
|
|
@@ -602,175 +634,23 @@ declare type RoomContextBundle<TPresence extends JsonObject, TStorage extends Ls
|
|
|
602
634
|
*/
|
|
603
635
|
useSelf<T>(selector: (me: User<TPresence, TUserMeta>) => T, isEqual?: (prev: T, curr: T) => boolean): T;
|
|
604
636
|
/**
|
|
605
|
-
*
|
|
606
|
-
* It is different from the setState function returned by the useState hook from React.
|
|
607
|
-
* You don't need to pass the full presence object to update it.
|
|
608
|
-
*
|
|
609
|
-
* @example
|
|
610
|
-
* const [myPresence, updateMyPresence] = useMyPresence();
|
|
611
|
-
* updateMyPresence({ x: 0 });
|
|
612
|
-
* updateMyPresence({ y: 0 });
|
|
613
|
-
*
|
|
614
|
-
* // At the next render, "myPresence" will be equal to "{ x: 0, y: 0 }"
|
|
615
|
-
*/
|
|
616
|
-
useMyPresence(): [
|
|
617
|
-
TPresence,
|
|
618
|
-
(patch: Partial<TPresence>, options?: {
|
|
619
|
-
addToHistory: boolean;
|
|
620
|
-
}) => void
|
|
621
|
-
];
|
|
622
|
-
/**
|
|
623
|
-
* Returns an object that lets you get information about all the users
|
|
624
|
-
* currently connected in the room.
|
|
625
|
-
*
|
|
626
|
-
* @example
|
|
627
|
-
* const others = useOthers();
|
|
628
|
-
*
|
|
629
|
-
* // Example to map all cursors in JSX
|
|
630
|
-
* return (
|
|
631
|
-
* <>
|
|
632
|
-
* {others.map((user) => {
|
|
633
|
-
* if (user.presence.cursor == null) {
|
|
634
|
-
* return null;
|
|
635
|
-
* }
|
|
636
|
-
* return <Cursor key={user.connectionId} cursor={user.presence.cursor} />
|
|
637
|
-
* })}
|
|
638
|
-
* </>
|
|
639
|
-
* )
|
|
640
|
-
*/
|
|
641
|
-
useOthers(): Others<TPresence, TUserMeta>;
|
|
642
|
-
/**
|
|
643
|
-
* Extract arbitrary data based on all the users currently connected in the
|
|
644
|
-
* room (except yourself).
|
|
645
|
-
*
|
|
646
|
-
* The selector function will get re-evaluated any time a user enters or
|
|
647
|
-
* leaves the room, as well as whenever their presence data changes.
|
|
648
|
-
*
|
|
649
|
-
* The component that uses this hook will automatically re-render if your
|
|
650
|
-
* selector function returns a different value from its previous run.
|
|
651
|
-
*
|
|
652
|
-
* By default `useOthers()` uses strict `===` to check for equality. Take
|
|
653
|
-
* extra care when returning a computed object or list, for example when you
|
|
654
|
-
* return the result of a .map() or .filter() call from the selector. In
|
|
655
|
-
* those cases, you'll probably want to use a `shallow` comparison check.
|
|
656
|
-
*
|
|
657
|
-
* @example
|
|
658
|
-
* const avatars = useOthers(users => users.map(u => u.info.avatar), shallow);
|
|
659
|
-
* const cursors = useOthers(users => users.map(u => u.presence.cursor), shallow);
|
|
660
|
-
* const someoneIsTyping = useOthers(users => users.some(u => u.presence.isTyping));
|
|
661
|
-
*
|
|
662
|
-
*/
|
|
663
|
-
useOthers<T>(selector: (others: Others<TPresence, TUserMeta>) => T, isEqual?: (prev: T, curr: T) => boolean): T;
|
|
664
|
-
/**
|
|
665
|
-
* Returns an array of connection IDs. This matches the values you'll get by
|
|
666
|
-
* using the `useOthers()` hook.
|
|
667
|
-
*
|
|
668
|
-
* Roughly equivalent to:
|
|
669
|
-
* useOthers((others) => others.map(other => other.connectionId), shallow)
|
|
670
|
-
*
|
|
671
|
-
* This is useful in particular to implement efficiently rendering components
|
|
672
|
-
* for each user in the room, e.g. cursors.
|
|
673
|
-
*
|
|
674
|
-
* @example
|
|
675
|
-
* const ids = useOthersConnectionIds();
|
|
676
|
-
* // [2, 4, 7]
|
|
677
|
-
*/
|
|
678
|
-
useOthersConnectionIds(): readonly number[];
|
|
679
|
-
/**
|
|
680
|
-
* Related to useOthers(), but optimized for selecting only "subsets" of
|
|
681
|
-
* others. This is useful for performance reasons in particular, because
|
|
682
|
-
* selecting only a subset of users also means limiting the number of
|
|
683
|
-
* re-renders that will be triggered.
|
|
637
|
+
* @beta
|
|
684
638
|
*
|
|
685
|
-
*
|
|
686
|
-
* const avatars = useOthersMapped(user => user.info.avatar);
|
|
687
|
-
* // ^^^^^^^
|
|
688
|
-
* // { connectionId: number; data: string }[]
|
|
689
|
-
*
|
|
690
|
-
* The selector function you pass to useOthersMapped() is called an "item
|
|
691
|
-
* selector", and operates on a single user at a time. If you provide an
|
|
692
|
-
* (optional) "item comparison" function, it will be used to compare each
|
|
693
|
-
* item pairwise.
|
|
694
|
-
*
|
|
695
|
-
* For example, to select multiple properties:
|
|
639
|
+
* Returns the threads within the current room.
|
|
696
640
|
*
|
|
697
641
|
* @example
|
|
698
|
-
* const
|
|
699
|
-
* user => [u.info.avatar, u.presence.cursor],
|
|
700
|
-
* shallow, // 👈
|
|
701
|
-
* );
|
|
642
|
+
* const threads = useThreads();
|
|
702
643
|
*/
|
|
703
|
-
|
|
644
|
+
useThreads(): ThreadData<TThreadMetadata>[];
|
|
704
645
|
/**
|
|
705
|
-
*
|
|
706
|
-
* you can call this selector deep down in your component stack to only
|
|
707
|
-
* have the component re-render if properties for this particular user
|
|
708
|
-
* change.
|
|
646
|
+
* @beta
|
|
709
647
|
*
|
|
710
|
-
*
|
|
711
|
-
* // Returns only the selected values re-renders whenever that selection changes)
|
|
712
|
-
* const { x, y } = useOther(2, user => user.presence.cursor);
|
|
713
|
-
*/
|
|
714
|
-
useOther<T>(connectionId: number, selector: (other: User<TPresence, TUserMeta>) => T, isEqual?: (prev: T, curr: T) => boolean): T;
|
|
715
|
-
/**
|
|
716
|
-
* useUpdateMyPresence is similar to useMyPresence but it only returns the function to update the current user presence.
|
|
717
|
-
* If you don't use the current user presence in your component, but you need to update it (e.g. live cursor), it's better to use useUpdateMyPresence to avoid unnecessary renders.
|
|
648
|
+
* Returns user info from a given user ID.
|
|
718
649
|
*
|
|
719
650
|
* @example
|
|
720
|
-
* const
|
|
721
|
-
* updateMyPresence({ x: 0 });
|
|
722
|
-
* updateMyPresence({ y: 0 });
|
|
723
|
-
*
|
|
724
|
-
* // At the next render, the presence of the current user will be equal to "{ x: 0, y: 0 }"
|
|
651
|
+
* const { user, error, isLoading } = useUser("user-id");
|
|
725
652
|
*/
|
|
726
|
-
|
|
727
|
-
addToHistory: boolean;
|
|
728
|
-
}) => void;
|
|
729
|
-
/**
|
|
730
|
-
* Create a callback function that lets you mutate Liveblocks state.
|
|
731
|
-
*
|
|
732
|
-
* The first argument that gets passed into your callback will be
|
|
733
|
-
* a "mutation context", which exposes the following:
|
|
734
|
-
*
|
|
735
|
-
* - `root` - The mutable Storage root.
|
|
736
|
-
* You can normal mutation on Live structures with this, for
|
|
737
|
-
* example: root.get('layers').get('layer1').set('fill',
|
|
738
|
-
* 'red')
|
|
739
|
-
*
|
|
740
|
-
* - `setMyPresence` - Call this with a new (partial) Presence value.
|
|
741
|
-
*
|
|
742
|
-
* - `self` - A read-only version of the latest self, if you need it to
|
|
743
|
-
* compute the next state.
|
|
744
|
-
*
|
|
745
|
-
* - `others` - A read-only version of the latest others list, if you
|
|
746
|
-
* need it to compute the next state.
|
|
747
|
-
*
|
|
748
|
-
* useMutation is like React's useCallback, except that the first argument
|
|
749
|
-
* that gets passed into your callback will be a "mutation context".
|
|
750
|
-
*
|
|
751
|
-
* If you want get access to the immutable root somewhere in your mutation,
|
|
752
|
-
* you can use `root.ToImmutable()`.
|
|
753
|
-
*
|
|
754
|
-
* @example
|
|
755
|
-
* const fillLayers = useMutation(
|
|
756
|
-
* ({ root }, color: Color) => {
|
|
757
|
-
* ...
|
|
758
|
-
* },
|
|
759
|
-
* [],
|
|
760
|
-
* );
|
|
761
|
-
*
|
|
762
|
-
* fillLayers('red');
|
|
763
|
-
*
|
|
764
|
-
* const deleteLayers = useMutation(
|
|
765
|
-
* ({ root }) => {
|
|
766
|
-
* ...
|
|
767
|
-
* },
|
|
768
|
-
* [],
|
|
769
|
-
* );
|
|
770
|
-
*
|
|
771
|
-
* deleteLayers();
|
|
772
|
-
*/
|
|
773
|
-
useMutation<F extends (context: MutationContext<TPresence, TStorage, TUserMeta>, ...args: any[]) => any>(callback: F, deps: readonly unknown[]): OmitFirstArg<F>;
|
|
653
|
+
useUser(userId: string): UserStateSuspense<TUserMeta["info"]>;
|
|
774
654
|
/**
|
|
775
655
|
* Returns the LiveList associated with the provided key. The hook triggers
|
|
776
656
|
* a re-render if the LiveList is updated, however it does not triggers
|
|
@@ -807,9 +687,746 @@ declare type RoomContextBundle<TPresence extends JsonObject, TStorage extends Ls
|
|
|
807
687
|
* const object = useObject("obj");
|
|
808
688
|
*/
|
|
809
689
|
useObject<TKey extends Extract<keyof TStorage, string>>(key: TKey): TStorage[TKey];
|
|
690
|
+
}>;
|
|
691
|
+
}>;
|
|
692
|
+
|
|
693
|
+
declare type Options<TUserMeta extends BaseUserMeta> = {
|
|
694
|
+
/**
|
|
695
|
+
* @beta
|
|
696
|
+
*
|
|
697
|
+
* An asynchronous function that returns user info from a user ID.
|
|
698
|
+
*/
|
|
699
|
+
resolveUser?: (options: ResolveUserOptions) => Promise<TUserMeta["info"] | undefined>;
|
|
700
|
+
/**
|
|
701
|
+
* @beta
|
|
702
|
+
*
|
|
703
|
+
* An asynchronous function that returns a list of user IDs matching a string.
|
|
704
|
+
*/
|
|
705
|
+
resolveMentionSuggestions?: (options: ResolveMentionSuggestionsOptions) => Promise<string[]>;
|
|
706
|
+
};
|
|
707
|
+
/**
|
|
708
|
+
* @private
|
|
709
|
+
*
|
|
710
|
+
* This is an internal API, use `createRoomContext` instead.
|
|
711
|
+
*/
|
|
712
|
+
declare function useRoomContextBundle(): {
|
|
713
|
+
RoomContext: React$1.Context<Room<JsonObject, LsonObject, BaseUserMeta, never> | null>;
|
|
714
|
+
RoomProvider: (props: {
|
|
715
|
+
id: string;
|
|
716
|
+
children: React$1.ReactNode;
|
|
717
|
+
shouldInitiallyConnect?: boolean | undefined;
|
|
718
|
+
unstable_batchedUpdates?: ((cb: () => void) => void) | undefined;
|
|
719
|
+
initialPresence: JsonObject | ((roomId: string) => JsonObject);
|
|
720
|
+
initialStorage?: LsonObject | ((roomId: string) => LsonObject) | undefined;
|
|
721
|
+
}) => JSX.Element;
|
|
722
|
+
useRoom: () => Room<JsonObject, LsonObject, BaseUserMeta, never>;
|
|
723
|
+
useStatus: () => Status;
|
|
724
|
+
useBatch: <T>() => (callback: () => T) => T;
|
|
725
|
+
useBroadcastEvent: () => (event: never, options?: BroadcastOptions | undefined) => void;
|
|
726
|
+
useLostConnectionListener: (callback: (event: LostConnectionEvent) => void) => void;
|
|
727
|
+
useErrorListener: (callback: (err: Error) => void) => void;
|
|
728
|
+
useEventListener: (callback: (eventData: {
|
|
729
|
+
connectionId: number;
|
|
730
|
+
event: never;
|
|
731
|
+
}) => void) => void;
|
|
732
|
+
useHistory: () => History;
|
|
733
|
+
useUndo: () => () => void;
|
|
734
|
+
useRedo: () => () => void;
|
|
735
|
+
useCanUndo: () => boolean;
|
|
736
|
+
useCanRedo: () => boolean;
|
|
737
|
+
useStorageRoot: () => [root: LiveObject<LsonObject> | null];
|
|
738
|
+
useMyPresence: () => [JsonObject, (patch: Partial<JsonObject>, options?: {
|
|
739
|
+
addToHistory: boolean;
|
|
740
|
+
} | undefined) => void];
|
|
741
|
+
useUpdateMyPresence: () => (patch: Partial<JsonObject>, options?: {
|
|
742
|
+
addToHistory: boolean;
|
|
743
|
+
} | undefined) => void;
|
|
744
|
+
useMutation: <F extends (context: MutationContext<JsonObject, LsonObject, BaseUserMeta>, ...args: any[]) => any>(callback: F, deps: readonly unknown[]) => OmitFirstArg<F>;
|
|
745
|
+
useOthers: {
|
|
746
|
+
(): _liveblocks_core.Others<JsonObject, BaseUserMeta>;
|
|
747
|
+
<T_1>(selector: (others: _liveblocks_core.Others<JsonObject, BaseUserMeta>) => T_1, isEqual?: ((prev: T_1, curr: T_1) => boolean) | undefined): T_1;
|
|
748
|
+
};
|
|
749
|
+
useOthersConnectionIds: () => readonly number[];
|
|
750
|
+
useOthersMapped: <T_2>(itemSelector: (other: User<JsonObject, BaseUserMeta>) => T_2, itemIsEqual?: ((prev: T_2, curr: T_2) => boolean) | undefined) => readonly (readonly [connectionId: number, data: T_2])[];
|
|
751
|
+
useOther: <T_3>(connectionId: number, selector: (other: User<JsonObject, BaseUserMeta>) => T_3, isEqual?: ((prev: T_3, curr: T_3) => boolean) | undefined) => T_3;
|
|
752
|
+
useCreateThread: () => (options: {
|
|
753
|
+
body: _liveblocks_core.CommentBody;
|
|
754
|
+
metadata: BaseMetadata;
|
|
755
|
+
}) => _liveblocks_core.ThreadData<BaseMetadata>;
|
|
756
|
+
useEditThreadMetadata: () => (options: {
|
|
757
|
+
threadId: string;
|
|
758
|
+
metadata: Partial<BaseMetadata>;
|
|
759
|
+
}) => void;
|
|
760
|
+
useCreateComment: () => (options: CreateCommentOptions) => CommentData;
|
|
761
|
+
useEditComment: () => (options: EditCommentOptions) => void;
|
|
762
|
+
useDeleteComment: () => (options: DeleteCommentOptions) => void;
|
|
763
|
+
useStorage: <T_4>(selector: (root: {
|
|
764
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
765
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
766
|
+
})[] | {
|
|
767
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
768
|
+
})[] | {
|
|
769
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
770
|
+
})[] | {
|
|
771
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
772
|
+
})[] | {
|
|
773
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
774
|
+
})[] | {
|
|
775
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
776
|
+
})[] | {
|
|
777
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
778
|
+
})[] | {
|
|
779
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
780
|
+
})[] | {
|
|
781
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
782
|
+
})[] | {
|
|
783
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
784
|
+
})[] | {
|
|
785
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
786
|
+
})[] | {
|
|
787
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
788
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
789
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
790
|
+
})[] | {
|
|
791
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
792
|
+
})[] | {
|
|
793
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
794
|
+
})[] | {
|
|
795
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
796
|
+
})[] | {
|
|
797
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
798
|
+
})[] | {
|
|
799
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
800
|
+
})[] | {
|
|
801
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
802
|
+
})[] | {
|
|
803
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
804
|
+
})[] | {
|
|
805
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
806
|
+
})[] | {
|
|
807
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
808
|
+
})[] | {
|
|
809
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
810
|
+
})[] | {
|
|
811
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
812
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
813
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
814
|
+
})[] | {
|
|
815
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
816
|
+
})[] | {
|
|
817
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
818
|
+
})[] | {
|
|
819
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
820
|
+
})[] | {
|
|
821
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
822
|
+
})[] | {
|
|
823
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
824
|
+
})[] | {
|
|
825
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
826
|
+
})[] | {
|
|
827
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
828
|
+
})[] | {
|
|
829
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
830
|
+
})[] | {
|
|
831
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
832
|
+
})[] | {
|
|
833
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
834
|
+
})[] | {
|
|
835
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
836
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
837
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
838
|
+
})[] | {
|
|
839
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
840
|
+
})[] | {
|
|
841
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
842
|
+
})[] | {
|
|
843
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
844
|
+
})[] | {
|
|
845
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
846
|
+
})[] | {
|
|
847
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
848
|
+
})[] | {
|
|
849
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
850
|
+
})[] | {
|
|
851
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
852
|
+
})[] | {
|
|
853
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
854
|
+
})[] | {
|
|
855
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
856
|
+
})[] | {
|
|
857
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
858
|
+
})[] | {
|
|
859
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
860
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
861
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
862
|
+
})[] | {
|
|
863
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
864
|
+
})[] | {
|
|
865
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
866
|
+
})[] | {
|
|
867
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
868
|
+
})[] | {
|
|
869
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
870
|
+
})[] | {
|
|
871
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
872
|
+
})[] | {
|
|
873
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
874
|
+
})[] | {
|
|
875
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
876
|
+
})[] | {
|
|
877
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
878
|
+
})[] | {
|
|
879
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
880
|
+
})[] | {
|
|
881
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
882
|
+
})[] | {
|
|
883
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
884
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
885
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
886
|
+
})[] | {
|
|
887
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
888
|
+
})[] | {
|
|
889
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
890
|
+
})[] | {
|
|
891
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
892
|
+
})[] | {
|
|
893
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
894
|
+
})[] | {
|
|
895
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
896
|
+
})[] | {
|
|
897
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
898
|
+
})[] | {
|
|
899
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
900
|
+
})[] | {
|
|
901
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
902
|
+
})[] | {
|
|
903
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
904
|
+
})[] | {
|
|
905
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
906
|
+
})[] | {
|
|
907
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
908
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
909
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
910
|
+
})[] | {
|
|
911
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
912
|
+
})[] | {
|
|
913
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
914
|
+
})[] | {
|
|
915
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
916
|
+
})[] | {
|
|
917
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
918
|
+
})[] | {
|
|
919
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
920
|
+
})[] | {
|
|
921
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
922
|
+
})[] | {
|
|
923
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
924
|
+
})[] | {
|
|
925
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
926
|
+
})[] | {
|
|
927
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
928
|
+
})[] | {
|
|
929
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
930
|
+
})[] | {
|
|
931
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
932
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
933
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
934
|
+
})[] | {
|
|
935
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
936
|
+
})[] | {
|
|
937
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
938
|
+
})[] | {
|
|
939
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
940
|
+
})[] | {
|
|
941
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
942
|
+
})[] | {
|
|
943
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
944
|
+
})[] | {
|
|
945
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
946
|
+
})[] | {
|
|
947
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
948
|
+
})[] | {
|
|
949
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
950
|
+
})[] | {
|
|
951
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
952
|
+
})[] | {
|
|
953
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
954
|
+
})[] | {
|
|
955
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
956
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
957
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
958
|
+
})[] | {
|
|
959
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
960
|
+
})[] | {
|
|
961
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
962
|
+
})[] | {
|
|
963
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
964
|
+
})[] | {
|
|
965
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
966
|
+
})[] | {
|
|
967
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
968
|
+
})[] | {
|
|
969
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
970
|
+
})[] | {
|
|
971
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
972
|
+
})[] | {
|
|
973
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
974
|
+
})[] | {
|
|
975
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
976
|
+
})[] | {
|
|
977
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
978
|
+
})[] | {
|
|
979
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
980
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
981
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
982
|
+
})[] | {
|
|
983
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
984
|
+
})[] | {
|
|
985
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
986
|
+
})[] | {
|
|
987
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
988
|
+
})[] | {
|
|
989
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
990
|
+
})[] | {
|
|
991
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
992
|
+
})[] | {
|
|
993
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
994
|
+
})[] | {
|
|
995
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
996
|
+
})[] | {
|
|
997
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
998
|
+
})[] | {
|
|
999
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1000
|
+
})[] | {
|
|
1001
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1002
|
+
})[] | {
|
|
1003
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1004
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1005
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1006
|
+
})[] | {
|
|
1007
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1008
|
+
})[] | {
|
|
1009
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1010
|
+
})[] | {
|
|
1011
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1012
|
+
})[] | {
|
|
1013
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1014
|
+
})[] | {
|
|
1015
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1016
|
+
})[] | {
|
|
1017
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1018
|
+
})[] | {
|
|
1019
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1020
|
+
})[] | {
|
|
1021
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1022
|
+
})[] | {
|
|
1023
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1024
|
+
})[] | {
|
|
1025
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1026
|
+
})[] | {
|
|
1027
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1028
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1029
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1030
|
+
})[] | {
|
|
1031
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1032
|
+
})[] | {
|
|
1033
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1034
|
+
})[] | {
|
|
1035
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1036
|
+
})[] | {
|
|
1037
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1038
|
+
})[] | {
|
|
1039
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1040
|
+
})[] | {
|
|
1041
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1042
|
+
})[] | {
|
|
1043
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1044
|
+
})[] | {
|
|
1045
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1046
|
+
})[] | {
|
|
1047
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1048
|
+
})[] | {
|
|
1049
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1050
|
+
})[] | {
|
|
1051
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1052
|
+
} | undefined;
|
|
1053
|
+
}) => T_4, isEqual?: ((prev: T_4 | null, curr: T_4 | null) => boolean) | undefined) => T_4 | null;
|
|
1054
|
+
useSelf: {
|
|
1055
|
+
(): User<JsonObject, BaseUserMeta> | null;
|
|
1056
|
+
<T_5>(selector: (me: User<JsonObject, BaseUserMeta>) => T_5, isEqual?: ((prev: T_5, curr: T_5) => boolean) | undefined): T_5 | null;
|
|
1057
|
+
};
|
|
1058
|
+
useThreads: () => RoomThreads<BaseMetadata>;
|
|
1059
|
+
useUser: (userId: string) => UserState<{
|
|
1060
|
+
[key: string]: Json | undefined;
|
|
1061
|
+
name?: string | undefined;
|
|
1062
|
+
avatar?: string | undefined;
|
|
1063
|
+
} | undefined>;
|
|
1064
|
+
useList: <TKey extends string>(key: TKey) => _liveblocks_core.Lson | undefined;
|
|
1065
|
+
useMap: <TKey_1 extends string>(key: TKey_1) => _liveblocks_core.Lson | undefined;
|
|
1066
|
+
useObject: <TKey_2 extends string>(key: TKey_2) => _liveblocks_core.Lson | undefined;
|
|
1067
|
+
suspense: {
|
|
1068
|
+
RoomContext: React$1.Context<Room<JsonObject, LsonObject, BaseUserMeta, never> | null>;
|
|
1069
|
+
RoomProvider: (props: {
|
|
1070
|
+
id: string;
|
|
1071
|
+
children: React$1.ReactNode;
|
|
1072
|
+
shouldInitiallyConnect?: boolean | undefined;
|
|
1073
|
+
unstable_batchedUpdates?: ((cb: () => void) => void) | undefined;
|
|
1074
|
+
initialPresence: JsonObject | ((roomId: string) => JsonObject);
|
|
1075
|
+
initialStorage?: LsonObject | ((roomId: string) => LsonObject) | undefined;
|
|
1076
|
+
}) => JSX.Element;
|
|
1077
|
+
useRoom: () => Room<JsonObject, LsonObject, BaseUserMeta, never>;
|
|
1078
|
+
useStatus: () => Status;
|
|
1079
|
+
useBatch: <T>() => (callback: () => T) => T;
|
|
1080
|
+
useBroadcastEvent: () => (event: never, options?: BroadcastOptions | undefined) => void;
|
|
1081
|
+
useLostConnectionListener: (callback: (event: LostConnectionEvent) => void) => void;
|
|
1082
|
+
useErrorListener: (callback: (err: Error) => void) => void;
|
|
1083
|
+
useEventListener: (callback: (eventData: {
|
|
1084
|
+
connectionId: number;
|
|
1085
|
+
event: never;
|
|
1086
|
+
}) => void) => void;
|
|
1087
|
+
useHistory: () => History;
|
|
1088
|
+
useUndo: () => () => void;
|
|
1089
|
+
useRedo: () => () => void;
|
|
1090
|
+
useCanUndo: () => boolean;
|
|
1091
|
+
useCanRedo: () => boolean;
|
|
1092
|
+
useStorageRoot: () => [root: LiveObject<LsonObject> | null];
|
|
1093
|
+
useMyPresence: () => [JsonObject, (patch: Partial<JsonObject>, options?: {
|
|
1094
|
+
addToHistory: boolean;
|
|
1095
|
+
} | undefined) => void];
|
|
1096
|
+
useUpdateMyPresence: () => (patch: Partial<JsonObject>, options?: {
|
|
1097
|
+
addToHistory: boolean;
|
|
1098
|
+
} | undefined) => void;
|
|
1099
|
+
useMutation: <F extends (context: MutationContext<JsonObject, LsonObject, BaseUserMeta>, ...args: any[]) => any>(callback: F, deps: readonly unknown[]) => OmitFirstArg<F>;
|
|
1100
|
+
useOthers: {
|
|
1101
|
+
(): _liveblocks_core.Others<JsonObject, BaseUserMeta>;
|
|
1102
|
+
<T_1>(selector: (others: _liveblocks_core.Others<JsonObject, BaseUserMeta>) => T_1, isEqual?: ((prev: T_1, curr: T_1) => boolean) | undefined): T_1;
|
|
1103
|
+
};
|
|
1104
|
+
useOthersConnectionIds: () => readonly number[];
|
|
1105
|
+
useOthersMapped: <T_2>(itemSelector: (other: User<JsonObject, BaseUserMeta>) => T_2, itemIsEqual?: ((prev: T_2, curr: T_2) => boolean) | undefined) => readonly (readonly [connectionId: number, data: T_2])[];
|
|
1106
|
+
useOther: <T_3>(connectionId: number, selector: (other: User<JsonObject, BaseUserMeta>) => T_3, isEqual?: ((prev: T_3, curr: T_3) => boolean) | undefined) => T_3;
|
|
1107
|
+
useCreateThread: () => (options: {
|
|
1108
|
+
body: _liveblocks_core.CommentBody;
|
|
1109
|
+
metadata: BaseMetadata;
|
|
1110
|
+
}) => _liveblocks_core.ThreadData<BaseMetadata>;
|
|
1111
|
+
useEditThreadMetadata: () => (options: {
|
|
1112
|
+
threadId: string;
|
|
1113
|
+
metadata: Partial<BaseMetadata>;
|
|
1114
|
+
}) => void;
|
|
1115
|
+
useCreateComment: () => (options: CreateCommentOptions) => CommentData;
|
|
1116
|
+
useEditComment: () => (options: EditCommentOptions) => void;
|
|
1117
|
+
useDeleteComment: () => (options: DeleteCommentOptions) => void;
|
|
1118
|
+
useStorage: <T_6>(selector: (root: {
|
|
1119
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | ReadonlyMap<string, _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1120
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1121
|
+
})[] | {
|
|
1122
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1123
|
+
})[] | {
|
|
1124
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1125
|
+
})[] | {
|
|
1126
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1127
|
+
})[] | {
|
|
1128
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1129
|
+
})[] | {
|
|
1130
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1131
|
+
})[] | {
|
|
1132
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1133
|
+
})[] | {
|
|
1134
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1135
|
+
})[] | {
|
|
1136
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1137
|
+
})[] | {
|
|
1138
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1139
|
+
})[] | {
|
|
1140
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1141
|
+
})[] | {
|
|
1142
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1143
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1144
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1145
|
+
})[] | {
|
|
1146
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1147
|
+
})[] | {
|
|
1148
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1149
|
+
})[] | {
|
|
1150
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1151
|
+
})[] | {
|
|
1152
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1153
|
+
})[] | {
|
|
1154
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1155
|
+
})[] | {
|
|
1156
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1157
|
+
})[] | {
|
|
1158
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1159
|
+
})[] | {
|
|
1160
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1161
|
+
})[] | {
|
|
1162
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1163
|
+
})[] | {
|
|
1164
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1165
|
+
})[] | {
|
|
1166
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1167
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1168
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1169
|
+
})[] | {
|
|
1170
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1171
|
+
})[] | {
|
|
1172
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1173
|
+
})[] | {
|
|
1174
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1175
|
+
})[] | {
|
|
1176
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1177
|
+
})[] | {
|
|
1178
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1179
|
+
})[] | {
|
|
1180
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1181
|
+
})[] | {
|
|
1182
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1183
|
+
})[] | {
|
|
1184
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1185
|
+
})[] | {
|
|
1186
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1187
|
+
})[] | {
|
|
1188
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1189
|
+
})[] | {
|
|
1190
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1191
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1192
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1193
|
+
})[] | {
|
|
1194
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1195
|
+
})[] | {
|
|
1196
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1197
|
+
})[] | {
|
|
1198
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1199
|
+
})[] | {
|
|
1200
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1201
|
+
})[] | {
|
|
1202
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1203
|
+
})[] | {
|
|
1204
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1205
|
+
})[] | {
|
|
1206
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1207
|
+
})[] | {
|
|
1208
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1209
|
+
})[] | {
|
|
1210
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1211
|
+
})[] | {
|
|
1212
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1213
|
+
})[] | {
|
|
1214
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1215
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1216
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1217
|
+
})[] | {
|
|
1218
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1219
|
+
})[] | {
|
|
1220
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1221
|
+
})[] | {
|
|
1222
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1223
|
+
})[] | {
|
|
1224
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1225
|
+
})[] | {
|
|
1226
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1227
|
+
})[] | {
|
|
1228
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1229
|
+
})[] | {
|
|
1230
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1231
|
+
})[] | {
|
|
1232
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1233
|
+
})[] | {
|
|
1234
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1235
|
+
})[] | {
|
|
1236
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1237
|
+
})[] | {
|
|
1238
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1239
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1240
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1241
|
+
})[] | {
|
|
1242
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1243
|
+
})[] | {
|
|
1244
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1245
|
+
})[] | {
|
|
1246
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1247
|
+
})[] | {
|
|
1248
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1249
|
+
})[] | {
|
|
1250
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1251
|
+
})[] | {
|
|
1252
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1253
|
+
})[] | {
|
|
1254
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1255
|
+
})[] | {
|
|
1256
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1257
|
+
})[] | {
|
|
1258
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1259
|
+
})[] | {
|
|
1260
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1261
|
+
})[] | {
|
|
1262
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1263
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1264
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1265
|
+
})[] | {
|
|
1266
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1267
|
+
})[] | {
|
|
1268
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1269
|
+
})[] | {
|
|
1270
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1271
|
+
})[] | {
|
|
1272
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1273
|
+
})[] | {
|
|
1274
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1275
|
+
})[] | {
|
|
1276
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1277
|
+
})[] | {
|
|
1278
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1279
|
+
})[] | {
|
|
1280
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1281
|
+
})[] | {
|
|
1282
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1283
|
+
})[] | {
|
|
1284
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1285
|
+
})[] | {
|
|
1286
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1287
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1288
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1289
|
+
})[] | {
|
|
1290
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1291
|
+
})[] | {
|
|
1292
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1293
|
+
})[] | {
|
|
1294
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1295
|
+
})[] | {
|
|
1296
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1297
|
+
})[] | {
|
|
1298
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1299
|
+
})[] | {
|
|
1300
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1301
|
+
})[] | {
|
|
1302
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1303
|
+
})[] | {
|
|
1304
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1305
|
+
})[] | {
|
|
1306
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1307
|
+
})[] | {
|
|
1308
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1309
|
+
})[] | {
|
|
1310
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1311
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1312
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1313
|
+
})[] | {
|
|
1314
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1315
|
+
})[] | {
|
|
1316
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1317
|
+
})[] | {
|
|
1318
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1319
|
+
})[] | {
|
|
1320
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1321
|
+
})[] | {
|
|
1322
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1323
|
+
})[] | {
|
|
1324
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1325
|
+
})[] | {
|
|
1326
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1327
|
+
})[] | {
|
|
1328
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1329
|
+
})[] | {
|
|
1330
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1331
|
+
})[] | {
|
|
1332
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1333
|
+
})[] | {
|
|
1334
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1335
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1336
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1337
|
+
})[] | {
|
|
1338
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1339
|
+
})[] | {
|
|
1340
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1341
|
+
})[] | {
|
|
1342
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1343
|
+
})[] | {
|
|
1344
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1345
|
+
})[] | {
|
|
1346
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1347
|
+
})[] | {
|
|
1348
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1349
|
+
})[] | {
|
|
1350
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1351
|
+
})[] | {
|
|
1352
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1353
|
+
})[] | {
|
|
1354
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1355
|
+
})[] | {
|
|
1356
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1357
|
+
})[] | {
|
|
1358
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1359
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1360
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1361
|
+
})[] | {
|
|
1362
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1363
|
+
})[] | {
|
|
1364
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1365
|
+
})[] | {
|
|
1366
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1367
|
+
})[] | {
|
|
1368
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1369
|
+
})[] | {
|
|
1370
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1371
|
+
})[] | {
|
|
1372
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1373
|
+
})[] | {
|
|
1374
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1375
|
+
})[] | {
|
|
1376
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1377
|
+
})[] | {
|
|
1378
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1379
|
+
})[] | {
|
|
1380
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1381
|
+
})[] | {
|
|
1382
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1383
|
+
}> | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | readonly (_liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | any | any | {
|
|
1384
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1385
|
+
})[] | {
|
|
1386
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1387
|
+
})[] | {
|
|
1388
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1389
|
+
})[] | {
|
|
1390
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1391
|
+
})[] | {
|
|
1392
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1393
|
+
})[] | {
|
|
1394
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1395
|
+
})[] | {
|
|
1396
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1397
|
+
})[] | {
|
|
1398
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1399
|
+
})[] | {
|
|
1400
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1401
|
+
})[] | {
|
|
1402
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1403
|
+
})[] | {
|
|
1404
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1405
|
+
})[] | {
|
|
1406
|
+
readonly [x: string]: _liveblocks_core.JsonScalar | _liveblocks_core.JsonArray | any | undefined;
|
|
1407
|
+
} | undefined;
|
|
1408
|
+
}) => T_6, isEqual?: ((prev: T_6, curr: T_6) => boolean) | undefined) => T_6;
|
|
1409
|
+
useSelf: {
|
|
1410
|
+
(): User<JsonObject, BaseUserMeta>;
|
|
1411
|
+
<T_7>(selector: (me: User<JsonObject, BaseUserMeta>) => T_7, isEqual?: ((prev: T_7, curr: T_7) => boolean) | undefined): T_7;
|
|
1412
|
+
};
|
|
1413
|
+
useThreads: () => _liveblocks_core.ThreadData<BaseMetadata>[];
|
|
1414
|
+
useUser: (userId: string) => {
|
|
1415
|
+
user?: {
|
|
1416
|
+
[key: string]: Json | undefined;
|
|
1417
|
+
name?: string | undefined;
|
|
1418
|
+
avatar?: string | undefined;
|
|
1419
|
+
} | undefined;
|
|
1420
|
+
isLoading: false;
|
|
1421
|
+
error?: undefined;
|
|
1422
|
+
};
|
|
1423
|
+
useList: <TKey_3 extends string>(key: TKey_3) => _liveblocks_core.Lson | undefined;
|
|
1424
|
+
useMap: <TKey_4 extends string>(key: TKey_4) => _liveblocks_core.Lson | undefined;
|
|
1425
|
+
useObject: <TKey_5 extends string>(key: TKey_5) => _liveblocks_core.Lson | undefined;
|
|
810
1426
|
};
|
|
1427
|
+
hasResolveMentionSuggestions: boolean;
|
|
1428
|
+
useMentionSuggestions: (search?: string | undefined) => string[] | undefined;
|
|
811
1429
|
};
|
|
1430
|
+
declare function createRoomContext<TPresence extends JsonObject, TStorage extends LsonObject = LsonObject, TUserMeta extends BaseUserMeta = BaseUserMeta, TRoomEvent extends Json = never, TThreadMetadata extends BaseMetadata = never>(client: Client, options?: Options<TUserMeta>): RoomContextBundle<TPresence, TStorage, TUserMeta, TRoomEvent, TThreadMetadata>;
|
|
812
1431
|
|
|
813
|
-
|
|
814
|
-
|
|
815
|
-
export { ClientSideSuspense, MutationContext, createRoomContext };
|
|
1432
|
+
export { ClientSideSuspense, MutationContext, ResolveMentionSuggestionsOptions, ResolveUserOptions, createRoomContext, useRoomContextBundle };
|