react-native-nami-sdk 3.0.30 → 3.0.31

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.
@@ -84,7 +84,7 @@ dependencies {
84
84
  implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8:$kotlin_version"
85
85
 
86
86
  implementation 'com.github.jeziellago:compose-markdown:0.3.0'
87
- compileOnly "com.namiml:sdk-amazon:3.1.5"
87
+ compileOnly "com.namiml:sdk-amazon:3.1.7"
88
88
 
89
89
  implementation 'com.facebook.react:react-native:+' // From node_modules
90
90
  coreLibraryDesugaring "com.android.tools:desugar_jdk_libs:1.1.5"
@@ -115,7 +115,7 @@ class NamiBridgeModule(reactContext: ReactApplicationContext) :
115
115
  } else {
116
116
  Arguments.createArray()
117
117
  }
118
- val settingsList = mutableListOf("extendedClientInfo:react-native:3.0.30")
118
+ val settingsList = mutableListOf("extendedClientInfo:react-native:3.0.31")
119
119
  namiCommandsReact?.toArrayList()?.filterIsInstance<String>()?.let { commandsFromReact ->
120
120
  settingsList.addAll(commandsFromReact)
121
121
  }
@@ -235,6 +235,18 @@ class NamiPaywallManagerBridgeModule(reactContext: ReactApplicationContext) :
235
235
  }
236
236
  }
237
237
 
238
+ @ReactMethod
239
+ fun registerDeeplinkActionHandler() {
240
+ NamiPaywallManager.registerDeepLinkHandler { activity , url ->
241
+ latestPaywallActivity = activity
242
+ reactApplicationContext
243
+ .getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter::class.java)
244
+ .emit("PaywallDeeplinkAction", url)
245
+ }
246
+
247
+ }
248
+
249
+
238
250
  @ReactMethod
