ngx-agora
Version:
Angular wrapper for Agora RTC client (https://www.agora.io/en/)
386 lines • 42.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/data/enums/client-event.enum.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/** @enum {string} */
const ClientEvent = {
/**
* Occurs when the first remote audio frame is decoded.
* The SDK triggers this callback when the local client successfully subscribes to a remote stream and decodes the first audio frame.
*
* @example
* client.on('first-audio-frame-decode', function (evt) {
* console.log('first-audio-frame-decode');
* console.log(evt.stream);
* })
*/
FirstAudioFrameDecoded: "first-audio-frame-decode",
/**
* Occurs when the first remote video frame is decoded.
* The SDK triggers this callback when the local client successfully subscribes to a remote stream and decodes the first video frame.
*
* @example
* client.on('first-video-frame-decode', function (evt) {
* console.log('first-video-frame-decode');
* console.log(evt.stream);
* })
*/
FirstVideoFrameDecoded: "first-video-frame-decode",
/**
* Occurs when the local stream is published.
*
* @example
* client.on("stream-published", function(evt) {
* console.log("local stream published");
* //……
* })
*/
LocalStreamPublished: "stream-published",
/**
* Occurs when the remote stream is added.
*
* @remark
* When the local user joins the channel, if other users are already in the channel,
* the SDK also reports to the app on the existing remote streams.
*
* @example
* client.on("stream-added", function(evt) {
* var stream = evt.stream;
* console.log("new stream added ", stream.getId());
* // Subscribe the stream.
* //……
* })
*/
RemoteStreamAdded: "stream-added",
/**
* Occurs when the remote stream is removed; for example, a peer user calls
* [Client.unpublish](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#unpublish).
*
* @example
* client.on("stream-removed", function(evt) {
* var stream = evt.stream;
* console.log("remote stream was removed", stream.getId());
* //……
* });
*/
RemoteStreamRemoved: "stream-removed",
/**
* Occurs when a user subscribes to a remote stream.
*
* @example
* client.on("stream-subscribed", function(evt) {
* var stream = evt.stream;
* console.log("new stream subscribed ", stream.getId());
* // Play the stream.
* //……
* })
*/
RemoteStreamSubscribed: "stream-subscribed",
/**
* Occurs when the peer user leaves the channel; for example, the peer user calls
* [Client.leave](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.client.html#leave).
*/
PeerLeave: "peer-leave",
/**
* Occurs when a remote user or host joins the channel.
* - Communication channel (rtc mode): This callback notifies the app that another user joins the channel.
* If other users are already in the channel, the SDK also reports to the app on the existing users.
* - Live-broadcast channel (live mode): This callback notifies the app that the host joins the channel.
* If other hosts are already in the channel, the SDK also reports to the app on the existing hosts.
* Agora recommends limiting the number of hosts to 17.
*/
PeerOnline: "peer-online",
/**
* Occurs when the peer user mutes the audio.
*
* @example
* client.on("mute-audio", function(evt) {
* var uid = evt.uid;
* console.log("mute audio:" + uid);
* //alert("mute audio:" + uid)
* });
*/
RemoteAudioMuted: "mute-audio",
/**
* Occurs when the peer user unmutes the audio.
*
* @example
* client.on("unmute-audio", function (evt) {
* var uid = evt.uid;
* console.log("unmute audio:" + uid);
* });
*/
RemoteAudioUnmuted: "unmute-audio",
/**
* Occurs when the peer user turns off the video.
*
* @example
* client.on("mute-video", function (evt) {
* var uid = evt.uid;
* console.log("mute video" + uid);
* //alert("mute video:" + uid);
* })
*/
RemoveVideoMuted: "mute-video",
/**
* Occurs when the peer user turns on the video.
*
* @example
* client.on("unmute-video", function (evt) {
* var uid = evt.uid;
* console.log("unmute video:" + uid);
* })
*/
RemoteVideoUnmuted: "unmute-video",
/**
* Occurs when encryption or decryption fails during publishing or subscribing to a stream.
* The failure is usually due to a wrong encryption password
* ([setEncryptionSecret](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#setencryptionsecret))
* or an incorrect encryption
* mode ([setEncryptionMode](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#setencryptionmode)).
*
* @since 3.0.0
*/
CryptError: "crypt-error",
/**
* This callback notifies the peer user that he/she is banned from the channel. Only the banned users receive this callback.
* Usually the reason is that the UID is banned (`K_UID_BANNED`(14)).
*
* @example
* client.on("client-banned", function (evt) {
* var uid = evt.uid;
* var attr = evt.attr;
* console.log(" user banned:" + uid + ", bantype:" + attr);
* alert(" user banned:" + uid + ", bantype:" + attr);
* });
*/
LocalClientBanned: "client-banned",
/** This callback notifies the application who is the active speaker in the channel. */
ActiveSpeaker: "active-speaker",
/**
* This callback notifies the application of all the speaking remote users and their volumes.
*
* It is disabled by default. You can enable this event by calling enableAudioVolumeIndicator.
* If enabled, it reports the volumes every two seconds regardless of whether there are users speaking.
*
* The volume is an integer ranging from 0 to 100. Usually a user with volume above five will be countedas a speaking user.
*/
VolumeIndicator: "volume-indicator",
/** Occurs when the live streaming starts. */
LiveStreamingStarted: "liveStreamingStarted",
/** Occurs when the live streaming fails. */
LiveStreamingFailed: "liveStreamingFailed",
/** Occurs when the live streaming stops. */
LiveStreamingStopped: "liveStreamingStopped",
/**
* Occurs when the live transcoding setting is updated.
*
* The SDK triggers this callback when the live transcoding setting is updated by calling the
* [setLiveTranscoding](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#setlivetranscoding) method.
*
* @remark
* The first call of the
* [setLiveTranscoding](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#setlivetranscoding)
* method does not trigger this callback.
*/
LiveTranscodingUpdated: "liveTranscodingUpdated",
/** Occurs when the injected online media stream's status is updated. */
StreamInjectedStatusUpdated: "streamInjectedStatus",
/**
* Occurs when the Token expires in 30 seconds.
*
* You should request a new Token from your server and call
* [Client.renewToken](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.client.html#renewtoken).
*/
TokenPrivelegeWillExpire: "onTokenPrivilegeWillExpire",
/**
* Occurs when the Token expires.
*
* You should request a new Token from your server and call
* [Client.renewToken](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.client.html#renewtoken).
*/
TokenPrivelegeExpired: "onTokenPrivilegeDidExpire",
/**
* Occurs when an error message is reported and requires error handling.
* For details, @see [Error Codes and Warning Codes](https://docs.agora.io/en/Video/the_error_web).
*/
Error: "error",
/**
* Occurs when the network type changes.
*
* @remark
* Chrome 61+ is required for this function, and the compatibility is not guaranteed.
*
* @see [Network Information API](https://developer.mozilla.org/en-US/docs/Web/API/Network_Information_API) for details.
*/
NetworkTypeChanged: "network-type-changed",
/**
* Occurs when an audio input device is added or removed.
*
* @example
* client.on("recording-device-changed", function(evt) {
* console.log("Recording Device Changed", evt.state, evt.device);
* });
*/
RecordingDeviceChanged: "recording-device-changed",
/**
* Occurs when an audio output device is added or removed.
* @remark
* Only supports Chrome 49+.
*/
AudioOutputDeviceChanged: "playout-device-changed",
/** Occurs when a camera is added or removed. */
CameraChanged: "camera-changed",
/**
* Occurs when the type of a video stream changes.
* It happens when a high-video stream changes to a low-video stream, or vice versa.
*
* The stream type (streamType):
* - 0: High-bitrate, high-resolution video stream.
* - 1: Low-bitrate, low-resolution video stream.
*/
StreamTypeChanged: "stream-type-changed",
/**
* Occurs when the network connection state changes.
*
* The connection between the SDK and Agora's edge server has the following states:
*
* - DISCONNECTED: The SDK is disconnected from Agora's edge server.
* This is the initial state before Client.join.
* The SDK also enters this state after the app calls Client.leave.
* - CONNECTING: The SDK is connecting to Agora's edge server. The SDK enters this state when calling Client.join or
* reconnecting to Agora's edge server automatically after the connection is lost.
* - CONNECTED: The SDK is connected to Agora's edge server and joins a channel. You can now publish or subscribe to a stream
* in the channel. If the connection is lost because, for example, the network is down or switched, the SDK triggers this callback
* and notifies the app that the state changes from CONNECTED to CONNECTING.
* - DISCONNECTING: The SDK is disconnecting from Agora's edge server. The SDK enters this state when calling Client.leave.
*/
ConnectionStateChanged: "connection-state-change",
/** Occurs when the SDK starts republishing or re-subscribing to a stream. */
StreamReconnectionStart: "stream-reconnect-start",
/** Occurs when the SDK finishes republishing or re-subscribing to a stream. */
StreamReconnectionEnd: "stream-reconnect-end",
/** Occurs when the user role switches in a live broadcast. For example, from a host to an audience or vice versa. */
ClientRoleChanged: "client-role-changed",
/**
* Reports the network quality of the local user once every two seconds.
*
* This callback reports on the uplink and downlink network conditions of the local user.
*
* @remark
* This is an experimental feature and the network quality rating is for reference only.
*/
NetworkQualityReported: "network-quality",
/**
* Occurs when the remote video stream falls back to an audio-only stream due to unreliable network
* conditions or switches back to the video after the network conditions improve.
*
* If you set `fallbackType` as 2 in
* [setStreamFallbackOption](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.client.html#setstreamfallbackoption),
* the SDK triggers this callback when the remote media stream falls back to audio only due to unreliable network conditions
* or switches back to the video after the network condition improves.
*
* @remark
* Once the remote media stream is switched to the low stream due to unreliable network conditions, you can monitor
* the stream switch between a high stream and low stream in the stream-type-changed callback.
*/
StreamFallback: "stream-fallback",
/**
* Occurs when a remote stream adds or removes a track.
*
* When a remote stream calls the [addTrack](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.stream.html#addtrack)
* or [removeTrack](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.stream.html#removetrack)
* method, the SDK triggers this callback.
*/
StreamUpdated: "stream-updated",
/**
* Reports exception events in the channel.
* Exceptions are not errors, but usually mean quality issues.
* This callback also reports recovery from an exception.
* Each exception event has a corresponding recovery event
* @see https://web-cdn.agora.io/docs-files/1547180053430 for details
*/
Exception: "exception",
/**
* Occurs when a remote user of the Native SDK calls `enableLocalVideo(true)` to enable video capture.
*
* @since 3.0.0
*/
RemoteVideoCaptureEnabled: "enable-local-video",
/**
* Occurs when a remote user of the Native SDK calls `enableLocalVideo(false)` to disable video capture.
*
* @since 3.0.0
*/
RemoteVideoCaptureDisabled: "disable-local-video",
/**
* Reports events during the media stream relay.
*
* Parameters
* - evt: `object`
* - code: `number`
* The event code for media stream relay.
* - 0: The user disconnects from the server due to a poor network connection.
* - 1: The user is connected to the server.
* - 2: The user joins the source channel.
* - 3: The user joins the destination channel.
* - 4: The SDK starts relaying the media stream to the destination channel.
* - 5: The server receives the video stream from the source channel.
* - 6: The server receives the audio stream from the source channel.
* - 7: The destination channel is updated.
*/
MediaStreamEventRelayed: "channel-media-relay-event",
/**
* Occurs when the state of the media stream relay changes.
*
* @since 3.0.0
* @description
* The SDK reports the state and error code of the current media relay in this callback.
*
* Parameters
* - evt: `object`
* - code: `number`
* The error code.
* - 0: No error.
* - 1: An error occurs in the server response.
* - 2: No server response.
* - 3: The SDK fails to access the service, probably due to limited resources of the server.
* - 4: Fails to send the relay request.
* - 5: Fails to accept the relay request.
* - 6: The server fails to receive the media stream.
* - 7: The server fails to send the media stream.
* - 8: The SDK disconnects from the server and fails to reconnect to the server due to a poor network connection.
* In this case, the SDK resets the relay state. You can try
* [startChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#startchannelmediarelay)
* to restart the media stream relay.
* - 9: An internal error occurs in the server.
* - 10: The token of the source channel has expired.
* - 11: The token of the destination channel has expired.
* - 12: The relay has already started. Possibly caused by calling
* [startChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#startchannelmediarelay)
* repeatedly, or calling
* [startChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#startchannelmediarelay)
* before
* [stopChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#stopchannelmediarelay)
* succeeds.
* - 13: The relay has not started. Possibly caused by calling
* [updateChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#updatechannelmediarelay)
* before
* [startChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#startchannelmediarelay)
* succeeds.
*
* - state: `number`
* The state code.
* - 0: The SDK is initializing.
* - 1: The SDK tries to relay the media stream to the destination channel.
* - 2: The SDK successfully relays the media stream to the destination channel.
* - 3: An error occurs. See `code` for the error code. In case of an error, the SDK resets the media stream relay state,
* and you need to call
* [startChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#startchannelmediarelay)
* to restart the relay.
*/
MediaStreamRelayStateChanged: "channel-media-relay-state",
};
export { ClientEvent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client-event.enum.js","sourceRoot":"ng://ngx-agora/","sources":["lib/data/enums/client-event.enum.ts"],"names":[],"mappings":";;;;;;AAQA,MAAY,WAAW;IACrB;;;;;;;;;OASG;IACH,sBAAsB,4BAA6B;IACnD;;;;;;;;;OASG;IACH,sBAAsB,4BAA6B;IACnD;;;;;;;;OAQG;IACH,oBAAoB,oBAAqB;IACzC;;;;;;;;;;;;;;OAcG;IACH,iBAAiB,gBAAiB;IAClC;;;;;;;;;;OAUG;IACH,mBAAmB,kBAAmB;IACtC;;;;;;;;;;OAUG;IACH,sBAAsB,qBAAsB;IAC5C;;;OAGG;IACH,SAAS,cAAe;IACxB;;;;;;;OAOG;IACH,UAAU,eAAgB;IAC1B;;;;;;;;;OASG;IACH,gBAAgB,cAAe;IAC/B;;;;;;;;OAQG;IACH,kBAAkB,gBAAiB;IACnC;;;;;;;;;OASG;IACH,gBAAgB,cAAe;IAC/B;;;;;;;;OAQG;IACH,kBAAkB,gBAAiB;IACnC;;;;;;;;OAQG;IACH,UAAU,eAAgB;IAC1B;;;;;;;;;;;OAWG;IACH,iBAAiB,iBAAkB;IACnC,uFAAuF;IACvF,aAAa,kBAAmB;IAChC;;;;;;;OAOG;IACH,eAAe,oBAAqB;IACpC,6CAA6C;IAC7C,oBAAoB,wBAAyB;IAC7C,4CAA4C;IAC5C,mBAAmB,uBAAwB;IAC3C,4CAA4C;IAC5C,oBAAoB,wBAAyB;IAC7C;;;;;;;;;;OAUG;IACH,sBAAsB,0BAA2B;IACjD,wEAAwE;IACxE,2BAA2B,wBAAyB;IACpD;;;;;OAKG;IACH,wBAAwB,8BAA+B;IACvD;;;;;OAKG;IACH,qBAAqB,6BAA8B;IACnD;;;OAGG;IACH,KAAK,SAAU;IACf;;;;;;;OAOG;IACH,kBAAkB,wBAAyB;IAC3C;;;;;;;OAOG;IACH,sBAAsB,4BAA6B;IACnD;;;;OAIG;IACH,wBAAwB,0BAA2B;IACnD,gDAAgD;IAChD,aAAa,kBAAmB;IAChC;;;;;;;OAOG;IACH,iBAAiB,uBAAwB;IACzC;;;;;;;;;;;;;;OAcG;IACH,sBAAsB,2BAA4B;IAClD,6EAA6E;IAC7E,uBAAuB,0BAA2B;IAClD,+EAA+E;IAC/E,qBAAqB,wBAAyB;IAC9C,qHAAqH;IACrH,iBAAiB,uBAAwB;IAEzC;;;;;;;OAOG;IACH,sBAAsB,mBAAoB;IAC1C;;;;;;;;;;;;OAYG;IACH,cAAc,mBAAoB;IAClC;;;;;;OAMG;IACH,aAAa,kBAAmB;IAChC;;;;;;OAMG;IACH,SAAS,aAAc;IACvB;;;;OAIG;IACH,yBAAyB,sBAAuB;IAChD;;;;OAIG;IACH,0BAA0B,uBAAwB;IAClD;;;;;;;;;;;;;;;OAeG;IACH,uBAAuB,6BAA8B;IACrD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAgDG;IACH,4BAA4B,6BAA8B;EAC3D","sourcesContent":["/**\n * Events that the Agora.io SDK `client.on()` function recognizes.\n *\n * If the API changes faster than the library, a quick type override can help bypass compiler errors:\n *\n * @example\n * this.ngxAgoraService.client.on('new-event' as ClientEvent, (data) => {})\n */\nexport enum ClientEvent {\n  /**\n   * Occurs when the first remote audio frame is decoded.\n   * The SDK triggers this callback when the local client successfully subscribes to a remote stream and decodes the first audio frame.\n   *\n   * @example\n   * client.on('first-audio-frame-decode', function (evt) {\n   *  console.log('first-audio-frame-decode');\n   *  console.log(evt.stream);\n   * })\n   */\n  FirstAudioFrameDecoded = 'first-audio-frame-decode',\n  /**\n   * Occurs when the first remote video frame is decoded.\n   * The SDK triggers this callback when the local client successfully subscribes to a remote stream and decodes the first video frame.\n   *\n   * @example\n   * client.on('first-video-frame-decode', function (evt) {\n   *  console.log('first-video-frame-decode');\n   *  console.log(evt.stream);\n   * })\n   */\n  FirstVideoFrameDecoded = 'first-video-frame-decode',\n  /**\n   * Occurs when the local stream is published.\n   *\n   * @example\n   * client.on(\"stream-published\", function(evt) {\n   *  console.log(\"local stream published\");\n   *  //……\n   * })\n   */\n  LocalStreamPublished = 'stream-published',\n  /**\n   * Occurs when the remote stream is added.\n   *\n   * @remark\n   * When the local user joins the channel, if other users are already in the channel,\n   * the SDK also reports to the app on the existing remote streams.\n   *\n   * @example\n   * client.on(\"stream-added\", function(evt) {\n   *  var stream = evt.stream;\n   *  console.log(\"new stream added \", stream.getId());\n   *  // Subscribe the stream.\n   *  //……\n   * })\n   */\n  RemoteStreamAdded = 'stream-added',\n  /**\n   * Occurs when the remote stream is removed; for example, a peer user calls\n   * [Client.unpublish](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#unpublish).\n   *\n   * @example\n   * client.on(\"stream-removed\", function(evt) {\n   *  var stream = evt.stream;\n   *  console.log(\"remote stream was removed\", stream.getId());\n   *  //……\n   * });\n   */\n  RemoteStreamRemoved = 'stream-removed',\n  /**\n   * Occurs when a user subscribes to a remote stream.\n   *\n   * @example\n   * client.on(\"stream-subscribed\", function(evt) {\n   *  var stream = evt.stream;\n   *  console.log(\"new stream subscribed \", stream.getId());\n   *  // Play the stream.\n   *  //……\n   * })\n   */\n  RemoteStreamSubscribed = 'stream-subscribed',\n  /**\n   * Occurs when the peer user leaves the channel; for example, the peer user calls\n   * [Client.leave](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.client.html#leave).\n   */\n  PeerLeave = 'peer-leave',\n  /**\n   * Occurs when a remote user or host joins the channel.\n   * - Communication channel (rtc mode): This callback notifies the app that another user joins the channel.\n   *   If other users are already in the channel, the SDK also reports to the app on the existing users.\n   * - Live-broadcast channel (live mode): This callback notifies the app that the host joins the channel.\n   *   If other hosts are already in the channel, the SDK also reports to the app on the existing hosts.\n   *   Agora recommends limiting the number of hosts to 17.\n   */\n  PeerOnline = 'peer-online',\n  /**\n   * Occurs when the peer user mutes the audio.\n   *\n   * @example\n   * client.on(\"mute-audio\", function(evt) {\n   *  var uid = evt.uid;\n   *  console.log(\"mute audio:\" + uid);\n   *  //alert(\"mute audio:\" + uid)\n   * });\n   */\n  RemoteAudioMuted = 'mute-audio',\n  /**\n   * Occurs when the peer user unmutes the audio.\n   *\n   * @example\n   * client.on(\"unmute-audio\", function (evt) {\n   *  var uid = evt.uid;\n   *  console.log(\"unmute audio:\" + uid);\n   * });\n   */\n  RemoteAudioUnmuted = 'unmute-audio',\n  /**\n   * Occurs when the peer user turns off the video.\n   *\n   * @example\n   * client.on(\"mute-video\", function (evt) {\n   *  var uid = evt.uid;\n   *  console.log(\"mute video\" + uid);\n   *  //alert(\"mute video:\" + uid);\n   * })\n   */\n  RemoveVideoMuted = 'mute-video',\n  /**\n   * Occurs when the peer user turns on the video.\n   *\n   * @example\n   * client.on(\"unmute-video\", function (evt) {\n   *  var uid = evt.uid;\n   *  console.log(\"unmute video:\" + uid);\n   * })\n   */\n  RemoteVideoUnmuted = 'unmute-video',\n  /**\n   * Occurs when encryption or decryption fails during publishing or subscribing to a stream.\n   * The failure is usually due to a wrong encryption password\n   * ([setEncryptionSecret](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#setencryptionsecret))\n   * or an incorrect encryption\n   * mode ([setEncryptionMode](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#setencryptionmode)).\n   *\n   * @since 3.0.0\n   */\n  CryptError = 'crypt-error',\n  /**\n   * This callback notifies the peer user that he/she is banned from the channel. Only the banned users receive this callback.\n   * Usually the reason is that the UID is banned (`K_UID_BANNED`(14)).\n   *\n   * @example\n   * client.on(\"client-banned\", function (evt) {\n   *  var uid = evt.uid;\n   *  var attr = evt.attr;\n   *  console.log(\" user banned:\" + uid + \", bantype:\" + attr);\n   *  alert(\" user banned:\" + uid + \", bantype:\" + attr);\n   * });\n   */\n  LocalClientBanned = 'client-banned',\n  /** This callback notifies the application who is the active speaker in the channel. */\n  ActiveSpeaker = 'active-speaker',\n  /**\n   * This callback notifies the application of all the speaking remote users and their volumes.\n   *\n   * It is disabled by default. You can enable this event by calling enableAudioVolumeIndicator.\n   * If enabled, it reports the volumes every two seconds regardless of whether there are users speaking.\n   *\n   * The volume is an integer ranging from 0 to 100. Usually a user with volume above five will be countedas a speaking user.\n   */\n  VolumeIndicator = 'volume-indicator',\n  /** Occurs when the live streaming starts. */\n  LiveStreamingStarted = 'liveStreamingStarted',\n  /** Occurs when the live streaming fails. */\n  LiveStreamingFailed = 'liveStreamingFailed',\n  /** Occurs when the live streaming stops. */\n  LiveStreamingStopped = 'liveStreamingStopped',\n  /**\n   * Occurs when the live transcoding setting is updated.\n   *\n   * The SDK triggers this callback when the live transcoding setting is updated by calling the\n   * [setLiveTranscoding](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#setlivetranscoding) method.\n   *\n   * @remark\n   * The first call of the\n   * [setLiveTranscoding](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#setlivetranscoding)\n   * method does not trigger this callback.\n   */\n  LiveTranscodingUpdated = 'liveTranscodingUpdated',\n  /** Occurs when the injected online media stream's status is updated. */\n  StreamInjectedStatusUpdated = 'streamInjectedStatus',\n  /**\n   * Occurs when the Token expires in 30 seconds.\n   *\n   * You should request a new Token from your server and call\n   * [Client.renewToken](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.client.html#renewtoken).\n   */\n  TokenPrivelegeWillExpire = 'onTokenPrivilegeWillExpire',\n  /**\n   * Occurs when the Token expires.\n   *\n   * You should request a new Token from your server and call\n   * [Client.renewToken](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.client.html#renewtoken).\n   */\n  TokenPrivelegeExpired = 'onTokenPrivilegeDidExpire',\n  /**\n   * Occurs when an error message is reported and requires error handling.\n   * For details, @see [Error Codes and Warning Codes](https://docs.agora.io/en/Video/the_error_web).\n   */\n  Error = 'error',\n  /**\n   * Occurs when the network type changes.\n   *\n   * @remark\n   * Chrome 61+ is required for this function, and the compatibility is not guaranteed.\n   *\n   * @see [Network Information API](https://developer.mozilla.org/en-US/docs/Web/API/Network_Information_API) for details.\n   */\n  NetworkTypeChanged = 'network-type-changed',\n  /**\n   * Occurs when an audio input device is added or removed.\n   *\n   * @example\n   * client.on(\"recording-device-changed\", function(evt) {\n   *  console.log(\"Recording Device Changed\", evt.state, evt.device);\n   * });\n   */\n  RecordingDeviceChanged = 'recording-device-changed',\n  /**\n   * Occurs when an audio output device is added or removed.\n   * @remark\n   * Only supports Chrome 49+.\n   */\n  AudioOutputDeviceChanged = 'playout-device-changed',\n  /** Occurs when a camera is added or removed. */\n  CameraChanged = 'camera-changed',\n  /**\n   * Occurs when the type of a video stream changes.\n   * It happens when a high-video stream changes to a low-video stream, or vice versa.\n   *\n   * The stream type (streamType):\n   * - 0: High-bitrate, high-resolution video stream.\n   * - 1: Low-bitrate, low-resolution video stream.\n   */\n  StreamTypeChanged = 'stream-type-changed',\n  /**\n   * Occurs when the network connection state changes.\n   *\n   * The connection between the SDK and Agora's edge server has the following states:\n   *\n   * - DISCONNECTED: The SDK is disconnected from Agora's edge server.\n   *   This is the initial state before Client.join.\n   *   The SDK also enters this state after the app calls Client.leave.\n   * - CONNECTING: The SDK is connecting to Agora's edge server. The SDK enters this state when calling Client.join or\n   *   reconnecting to Agora's edge server automatically after the connection is lost.\n   * - CONNECTED: The SDK is connected to Agora's edge server and joins a channel. You can now publish or subscribe to a stream\n   *   in the channel. If the connection is lost because, for example, the network is down or switched, the SDK triggers this callback\n   *   and notifies the app that the state changes from CONNECTED to CONNECTING.\n   * - DISCONNECTING: The SDK is disconnecting from Agora's edge server. The SDK enters this state when calling Client.leave.\n   */\n  ConnectionStateChanged = 'connection-state-change',\n  /** Occurs when the SDK starts republishing or re-subscribing to a stream. */\n  StreamReconnectionStart = 'stream-reconnect-start',\n  /** Occurs when the SDK finishes republishing or re-subscribing to a stream. */\n  StreamReconnectionEnd = 'stream-reconnect-end',\n  /** Occurs when the user role switches in a live broadcast. For example, from a host to an audience or vice versa. */\n  ClientRoleChanged = 'client-role-changed',\n\n  /**\n   * Reports the network quality of the local user once every two seconds.\n   *\n   * This callback reports on the uplink and downlink network conditions of the local user.\n   *\n   * @remark\n   * This is an experimental feature and the network quality rating is for reference only.\n   */\n  NetworkQualityReported = 'network-quality',\n  /**\n   * Occurs when the remote video stream falls back to an audio-only stream due to unreliable network\n   * conditions or switches back to the video after the network conditions improve.\n   *\n   * If you set `fallbackType` as 2 in\n   * [setStreamFallbackOption](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.client.html#setstreamfallbackoption),\n   * the SDK triggers this callback when the remote media stream falls back to audio only due to unreliable network conditions\n   * or switches back to the video after the network condition improves.\n   *\n   * @remark\n   * Once the remote media stream is switched to the low stream due to unreliable network conditions, you can monitor\n   * the stream switch between a high stream and low stream in the stream-type-changed callback.\n   */\n  StreamFallback = 'stream-fallback',\n  /**\n   * Occurs when a remote stream adds or removes a track.\n   *\n   * When a remote stream calls the [addTrack](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.stream.html#addtrack)\n   * or [removeTrack](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.stream.html#removetrack)\n   * method, the SDK triggers this callback.\n   */\n  StreamUpdated = 'stream-updated',\n  /**\n   * Reports exception events in the channel.\n   * Exceptions are not errors, but usually mean quality issues.\n   * This callback also reports recovery from an exception.\n   * Each exception event has a corresponding recovery event\n   * @see https://web-cdn.agora.io/docs-files/1547180053430 for details\n   */\n  Exception = 'exception',\n  /**\n   * Occurs when a remote user of the Native SDK calls `enableLocalVideo(true)` to enable video capture.\n   *\n   * @since 3.0.0\n   */\n  RemoteVideoCaptureEnabled = 'enable-local-video',\n  /**\n   * Occurs when a remote user of the Native SDK calls `enableLocalVideo(false)` to disable video capture.\n   *\n   * @since 3.0.0\n   */\n  RemoteVideoCaptureDisabled = 'disable-local-video',\n  /**\n   * Reports events during the media stream relay.\n   *\n   * Parameters\n   * - evt: `object`\n   *  - code: `number`\n   *  The event code for media stream relay.\n   *    - 0: The user disconnects from the server due to a poor network connection.\n   *    - 1: The user is connected to the server.\n   *    - 2: The user joins the source channel.\n   *    - 3: The user joins the destination channel.\n   *    - 4: The SDK starts relaying the media stream to the destination channel.\n   *    - 5: The server receives the video stream from the source channel.\n   *    - 6: The server receives the audio stream from the source channel.\n   *    - 7: The destination channel is updated.\n   */\n  MediaStreamEventRelayed = 'channel-media-relay-event',\n  /**\n   * Occurs when the state of the media stream relay changes.\n   *\n   * @since 3.0.0\n   * @description\n   * The SDK reports the state and error code of the current media relay in this callback.\n   *\n   * Parameters\n   * - evt: `object`\n   *  - code: `number`\n   *  The error code.\n   *    - 0: No error.\n   *    - 1: An error occurs in the server response.\n   *    - 2: No server response.\n   *    - 3: The SDK fails to access the service, probably due to limited resources of the server.\n   *    - 4: Fails to send the relay request.\n   *    - 5: Fails to accept the relay request.\n   *    - 6: The server fails to receive the media stream.\n   *    - 7: The server fails to send the media stream.\n   *    - 8: The SDK disconnects from the server and fails to reconnect to the server due to a poor network connection.\n   *         In this case, the SDK resets the relay state. You can try\n   *  [startChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#startchannelmediarelay)\n   *         to restart the media stream relay.\n   *    - 9: An internal error occurs in the server.\n   *    - 10: The token of the source channel has expired.\n   *    - 11: The token of the destination channel has expired.\n   *    - 12: The relay has already started. Possibly caused by calling\n   *  [startChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#startchannelmediarelay)\n   *          repeatedly, or calling\n   *  [startChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#startchannelmediarelay)\n   *          before\n   *  [stopChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#stopchannelmediarelay)\n   *          succeeds.\n   *    - 13: The relay has not started. Possibly caused by calling\n   *  [updateChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#updatechannelmediarelay)\n   *          before\n   *  [startChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#startchannelmediarelay)\n   *          succeeds.\n   *\n   *  - state: `number`\n   *    The state code.\n   *    - 0: The SDK is initializing.\n   *    - 1: The SDK tries to relay the media stream to the destination channel.\n   *    - 2: The SDK successfully relays the media stream to the destination channel.\n   *    - 3: An error occurs. See `code` for the error code. In case of an error, the SDK resets the media stream relay state,\n   *         and you need to call\n   * [startChannelMediaRelay](https://docs.agora.io/en/Voice/API%20Reference/web/interfaces/agorartc.client.html#startchannelmediarelay)\n   *         to restart the relay.\n   */\n  MediaStreamRelayStateChanged = 'channel-media-relay-state',\n}\n"]}