@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/CHANGELOG.md +11 -0
- package/dist/index.cjs.js +33 -14
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.es.js +33 -14
- package/dist/index.es.js.map +1 -1
- package/package.json +4 -5
- package/src/components/CallControls/ScreenShareButton.tsx +8 -3
- package/src/hooks/usePersistedDevicePreferences.ts +28 -12
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@stream-io/video-react-sdk",
|
|
3
|
-
"version": "0.4.
|
|
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.
|
|
35
|
-
"@stream-io/video-react-bindings": "^0.3.
|
|
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:
|
|
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={
|
|
39
|
+
icon={
|
|
40
|
+
isSomeoneScreenSharing ? 'screen-share-on' : 'screen-share-off'
|
|
41
|
+
}
|
|
37
42
|
title={t('Share screen')}
|
|
38
|
-
disabled={
|
|
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 {
|
|
20
|
-
|
|
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
|
-
|
|
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
|
/**
|