customerio-expo-plugin 2.5.0 → 2.6.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.
Files changed (161) hide show
  1. package/package.json +13 -31
  2. package/plugin/app.plugin.js +1 -1
  3. package/plugin/lib/commonjs/android/withAndroidManifestUpdates.js +4 -4
  4. package/plugin/lib/commonjs/android/withAndroidManifestUpdates.js.map +1 -1
  5. package/plugin/lib/commonjs/android/withCIOAndroid.js +6 -1
  6. package/plugin/lib/commonjs/android/withCIOAndroid.js.map +1 -1
  7. package/plugin/lib/commonjs/android/withGoogleServicesJSON.js +1 -1
  8. package/plugin/lib/commonjs/android/withGoogleServicesJSON.js.map +1 -1
  9. package/plugin/lib/commonjs/android/withMainApplicationModifications.js +45 -0
  10. package/plugin/lib/commonjs/android/withMainApplicationModifications.js.map +1 -0
  11. package/plugin/lib/commonjs/android/withNotificationChannelMetadata.js +1 -1
  12. package/plugin/lib/commonjs/android/withNotificationChannelMetadata.js.map +1 -1
  13. package/plugin/lib/commonjs/android/withProjectStrings.js +14 -7
  14. package/plugin/lib/commonjs/android/withProjectStrings.js.map +1 -1
  15. package/plugin/lib/commonjs/helpers/constants/android.js +7 -1
  16. package/plugin/lib/commonjs/helpers/constants/android.js.map +1 -1
  17. package/plugin/lib/commonjs/helpers/constants/common.js +18 -0
  18. package/plugin/lib/commonjs/helpers/constants/common.js.map +1 -0
  19. package/plugin/lib/commonjs/helpers/constants/ios.js +7 -7
  20. package/plugin/lib/commonjs/helpers/constants/ios.js.map +1 -1
  21. package/plugin/lib/commonjs/helpers/native-files/android/CustomerIOSDKInitializer.kt +64 -0
  22. package/plugin/lib/commonjs/helpers/native-files/ios/CustomerIOSDKInitializer.swift +54 -0
  23. package/plugin/lib/commonjs/helpers/utils/injectCIOPodfileCode.js +2 -2
  24. package/plugin/lib/commonjs/helpers/utils/injectCIOPodfileCode.js.map +1 -1
  25. package/plugin/lib/commonjs/helpers/utils/patchPluginNativeCode.js +62 -0
  26. package/plugin/lib/commonjs/helpers/utils/patchPluginNativeCode.js.map +1 -0
  27. package/plugin/lib/commonjs/index.js +13 -2
  28. package/plugin/lib/commonjs/index.js.map +1 -1
  29. package/plugin/lib/commonjs/ios/utils.js +1 -1
  30. package/plugin/lib/commonjs/ios/utils.js.map +1 -1
  31. package/plugin/lib/commonjs/ios/withAppDelegateModifications.js +1 -1
  32. package/plugin/lib/commonjs/ios/withAppDelegateModifications.js.map +1 -1
  33. package/plugin/lib/commonjs/ios/withCIOIos.js +17 -11
  34. package/plugin/lib/commonjs/ios/withCIOIos.js.map +1 -1
  35. package/plugin/lib/commonjs/ios/withCIOIosSwift.js +133 -49
  36. package/plugin/lib/commonjs/ios/withCIOIosSwift.js.map +1 -1
  37. package/plugin/lib/commonjs/ios/withGoogleServicesJsonFile.js +1 -1
  38. package/plugin/lib/commonjs/ios/withGoogleServicesJsonFile.js.map +1 -1
  39. package/plugin/lib/commonjs/ios/withNotificationsXcodeProject.js +17 -19
  40. package/plugin/lib/commonjs/ios/withNotificationsXcodeProject.js.map +1 -1
  41. package/plugin/lib/commonjs/ios/withXcodeProject.js +1 -1
  42. package/plugin/lib/commonjs/ios/withXcodeProject.js.map +1 -1
  43. package/plugin/lib/commonjs/postInstallHelper.js.map +1 -1
  44. package/plugin/lib/commonjs/types/cio-types.js.map +1 -1
  45. package/plugin/lib/commonjs/utils/android.js +109 -0
  46. package/plugin/lib/commonjs/utils/android.js.map +1 -0
  47. package/plugin/lib/commonjs/utils/config.js +43 -0
  48. package/plugin/lib/commonjs/utils/config.js.map +1 -0
  49. package/plugin/lib/commonjs/utils/plugin.js +49 -0
  50. package/plugin/lib/commonjs/utils/plugin.js.map +1 -0
  51. package/plugin/lib/commonjs/utils/validation.js +44 -0
  52. package/plugin/lib/commonjs/utils/validation.js.map +1 -0
  53. package/plugin/lib/commonjs/utils/xcode.js +67 -0
  54. package/plugin/lib/commonjs/utils/xcode.js.map +1 -0
  55. package/plugin/lib/module/android/withAndroidManifestUpdates.js +4 -4
  56. package/plugin/lib/module/android/withAndroidManifestUpdates.js.map +1 -1
  57. package/plugin/lib/module/android/withCIOAndroid.js +6 -1
  58. package/plugin/lib/module/android/withCIOAndroid.js.map +1 -1
  59. package/plugin/lib/module/android/withGoogleServicesJSON.js +1 -1
  60. package/plugin/lib/module/android/withGoogleServicesJSON.js.map +1 -1
  61. package/plugin/lib/module/android/withMainApplicationModifications.js +38 -0
  62. package/plugin/lib/module/android/withMainApplicationModifications.js.map +1 -0
  63. package/plugin/lib/module/android/withNotificationChannelMetadata.js +1 -1
  64. package/plugin/lib/module/android/withNotificationChannelMetadata.js.map +1 -1
  65. package/plugin/lib/module/android/withProjectStrings.js +13 -6
  66. package/plugin/lib/module/android/withProjectStrings.js.map +1 -1
  67. package/plugin/lib/module/helpers/constants/android.js +6 -0
  68. package/plugin/lib/module/helpers/constants/android.js.map +1 -1
  69. package/plugin/lib/module/helpers/constants/common.js +12 -0
  70. package/plugin/lib/module/helpers/constants/common.js.map +1 -0
  71. package/plugin/lib/module/helpers/constants/ios.js +6 -6
  72. package/plugin/lib/module/helpers/constants/ios.js.map +1 -1
  73. package/plugin/lib/module/helpers/native-files/android/CustomerIOSDKInitializer.kt +64 -0
  74. package/plugin/lib/module/helpers/native-files/ios/CustomerIOSDKInitializer.swift +54 -0
  75. package/plugin/lib/module/helpers/utils/injectCIOPodfileCode.js +2 -2
  76. package/plugin/lib/module/helpers/utils/injectCIOPodfileCode.js.map +1 -1
  77. package/plugin/lib/module/helpers/utils/patchPluginNativeCode.js +57 -0
  78. package/plugin/lib/module/helpers/utils/patchPluginNativeCode.js.map +1 -0
  79. package/plugin/lib/module/index.js +14 -2
  80. package/plugin/lib/module/index.js.map +1 -1
  81. package/plugin/lib/module/ios/utils.js +1 -2
  82. package/plugin/lib/module/ios/utils.js.map +1 -1
  83. package/plugin/lib/module/ios/withAppDelegateModifications.js +3 -3
  84. package/plugin/lib/module/ios/withAppDelegateModifications.js.map +1 -1
  85. package/plugin/lib/module/ios/withCIOIos.js +17 -11
  86. package/plugin/lib/module/ios/withCIOIos.js.map +1 -1
  87. package/plugin/lib/module/ios/withCIOIosSwift.js +134 -50
  88. package/plugin/lib/module/ios/withCIOIosSwift.js.map +1 -1
  89. package/plugin/lib/module/ios/withGoogleServicesJsonFile.js +2 -2
  90. package/plugin/lib/module/ios/withGoogleServicesJsonFile.js.map +1 -1
  91. package/plugin/lib/module/ios/withNotificationsXcodeProject.js +18 -20
  92. package/plugin/lib/module/ios/withNotificationsXcodeProject.js.map +1 -1
  93. package/plugin/lib/module/ios/withXcodeProject.js +1 -1
  94. package/plugin/lib/module/ios/withXcodeProject.js.map +1 -1
  95. package/plugin/lib/module/postInstallHelper.js.map +1 -1
  96. package/plugin/lib/module/types/cio-types.js.map +1 -1
  97. package/plugin/lib/module/utils/android.js +100 -0
  98. package/plugin/lib/module/utils/android.js.map +1 -0
  99. package/plugin/lib/module/utils/config.js +38 -0
  100. package/plugin/lib/module/utils/config.js.map +1 -0
  101. package/plugin/lib/module/utils/plugin.js +38 -0
  102. package/plugin/lib/module/utils/plugin.js.map +1 -0
  103. package/plugin/lib/module/utils/validation.js +39 -0
  104. package/plugin/lib/module/utils/validation.js.map +1 -0
  105. package/plugin/lib/module/utils/xcode.js +60 -0
  106. package/plugin/lib/module/utils/xcode.js.map +1 -0
  107. package/plugin/lib/typescript/android/withCIOAndroid.d.ts +2 -2
  108. package/plugin/lib/typescript/android/withMainApplicationModifications.d.ts +3 -0
  109. package/plugin/lib/typescript/android/withProjectStrings.d.ts +2 -1
  110. package/plugin/lib/typescript/helpers/constants/android.d.ts +3 -0
  111. package/plugin/lib/typescript/helpers/constants/common.d.ts +11 -0
  112. package/plugin/lib/typescript/helpers/constants/ios.d.ts +3 -1
  113. package/plugin/lib/typescript/helpers/utils/patchPluginNativeCode.d.ts +7 -0
  114. package/plugin/lib/typescript/ios/utils.d.ts +2 -2
  115. package/plugin/lib/typescript/ios/withCIOIos.d.ts +2 -2
  116. package/plugin/lib/typescript/ios/withCIOIosSwift.d.ts +3 -3
  117. package/plugin/lib/typescript/types/cio-types.d.ts +46 -6
  118. package/plugin/lib/typescript/utils/android.d.ts +5 -0
  119. package/plugin/lib/typescript/utils/config.d.ts +8 -0
  120. package/plugin/lib/typescript/utils/plugin.d.ts +4 -0
  121. package/plugin/lib/typescript/utils/validation.d.ts +3 -0
  122. package/plugin/lib/typescript/utils/xcode.d.ts +28 -0
  123. package/plugin/src/android/withAndroidManifestUpdates.ts +5 -5
  124. package/plugin/src/android/withCIOAndroid.ts +7 -1
  125. package/plugin/src/android/withGoogleServicesJSON.ts +2 -2
  126. package/plugin/src/android/withMainApplicationModifications.ts +50 -0
  127. package/plugin/src/android/withNotificationChannelMetadata.ts +7 -3
  128. package/plugin/src/android/withProjectStrings.ts +20 -10
  129. package/plugin/src/helpers/constants/android.ts +7 -0
  130. package/plugin/src/helpers/constants/common.ts +12 -0
  131. package/plugin/src/helpers/constants/ios.ts +11 -13
  132. package/plugin/src/helpers/native-files/android/CustomerIOSDKInitializer.kt +64 -0
  133. package/plugin/src/helpers/native-files/ios/CustomerIOSDKInitializer.swift +54 -0
  134. package/plugin/src/helpers/utils/injectCIOPodfileCode.ts +8 -7
  135. package/plugin/src/helpers/utils/patchPluginNativeCode.ts +97 -0
  136. package/plugin/src/index.ts +18 -2
  137. package/plugin/src/ios/utils.ts +5 -5
  138. package/plugin/src/ios/withAppDelegateModifications.ts +11 -8
  139. package/plugin/src/ios/withCIOIos.ts +19 -11
  140. package/plugin/src/ios/withCIOIosSwift.ts +195 -73
  141. package/plugin/src/ios/withGoogleServicesJsonFile.ts +7 -10
  142. package/plugin/src/ios/withNotificationsXcodeProject.ts +25 -26
  143. package/plugin/src/ios/withXcodeProject.ts +1 -1
  144. package/plugin/src/postInstallHelper.js +1 -1
  145. package/plugin/src/types/cio-types.ts +48 -8
  146. package/plugin/src/utils/android.ts +112 -0
  147. package/plugin/src/utils/config.ts +53 -0
  148. package/plugin/src/utils/plugin.ts +46 -0
  149. package/plugin/src/utils/validation.ts +54 -0
  150. package/plugin/src/utils/xcode.ts +74 -0
  151. package/plugin/lib/commonjs/helpers/constants/globals.d.js +0 -2
  152. package/plugin/lib/commonjs/helpers/constants/globals.d.js.map +0 -1
  153. package/plugin/lib/commonjs/helpers/utils/pluginUtils.js +0 -26
  154. package/plugin/lib/commonjs/helpers/utils/pluginUtils.js.map +0 -1
  155. package/plugin/lib/module/helpers/constants/globals.d.js +0 -2
  156. package/plugin/lib/module/helpers/constants/globals.d.js.map +0 -1
  157. package/plugin/lib/module/helpers/utils/pluginUtils.js +0 -19
  158. package/plugin/lib/module/helpers/utils/pluginUtils.js.map +0 -1
  159. package/plugin/lib/typescript/helpers/utils/pluginUtils.d.ts +0 -4
  160. package/plugin/src/helpers/constants/globals.d.ts +0 -8
  161. package/plugin/src/helpers/utils/pluginUtils.ts +0 -22
