@stream-io/video-react-native-sdk 1.29.3 → 1.29.4-beta.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/android/src/main/AndroidManifest.xml +8 -1
- package/android/src/main/AndroidManifestNew.xml +11 -0
- package/android/src/main/java/com/streamvideo/reactnative/StreamVideoReactNativeModule.kt +42 -5
- package/android/src/main/java/com/streamvideo/reactnative/audio/utils/WebRtcAudioUtils.kt +70 -6
- package/android/src/main/java/com/streamvideo/reactnative/callmanager/StreamInCallManagerModule.kt +6 -4
- package/android/src/main/java/com/streamvideo/reactnative/keepalive/KeepAliveNotification.kt +83 -0
- package/android/src/main/java/com/streamvideo/reactnative/keepalive/StreamCallKeepAliveHeadlessService.kt +149 -0
- package/dist/commonjs/hooks/push/index.js +0 -2
- package/dist/commonjs/hooks/push/index.js.map +1 -1
- package/dist/commonjs/hooks/push/useCallingExpWithCallingStateEffect.js +121 -0
- package/dist/commonjs/hooks/push/useCallingExpWithCallingStateEffect.js.map +1 -0
- package/dist/commonjs/hooks/push/useIosVoipPushEventsSetupEffect.js +18 -31
- package/dist/commonjs/hooks/push/useIosVoipPushEventsSetupEffect.js.map +1 -1
- package/dist/commonjs/hooks/useAndroidKeepCallAliveEffect.js +64 -97
- package/dist/commonjs/hooks/useAndroidKeepCallAliveEffect.js.map +1 -1
- package/dist/commonjs/index.js +1 -0
- package/dist/commonjs/index.js.map +1 -1
- package/dist/commonjs/modules/call-manager/CallManager.js +26 -0
- package/dist/commonjs/modules/call-manager/CallManager.js.map +1 -1
- package/dist/commonjs/providers/StreamCall/index.js +6 -6
- package/dist/commonjs/providers/StreamCall/index.js.map +1 -1
- package/dist/commonjs/utils/StreamVideoRN/index.js +33 -21
- package/dist/commonjs/utils/StreamVideoRN/index.js.map +1 -1
- package/dist/commonjs/utils/internal/callingx/audioSessionPromise.js +58 -0
- package/dist/commonjs/utils/internal/callingx/audioSessionPromise.js.map +1 -0
- package/dist/commonjs/utils/internal/callingx/callingx.js +109 -0
- package/dist/commonjs/utils/internal/callingx/callingx.js.map +1 -0
- package/dist/commonjs/utils/internal/registerSDKGlobals.js +52 -3
- package/dist/commonjs/utils/internal/registerSDKGlobals.js.map +1 -1
- package/dist/commonjs/utils/keepCallAliveHeadlessTask.js +48 -0
- package/dist/commonjs/utils/keepCallAliveHeadlessTask.js.map +1 -0
- package/dist/commonjs/utils/push/android.js +151 -202
- package/dist/commonjs/utils/push/android.js.map +1 -1
- package/dist/commonjs/utils/push/internal/ios.js +17 -34
- package/dist/commonjs/utils/push/internal/ios.js.map +1 -1
- package/dist/commonjs/utils/push/internal/rxSubjects.js +1 -45
- package/dist/commonjs/utils/push/internal/rxSubjects.js.map +1 -1
- package/dist/commonjs/utils/push/internal/utils.js +32 -20
- package/dist/commonjs/utils/push/internal/utils.js.map +1 -1
- package/dist/commonjs/utils/push/ios.js.map +1 -1
- package/dist/commonjs/utils/push/libs/callingx.js +75 -0
- package/dist/commonjs/utils/push/libs/callingx.js.map +1 -0
- package/dist/commonjs/utils/push/libs/index.js +8 -19
- package/dist/commonjs/utils/push/libs/index.js.map +1 -1
- package/dist/commonjs/utils/push/libs/notifee/index.js +0 -19
- package/dist/commonjs/utils/push/libs/notifee/index.js.map +1 -1
- package/dist/commonjs/utils/push/setupCallingExpEvents.js +108 -0
- package/dist/commonjs/utils/push/setupCallingExpEvents.js.map +1 -0
- package/dist/commonjs/utils/push/setupIosVoipPushEvents.js +7 -6
- package/dist/commonjs/utils/push/setupIosVoipPushEvents.js.map +1 -1
- package/dist/commonjs/version.js +1 -1
- package/dist/commonjs/version.js.map +1 -1
- package/dist/module/hooks/push/index.js +0 -2
- package/dist/module/hooks/push/index.js.map +1 -1
- package/dist/module/hooks/push/useCallingExpWithCallingStateEffect.js +114 -0
- package/dist/module/hooks/push/useCallingExpWithCallingStateEffect.js.map +1 -0
- package/dist/module/hooks/push/useIosVoipPushEventsSetupEffect.js +18 -31
- package/dist/module/hooks/push/useIosVoipPushEventsSetupEffect.js.map +1 -1
- package/dist/module/hooks/useAndroidKeepCallAliveEffect.js +66 -99
- package/dist/module/hooks/useAndroidKeepCallAliveEffect.js.map +1 -1
- package/dist/module/index.js +1 -0
- package/dist/module/index.js.map +1 -1
- package/dist/module/modules/call-manager/CallManager.js +26 -0
- package/dist/module/modules/call-manager/CallManager.js.map +1 -1
- package/dist/module/providers/StreamCall/index.js +6 -6
- package/dist/module/providers/StreamCall/index.js.map +1 -1
- package/dist/module/utils/StreamVideoRN/index.js +33 -21
- package/dist/module/utils/StreamVideoRN/index.js.map +1 -1
- package/dist/module/utils/internal/callingx/audioSessionPromise.js +51 -0
- package/dist/module/utils/internal/callingx/audioSessionPromise.js.map +1 -0
- package/dist/module/utils/internal/callingx/callingx.js +100 -0
- package/dist/module/utils/internal/callingx/callingx.js.map +1 -0
- package/dist/module/utils/internal/registerSDKGlobals.js +52 -3
- package/dist/module/utils/internal/registerSDKGlobals.js.map +1 -1
- package/dist/module/utils/keepCallAliveHeadlessTask.js +42 -0
- package/dist/module/utils/keepCallAliveHeadlessTask.js.map +1 -0
- package/dist/module/utils/push/android.js +153 -204
- package/dist/module/utils/push/android.js.map +1 -1
- package/dist/module/utils/push/internal/ios.js +17 -34
- package/dist/module/utils/push/internal/ios.js.map +1 -1
- package/dist/module/utils/push/internal/rxSubjects.js +0 -44
- package/dist/module/utils/push/internal/rxSubjects.js.map +1 -1
- package/dist/module/utils/push/internal/utils.js +29 -19
- package/dist/module/utils/push/internal/utils.js.map +1 -1
- package/dist/module/utils/push/ios.js.map +1 -1
- package/dist/module/utils/push/libs/callingx.js +67 -0
- package/dist/module/utils/push/libs/callingx.js.map +1 -0
- package/dist/module/utils/push/libs/index.js +1 -2
- package/dist/module/utils/push/libs/index.js.map +1 -1
- package/dist/module/utils/push/libs/notifee/index.js +0 -18
- package/dist/module/utils/push/libs/notifee/index.js.map +1 -1
- package/dist/module/utils/push/setupCallingExpEvents.js +102 -0
- package/dist/module/utils/push/setupCallingExpEvents.js.map +1 -0
- package/dist/module/utils/push/setupIosVoipPushEvents.js +7 -6
- package/dist/module/utils/push/setupIosVoipPushEvents.js.map +1 -1
- package/dist/module/version.js +1 -1
- package/dist/module/version.js.map +1 -1
- package/dist/typescript/hooks/push/index.d.ts.map +1 -1
- package/dist/typescript/hooks/push/useCallingExpWithCallingStateEffect.d.ts +5 -0
- package/dist/typescript/hooks/push/useCallingExpWithCallingStateEffect.d.ts.map +1 -0
- package/dist/typescript/hooks/push/useIosVoipPushEventsSetupEffect.d.ts.map +1 -1
- package/dist/typescript/hooks/useAndroidKeepCallAliveEffect.d.ts.map +1 -1
- package/dist/typescript/index.d.ts +1 -0
- package/dist/typescript/index.d.ts.map +1 -1
- package/dist/typescript/modules/call-manager/CallManager.d.ts +5 -0
- package/dist/typescript/modules/call-manager/CallManager.d.ts.map +1 -1
- package/dist/typescript/utils/StreamVideoRN/index.d.ts +20 -2
- package/dist/typescript/utils/StreamVideoRN/index.d.ts.map +1 -1
- package/dist/typescript/utils/StreamVideoRN/types.d.ts +54 -29
- package/dist/typescript/utils/StreamVideoRN/types.d.ts.map +1 -1
- package/dist/typescript/utils/internal/callingx/audioSessionPromise.d.ts +16 -0
- package/dist/typescript/utils/internal/callingx/audioSessionPromise.d.ts.map +1 -0
- package/dist/typescript/utils/internal/callingx/callingx.d.ts +14 -0
- package/dist/typescript/utils/internal/callingx/callingx.d.ts.map +1 -0
- package/dist/typescript/utils/internal/registerSDKGlobals.d.ts.map +1 -1
- package/dist/typescript/utils/keepCallAliveHeadlessTask.d.ts +10 -0
- package/dist/typescript/utils/keepCallAliveHeadlessTask.d.ts.map +1 -0
- package/dist/typescript/utils/push/android.d.ts +1 -2
- package/dist/typescript/utils/push/android.d.ts.map +1 -1
- package/dist/typescript/utils/push/internal/ios.d.ts.map +1 -1
- package/dist/typescript/utils/push/internal/rxSubjects.d.ts +0 -33
- package/dist/typescript/utils/push/internal/rxSubjects.d.ts.map +1 -1
- package/dist/typescript/utils/push/internal/utils.d.ts +8 -1
- package/dist/typescript/utils/push/internal/utils.d.ts.map +1 -1
- package/dist/typescript/utils/push/ios.d.ts +1 -2
- package/dist/typescript/utils/push/ios.d.ts.map +1 -1
- package/dist/typescript/utils/push/libs/callingx.d.ts +9 -0
- package/dist/typescript/utils/push/libs/callingx.d.ts.map +1 -0
- package/dist/typescript/utils/push/libs/index.d.ts +1 -2
- package/dist/typescript/utils/push/libs/index.d.ts.map +1 -1
- package/dist/typescript/utils/push/libs/notifee/index.d.ts +0 -1
- package/dist/typescript/utils/push/libs/notifee/index.d.ts.map +1 -1
- package/dist/typescript/utils/push/setupCallingExpEvents.d.ts +8 -0
- package/dist/typescript/utils/push/setupCallingExpEvents.d.ts.map +1 -0
- package/dist/typescript/utils/push/setupIosVoipPushEvents.d.ts.map +1 -1
- package/dist/typescript/version.d.ts +1 -1
- package/dist/typescript/version.d.ts.map +1 -1
- package/expo-config-plugin/dist/withAndroidManifest.js +1 -33
- package/expo-config-plugin/dist/withAndroidPermissions.js +2 -7
- package/expo-config-plugin/dist/withAppDelegate.js +19 -197
- package/expo-config-plugin/dist/withMainActivity.js +1 -1
- package/expo-config-plugin/dist/withiOSInfoPlist.js +2 -3
- package/ios/StreamInCallManager.m +2 -0
- package/ios/StreamInCallManager.swift +19 -7
- package/ios/StreamVideoReactNative.h +7 -4
- package/ios/StreamVideoReactNative.m +189 -82
- package/package.json +13 -18
- package/src/hooks/push/index.ts +0 -2
- package/src/hooks/push/useCallingExpWithCallingStateEffect.ts +147 -0
- package/src/hooks/push/useIosVoipPushEventsSetupEffect.ts +21 -34
- package/src/hooks/useAndroidKeepCallAliveEffect.ts +94 -120
- package/src/index.ts +1 -0
- package/src/modules/call-manager/CallManager.ts +36 -0
- package/src/modules/call-manager/native-module.d.ts +7 -0
- package/src/providers/StreamCall/index.tsx +6 -6
- package/src/utils/StreamVideoRN/index.ts +40 -30
- package/src/utils/StreamVideoRN/types.ts +56 -29
- package/src/utils/internal/callingx/audioSessionPromise.ts +53 -0
- package/src/utils/internal/callingx/callingx.ts +146 -0
- package/src/utils/internal/registerSDKGlobals.ts +47 -4
- package/src/utils/keepCallAliveHeadlessTask.ts +54 -0
- package/src/utils/push/android.ts +227 -309
- package/src/utils/push/internal/ios.ts +28 -44
- package/src/utils/push/internal/rxSubjects.ts +0 -61
- package/src/utils/push/internal/utils.ts +45 -26
- package/src/utils/push/ios.ts +1 -6
- package/src/utils/push/libs/callingx.ts +90 -0
- package/src/utils/push/libs/index.ts +1 -2
- package/src/utils/push/libs/notifee/index.ts +0 -27
- package/src/utils/push/setupCallingExpEvents.ts +130 -0
- package/src/utils/push/setupIosVoipPushEvents.ts +11 -7
- package/src/version.ts +1 -1
- package/CHANGELOG.md +0 -3144
- package/android/src/main/java/com/streamvideo/reactnative/util/CallAliveServiceChecker.kt +0 -95
- package/dist/commonjs/hooks/push/useIosCallkeepWithCallingStateEffect.js +0 -160
- package/dist/commonjs/hooks/push/useIosCallkeepWithCallingStateEffect.js.map +0 -1
- package/dist/commonjs/hooks/push/useProcessPushCallEffect.js +0 -67
- package/dist/commonjs/hooks/push/useProcessPushCallEffect.js.map +0 -1
- package/dist/commonjs/utils/push/libs/callkeep.js +0 -17
- package/dist/commonjs/utils/push/libs/callkeep.js.map +0 -1
- package/dist/commonjs/utils/push/libs/voipPushNotification.js +0 -17
- package/dist/commonjs/utils/push/libs/voipPushNotification.js.map +0 -1
- package/dist/commonjs/utils/push/setupIosCallKeepEvents.js +0 -205
- package/dist/commonjs/utils/push/setupIosCallKeepEvents.js.map +0 -1
- package/dist/module/hooks/push/useIosCallkeepWithCallingStateEffect.js +0 -153
- package/dist/module/hooks/push/useIosCallkeepWithCallingStateEffect.js.map +0 -1
- package/dist/module/hooks/push/useProcessPushCallEffect.js +0 -60
- package/dist/module/hooks/push/useProcessPushCallEffect.js.map +0 -1
- package/dist/module/utils/push/libs/callkeep.js +0 -11
- package/dist/module/utils/push/libs/callkeep.js.map +0 -1
- package/dist/module/utils/push/libs/voipPushNotification.js +0 -11
- package/dist/module/utils/push/libs/voipPushNotification.js.map +0 -1
- package/dist/module/utils/push/setupIosCallKeepEvents.js +0 -199
- package/dist/module/utils/push/setupIosCallKeepEvents.js.map +0 -1
- package/dist/typescript/hooks/push/useIosCallkeepWithCallingStateEffect.d.ts +0 -5
- package/dist/typescript/hooks/push/useIosCallkeepWithCallingStateEffect.d.ts.map +0 -1
- package/dist/typescript/hooks/push/useProcessPushCallEffect.d.ts +0 -8
- package/dist/typescript/hooks/push/useProcessPushCallEffect.d.ts.map +0 -1
- package/dist/typescript/utils/push/libs/callkeep.d.ts +0 -3
- package/dist/typescript/utils/push/libs/callkeep.d.ts.map +0 -1
- package/dist/typescript/utils/push/libs/voipPushNotification.d.ts +0 -3
- package/dist/typescript/utils/push/libs/voipPushNotification.d.ts.map +0 -1
- package/dist/typescript/utils/push/setupIosCallKeepEvents.d.ts +0 -6
- package/dist/typescript/utils/push/setupIosCallKeepEvents.d.ts.map +0 -1
- package/src/hooks/push/useIosCallkeepWithCallingStateEffect.ts +0 -235
- package/src/hooks/push/useProcessPushCallEffect.ts +0 -108
- package/src/utils/push/libs/callkeep.ts +0 -16
- package/src/utils/push/libs/voipPushNotification.ts +0 -17
- package/src/utils/push/setupIosCallKeepEvents.ts +0 -252
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { useIosVoipPushEventsSetupEffect } from './useIosVoipPushEventsSetupEffect';
|
|
2
|
-
import { useProcessPushCallEffect } from './useProcessPushCallEffect';
|
|
3
2
|
import { useInitAndroidTokenAndRest } from './useInitAndroidTokenAndRest';
|
|
4
3
|
import { useIosInitRemoteNotifications } from './useIosInitRemoteNotifications';
|
|
5
4
|
import { useProcessPushNonRingingCallEffect } from './useProcessPushNonRingingCallEffect';
|
|
@@ -12,7 +11,6 @@ export const usePushRegisterEffect = () => {
|
|
|
12
11
|
useIosInitRemoteNotifications();
|
|
13
12
|
useIosVoipPushEventsSetupEffect();
|
|
14
13
|
useProcessPushNonRingingCallEffect();
|
|
15
|
-
useProcessPushCallEffect();
|
|
16
14
|
useInitAndroidTokenAndRest();
|
|
17
15
|
};
|
|
18
16
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["useIosVoipPushEventsSetupEffect","
|
|
1
|
+
{"version":3,"names":["useIosVoipPushEventsSetupEffect","useInitAndroidTokenAndRest","useIosInitRemoteNotifications","useProcessPushNonRingingCallEffect","usePushRegisterEffect"],"sourceRoot":"../../../../src","sources":["hooks/push/index.ts"],"mappings":"AAAA,SAASA,+BAA+B,QAAQ,mCAAmC;AACnF,SAASC,0BAA0B,QAAQ,8BAA8B;AACzE,SAASC,6BAA6B,QAAQ,iCAAiC;AAC/E,SAASC,kCAAkC,QAAQ,sCAAsC;;AAEzF;AACA;AACA;AACA;AACA,OAAO,MAAMC,qBAAqB,GAAGA,CAAA,KAAM;EACzCF,6BAA6B,CAAC,CAAC;EAC/BF,+BAA+B,CAAC,CAAC;EACjCG,kCAAkC,CAAC,CAAC;EACpCF,0BAA0B,CAAC,CAAC;AAC9B,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { videoLoggerSystem } from '@stream-io/video-client';
|
|
2
|
+
import { useCall, useCallStateHooks } from '@stream-io/video-react-bindings';
|
|
3
|
+
import { useEffect, useMemo } from 'react';
|
|
4
|
+
import { getCallDisplayName } from '../../utils/internal/callingx/callingx';
|
|
5
|
+
import { getCallingxLibIfAvailable } from '../../utils/push/libs/callingx';
|
|
6
|
+
const logger = videoLoggerSystem.getLogger('callingx');
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* This hook is used to inform sync call state with CallKit/Telecom (i.e. start call, end call, mute/unmute call).
|
|
10
|
+
*/
|
|
11
|
+
export const useCallingExpWithCallingStateEffect = () => {
|
|
12
|
+
const {
|
|
13
|
+
useMicrophoneState,
|
|
14
|
+
useParticipants,
|
|
15
|
+
useCallMembers
|
|
16
|
+
} = useCallStateHooks();
|
|
17
|
+
const activeCall = useCall();
|
|
18
|
+
const {
|
|
19
|
+
isMute,
|
|
20
|
+
microphone
|
|
21
|
+
} = useMicrophoneState();
|
|
22
|
+
const callMembers = useCallMembers();
|
|
23
|
+
const participants = useParticipants();
|
|
24
|
+
const activeCallCid = activeCall?.cid;
|
|
25
|
+
const currentUserId = activeCall?.currentUserId;
|
|
26
|
+
const callDisplayName = useMemo(() => getCallDisplayName(callMembers, participants, currentUserId), [callMembers, participants, currentUserId]);
|
|
27
|
+
useEffect(() => {
|
|
28
|
+
return () => {
|
|
29
|
+
const callingx = getCallingxLibIfAvailable();
|
|
30
|
+
if (!callingx?.isSetup || !activeCallCid) {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const isCallTracked = callingx.isCallTracked(activeCallCid);
|
|
34
|
+
if (!isCallTracked) {
|
|
35
|
+
logger.debug(`useCallingExpWithCallingStateEffect:No active call cid to end in calling exp: ${activeCallCid} isCallTracked: ${isCallTracked}`);
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
//if incoming stream call was unmounted, we need to end the call in CallKit/Telecom
|
|
39
|
+
logger.debug(`useCallingExpWithCallingStateEffect: Ending call in callingx: ${activeCallCid}`);
|
|
40
|
+
callingx.endCallWithReason(activeCallCid, 'local').catch(error => {
|
|
41
|
+
logger.error(`useCallingExpWithCallingStateEffect: Error ending call in callingx: ${activeCallCid}`, error);
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
}, [activeCallCid]);
|
|
45
|
+
useEffect(() => {
|
|
46
|
+
const callingx = getCallingxLibIfAvailable();
|
|
47
|
+
if (!callingx?.isSetup || !activeCallCid) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
const isCallTracked = callingx.isCallTracked(activeCallCid);
|
|
51
|
+
if (!isCallTracked) {
|
|
52
|
+
logger.debug(`useCallingExpWithCallingStateEffect:No active call cid to update callingx: ${activeCallCid} isCallTracked: ${isCallTracked}`);
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
callingx.updateDisplay(activeCallCid, activeCallCid, callDisplayName);
|
|
56
|
+
}, [activeCallCid, callDisplayName]);
|
|
57
|
+
|
|
58
|
+
// Sync microphone mute state from app → CallKit
|
|
59
|
+
useEffect(() => {
|
|
60
|
+
const callingx = getCallingxLibIfAvailable();
|
|
61
|
+
if (!callingx?.isSetup || !activeCallCid) {
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
const isCallTracked = callingx.isCallTracked(activeCallCid);
|
|
65
|
+
if (!isCallTracked) {
|
|
66
|
+
logger.debug(`useCallingExpWithCallingStateEffect: No active call cid to set muted in calling exp: ${activeCallCid} isCallTracked: ${isCallTracked}`);
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
callingx.setMutedCall(activeCallCid, isMute);
|
|
70
|
+
}, [activeCallCid, isMute]);
|
|
71
|
+
|
|
72
|
+
// Sync mute state from CallKit → app (only for system-initiated mute actions)
|
|
73
|
+
useEffect(() => {
|
|
74
|
+
const callingx = getCallingxLibIfAvailable();
|
|
75
|
+
if (!callingx?.isSetup || !activeCallCid) {
|
|
76
|
+
logger.debug(`useCallingExpWithCallingStateEffect: No active call cid to set muted in calling exp: ${activeCallCid} callingx isSetup: ${callingx?.isSetup}`);
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
// Listen to mic toggle events from CallKit/Telecom and update stream call microphone state.
|
|
81
|
+
// Only system-initiated mute actions (e.g. user tapped mute on the native CallKit UI)
|
|
82
|
+
// are sent here — app-initiated actions are filtered out on the native side to prevent
|
|
83
|
+
// the feedback loop: app mutes mic → setMutedCall → CallKit delegate → event to JS → loop.
|
|
84
|
+
const subscription = callingx.addEventListener('didPerformSetMutedCallAction', async event => {
|
|
85
|
+
const {
|
|
86
|
+
callId,
|
|
87
|
+
muted
|
|
88
|
+
} = event;
|
|
89
|
+
const isCallTracked = callingx.isCallTracked(activeCallCid);
|
|
90
|
+
if (!isCallTracked || callId !== activeCallCid) {
|
|
91
|
+
logger.debug(`useCallingExpWithCallingStateEffect: No active call cid to set muted in calling exp: ${activeCallCid} isCallTracked: ${isCallTracked} callId: ${callId}`);
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
const isCurrentlyMuted = microphone.state.status === 'disabled';
|
|
95
|
+
if (isCurrentlyMuted === muted) {
|
|
96
|
+
logger.debug(`useCallingExpWithCallingStateEffect: Mic toggle is already in the desired state: ${muted} for call: ${activeCallCid}`);
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
try {
|
|
100
|
+
if (muted) {
|
|
101
|
+
await microphone.disable();
|
|
102
|
+
} else {
|
|
103
|
+
await microphone.enable();
|
|
104
|
+
}
|
|
105
|
+
} catch (error) {
|
|
106
|
+
logger.error(`useCallingExpWithCallingStateEffect: Error toggling mic in calling exp: ${activeCallCid}`, error);
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
return () => {
|
|
110
|
+
subscription.remove();
|
|
111
|
+
};
|
|
112
|
+
}, [activeCallCid, microphone]);
|
|
113
|
+
};
|
|
114
|
+
//# sourceMappingURL=useCallingExpWithCallingStateEffect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["videoLoggerSystem","useCall","useCallStateHooks","useEffect","useMemo","getCallDisplayName","getCallingxLibIfAvailable","logger","getLogger","useCallingExpWithCallingStateEffect","useMicrophoneState","useParticipants","useCallMembers","activeCall","isMute","microphone","callMembers","participants","activeCallCid","cid","currentUserId","callDisplayName","callingx","isSetup","isCallTracked","debug","endCallWithReason","catch","error","updateDisplay","setMutedCall","subscription","addEventListener","event","callId","muted","isCurrentlyMuted","state","status","disable","enable","remove"],"sourceRoot":"../../../../src","sources":["hooks/push/useCallingExpWithCallingStateEffect.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { useEffect, useRef, useState } from 'react';
|
|
2
|
-
import { getVoipPushNotificationLib } from '../../utils/push/libs';
|
|
3
2
|
import { Platform } from 'react-native';
|
|
4
3
|
import { StreamVideoRN } from '../../utils';
|
|
5
4
|
import { onVoipNotificationReceived } from '../../utils/push/internal/ios';
|
|
6
5
|
import { useConnectedUser, useStreamVideoClient } from '@stream-io/video-react-bindings';
|
|
7
6
|
import { setPushLogoutCallback } from '../../utils/internal/pushLogoutCallback';
|
|
8
7
|
import { videoLoggerSystem } from '@stream-io/video-client';
|
|
8
|
+
import { getCallingxLibIfAvailable } from '../../utils/push/libs';
|
|
9
9
|
const logger = videoLoggerSystem.getLogger('useIosVoipPushEventsSetupEffect');
|
|
10
10
|
|
|
11
11
|
/* VoipPushNotificationLib has support for only one listener type at a time
|
|
@@ -23,6 +23,7 @@ function setLogoutCallback(client, token, lastVoipTokenRef) {
|
|
|
23
23
|
};
|
|
24
24
|
try {
|
|
25
25
|
await client.removeDevice(token);
|
|
26
|
+
logger.debug('PushLogoutCallback - Removed voip token', token);
|
|
26
27
|
} catch (err) {
|
|
27
28
|
logger.warn('PushLogoutCallback - Failed to remove voip token', err);
|
|
28
29
|
}
|
|
@@ -77,20 +78,10 @@ export const useIosVoipPushEventsSetupEffect = () => {
|
|
|
77
78
|
useEffect(() => {
|
|
78
79
|
const pushConfig = StreamVideoRN.getConfig().push;
|
|
79
80
|
const pushProviderName = pushConfig?.ios.pushProviderName;
|
|
80
|
-
|
|
81
|
+
const callingx = getCallingxLibIfAvailable();
|
|
82
|
+
if (Platform.OS !== 'ios' || !client || !pushProviderName || !callingx) {
|
|
81
83
|
return;
|
|
82
84
|
}
|
|
83
|
-
if (!pushConfig.android.incomingCallChannel) {
|
|
84
|
-
// TODO: remove this check and find a better way once we have telecom integration for android
|
|
85
|
-
logger.debug('android incomingCallChannel is not defined, so skipping the useIosVoipPushEventsSetupEffect');
|
|
86
|
-
return;
|
|
87
|
-
}
|
|
88
|
-
const voipPushNotification = getVoipPushNotificationLib();
|
|
89
|
-
|
|
90
|
-
// even though we do this natively, we have to still register here again
|
|
91
|
-
// natively this will make sure "register" event for JS is sent with the last push token
|
|
92
|
-
// Necessary if client changed before we got the event here or user logged out and logged in again
|
|
93
|
-
voipPushNotification.registerVoipToken();
|
|
94
85
|
const onTokenReceived = token => {
|
|
95
86
|
const userId = client.streamClient._user?.id ?? '';
|
|
96
87
|
if (client.streamClient.anonymous || !token || !userId) {
|
|
@@ -118,27 +109,24 @@ export const useIosVoipPushEventsSetupEffect = () => {
|
|
|
118
109
|
});
|
|
119
110
|
};
|
|
120
111
|
// fired when PushKit give us the latest token
|
|
121
|
-
|
|
112
|
+
const voipRegisterListener = callingx.addEventListener('voipNotificationsRegistered', ({
|
|
113
|
+
token
|
|
114
|
+
}) => {
|
|
122
115
|
onTokenReceived(token);
|
|
123
116
|
});
|
|
124
117
|
|
|
125
|
-
// this will
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
} = voipPushEvent;
|
|
135
|
-
if (name === 'RNVoipPushRemoteNotificationsRegisteredEvent') {
|
|
136
|
-
onTokenReceived(data);
|
|
137
|
-
} else if (name === 'RNVoipPushRemoteNotificationReceivedEvent') {
|
|
138
|
-
onVoipNotificationReceived(data, pushConfig);
|
|
139
|
-
}
|
|
118
|
+
// this will return events that were fired before js bridge initialized
|
|
119
|
+
callingx.getInitialVoipEvents().forEach(({
|
|
120
|
+
eventName,
|
|
121
|
+
params
|
|
122
|
+
}) => {
|
|
123
|
+
if (eventName === 'voipNotificationsRegistered' && 'token' in params) {
|
|
124
|
+
onTokenReceived(params.token);
|
|
125
|
+
} else if (eventName === 'voipNotificationReceived') {
|
|
126
|
+
onVoipNotificationReceived(params, pushConfig);
|
|
140
127
|
}
|
|
141
128
|
});
|
|
129
|
+
callingx.registerVoipToken();
|
|
142
130
|
lastListener.count += 1;
|
|
143
131
|
const currentListenerCount = lastListener.count;
|
|
144
132
|
return () => {
|
|
@@ -148,8 +136,7 @@ export const useIosVoipPushEventsSetupEffect = () => {
|
|
|
148
136
|
return;
|
|
149
137
|
}
|
|
150
138
|
logger.debug(`Voip event listeners are removed for user: ${userId}`);
|
|
151
|
-
|
|
152
|
-
voipPushNotification.removeEventListener('register');
|
|
139
|
+
voipRegisterListener.remove();
|
|
153
140
|
};
|
|
154
141
|
}, [client]);
|
|
155
142
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["useEffect","useRef","useState","
|
|
1
|
+
{"version":3,"names":["useEffect","useRef","useState","Platform","StreamVideoRN","onVoipNotificationReceived","useConnectedUser","useStreamVideoClient","setPushLogoutCallback","videoLoggerSystem","getCallingxLibIfAvailable","logger","getLogger","lastListener","count","setLogoutCallback","client","token","lastVoipTokenRef","current","userId","removeDevice","debug","err","warn","useIosVoipPushEventsSetupEffect","connectedUserId","id","unsentToken","setUnsentToken","pushProviderName","getConfig","push","ios","tokenToSend","addVoipDevice","then","undefined","catch","error","pushConfig","callingx","OS","onTokenReceived","streamClient","_user","anonymous","reason","lastVoipToken","voipRegisterListener","addEventListener","getInitialVoipEvents","forEach","eventName","params","registerVoipToken","currentListenerCount","remove"],"sourceRoot":"../../../../src","sources":["hooks/push/useIosVoipPushEventsSetupEffect.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,93 +1,58 @@
|
|
|
1
1
|
import { useCall, useCallStateHooks } from '@stream-io/video-react-bindings';
|
|
2
2
|
import { useEffect, useRef } from 'react';
|
|
3
3
|
import { StreamVideoRN } from '../utils';
|
|
4
|
-
import { AppState, NativeModules, Platform } from 'react-native';
|
|
4
|
+
import { AppState, NativeModules, PermissionsAndroid, Platform } from 'react-native';
|
|
5
5
|
import { CallingState, videoLoggerSystem } from '@stream-io/video-client';
|
|
6
|
-
import {
|
|
6
|
+
import { keepCallAliveCallRef } from '../utils/keepCallAliveHeadlessTask';
|
|
7
|
+
import { getNotifeeLibNoThrowForKeepCallAlive } from '../utils/push/libs/notifee';
|
|
8
|
+
import { getCallingxLibIfAvailable } from '../utils/push/libs';
|
|
7
9
|
const notifeeLib = getNotifeeLibNoThrowForKeepCallAlive();
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
const logger = videoLoggerSystem.getLogger('setForegroundService method');
|
|
16
|
-
logger.info('KeepCallAlive is not configured. Skipping foreground service setup.');
|
|
17
|
-
return;
|
|
18
|
-
}
|
|
19
|
-
notifeeLib.default.registerForegroundService(() => {
|
|
20
|
-
const task = new Promise(resolve => {
|
|
21
|
-
const logger = videoLoggerSystem.getLogger('setForegroundService method');
|
|
22
|
-
logger.info('Foreground service running for call in progress');
|
|
23
|
-
// any task to run from SDK in the foreground service must be added
|
|
24
|
-
resolve(true);
|
|
25
|
-
});
|
|
26
|
-
const videoConfig = StreamVideoRN.getConfig();
|
|
27
|
-
const foregroundServiceConfig = videoConfig.foregroundService;
|
|
28
|
-
const {
|
|
29
|
-
taskToRun
|
|
30
|
-
} = foregroundServiceConfig.android;
|
|
31
|
-
const call = callToPassToForegroundService.current;
|
|
32
|
-
if (!call) {
|
|
33
|
-
const logger = videoLoggerSystem.getLogger('setForegroundService method');
|
|
34
|
-
logger.warn('No call to pass to foreground service');
|
|
35
|
-
return task.then(() => new Promise(() => {}));
|
|
36
|
-
}
|
|
37
|
-
callToPassToForegroundService.current = undefined;
|
|
38
|
-
return task.then(() => taskToRun(call));
|
|
39
|
-
});
|
|
40
|
-
});
|
|
10
|
+
async function stopForegroundServiceNoThrow() {
|
|
11
|
+
const logger = videoLoggerSystem.getLogger('stopForegroundServiceNoThrow');
|
|
12
|
+
try {
|
|
13
|
+
await NativeModules.StreamVideoReactNative.stopKeepCallAliveService();
|
|
14
|
+
} catch (e) {
|
|
15
|
+
logger.warn('Failed to stop keep-call-alive foreground service', e);
|
|
16
|
+
}
|
|
41
17
|
}
|
|
42
18
|
async function startForegroundService(call_cid) {
|
|
43
|
-
const
|
|
19
|
+
const logger = videoLoggerSystem.getLogger('startForegroundService');
|
|
20
|
+
const isCallAliveConfigured = await (async () => {
|
|
21
|
+
try {
|
|
22
|
+
return await NativeModules.StreamVideoReactNative.isCallAliveConfigured();
|
|
23
|
+
} catch (e) {
|
|
24
|
+
logger.warn('Failed to check whether KeepCallAlive is configured', e);
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
})();
|
|
44
28
|
if (!isCallAliveConfigured) {
|
|
45
|
-
const logger = videoLoggerSystem.getLogger('startForegroundService');
|
|
46
29
|
logger.info('KeepCallAlive is not configured. Skipping foreground service setup.');
|
|
47
30
|
return;
|
|
48
31
|
}
|
|
49
|
-
//
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
if (settings.authorizationStatus !== notifeeLib.AuthorizationStatus.AUTHORIZED) {
|
|
53
|
-
const logger = videoLoggerSystem.getLogger('startForegroundService');
|
|
32
|
+
// Check for notification permission (Android 13+) before starting the service.
|
|
33
|
+
const hasPostNotificationsPermission = Number(Platform.Version) < 33 || (await PermissionsAndroid.check(PermissionsAndroid.PERMISSIONS.POST_NOTIFICATIONS));
|
|
34
|
+
if (!hasPostNotificationsPermission) {
|
|
54
35
|
logger.info('Notification permission not granted, can not start foreground service to keep the call alive');
|
|
55
36
|
return;
|
|
56
37
|
}
|
|
57
38
|
const videoConfig = StreamVideoRN.getConfig();
|
|
58
39
|
const foregroundServiceConfig = videoConfig.foregroundService;
|
|
59
40
|
const notificationTexts = foregroundServiceConfig.android.notificationTexts;
|
|
60
|
-
const
|
|
61
|
-
|
|
62
|
-
|
|
41
|
+
const channel = foregroundServiceConfig.android.channel;
|
|
42
|
+
const smallIconName = videoConfig.push?.android.smallIcon;
|
|
43
|
+
|
|
63
44
|
// NOTE: we use requestAnimationFrame to ensure that the foreground service is started after all the current UI operations are done
|
|
64
45
|
// this is a workaround for the crash - android.app.RemoteServiceException$ForegroundServiceDidNotStartInTimeException: Context.startForegroundService() did not then call Service.startForeground()
|
|
65
46
|
// this crash was reproducible only in some android devices
|
|
66
|
-
requestAnimationFrame(() => {
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
channelId,
|
|
73
|
-
smallIcon: videoConfig.push?.android.smallIcon,
|
|
74
|
-
foregroundServiceTypes,
|
|
75
|
-
asForegroundService: true,
|
|
76
|
-
ongoing: true,
|
|
77
|
-
// user cannot dismiss the notification
|
|
78
|
-
colorized: true,
|
|
79
|
-
pressAction: {
|
|
80
|
-
id: 'default',
|
|
81
|
-
launchActivity: 'default' // open the app when the notification is pressed
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
});
|
|
47
|
+
requestAnimationFrame(async () => {
|
|
48
|
+
try {
|
|
49
|
+
await NativeModules.StreamVideoReactNative.startKeepCallAliveService(call_cid, channel.id, channel.name, notificationTexts.title, notificationTexts.body, smallIconName ?? null);
|
|
50
|
+
} catch (e) {
|
|
51
|
+
logger.warn('Failed to start keep-call-alive foreground service', e);
|
|
52
|
+
}
|
|
85
53
|
});
|
|
86
54
|
}
|
|
87
55
|
|
|
88
|
-
// flag to check if setForegroundService has already been run once
|
|
89
|
-
let isSetForegroundServiceRan = false;
|
|
90
|
-
|
|
91
56
|
/**
|
|
92
57
|
* This hook is used to keep the call alive in the background for Android.
|
|
93
58
|
* It starts a foreground service to keep the call alive as soon as the call is joined
|
|
@@ -97,7 +62,7 @@ let isSetForegroundServiceRan = false;
|
|
|
97
62
|
export const useAndroidKeepCallAliveEffect = () => {
|
|
98
63
|
const foregroundServiceStartedRef = useRef(false);
|
|
99
64
|
const call = useCall();
|
|
100
|
-
|
|
65
|
+
keepCallAliveCallRef.current = call;
|
|
101
66
|
const activeCallCid = call?.cid;
|
|
102
67
|
const {
|
|
103
68
|
useCallCallingState
|
|
@@ -105,12 +70,16 @@ export const useAndroidKeepCallAliveEffect = () => {
|
|
|
105
70
|
const callingState = useCallCallingState();
|
|
106
71
|
const isOutgoingCall = callingState === CallingState.RINGING && call?.isCreatedByMe;
|
|
107
72
|
const isCallJoined = callingState === CallingState.JOINED;
|
|
73
|
+
const isRingingCall = call?.ringing;
|
|
108
74
|
const shouldStartForegroundService = !foregroundServiceStartedRef.current && (isOutgoingCall || isCallJoined);
|
|
109
75
|
useEffect(() => {
|
|
110
76
|
if (Platform.OS === 'ios' || !activeCallCid) {
|
|
111
77
|
return undefined;
|
|
112
78
|
}
|
|
113
|
-
|
|
79
|
+
const callingx = getCallingxLibIfAvailable();
|
|
80
|
+
if (callingx?.isSetup && (isRingingCall || !isRingingCall && callingx?.isOngoingCallsEnabled)) {
|
|
81
|
+
return undefined;
|
|
82
|
+
}
|
|
114
83
|
|
|
115
84
|
// start foreground service as soon as the call is joined
|
|
116
85
|
if (shouldStartForegroundService) {
|
|
@@ -118,21 +87,18 @@ export const useAndroidKeepCallAliveEffect = () => {
|
|
|
118
87
|
if (foregroundServiceStartedRef.current) {
|
|
119
88
|
return;
|
|
120
89
|
}
|
|
121
|
-
if
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
notifee.cancelDisplayedNotification(activeCallCid);
|
|
90
|
+
// Optional compatibility cleanup: if the app uses Notifee for ringing push,
|
|
91
|
+
// we might have an incoming call notification running as a foreground service.
|
|
92
|
+
if (notifeeLib) {
|
|
93
|
+
const notifee = notifeeLib.default;
|
|
94
|
+
const displayedNotifications = await notifee.getDisplayedNotifications();
|
|
95
|
+
const activeCallNotification = displayedNotifications.find(notification => notification.id === activeCallCid);
|
|
96
|
+
if (activeCallNotification) {
|
|
97
|
+
// this means that we have a incoming call notification shown as foreground service and we must stop it
|
|
98
|
+
notifee.stopForegroundService();
|
|
99
|
+
notifee.cancelDisplayedNotification(activeCallCid);
|
|
100
|
+
}
|
|
133
101
|
}
|
|
134
|
-
// check for notification permission and then start the foreground service
|
|
135
|
-
|
|
136
102
|
await startForegroundService(activeCallCid);
|
|
137
103
|
foregroundServiceStartedRef.current = true;
|
|
138
104
|
};
|
|
@@ -140,7 +106,6 @@ export const useAndroidKeepCallAliveEffect = () => {
|
|
|
140
106
|
// ensure that app is active before running the function
|
|
141
107
|
if (AppState.currentState === 'active') {
|
|
142
108
|
run();
|
|
143
|
-
return undefined;
|
|
144
109
|
}
|
|
145
110
|
const sub = AppState.addEventListener('change', nextAppState => {
|
|
146
111
|
if (nextAppState === 'active') {
|
|
@@ -155,34 +120,36 @@ export const useAndroidKeepCallAliveEffect = () => {
|
|
|
155
120
|
return () => {
|
|
156
121
|
// cancel any notifee displayed notification when the call has transitioned out of ringing
|
|
157
122
|
// NOTE: cancels only the non fg service notifications
|
|
158
|
-
notifeeLib
|
|
123
|
+
if (notifeeLib) {
|
|
124
|
+
notifeeLib.default.cancelDisplayedNotification(activeCallCid);
|
|
125
|
+
}
|
|
159
126
|
};
|
|
160
127
|
} else if (callingState === CallingState.IDLE || callingState === CallingState.LEFT) {
|
|
161
128
|
if (foregroundServiceStartedRef.current) {
|
|
162
|
-
|
|
129
|
+
keepCallAliveCallRef.current = undefined;
|
|
163
130
|
// stop foreground service when the call is not active
|
|
164
|
-
|
|
131
|
+
stopForegroundServiceNoThrow();
|
|
165
132
|
foregroundServiceStartedRef.current = false;
|
|
166
133
|
} else {
|
|
167
|
-
notifeeLib
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
134
|
+
if (notifeeLib) {
|
|
135
|
+
notifeeLib.default.getDisplayedNotifications().then(displayedNotifications => {
|
|
136
|
+
const activeCallNotification = displayedNotifications.find(notification => notification.id === activeCallCid);
|
|
137
|
+
if (activeCallNotification) {
|
|
138
|
+
// this means that we have a incoming call notification shown as foreground service and we must stop it
|
|
139
|
+
notifeeLib.default.stopForegroundService();
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
}
|
|
175
143
|
}
|
|
176
144
|
}
|
|
177
145
|
return undefined;
|
|
178
|
-
}, [activeCallCid, callingState, shouldStartForegroundService]);
|
|
146
|
+
}, [activeCallCid, callingState, shouldStartForegroundService, isRingingCall]);
|
|
179
147
|
useEffect(() => {
|
|
180
148
|
return () => {
|
|
181
149
|
// stop foreground service when this effect is unmounted
|
|
182
150
|
if (foregroundServiceStartedRef.current) {
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
notifeeLib.default.stopForegroundService();
|
|
151
|
+
keepCallAliveCallRef.current = undefined;
|
|
152
|
+
stopForegroundServiceNoThrow();
|
|
186
153
|
foregroundServiceStartedRef.current = false;
|
|
187
154
|
}
|
|
188
155
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["useCall","useCallStateHooks","useEffect","useRef","StreamVideoRN","AppState","NativeModules","Platform","CallingState","videoLoggerSystem","
|
|
1
|
+
{"version":3,"names":["useCall","useCallStateHooks","useEffect","useRef","StreamVideoRN","AppState","NativeModules","PermissionsAndroid","Platform","CallingState","videoLoggerSystem","keepCallAliveCallRef","getNotifeeLibNoThrowForKeepCallAlive","getCallingxLibIfAvailable","notifeeLib","stopForegroundServiceNoThrow","logger","getLogger","StreamVideoReactNative","stopKeepCallAliveService","e","warn","startForegroundService","call_cid","isCallAliveConfigured","info","hasPostNotificationsPermission","Number","Version","check","PERMISSIONS","POST_NOTIFICATIONS","videoConfig","getConfig","foregroundServiceConfig","foregroundService","notificationTexts","android","channel","smallIconName","push","smallIcon","requestAnimationFrame","startKeepCallAliveService","id","name","title","body","useAndroidKeepCallAliveEffect","foregroundServiceStartedRef","call","current","activeCallCid","cid","useCallCallingState","callingState","isOutgoingCall","RINGING","isCreatedByMe","isCallJoined","JOINED","isRingingCall","ringing","shouldStartForegroundService","OS","undefined","callingx","isSetup","isOngoingCallsEnabled","run","notifee","default","displayedNotifications","getDisplayedNotifications","activeCallNotification","find","notification","stopForegroundService","cancelDisplayedNotification","currentState","sub","addEventListener","nextAppState","remove","IDLE","LEFT","then"],"sourceRoot":"../../../src","sources":["hooks/useAndroidKeepCallAliveEffect.ts"],"mappings":"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","ignoreList":[]}
|
package/dist/module/index.js
CHANGED
|
@@ -9,6 +9,7 @@ import { registerGlobals } from '@stream-io/react-native-webrtc';
|
|
|
9
9
|
import Logger from '@stream-io/react-native-webrtc/src/Logger';
|
|
10
10
|
import { Platform } from 'react-native';
|
|
11
11
|
import { registerSDKGlobals } from './utils/internal/registerSDKGlobals';
|
|
12
|
+
import './utils/keepCallAliveHeadlessTask';
|
|
12
13
|
|
|
13
14
|
// We're registering globals, because our video JS client is serving SDKs that use browser based webRTC functions.
|
|
14
15
|
// This will result in creation of 2 global objects: `window` and `navigator`
|
package/dist/module/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["setClientDetails","registerGlobals","Logger","Platform","registerSDKGlobals","OS","enable","ROOT_PREFIX","StreamVideo","StreamCall"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":"AAAA,SAASA,gBAAgB,QAAQ,0BAA0B;AAC3D;AACA,OAAO,wBAAwB;AAC/B;AACA,OAAO,gCAAgC;AACvC;AACA,OAAO,kBAAkB;AACzB,SAASC,eAAe,QAAQ,gCAAgC;AAChE,OAAOC,MAAM,MAAM,2CAA2C;AAC9D,SAASC,QAAQ,QAAQ,cAAc;AACvC,SAASC,kBAAkB,QAAQ,qCAAqC;;
|
|
1
|
+
{"version":3,"names":["setClientDetails","registerGlobals","Logger","Platform","registerSDKGlobals","OS","enable","ROOT_PREFIX","StreamVideo","StreamCall"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":"AAAA,SAASA,gBAAgB,QAAQ,0BAA0B;AAC3D;AACA,OAAO,wBAAwB;AAC/B;AACA,OAAO,gCAAgC;AACvC;AACA,OAAO,kBAAkB;AACzB,SAASC,eAAe,QAAQ,gCAAgC;AAChE,OAAOC,MAAM,MAAM,2CAA2C;AAC9D,SAASC,QAAQ,QAAQ,cAAc;AACvC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,OAAO,mCAAmC;;AAE1C;AACA;AACA;AACA,IAAID,QAAQ,CAACE,EAAE,KAAK,KAAK,EAAE;EACzBJ,eAAe,CAAC,CAAC;EACjBG,kBAAkB,CAAC,CAAC;AACtB;;AAEA;AACAF,MAAM,CAACI,MAAM,CAAC,GAAGJ,MAAM,CAACK,WAAW,eAAe,CAAC;AAEnD,cAAc,yBAAyB;AACvC,cAAc,iCAAiC;AAC/C,cAAc,cAAc;AAC5B,cAAc,YAAY;AAC1B,cAAc,SAAS;AACvB,cAAc,SAAS;AACvB,cAAc,SAAS;AACvB,cAAc,gBAAgB;AAC9B,cAAc,wBAAwB;;AAEtC;AACA;AACA,SAASC,WAAW,QAAQ,yBAAyB;AACrD,SAASC,UAAU,QAAQ,wBAAwB;AACnD,cAAc,+BAA+B;AAE7CT,gBAAgB,CAAC,CAAC","ignoreList":[]}
|