react-native-nami-sdk 3.0.22 → 3.0.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/android/src/main/java/com/nami/reactlibrary/NamiBridgeModule.kt +1 -1
- package/android/src/main/java/com/nami/reactlibrary/NamiPaywallManagerBridgeModule.kt +13 -0
- package/ios/Nami.m +1 -1
- package/ios/NamiPaywallManagerBridge.m +2 -0
- package/ios/NamiPaywallManagerBridge.swift +10 -2
- package/package.json +1 -1
- package/src/NamiPaywallManager.d.ts +1 -0
- package/src/NamiPaywallManager.js +11 -0
|
@@ -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.
|
|
118
|
+
val settingsList = mutableListOf("extendedClientInfo:react-native:3.0.23")
|
|
119
119
|
namiCommandsReact?.toArrayList()?.filterIsInstance<String>()?.let { commandsFromReact ->
|
|
120
120
|
settingsList.addAll(commandsFromReact)
|
|
121
121
|
}
|
|
@@ -222,6 +222,19 @@ class NamiPaywallManagerBridgeModule(reactContext: ReactApplicationContext) :
|
|
|
222
222
|
}
|
|
223
223
|
}
|
|
224
224
|
|
|
225
|
+
@ReactMethod
|
|
226
|
+
fun registerRestoreHandler() {
|
|
227
|
+
NamiPaywallManager.registerRestoreHandler { activity ->
|
|
228
|
+
latestPaywallActivity = activity
|
|
229
|
+
val map = Arguments.createMap().apply {
|
|
230
|
+
putBoolean("paywallRestoreRequested", true)
|
|
231
|
+
}
|
|
232
|
+
reactApplicationContext
|
|
233
|
+
.getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter::class.java)
|
|
234
|
+
.emit("PaywallRestoreRequested", map)
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
|
|
225
238
|
@ReactMethod
|
|
226
239
|
fun show() {
|
|
227
240
|
// 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.
|
|
55
|
+
NSMutableArray *namiCommandStrings = [NSMutableArray arrayWithArray:@[@"extendedClientInfo:react-native:3.0.23"]];
|
|
56
56
|
|
|
57
57
|
// Add additional namiCommands app may have sent in.
|
|
58
58
|
NSObject *appCommandStrings = configDict[@"namiCommands"];
|
|
@@ -19,7 +19,7 @@ class RNNamiPaywallManager: RCTEventEmitter {
|
|
|
19
19
|
}
|
|
20
20
|
|
|
21
21
|
override func supportedEvents() -> [String]! {
|
|
22
|
-
return ["RegisterBuySKU", "PaywallCloseRequested", "PaywallSignInRequested"]
|
|
22
|
+
return ["RegisterBuySKU", "PaywallCloseRequested", "PaywallSignInRequested", "PaywallRestoreRequested"]
|
|
23
23
|
}
|
|
24
24
|
|
|
25
25
|
@objc(buySkuComplete:)
|
|
@@ -103,6 +103,14 @@ class RNNamiPaywallManager: RCTEventEmitter {
|
|
|
103
103
|
}
|
|
104
104
|
}
|
|
105
105
|
|
|
106
|
+
@objc(registerRestoreHandler)
|
|
107
|
+
func registerRestoreHandler() {
|
|
108
|
+
NamiPaywallManager.registerRestoreHandler {
|
|
109
|
+
let dictionary = NSDictionary(dictionary: ["PaywallRestoreRequested": true].compactMapValues { $0 })
|
|
110
|
+
RNNamiPaywallManager.shared?.sendEvent(withName: "PaywallRestoreRequested", body: dictionary)
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
106
114
|
@objc(dismiss:)
|
|
107
115
|
func dismiss(animated: Bool) {
|
|
108
116
|
NamiPaywallManager.dismiss(animated: animated) {}
|
|
@@ -129,4 +137,4 @@ class RNNamiPaywallManager: RCTEventEmitter {
|
|
|
129
137
|
resolve(isHidden)
|
|
130
138
|
}
|
|
131
139
|
}
|
|
132
|
-
}
|
|
140
|
+
}
|
package/package.json
CHANGED
|
@@ -13,6 +13,7 @@ export const NamiPaywallManager: {
|
|
|
13
13
|
) => EmitterSubscription["remove"];
|
|
14
14
|
registerCloseHandler: (callback: () => void) => EmitterSubscription["remove"];
|
|
15
15
|
registerSignInHandler: (callback: () => void) => EmitterSubscription["remove"];
|
|
16
|
+
registerRestoreHandler: (callback: () => void) => EmitterSubscription["remove"];
|
|
16
17
|
show: () => void;
|
|
17
18
|
hide: () => void;
|
|
18
19
|
isHidden: () => Promise<boolean>;
|
|
@@ -47,6 +47,17 @@ export const NamiPaywallManager = {
|
|
|
47
47
|
RNNamiPaywallManager.registerSignInHandler();
|
|
48
48
|
return subscription.remove;
|
|
49
49
|
},
|
|
50
|
+
registerRestoreHandler(callback) {
|
|
51
|
+
var subscription;
|
|
52
|
+
subscription = this.paywallEmitter.addListener(
|
|
53
|
+
"PaywallRestoreRequested",
|
|
54
|
+
(body) => {
|
|
55
|
+
callback(body);
|
|
56
|
+
}
|
|
57
|
+
);
|
|
58
|
+
RNNamiPaywallManager.registerRestoreHandler();
|
|
59
|
+
return subscription.remove;
|
|
60
|
+
},
|
|
50
61
|
dismiss(animated) {
|
|
51
62
|
RNNamiPaywallManager.dismiss(animated ?? true);
|
|
52
63
|
},
|