@@ -0,0 +1 @@
1
+ {"version":3,"names":["PLATFORM","getPluginVersion","patchNativeSDKInitializer","rawContent","platform","sdkConfig","_siteId","_migrationSiteId","content","replaceValue","placeholder","value","transform","fallback","ANDROID","undefined","replace","pluginVersion","cdpApiKey","region","configValue","logLevel","autoTrackDeviceAttributes","toString","trackApplicationLifecycleEvents","screenViewUse","siteId","migrationSiteId","trim"],"sources":["patchPluginNativeCode.ts"],"sourcesContent":["import type { NativeSDKConfig } from '../../types/cio-types';\nimport { PLATFORM, type Platform } from '../constants/common';\nimport { getPluginVersion } from '../../utils/plugin';\n\n/**\n * Shared utility function to perform common SDK config replacements\n * for both iOS and Android template files\n */\nexport function patchNativeSDKInitializer(\n rawContent: string,\n platform: Platform,\n sdkConfig: NativeSDKConfig\n): string {\n let content = rawContent;\n\n // Helper function to replace placeholders with platform-specific fallback values\n const replaceValue = <T>(\n placeholder: RegExp,\n value: T | undefined,\n transform: (configValue: T) => string,\n fallback: string = platform === PLATFORM.ANDROID ? 'null' : 'nil'\n ) => {\n if (value !== undefined && value !== null) {\n content = content.replace(placeholder, transform(value));\n } else {\n content = content.replace(placeholder, fallback);\n }\n };\n\n // Replace EXPO_PLUGIN_VERSION with actual plugin version\n const pluginVersion = getPluginVersion();\n content = content.replace(/\\{\\{EXPO_PLUGIN_VERSION\\}\\}/g, pluginVersion);\n\n // Replace CDP API Key (required field)\n content = content.replace(/\\{\\{CDP_API_KEY\\}\\}/g, sdkConfig.cdpApiKey);\n\n // Handle region - use empty string as fallback (nil not supported for region)\n replaceValue(\n /\\{\\{REGION\\}\\}/g,\n sdkConfig.region,\n (configValue) => `\"${configValue}\"`,\n '\"\"'\n );\n\n // Handle logLevel - use nil/null as fallback\n replaceValue(\n /\\{\\{LOG_LEVEL\\}\\}/g,\n sdkConfig.logLevel,\n (configValue) => `\"${configValue}\"`\n );\n\n // Handle optional boolean configurations\n replaceValue(\n /\\{\\{AUTO_TRACK_DEVICE_ATTRIBUTES\\}\\}/g,\n sdkConfig.autoTrackDeviceAttributes,\n (configValue) => configValue.toString()\n );\n\n replaceValue(\n /\\{\\{TRACK_APPLICATION_LIFECYCLE_EVENTS\\}\\}/g,\n sdkConfig.trackApplicationLifecycleEvents,\n (configValue) => configValue.toString()\n );\n\n // Handle screenViewUse - use nil/null as fallback\n replaceValue(\n /\\{\\{SCREEN_VIEW_USE\\}\\}/g,\n sdkConfig.screenViewUse,\n (configValue) => `\"${configValue}\"`\n );\n\n // Handle siteId/migrationSiteId business logic\n let siteId = sdkConfig.siteId;\n let migrationSiteId = sdkConfig.migrationSiteId;\n\n // Business rule: if only siteId provided, copy to migrationSiteId; if only migrationSiteId provided, set siteId to undefined\n if (siteId && !migrationSiteId) {\n migrationSiteId = siteId;\n } else if (migrationSiteId && !siteId) {\n siteId = undefined;\n }\n\n // Replace siteId and migrationSiteId placeholders (trim whitespace and handle empty strings)\n replaceValue(\n /\\{\\{SITE_ID\\}\\}/g,\n siteId?.trim() || undefined,\n (configValue) => `\"${configValue}\"`\n );\n\n replaceValue(\n /\\{\\{MIGRATION_SITE_ID\\}\\}/g,\n migrationSiteId?.trim() || undefined,\n (configValue) => `\"${configValue}\"`\n );\n\n return content;\n}\n"],"mappings":"AACA,SAASA,QAAQ,QAAuB,qBAAqB;AAC7D,SAASC,gBAAgB,QAAQ,oBAAoB;;AAErD;AACA;AACA;AACA;AACA,OAAO,SAASC,yBAAyBA,CACvCC,UAAkB,EAClBC,QAAkB,EAClBC,SAA0B,EAClB;EAAA,IAAAC,OAAA,EAAAC,gBAAA;EACR,IAAIC,OAAO,GAAGL,UAAU;;EAExB;EACA,MAAMM,YAAY,GAAGA,CACnBC,WAAmB,EACnBC,KAAoB,EACpBC,SAAqC,EACrCC,QAAgB,GAAGT,QAAQ,KAAKJ,QAAQ,CAACc,OAAO,GAAG,MAAM,GAAG,KAAK,KAC9D;IACH,IAAIH,KAAK,KAAKI,SAAS,IAAIJ,KAAK,KAAK,IAAI,EAAE;MACzCH,OAAO,GAAGA,OAAO,CAACQ,OAAO,CAACN,WAAW,EAAEE,SAAS,CAACD,KAAK,CAAC,CAAC;IAC1D,CAAC,MAAM;MACLH,OAAO,GAAGA,OAAO,CAACQ,OAAO,CAACN,WAAW,EAAEG,QAAQ,CAAC;IAClD;EACF,CAAC;;EAED;EACA,MAAMI,aAAa,GAAGhB,gBAAgB,CAAC,CAAC;EACxCO,OAAO,GAAGA,OAAO,CAACQ,OAAO,CAAC,8BAA8B,EAAEC,aAAa,CAAC;;EAExE;EACAT,OAAO,GAAGA,OAAO,CAACQ,OAAO,CAAC,sBAAsB,EAAEX,SAAS,CAACa,SAAS,CAAC;;EAEtE;EACAT,YAAY,CACV,iBAAiB,EACjBJ,SAAS,CAACc,MAAM,EACfC,WAAW,IAAK,IAAIA,WAAW,GAAG,EACnC,IACF,CAAC;;EAED;EACAX,YAAY,CACV,oBAAoB,EACpBJ,SAAS,CAACgB,QAAQ,EACjBD,WAAW,IAAK,IAAIA,WAAW,GAClC,CAAC;;EAED;EACAX,YAAY,CACV,uCAAuC,EACvCJ,SAAS,CAACiB,yBAAyB,EAClCF,WAAW,IAAKA,WAAW,CAACG,QAAQ,CAAC,CACxC,CAAC;EAEDd,YAAY,CACV,6CAA6C,EAC7CJ,SAAS,CAACmB,+BAA+B,EACxCJ,WAAW,IAAKA,WAAW,CAACG,QAAQ,CAAC,CACxC,CAAC;;EAED;EACAd,YAAY,CACV,0BAA0B,EAC1BJ,SAAS,CAACoB,aAAa,EACtBL,WAAW,IAAK,IAAIA,WAAW,GAClC,CAAC;;EAED;EACA,IAAIM,MAAM,GAAGrB,SAAS,CAACqB,MAAM;EAC7B,IAAIC,eAAe,GAAGtB,SAAS,CAACsB,eAAe;;EAE/C;EACA,IAAID,MAAM,IAAI,CAACC,eAAe,EAAE;IAC9BA,eAAe,GAAGD,MAAM;EAC1B,CAAC,MAAM,IAAIC,eAAe,IAAI,CAACD,MAAM,EAAE;IACrCA,MAAM,GAAGX,SAAS;EACpB;;EAEA;EACAN,YAAY,CACV,kBAAkB,EAClB,EAAAH,OAAA,GAAAoB,MAAM,cAAApB,OAAA,uBAANA,OAAA,CAAQsB,IAAI,CAAC,CAAC,KAAIb,SAAS,EAC1BK,WAAW,IAAK,IAAIA,WAAW,GAClC,CAAC;EAEDX,YAAY,CACV,4BAA4B,EAC5B,EAAAF,gBAAA,GAAAoB,eAAe,cAAApB,gBAAA,uBAAfA,gBAAA,CAAiBqB,IAAI,CAAC,CAAC,KAAIb,SAAS,EACnCK,WAAW,IAAK,IAAIA,WAAW,GAClC,CAAC;EAED,OAAOZ,OAAO;AAChB","ignoreList":[]}
@@ -1,12 +1,24 @@
1
1
  import { withCIOAndroid } from './android/withCIOAndroid';
2
+ import { isExpoVersion53OrHigher } from './ios/utils';
2
3
  import { withCIOIos } from './ios/withCIOIos';
4
+ import { validateNativeSDKConfig } from './utils/validation';
5
+
3
6
  // Entry point for config plugin
4
7
  function withCustomerIOPlugin(config, props) {
8
+ // Check if config is being used with unsupported Expo version
9
+ if (props.config && !isExpoVersion53OrHigher(config)) {
10
+ throw new Error('CustomerIO auto initialization (config property) requires Expo SDK 53 or higher. ' + 'Please upgrade to Expo SDK 53+ or use manual initialization instead. ' + 'See documentation for manual setup instructions.');
11
+ }
12
+
13
+ // Validate SDK config if provided
14
+ if (props.config) {
15
+ validateNativeSDKConfig(props.config);
16
+ }
5
17
  if (props.ios) {
6
- config = withCIOIos(config, props.ios);
18
+ config = withCIOIos(config, props.config, props.ios);
7
19
  }
8
20
  if (props.android) {
9
- config = withCIOAndroid(config, props.android);
21
+ config = withCIOAndroid(config, props.config, props.android);
10
22
  }
11
23
  return config;
12
24
  }
