From 1a3ba77bb01977d5b7a76611c2f21c97c68f83fe Mon Sep 17 00:00:00 2001 From: Frank Owusu-Agyemang Date: Wed, 18 Sep 2024 15:46:22 +0200 Subject: [PATCH 1/2] patch: add on new intent override plugin for expo android --- expo/withAppsFlyer.js | 3 +++ expo/withAppsFlyerAndroid.js | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 35 insertions(+) create mode 100644 expo/withAppsFlyerAndroid.js diff --git a/expo/withAppsFlyer.js b/expo/withAppsFlyer.js index b2b4a66c..58e60d16 100644 --- a/expo/withAppsFlyer.js +++ b/expo/withAppsFlyer.js @@ -1,5 +1,8 @@ const withAppsFlyerIos = require('./withAppsFlyerIos'); +const withAppsFlyerAndroid = require('./withAppsFlyerAndroid'); + module.exports = function withAppsFlyer(config, { shouldUseStrictMode = false }) { config = withAppsFlyerIos(config, shouldUseStrictMode); + config = withAppsFlyerAndroid(config) return config; }; diff --git a/expo/withAppsFlyerAndroid.js b/expo/withAppsFlyerAndroid.js new file mode 100644 index 00000000..125d1af3 --- /dev/null +++ b/expo/withAppsFlyerAndroid.js @@ -0,0 +1,32 @@ +const {withMainActivity} = require('@expo/config-plugins') + +function overrideOnNewIntent(contents, packageName = ''){ + let nextContent = contents + const intentImportString = 'import android.content.intent' + + if (!nextContent.includes(intentImportString)){ + const packageString = `${packageName}\n` + nextContent = nextContent.replace(packageString,`${packageString}\n${intentImportString}`) + } + + if (!nextContent.includes('override fun onNewIntent(intent: Intent?)')) { + const classDeclarationRegex = /class\s+\w+.*\{/ + nextContent = nextContent.replace( + classDeclarationRegex, + match=>`${match} + override fun onNewIntent(intent: Intent?) { + super.onNewIntent(intent) + setIntent(intent) + } +`) + } + return nextContent +} + +module.exports = function withAppsFlyerAndroid(config){ + return withMainActivity(config, function(config){ + const {modResults:{contents},android} = config + config.modResults.contents = overrideOnNewIntent(contents,android?.package) + return config + }) +} From 2c31ff967d5e37c84aa0601c5a440ed2b1f99c67 Mon Sep 17 00:00:00 2001 From: Frank Owusu-Agyemang <26269088+f0wu5u@users.noreply.github.com> Date: Mon, 27 Jan 2025 14:00:31 +0100 Subject: [PATCH 2/2] Update expo/withAppsFlyerAndroid.js Co-authored-by: Jesper Paardekooper --- expo/withAppsFlyerAndroid.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/expo/withAppsFlyerAndroid.js b/expo/withAppsFlyerAndroid.js index 125d1af3..57fdebfc 100644 --- a/expo/withAppsFlyerAndroid.js +++ b/expo/withAppsFlyerAndroid.js @@ -2,7 +2,7 @@ const {withMainActivity} = require('@expo/config-plugins') function overrideOnNewIntent(contents, packageName = ''){ let nextContent = contents - const intentImportString = 'import android.content.intent' + const intentImportString = 'import android.content.Intent' if (!nextContent.includes(intentImportString)){ const packageString = `${packageName}\n`