UpdatedThe
useAmbientSession hook now returns a sessionType property. This helps you determine whether the session is an online or offline session.Quick Summary
The
The hook provides methods to
useAmbientSession hook controls your audio recording workflow. Use it after creating a session with useAmbient to manage recording, pausing, and submitting audio.The hook provides methods to
start, pause, resume, cancel, and submit recordings. It returns session status so you can update your UI and provides real-time audio data through callbacks for building visualizations.Overview
TheuseAmbientSession hook controls your audio recording workflow. Use it after creating a session with useAmbient to manage recording, pausing, and submitting audio.
What it does:
- Provides methods to control recording: Start, pause, resume, cancel, and submit audio
- Returns session status: Shows the current state of your session
- Provides real-time audio data: Gives you access to audio chunks through callbacks for building visualizations
- Manages session context: Lets you send patient and visit information to improve note quality
How It Works
The hook works in three steps:- Pass the session ID - Provide the
ambientSessionIdyou got fromuseAmbient - Configure options - Optionally set up audio batch size and callbacks for real-time audio data
- Use the controls - Call methods like
start(),pause(), andsubmit()to control recording
Configuration
Configure the hook with these parameters:Pass the unique session identifier you received from the
useAmbient hook. This links the recording to the session you created.Optional: Configure the audio batch size for the
onAudioChunkAvailable callback.Optional: Provide a callback function that receives audio chunks as they become available. The SDK calls this function whenever a batch of audio data is ready. Use this to draw real-time waveforms, visualizers, or other audio visualizations in your UI.
What It Returns
The hook returns control methods and status information you use to manage recording and update your UI.Actions (Methods)
Use these methods to control the recording workflow:Call this to begin recording audio. Call this when the user clicks a “Start Recording” button.
Call this to pause recording temporarily. You can resume later. Call this when the user clicks a “Pause” button.
Call this to resume a paused recording. Call this when the user clicks a “Resume” button.
Call this to stop recording and cancel the session. Call this when the user clicks a “Cancel” or “Discard” button.
Call this to finish recording and submit the session for note generation. Call this when the user clicks a “Finish” or “Submit” button.
Call this to send patient, provider, and visit metadata to Suki. The function sends context information that helps Suki generate more accurate clinical notes. Call this after
start() but before submit() for best results.State (Data)
Use these values to control your UI and show the current session state:Check this value to display the current session state in your UI. Common values:
"created" (session ready to start), "submitted" (recording finished, processing), "completed" (note generated), and "cancelled" (session cancelled). Use this to show status messages, enable/disable buttons, or change UI states based on the session status.Check this flag to show a loading state while syncing session information. When
true, the SDK is currently fetching session status from Suki’s backend. Display a loading indicator or disable actions while this is true.Use this value to determine whether the session is an online or offline session.
Session Context
ThesetSessionContext method lets you send patient, provider, and visit information to Suki. This context helps Suki’s AI generate more accurate and relevant clinical notes.
What Is Session Context?
Session context is metadata about the patient visit that improves note quality. Include:- Patient details: Date of birth, sex
- Provider information: Specialty, role
- Visit information: Visit type, encounter type, reason for visit, chief complaint
- Clinical sections: LOINC codes for specific sections you want in the note
- Diagnoses: Pre-existing or current diagnoses with codes and descriptions
When To Use It
CallsetSessionContext after calling start() but before calling submit(). Providing context early helps the AI understand the clinical scenario and generate better notes.
Session Context Structure
Response Type
setSessionContext method returns an empty object when successful. If an error occurs, it throws a ContextUpdateFailed error. See the Error Handling guide for details.
Code Example
This example shows how to build a recording interface with Start, Pause, Resume, and Submit controls. The UI updates based onsessionStatus to show the appropriate buttons at each stage.
React