@xbenjii/react-native-braintree-dropin-ui 2.1.0 → 2.2.0

Sign up to get free protection for your applications and to get access to all the features.
package/README.md CHANGED
@@ -3,8 +3,8 @@
3
3
  > React Native integration of Braintree Drop-in for IOS & ANDROID (Apple Pay, Google Pay, Paypal, Venmo, Credit Card)
4
4
 
5
5
  <p align="center">
6
- <img src="https://raw.githubusercontent.com/xbenjii/react-native-braintree-dropin-ui/master/node_modules/iphone.png" width="250">
7
- <img src="https://raw.githubusercontent.com/xbenjii/react-native-braintree-dropin-ui/master/node_modules/android.png" width="250">
6
+ <img src="https://raw.githubusercontent.com/xbenjii/react-native-braintree-dropin-ui/master/images/iphone.png" width="250">
7
+ <img src="https://raw.githubusercontent.com/xbenjii/react-native-braintree-dropin-ui/master/images/android.png" width="250">
8
8
  </p>
9
9
 
10
10
  ## Getting started
@@ -289,6 +289,18 @@ BraintreeDropIn.show({
289
289
  clientToken: 'token',
290
290
  threeDSecure: {
291
291
  amount: 1.0,
292
+ email: 'john.doe@gmail.com',
293
+ billingAddress: { //optional
294
+ givenName:"Joe",
295
+ surname:"Guy",
296
+ phoneNumber:"12345678",
297
+ streetAddress:"555 Smith St.",
298
+ extendedAddress:"#5",
299
+ locality:"Oakland",
300
+ region:"CA",
301
+ countryCodeAlpha2:"US",
302
+ postalCode:"54321"
303
+ }
292
304
  },
293
305
  merchantIdentifier: 'applePayMerchantIdentifier',
294
306
  googlePayMerchantId: 'googlePayMerchantId',
@@ -1,3 +1,6 @@
1
+ import java.nio.file.Paths
2
+ import com.android.Version
3
+
1
4
  buildscript {
2
5
  repositories {
3
6
  google()
@@ -9,31 +12,39 @@ buildscript {
9
12
  }
10
13
  }
11
14
 
12
- apply plugin: 'com.android.library'
15
+ def reactNativeArchitectures() {
16
+ def value = rootProject.getProperties().get("reactNativeArchitectures")
17
+ return value ? value.split(",") : ["armeabi-v7a", "x86", "x86_64", "arm64-v8a"]
18
+ }
13
19
 
14
- android {
15
- compileSdkVersion 33
16
- buildToolsVersion '33.0.1'
20
+ def isNewArchitectureEnabled() {
21
+ return rootProject.hasProperty("newArchEnabled") && rootProject.getProperty("newArchEnabled") == "true"
22
+ }
17
23
 
18
- defaultConfig {
19
- minSdkVersion 21
20
- targetSdkVersion 33
21
- versionCode 1
22
- versionName "2.1.0"
23
- }
24
- lintOptions {
25
- abortOnError false
26
- }
24
+ def safeExtGet(prop, fallback) {
25
+ rootProject.ext.has(prop) ? rootProject.ext.get(prop) : fallback
27
26
  }
28
27
 
29
- repositories {
30
- mavenCentral()
31
- google()
28
+ def getNpmVersion() {
29
+ def inputFile = file("$rootDir/../package.json")
30
+ def jsonPackage = new JsonSlurper().parseText(inputFile.text)
31
+
32
+ return jsonPackage["version"]
32
33
  }
33
34
 
34
- dependencies {
35
- implementation 'com.braintreepayments.api:drop-in:6.16.0'
36
- implementation 'com.facebook.react:react-native:+'
35
+ static def findNodeModules(baseDir) {
36
+ def basePath = baseDir.toPath().normalize()
37
+ // Node"s module resolution algorithm searches up to the root directory,
38
+ // after which the base path will be null
39
+ while (basePath) {
40
+ def nodeModulesPath = Paths.get(basePath.toString(), "node_modules")
41
+ def reactNativePath = Paths.get(nodeModulesPath.toString(), "react-native")
42
+ if (nodeModulesPath.toFile().exists() && reactNativePath.toFile().exists()) {
43
+ return nodeModulesPath.toString()
44
+ }
45
+ basePath = basePath.getParent()
46
+ }
47
+ throw new GradleException("@xbenjii/react-native-braintree-dropin-ui: Failed to find node_modules/ path!")
37
48
  }
38
49
 
39
50
  // https://developers.braintreepayments.com/guides/3d-secure/migration/android/v3
@@ -48,3 +59,45 @@ rootProject.allprojects {
48
59
  }
49
60
  }
50
61
  }
62
+
63
+ apply plugin: "com.android.library"
64
+ if (isNewArchitectureEnabled()) {
65
+ apply plugin: "com.facebook.react"
66
+ }
67
+
68
+ def nodeModules = findNodeModules(projectDir)
69
+ logger.warn("[@xbenjii/react-native-braintree-dropin-ui] node_modules found at $nodeModules")
70
+
71
+ android {
72
+ if (rootProject.hasProperty("ndkPath")) {
73
+ ndkPath rootProject.ext.ndkPath
74
+ }
75
+ if (rootProject.hasProperty("ndkVersion")) {
76
+ ndkVersion rootProject.ext.ndkVersion
77
+ }
78
+
79
+ namespace "com.xbenjii.RNBraintreeDropIn"
80
+
81
+ defaultConfig {
82
+ minSdkVersion safeExtGet("minSdkVersion", 21)
83
+ compileSdkVersion safeExtGet("compileSdkVersion", 34)
84
+ targetSdkVersion safeExtGet("targetSdkVersion", 34)
85
+ versionCode 1
86
+ versionName getNpmVersion()
87
+ buildConfigField "boolean", "IS_NEW_ARCHITECTURE_ENABLED", isNewArchitectureEnabled().toString()
88
+ }
89
+
90
+ buildFeatures {
91
+ buildConfig true
92
+ }
93
+ }
94
+
95
+ repositories {
96
+ mavenCentral()
97
+ google()
98
+ }
99
+
100
+ dependencies {
101
+ implementation 'com.braintreepayments.api:drop-in:6.16.0'
102
+ implementation "com.facebook.react:react-android:+"
103
+ }
@@ -0,0 +1,8 @@
1
+ #Thu Jul 04 14:09:24 BST 2024
2
+ distributionBase=GRADLE_USER_HOME
3
+ distributionPath=wrapper/dists
4
+ distributionUrl=https\://services.gradle.org/distributions/gradle-8.5-bin.zip
5
+ networkTimeout=10000
6
+ validateDistributionUrl=true
7
+ zipStoreBase=GRADLE_USER_HOME
8
+ zipStorePath=wrapper/dists
@@ -0,0 +1,16 @@
1
+ ## For more details on how to configure your build environment visit
2
+ # http://www.gradle.org/docs/current/userguide/build_environment.html
3
+ #
4
+ # Specifies the JVM arguments used for the daemon process.
5
+ # The setting is particularly useful for tweaking memory settings.
6
+ # Default value: -Xmx1024m -XX:MaxPermSize=256m
7
+ # org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8
8
+ #
9
+ # When configured, Gradle will run in incubating parallel mode.
10
+ # This option should only be used with decoupled projects. For more details, visit
11
+ # https://developer.android.com/r/tools/gradle-multi-project-decoupled-projects
12
+ # org.gradle.parallel=true
13
+ #Thu Jul 04 13:49:44 BST 2024
14
+ android.enableJetifier=true
15
+ android.useAndroidX=true
16
+ org.gradle.jvmargs=-Xmx4096M -XX:MaxMetaspaceSize=512m
@@ -0,0 +1,249 @@
1
+ #!/bin/sh
2
+
3
+ #
4
+ # Copyright © 2015-2021 the original authors.
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # https://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+ #
18
+
19
+ ##############################################################################
20
+ #
21
+ # Gradle start up script for POSIX generated by Gradle.
22
+ #
23
+ # Important for running:
24
+ #
25
+ # (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is
26
+ # noncompliant, but you have some other compliant shell such as ksh or
27
+ # bash, then to run this script, type that shell name before the whole
28
+ # command line, like:
29
+ #
30
+ # ksh Gradle
31
+ #
32
+ # Busybox and similar reduced shells will NOT work, because this script
33
+ # requires all of these POSIX shell features:
34
+ # * functions;
35
+ # * expansions «$var», «${var}», «${var:-default}», «${var+SET}»,
36
+ # «${var#prefix}», «${var%suffix}», and «$( cmd )»;
37
+ # * compound commands having a testable exit status, especially «case»;
38
+ # * various built-in commands including «command», «set», and «ulimit».
39
+ #
40
+ # Important for patching:
41
+ #
42
+ # (2) This script targets any POSIX shell, so it avoids extensions provided
43
+ # by Bash, Ksh, etc; in particular arrays are avoided.
44
+ #
45
+ # The "traditional" practice of packing multiple parameters into a
46
+ # space-separated string is a well documented source of bugs and security
47
+ # problems, so this is (mostly) avoided, by progressively accumulating
48
+ # options in "$@", and eventually passing that to Java.
49
+ #
50
+ # Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS,
51
+ # and GRADLE_OPTS) rely on word-splitting, this is performed explicitly;
52
+ # see the in-line comments for details.
53
+ #
54
+ # There are tweaks for specific operating systems such as AIX, CygWin,
55
+ # Darwin, MinGW, and NonStop.
56
+ #
57
+ # (3) This script is generated from the Groovy template
58
+ # https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
59
+ # within the Gradle project.
60
+ #
61
+ # You can find Gradle at https://github.com/gradle/gradle/.
62
+ #
63
+ ##############################################################################
64
+
65
+ # Attempt to set APP_HOME
66
+
67
+ # Resolve links: $0 may be a link
68
+ app_path=$0
69
+
70
+ # Need this for daisy-chained symlinks.
71
+ while
72
+ APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path
73
+ [ -h "$app_path" ]
74
+ do
75
+ ls=$( ls -ld "$app_path" )
76
+ link=${ls#*' -> '}
77
+ case $link in #(
78
+ /*) app_path=$link ;; #(
79
+ *) app_path=$APP_HOME$link ;;
80
+ esac
81
+ done
82
+
83
+ # This is normally unused
84
+ # shellcheck disable=SC2034
85
+ APP_BASE_NAME=${0##*/}
86
+ # Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036)
87
+ APP_HOME=$( cd "${APP_HOME:-./}" > /dev/null && pwd -P ) || exit
88
+
89
+ # Use the maximum available, or set MAX_FD != -1 to use that value.
90
+ MAX_FD=maximum
91
+
92
+ warn () {
93
+ echo "$*"
94
+ } >&2
95
+
96
+ die () {
97
+ echo
98
+ echo "$*"
99
+ echo
100
+ exit 1
101
+ } >&2
102
+
103
+ # OS specific support (must be 'true' or 'false').
104
+ cygwin=false
105
+ msys=false
106
+ darwin=false
107
+ nonstop=false
108
+ case "$( uname )" in #(
109
+ CYGWIN* ) cygwin=true ;; #(
110
+ Darwin* ) darwin=true ;; #(
111
+ MSYS* | MINGW* ) msys=true ;; #(
112
+ NONSTOP* ) nonstop=true ;;
113
+ esac
114
+
115
+ CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
116
+
117
+
118
+ # Determine the Java command to use to start the JVM.
119
+ if [ -n "$JAVA_HOME" ] ; then
120
+ if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
121
+ # IBM's JDK on AIX uses strange locations for the executables
122
+ JAVACMD=$JAVA_HOME/jre/sh/java
123
+ else
124
+ JAVACMD=$JAVA_HOME/bin/java
125
+ fi
126
+ if [ ! -x "$JAVACMD" ] ; then
127
+ die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
128
+
129
+ Please set the JAVA_HOME variable in your environment to match the
130
+ location of your Java installation."
131
+ fi
132
+ else
133
+ JAVACMD=java
134
+ if ! command -v java >/dev/null 2>&1
135
+ then
136
+ die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
137
+
138
+ Please set the JAVA_HOME variable in your environment to match the
139
+ location of your Java installation."
140
+ fi
141
+ fi
142
+
143
+ # Increase the maximum file descriptors if we can.
144
+ if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
145
+ case $MAX_FD in #(
146
+ max*)
147
+ # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
148
+ # shellcheck disable=SC2039,SC3045
149
+ MAX_FD=$( ulimit -H -n ) ||
150
+ warn "Could not query maximum file descriptor limit"
151
+ esac
152
+ case $MAX_FD in #(
153
+ '' | soft) :;; #(
154
+ *)
155
+ # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
156
+ # shellcheck disable=SC2039,SC3045
157
+ ulimit -n "$MAX_FD" ||
158
+ warn "Could not set maximum file descriptor limit to $MAX_FD"
159
+ esac
160
+ fi
161
+
162
+ # Collect all arguments for the java command, stacking in reverse order:
163
+ # * args from the command line
164
+ # * the main class name
165
+ # * -classpath
166
+ # * -D...appname settings
167
+ # * --module-path (only if needed)
168
+ # * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables.
169
+
170
+ # For Cygwin or MSYS, switch paths to Windows format before running java
171
+ if "$cygwin" || "$msys" ; then
172
+ APP_HOME=$( cygpath --path --mixed "$APP_HOME" )
173
+ CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" )
174
+
175
+ JAVACMD=$( cygpath --unix "$JAVACMD" )
176
+
177
+ # Now convert the arguments - kludge to limit ourselves to /bin/sh
178
+ for arg do
179
+ if
180
+ case $arg in #(
181
+ -*) false ;; # don't mess with options #(
182
+ /?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath
183
+ [ -e "$t" ] ;; #(
184
+ *) false ;;
185
+ esac
186
+ then
187
+ arg=$( cygpath --path --ignore --mixed "$arg" )
188
+ fi
189
+ # Roll the args list around exactly as many times as the number of
190
+ # args, so each arg winds up back in the position where it started, but
191
+ # possibly modified.
192
+ #
193
+ # NB: a `for` loop captures its iteration list before it begins, so
194
+ # changing the positional parameters here affects neither the number of
195
+ # iterations, nor the values presented in `arg`.
196
+ shift # remove old arg
197
+ set -- "$@" "$arg" # push replacement arg
198
+ done
199
+ fi
200
+
201
+
202
+ # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
203
+ DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
204
+
205
+ # Collect all arguments for the java command:
206
+ # * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
207
+ # and any embedded shellness will be escaped.
208
+ # * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
209
+ # treated as '${Hostname}' itself on the command line.
210
+
211
+ set -- \
212
+ "-Dorg.gradle.appname=$APP_BASE_NAME" \
213
+ -classpath "$CLASSPATH" \
214
+ org.gradle.wrapper.GradleWrapperMain \
215
+ "$@"
216
+
217
+ # Stop when "xargs" is not available.
218
+ if ! command -v xargs >/dev/null 2>&1
219
+ then
220
+ die "xargs is not available"
221
+ fi
222
+
223
+ # Use "xargs" to parse quoted args.
224
+ #
225
+ # With -n1 it outputs one arg per line, with the quotes and backslashes removed.
226
+ #
227
+ # In Bash we could simply go:
228
+ #
229
+ # readarray ARGS < <( xargs -n1 <<<"$var" ) &&
230
+ # set -- "${ARGS[@]}" "$@"
231
+ #
232
+ # but POSIX shell has neither arrays nor command substitution, so instead we
233
+ # post-process each arg (as a line of input to sed) to backslash-escape any
234
+ # character that might be a shell metacharacter, then use eval to reverse
235
+ # that process (while maintaining the separation between arguments), and wrap
236
+ # the whole thing up as a single "set" statement.
237
+ #
238
+ # This will of course break if any of these variables contains a newline or
239
+ # an unmatched quote.
240
+ #
241
+
242
+ eval "set -- $(
243
+ printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" |
244
+ xargs -n1 |
245
+ sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' |
246
+ tr '\n' ' '
247
+ )" '"$@"'
248
+
249
+ exec "$JAVACMD" "$@"
@@ -0,0 +1,92 @@
1
+ @rem
2
+ @rem Copyright 2015 the original author or authors.
3
+ @rem
4
+ @rem Licensed under the Apache License, Version 2.0 (the "License");
5
+ @rem you may not use this file except in compliance with the License.
6
+ @rem You may obtain a copy of the License at
7
+ @rem
8
+ @rem https://www.apache.org/licenses/LICENSE-2.0
9
+ @rem
10
+ @rem Unless required by applicable law or agreed to in writing, software
11
+ @rem distributed under the License is distributed on an "AS IS" BASIS,
12
+ @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ @rem See the License for the specific language governing permissions and
14
+ @rem limitations under the License.
15
+ @rem
16
+
17
+ @if "%DEBUG%"=="" @echo off
18
+ @rem ##########################################################################
19
+ @rem
20
+ @rem Gradle startup script for Windows
21
+ @rem
22
+ @rem ##########################################################################
23
+
24
+ @rem Set local scope for the variables with windows NT shell
25
+ if "%OS%"=="Windows_NT" setlocal
26
+
27
+ set DIRNAME=%~dp0
28
+ if "%DIRNAME%"=="" set DIRNAME=.
29
+ @rem This is normally unused
30
+ set APP_BASE_NAME=%~n0
31
+ set APP_HOME=%DIRNAME%
32
+
33
+ @rem Resolve any "." and ".." in APP_HOME to make it shorter.
34
+ for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
35
+
36
+ @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
37
+ set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
38
+
39
+ @rem Find java.exe
40
+ if defined JAVA_HOME goto findJavaFromJavaHome
41
+
42
+ set JAVA_EXE=java.exe
43
+ %JAVA_EXE% -version >NUL 2>&1
44
+ if %ERRORLEVEL% equ 0 goto execute
45
+
46
+ echo.
47
+ echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
48
+ echo.
49
+ echo Please set the JAVA_HOME variable in your environment to match the
50
+ echo location of your Java installation.
51
+
52
+ goto fail
53
+
54
+ :findJavaFromJavaHome
55
+ set JAVA_HOME=%JAVA_HOME:"=%
56
+ set JAVA_EXE=%JAVA_HOME%/bin/java.exe
57
+
58
+ if exist "%JAVA_EXE%" goto execute
59
+
60
+ echo.
61
+ echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
62
+ echo.
63
+ echo Please set the JAVA_HOME variable in your environment to match the
64
+ echo location of your Java installation.
65
+
66
+ goto fail
67
+
68
+ :execute
69
+ @rem Setup the command line
70
+
71
+ set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
72
+
73
+
74
+ @rem Execute Gradle
75
+ "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*
76
+
77
+ :end
78
+ @rem End local scope for the variables with windows NT shell
79
+ if %ERRORLEVEL% equ 0 goto mainEnd
80
+
81
+ :fail
82
+ rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
83
+ rem the _cmd.exe /c_ return code!
84
+ set EXIT_CODE=%ERRORLEVEL%
85
+ if %EXIT_CODE% equ 0 set EXIT_CODE=1
86
+ if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE%
87
+ exit /b %EXIT_CODE%
88
+
89
+ :mainEnd
90
+ if "%OS%"=="Windows_NT" endlocal
91
+
92
+ :omega
@@ -13,6 +13,8 @@ import com.braintreepayments.api.DropInClient;
13
13
  import com.braintreepayments.api.DropInListener;