239
251
  fun show() {
240
252
  // Do nothing on Android side
package/ios/Nami.m CHANGED
@@ -52,7 +52,7 @@ RCT_EXPORT_METHOD(configure: (NSDictionary *)configDict completion: (RCTResponse
52
52
  }
53
53
 
54
54
  // Start commands with header iformation for Nami to let them know this is a React client.
55
- NSMutableArray *namiCommandStrings = [NSMutableArray arrayWithArray:@[@"extendedClientInfo:react-native:3.0.30"]];
55
+ NSMutableArray *namiCommandStrings = [NSMutableArray arrayWithArray:@[@"extendedClientInfo:react-native:3.0.31"]];
56
56
 
57
57
  // Add additional namiCommands app may have sent in.
58
58
  NSObject *appCommandStrings = configDict[@"namiCommands"];
@@ -63,6 +63,8 @@ class RNNamiCampaignManager: RCTEventEmitter {
63
63
  actionString = "PURCHASE_SELECTED_SKU"
64
64
  case .purchase_success:
65
65
  actionString = "PURCHASE_SUCCESS"
66
+ case .purchase_pending:
67
+ actionString = "PURCHASE_PENDING"
66
68
  case .purchase_deferred:
67
69
  actionString = "PURCHASE_DEFERRED"
68
70
  case .purchase_failed:
@@ -25,6 +25,8 @@ RCT_EXTERN_METHOD(registerSignInHandler)
25
25
 
26
26
  RCT_EXTERN_METHOD(registerRestoreHandler)
27
27
 
28
+ RCT_EXTERN_METHOD(registerDeeplinkActionHandler)
29
+
28
30
  RCT_EXTERN_METHOD(dismiss:(BOOL)animated)
29
31
 
30
32
  RCT_EXTERN_METHOD(show)
@@ -19,7 +19,7 @@ class RNNamiPaywallManager: RCTEventEmitter {
19
19
  }
20
20
 
21
21
  override func supportedEvents() -> [String]! {
22
- return ["RegisterBuySKU", "PaywallCloseRequested", "PaywallSignInRequested", "PaywallRestoreRequested"]
22
+ return ["RegisterBuySKU", "PaywallCloseRequested", "PaywallSignInRequested", "PaywallRestoreRequested", "PaywallDeeplinkAction"]
23
23
  }
24
24
 
25
25
  @objc(buySkuComplete:)
@@ -111,6 +111,13 @@ class RNNamiPaywallManager: RCTEventEmitter {
111
111
  }
112
112
  }
113
113
 
114
+ @objc(registerDeeplinkActionHandler)
115
+ func registerDeeplinkActionHandler() {
116
+ NamiPaywallManager.registerDeeplinkActionHandler { url in
117
+ RNNamiPaywallManager.shared?.sendEvent(withName: "PaywallDeeplinkAction", body: url)
118
+ }
119
+ }
120
+
114
121
  @objc(dismiss:)
115
122
  func dismiss(animated: Bool) {
116
123
  NamiPaywallManager.dismiss(animated: animated) {}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-native-nami-sdk",
3
- "version": "3.0.30",
3
+ "version": "3.0.31",
4
4
  "description": "React Native Module for Nami - Easy subscriptions & in-app purchases, with powerful built-in paywalls and A/B testing.",
5
5
  "main": "index.ts",
6
6
  "types": "index.d.ts",
@@ -20,7 +20,7 @@ Pod::Spec.new do |s|
20
20
  s.source_files = "ios/**/*.{h,m,swift}"
21
21
  s.requires_arc = true
22
22
 
23
- s.dependency 'Nami', '3.1.6'
23
+ s.dependency 'Nami', '3.1.7'
24
24
  s.dependency 'React'
25
25
 
26
26
  end
@@ -18,6 +18,9 @@ export const NamiPaywallManager: {
18
18
  registerRestoreHandler: (
19
19
  callback: () => void,
20
20
  ) => EmitterSubscription['remove'];
21
+ registerDeeplinkActionHandler: (
22
+ callback: (url: string) => void,
23
+ ) => EmitterSubscription['remove'];
21
24
  show: () => void;
22
25
  hide: () => void;
23
26
  buySkuCancel: () => void;
@@ -15,6 +15,7 @@ export enum NamiPaywallManagerEvents {
15
15
  PaywallCloseRequested = 'PaywallCloseRequested',
16
16
  PaywallSignInRequested = 'PaywallSignInRequested',
17
17
  PaywallRestoreRequested = 'PaywallRestoreRequested',
18
+ PaywallDeeplinkAction = 'PaywallDeeplinkAction',
18
19
  }
19
20
 
20
21
  export enum ServicesEnum {
@@ -39,6 +40,9 @@ export interface INamiPaywallManager {
39
40
  registerRestoreHandler: (
40
41
  callback: () => void,
41
42
  ) => EmitterSubscription['remove'];
43
+ registerDeeplinkActionHandler: (
44
+ callback: (url: string) => void,
45
+ ) => EmitterSubscription['remove'];
42
46
  dismiss: (animated?: boolean) => void;
43
47
  show: () => void;
44
48
  hide: () => void;
@@ -69,8 +73,7 @@ export const NamiPaywallManager: INamiPaywallManager = {
69
73
  RNNamiPaywallManager.buySkuCancel();
70
74
  },
71
75
  registerBuySkuHandler: (callback: (sku: NamiSKU) => void) => {
72
- let subscription;
73
- subscription = NamiPaywallManager.paywallEmitter.addListener(
76
+ let subscription = NamiPaywallManager.paywallEmitter.addListener(
74
77
  NamiPaywallManagerEvents.RegisterBuySKU,
75
78
  sku => {
76
79
  callback(sku);
@@ -84,8 +87,7 @@ export const NamiPaywallManager: INamiPaywallManager = {
84
87
  };
85
88
  },
86
89
  registerCloseHandler: (callback: (body: any) => void) => {
87
- let subscription;
88
- subscription = NamiPaywallManager.paywallEmitter.addListener(
90
+ let subscription = NamiPaywallManager.paywallEmitter.addListener(
89
91
  NamiPaywallManagerEvents.PaywallCloseRequested,
90
92
  body => {
91
93
  callback(body);
@@ -99,8 +101,7 @@ export const NamiPaywallManager: INamiPaywallManager = {
99
101
  };
100
102
  },
101
103
  registerSignInHandler(callback) {
102
- let subscription;
103
- subscription = NamiPaywallManager.paywallEmitter.addListener(
104
+ let subscription = NamiPaywallManager.paywallEmitter.addListener(
104
105
  NamiPaywallManagerEvents.PaywallSignInRequested,
105
106
  () => {
106
107
  callback();
@@ -115,8 +116,7 @@ export const NamiPaywallManager: INamiPaywallManager = {
115
116
  };
116
117
  },
117
118
  registerRestoreHandler(callback) {
118
- let subscription;
119
- subscription = NamiPaywallManager.paywallEmitter.addListener(
119
+ let subscription = NamiPaywallManager.paywallEmitter.addListener(
120
120
  NamiPaywallManagerEvents.PaywallRestoreRequested,
121
121
  () => {
122
122
  callback();
@@ -129,6 +129,20 @@ export const NamiPaywallManager: INamiPaywallManager = {
129
129
  }
130
130
  };
131
131
  },
132
+ registerDeeplinkActionHandler: (callback: (url: string) => void) => {
133
+ let subscription = NamiPaywallManager.paywallEmitter.addListener(
134
+ NamiPaywallManagerEvents.PaywallDeeplinkAction,
135
+ url => {
136
+ callback(url);
137
+ },
138
+ );
139
+ RNNamiPaywallManager.registerDeeplinkActionHandler();
140
+ return () => {
141
+ if (subscription) {
142
+ subscription.remove();
143
+ }
144
+ };
145
+ },
132
146
  dismiss: (animated?: boolean) => {
133
147
  RNNamiPaywallManager.dismiss(animated ?? true);
134
148
  },