@stream-io/video-react-sdk 0.4.3 → 0.4.4

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@stream-io/video-react-sdk",
3
- "version": "0.4.3",
3
+ "version": "0.4.4",
4
4
  "packageManager": "yarn@3.2.4",
5
5
  "main": "./dist/index.cjs.js",
6
6
  "module": "./dist/index.es.js",
@@ -31,11 +31,10 @@
31
31
  "@floating-ui/react": "^0.22.0",
32
32
  "@nivo/core": "^0.80.0",
33
33
  "@nivo/line": "^0.80.0",
34
- "@stream-io/video-client": "^0.4.1",
35
- "@stream-io/video-react-bindings": "^0.3.1",
34
+ "@stream-io/video-client": "^0.4.2",
35
+ "@stream-io/video-react-bindings": "^0.3.2",
36
36
  "clsx": "^2.0.0",
37
- "prop-types": "^15.8.1",
38
- "rxjs": "~7.8.1"
37
+ "prop-types": "^15.8.1"
39
38
  },
40
39
  "peerDependencies": {
41
40
  "react": "^18.0.0",
@@ -21,7 +21,10 @@ export const ScreenShareButton = (props: ScreenShareButtonProps) => {
21
21
  const { hasPermission, requestPermission, isAwaitingPermission } =
22
22
  useRequestPermission(OwnCapability.SCREENSHARE);
23
23
 
24
- const { screenShare, isMute: isScreenSharing } = useScreenShareState();
24
+ const { screenShare, isMute: amIScreenSharing } = useScreenShareState();
25
+ const disableScreenShareButton = amIScreenSharing
26
+ ? isSomeoneScreenSharing
27
+ : false;
25
28
  return (
26
29
  <Restricted requiredGrants={[OwnCapability.SCREENSHARE]}>
27
30
  <PermissionNotification
@@ -33,9 +36,11 @@ export const ScreenShareButton = (props: ScreenShareButtonProps) => {
33
36
  >
34
37
  <CompositeButton active={isSomeoneScreenSharing} caption={caption}>
35
38
  <IconButton
36
- icon={isScreenSharing ? 'screen-share-on' : 'screen-share-off'}
39
+ icon={
40
+ isSomeoneScreenSharing ? 'screen-share-on' : 'screen-share-off'
41
+ }
37
42
  title={t('Share screen')}
38
- disabled={!isScreenSharing && isSomeoneScreenSharing}
43
+ disabled={disableScreenShareButton}
39
44
  onClick={async () => {
40
45
  if (!hasPermission) {
41
46
  await requestPermission();
@@ -16,22 +16,30 @@ export type LocalDevicePreferences = {
16
16
  * @param key the key to use for local storage.
17
17
  */
18
18
  const usePersistDevicePreferences = (key: string) => {
19
- const { useMicrophoneState, useCameraState, useSpeakerState } =
20
- useCallStateHooks();
19
+ const {
20
+ useMicrophoneState,
21
+ useCameraState,
22
+ useSpeakerState,
23
+ useCallSettings,
24
+ } = useCallStateHooks();
21
25
  const mic = useMicrophoneState();
22
26
  const camera = useCameraState();
23
27
  const speaker = useSpeakerState();
28
+ const settings = useCallSettings();
24
29
  useEffect(() => {
30
+ if (!settings) return;
25
31
  try {
32
+ const hasPreferences = !!window.localStorage.getItem(key);
33
+ const { audio, video } = settings;
26
34
  const defaultDevice = 'default';
27
35
  const preferences: LocalDevicePreferences = {
28
36
  mic: {
29
37
  selectedDeviceId: mic.selectedDevice || defaultDevice,
30
- muted: mic.isMute,
38
+ muted: hasPreferences ? mic.isMute : !audio.mic_default_on,
31
39
  },
32
40
  camera: {
33
41
  selectedDeviceId: camera.selectedDevice || defaultDevice,
34
- muted: camera.isMute,
42
+ muted: hasPreferences ? camera.isMute : !video.camera_default_on,
35
43
  },
36
44
  speaker: {
37
45
  selectedDeviceId: speaker.selectedDevice || defaultDevice,
@@ -48,6 +56,7 @@ const usePersistDevicePreferences = (key: string) => {
48
56
  key,
49
57
  mic.isMute,
50
58
  mic.selectedDevice,
59
+ settings,
51
60
  speaker.selectedDevice,
52
61
  ]);
53
62
  };
@@ -59,8 +68,10 @@ const usePersistDevicePreferences = (key: string) => {
59
68
  */
60
69
  const useApplyDevicePreferences = (key: string) => {
61
70
  const call = useCall();
71
+ const { useCallSettings } = useCallStateHooks();
72
+ const settings = useCallSettings();
62
73
  useEffect(() => {
63
- if (!call) return;
74
+ if (!call || !settings) return;
64
75
 
65
76
  const apply = async () => {
66
77
  const initMic = async (setting: LocalDevicePreference) => {
@@ -85,24 +96,29 @@ const useApplyDevicePreferences = (key: string) => {
85
96
  call.speaker.select(setting.selectedDeviceId);
86
97
  };
87
98
 
99
+ let preferences: LocalDevicePreferences | null = null;
88
100
  try {
89
- const preferences = JSON.parse(
101
+ preferences = JSON.parse(
90
102
  window.localStorage.getItem(key)!,
91
103
  ) as LocalDevicePreferences;
92
- if (preferences) {
93
- await initMic(preferences.mic);
94
- await initCamera(preferences.camera);
95
- initSpeaker(preferences.speaker);
96
- }
97
104
  } catch (err) {
98
105
  console.warn('Failed to load device preferences', err);
99
106
  }
107
+ if (preferences) {
108
+ await initMic(preferences.mic);
109
+ await initCamera(preferences.camera);
110
+ initSpeaker(preferences.speaker);
111
+ } else {
112
+ const { audio, video } = settings;
113
+ if (audio.mic_default_on) await call.microphone.enable();
114
+ if (video.camera_default_on) await call.camera.enable();
115
+ }
100
116
  };
101
117
 
102
118
  apply().catch((err) => {
103
119
  console.warn('Failed to apply device preferences', err);
104
120
  });
105
- }, [call, key]);
121
+ }, [call, key, settings]);
106
122
  };
107
123
 
108
124
  /**