@@ -1 +1 @@
1
- {"version":3,"names":["withCIOAndroid","withCIOIos","withCustomerIOPlugin","config","props","ios","android"],"sources":["index.ts"],"sourcesContent":["import type { ExpoConfig } from '@expo/config-types';\n\nimport { withCIOAndroid } from './android/withCIOAndroid';\nimport { withCIOIos } from './ios/withCIOIos';\nimport type { CustomerIOPluginOptions } from './types/cio-types';\n\n// Entry point for config plugin\nfunction withCustomerIOPlugin(\n config: ExpoConfig,\n props: CustomerIOPluginOptions\n) {\n if (props.ios) {\n config = withCIOIos(config, props.ios);\n }\n\n if (props.android) {\n config = withCIOAndroid(config, props.android);\n }\n\n return config;\n}\n\nexport default withCustomerIOPlugin;\n"],"mappings":"AAEA,SAASA,cAAc,QAAQ,0BAA0B;AACzD,SAASC,UAAU,QAAQ,kBAAkB;AAG7C;AACA,SAASC,oBAAoBA,CAC3BC,MAAkB,EAClBC,KAA8B,EAC9B;EACA,IAAIA,KAAK,CAACC,GAAG,EAAE;IACbF,MAAM,GAAGF,UAAU,CAACE,MAAM,EAAEC,KAAK,CAACC,GAAG,CAAC;EACxC;EAEA,IAAID,KAAK,CAACE,OAAO,EAAE;IACjBH,MAAM,GAAGH,cAAc,CAACG,MAAM,EAAEC,KAAK,CAACE,OAAO,CAAC;EAChD;EAEA,OAAOH,MAAM;AACf;AAEA,eAAeD,oBAAoB","ignoreList":[]}
1
+ {"version":3,"names":["withCIOAndroid","isExpoVersion53OrHigher","withCIOIos","validateNativeSDKConfig","withCustomerIOPlugin","config","props","Error","ios","android"],"sources":["index.ts"],"sourcesContent":["import type { ExpoConfig } from '@expo/config-types';\n\nimport { withCIOAndroid } from './android/withCIOAndroid';\nimport { isExpoVersion53OrHigher } from './ios/utils';\nimport { withCIOIos } from './ios/withCIOIos';\nimport type { CustomerIOPluginOptions } from './types/cio-types';\nimport { validateNativeSDKConfig } from './utils/validation';\n\n// Entry point for config plugin\nfunction withCustomerIOPlugin(\n config: ExpoConfig,\n props: CustomerIOPluginOptions\n) {\n // Check if config is being used with unsupported Expo version\n if (props.config && !isExpoVersion53OrHigher(config)) {\n throw new Error(\n 'CustomerIO auto initialization (config property) requires Expo SDK 53 or higher. ' +\n 'Please upgrade to Expo SDK 53+ or use manual initialization instead. ' +\n 'See documentation for manual setup instructions.'\n );\n }\n\n // Validate SDK config if provided\n if (props.config) {\n validateNativeSDKConfig(props.config);\n }\n\n if (props.ios) {\n config = withCIOIos(config, props.config, props.ios);\n }\n\n if (props.android) {\n config = withCIOAndroid(config, props.config, props.android);\n }\n\n return config;\n}\n\nexport default withCustomerIOPlugin;\n"],"mappings":"AAEA,SAASA,cAAc,QAAQ,0BAA0B;AACzD,SAASC,uBAAuB,QAAQ,aAAa;AACrD,SAASC,UAAU,QAAQ,kBAAkB;AAE7C,SAASC,uBAAuB,QAAQ,oBAAoB;;AAE5D;AACA,SAASC,oBAAoBA,CAC3BC,MAAkB,EAClBC,KAA8B,EAC9B;EACA;EACA,IAAIA,KAAK,CAACD,MAAM,IAAI,CAACJ,uBAAuB,CAACI,MAAM,CAAC,EAAE;IACpD,MAAM,IAAIE,KAAK,CACb,mFAAmF,GACnF,uEAAuE,GACvE,kDACF,CAAC;EACH;;EAEA;EACA,IAAID,KAAK,CAACD,MAAM,EAAE;IAChBF,uBAAuB,CAACG,KAAK,CAACD,MAAM,CAAC;EACvC;EAEA,IAAIC,KAAK,CAACE,GAAG,EAAE;IACbH,MAAM,GAAGH,UAAU,CAACG,MAAM,EAAEC,KAAK,CAACD,MAAM,EAAEC,KAAK,CAACE,GAAG,CAAC;EACtD;EAEA,IAAIF,KAAK,CAACG,OAAO,EAAE;IACjBJ,MAAM,GAAGL,cAAc,CAACK,MAAM,EAAEC,KAAK,CAACD,MAAM,EAAEC,KAAK,CAACG,OAAO,CAAC;EAC9D;EAEA,OAAOJ,MAAM;AACf;AAEA,eAAeD,oBAAoB","ignoreList":[]}
@@ -1,7 +1,6 @@
1
1
  import * as semver from 'semver';
2
-
3
2
  /**
4
- * Returns t
3
+ * Returns true if FCM is configured to be used as push provider
5
4
  * @param iosOptions The plugin iOS configuration options
6
5
  * @returns true if FCM is configured to be used as push provider
7
6
  */
