From 1ea735fc98972a8f357e68f977b64f1008065e79 Mon Sep 17 00:00:00 2001 From: Matvei Andrienko Date: Wed, 6 Nov 2024 14:27:31 +0100 Subject: [PATCH] docs: add a note about participant list truncation and livestreaming use case --- .../javascript/02-guides/03-call-and-participant-state.mdx | 2 ++ .../reactnative/03-core/03-call-and-participant-state.mdx | 4 +++- .../docs/React/02-guides/03-call-and-participant-state.mdx | 2 ++ 3 files changed, 7 insertions(+), 1 deletion(-) diff --git a/packages/client/docusaurus/docs/javascript/02-guides/03-call-and-participant-state.mdx b/packages/client/docusaurus/docs/javascript/02-guides/03-call-and-participant-state.mdx index c4f02a53be..7971adfc36 100644 --- a/packages/client/docusaurus/docs/javascript/02-guides/03-call-and-participant-state.mdx +++ b/packages/client/docusaurus/docs/javascript/02-guides/03-call-and-participant-state.mdx @@ -151,6 +151,8 @@ const subscription = call.state.participants$.subscribe((participants) => { subscription.unsubscribe(); ``` +In a call with many participants, the value of the `participants$` call state observable is truncated to 250 participants. The participants who are publishing video, audio, or screen sharing have priority over the other participants in the list. This means, for example, that in a livestream with one host and many viewers, the host is guaranteed to be in the list. + ## Client state The client state can be accessed by `client.state`. diff --git a/packages/react-native-sdk/docusaurus/docs/reactnative/03-core/03-call-and-participant-state.mdx b/packages/react-native-sdk/docusaurus/docs/reactnative/03-core/03-call-and-participant-state.mdx index 620ab1fe27..20cd790ba3 100644 --- a/packages/react-native-sdk/docusaurus/docs/reactnative/03-core/03-call-and-participant-state.mdx +++ b/packages/react-native-sdk/docusaurus/docs/reactnative/03-core/03-call-and-participant-state.mdx @@ -205,10 +205,12 @@ const hosts = participants.filter((p) => p.roles.includes('host')); // participants that publish video and audio const videoParticipants = participants.filter( - (p) => hasVideo(p) && hasAudio(p), + (p) => hasVideo(p) && hasAudio(p) ); ``` +In a call with many participants, the list returned by the `useParticipants` call state hook is truncated to 250 participants. The participants who are publishing video, audio, or screen sharing have priority over the other participants in the list. This means, for example, that in a livestream with one host and many viewers, the host is guaranteed to be in the list. + ## Client state To observe client state you need to provide a `StreamVideoClient` instance to the `StreamVideo` context provider. diff --git a/packages/react-sdk/docusaurus/docs/React/02-guides/03-call-and-participant-state.mdx b/packages/react-sdk/docusaurus/docs/React/02-guides/03-call-and-participant-state.mdx index e329305b40..d0d703b5d8 100644 --- a/packages/react-sdk/docusaurus/docs/React/02-guides/03-call-and-participant-state.mdx +++ b/packages/react-sdk/docusaurus/docs/React/02-guides/03-call-and-participant-state.mdx @@ -207,6 +207,8 @@ const videoParticipants = participants.filter( ); ``` +In a call with many participants, the list returned by the `useParticipants` call state hook is truncated to 250 participants. The participants who are publishing video, audio, or screen sharing have priority over the other participants in the list. This means, for example, that in a livestream with one host and many viewers, the host is guaranteed to be in the list. + ## Client state To observe client state you need to provide a `StreamVideoClient` instance to the `StreamVideo` context provider.