14
14
  import com.braintreepayments.api.DropInPaymentMethod;
15
15
  import com.braintreepayments.api.ThreeDSecureRequest;
16
+ import com.braintreepayments.api.ThreeDSecureAdditionalInformation;
17
+ import com.braintreepayments.api.ThreeDSecurePostalAddress;
16
18
  import com.braintreepayments.api.UserCanceledException;
17
19
  import com.braintreepayments.api.PayPalAccountNonce;
18
20
  import com.braintreepayments.api.GooglePayCardNonce;
@@ -107,8 +109,54 @@ public class RNBraintreeDropInModule extends ReactContextBaseJavaModule {
107
109
 
108
110
  isVerifyingThreeDSecure = true;
109
111
 
112
+ String amount = String.valueOf(threeDSecureOptions.getDouble("amount"));
113
+
110
114
  ThreeDSecureRequest threeDSecureRequest = new ThreeDSecureRequest();
111
115
  threeDSecureRequest.setAmount(threeDSecureOptions.getString("amount"));
116
+ threeDSecureRequest.setVersionRequested(ThreeDSecureRequest.VERSION_2);
117
+
118
+ if (threeDSecureOptions.hasKey("email")) {
119
+ threeDSecureRequest.setEmail(threeDSecureOptions.getString("email"));
120
+ }
121
+
122
+ if(threeDSecureOptions.hasKey("billingAddress")) {
123
+ final ReadableMap threeDSecureBillingAddress = threeDSecureOptions.getMap("billingAddress");
124
+ ThreeDSecurePostalAddress billingAddress = new ThreeDSecurePostalAddress();
125
+
126
+ if(threeDSecureBillingAddress.hasKey("givenName")) {
127
+ billingAddress.setGivenName(threeDSecureBillingAddress.getString("givenName"));
128
+ }
129
+
130
+ if(threeDSecureBillingAddress.hasKey("surname")) {
131
+ billingAddress.setGivenName(threeDSecureBillingAddress.getString("surname"));
132
+ }
133
+
134
+ if(threeDSecureBillingAddress.hasKey("streetAddress")) {
135
+ billingAddress.setGivenName(threeDSecureBillingAddress.getString("streetAddress"));
136
+ }
137
+
138
+ if(threeDSecureBillingAddress.hasKey("extendedAddress")) {
139
+ billingAddress.setGivenName(threeDSecureBillingAddress.getString("extendedAddress"));
140
+ }
141
+
142
+ if(threeDSecureBillingAddress.hasKey("locality")) {
143
+ billingAddress.setGivenName(threeDSecureBillingAddress.getString("locality"));
144
+ }
145
+
146
+ if(threeDSecureBillingAddress.hasKey("region")) {
147
+ billingAddress.setGivenName(threeDSecureBillingAddress.getString("region"));
148
+ }
149
+
150
+ if(threeDSecureBillingAddress.hasKey("countryCodeAlpha2")) {
151
+ billingAddress.setGivenName(threeDSecureBillingAddress.getString("countryCodeAlpha2"));
152
+ }
153
+
154
+ if(threeDSecureBillingAddress.hasKey("postalCode")) {
155
+ billingAddress.setGivenName(threeDSecureBillingAddress.getString("postalCode"));
156
+ }
157
+
158
+ threeDSecureRequest.setBillingAddress(billingAddress);
159
+ }
112
160
 
113
161
  dropInRequest.setThreeDSecureRequest(threeDSecureRequest);
114
162
  }