@@ -1 +1 @@
1
- {"version":3,"names":["semver","isFcmPushProvider","iosOptions","_iosOptions$pushNotif","pushNotification","provider","isExpoVersion53OrHigher","config","sdkVersion","validVersion","valid","coerce","gte"],"sources":["utils.ts"],"sourcesContent":["import type { CustomerIOPluginOptionsIOS } from '../types/cio-types';\nimport type { ExpoConfig } from '@expo/config-types';\nimport * as semver from 'semver';\n\n/**\n * Returns t\n * @param iosOptions The plugin iOS configuration options\n * @returns true if FCM is configured to be used as push provider\n */\nexport const isFcmPushProvider = (\n iosOptions?: CustomerIOPluginOptionsIOS\n): boolean => {\n return iosOptions?.pushNotification?.provider === 'fcm';\n};\n\nexport const isExpoVersion53OrHigher = (config: ExpoConfig): boolean => {\n const sdkVersion = config.sdkVersion || '';\n \n // If sdkVersion is not a valid semver, coerce it to a valid one if possible\n const validVersion = semver.valid(sdkVersion) || semver.coerce(sdkVersion);\n \n // If we couldn't get a valid version, return false\n if (!validVersion) return false;\n \n // Check if the version is greater than or equal to 53.0.0\n return semver.gte(validVersion, '53.0.0');\n};\n"],"mappings":"AAEA,OAAO,KAAKA,MAAM,MAAM,QAAQ;;AAEhC;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,iBAAiB,GAC5BC,UAAuC,IAC3B;EAAA,IAAAC,qBAAA;EACZ,OAAO,CAAAD,UAAU,aAAVA,UAAU,gBAAAC,qBAAA,GAAVD,UAAU,CAAEE,gBAAgB,cAAAD,qBAAA,uBAA5BA,qBAAA,CAA8BE,QAAQ,MAAK,KAAK;AACzD,CAAC;AAED,OAAO,MAAMC,uBAAuB,GAAIC,MAAkB,IAAc;EACtE,MAAMC,UAAU,GAAGD,MAAM,CAACC,UAAU,IAAI,EAAE;;EAE1C;EACA,MAAMC,YAAY,GAAGT,MAAM,CAACU,KAAK,CAACF,UAAU,CAAC,IAAIR,MAAM,CAACW,MAAM,CAACH,UAAU,CAAC;;EAE1E;EACA,IAAI,CAACC,YAAY,EAAE,OAAO,KAAK;;EAE/B;EACA,OAAOT,MAAM,CAACY,GAAG,CAACH,YAAY,EAAE,QAAQ,CAAC;AAC3C,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["semver","isFcmPushProvider","iosOptions","_iosOptions$pushNotif","pushNotification","provider","isExpoVersion53OrHigher","config","sdkVersion","validVersion","valid","coerce","gte"],"sources":["utils.ts"],"sourcesContent":["import type { ExpoConfig } from '@expo/config-types';\nimport * as semver from 'semver';\nimport type { CustomerIOPluginOptionsIOS } from '../types/cio-types';\n\n/**\n * Returns true if FCM is configured to be used as push provider\n * @param iosOptions The plugin iOS configuration options\n * @returns true if FCM is configured to be used as push provider\n */\nexport const isFcmPushProvider = (\n iosOptions?: CustomerIOPluginOptionsIOS\n): boolean => {\n return iosOptions?.pushNotification?.provider === 'fcm';\n};\n\nexport const isExpoVersion53OrHigher = (config: ExpoConfig): boolean => {\n const sdkVersion = config.sdkVersion || '';\n\n // If sdkVersion is not a valid semver, coerce it to a valid one if possible\n const validVersion = semver.valid(sdkVersion) || semver.coerce(sdkVersion);\n\n // If we couldn't get a valid version, return false\n if (!validVersion) return false;\n\n // Check if the version is greater than or equal to 53.0.0\n return semver.gte(validVersion, '53.0.0');\n};\n"],"mappings":"AACA,OAAO,KAAKA,MAAM,MAAM,QAAQ;AAGhC;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,iBAAiB,GAC5BC,UAAuC,IAC3B;EAAA,IAAAC,qBAAA;EACZ,OAAO,CAAAD,UAAU,aAAVA,UAAU,gBAAAC,qBAAA,GAAVD,UAAU,CAAEE,gBAAgB,cAAAD,qBAAA,uBAA5BA,qBAAA,CAA8BE,QAAQ,MAAK,KAAK;AACzD,CAAC;AAED,OAAO,MAAMC,uBAAuB,GAAIC,MAAkB,IAAc;EACtE,MAAMC,UAAU,GAAGD,MAAM,CAACC,UAAU,IAAI,EAAE;;EAE1C;EACA,MAAMC,YAAY,GAAGT,MAAM,CAACU,KAAK,CAACF,UAAU,CAAC,IAAIR,MAAM,CAACW,MAAM,CAACH,UAAU,CAAC;;EAE1E;EACA,IAAI,CAACC,YAAY,EAAE,OAAO,KAAK;;EAE/B;EACA,OAAOT,MAAM,CAACY,GAAG,CAACH,YAAY,EAAE,QAAQ,CAAC;AAC3C,CAAC","ignoreList":[]}
@@ -1,7 +1,7 @@
1
1
  import { withAppDelegate } from '@expo/config-plugins';
2
2
  import { getAppDelegateHeaderFilePath } from '@expo/config-plugins/build/ios/Paths';
3
- import { CIO_APPDELEGATEDECLARATION_REGEX, CIO_APPDELEGATEHEADER_IMPORT_SNIPPET, CIO_APPDELEGATEHEADER_REGEX, CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET, CIO_CONFIGURECIOSDKPUSHNOTIFICATION_SNIPPET, CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SNIPPET, CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_REGEX, CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_REGEX, CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_SNIPPET, CIO_DIDFINISHLAUNCHINGMETHOD_REGEX, CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_REGEX, CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_SNIPPET, CIO_LAUNCHOPTIONS_DEEPLINK_MODIFIEDOPTIONS_REGEX, CIO_PUSHNOTIFICATIONHANDLERDECLARATION_SNIPPET, CIO_LAUNCHOPTIONS_MODIFIEDOPTIONS_SNIPPET, CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_SNIPPET, CIO_DEEPLINK_COMMENT_REGEX, CIO_INITIALIZECIOSDK_SNIPPET } from '../helpers/constants/ios';
4
- import { injectCodeBeforeMultiLineRegex, injectCodeByLineNumber, injectCodeByMultiLineRegex, injectCodeByMultiLineRegexAndReplaceLine, replaceCodeByRegex, matchRegexExists } from '../helpers/utils/codeInjection';
3
+ import { CIO_APPDELEGATEDECLARATION_REGEX, CIO_APPDELEGATEHEADER_IMPORT_SNIPPET, CIO_APPDELEGATEHEADER_REGEX, CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET, CIO_CONFIGURECIOSDKPUSHNOTIFICATION_SNIPPET, CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SNIPPET, CIO_DEEPLINK_COMMENT_REGEX, CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_REGEX, CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_SNIPPET, CIO_DIDFINISHLAUNCHINGMETHOD_REGEX, CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_REGEX, CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_SNIPPET, CIO_INITIALIZECIOSDK_SNIPPET, CIO_LAUNCHOPTIONS_DEEPLINK_MODIFIEDOPTIONS_REGEX, CIO_LAUNCHOPTIONS_MODIFIEDOPTIONS_SNIPPET, CIO_PUSHNOTIFICATIONHANDLERDECLARATION_SNIPPET, CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_REGEX, CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_SNIPPET } from '../helpers/constants/ios';
4
+ import { injectCodeBeforeMultiLineRegex, injectCodeByLineNumber, injectCodeByMultiLineRegex, injectCodeByMultiLineRegexAndReplaceLine, matchRegexExists, replaceCodeByRegex } from '../helpers/utils/codeInjection';
5
5
  import { FileManagement } from '../helpers/utils/fileManagement';
6
6
  import { isFcmPushProvider } from './utils';
7
7
  const addImport = (stringContents, appName) => {
@@ -85,7 +85,7 @@ const addHandleDeeplinkInKilledState = stringContents => {
85
85
  }
86
86
 
87
87
  // Check if the app delegate is using RCTBridge or LaunchOptions
88
- let snippet = undefined;
88
+ let snippet;
89
89
  let regex = CIO_LAUNCHOPTIONS_DEEPLINK_MODIFIEDOPTIONS_REGEX;
90
90
  if (matchRegexExists(stringContents, CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_REGEX)) {
91
91
  snippet = CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_SNIPPET;
@@ -1 +1 @@
1
- {"version":3,"names":["withAppDelegate","getAppDelegateHeaderFilePath","CIO_APPDELEGATEDECLARATION_REGEX","CIO_APPDELEGATEHEADER_IMPORT_SNIPPET","CIO_APPDELEGATEHEADER_REGEX","CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET","CIO_CONFIGURECIOSDKPUSHNOTIFICATION_SNIPPET","CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SNIPPET","CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_REGEX","CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_REGEX","CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_SNIPPET","CIO_DIDFINISHLAUNCHINGMETHOD_REGEX","CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_REGEX","CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_SNIPPET","CIO_LAUNCHOPTIONS_DEEPLINK_MODIFIEDOPTIONS_REGEX","CIO_PUSHNOTIFICATIONHANDLERDECLARATION_SNIPPET","CIO_LAUNCHOPTIONS_MODIFIEDOPTIONS_SNIPPET","CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_SNIPPET","CIO_DEEPLINK_COMMENT_REGEX","CIO_INITIALIZECIOSDK_SNIPPET","injectCodeBeforeMultiLineRegex","injectCodeByLineNumber","injectCodeByMultiLineRegex","injectCodeByMultiLineRegexAndReplaceLine","replaceCodeByRegex","matchRegexExists","FileManagement","isFcmPushProvider","addImport","stringContents","appName","importRegex","addedImport","getImportSnippet","match","endOfMatchIndex","index","undefined","length","addNotificationHandlerDeclaration","addNotificationConfiguration","addInitializeNativeCioSdk","addHandleDeeplinkInKilledStateConfiguration","regex","addDidFailToRegisterForRemoteNotificationsWithError","addDidRegisterForRemoteNotificationsWithDeviceToken","addExpoNotificationsHeaderModification","addFirebaseDelegateForwardDeclarationIfNeeded","addAppdelegateHeaderModification","replace","interfaceDeclaration","_groupedDelegates","existingDelegates","includes","trim","addHandleDeeplinkInKilledState","snippet","withAppDelegateModifications","configOuter","props","config","modResults","contents","RegExp","modRequest","projectName","_props$pushNotificati","_props$pushNotificati2","headerPath","projectRoot","headerContent","read","write","pushNotification","disableNotificationRegistration","handleDeeplinkInKilledState","console","log"],"sources":["withAppDelegateModifications.ts"],"sourcesContent":["import type { ConfigPlugin } from '@expo/config-plugins';\nimport { withAppDelegate } from '@expo/config-plugins';\nimport { getAppDelegateHeaderFilePath } from '@expo/config-plugins/build/ios/Paths';\n\nimport {\n CIO_APPDELEGATEDECLARATION_REGEX,\n CIO_APPDELEGATEHEADER_IMPORT_SNIPPET,\n CIO_APPDELEGATEHEADER_REGEX,\n CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET,\n CIO_CONFIGURECIOSDKPUSHNOTIFICATION_SNIPPET,\n CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SNIPPET,\n CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_REGEX,\n CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_REGEX,\n CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_SNIPPET,\n CIO_DIDFINISHLAUNCHINGMETHOD_REGEX,\n CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_REGEX,\n CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_SNIPPET,\n CIO_LAUNCHOPTIONS_DEEPLINK_MODIFIEDOPTIONS_REGEX,\n CIO_PUSHNOTIFICATIONHANDLERDECLARATION_SNIPPET,\n CIO_LAUNCHOPTIONS_MODIFIEDOPTIONS_SNIPPET,\n CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_SNIPPET,\n CIO_DEEPLINK_COMMENT_REGEX,\n CIO_INITIALIZECIOSDK_SNIPPET,\n} from '../helpers/constants/ios';\nimport {\n injectCodeBeforeMultiLineRegex,\n injectCodeByLineNumber,\n injectCodeByMultiLineRegex,\n injectCodeByMultiLineRegexAndReplaceLine,\n replaceCodeByRegex,\n matchRegexExists,\n} from '../helpers/utils/codeInjection';\nimport { FileManagement } from '../helpers/utils/fileManagement';\nimport type { CustomerIOPluginOptionsIOS } from '../types/cio-types';\nimport { isFcmPushProvider } from './utils';\n\nconst addImport = (stringContents: string, appName: string) => {\n const importRegex = /^(#import .*)\\n/gm;\n const addedImport = getImportSnippet(appName);\n\n const match = stringContents.match(importRegex);\n let endOfMatchIndex: number;\n if (!match || match.index === undefined) {\n // No imports found, just add to start of file:\n endOfMatchIndex = 0;\n } else {\n // Add after first import:\n endOfMatchIndex = match.index + match[0].length;\n }\n\n stringContents = injectCodeByLineNumber(\n stringContents,\n endOfMatchIndex,\n addedImport\n );\n\n return stringContents;\n};\n\nconst addNotificationHandlerDeclaration = (stringContents: string) => {\n stringContents = injectCodeByMultiLineRegex(\n stringContents,\n CIO_APPDELEGATEDECLARATION_REGEX,\n CIO_PUSHNOTIFICATIONHANDLERDECLARATION_SNIPPET\n );\n\n return stringContents;\n};\n\nconst addNotificationConfiguration = (stringContents: string) => {\n stringContents = injectCodeBeforeMultiLineRegex(\n stringContents,\n CIO_DIDFINISHLAUNCHINGMETHOD_REGEX,\n CIO_CONFIGURECIOSDKPUSHNOTIFICATION_SNIPPET\n );\n\n return stringContents;\n};\n\nconst addInitializeNativeCioSdk = (stringContents: string) => {\n stringContents = injectCodeBeforeMultiLineRegex(\n stringContents,\n CIO_DIDFINISHLAUNCHINGMETHOD_REGEX,\n CIO_INITIALIZECIOSDK_SNIPPET\n );\n\n return stringContents;\n};\n\nconst addHandleDeeplinkInKilledStateConfiguration = (\n stringContents: string,\n regex: RegExp\n) => {\n stringContents = injectCodeBeforeMultiLineRegex(\n stringContents,\n regex,\n CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SNIPPET\n );\n\n return stringContents;\n};\n\nconst addDidFailToRegisterForRemoteNotificationsWithError = (\n stringContents: string\n) => {\n stringContents = injectCodeByMultiLineRegexAndReplaceLine(\n stringContents,\n CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_REGEX,\n CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_SNIPPET\n );\n\n return stringContents;\n};\n\nconst addDidRegisterForRemoteNotificationsWithDeviceToken = (\n stringContents: string\n) => {\n stringContents = injectCodeByMultiLineRegexAndReplaceLine(\n stringContents,\n CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_REGEX,\n CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_SNIPPET\n );\n\n return stringContents;\n};\n\n// Adds required import for Expo Notifications package in AppDelegate.\n// Required to call functions from the package.\nconst addExpoNotificationsHeaderModification = (stringContents: string) => {\n stringContents = injectCodeByLineNumber(\n stringContents,\n 0,\n `\n#if __has_include(<EXNotifications/EXNotificationCenterDelegate.h>)\n#import <EXNotifications/EXNotificationCenterDelegate.h>\n#endif\n`\n );\n\n return stringContents;\n};\n\nconst addFirebaseDelegateForwardDeclarationIfNeeded = (stringContents: string) => {\n stringContents = injectCodeByLineNumber(\n stringContents,\n 0,\n '@protocol FIRMessagingDelegate;'\n );\n\n return stringContents;\n};\n\nconst addAppdelegateHeaderModification = (stringContents: string) => {\n // Add UNUserNotificationCenterDelegate if needed\n stringContents = stringContents.replace(\n CIO_APPDELEGATEHEADER_REGEX,\n (match, interfaceDeclaration, _groupedDelegates, existingDelegates) => {\n if (\n existingDelegates &&\n existingDelegates.includes(\n CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET\n )\n ) {\n // The AppDelegate declaration already includes UNUserNotificationCenterDelegate, so we don't need to modify it\n return match;\n } else if (existingDelegates) {\n // Other delegates exist, append ours\n return `${CIO_APPDELEGATEHEADER_IMPORT_SNIPPET}\n${interfaceDeclaration}<${existingDelegates}, ${CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET}>\n`;\n } else {\n // No delegates exist, add ours\n return `${CIO_APPDELEGATEHEADER_IMPORT_SNIPPET}\n${interfaceDeclaration.trim()} <${CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET}>\n`;\n }\n }\n );\n\n return stringContents;\n};\n\nconst addHandleDeeplinkInKilledState = (stringContents: string) => {\n // Find if the deep link code snippet is already present\n if (matchRegexExists(stringContents, CIO_DEEPLINK_COMMENT_REGEX)) {\n return stringContents;\n }\n\n // Check if the app delegate is using RCTBridge or LaunchOptions\n let snippet = undefined;\n let regex = CIO_LAUNCHOPTIONS_DEEPLINK_MODIFIEDOPTIONS_REGEX;\n if (\n matchRegexExists(\n stringContents,\n CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_REGEX\n )\n ) {\n snippet = CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_SNIPPET;\n regex = CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_REGEX;\n } else if (\n matchRegexExists(\n stringContents,\n CIO_LAUNCHOPTIONS_DEEPLINK_MODIFIEDOPTIONS_REGEX\n )\n ) {\n snippet = CIO_LAUNCHOPTIONS_MODIFIEDOPTIONS_SNIPPET;\n }\n // Add code only if the app delegate is using RCTBridge or LaunchOptions\n if (snippet !== undefined) {\n stringContents = addHandleDeeplinkInKilledStateConfiguration(\n stringContents,\n regex\n );\n stringContents = replaceCodeByRegex(stringContents, regex, snippet);\n }\n return stringContents;\n};\n\nexport const withAppDelegateModifications: ConfigPlugin<\n CustomerIOPluginOptionsIOS\n> = (configOuter, props) => {\n return withAppDelegate(configOuter, async (config) => {\n let stringContents = config.modResults.contents;\n const regex = new RegExp(\n `#import <${config.modRequest.projectName}-Swift.h>`\n );\n const match = stringContents.match(regex);\n\n if (!match) {\n const headerPath = getAppDelegateHeaderFilePath(\n config.modRequest.projectRoot\n );\n let headerContent = await FileManagement.read(headerPath);\n headerContent = addAppdelegateHeaderModification(headerContent);\n FileManagement.write(headerPath, headerContent);\n\n stringContents = addImport(\n stringContents,\n config.modRequest.projectName as string\n );\n stringContents = addNotificationHandlerDeclaration(stringContents);\n\n // unless this property is explicity set to true, push notification\n // registration will be added to the AppDelegate\n if (props.pushNotification?.disableNotificationRegistration !== true) {\n stringContents = addNotificationConfiguration(stringContents);\n }\n\n stringContents = addInitializeNativeCioSdk(stringContents);\n\n if (props.pushNotification?.handleDeeplinkInKilledState === true) {\n stringContents = addHandleDeeplinkInKilledState(stringContents);\n }\n\n stringContents =\n addDidFailToRegisterForRemoteNotificationsWithError(stringContents);\n stringContents =\n addDidRegisterForRemoteNotificationsWithDeviceToken(stringContents);\n\n if (isFcmPushProvider(props)) {\n stringContents = addFirebaseDelegateForwardDeclarationIfNeeded(stringContents);\n }\n\n stringContents = addExpoNotificationsHeaderModification(stringContents);\n\n config.modResults.contents = stringContents;\n } else {\n console.log('Customerio AppDelegate changes already exist. Skipping...');\n }\n\n return config;\n });\n};\nfunction getImportSnippet(appName: string) {\n return `\n// Add swift bridge imports\n#import <ExpoModulesCore-Swift.h>\n#import <${appName}-Swift.h>\n `;\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["withAppDelegate","getAppDelegateHeaderFilePath","CIO_APPDELEGATEDECLARATION_REGEX","CIO_APPDELEGATEHEADER_IMPORT_SNIPPET","CIO_APPDELEGATEHEADER_REGEX","CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET","CIO_CONFIGURECIOSDKPUSHNOTIFICATION_SNIPPET","CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SNIPPET","CIO_DEEPLINK_COMMENT_REGEX","CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_REGEX","CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_SNIPPET","CIO_DIDFINISHLAUNCHINGMETHOD_REGEX","CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_REGEX","CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_SNIPPET","CIO_INITIALIZECIOSDK_SNIPPET","CIO_LAUNCHOPTIONS_DEEPLINK_MODIFIEDOPTIONS_REGEX","CIO_LAUNCHOPTIONS_MODIFIEDOPTIONS_SNIPPET","CIO_PUSHNOTIFICATIONHANDLERDECLARATION_SNIPPET","CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_REGEX","CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_SNIPPET","injectCodeBeforeMultiLineRegex","injectCodeByLineNumber","injectCodeByMultiLineRegex","injectCodeByMultiLineRegexAndReplaceLine","matchRegexExists","replaceCodeByRegex","FileManagement","isFcmPushProvider","addImport","stringContents","appName","importRegex","addedImport","getImportSnippet","match","endOfMatchIndex","index","undefined","length","addNotificationHandlerDeclaration","addNotificationConfiguration","addInitializeNativeCioSdk","addHandleDeeplinkInKilledStateConfiguration","regex","addDidFailToRegisterForRemoteNotificationsWithError","addDidRegisterForRemoteNotificationsWithDeviceToken","addExpoNotificationsHeaderModification","addFirebaseDelegateForwardDeclarationIfNeeded","addAppdelegateHeaderModification","replace","interfaceDeclaration","_groupedDelegates","existingDelegates","includes","trim","addHandleDeeplinkInKilledState","snippet","withAppDelegateModifications","configOuter","props","config","modResults","contents","RegExp","modRequest","projectName","_props$pushNotificati","_props$pushNotificati2","headerPath","projectRoot","headerContent","read","write","pushNotification","disableNotificationRegistration","handleDeeplinkInKilledState","console","log"],"sources":["withAppDelegateModifications.ts"],"sourcesContent":["import type { ConfigPlugin } from '@expo/config-plugins';\nimport { withAppDelegate } from '@expo/config-plugins';\nimport { getAppDelegateHeaderFilePath } from '@expo/config-plugins/build/ios/Paths';\n\nimport {\n CIO_APPDELEGATEDECLARATION_REGEX,\n CIO_APPDELEGATEHEADER_IMPORT_SNIPPET,\n CIO_APPDELEGATEHEADER_REGEX,\n CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET,\n CIO_CONFIGURECIOSDKPUSHNOTIFICATION_SNIPPET,\n CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SNIPPET,\n CIO_DEEPLINK_COMMENT_REGEX,\n CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_REGEX,\n CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_SNIPPET,\n CIO_DIDFINISHLAUNCHINGMETHOD_REGEX,\n CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_REGEX,\n CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_SNIPPET,\n CIO_INITIALIZECIOSDK_SNIPPET,\n CIO_LAUNCHOPTIONS_DEEPLINK_MODIFIEDOPTIONS_REGEX,\n CIO_LAUNCHOPTIONS_MODIFIEDOPTIONS_SNIPPET,\n CIO_PUSHNOTIFICATIONHANDLERDECLARATION_SNIPPET,\n CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_REGEX,\n CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_SNIPPET,\n} from '../helpers/constants/ios';\nimport {\n injectCodeBeforeMultiLineRegex,\n injectCodeByLineNumber,\n injectCodeByMultiLineRegex,\n injectCodeByMultiLineRegexAndReplaceLine,\n matchRegexExists,\n replaceCodeByRegex,\n} from '../helpers/utils/codeInjection';\nimport { FileManagement } from '../helpers/utils/fileManagement';\nimport type { CustomerIOPluginOptionsIOS } from '../types/cio-types';\nimport { isFcmPushProvider } from './utils';\n\nconst addImport = (stringContents: string, appName: string) => {\n const importRegex = /^(#import .*)\\n/gm;\n const addedImport = getImportSnippet(appName);\n\n const match = stringContents.match(importRegex);\n let endOfMatchIndex: number;\n if (!match || match.index === undefined) {\n // No imports found, just add to start of file:\n endOfMatchIndex = 0;\n } else {\n // Add after first import:\n endOfMatchIndex = match.index + match[0].length;\n }\n\n stringContents = injectCodeByLineNumber(\n stringContents,\n endOfMatchIndex,\n addedImport\n );\n\n return stringContents;\n};\n\nconst addNotificationHandlerDeclaration = (stringContents: string) => {\n stringContents = injectCodeByMultiLineRegex(\n stringContents,\n CIO_APPDELEGATEDECLARATION_REGEX,\n CIO_PUSHNOTIFICATIONHANDLERDECLARATION_SNIPPET\n );\n\n return stringContents;\n};\n\nconst addNotificationConfiguration = (stringContents: string) => {\n stringContents = injectCodeBeforeMultiLineRegex(\n stringContents,\n CIO_DIDFINISHLAUNCHINGMETHOD_REGEX,\n CIO_CONFIGURECIOSDKPUSHNOTIFICATION_SNIPPET\n );\n\n return stringContents;\n};\n\nconst addInitializeNativeCioSdk = (stringContents: string) => {\n stringContents = injectCodeBeforeMultiLineRegex(\n stringContents,\n CIO_DIDFINISHLAUNCHINGMETHOD_REGEX,\n CIO_INITIALIZECIOSDK_SNIPPET\n );\n\n return stringContents;\n};\n\nconst addHandleDeeplinkInKilledStateConfiguration = (\n stringContents: string,\n regex: RegExp\n) => {\n stringContents = injectCodeBeforeMultiLineRegex(\n stringContents,\n regex,\n CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SNIPPET\n );\n\n return stringContents;\n};\n\nconst addDidFailToRegisterForRemoteNotificationsWithError = (\n stringContents: string\n) => {\n stringContents = injectCodeByMultiLineRegexAndReplaceLine(\n stringContents,\n CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_REGEX,\n CIO_DIDFAILTOREGISTERFORREMOTENOTIFICATIONSWITHERROR_SNIPPET\n );\n\n return stringContents;\n};\n\nconst addDidRegisterForRemoteNotificationsWithDeviceToken = (\n stringContents: string\n) => {\n stringContents = injectCodeByMultiLineRegexAndReplaceLine(\n stringContents,\n CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_REGEX,\n CIO_DIDREGISTERFORREMOTENOTIFICATIONSWITHDEVICETOKEN_SNIPPET\n );\n\n return stringContents;\n};\n\n// Adds required import for Expo Notifications package in AppDelegate.\n// Required to call functions from the package.\nconst addExpoNotificationsHeaderModification = (stringContents: string) => {\n stringContents = injectCodeByLineNumber(\n stringContents,\n 0,\n `\n#if __has_include(<EXNotifications/EXNotificationCenterDelegate.h>)\n#import <EXNotifications/EXNotificationCenterDelegate.h>\n#endif\n`\n );\n\n return stringContents;\n};\n\nconst addFirebaseDelegateForwardDeclarationIfNeeded = (\n stringContents: string\n) => {\n stringContents = injectCodeByLineNumber(\n stringContents,\n 0,\n '@protocol FIRMessagingDelegate;'\n );\n\n return stringContents;\n};\n\nconst addAppdelegateHeaderModification = (stringContents: string) => {\n // Add UNUserNotificationCenterDelegate if needed\n stringContents = stringContents.replace(\n CIO_APPDELEGATEHEADER_REGEX,\n (match, interfaceDeclaration, _groupedDelegates, existingDelegates) => {\n if (\n existingDelegates &&\n existingDelegates.includes(\n CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET\n )\n ) {\n // The AppDelegate declaration already includes UNUserNotificationCenterDelegate, so we don't need to modify it\n return match;\n } else if (existingDelegates) {\n // Other delegates exist, append ours\n return `${CIO_APPDELEGATEHEADER_IMPORT_SNIPPET}\n${interfaceDeclaration}<${existingDelegates}, ${CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET}>\n`;\n } else {\n // No delegates exist, add ours\n return `${CIO_APPDELEGATEHEADER_IMPORT_SNIPPET}\n${interfaceDeclaration.trim()} <${CIO_APPDELEGATEHEADER_USER_NOTIFICATION_CENTER_SNIPPET}>\n`;\n }\n }\n );\n\n return stringContents;\n};\n\nconst addHandleDeeplinkInKilledState = (stringContents: string) => {\n // Find if the deep link code snippet is already present\n if (matchRegexExists(stringContents, CIO_DEEPLINK_COMMENT_REGEX)) {\n return stringContents;\n }\n\n // Check if the app delegate is using RCTBridge or LaunchOptions\n let snippet;\n let regex = CIO_LAUNCHOPTIONS_DEEPLINK_MODIFIEDOPTIONS_REGEX;\n if (\n matchRegexExists(\n stringContents,\n CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_REGEX\n )\n ) {\n snippet = CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_SNIPPET;\n regex = CIO_RCTBRIDGE_DEEPLINK_MODIFIEDOPTIONS_REGEX;\n } else if (\n matchRegexExists(\n stringContents,\n CIO_LAUNCHOPTIONS_DEEPLINK_MODIFIEDOPTIONS_REGEX\n )\n ) {\n snippet = CIO_LAUNCHOPTIONS_MODIFIEDOPTIONS_SNIPPET;\n }\n // Add code only if the app delegate is using RCTBridge or LaunchOptions\n if (snippet !== undefined) {\n stringContents = addHandleDeeplinkInKilledStateConfiguration(\n stringContents,\n regex\n );\n stringContents = replaceCodeByRegex(stringContents, regex, snippet);\n }\n return stringContents;\n};\n\nexport const withAppDelegateModifications: ConfigPlugin<\n CustomerIOPluginOptionsIOS\n> = (configOuter, props) => {\n return withAppDelegate(configOuter, async (config) => {\n let stringContents = config.modResults.contents;\n const regex = new RegExp(\n `#import <${config.modRequest.projectName}-Swift.h>`\n );\n const match = stringContents.match(regex);\n\n if (!match) {\n const headerPath = getAppDelegateHeaderFilePath(\n config.modRequest.projectRoot\n );\n let headerContent = await FileManagement.read(headerPath);\n headerContent = addAppdelegateHeaderModification(headerContent);\n FileManagement.write(headerPath, headerContent);\n\n stringContents = addImport(\n stringContents,\n config.modRequest.projectName as string\n );\n stringContents = addNotificationHandlerDeclaration(stringContents);\n\n // unless this property is explicity set to true, push notification\n // registration will be added to the AppDelegate\n if (props.pushNotification?.disableNotificationRegistration !== true) {\n stringContents = addNotificationConfiguration(stringContents);\n }\n\n stringContents = addInitializeNativeCioSdk(stringContents);\n\n if (props.pushNotification?.handleDeeplinkInKilledState === true) {\n stringContents = addHandleDeeplinkInKilledState(stringContents);\n }\n\n stringContents =\n addDidFailToRegisterForRemoteNotificationsWithError(stringContents);\n stringContents =\n addDidRegisterForRemoteNotificationsWithDeviceToken(stringContents);\n\n if (isFcmPushProvider(props)) {\n stringContents =\n addFirebaseDelegateForwardDeclarationIfNeeded(stringContents);\n }\n\n stringContents = addExpoNotificationsHeaderModification(stringContents);\n\n config.modResults.contents = stringContents;\n } else {\n console.log('Customerio AppDelegate changes already exist. Skipping...');\n }\n\n return config;\n });\n};\nfunction getImportSnippet(appName: string) {\n return `\n// Add swift bridge imports\n#import <ExpoModulesCore-Swift.h>\n#import <${appName}-Swift.h>\n `;\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,21 +1,27 @@
1
+ import { mergeConfigWithEnvValues } from '../utils/config';
2
+ import { isExpoVersion53OrHigher } from './utils';
1
3
  import { withAppDelegateModifications } from './withAppDelegateModifications';
4
+ import { withCIOIosSwift } from './withCIOIosSwift';
5
+ import { withGoogleServicesJsonFile } from './withGoogleServicesJsonFile';
2
6
  import { withCioNotificationsXcodeProject } from './withNotificationsXcodeProject';
3
7
  import { withCioXcodeProject } from './withXcodeProject';
4
- import { withGoogleServicesJsonFile } from './withGoogleServicesJsonFile';
5
- import { withCIOIosSwift } from './withCIOIosSwift';
6
- import { isExpoVersion53OrHigher } from './utils';
7
- export function withCIOIos(config, props) {
8
- const cioProps = mergeDeprecatedPropertiesAndLogWarnings(props);
8
+ export function withCIOIos(config, sdkConfig, props) {
9
9
  const isSwiftProject = isExpoVersion53OrHigher(config);
10
- if (cioProps.pushNotification) {
10
+ const platformConfig = mergeDeprecatedPropertiesAndLogWarnings(props);
11
+ if (platformConfig.pushNotification) {
11
12
  if (isSwiftProject) {
12
- config = withCIOIosSwift(config, cioProps);
13
+ config = withCIOIosSwift(config, sdkConfig, platformConfig);
13
14
  } else {
14
- config = withAppDelegateModifications(config, cioProps);
15
+ // Auto initialization is only supported in Swift projects (Expo SDK 53+)
16
+ // Legacy Objective-C projects only support push notifications
17
+ config = withAppDelegateModifications(config, platformConfig);
15
18
  }
16
- config = withCioNotificationsXcodeProject(config, cioProps);
17
- config = withCioXcodeProject(config, cioProps);
18
- config = withGoogleServicesJsonFile(config, cioProps);
19
+ platformConfig.pushNotification.env = platformConfig.pushNotification.env || mergeConfigWithEnvValues(platformConfig, sdkConfig);
20
+ config = withCioNotificationsXcodeProject(config, platformConfig);
21
+ config = withCioXcodeProject(config, platformConfig);
22
+ config = withGoogleServicesJsonFile(config, platformConfig);
23
+ } else if (sdkConfig && isSwiftProject) {
24
+ config = withCIOIosSwift(config, sdkConfig, platformConfig);
19
25
  }
20
26
  return config;
21
27
  }
@@ -1 +1 @@
1
- {"version":3,"names":["withAppDelegateModifications","withCioNotificationsXcodeProject","withCioXcodeProject","withGoogleServicesJsonFile","withCIOIosSwift","isExpoVersion53OrHigher","withCIOIos","config","props","cioProps","mergeDeprecatedPropertiesAndLogWarnings","isSwiftProject","pushNotification","deprecatedTopLevelProperties","showPushAppInForeground","autoTrackPushEvents","handleDeeplinkInKilledState","disableNotificationRegistration","autoFetchDeviceToken","Object","entries","forEach","key","value","undefined","console","warn","propKey"],"sources":["withCIOIos.ts"],"sourcesContent":["import type { ExpoConfig } from '@expo/config-types';\n\nimport type {\n CustomerIOPluginOptionsIOS,\n CustomerIOPluginPushNotificationOptions,\n} from '../types/cio-types';\nimport { withAppDelegateModifications } from './withAppDelegateModifications';\nimport { withCioNotificationsXcodeProject } from './withNotificationsXcodeProject';\nimport { withCioXcodeProject } from './withXcodeProject';\nimport { withGoogleServicesJsonFile } from './withGoogleServicesJsonFile';\nimport { withCIOIosSwift } from './withCIOIosSwift';\nimport { isExpoVersion53OrHigher } from './utils';\n\nexport function withCIOIos(\n config: ExpoConfig,\n props: CustomerIOPluginOptionsIOS\n) {\n const cioProps = mergeDeprecatedPropertiesAndLogWarnings(props);\n const isSwiftProject = isExpoVersion53OrHigher(config);\n\n if (cioProps.pushNotification) {\n if (isSwiftProject) {\n config = withCIOIosSwift(config, cioProps);\n } else {\n config = withAppDelegateModifications(config, cioProps);\n }\n\n config = withCioNotificationsXcodeProject(config, cioProps);\n config = withCioXcodeProject(config, cioProps);\n config = withGoogleServicesJsonFile(config, cioProps);\n }\n\n return config;\n}\n\n/** The basic purpose of this function is to centralize where we handle the deprecation\n by merging the deprecated properties into the new ios.pushNotification.* properties\n and logging a warning if they are set. This way, we can remove the deprecated properties\n from the top level of the ios object in the future, and update this function\n while the rest of the plugin code remains unchanged.\n*/\nconst mergeDeprecatedPropertiesAndLogWarnings = (\n props: CustomerIOPluginOptionsIOS\n) => {\n // The deprecatedTopLevelProperties maps the top level properties\n // that are deprecated to the new ios.pushNotification.* properties\n // that should be used instead. The deprecated properties are\n // still available for backwards compatibility, but they will\n // be removed in the future.\n\n const deprecatedTopLevelProperties = {\n showPushAppInForeground: props.showPushAppInForeground,\n autoTrackPushEvents: props.autoTrackPushEvents,\n handleDeeplinkInKilledState: props.handleDeeplinkInKilledState,\n disableNotificationRegistration: props.disableNotificationRegistration,\n autoFetchDeviceToken: props.autoFetchDeviceToken,\n };\n\n // loop over all the deprecated properties and log a warning if they are set\n Object.entries(deprecatedTopLevelProperties).forEach(([key, value]) => {\n if (value !== undefined) {\n console.warn(\n `The ios.${key} property is deprecated. Please use ios.pushNotification.${key} instead.`\n );\n\n if (props.pushNotification === undefined) {\n props.pushNotification = {} as CustomerIOPluginPushNotificationOptions;\n }\n const propKey = key as keyof CustomerIOPluginPushNotificationOptions;\n if (props.pushNotification[propKey] === undefined) {\n props.pushNotification = {\n ...props.pushNotification,\n [propKey]: value,\n };\n } else {\n console.warn(\n `The ios.${key} property is deprecated. Since the value of ios.pushNotification.${key} is set, it will be used.`\n );\n }\n }\n });\n\n return props;\n};\n\n"],"mappings":"AAMA,SAASA,4BAA4B,QAAQ,gCAAgC;AAC7E,SAASC,gCAAgC,QAAQ,iCAAiC;AAClF,SAASC,mBAAmB,QAAQ,oBAAoB;AACxD,SAASC,0BAA0B,QAAQ,8BAA8B;AACzE,SAASC,eAAe,QAAQ,mBAAmB;AACnD,SAASC,uBAAuB,QAAQ,SAAS;AAEjD,OAAO,SAASC,UAAUA,CACxBC,MAAkB,EAClBC,KAAiC,EACjC;EACA,MAAMC,QAAQ,GAAGC,uCAAuC,CAACF,KAAK,CAAC;EAC/D,MAAMG,cAAc,GAAGN,uBAAuB,CAACE,MAAM,CAAC;EAEtD,IAAIE,QAAQ,CAACG,gBAAgB,EAAE;IAC7B,IAAID,cAAc,EAAE;MAClBJ,MAAM,GAAGH,eAAe,CAACG,MAAM,EAAEE,QAAQ,CAAC;IAC5C,CAAC,MAAM;MACLF,MAAM,GAAGP,4BAA4B,CAACO,MAAM,EAAEE,QAAQ,CAAC;IACzD;IAEAF,MAAM,GAAGN,gCAAgC,CAACM,MAAM,EAAEE,QAAQ,CAAC;IAC3DF,MAAM,GAAGL,mBAAmB,CAACK,MAAM,EAAEE,QAAQ,CAAC;IAC9CF,MAAM,GAAGJ,0BAA0B,CAACI,MAAM,EAAEE,QAAQ,CAAC;EACvD;EAEA,OAAOF,MAAM;AACf;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,MAAMG,uCAAuC,GAC3CF,KAAiC,IAC9B;EACH;EACA;EACA;EACA;EACA;;EAEA,MAAMK,4BAA4B,GAAG;IACnCC,uBAAuB,EAAEN,KAAK,CAACM,uBAAuB;IACtDC,mBAAmB,EAAEP,KAAK,CAACO,mBAAmB;IAC9CC,2BAA2B,EAAER,KAAK,CAACQ,2BAA2B;IAC9DC,+BAA+B,EAAET,KAAK,CAACS,+BAA+B;IACtEC,oBAAoB,EAAEV,KAAK,CAACU;EAC9B,CAAC;;EAED;EACAC,MAAM,CAACC,OAAO,CAACP,4BAA4B,CAAC,CAACQ,OAAO,CAAC,CAAC,CAACC,GAAG,EAAEC,KAAK,CAAC,KAAK;IACrE,IAAIA,KAAK,KAAKC,SAAS,EAAE;MACvBC,OAAO,CAACC,IAAI,CACV,WAAWJ,GAAG,4DAA4DA,GAAG,WAC/E,CAAC;MAED,IAAId,KAAK,CAACI,gBAAgB,KAAKY,SAAS,EAAE;QACxChB,KAAK,CAACI,gBAAgB,GAAG,CAAC,CAA4C;MACxE;MACA,MAAMe,OAAO,GAAGL,GAAoD;MACpE,IAAId,KAAK,CAACI,gBAAgB,CAACe,OAAO,CAAC,KAAKH,SAAS,EAAE;QACjDhB,KAAK,CAACI,gBAAgB,GAAG;UACvB,GAAGJ,KAAK,CAACI,gBAAgB;UACzB,CAACe,OAAO,GAAGJ;QACb,CAAC;MACH,CAAC,MAAM;QACLE,OAAO,CAACC,IAAI,CACV,WAAWJ,GAAG,oEAAoEA,GAAG,2BACvF,CAAC;MACH;IACF;EACF,CAAC,CAAC;EAEF,OAAOd,KAAK;AACd,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["mergeConfigWithEnvValues","isExpoVersion53OrHigher","withAppDelegateModifications","withCIOIosSwift","withGoogleServicesJsonFile","withCioNotificationsXcodeProject","withCioXcodeProject","withCIOIos","config","sdkConfig","props","isSwiftProject","platformConfig","mergeDeprecatedPropertiesAndLogWarnings","pushNotification","env","deprecatedTopLevelProperties","showPushAppInForeground","autoTrackPushEvents","handleDeeplinkInKilledState","disableNotificationRegistration","autoFetchDeviceToken","Object","entries","forEach","key","value","undefined","console","warn","propKey"],"sources":["withCIOIos.ts"],"sourcesContent":["import type { ExpoConfig } from '@expo/config-types';\n\nimport type {\n CustomerIOPluginOptionsIOS,\n CustomerIOPluginPushNotificationOptions,\n NativeSDKConfig,\n} from '../types/cio-types';\nimport { mergeConfigWithEnvValues } from '../utils/config';\nimport { isExpoVersion53OrHigher } from './utils';\nimport { withAppDelegateModifications } from './withAppDelegateModifications';\nimport { withCIOIosSwift } from './withCIOIosSwift';\nimport { withGoogleServicesJsonFile } from './withGoogleServicesJsonFile';\nimport { withCioNotificationsXcodeProject } from './withNotificationsXcodeProject';\nimport { withCioXcodeProject } from './withXcodeProject';\n\nexport function withCIOIos(\n config: ExpoConfig,\n sdkConfig: NativeSDKConfig | undefined,\n props: CustomerIOPluginOptionsIOS\n) {\n const isSwiftProject = isExpoVersion53OrHigher(config);\n const platformConfig = mergeDeprecatedPropertiesAndLogWarnings(props);\n\n if (platformConfig.pushNotification) {\n if (isSwiftProject) {\n config = withCIOIosSwift(config, sdkConfig, platformConfig);\n } else {\n // Auto initialization is only supported in Swift projects (Expo SDK 53+)\n // Legacy Objective-C projects only support push notifications\n config = withAppDelegateModifications(config, platformConfig);\n }\n\n platformConfig.pushNotification.env = platformConfig.pushNotification.env\n || mergeConfigWithEnvValues(platformConfig, sdkConfig);\n config = withCioNotificationsXcodeProject(config, platformConfig);\n config = withCioXcodeProject(config, platformConfig);\n config = withGoogleServicesJsonFile(config, platformConfig);\n } else if (sdkConfig && isSwiftProject) {\n config = withCIOIosSwift(config, sdkConfig, platformConfig);\n }\n\n return config;\n}\n\n/** The basic purpose of this function is to centralize where we handle the deprecation\n by merging the deprecated properties into the new ios.pushNotification.* properties\n and logging a warning if they are set. This way, we can remove the deprecated properties\n from the top level of the ios object in the future, and update this function\n while the rest of the plugin code remains unchanged.\n*/\nconst mergeDeprecatedPropertiesAndLogWarnings = (\n props: CustomerIOPluginOptionsIOS\n) => {\n // The deprecatedTopLevelProperties maps the top level properties\n // that are deprecated to the new ios.pushNotification.* properties\n // that should be used instead. The deprecated properties are\n // still available for backwards compatibility, but they will\n // be removed in the future.\n\n const deprecatedTopLevelProperties = {\n showPushAppInForeground: props.showPushAppInForeground,\n autoTrackPushEvents: props.autoTrackPushEvents,\n handleDeeplinkInKilledState: props.handleDeeplinkInKilledState,\n disableNotificationRegistration: props.disableNotificationRegistration,\n autoFetchDeviceToken: props.autoFetchDeviceToken,\n };\n\n // loop over all the deprecated properties and log a warning if they are set\n Object.entries(deprecatedTopLevelProperties).forEach(([key, value]) => {\n if (value !== undefined) {\n console.warn(\n `The ios.${key} property is deprecated. Please use ios.pushNotification.${key} instead.`\n );\n\n if (props.pushNotification === undefined) {\n props.pushNotification = {} as CustomerIOPluginPushNotificationOptions;\n }\n const propKey = key as keyof CustomerIOPluginPushNotificationOptions;\n if (props.pushNotification[propKey] === undefined) {\n props.pushNotification = {\n ...props.pushNotification,\n [propKey]: value,\n };\n } else {\n console.warn(\n `The ios.${key} property is deprecated. Since the value of ios.pushNotification.${key} is set, it will be used.`\n );\n }\n }\n });\n\n return props;\n};\n"],"mappings":"AAOA,SAASA,wBAAwB,QAAQ,iBAAiB;AAC1D,SAASC,uBAAuB,QAAQ,SAAS;AACjD,SAASC,4BAA4B,QAAQ,gCAAgC;AAC7E,SAASC,eAAe,QAAQ,mBAAmB;AACnD,SAASC,0BAA0B,QAAQ,8BAA8B;AACzE,SAASC,gCAAgC,QAAQ,iCAAiC;AAClF,SAASC,mBAAmB,QAAQ,oBAAoB;AAExD,OAAO,SAASC,UAAUA,CACxBC,MAAkB,EAClBC,SAAsC,EACtCC,KAAiC,EACjC;EACA,MAAMC,cAAc,GAAGV,uBAAuB,CAACO,MAAM,CAAC;EACtD,MAAMI,cAAc,GAAGC,uCAAuC,CAACH,KAAK,CAAC;EAErE,IAAIE,cAAc,CAACE,gBAAgB,EAAE;IACnC,IAAIH,cAAc,EAAE;MAClBH,MAAM,GAAGL,eAAe,CAACK,MAAM,EAAEC,SAAS,EAAEG,cAAc,CAAC;IAC7D,CAAC,MAAM;MACL;MACA;MACAJ,MAAM,GAAGN,4BAA4B,CAACM,MAAM,EAAEI,cAAc,CAAC;IAC/D;IAEAA,cAAc,CAACE,gBAAgB,CAACC,GAAG,GAAGH,cAAc,CAACE,gBAAgB,CAACC,GAAG,IACpEf,wBAAwB,CAACY,cAAc,EAAEH,SAAS,CAAC;IACxDD,MAAM,GAAGH,gCAAgC,CAACG,MAAM,EAAEI,cAAc,CAAC;IACjEJ,MAAM,GAAGF,mBAAmB,CAACE,MAAM,EAAEI,cAAc,CAAC;IACpDJ,MAAM,GAAGJ,0BAA0B,CAACI,MAAM,EAAEI,cAAc,CAAC;EAC7D,CAAC,MAAM,IAAIH,SAAS,IAAIE,cAAc,EAAE;IACtCH,MAAM,GAAGL,eAAe,CAACK,MAAM,EAAEC,SAAS,EAAEG,cAAc,CAAC;EAC7D;EAEA,OAAOJ,MAAM;AACf;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,MAAMK,uCAAuC,GAC3CH,KAAiC,IAC9B;EACH;EACA;EACA;EACA;EACA;;EAEA,MAAMM,4BAA4B,GAAG;IACnCC,uBAAuB,EAAEP,KAAK,CAACO,uBAAuB;IACtDC,mBAAmB,EAAER,KAAK,CAACQ,mBAAmB;IAC9CC,2BAA2B,EAAET,KAAK,CAACS,2BAA2B;IAC9DC,+BAA+B,EAAEV,KAAK,CAACU,+BAA+B;IACtEC,oBAAoB,EAAEX,KAAK,CAACW;EAC9B,CAAC;;EAED;EACAC,MAAM,CAACC,OAAO,CAACP,4BAA4B,CAAC,CAACQ,OAAO,CAAC,CAAC,CAACC,GAAG,EAAEC,KAAK,CAAC,KAAK;IACrE,IAAIA,KAAK,KAAKC,SAAS,EAAE;MACvBC,OAAO,CAACC,IAAI,CACV,WAAWJ,GAAG,4DAA4DA,GAAG,WAC/E,CAAC;MAED,IAAIf,KAAK,CAACI,gBAAgB,KAAKa,SAAS,EAAE;QACxCjB,KAAK,CAACI,gBAAgB,GAAG,CAAC,CAA4C;MACxE;MACA,MAAMgB,OAAO,GAAGL,GAAoD;MACpE,IAAIf,KAAK,CAACI,gBAAgB,CAACgB,OAAO,CAAC,KAAKH,SAAS,EAAE;QACjDjB,KAAK,CAACI,gBAAgB,GAAG;UACvB,GAAGJ,KAAK,CAACI,gBAAgB;UACzB,CAACgB,OAAO,GAAGJ;QACb,CAAC;MACH,CAAC,MAAM;QACLE,OAAO,CAACC,IAAI,CACV,WAAWJ,GAAG,oEAAoEA,GAAG,2BACvF,CAAC;MACH;IACF;EACF,CAAC,CAAC;EAEF,OAAOf,KAAK;AACd,CAAC","ignoreList":[]}
@@ -1,8 +1,12 @@
1
1
  import { withAppDelegate, withXcodeProject } from '@expo/config-plugins';
2
2
  import path from 'path';
3
- import { FileManagement } from '../helpers/utils/fileManagement';
4
- import { LOCAL_PATH_TO_CIO_NSE_FILES, CIO_REGISTER_PUSHNOTIFICATION_SNIPPET_v2, CIO_REGISTER_PUSH_NOTIFICATION_PLACEHOLDER, CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SWIFT_SNIPPET } from '../helpers/constants/ios';
3
+ import { PLATFORM } from '../helpers/constants/common';
4
+ import { CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SWIFT_SNIPPET, CIO_MESSAGING_PUSH_APP_DELEGATE_INIT_REGEX, CIO_NATIVE_SDK_INITIALIZE_CALL, CIO_NATIVE_SDK_INITIALIZE_SNIPPET, CIO_REGISTER_PUSHNOTIFICATION_SNIPPET_v2, CIO_REGISTER_PUSH_NOTIFICATION_PLACEHOLDER } from '../helpers/constants/ios';
5
5
  import { replaceCodeByRegex } from '../helpers/utils/codeInjection';
6
+ import { FileManagement } from '../helpers/utils/fileManagement';
7
+ import { patchNativeSDKInitializer } from '../helpers/utils/patchPluginNativeCode';
8
+ import { getIosNativeFilesPath } from '../utils/plugin';
9
+ import { copyFileToXcode, getOrCreateCustomerIOGroup } from '../utils/xcode';
6
10
  import { isFcmPushProvider } from './utils';
7
11
 
8
12
  // Constants
@@ -12,39 +16,56 @@ const CIO_SDK_APP_DELEGATE_HANDLER_FILENAME = `${CIO_SDK_APP_DELEGATE_HANDLER_CL
12
16
  /**
13
17
  * Copy and configure the CioSdkAppDelegateHandler.swift file
14
18
  */
15
- const copyAndConfigureAppDelegateHandler = (config, props) => {
16
- var _props$pushNotificati, _props$pushNotificati2, _props$pushNotificati3, _props$pushNotificati4;
17
- const projectRoot = config.modRequest.projectRoot;
18
- const iosProjectRoot = path.join(projectRoot, 'ios');
19
- const useFcm = isFcmPushProvider(props);
20
-
21
- // Source path for the handler file
22
- const handlerSourcePath = path.join(LOCAL_PATH_TO_CIO_NSE_FILES, useFcm ? 'fcm' : 'apn', CIO_SDK_APP_DELEGATE_HANDLER_FILENAME);
23
-
19
+ const copyAndConfigureAppDelegateHandler = (config, sdkConfig, props) => {
24
20
  // Destination path in the iOS project
25
21
  const projectName = config.modRequest.projectName || '';
26
22
  if (!projectName) {
27
- console.warn('Project name is undefined, cannot copy CioSdkAppDelegateHandler.swift');
23
+ console.warn('Project name is undefined, cannot copy CustomerIO files');
28
24
  return config;
29
25
  }
30
- const handlerDestPath = path.join(iosProjectRoot, projectName, CIO_SDK_APP_DELEGATE_HANDLER_FILENAME);
31
- FileManagement.copyFile(handlerSourcePath, handlerDestPath);
32
26
 
33
- // Add the file to the Xcode project
27
+ // Add files to the Xcode project
34
28
  const xcodeProject = config.modResults;
35
-
36
- // Create a group for CustomerIO files if it doesn't exist
37
- let group;
38
- const existingGroup = xcodeProject.pbxGroupByName('CustomerIO');
39
- if (existingGroup) {
40
- group = existingGroup;
41
- } else {
42
- group = xcodeProject.pbxCreateGroup('CustomerIO');
43
- const classesKey = xcodeProject.findPBXGroupKey({
44
- name: projectName
29
+ const projectRoot = config.modRequest.projectRoot;
30
+ const iosProjectRoot = path.join(projectRoot, 'ios');
31
+ const group = getOrCreateCustomerIOGroup(xcodeProject, projectName);
32
+ if (props.pushNotification) {
33
+ // Copy CioSdkAppDelegateHandler.swift for full push notification + auto-init support
34
+ copyAndConfigurePushAppDelegateHandler({
35
+ xcodeProject,
36
+ group,
37
+ iosProjectRoot,
38
+ projectName,
39
+ sdkConfig,
40
+ props
41
+ });
42
+ } else if (sdkConfig) {
43
+ // Copy only CustomerIOSDKInitializer.swift for auto-init without push notifications
44
+ copyAndConfigureNativeSDKInitializer({
45
+ xcodeProject,
46
+ group,
47
+ iosProjectRoot,
48
+ projectName,
49
+ sdkConfig
45
50
  });
46
- xcodeProject.addToPbxGroup(group, classesKey);
47
51
  }
52
+ return config;
53
+ };
54
+ const copyAndConfigurePushAppDelegateHandler = ({
55
+ xcodeProject,
56
+ group,
57
+ iosProjectRoot,
58
+ projectName,
59
+ sdkConfig,
60
+ props
61
+ }) => {
62
+ var _props$pushNotificati, _props$pushNotificati2, _props$pushNotificati3, _props$pushNotificati4;
63
+ const useFcm = isFcmPushProvider(props);
64
+
65
+ // Source path for the handler file
66
+ const handlerSourcePath = path.join(getIosNativeFilesPath(), useFcm ? 'fcm' : 'apn', CIO_SDK_APP_DELEGATE_HANDLER_FILENAME);
67
+ const handlerDestPath = path.join(iosProjectRoot, projectName, CIO_SDK_APP_DELEGATE_HANDLER_FILENAME);
68
+ FileManagement.copyFile(handlerSourcePath, handlerDestPath);
48
69
 
49
70
  // Add the file to the Xcode project
50
71
  xcodeProject.addSourceFile(`${projectName}/${CIO_SDK_APP_DELEGATE_HANDLER_FILENAME}`, null, group);
@@ -63,25 +84,69 @@ const copyAndConfigureAppDelegateHandler = (config, props) => {
63
84
  handlerFileContent = replaceCodeByRegex(handlerFileContent, /\{\{AUTO_FETCH_DEVICE_TOKEN\}\}/, autoFetchDeviceToken.toString());
64
85
  const showPushAppInForeground = ((_props$pushNotificati4 = props.pushNotification) === null || _props$pushNotificati4 === void 0 ? void 0 : _props$pushNotificati4.showPushAppInForeground) !== false;
65
86
  handlerFileContent = replaceCodeByRegex(handlerFileContent, /\{\{SHOW_PUSH_APP_IN_FOREGROUND\}\}/, showPushAppInForeground.toString());
87
+
88
+ // Add auto initialization if sdkConfig is provided
89
+ if (sdkConfig) {
90
+ // Also copy CustomerIOSDKInitializer.swift for auto-initialization
91
+ copyAndConfigureNativeSDKInitializer({
92
+ xcodeProject,
93
+ group,
94
+ iosProjectRoot,
95
+ projectName,
96
+ sdkConfig
97
+ });
98
+
99
+ // Inject auto initialization call before MessagingPush initialization
100
+ handlerFileContent = handlerFileContent.replace(CIO_MESSAGING_PUSH_APP_DELEGATE_INIT_REGEX, CIO_NATIVE_SDK_INITIALIZE_SNIPPET + '$1');
101
+ }
66
102
  FileManagement.writeFile(handlerDestPath, handlerFileContent);
67
- return config;
68
103
  };
69
- export const withCIOIosSwift = (configOuter, props) => {
70
- // First, copy the CioSdkAppDelegateHandler.swift file to the iOS project and add it to Xcode project
104
+ const copyAndConfigureNativeSDKInitializer = ({
105
+ xcodeProject,
106
+ group,
107
+ iosProjectRoot,
108
+ projectName,
109
+ sdkConfig
110
+ }) => {
111
+ const filename = 'CustomerIOSDKInitializer.swift';
112
+ const sourcePath = path.join(getIosNativeFilesPath(), filename);
113
+ // Add the CustomerIOSDKInitializer.swift file to the same Xcode group as CioSdkAppDelegateHandler
114
+ copyFileToXcode({
115
+ xcodeProject,
116
+ iosProjectRoot,
117
+ projectName,
118
+ sourceFilePath: sourcePath,
119
+ targetFileName: filename,
120
+ transform: content => patchNativeSDKInitializer(content, PLATFORM.IOS, sdkConfig),
121
+ customerIOGroup: group
122
+ });
123
+ };
124
+ export const withCIOIosSwift = (configOuter, sdkConfig, props) => {
125
+ // First, copy required swift files to iOS folder and add it to Xcode project
71
126
  configOuter = withXcodeProject(configOuter, async config => {
72
- return copyAndConfigureAppDelegateHandler(config, props);
127
+ return copyAndConfigureAppDelegateHandler(config, sdkConfig, props);
73
128
  });
74
129
 
75
- // Then modify the AppDelegate
76
- return withAppDelegate(configOuter, async config => {
77
- return modifyAppDelegate(config, props);
78
- });
130
+ // Modify the AppDelegate based on configuration
131
+ if (props.pushNotification) {
132
+ // With push notifications: delegate to CioSdkAppDelegateHandler for both push and auto-init
133
+ return withAppDelegate(configOuter, async config => {
134
+ return modifyAppDelegateWithPushAppDelegateHandler(config, props);
135
+ });
136
+ } else if (sdkConfig) {
137
+ // Without push notifications: directly inject auto initialization into AppDelegate
138
+ return withAppDelegate(configOuter, async config => {
139
+ return modifyAppDelegateWithNativeSDKInitializer(config);
140
+ });
141
+ } else {
142
+ return configOuter;
143
+ }
79
144
  };
80
145
 
81
146
  /**
82
147
  * Modify the AppDelegate to integrate with Customer.io SDK
83
148
  */
84
- const modifyAppDelegate = (config, props) => {
149
+ const modifyAppDelegateWithPushAppDelegateHandler = (config, props) => {
85
150
  var _props$pushNotificati5;
86
151
  const appDelegateContent = config.modResults.contents;
87
152
 
@@ -95,7 +160,7 @@ const modifyAppDelegate = (config, props) => {
95
160
  let modifiedContent = addHandlerPropertyDeclaration(appDelegateContent);
96
161
 
97
162
  // Modify didFinishLaunchingWithOptions to initialize and call the handler
98
- modifiedContent = modifyDidFinishLaunchingWithOptions(modifiedContent);
163
+ modifiedContent = modifyDidFinishLaunchingWithOptions(modifiedContent, ` cioSdkHandler.application(application, didFinishLaunchingWithOptions: launchOptions)\n\n `);
99
164
 
100
165
  // Add didRegisterForRemoteNotificationsWithDeviceToken implementation
101
166
  modifiedContent = addDidRegisterForRemoteNotificationsWithDeviceToken(modifiedContent);
@@ -111,6 +176,26 @@ const modifyAppDelegate = (config, props) => {
111
176
  return config;
112
177
  };
113
178
 
179
+ /**
180
+ * Modify the AppDelegate to integrate with Customer.io SDK
181
+ */
182
+ const modifyAppDelegateWithNativeSDKInitializer = (config
183
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
184
+ ) => {
185
+ const appDelegateContent = config.modResults.contents;
186
+
187
+ // Check if modifications have already been applied
188
+ if (appDelegateContent.includes(CIO_NATIVE_SDK_INITIALIZE_CALL)) {
189
+ console.log('CustomerIO Swift AppDelegate changes already exist. Skipping...');
190
+ return config;
191
+ }
192
+
193
+ // Modify didFinishLaunchingWithOptions to initialize and call the handler
194
+ const modifiedContent = modifyDidFinishLaunchingWithOptions(appDelegateContent, CIO_NATIVE_SDK_INITIALIZE_SNIPPET);
195
+ config.modResults.contents = modifiedContent;
196
+ return config;
197
+ };
198
+
114
199
  /**
115
200
  * Check if a method exists in the AppDelegate content
116
201
  * @param content The AppDelegate content
@@ -134,15 +219,15 @@ const addHandlerPropertyDeclaration = content => {
134
219
  console.warn('Could not find AppDelegate class declaration');
135
220
  return content;
136
221
  }
137
- const position = match.index + match[0].length;
222
+ const position = (match.index ?? 0) + match[0].length;
138
223
  return content.substring(0, position) + `\n let cioSdkHandler = ${CIO_SDK_APP_DELEGATE_HANDLER_CLASS}()\n` + content.substring(position);
139
224
  };
140
225
 
141
226
  /**
142
- * Modify didFinishLaunchingWithOptions to call the handler
143
- * This adds the handler call before the return statement in didFinishLaunchingWithOptions
227
+ * Modify didFinishLaunchingWithOptions to inject Customer.io code
228
+ * Injects the provided code (either handler call or auto initialization) before the return statement
144
229
  */
145
- const modifyDidFinishLaunchingWithOptions = content => {
230
+ const modifyDidFinishLaunchingWithOptions = (content, codeToInject) => {
146
231
  // Find the return statement in didFinishLaunchingWithOptions
147
232
  // Always look for launchOptions since modifiedLaunchOptions is only set later
148
233
  const returnStatementRegex = /return\s+super\.application\s*\(\s*application\s*,\s*didFinishLaunchingWithOptions\s*:\s*launchOptions\s*\)/;
@@ -152,10 +237,9 @@ const modifyDidFinishLaunchingWithOptions = content => {
152
237
  return content;
153
238
  }
154
239
 
155
- // Add handler call before the return statement
156
- const insertPosition = returnStatementMatch.index;
157
- const handlerCallCode = ` cioSdkHandler.application(application, didFinishLaunchingWithOptions: launchOptions)\n\n `;
158
- return content.substring(0, insertPosition) + handlerCallCode + content.substring(insertPosition);
240
+ // Inject Customer.io code before the return statement
241
+ const insertPosition = returnStatementMatch.index ?? 0;
242
+ return content.substring(0, insertPosition) + codeToInject + content.substring(insertPosition);
159
243
  };
160
244
 
161
245
  /**
@@ -190,7 +274,7 @@ const addDidRegisterForRemoteNotificationsWithDeviceToken = content => {
190
274
  }
191
275
 
192
276
  // Insert the method inside the class
193
- const position = classEndMatch.index;
277
+ const position = classEndMatch.index ?? 0;
194
278
  return content.substring(0, position) + '\n // Handle device token registration\n' + ' public override func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {\n' + ' // Call CustomerIO SDK handler\n' + ' cioSdkHandler.application(application, didRegisterForRemoteNotificationsWithDeviceToken: deviceToken)\n' + ' super.application(application, didRegisterForRemoteNotificationsWithDeviceToken: deviceToken)\n' + ' }\n' + content.substring(position);
195
279
  }
196
280
  };
@@ -227,7 +311,7 @@ const addDidFailToRegisterForRemoteNotificationsWithError = content => {
227
311
  }
228
312
 
229
313
  // Insert the method inside the class
230
- const position = classEndMatch.index;
314
+ const position = classEndMatch.index ?? 0;
231
315
  return content.substring(0, position) + '\n // Handle remote notification registration errors\n' + ' public override func application(_ application: UIApplication, didFailToRegisterForRemoteNotificationsWithError error: Error) {\n' + ' // Call CustomerIO SDK handler\n' + ' cioSdkHandler.application(application, didFailToRegisterForRemoteNotificationsWithError: error)\n' + ' super.application(application, didFailToRegisterForRemoteNotificationsWithError: error)\n' + ' }\n' + content.substring(position);
232
316
  }
233
317
  };
@@ -239,7 +323,7 @@ const addDidFailToRegisterForRemoteNotificationsWithError = content => {
239
323
  */
240
324
  const addHandleDeeplinkInKilledState = content => {
241
325
  // Check if deep link code snippet is already present
242
- const deepLinkMarker = "Deep link workaround for app killed state start";
326
+ const deepLinkMarker = 'Deep link workaround for app killed state start';
243
327
  if (content.includes(deepLinkMarker)) {
244
328
  return content;
245
329
  }
@@ -248,13 +332,13 @@ const addHandleDeeplinkInKilledState = content => {
248
332
  const returnStatementRegex = /return\s+super\.application\s*\(\s*application\s*,\s*didFinishLaunchingWithOptions\s*:\s*launchOptions\s*\)/;
249
333
  const returnStatementMatch = content.match(returnStatementRegex);
250
334
  if (!returnStatementMatch) {
251
- console.warn("Could not find return statement with launchOptions");
335
+ console.warn('Could not find return statement with launchOptions');
252
336
  return content;
253
337
  }
254
338
 
255
339
  // Create the replacement code with deep link handling and modified return statement
256
- const modifiedReturnStatement = "return super.application(application, didFinishLaunchingWithOptions: modifiedLaunchOptions)";
257
- const replacementCode = CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SWIFT_SNIPPET + "\n\n " + modifiedReturnStatement;
340
+ const modifiedReturnStatement = 'return super.application(application, didFinishLaunchingWithOptions: modifiedLaunchOptions)';
341
+ const replacementCode = CIO_CONFIGUREDEEPLINK_KILLEDSTATE_SWIFT_SNIPPET + '\n\n ' + modifiedReturnStatement;
258
342
 
259
343
  // Replace the return statement with deep link handling code and modified return statement
260
344
  return content.replace(returnStatementRegex, replacementCode);