var clientState = streamVideo.state;
var callState = call.state;
var participants = call.state.value.callParticipants;
Call and Participant State
When you join a call, we’ll automatically expose state in 3 different places: the Stream Video Client, the Call, and the participants.
Call State
When a Call
is created, users can subscribe to receive notifications about any changes that may occur during the call’s lifecycle.
To access the state of a call, use call.state.value
to obtain the latest CallState
snapshot, or use valueStream
to listen for real-time changes to the CallState
.
This functionality is particularly useful for determining which parts of the UI or application to render based on the current state or lifecycle of the ongoing call.
For example, you may want to display an indicator to users when a call is being recorded:
StreamBuilder<CallState>(
stream: call.state.valueStream, // Subscribe to state changes
builder: (context, snapshot) {
final state = snapshot.data;
if (state.isRecording) {
return CallRecordingUI();
} else {
return RegularCallUI();
}
},
),
The following fields are available on the call:
Attribute | Description |
---|---|
callCid | The type and id of the call. |
currentUserId | The user ID of the local user. |
createdByUserId | The id of a user that created the call. |
isRingingFlow | If this call has ringing set to true. |
sessionId | The current session ID for the call. |
status | The current call state - see next section for more information. |
settings | The settings for this call. |
egress | Contains URL for playlist of recording. |
rtmpIngress | Contains the RTMP ingest URL used for live streaming. |
isRecording | If the call is being recorded or not. |
isBroadcasting | If a call is broadcasting (to HLS) or not. |
isTranscribing | If transcriptions are active or not for this call. |
isCaptioning | If closed captions are active or not for this call. |
isBackstage | If a call is in backstage mode or not. |
videoInputDevice | Video input device currently set for the call. |
audioInputDevice | Audio input device currently set for the call. |
audioOutputDevice | Audio output device currently set for the call. |
ownCapabilities | Which actions you have permission to do. |
callParticipants | The list of call participants. |
createdAt | When the call was created. |
startsAt | When the call is scheduled to start. |
endedAt | When the call ended. |
updatedAt | When the call was updated. |
liveStartedAt | When call was set as live. |
liveEndedAt | When call was set as not live. |
timerEndsAt | Timestamp when the call will end, if maxDuration was set for the call. |
blockedUserIds | Ids of blocked users for this call. |
participantCount | Current participants count on this call. |
anonymousParticipantCount | Current anonymous participants count on this call. |
localParticipant | Shortcut to your own participant state. |
otherParticipants | The list of call participants other than yourself. |
capabilitiesByRole | What different roles (user, admin, moderator etc.) are allowed to do. |
custom | Custom data provided for this call. |
Understanding Call Status
The status
property of the CallState
object indicates the current state of the call. Depending on where you are in the call lifecycle, CallStatus
can have one of the following possible values.
Call Status | Description |
---|---|
CallStatusIdle | Indicates that there is no active call at the moment. |
CallStatusIncoming | Indicates that there’s an incoming call, and you need to display an incoming call screen. |
CallStatusOutgoing | Indicates that the user is making an outgoing call, and you need to display an outgoing call screen. |
CallStatusConnecting | Indicates that the SDK is attempting to connect to the call. |
CallStatusReconnecting | Indicates that the SDK is attempting to reconnect to the call. The number of attempts can be set via the attempt property. |
CallStatusReconnectionFailed | Indicates that the SDK failed to reconnect. |
CallStatusMigrating | Indicates that the SDK is attempting to migrate from one SFU to another. |
CallStatusConnected | Indicates that the user is connected to the call and is ready to send and receive tracks. |
CallStatusDisconnected | Indicates that the call has ended, failed, or has been canceled. The exact reason can be accessed via the DisconnectedReason property. |
CallStatusJoining | Indicates that the user is in the process of joining the call. |
CallStatusJoined | Indicates that the user has successfully joined the call. |
By checking the CallStatus
value in the CallState
object, you can determine the current state of the call and adjust your UI accordingly.
Participant State
var participants = call.state.value.callParticipants;
var localParticipant = call.state.value.localParticipant;
In the call state, you can find the parameter callParticipants
. This parameter allows you to access and manipulate the participants present on the call. By using callParticipants
, you can easily map over the participants and observe changes in their configuration.
For instance, you can keep track of which participant is currently speaking, which participant is the dominant speaker, and which participant is pinned to the call. Additionally, callParticipants
allows you to monitor other changes to the call’s configuration as well.
Overall, callParticipants
is a powerful tool that provides you with a lot of control and insight into the call’s current state and configuration. By leveraging this parameter effectively, you can create more advanced and robust call applications.
for (final user in call.state.value.callParticipants){
if (user.isDominantSpeaker){
setState(() => dominantSpeaker = user);
}
}
The following fields are available on the participant:
Attribute | Description |
---|---|
userId | The unique call ID of the participant. |
role | The user’s role in the call. |
custom | Any custom data added to the user. |
trackIdPrefix | Returns the user’s track ID prefix. |
publishedTracks | Returns the participant’s tracks. |
isSpeaking | Returns whether the participant is speaking. |
isDominantSpeaker | Returns whether the participant is a dominant speaker. |
isPinned | Returns whether the participant is pinned. |
isLocal | Returns whether the participant is local. |
isOnline | Returns whether the participant is online. |
sessionId | The session ID of the participant. |
connectionQuality | The participant’s connection quality. |
joinedAt | The date when the user joined the call. |
audioLevel | The audio level for the user. |
reaction | The current reaction added by the user. |
viewportVisibility | The user’s visibility on the screen. |
Combining CallState
and CallParticipantState
makes building custom UIs and integrations a breeze.
If there is a property or API that is not exposed for your specific use case, feel free to reach out to us.
We are constantly iterating and exposing APIs based on your feedback.
Client State
// Client state is available in the client object
var clientState = StreamVideo.instance.state;
Attribute | Description |
---|---|
user | The user you’re currently authenticated as. |
connection | The connection state of Stream Video. |
activeCall | The call you’ve currently joined. |
incomingCall | Contains the incoming call if ringing is set to true. |
outgoingCall | Contains the outgoing call if ringing is set to true. |