@stream-io/video-react-bindings 1.6.7 → 1.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.es.js CHANGED
@@ -19,78 +19,37 @@ const useCall = () => {
19
19
  return useContext(StreamCallContext);
20
20
  };
21
21
 
22
- const DEFAULT_NAMESPACE = 'stream-video';
23
- const DEFAULT_CONFIG = {
24
- debug: false,
25
- currentLanguage: 'en',
26
- fallbackLanguage: false,
27
- };
28
22
  const mapToRegistry = (translationsMap, namespace) => Object.entries(translationsMap).reduce((acc, [lng, translations]) => {
29
23
  acc[lng] = { [namespace]: translations };
30
24
  return acc;
31
25
  }, {});
32
- const DEFAULT_TRANSLATIONS_REGISTRY = mapToRegistry({}, DEFAULT_NAMESPACE);
33
26
  const defaultTranslationFunction = (key) => key;
34
27
  class StreamI18n {
35
- /** Simple logger function */
36
- constructor(options = {}) {
28
+ constructor({ debug = false, currentLanguage = 'en', fallbackLanguage, translationsOverrides = { en: {} }, } = {}) {
37
29
  /** Translator function that converts the provided string into its equivalent in the current language. */
38
30
  this.t = defaultTranslationFunction;
39
31
  this.init = async () => {
40
- try {
41
- this.t = await this.i18nInstance.init();
42
- }
43
- catch (e) {
44
- console.error(`Failed to initialize translations: ${JSON.stringify(e)}`);
45
- }
46
- return this;
47
- };
48
- this.changeLanguage = async (language, onChange) => {
49
- if (!this._checkIsInitialized())
50
- return;
51
- // i18next detects the language, if none provided, but it is better
52
- // to show this detection here explicitly
53
- const browserLanguage = typeof window !== 'undefined' && window.navigator
54
- ? window.navigator.language
55
- : undefined;
56
- await this.i18nInstance.changeLanguage(language || browserLanguage);
57
- onChange?.(this.currentLanguage);
32
+ this.t = await this.i18nInstance.init();
33
+ return this.t;
58
34
  };
59
- this.registerTranslationsForLanguage = ({ lng, translations, }) => {
60
- if (!this._checkIsInitialized())
61
- return;
62
- this.i18nInstance.addResourceBundle(lng, DEFAULT_NAMESPACE, translations, true, true);
35
+ this.changeLanguage = async (language) => {
36
+ this.t = await this.i18nInstance.changeLanguage(language);
37
+ return this.t;
63
38
  };
64
- this._checkIsInitialized = () => {
65
- if (!this.i18nInstance.isInitialized) {
66
- console.warn('I18n instance is not initialized. Call yourStreamI18nInstance.init().');
67
- }
68
- return this.i18nInstance.isInitialized;
69
- };
70
- const { debug = DEFAULT_CONFIG.debug, currentLanguage = DEFAULT_CONFIG.currentLanguage, fallbackLanguage = DEFAULT_CONFIG.fallbackLanguage, translationsOverrides, } = options;
39
+ const ns = 'stream-video';
71
40
  this.i18nInstance = i18next.createInstance({
72
41
  debug,
73
- defaultNS: DEFAULT_NAMESPACE,
42
+ defaultNS: ns,
74
43
  fallbackLng: fallbackLanguage,
75
44
  interpolation: { escapeValue: false },
76
45
  keySeparator: false,
77
46
  lng: currentLanguage,
78
47
  nsSeparator: false,
79
- parseMissingKeyHandler: (key) => {
80
- return key;
81
- },
82
- resources: DEFAULT_TRANSLATIONS_REGISTRY,
48
+ parseMissingKeyHandler: defaultTranslationFunction,
49
+ resources: mapToRegistry(translationsOverrides, ns),
83
50
  });
84
- if (translationsOverrides) {
85
- this.i18nInstance.on('initialized', () => {
86
- Object.entries(translationsOverrides).forEach(([lng, translations]) => {
87
- this.registerTranslationsForLanguage({ lng, translations });
88
- });
89
- });
90
- }
91
51
  }
92
52
  get currentLanguage() {
93
- this._checkIsInitialized();
94
53
  return this.i18nInstance.language;
95
54
  }
96
55
  get isInitialized() {
@@ -102,8 +61,8 @@ const StreamI18nContext = createContext({
102
61
  t: defaultTranslationFunction,
103
62
  });
104
63
  const StreamI18nProvider = ({ children, ...createI18nParams }) => {
105
- const { i18n, t } = useCreateI18n(createI18nParams);
106
- return (jsx(StreamI18nContext.Provider, { value: { t, i18n }, children: children }));
64
+ const api = useCreateI18n(createI18nParams);
65
+ return (jsx(StreamI18nContext.Provider, { value: api, children: children }));
107
66
  };
108
67
  const useCreateI18n = ({ i18nInstance, language, fallbackLanguage, translationsOverrides, }) => {
109
68
  const [i18n] = useState(() => i18nInstance ||
@@ -112,38 +71,37 @@ const useCreateI18n = ({ i18nInstance, language, fallbackLanguage, translationsO
112
71
  fallbackLanguage,
113
72
  translationsOverrides,
114
73
  }));
115
- const [t, setTranslationFn] = useState(() => defaultTranslationFunction);
74
+ const [t, setTranslationFn] = useState(() => i18n.t);
116
75
  useEffect(() => {
117
- const { isInitialized } = i18n;
118
- if (!isInitialized) {
119
- i18n.init().then((_i18n) => setTranslationFn(() => _i18n.i18nInstance.t));
120
- return;
76
+ if (!i18n.isInitialized) {
77
+ i18n.init().then(() => setTranslationFn(() => i18n.t));
121
78
  }
122
- if (language && i18n?.currentLanguage !== language) {
123
- i18n.changeLanguage(language).catch((err) => {
124
- console.log('Error while changing language', err);
125
- });
79
+ else if (i18n.currentLanguage !== language) {
80
+ i18n.changeLanguage(language).then(() => setTranslationFn(() => i18n.t));
126
81
  }
127
- }, [i18n, i18nInstance, language, translationsOverrides]);
128
- return { i18n, t };
82
+ }, [i18n, language]);
83
+ return useMemo(() => ({ i18n, t }), [i18n, t]);
129
84
  };
85
+ /**
86
+ * A hook to get the i18n instance and translation function from the closest provider.
87
+ *
88
+ * Example usage:
89
+ * const { t, i18n } = useI18n();
90
+ * const message = t('hello_world');
91
+ * console.log(message);
92
+ */
130
93
  const useI18n = () => useContext(StreamI18nContext);
131
94
 
132
95
  const StreamVideoContext = createContext(undefined);
133
96
  /**
134
97
  * StreamVideo is a provider component which should be used to wrap the entire application.
135
98
  * It provides the client object to all children components and initializes the i18n instance.
136
- * @param PropsWithChildren<StreamVideoProps>
137
- * @category Client State
138
99
  */
139
100
  const StreamVideoProvider = ({ children, client, i18nInstance, language, translationsOverrides, }) => {
140
101
  return (jsx(StreamVideoContext.Provider, { value: client, children: jsx(StreamI18nProvider, { i18nInstance: i18nInstance, language: language, translationsOverrides: translationsOverrides, children: children }) }));
141
102
  };
142
103
  /**
143
- *
144
- * @returns
145
- *
146
- * @category Client State
104
+ * Hook to access the nearest StreamVideo client instance.
147
105
  */
148
106
  const useStreamVideoClient = () => {
149
107
  return useContext(StreamVideoContext);
@@ -189,8 +147,6 @@ const useObservableValue = (observable$, defaultValue) => {
189
147
  const EMPTY_DEVICES_ARRAY = Object.freeze([]);
190
148
  /**
191
149
  * Utility hook, which provides the current call's state.
192
- *
193
- * @category Call State
194
150
  */
195
151
  const useCallState = () => {
196
152
  const call = useCall();
@@ -206,8 +162,6 @@ const useCallState = () => {
206
162
  };
207
163
  /**
208
164
  * Utility hook which provides information whether the current call is being recorded. It will return `true` if the call is being recorded.
209
- *
210
- * @category Call State
211
165
  */
212
166
  const useIsCallRecordingInProgress = () => {
213
167
  const { recording$ } = useCallState();
@@ -215,8 +169,6 @@ const useIsCallRecordingInProgress = () => {
215
169
  };
216
170
  /**
217
171
  * Utility hook which provides information whether the current call is broadcasting.
218
- *
219
- * @category Call State
220
172
  */
221
173
  const useIsCallHLSBroadcastingInProgress = () => {
222
174
  const { egress$ } = useCallState();
@@ -227,8 +179,6 @@ const useIsCallHLSBroadcastingInProgress = () => {
227
179
  };
228
180
  /**
229
181
  * Utility hook which provides information whether the current call is live.
230
- *
231
- * @category Call State
232
182
  */
233
183
  const useIsCallLive = () => {
234
184
  const { backstage$ } = useCallState();
@@ -329,8 +279,6 @@ const useCallEndedBy = () => {
329
279
  /**
330
280
  * Utility hook which provides a boolean indicating whether there is
331
281
  * a participant in the current call which shares their screen.
332
- *
333
- * @category Call State
334
282
  */
335
283
  const useHasOngoingScreenShare = () => {
336
284
  const { hasOngoingScreenShare$ } = useCallState();
@@ -345,8 +293,6 @@ const useHasOngoingScreenShare = () => {
345
293
  *
346
294
  * Consumers of this observable can implement their own batching logic
347
295
  * in case they want to show historical stats data.
348
- *
349
- * @category Call State
350
296
  */
351
297
  const useCallStatsReport = () => {
352
298
  const { callStatsReport$ } = useCallState();
@@ -354,8 +300,6 @@ const useCallStatsReport = () => {
354
300
  };
355
301
  /**
356
302
  * Utility hook which provides the dominant speaker of the current call.
357
- *
358
- * @category Call State
359
303
  */
360
304
  const useDominantSpeaker = () => {
361
305
  const { dominantSpeaker$ } = useCallState();
@@ -363,8 +307,6 @@ const useDominantSpeaker = () => {
363
307
  };
364
308
  /**
365
309
  * Utility hook which provides a list of call members.
366
- *
367
- * @category Call State
368
310
  */
369
311
  const useCallMembers = () => {
370
312
  const { members$ } = useCallState();
@@ -372,8 +314,6 @@ const useCallMembers = () => {
372
314
  };
373
315
  /**
374
316
  * Utility hook providing the current calling state of the call. For example, `RINGING` or `JOINED`.
375
- *
376
- * @category Call State
377
317
  */
378
318
  const useCallCallingState = () => {
379
319
  const { callingState$ } = useCallState();
@@ -382,8 +322,6 @@ const useCallCallingState = () => {
382
322
  /**
383
323
  * Utility hook providing the actual start time of the current session.
384
324
  * Useful for calculating the call duration.
385
- *
386
- * @category Call State
387
325
  */
388
326
  const useCallStartedAt = () => {
389
327
  const { startedAt$ } = useCallState();
@@ -392,8 +330,6 @@ const useCallStartedAt = () => {
392
330
  /**
393
331
  * A hook which provides a list of all participants that have joined an active call.
394
332
  *
395
- * @category Call State
396
- *
397
333
  * @param options.sortBy - A comparator function to sort the participants by.
398
334
  * Make sure to memoize output of the `combineComparators` function
399
335
  * (or keep it out of component's scope if possible) before passing it down to this property.
@@ -422,8 +358,6 @@ const useRawParticipants = () => {
422
358
  /**
423
359
  * A hook which provides a StreamVideoLocalParticipant object.
424
360
  * It signals that I have joined a call.
425
- *
426
- * @category Call State
427
361
  */
428
362
  const useLocalParticipant = () => {
429
363
  const { localParticipant$ } = useCallState();
@@ -431,8 +365,6 @@ const useLocalParticipant = () => {
431
365
  };
432
366
  /**
433
367
  * A hook which provides a list of all other participants than me that have joined an active call.
434
- *
435
- * @category Call State
436
368
  */
437
369
  const useRemoteParticipants = () => {
438
370
  const { remoteParticipants$ } = useCallState();
@@ -441,8 +373,6 @@ const useRemoteParticipants = () => {
441
373
  /**
442
374
  * Returns the approximate participant count of the active call.
443
375
  * This includes the anonymous users as well, and it is computed on the server.
444
- *
445
- * @category Call State
446
376
  */
447
377
  const useParticipantCount = () => {
448
378
  const { participantCount$ } = useCallState();
@@ -451,8 +381,6 @@ const useParticipantCount = () => {
451
381
  /**
452
382
  * Returns the approximate anonymous participant count of the active call.
453
383
  * The regular participants are not included in this count. It is computed on the server.
454
- *
455
- * @category Call State
456
384
  */
457
385
  const useAnonymousParticipantCount = () => {
458
386
  const { anonymousParticipantCount$ } = useCallState();
@@ -483,9 +411,6 @@ const useHasPermissions = (...permissions) => {
483
411
  };
484
412
  /**
485
413
  * Returns the camera state of the current call.
486
- *
487
- * @category Camera Manager State
488
- *
489
414
  */
490
415
  const useCameraState = () => {
491
416
  const call = useCall();
@@ -512,8 +437,6 @@ const useCameraState = () => {
512
437
  };
513
438
  /**
514
439
  * Returns the microphone state of the current call.
515
- *
516
- * @category Microphone Manager State
517
440
  */
518
441
  const useMicrophoneState = () => {
519
442
  const call = useCall();
@@ -676,8 +599,6 @@ const useStore = () => {
676
599
  * Utility hook which provides a list of all notifications about created calls.
677
600
  * In the ring call settings, these calls can be outgoing (I have called somebody)
678
601
  * or incoming (somebody has called me).
679
- *
680
- * @category Client State
681
602
  */
682
603
  const useCalls = () => {
683
604
  const { calls$ } = useStore();
@@ -685,8 +606,6 @@ const useCalls = () => {
685
606
  };
686
607
  /**
687
608
  * Returns the current connected user.
688
- *
689
- * @category Client State
690
609
  */
691
610
  const useConnectedUser = () => {
692
611
  const { connectedUser$ } = useStore();
@@ -735,8 +654,6 @@ const useToggleCallRecording = () => {
735
654
 
736
655
  /**
737
656
  * A hook-alike function that exposes all call state hooks.
738
- *
739
- * @category Call State
740
657
  */
741
658
  const useCallStateHooks = () => CallStateHooks;
742
659
 
@@ -756,5 +673,5 @@ const Restricted = ({ canRequestOnly, hasPermissionsOnly, requiredGrants, requir
756
673
  return null;
757
674
  };
758
675
 
759
- export { Restricted, StreamCallProvider, StreamI18n, StreamI18nProvider, StreamVideoProvider, defaultTranslationFunction, useCall, useCallStateHooks, useCalls, useConnectedUser, useCreateI18n, useI18n, useObservableValue, useStore, useStreamVideoClient, useToggleCallRecording };
676
+ export { Restricted, StreamCallProvider, StreamI18n, StreamI18nProvider, StreamVideoProvider, defaultTranslationFunction, useCall, useCallStateHooks, useCalls, useConnectedUser, useI18n, useObservableValue, useStore, useStreamVideoClient, useToggleCallRecording };
760
677
  //# sourceMappingURL=index.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.es.js","sources":["../../src/contexts/StreamCallContext.tsx","../../src/i18n/StreamI18n.ts","../../src/contexts/StreamI18nContext.tsx","../../src/contexts/StreamVideoContext.tsx","../../src/helpers/platforms.ts","../../src/hooks/useObservableValue.ts","../../src/hooks/callStateHooks.ts","../../src/hooks/store.ts","../../src/hooks/callUtilHooks.ts","../../src/hooks/index.ts","../../src/wrappers/Restricted.tsx"],"sourcesContent":["import { createContext, PropsWithChildren, useContext } from 'react';\nimport { Call } from '@stream-io/video-client';\n\nconst StreamCallContext = createContext<Call | undefined>(undefined);\n\n/**\n * The props for the StreamCallProvider component.\n */\nexport interface StreamCallProviderProps {\n call?: Call;\n}\n\n/**\n * A provider for the call object.\n */\nexport const StreamCallProvider = (\n props: PropsWithChildren<StreamCallProviderProps>,\n) => {\n const { call, children } = props;\n return (\n <StreamCallContext.Provider value={call}>\n {children}\n </StreamCallContext.Provider>\n );\n};\n\n/**\n * A hook to get the call object from the closest provider.\n */\nexport const useCall = () => {\n return useContext(StreamCallContext);\n};\n","import i18next from 'i18next';\nimport {\n TranslationLanguage,\n TranslationSheet,\n TranslationsMap,\n TranslationsRegistry,\n TranslatorFunction,\n} from './types';\n\nconst DEFAULT_NAMESPACE = 'stream-video';\nconst DEFAULT_CONFIG = {\n debug: false,\n currentLanguage: 'en',\n fallbackLanguage: false,\n} as const;\n\nconst mapToRegistry = (translationsMap: TranslationsMap, namespace: string) =>\n Object.entries(translationsMap).reduce((acc, [lng, translations]) => {\n acc[lng] = { [namespace]: translations };\n return acc;\n }, {} as TranslationsRegistry);\n\nconst DEFAULT_TRANSLATIONS_REGISTRY = mapToRegistry({}, DEFAULT_NAMESPACE);\n\nexport const defaultTranslationFunction = (key: string) => key;\n\nexport type StreamI18nConstructor = {\n /** Language into which the provided strings are translated */\n currentLanguage?: TranslationLanguage;\n /** Fallback language which will be used if no translation is found for current language */\n fallbackLanguage?: TranslationLanguage;\n /** Logs info level to console output. Helps find issues with loading not working. */\n debug?: boolean;\n /** Custom translations that will be merged with the defaults provided by the library. */\n translationsOverrides?: TranslationsMap;\n};\n\nexport class StreamI18n {\n /** Exposed i18n instance from the i18next library */\n i18nInstance;\n /** Translator function that converts the provided string into its equivalent in the current language. */\n t: TranslatorFunction = defaultTranslationFunction;\n /** Simple logger function */\n constructor(options: StreamI18nConstructor = {}) {\n const {\n debug = DEFAULT_CONFIG.debug,\n currentLanguage = DEFAULT_CONFIG.currentLanguage,\n fallbackLanguage = DEFAULT_CONFIG.fallbackLanguage,\n translationsOverrides,\n } = options;\n\n this.i18nInstance = i18next.createInstance({\n debug,\n defaultNS: DEFAULT_NAMESPACE,\n fallbackLng: fallbackLanguage,\n interpolation: { escapeValue: false },\n keySeparator: false,\n lng: currentLanguage,\n nsSeparator: false,\n parseMissingKeyHandler: (key) => {\n return key;\n },\n resources: DEFAULT_TRANSLATIONS_REGISTRY,\n });\n\n if (translationsOverrides) {\n this.i18nInstance.on('initialized', () => {\n Object.entries(translationsOverrides).forEach(([lng, translations]) => {\n this.registerTranslationsForLanguage({ lng, translations });\n });\n });\n }\n }\n\n get currentLanguage() {\n this._checkIsInitialized();\n return this.i18nInstance.language;\n }\n\n get isInitialized() {\n return this.i18nInstance.isInitialized;\n }\n\n init = async () => {\n try {\n this.t = await this.i18nInstance.init();\n } catch (e) {\n console.error(`Failed to initialize translations: ${JSON.stringify(e)}`);\n }\n return this;\n };\n\n changeLanguage = async (\n language?: TranslationLanguage,\n onChange?: (language: TranslationLanguage) => void,\n ) => {\n if (!this._checkIsInitialized()) return;\n // i18next detects the language, if none provided, but it is better\n // to show this detection here explicitly\n const browserLanguage =\n typeof window !== 'undefined' && window.navigator\n ? window.navigator.language\n : undefined;\n await this.i18nInstance.changeLanguage(language || browserLanguage);\n onChange?.(this.currentLanguage);\n };\n\n registerTranslationsForLanguage = ({\n lng,\n translations,\n }: {\n lng: TranslationLanguage;\n translations: TranslationSheet;\n }) => {\n if (!this._checkIsInitialized()) return;\n this.i18nInstance.addResourceBundle(\n lng,\n DEFAULT_NAMESPACE,\n translations,\n true,\n true,\n );\n };\n\n private _checkIsInitialized = () => {\n if (!this.i18nInstance.isInitialized) {\n console.warn(\n 'I18n instance is not initialized. Call yourStreamI18nInstance.init().',\n );\n }\n return this.i18nInstance.isInitialized;\n };\n}\n","import {\n createContext,\n PropsWithChildren,\n useContext,\n useEffect,\n useState,\n} from 'react';\nimport {\n defaultTranslationFunction,\n StreamI18n,\n TranslationsMap,\n} from '../i18n';\n\ntype StreamI18nContextValue = {\n t: StreamI18n['t'];\n i18n?: StreamI18n;\n};\n\nconst StreamI18nContext = createContext<StreamI18nContextValue>({\n t: defaultTranslationFunction,\n});\n\ntype CreateI18nParams = {\n i18nInstance?: StreamI18n;\n language?: string;\n fallbackLanguage?: string;\n translationsOverrides?: TranslationsMap;\n};\n\nexport type StreamI18nProviderProps = CreateI18nParams;\n\nexport const StreamI18nProvider = ({\n children,\n ...createI18nParams\n}: PropsWithChildren<StreamI18nProviderProps>) => {\n const { i18n, t } = useCreateI18n(createI18nParams);\n\n return (\n <StreamI18nContext.Provider value={{ t, i18n }}>\n {children}\n </StreamI18nContext.Provider>\n );\n};\n\nexport const useCreateI18n = ({\n i18nInstance,\n language,\n fallbackLanguage,\n translationsOverrides,\n}: CreateI18nParams) => {\n const [i18n] = useState(\n () =>\n i18nInstance ||\n new StreamI18n({\n currentLanguage: language,\n fallbackLanguage,\n translationsOverrides,\n }),\n );\n const [t, setTranslationFn] = useState<StreamI18n['t']>(\n () => defaultTranslationFunction,\n );\n\n useEffect(() => {\n const { isInitialized } = i18n;\n if (!isInitialized) {\n i18n.init().then((_i18n) => setTranslationFn(() => _i18n.i18nInstance.t));\n return;\n }\n if (language && i18n?.currentLanguage !== language) {\n i18n.changeLanguage(language).catch((err) => {\n console.log('Error while changing language', err);\n });\n }\n }, [i18n, i18nInstance, language, translationsOverrides]);\n\n return { i18n, t };\n};\n\nexport const useI18n = () => useContext(StreamI18nContext);\n","import { createContext, PropsWithChildren, useContext } from 'react';\nimport { StreamVideoClient } from '@stream-io/video-client';\nimport {\n StreamI18nProvider,\n StreamI18nProviderProps,\n} from './StreamI18nContext';\n\nconst StreamVideoContext = createContext<StreamVideoClient | undefined>(\n undefined,\n);\n\n/**\n * Exclude types from documentation site, but we should still add doc comments\n * @internal\n */\nexport type StreamVideoProps = StreamI18nProviderProps & {\n client: StreamVideoClient;\n};\n\n/**\n * StreamVideo is a provider component which should be used to wrap the entire application.\n * It provides the client object to all children components and initializes the i18n instance.\n * @param PropsWithChildren<StreamVideoProps>\n * @category Client State\n */\nexport const StreamVideoProvider = ({\n children,\n client,\n i18nInstance,\n language,\n translationsOverrides,\n}: PropsWithChildren<StreamVideoProps>) => {\n return (\n <StreamVideoContext.Provider value={client}>\n <StreamI18nProvider\n i18nInstance={i18nInstance}\n language={language}\n translationsOverrides={translationsOverrides}\n >\n {children}\n </StreamI18nProvider>\n </StreamVideoContext.Provider>\n );\n};\n\n/**\n *\n * @returns\n *\n * @category Client State\n */\nexport const useStreamVideoClient = () => {\n return useContext(StreamVideoContext);\n};\n","/**\n * Checks whether we are using React Native\n */\nexport const isReactNative = () => {\n if (typeof navigator === 'undefined') return false;\n return navigator.product?.toLowerCase() === 'reactnative';\n};\n","import type { Observable } from 'rxjs';\nimport { useEffect, useState } from 'react';\nimport { RxUtils } from '@stream-io/video-client';\n\n/**\n * Utility hook which provides the current value of the given observable.\n *\n * @param observable$ the observable to read data from.\n * @param defaultValue a default value. Used when the observable data can't be read or emits an error.\n */\nexport const useObservableValue = <T>(\n observable$: Observable<T>,\n defaultValue?: T,\n) => {\n const [value, setValue] = useState<T>(() => {\n try {\n return RxUtils.getCurrentValue(observable$);\n } catch (err) {\n if (typeof defaultValue === 'undefined') throw err;\n return defaultValue;\n }\n });\n\n useEffect(() => {\n return RxUtils.createSubscription(observable$, setValue, (err) => {\n console.log('An error occurred while reading an observable', err);\n if (defaultValue) setValue(defaultValue);\n });\n }, [defaultValue, observable$]);\n\n return value;\n};\n","import {\n Call,\n CallClosedCaption,\n CallIngressResponse,\n CallSessionResponse,\n CallSettingsResponse,\n CallState,\n CallStatsReport,\n Comparator,\n EgressResponse,\n InputDeviceStatus,\n MemberResponse,\n OwnCapability,\n StreamVideoParticipant,\n UserResponse,\n} from '@stream-io/video-client';\nimport { useMemo, useState } from 'react';\nimport { Observable, of } from 'rxjs';\nimport { useCall } from '../contexts';\nimport { isReactNative } from '../helpers/platforms';\nimport { useObservableValue } from './useObservableValue';\n\n// kind-of memoized, used as a default value\nconst EMPTY_DEVICES_ARRAY = Object.freeze<MediaDeviceInfo[]>(\n [],\n) as MediaDeviceInfo[];\n\n/**\n * Utility hook, which provides the current call's state.\n *\n * @category Call State\n */\nexport const useCallState = () => {\n const call = useCall();\n // return an empty and unlinked CallState object if there is no call in the provider\n // this ensures that the hooks always return a value and many null checks can be avoided\n if (!call) {\n const message =\n 'You are using useCallState() outside a Call context. ' +\n 'Please wrap your component in <StreamCall /> and provide a \"call\" instance.';\n console.warn(message);\n return new CallState();\n }\n return call.state;\n};\n\n/**\n * Utility hook which provides information whether the current call is being recorded. It will return `true` if the call is being recorded.\n *\n * @category Call State\n */\nexport const useIsCallRecordingInProgress = (): boolean => {\n const { recording$ } = useCallState();\n return useObservableValue(recording$);\n};\n\n/**\n * Utility hook which provides information whether the current call is broadcasting.\n *\n * @category Call State\n */\nexport const useIsCallHLSBroadcastingInProgress = (): boolean => {\n const { egress$ } = useCallState();\n const egress = useObservableValue(egress$);\n if (!egress) return false;\n return egress.broadcasting;\n};\n\n/**\n * Utility hook which provides information whether the current call is live.\n *\n * @category Call State\n */\nexport const useIsCallLive = (): boolean => {\n const { backstage$ } = useCallState();\n const isBackstageOn = useObservableValue(backstage$);\n return !isBackstageOn;\n};\n\n/**\n * Returns the list of blocked users in the current call.\n */\nexport const useCallBlockedUserIds = (): string[] => {\n const { blockedUserIds$ } = useCallState();\n return useObservableValue(blockedUserIds$);\n};\n\n/**\n * Returns the timestamp when this call was created.\n */\nexport const useCallCreatedAt = (): Date | undefined => {\n const { createdAt$ } = useCallState();\n return useObservableValue(createdAt$);\n};\n\n/**\n * Returns the timestamp when this call was ended.\n */\nexport const useCallEndedAt = (): Date | undefined => {\n const { endedAt$ } = useCallState();\n return useObservableValue(endedAt$);\n};\n\n/**\n * Returns the timestamp telling when the call is scheduled to start.\n */\nexport const useCallStartsAt = (): Date | undefined => {\n const { startsAt$ } = useCallState();\n return useObservableValue(startsAt$);\n};\n\n/**\n * Returns the timestamp when this call was updated.\n */\nexport const useCallUpdatedAt = (): Date | undefined => {\n const { updatedAt$ } = useCallState();\n return useObservableValue(updatedAt$);\n};\n\n/**\n * Returns the information about the call's creator.\n */\nexport const useCallCreatedBy = (): UserResponse | undefined => {\n const { createdBy$ } = useCallState();\n return useObservableValue(createdBy$);\n};\n\n/**\n * Returns the call's custom data.\n */\nexport const useCallCustomData = (): Record<string, any> => {\n const { custom$ } = useCallState();\n return useObservableValue(custom$);\n};\n\n/**\n * Returns the call's Egress information.\n */\nexport const useCallEgress = (): EgressResponse | undefined => {\n const { egress$ } = useCallState();\n return useObservableValue(egress$);\n};\n\n/**\n * Returns the call's Ingress information.\n */\nexport const useCallIngress = (): CallIngressResponse | undefined => {\n const { ingress$ } = useCallState();\n return useObservableValue(ingress$);\n};\n\n/**\n * Returns the data for the current call session.\n */\nexport const useCallSession = (): CallSessionResponse | undefined => {\n const { session$ } = useCallState();\n return useObservableValue(session$);\n};\n\n/**\n * Returns the call's settings.\n */\nexport const useCallSettings = (): CallSettingsResponse | undefined => {\n const { settings$ } = useCallState();\n return useObservableValue(settings$);\n};\n\n/**\n * Returns whether the call has transcribing enabled.\n */\nexport const useIsCallTranscribingInProgress = (): boolean => {\n const { transcribing$ } = useCallState();\n return useObservableValue(transcribing$);\n};\n\n/**\n * Returns information about the user who has marked this call as ended.\n */\nexport const useCallEndedBy = (): UserResponse | undefined => {\n const { endedBy$ } = useCallState();\n return useObservableValue(endedBy$);\n};\n\n/**\n * Utility hook which provides a boolean indicating whether there is\n * a participant in the current call which shares their screen.\n *\n * @category Call State\n */\nexport const useHasOngoingScreenShare = (): boolean => {\n const { hasOngoingScreenShare$ } = useCallState();\n return useObservableValue(hasOngoingScreenShare$);\n};\n\n/**\n * Utility hook which provides the latest stats report of the current call.\n *\n * The latest stats report of the current call.\n * When stats gathering is enabled, this observable will emit a new value\n * at a regular (configurable) interval.\n *\n * Consumers of this observable can implement their own batching logic\n * in case they want to show historical stats data.\n *\n * @category Call State\n */\nexport const useCallStatsReport = (): CallStatsReport | undefined => {\n const { callStatsReport$ } = useCallState();\n return useObservableValue(callStatsReport$);\n};\n\n/**\n * Utility hook which provides the dominant speaker of the current call.\n *\n * @category Call State\n */\nexport const useDominantSpeaker = (): StreamVideoParticipant | undefined => {\n const { dominantSpeaker$ } = useCallState();\n return useObservableValue(dominantSpeaker$);\n};\n\n/**\n * Utility hook which provides a list of call members.\n *\n * @category Call State\n */\nexport const useCallMembers = (): MemberResponse[] => {\n const { members$ } = useCallState();\n return useObservableValue(members$);\n};\n\n/**\n * Utility hook providing the current calling state of the call. For example, `RINGING` or `JOINED`.\n *\n * @category Call State\n */\nexport const useCallCallingState = () => {\n const { callingState$ } = useCallState();\n return useObservableValue(callingState$);\n};\n\n/**\n * Utility hook providing the actual start time of the current session.\n * Useful for calculating the call duration.\n *\n * @category Call State\n */\nexport const useCallStartedAt = () => {\n const { startedAt$ } = useCallState();\n return useObservableValue(startedAt$);\n};\n\n/**\n * A hook which provides a list of all participants that have joined an active call.\n *\n * @category Call State\n *\n * @param options.sortBy - A comparator function to sort the participants by.\n * Make sure to memoize output of the `combineComparators` function\n * (or keep it out of component's scope if possible) before passing it down to this property.\n */\nexport const useParticipants = ({\n sortBy,\n}: {\n /**\n * Make sure to memoize output of the `combineComparators` function\n * (or keep it out of component's scope if possible) before passing it down to this property.\n */\n sortBy?: Comparator<StreamVideoParticipant>;\n} = {}) => {\n const { participants$ } = useCallState();\n const participants = useObservableValue(participants$);\n\n return useMemo(() => {\n if (sortBy) {\n return [...participants].sort(sortBy);\n }\n return participants;\n }, [participants, sortBy]);\n};\n\n/**\n * A hook which provides a list of all participants that have joined an active call.\n * Unlike `useParticipants`, it returns a more stable reference that is not affected\n * by participant sort settings.\n *\n * @category Call State\n */\nexport const useRawParticipants = () => {\n const { rawParticipants$ } = useCallState();\n return useObservableValue(rawParticipants$);\n};\n\n/**\n * A hook which provides a StreamVideoLocalParticipant object.\n * It signals that I have joined a call.\n *\n * @category Call State\n */\nexport const useLocalParticipant = () => {\n const { localParticipant$ } = useCallState();\n return useObservableValue(localParticipant$);\n};\n\n/**\n * A hook which provides a list of all other participants than me that have joined an active call.\n *\n * @category Call State\n */\nexport const useRemoteParticipants = () => {\n const { remoteParticipants$ } = useCallState();\n return useObservableValue(remoteParticipants$);\n};\n\n/**\n * Returns the approximate participant count of the active call.\n * This includes the anonymous users as well, and it is computed on the server.\n *\n * @category Call State\n */\nexport const useParticipantCount = () => {\n const { participantCount$ } = useCallState();\n return useObservableValue(participantCount$);\n};\n\n/**\n * Returns the approximate anonymous participant count of the active call.\n * The regular participants are not included in this count. It is computed on the server.\n *\n * @category Call State\n */\nexport const useAnonymousParticipantCount = () => {\n const { anonymousParticipantCount$ } = useCallState();\n return useObservableValue(anonymousParticipantCount$);\n};\n\n/**\n * Returns the generated thumbnail of the current call, if enabled in settings.\n */\nexport const useCallThumbnail = () => {\n const { thumbnails$ } = useCallState();\n return useObservableValue(thumbnails$);\n};\n\n/**\n * A hook which returns the local participant's own capabilities.\n */\nexport const useOwnCapabilities = (): OwnCapability[] | undefined => {\n const { ownCapabilities$ } = useCallState();\n return useObservableValue(ownCapabilities$);\n};\n\n/**\n * Hook that returns true if the local participant has all the given permissions.\n *\n * @param permissions the permissions to check.\n */\nexport const useHasPermissions = (...permissions: OwnCapability[]): boolean => {\n const capabilities = useOwnCapabilities();\n return permissions.every((permission) => capabilities?.includes(permission));\n};\n\n/**\n * Returns the camera state of the current call.\n *\n * @category Camera Manager State\n *\n */\nexport const useCameraState = () => {\n const call = useCall();\n const { camera } = call as Call;\n\n const { state } = camera;\n const direction = useObservableValue(state.direction$);\n const mediaStream = useObservableValue(state.mediaStream$);\n const selectedDevice = useObservableValue(state.selectedDevice$);\n const { getDevices } = useLazyDeviceList(camera);\n const hasBrowserPermission = useObservableValue(state.hasBrowserPermission$);\n const isPromptingPermission = useObservableValue(\n state.isPromptingPermission$,\n );\n\n return {\n camera,\n direction,\n mediaStream,\n get devices() {\n return getDevices();\n },\n hasBrowserPermission,\n isPromptingPermission,\n selectedDevice,\n ...getComputedStatus(\n useObservableValue(state.status$),\n useObservableValue(state.optimisticStatus$),\n ),\n };\n};\n\n/**\n * Returns the microphone state of the current call.\n *\n * @category Microphone Manager State\n */\nexport const useMicrophoneState = () => {\n const call = useCall();\n const { microphone } = call as Call;\n\n const { state } = microphone;\n const mediaStream = useObservableValue(state.mediaStream$);\n const selectedDevice = useObservableValue(state.selectedDevice$);\n const { getDevices } = useLazyDeviceList(microphone);\n const hasBrowserPermission = useObservableValue(state.hasBrowserPermission$);\n const isPromptingPermission = useObservableValue(\n state.isPromptingPermission$,\n );\n const isSpeakingWhileMuted = useObservableValue(state.speakingWhileMuted$);\n\n return {\n microphone,\n mediaStream,\n get devices() {\n return getDevices();\n },\n selectedDevice,\n hasBrowserPermission,\n isPromptingPermission,\n isSpeakingWhileMuted,\n ...getComputedStatus(\n useObservableValue(state.status$),\n useObservableValue(state.optimisticStatus$),\n ),\n };\n};\n\n/**\n * Returns the speaker state of the current call.\n *\n * Note: This hook is not supported in React Native\n */\nexport const useSpeakerState = () => {\n if (isReactNative()) {\n throw new Error(\n 'This feature is not supported in React Native. Please visit https://getstream.io/video/docs/reactnative/core/camera-and-microphone/#speaker-management for more details',\n );\n }\n const call = useCall();\n const { speaker } = call as Call;\n\n const { getDevices } = useLazyDeviceList(speaker);\n const selectedDevice = useObservableValue(speaker.state.selectedDevice$);\n\n return {\n speaker,\n get devices() {\n return getDevices();\n },\n selectedDevice,\n isDeviceSelectionSupported: speaker.state.isDeviceSelectionSupported,\n };\n};\n\n/**\n * Returns the Screen Share state of the current call.\n */\nexport const useScreenShareState = () => {\n const call = useCall();\n const { screenShare } = call as Call;\n\n return {\n screenShare,\n mediaStream: useObservableValue(screenShare.state.mediaStream$),\n ...getComputedStatus(\n useObservableValue(screenShare.state.status$),\n useObservableValue(screenShare.state.optimisticStatus$),\n ),\n };\n};\n\n/**\n * Returns incoming video settings for the current call, including\n * global and per-participant manual video quality overrides.\n */\nexport const useIncomingVideoSettings = () => {\n const call = useCall() as Call;\n const settings = useObservableValue(\n call.dynascaleManager.incomingVideoSettings$,\n );\n return settings;\n};\n\n/**\n * Returns the current call's closed captions queue.\n */\nexport const useCallClosedCaptions = (): CallClosedCaption[] => {\n const { closedCaptions$ } = useCallState();\n return useObservableValue(closedCaptions$);\n};\n\n/**\n * Returns the current call's closed captions queue.\n */\nexport const useIsCallCaptioningInProgress = (): boolean => {\n const { captioning$ } = useCallState();\n return useObservableValue(captioning$);\n};\n\nfunction getComputedStatus(\n status: InputDeviceStatus,\n pendingStatus: InputDeviceStatus,\n) {\n const optimisticStatus = pendingStatus ?? status;\n\n return {\n status,\n optimisticStatus,\n isEnabled: status === 'enabled',\n isMute: status !== 'enabled',\n optimisticIsMute: optimisticStatus !== 'enabled',\n isTogglePending: optimisticStatus !== status,\n };\n}\n\ninterface DeviceManagerLike {\n listDevices(): Observable<MediaDeviceInfo[]>;\n}\n\nfunction useLazyDeviceList(manager: DeviceManagerLike) {\n const placeholderDevices$ = useMemo(() => of(EMPTY_DEVICES_ARRAY), []);\n const [devices$, setDevices$] = useState(placeholderDevices$);\n const devices = useObservableValue(devices$, EMPTY_DEVICES_ARRAY);\n\n const getDevices = () => {\n if (devices$ === placeholderDevices$) {\n setDevices$(manager.listDevices());\n }\n\n return devices;\n };\n\n return { getDevices };\n}\n","import { useStreamVideoClient } from '../contexts';\nimport { useObservableValue } from './useObservableValue';\n\n/**\n * Utility hook which provides access to client's state store.\n */\nexport const useStore = () => {\n const client = useStreamVideoClient();\n if (!client) {\n throw new Error(\n `StreamVideoClient isn't initialized or this hook is called outside of <StreamVideo> context.`,\n );\n }\n return client.state;\n};\n\n/**\n * Utility hook which provides a list of all notifications about created calls.\n * In the ring call settings, these calls can be outgoing (I have called somebody)\n * or incoming (somebody has called me).\n *\n * @category Client State\n */\nexport const useCalls = () => {\n const { calls$ } = useStore();\n return useObservableValue(calls$);\n};\n\n/**\n * Returns the current connected user.\n *\n * @category Client State\n */\nexport const useConnectedUser = () => {\n const { connectedUser$ } = useStore();\n return useObservableValue(connectedUser$);\n};\n","import { useCallback, useEffect, useState } from 'react';\nimport { useCall } from '../contexts';\nimport { useIsCallRecordingInProgress } from './callStateHooks';\n\n/**\n * Custom hook for toggling call recording in a video call.\n *\n * This hook provides functionality to start and stop call recording,\n * along with state management for tracking the recording status\n * and the loading indicator while awaiting a response.\n */\nexport const useToggleCallRecording = () => {\n const call = useCall();\n const isCallRecordingInProgress = useIsCallRecordingInProgress();\n const [isAwaitingResponse, setIsAwaitingResponse] = useState(false);\n\n // TODO: add permissions\n\n useEffect(() => {\n // we wait until call.recording_started/stopped event to flips the\n // `isCallRecordingInProgress` state variable.\n // Once the flip happens, we remove the loading indicator\n setIsAwaitingResponse((isAwaiting) => {\n if (isAwaiting) return false;\n return isAwaiting;\n });\n }, [isCallRecordingInProgress]);\n\n const toggleCallRecording = useCallback(async () => {\n try {\n setIsAwaitingResponse(true);\n if (isCallRecordingInProgress) {\n await call?.stopRecording();\n } else {\n await call?.startRecording();\n }\n } catch (e) {\n console.error(`Failed start recording`, e);\n throw e;\n }\n }, [call, isCallRecordingInProgress]);\n\n return { toggleCallRecording, isAwaitingResponse, isCallRecordingInProgress };\n};\n","import * as CallStateHooks from './callStateHooks';\n\nexport * from './useObservableValue';\n\nexport * from './store';\nexport * from './callUtilHooks';\n\n/**\n * A hook-alike function that exposes all call state hooks.\n *\n * @category Call State\n */\nexport const useCallStateHooks = () => CallStateHooks;\n","import { OwnCapability } from '@stream-io/video-client';\n\nimport { PropsWithChildren } from 'react';\nimport { useCall } from '../contexts';\nimport { useCallStateHooks } from '../hooks';\n\ntype RestrictedProps = PropsWithChildren<{\n /**\n * Required grants for the component to be able to render supplied children elements\n */\n requiredGrants: OwnCapability[];\n /**\n * Render children only if user can request capability, but does not have it\n */\n canRequestOnly?: boolean;\n /**\n * Render children only if user has capability\n */\n hasPermissionsOnly?: boolean;\n /**\n * Require all grants specified in `requiredGrants` to be available in the `availableGrants`,\n * component by default requires only one grant to appear in both arrays to render its children\n */\n requireAll?: boolean;\n}>;\n\nexport const Restricted = ({\n canRequestOnly,\n hasPermissionsOnly,\n requiredGrants,\n requireAll = true,\n children,\n}: RestrictedProps) => {\n const call = useCall();\n const { useCallSettings, useOwnCapabilities } = useCallStateHooks();\n const ownCapabilities = useOwnCapabilities();\n const settings = useCallSettings();\n const hasPermissions = requiredGrants[requireAll ? 'every' : 'some'](\n (capability) => ownCapabilities?.includes(capability),\n );\n\n if (hasPermissionsOnly) return hasPermissions ? <>{children}</> : null;\n\n const canRequest = requiredGrants.some((capability) =>\n call?.permissionsContext.canRequest(capability, settings),\n );\n\n if (canRequestOnly) return canRequest ? <>{children}</> : null;\n\n if (hasPermissions || canRequest) return <>{children}</>;\n\n return null;\n};\n"],"names":["_jsx","_Fragment"],"mappings":"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"}
1
+ {"version":3,"file":"index.es.js","sources":["../../src/contexts/StreamCallContext.tsx","../../src/i18n/StreamI18n.ts","../../src/contexts/StreamI18nContext.tsx","../../src/contexts/StreamVideoContext.tsx","../../src/helpers/platforms.ts","../../src/hooks/useObservableValue.ts","../../src/hooks/callStateHooks.ts","../../src/hooks/store.ts","../../src/hooks/callUtilHooks.ts","../../src/hooks/index.ts","../../src/wrappers/Restricted.tsx"],"sourcesContent":["import { createContext, PropsWithChildren, useContext } from 'react';\nimport { Call } from '@stream-io/video-client';\n\nconst StreamCallContext = createContext<Call | undefined>(undefined);\n\n/**\n * The props for the StreamCallProvider component.\n */\nexport interface StreamCallProviderProps {\n /**\n * The call instance to provide to the component tree.\n */\n call?: Call;\n}\n\n/**\n * A provider for the call object.\n */\nexport const StreamCallProvider = (\n props: PropsWithChildren<StreamCallProviderProps>,\n) => {\n const { call, children } = props;\n return (\n <StreamCallContext.Provider value={call}>\n {children}\n </StreamCallContext.Provider>\n );\n};\n\n/**\n * A hook to get the call object from the closest provider.\n */\nexport const useCall = () => {\n return useContext(StreamCallContext);\n};\n","import i18next from 'i18next';\nimport {\n TranslationLanguage,\n TranslationsMap,\n TranslationsRegistry,\n TranslatorFunction,\n} from './types';\n\nconst mapToRegistry = (translationsMap: TranslationsMap, namespace: string) =>\n Object.entries(translationsMap).reduce((acc, [lng, translations]) => {\n acc[lng] = { [namespace]: translations };\n return acc;\n }, {} as TranslationsRegistry);\n\nexport const defaultTranslationFunction = (key: string) => key;\n\nexport type StreamI18nConstructor = {\n /** Language into which the provided strings are translated */\n currentLanguage?: TranslationLanguage;\n /** Fallback language which will be used if no translation is found for current language */\n fallbackLanguage?: TranslationLanguage;\n /** Logs info level to console output. Helps find issues with loading not working. */\n debug?: boolean;\n /** Custom translations that will be merged with the defaults provided by the library. */\n translationsOverrides?: TranslationsMap;\n};\n\nexport class StreamI18n {\n /** Exposed i18n instance from the i18next library */\n i18nInstance;\n /** Translator function that converts the provided string into its equivalent in the current language. */\n t: TranslatorFunction = defaultTranslationFunction;\n\n constructor({\n debug = false,\n currentLanguage = 'en',\n fallbackLanguage,\n translationsOverrides = { en: {} },\n }: StreamI18nConstructor = {}) {\n const ns = 'stream-video';\n this.i18nInstance = i18next.createInstance({\n debug,\n defaultNS: ns,\n fallbackLng: fallbackLanguage,\n interpolation: { escapeValue: false },\n keySeparator: false,\n lng: currentLanguage,\n nsSeparator: false,\n parseMissingKeyHandler: defaultTranslationFunction,\n resources: mapToRegistry(translationsOverrides, ns),\n });\n }\n\n get currentLanguage() {\n return this.i18nInstance.language;\n }\n\n get isInitialized() {\n return this.i18nInstance.isInitialized;\n }\n\n init = async () => {\n this.t = await this.i18nInstance.init();\n return this.t;\n };\n\n changeLanguage = async (language?: TranslationLanguage) => {\n this.t = await this.i18nInstance.changeLanguage(language);\n return this.t;\n };\n}\n","import {\n createContext,\n PropsWithChildren,\n useContext,\n useEffect,\n useMemo,\n useState,\n} from 'react';\nimport {\n defaultTranslationFunction,\n StreamI18n,\n TranslationLanguage,\n TranslationsMap,\n} from '../i18n';\n\ntype StreamI18nContextValue = {\n t: StreamI18n['t'];\n i18n?: StreamI18n;\n};\n\nconst StreamI18nContext = createContext<StreamI18nContextValue>({\n t: defaultTranslationFunction,\n});\n\ntype CreateI18nParams = {\n i18nInstance?: StreamI18n;\n language?: TranslationLanguage;\n fallbackLanguage?: TranslationLanguage;\n translationsOverrides?: TranslationsMap;\n};\n\nexport type StreamI18nProviderProps = CreateI18nParams;\n\nexport const StreamI18nProvider = ({\n children,\n ...createI18nParams\n}: PropsWithChildren<StreamI18nProviderProps>) => {\n const api = useCreateI18n(createI18nParams);\n return (\n <StreamI18nContext.Provider value={api}>\n {children}\n </StreamI18nContext.Provider>\n );\n};\n\nconst useCreateI18n = ({\n i18nInstance,\n language,\n fallbackLanguage,\n translationsOverrides,\n}: CreateI18nParams) => {\n const [i18n] = useState(\n () =>\n i18nInstance ||\n new StreamI18n({\n currentLanguage: language,\n fallbackLanguage,\n translationsOverrides,\n }),\n );\n const [t, setTranslationFn] = useState<StreamI18n['t']>(() => i18n.t);\n useEffect(() => {\n if (!i18n.isInitialized) {\n i18n.init().then(() => setTranslationFn(() => i18n.t));\n } else if (i18n.currentLanguage !== language) {\n i18n.changeLanguage(language).then(() => setTranslationFn(() => i18n.t));\n }\n }, [i18n, language]);\n\n return useMemo(() => ({ i18n, t }), [i18n, t]);\n};\n\n/**\n * A hook to get the i18n instance and translation function from the closest provider.\n *\n * Example usage:\n * const { t, i18n } = useI18n();\n * const message = t('hello_world');\n * console.log(message);\n */\nexport const useI18n = () => useContext(StreamI18nContext);\n","import { createContext, PropsWithChildren, useContext } from 'react';\nimport { StreamVideoClient } from '@stream-io/video-client';\nimport {\n StreamI18nProvider,\n StreamI18nProviderProps,\n} from './StreamI18nContext';\n\nconst StreamVideoContext = createContext<StreamVideoClient | undefined>(\n undefined,\n);\n\n/**\n * The props for the StreamVideoProvider component.\n */\nexport type StreamVideoProps = StreamI18nProviderProps & {\n /**\n * The client instance to provide to the component tree.\n */\n client: StreamVideoClient;\n};\n\n/**\n * StreamVideo is a provider component which should be used to wrap the entire application.\n * It provides the client object to all children components and initializes the i18n instance.\n */\nexport const StreamVideoProvider = ({\n children,\n client,\n i18nInstance,\n language,\n translationsOverrides,\n}: PropsWithChildren<StreamVideoProps>) => {\n return (\n <StreamVideoContext.Provider value={client}>\n <StreamI18nProvider\n i18nInstance={i18nInstance}\n language={language}\n translationsOverrides={translationsOverrides}\n >\n {children}\n </StreamI18nProvider>\n </StreamVideoContext.Provider>\n );\n};\n\n/**\n * Hook to access the nearest StreamVideo client instance.\n */\nexport const useStreamVideoClient = () => {\n return useContext(StreamVideoContext);\n};\n","/**\n * Checks whether we are using React Native\n */\nexport const isReactNative = () => {\n if (typeof navigator === 'undefined') return false;\n return navigator.product?.toLowerCase() === 'reactnative';\n};\n","import type { Observable } from 'rxjs';\nimport { useEffect, useState } from 'react';\nimport { RxUtils } from '@stream-io/video-client';\n\n/**\n * Utility hook which provides the current value of the given observable.\n *\n * @param observable$ the observable to read data from.\n * @param defaultValue a default value. Used when the observable data can't be read or emits an error.\n */\nexport const useObservableValue = <T>(\n observable$: Observable<T>,\n defaultValue?: T,\n) => {\n const [value, setValue] = useState<T>(() => {\n try {\n return RxUtils.getCurrentValue(observable$);\n } catch (err) {\n if (typeof defaultValue === 'undefined') throw err;\n return defaultValue;\n }\n });\n\n useEffect(() => {\n return RxUtils.createSubscription(observable$, setValue, (err) => {\n console.log('An error occurred while reading an observable', err);\n if (defaultValue) setValue(defaultValue);\n });\n }, [defaultValue, observable$]);\n\n return value;\n};\n","import {\n Call,\n CallClosedCaption,\n CallIngressResponse,\n CallSessionResponse,\n CallSettingsResponse,\n CallState,\n CallStatsReport,\n Comparator,\n EgressResponse,\n InputDeviceStatus,\n MemberResponse,\n OwnCapability,\n StreamVideoParticipant,\n UserResponse,\n} from '@stream-io/video-client';\nimport { useMemo, useState } from 'react';\nimport { Observable, of } from 'rxjs';\nimport { useCall } from '../contexts';\nimport { isReactNative } from '../helpers/platforms';\nimport { useObservableValue } from './useObservableValue';\n\n// kind-of memoized, used as a default value\nconst EMPTY_DEVICES_ARRAY = Object.freeze<MediaDeviceInfo[]>(\n [],\n) as MediaDeviceInfo[];\n\n/**\n * Utility hook, which provides the current call's state.\n */\nexport const useCallState = () => {\n const call = useCall();\n // return an empty and unlinked CallState object if there is no call in the provider\n // this ensures that the hooks always return a value and many null checks can be avoided\n if (!call) {\n const message =\n 'You are using useCallState() outside a Call context. ' +\n 'Please wrap your component in <StreamCall /> and provide a \"call\" instance.';\n console.warn(message);\n return new CallState();\n }\n return call.state;\n};\n\n/**\n * Utility hook which provides information whether the current call is being recorded. It will return `true` if the call is being recorded.\n */\nexport const useIsCallRecordingInProgress = (): boolean => {\n const { recording$ } = useCallState();\n return useObservableValue(recording$);\n};\n\n/**\n * Utility hook which provides information whether the current call is broadcasting.\n */\nexport const useIsCallHLSBroadcastingInProgress = (): boolean => {\n const { egress$ } = useCallState();\n const egress = useObservableValue(egress$);\n if (!egress) return false;\n return egress.broadcasting;\n};\n\n/**\n * Utility hook which provides information whether the current call is live.\n */\nexport const useIsCallLive = (): boolean => {\n const { backstage$ } = useCallState();\n const isBackstageOn = useObservableValue(backstage$);\n return !isBackstageOn;\n};\n\n/**\n * Returns the list of blocked users in the current call.\n */\nexport const useCallBlockedUserIds = (): string[] => {\n const { blockedUserIds$ } = useCallState();\n return useObservableValue(blockedUserIds$);\n};\n\n/**\n * Returns the timestamp when this call was created.\n */\nexport const useCallCreatedAt = (): Date | undefined => {\n const { createdAt$ } = useCallState();\n return useObservableValue(createdAt$);\n};\n\n/**\n * Returns the timestamp when this call was ended.\n */\nexport const useCallEndedAt = (): Date | undefined => {\n const { endedAt$ } = useCallState();\n return useObservableValue(endedAt$);\n};\n\n/**\n * Returns the timestamp telling when the call is scheduled to start.\n */\nexport const useCallStartsAt = (): Date | undefined => {\n const { startsAt$ } = useCallState();\n return useObservableValue(startsAt$);\n};\n\n/**\n * Returns the timestamp when this call was updated.\n */\nexport const useCallUpdatedAt = (): Date | undefined => {\n const { updatedAt$ } = useCallState();\n return useObservableValue(updatedAt$);\n};\n\n/**\n * Returns the information about the call's creator.\n */\nexport const useCallCreatedBy = (): UserResponse | undefined => {\n const { createdBy$ } = useCallState();\n return useObservableValue(createdBy$);\n};\n\n/**\n * Returns the call's custom data.\n */\nexport const useCallCustomData = (): Record<string, any> => {\n const { custom$ } = useCallState();\n return useObservableValue(custom$);\n};\n\n/**\n * Returns the call's Egress information.\n */\nexport const useCallEgress = (): EgressResponse | undefined => {\n const { egress$ } = useCallState();\n return useObservableValue(egress$);\n};\n\n/**\n * Returns the call's Ingress information.\n */\nexport const useCallIngress = (): CallIngressResponse | undefined => {\n const { ingress$ } = useCallState();\n return useObservableValue(ingress$);\n};\n\n/**\n * Returns the data for the current call session.\n */\nexport const useCallSession = (): CallSessionResponse | undefined => {\n const { session$ } = useCallState();\n return useObservableValue(session$);\n};\n\n/**\n * Returns the call's settings.\n */\nexport const useCallSettings = (): CallSettingsResponse | undefined => {\n const { settings$ } = useCallState();\n return useObservableValue(settings$);\n};\n\n/**\n * Returns whether the call has transcribing enabled.\n */\nexport const useIsCallTranscribingInProgress = (): boolean => {\n const { transcribing$ } = useCallState();\n return useObservableValue(transcribing$);\n};\n\n/**\n * Returns information about the user who has marked this call as ended.\n */\nexport const useCallEndedBy = (): UserResponse | undefined => {\n const { endedBy$ } = useCallState();\n return useObservableValue(endedBy$);\n};\n\n/**\n * Utility hook which provides a boolean indicating whether there is\n * a participant in the current call which shares their screen.\n */\nexport const useHasOngoingScreenShare = (): boolean => {\n const { hasOngoingScreenShare$ } = useCallState();\n return useObservableValue(hasOngoingScreenShare$);\n};\n\n/**\n * Utility hook which provides the latest stats report of the current call.\n *\n * The latest stats report of the current call.\n * When stats gathering is enabled, this observable will emit a new value\n * at a regular (configurable) interval.\n *\n * Consumers of this observable can implement their own batching logic\n * in case they want to show historical stats data.\n */\nexport const useCallStatsReport = (): CallStatsReport | undefined => {\n const { callStatsReport$ } = useCallState();\n return useObservableValue(callStatsReport$);\n};\n\n/**\n * Utility hook which provides the dominant speaker of the current call.\n */\nexport const useDominantSpeaker = (): StreamVideoParticipant | undefined => {\n const { dominantSpeaker$ } = useCallState();\n return useObservableValue(dominantSpeaker$);\n};\n\n/**\n * Utility hook which provides a list of call members.\n */\nexport const useCallMembers = (): MemberResponse[] => {\n const { members$ } = useCallState();\n return useObservableValue(members$);\n};\n\n/**\n * Utility hook providing the current calling state of the call. For example, `RINGING` or `JOINED`.\n */\nexport const useCallCallingState = () => {\n const { callingState$ } = useCallState();\n return useObservableValue(callingState$);\n};\n\n/**\n * Utility hook providing the actual start time of the current session.\n * Useful for calculating the call duration.\n */\nexport const useCallStartedAt = () => {\n const { startedAt$ } = useCallState();\n return useObservableValue(startedAt$);\n};\n\n/**\n * A hook which provides a list of all participants that have joined an active call.\n *\n * @param options.sortBy - A comparator function to sort the participants by.\n * Make sure to memoize output of the `combineComparators` function\n * (or keep it out of component's scope if possible) before passing it down to this property.\n */\nexport const useParticipants = ({\n sortBy,\n}: {\n /**\n * Make sure to memoize output of the `combineComparators` function\n * (or keep it out of component's scope if possible) before passing it down to this property.\n */\n sortBy?: Comparator<StreamVideoParticipant>;\n} = {}) => {\n const { participants$ } = useCallState();\n const participants = useObservableValue(participants$);\n\n return useMemo(() => {\n if (sortBy) {\n return [...participants].sort(sortBy);\n }\n return participants;\n }, [participants, sortBy]);\n};\n\n/**\n * A hook which provides a list of all participants that have joined an active call.\n * Unlike `useParticipants`, it returns a more stable reference that is not affected\n * by participant sort settings.\n *\n * @category Call State\n */\nexport const useRawParticipants = () => {\n const { rawParticipants$ } = useCallState();\n return useObservableValue(rawParticipants$);\n};\n\n/**\n * A hook which provides a StreamVideoLocalParticipant object.\n * It signals that I have joined a call.\n */\nexport const useLocalParticipant = () => {\n const { localParticipant$ } = useCallState();\n return useObservableValue(localParticipant$);\n};\n\n/**\n * A hook which provides a list of all other participants than me that have joined an active call.\n */\nexport const useRemoteParticipants = () => {\n const { remoteParticipants$ } = useCallState();\n return useObservableValue(remoteParticipants$);\n};\n\n/**\n * Returns the approximate participant count of the active call.\n * This includes the anonymous users as well, and it is computed on the server.\n */\nexport const useParticipantCount = () => {\n const { participantCount$ } = useCallState();\n return useObservableValue(participantCount$);\n};\n\n/**\n * Returns the approximate anonymous participant count of the active call.\n * The regular participants are not included in this count. It is computed on the server.\n */\nexport const useAnonymousParticipantCount = () => {\n const { anonymousParticipantCount$ } = useCallState();\n return useObservableValue(anonymousParticipantCount$);\n};\n\n/**\n * Returns the generated thumbnail of the current call, if enabled in settings.\n */\nexport const useCallThumbnail = () => {\n const { thumbnails$ } = useCallState();\n return useObservableValue(thumbnails$);\n};\n\n/**\n * A hook which returns the local participant's own capabilities.\n */\nexport const useOwnCapabilities = (): OwnCapability[] | undefined => {\n const { ownCapabilities$ } = useCallState();\n return useObservableValue(ownCapabilities$);\n};\n\n/**\n * Hook that returns true if the local participant has all the given permissions.\n *\n * @param permissions the permissions to check.\n */\nexport const useHasPermissions = (...permissions: OwnCapability[]): boolean => {\n const capabilities = useOwnCapabilities();\n return permissions.every((permission) => capabilities?.includes(permission));\n};\n\n/**\n * Returns the camera state of the current call.\n */\nexport const useCameraState = () => {\n const call = useCall();\n const { camera } = call as Call;\n\n const { state } = camera;\n const direction = useObservableValue(state.direction$);\n const mediaStream = useObservableValue(state.mediaStream$);\n const selectedDevice = useObservableValue(state.selectedDevice$);\n const { getDevices } = useLazyDeviceList(camera);\n const hasBrowserPermission = useObservableValue(state.hasBrowserPermission$);\n const isPromptingPermission = useObservableValue(\n state.isPromptingPermission$,\n );\n\n return {\n camera,\n direction,\n mediaStream,\n get devices() {\n return getDevices();\n },\n hasBrowserPermission,\n isPromptingPermission,\n selectedDevice,\n ...getComputedStatus(\n useObservableValue(state.status$),\n useObservableValue(state.optimisticStatus$),\n ),\n };\n};\n\n/**\n * Returns the microphone state of the current call.\n */\nexport const useMicrophoneState = () => {\n const call = useCall();\n const { microphone } = call as Call;\n\n const { state } = microphone;\n const mediaStream = useObservableValue(state.mediaStream$);\n const selectedDevice = useObservableValue(state.selectedDevice$);\n const { getDevices } = useLazyDeviceList(microphone);\n const hasBrowserPermission = useObservableValue(state.hasBrowserPermission$);\n const isPromptingPermission = useObservableValue(\n state.isPromptingPermission$,\n );\n const isSpeakingWhileMuted = useObservableValue(state.speakingWhileMuted$);\n\n return {\n microphone,\n mediaStream,\n get devices() {\n return getDevices();\n },\n selectedDevice,\n hasBrowserPermission,\n isPromptingPermission,\n isSpeakingWhileMuted,\n ...getComputedStatus(\n useObservableValue(state.status$),\n useObservableValue(state.optimisticStatus$),\n ),\n };\n};\n\n/**\n * Returns the speaker state of the current call.\n *\n * Note: This hook is not supported in React Native\n */\nexport const useSpeakerState = () => {\n if (isReactNative()) {\n throw new Error(\n 'This feature is not supported in React Native. Please visit https://getstream.io/video/docs/reactnative/core/camera-and-microphone/#speaker-management for more details',\n );\n }\n const call = useCall();\n const { speaker } = call as Call;\n\n const { getDevices } = useLazyDeviceList(speaker);\n const selectedDevice = useObservableValue(speaker.state.selectedDevice$);\n\n return {\n speaker,\n get devices() {\n return getDevices();\n },\n selectedDevice,\n isDeviceSelectionSupported: speaker.state.isDeviceSelectionSupported,\n };\n};\n\n/**\n * Returns the Screen Share state of the current call.\n */\nexport const useScreenShareState = () => {\n const call = useCall();\n const { screenShare } = call as Call;\n\n return {\n screenShare,\n mediaStream: useObservableValue(screenShare.state.mediaStream$),\n ...getComputedStatus(\n useObservableValue(screenShare.state.status$),\n useObservableValue(screenShare.state.optimisticStatus$),\n ),\n };\n};\n\n/**\n * Returns incoming video settings for the current call, including\n * global and per-participant manual video quality overrides.\n */\nexport const useIncomingVideoSettings = () => {\n const call = useCall() as Call;\n const settings = useObservableValue(\n call.dynascaleManager.incomingVideoSettings$,\n );\n return settings;\n};\n\n/**\n * Returns the current call's closed captions queue.\n */\nexport const useCallClosedCaptions = (): CallClosedCaption[] => {\n const { closedCaptions$ } = useCallState();\n return useObservableValue(closedCaptions$);\n};\n\n/**\n * Returns the current call's closed captions queue.\n */\nexport const useIsCallCaptioningInProgress = (): boolean => {\n const { captioning$ } = useCallState();\n return useObservableValue(captioning$);\n};\n\nfunction getComputedStatus(\n status: InputDeviceStatus,\n pendingStatus: InputDeviceStatus,\n) {\n const optimisticStatus = pendingStatus ?? status;\n\n return {\n status,\n optimisticStatus,\n isEnabled: status === 'enabled',\n isMute: status !== 'enabled',\n optimisticIsMute: optimisticStatus !== 'enabled',\n isTogglePending: optimisticStatus !== status,\n };\n}\n\ninterface DeviceManagerLike {\n listDevices(): Observable<MediaDeviceInfo[]>;\n}\n\nfunction useLazyDeviceList(manager: DeviceManagerLike) {\n const placeholderDevices$ = useMemo(() => of(EMPTY_DEVICES_ARRAY), []);\n const [devices$, setDevices$] = useState(placeholderDevices$);\n const devices = useObservableValue(devices$, EMPTY_DEVICES_ARRAY);\n\n const getDevices = () => {\n if (devices$ === placeholderDevices$) {\n setDevices$(manager.listDevices());\n }\n\n return devices;\n };\n\n return { getDevices };\n}\n","import { useStreamVideoClient } from '../contexts';\nimport { useObservableValue } from './useObservableValue';\n\n/**\n * Utility hook which provides access to client's state store.\n */\nexport const useStore = () => {\n const client = useStreamVideoClient();\n if (!client) {\n throw new Error(\n `StreamVideoClient isn't initialized or this hook is called outside of <StreamVideo> context.`,\n );\n }\n return client.state;\n};\n\n/**\n * Utility hook which provides a list of all notifications about created calls.\n * In the ring call settings, these calls can be outgoing (I have called somebody)\n * or incoming (somebody has called me).\n */\nexport const useCalls = () => {\n const { calls$ } = useStore();\n return useObservableValue(calls$);\n};\n\n/**\n * Returns the current connected user.\n */\nexport const useConnectedUser = () => {\n const { connectedUser$ } = useStore();\n return useObservableValue(connectedUser$);\n};\n","import { useCallback, useEffect, useState } from 'react';\nimport { useCall } from '../contexts';\nimport { useIsCallRecordingInProgress } from './callStateHooks';\n\n/**\n * Custom hook for toggling call recording in a video call.\n *\n * This hook provides functionality to start and stop call recording,\n * along with state management for tracking the recording status\n * and the loading indicator while awaiting a response.\n */\nexport const useToggleCallRecording = () => {\n const call = useCall();\n const isCallRecordingInProgress = useIsCallRecordingInProgress();\n const [isAwaitingResponse, setIsAwaitingResponse] = useState(false);\n\n // TODO: add permissions\n\n useEffect(() => {\n // we wait until call.recording_started/stopped event to flips the\n // `isCallRecordingInProgress` state variable.\n // Once the flip happens, we remove the loading indicator\n setIsAwaitingResponse((isAwaiting) => {\n if (isAwaiting) return false;\n return isAwaiting;\n });\n }, [isCallRecordingInProgress]);\n\n const toggleCallRecording = useCallback(async () => {\n try {\n setIsAwaitingResponse(true);\n if (isCallRecordingInProgress) {\n await call?.stopRecording();\n } else {\n await call?.startRecording();\n }\n } catch (e) {\n console.error(`Failed start recording`, e);\n throw e;\n }\n }, [call, isCallRecordingInProgress]);\n\n return { toggleCallRecording, isAwaitingResponse, isCallRecordingInProgress };\n};\n","import * as CallStateHooks from './callStateHooks';\n\nexport * from './useObservableValue';\n\nexport * from './store';\nexport * from './callUtilHooks';\n\n/**\n * A hook-alike function that exposes all call state hooks.\n */\nexport const useCallStateHooks = () => CallStateHooks;\n","import { OwnCapability } from '@stream-io/video-client';\n\nimport { PropsWithChildren } from 'react';\nimport { useCall } from '../contexts';\nimport { useCallStateHooks } from '../hooks';\n\ntype RestrictedProps = PropsWithChildren<{\n /**\n * Required grants for the component to be able to render supplied children elements\n */\n requiredGrants: OwnCapability[];\n /**\n * Render children only if user can request capability, but does not have it\n */\n canRequestOnly?: boolean;\n /**\n * Render children only if user has capability\n */\n hasPermissionsOnly?: boolean;\n /**\n * Require all grants specified in `requiredGrants` to be available in the `availableGrants`,\n * component by default requires only one grant to appear in both arrays to render its children\n */\n requireAll?: boolean;\n}>;\n\nexport const Restricted = ({\n canRequestOnly,\n hasPermissionsOnly,\n requiredGrants,\n requireAll = true,\n children,\n}: RestrictedProps) => {\n const call = useCall();\n const { useCallSettings, useOwnCapabilities } = useCallStateHooks();\n const ownCapabilities = useOwnCapabilities();\n const settings = useCallSettings();\n const hasPermissions = requiredGrants[requireAll ? 'every' : 'some'](\n (capability) => ownCapabilities?.includes(capability),\n );\n\n if (hasPermissionsOnly) return hasPermissions ? <>{children}</> : null;\n\n const canRequest = requiredGrants.some((capability) =>\n call?.permissionsContext.canRequest(capability, settings),\n );\n\n if (canRequestOnly) return canRequest ? <>{children}</> : null;\n\n if (hasPermissions || canRequest) return <>{children}</>;\n\n return null;\n};\n"],"names":["_jsx","_Fragment"],"mappings":"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"}
@@ -4,6 +4,9 @@ import { Call } from '@stream-io/video-client';
4
4
  * The props for the StreamCallProvider component.
5
5
  */
6
6
  export interface StreamCallProviderProps {
7
+ /**
8
+ * The call instance to provide to the component tree.
9
+ */
7
10
  call?: Call;
8
11
  }
9
12
  /**
@@ -1,20 +1,24 @@
1
1
  import { PropsWithChildren } from 'react';
2
- import { StreamI18n, TranslationsMap } from '../i18n';
2
+ import { StreamI18n, TranslationLanguage, TranslationsMap } from '../i18n';
3
3
  type StreamI18nContextValue = {
4
4
  t: StreamI18n['t'];
5
5
  i18n?: StreamI18n;
6
6
  };
7
7
  type CreateI18nParams = {
8
8
  i18nInstance?: StreamI18n;
9
- language?: string;
10
- fallbackLanguage?: string;
9
+ language?: TranslationLanguage;
10
+ fallbackLanguage?: TranslationLanguage;
11
11
  translationsOverrides?: TranslationsMap;
12
12
  };
13
13
  export type StreamI18nProviderProps = CreateI18nParams;
14
14
  export declare const StreamI18nProvider: ({ children, ...createI18nParams }: PropsWithChildren<StreamI18nProviderProps>) => import("react/jsx-runtime").JSX.Element;
15
- export declare const useCreateI18n: ({ i18nInstance, language, fallbackLanguage, translationsOverrides, }: CreateI18nParams) => {
16
- i18n: StreamI18n;
17
- t: import("../i18n").TranslatorFunction;
18
- };
15
+ /**
16
+ * A hook to get the i18n instance and translation function from the closest provider.
17
+ *
18
+ * Example usage:
19
+ * const { t, i18n } = useI18n();
20
+ * const message = t('hello_world');
21
+ * console.log(message);
22
+ */
19
23
  export declare const useI18n: () => StreamI18nContextValue;
20
24
  export {};
@@ -2,23 +2,20 @@ import { PropsWithChildren } from 'react';
2
2
  import { StreamVideoClient } from '@stream-io/video-client';
3
3
  import { StreamI18nProviderProps } from './StreamI18nContext';
4
4
  /**
5
- * Exclude types from documentation site, but we should still add doc comments
6
- * @internal
5
+ * The props for the StreamVideoProvider component.
7
6
  */
8
7
  export type StreamVideoProps = StreamI18nProviderProps & {
8
+ /**
9
+ * The client instance to provide to the component tree.
10
+ */
9
11
  client: StreamVideoClient;
10
12
  };
11
13
  /**
12
14
  * StreamVideo is a provider component which should be used to wrap the entire application.
13
15
  * It provides the client object to all children components and initializes the i18n instance.
14
- * @param PropsWithChildren<StreamVideoProps>
15
- * @category Client State
16
16
  */
17
17
  export declare const StreamVideoProvider: ({ children, client, i18nInstance, language, translationsOverrides, }: PropsWithChildren<StreamVideoProps>) => import("react/jsx-runtime").JSX.Element;
18
18
  /**
19
- *
20
- * @returns
21
- *
22
- * @category Client State
19
+ * Hook to access the nearest StreamVideo client instance.
23
20
  */
24
21
  export declare const useStreamVideoClient: () => StreamVideoClient | undefined;