Binary file
Binary file
@@ -1,6 +1,8 @@
1
1
  #import "RNBraintreeDropIn.h"
2
2
  #import <React/RCTUtils.h>
3
3
  #import "BTThreeDSecureRequest.h"
4
+ #import "BTThreeDSecurePostalAddress.h"
5
+ #import "BTThreeDSecureAdditionalInformation.h"
4
6
 
5
7
  @implementation RNBraintreeDropIn
6
8
 
@@ -56,6 +58,47 @@ RCT_EXPORT_METHOD(show:(NSDictionary*)options resolver:(RCTPromiseResolveBlock)r
56
58
 
57
59
  BTThreeDSecureRequest *threeDSecureRequest = [[BTThreeDSecureRequest alloc] init];
58
60
  threeDSecureRequest.amount = [NSDecimalNumber decimalNumberWithString:threeDSecureAmount.stringValue];
61
+ threeDSecureRequest.versionRequested = BTThreeDSecureVersion2;
62
+
63
+ NSString *threeDSecureEmail = threeDSecureOptions[@"email"];
64
+ if(threeDSecureEmail) {
65
+ threeDSecureRequest.email = threeDSecureEmail;
66
+ }
67
+
68
+ NSDictionary* threeDSecureBillingAddress = threeDSecureOptions[@"billingAddress"];
69
+ if(threeDSecureBillingAddress) {
70
+ BTThreeDSecurePostalAddress *billingAddress = [BTThreeDSecurePostalAddress new];
71
+
72
+ if(threeDSecureBillingAddress[@"givenName"]) {
73
+ billingAddress.givenName = threeDSecureBillingAddress[@"givenName"];
74
+ }
75
+ if(threeDSecureBillingAddress[@"surname"]) {
76
+ billingAddress.surname = threeDSecureBillingAddress[@"surname"];
77
+ }
78
+ if(threeDSecureBillingAddress[@"streetAddress"]) {
79
+ billingAddress.streetAddress = threeDSecureBillingAddress[@"streetAddress"];
80
+ }
81
+ if(threeDSecureBillingAddress[@"extendedAddress"]) {
82
+ billingAddress.extendedAddress = threeDSecureBillingAddress[@"extendedAddress"];
83
+ }
84
+ if(threeDSecureBillingAddress[@"locality"]) {
85
+ billingAddress.locality = threeDSecureBillingAddress[@"locality"];
86
+ }
87
+ if(threeDSecureBillingAddress[@"region"]) {
88
+ billingAddress.region = threeDSecureBillingAddress[@"region"];
89
+ }
90
+ if(threeDSecureBillingAddress[@"countryCodeAlpha2"]) {
91
+ billingAddress.countryCodeAlpha2 = threeDSecureBillingAddress[@"countryCodeAlpha2"];
92
+ }
93
+ if(threeDSecureBillingAddress[@"postalCode"]) {
94
+ billingAddress.postalCode = threeDSecureBillingAddress[@"postalCode"];
95
+ }
96
+ if(threeDSecureBillingAddress[@"phoneNumber"]) {
97
+ billingAddress.phoneNumber = threeDSecureBillingAddress[@"phoneNumber"];
98
+ }
99
+ threeDSecureRequest.billingAddress = billingAddress;
100
+ }
101
+
59
102
  request.threeDSecureRequest = threeDSecureRequest;
60
103
 
61
104
  }
package/package.json CHANGED
@@ -1,10 +1,13 @@
1
1
  {
2
2
  "name": "@xbenjii/react-native-braintree-dropin-ui",
3
- "version": "2.1.0",
3
+ "version": "2.2.0",
4
4
  "description": "> React Native integration of Braintree Drop-in IOS V4 ANDROID V2 (Apple Pay &Android Pay Enabled)",
5
5
  "main": "index.js",
6
6
  "dependencies": {},
7
- "devDependencies": {},
7
+ "devDependencies": {
8
+ "react": "^18.2.0",
9
+ "react-native": "^0.73.8"
10
+ },
8
11
  "scripts": {
9
12
  "test": "echo \"Error: no test specified\" && exit 1"
10
13
  },
@@ -20,6 +23,7 @@
20
23
  "drop-in-ui"
21
24
  ],
22
25
  "peerDependencies": {
26
+ "react": "*",
23
27
  "react-native": "*"
24
28
  },
25
29
  "author": "Ben Fortune <github@xbenjii.co.uk>",