Developer Experience Guidelines - Javascript
This section provides best practices for creating a smooth and efficient development process when working with VideoSDK. From handling errors gracefully to managing resources and event subscriptions, these guidelines help developers build more reliable and maintainable applications. Following these practices can simplify troubleshooting, prevent common pitfalls, and improve overall application performance.
Initiate Key Features After Meeting Join Event​
To provide a seamless and reliable meeting experience, initiate specific features only after the meeting-joined event has been triggered.
-
Trigger Key Actions After Joining the Meeting : Initiating crucial actions after the
meeting-joined
event helps avoid errors and optimizes the meeting setup, ensuring a smoother experience for participants. If your application utilizes any of the following features or you want to perform any action as soon as meeting joins, it's recommended to call them only after the meeting has successfully started:Chat Subscription
: To enable in-meeting chat functionality, subscribe to the chat topic after themeeting-joined
event is triggered. This ensures that messages are reliably received by participants.
-
Device Management
: If you need users to use specific audio or video devices when the meeting is first joined, you can utilize the custom track. Pass thecameraId
to the createCameraVideoTrack() method for video, and themicrophoneId
to the createMicrophoneAudioTrack() method for audio. Once the track is created, provide it to the initMeeting() method. -
Recording and Transcription
: To automatically start recording or transcription as soon as the meeting begins, configure theautoStartConfig
in thecreateMeeting
API. For detailed information, refer to the documentation here.
Dispose Custom Tracks When Necessary​
Proper disposal of custom tracks is essential for managing system resources and ensuring a smooth experience. In most scenarios, tracks are automatically disposed of by the SDK, ensuring efficient resource management. However, in specific cases outlined below, you will need to dispose of custom tracks explicitly:
-
When Enabling/Disabling the Camera on a Precall Screen:
- If your application includes a precall screen and you want to ensure that the device's camera is not used when the camera is disabled, you must dispose of the custom video track. Otherwise, the device’s camera will continue to be used even when the camera is off.
- Additionally, remember to create a new track when the user enables the camera again.
- If you don’t need to manage the camera's usage on the device level (i.e., you’re okay with the camera being used whether it’s enabled or disabled), you can skip this step.
- Here's how you can manage customTrack on a precall screen :
let joinPageVideoStream = null;
let webCamEnable = false;
let joinPageWebcam = document.getElementById("joinCam");
async function toggleWebCam() {
if (joinPageVideoStream) {
// Remove the video stream from the video element
joinPageWebcam.srcObject = null;
webCamEnable = false;
const tracks = joinPageVideoStream.getTracks();
// Stop each track to release the resources
tracks.forEach((track) => {
track.stop();
});
joinPageVideoStream = null;
} else {
enableCam();
}
}
// Function to enable the webcam and create a new video stream
async function enableCam() {
try {
joinPageVideoStream = await window.VideoSDK.createCameraVideoTrack({
// Pass the selected camera ID
cameraId : selctedCameraId ? selectedCameraId : undefined,
optimizationMode: "motion",
multiStream: false,
});
} catch (ex) {
console.log("Exception in enableCam", ex);
}
if (joinPageVideoStream) {
// Set the stream as the source for the video element
joinPageWebcam.srcObject = mediaStream;
joinPageWebcam.play().catch((error) =>
console.log("videoElem.current.play() failed", error)
);
webCamEnable = true;
}
}
Listen for Error Events​
Listening to error events enables your application to handle unexpected issues efficiently, providing users with clear feedback and potential solutions. Error codes pinpoint specific problems, whether from configuration settings, account restrictions, permission limitations, or device constraints. Here are recommended solutions based on common error categories:
-
Errors associated with Organization: If you encounter errors related to your organization (e.g., account status or participant limits), reach out to support at support@videosdk.live or reach out to us on Discord for assistance.
-
Errors associated with Token: For errors related to authentication tokens, ensure the token is valid and hasn’t expired, then try the request again.
-
Errors associated with Meeting and Participant: Check that meetingId and participantId are correctly passed and valid. Also, ensure each participant has a unique participantId to avoid duplicate entries.
-
Errors associated with Add-on Service: If you encounter errors with add-on services (such as recording or streaming), try restarting the service after receiving a failure event. For example, if a
START_RECORDING_FAILED
error event occurs, attempt to call thestartRecording()
method again. If you're using webhooks, you can also retry on recording-failed hook. -
Errors associated with Media: Inform the user about media access issues, such as microphone or camera permissions. Design the UI to clearly indicate what is preventing the mic or camera from enabling, helping the user understand the problem.
-
Errors associated with Track: Ensure that the track you’ve created and passed to enable the mic or camera methods meets the required specifications.
-
Errors associated with Actions: If you need to perform actions as soon as a meeting joins, only initiate them after receiving the meeting-joined event, otherwise it will not work well.
- Here's how to listen for the error event:
meeting.on("error", (data) => {
const { code, message } = data;
});
Got a Question? Ask us on discord