rns-nativecall 0.2.7 → 0.2.8
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/build.gradle +3 -3
- package/package.json +1 -1
- package/withNativeCallVoip.js +38 -35
package/android/build.gradle
CHANGED
|
@@ -35,12 +35,12 @@ android {
|
|
|
35
35
|
}
|
|
36
36
|
|
|
37
37
|
compileOptions {
|
|
38
|
-
sourceCompatibility JavaVersion.
|
|
39
|
-
targetCompatibility JavaVersion.
|
|
38
|
+
sourceCompatibility JavaVersion.VERSION_17
|
|
39
|
+
targetCompatibility JavaVersion.VERSION_17
|
|
40
40
|
}
|
|
41
41
|
|
|
42
42
|
kotlinOptions {
|
|
43
|
-
jvmTarget = '1.8
|
|
43
|
+
jvmTarget = '17' // Changed from 1.8
|
|
44
44
|
}
|
|
45
45
|
|
|
46
46
|
// lintOptions is deprecated in newer AGP, using lint instead
|
package/package.json
CHANGED
package/withNativeCallVoip.js
CHANGED
|
@@ -5,12 +5,10 @@ function withMainActivityDataFix(config) {
|
|
|
5
5
|
return withMainActivity(config, (config) => {
|
|
6
6
|
let contents = config.modResults.contents;
|
|
7
7
|
|
|
8
|
-
// Ensure Intent import exists
|
|
9
8
|
if (!contents.includes('import android.content.Intent')) {
|
|
10
9
|
contents = contents.replace(/package .*/, (match) => `${match}\n\nimport android.content.Intent`);
|
|
11
10
|
}
|
|
12
11
|
|
|
13
|
-
// Add onNewIntent to catch data when app is open
|
|
14
12
|
const onNewIntentCode = `
|
|
15
13
|
override fun onNewIntent(intent: Intent) {
|
|
16
14
|
super.onNewIntent(intent)
|
|
@@ -34,15 +32,15 @@ function withAndroidConfig(config) {
|
|
|
34
32
|
const manifest = config.modResults;
|
|
35
33
|
const application = manifest.manifest.application[0];
|
|
36
34
|
|
|
37
|
-
// 1.
|
|
35
|
+
// 1. Unified Permissions
|
|
38
36
|
const permissions = [
|
|
39
37
|
'android.permission.USE_FULL_SCREEN_INTENT',
|
|
40
38
|
'android.permission.VIBRATE',
|
|
41
39
|
'android.permission.FOREGROUND_SERVICE',
|
|
42
|
-
'android.permission.FOREGROUND_SERVICE_PHONE_CALL',
|
|
43
|
-
'android.permission.POST_NOTIFICATIONS',
|
|
44
|
-
'android.permission.WAKE_LOCK',
|
|
45
|
-
'android.permission.DISABLE_KEYGUARD'
|
|
40
|
+
'android.permission.FOREGROUND_SERVICE_PHONE_CALL',
|
|
41
|
+
'android.permission.POST_NOTIFICATIONS',
|
|
42
|
+
'android.permission.WAKE_LOCK',
|
|
43
|
+
'android.permission.DISABLE_KEYGUARD'
|
|
46
44
|
];
|
|
47
45
|
|
|
48
46
|
manifest.manifest['uses-permission'] = manifest.manifest['uses-permission'] || [];
|
|
@@ -52,51 +50,54 @@ function withAndroidConfig(config) {
|
|
|
52
50
|
}
|
|
53
51
|
});
|
|
54
52
|
|
|
55
|
-
// 2.
|
|
56
|
-
// Added showWhenLocked and turnScreenOn for the "Gate" logic
|
|
53
|
+
// 2. Activity Cleanup & Setup
|
|
57
54
|
application.activity = application.activity || [];
|
|
58
|
-
const acceptActivityName = 'com.rnsnativecall.AcceptCallActivity';
|
|
59
55
|
|
|
60
|
-
// Remove old
|
|
61
|
-
application.activity = application.activity.filter(a =>
|
|
56
|
+
// Remove old/redundant activities
|
|
57
|
+
application.activity = application.activity.filter(a =>
|
|
58
|
+
a.$['android:name'] !== 'com.rnsnativecall.IncomingCallActivity' &&
|
|
59
|
+
a.$['android:name'] !== 'com.rnsnativecall.AcceptCallActivity'
|
|
60
|
+
);
|
|
62
61
|
|
|
62
|
+
// Add the specific AcceptCallActivity (Trampoline)
|
|
63
63
|
application.activity.push({
|
|
64
64
|
$: {
|
|
65
|
-
'android:name':
|
|
65
|
+
'android:name': 'com.rnsnativecall.AcceptCallActivity',
|
|
66
66
|
'android:theme': '@android:style/Theme.Translucent.NoTitleBar',
|
|
67
67
|
'android:excludeFromRecents': 'true',
|
|
68
68
|
'android:noHistory': 'true',
|
|
69
69
|
'android:exported': 'false',
|
|
70
70
|
'android:launchMode': 'singleInstance',
|
|
71
|
-
'android:showWhenLocked': 'true',
|
|
72
|
-
'android:turnScreenOn': 'true'
|
|
71
|
+
'android:showWhenLocked': 'true',
|
|
72
|
+
'android:turnScreenOn': 'true'
|
|
73
73
|
}
|
|
74
74
|
});
|
|
75
75
|
|
|
76
|
-
// 3.
|
|
76
|
+
// 3. Service Cleanup & Setup (Firebase only)
|
|
77
77
|
application.service = application.service || [];
|
|
78
|
-
// Removed MyConnectionService as you are no longer using Telecom
|
|
79
|
-
const services = [
|
|
80
|
-
{ name: 'com.rnsnativecall.CallMessagingService', action: 'com.google.firebase.MESSAGING_EVENT' }
|
|
81
|
-
];
|
|
82
78
|
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
79
|
+
// Explicitly remove Telecom Service
|
|
80
|
+
application.service = application.service.filter(
|
|
81
|
+
s => s.$['android:name'] !== 'com.rnsnativecall.MyConnectionService'
|
|
82
|
+
);
|
|
83
|
+
|
|
84
|
+
const firebaseServiceName = 'com.rnsnativecall.CallMessagingService';
|
|
85
|
+
if (!application.service.some(s => s.$['android:name'] === firebaseServiceName)) {
|
|
86
|
+
application.service.push({
|
|
87
|
+
$: {
|
|
88
|
+
'android:name': firebaseServiceName,
|
|
89
|
+
'android:exported': 'false'
|
|
90
|
+
},
|
|
91
|
+
'intent-filter': [{ action: [{ $: { 'android:name': 'com.google.firebase.MESSAGING_EVENT' } }] }]
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
94
|
|
|
95
|
-
// 4.
|
|
95
|
+
// 4. Receiver Setup
|
|
96
96
|
application.receiver = application.receiver || [];
|
|
97
|
-
|
|
97
|
+
const receiverName = 'com.rnsnativecall.CallActionReceiver';
|
|
98
|
+
if (!application.receiver.some(r => r.$['android:name'] === receiverName)) {
|
|
98
99
|
application.receiver.push({
|
|
99
|
-
$: { 'android:name':
|
|
100
|
+
$: { 'android:name': receiverName, 'android:exported': 'false' }
|
|
100
101
|
});
|
|
101
102
|
}
|
|
102
103
|
|
|
@@ -109,7 +110,9 @@ function withIosConfig(config) {
|
|
|
109
110
|
return withInfoPlist(config, (config) => {
|
|
110
111
|
const infoPlist = config.modResults;
|
|
111
112
|
if (!infoPlist.UIBackgroundModes) infoPlist.UIBackgroundModes = [];
|
|
112
|
-
['voip', 'audio'].forEach(mode => {
|
|
113
|
+
['voip', 'audio'].forEach(mode => {
|
|
114
|
+
if (!infoPlist.UIBackgroundModes.includes(mode)) infoPlist.UIBackgroundModes.push(mode);
|
|
115
|
+
});
|
|
113
116
|
return config;
|
|
114
117
|
});
|
|
115
118
|
}
|