react-native-payengine 1.0.5
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/LICENSE +20 -0
- package/README.md +152 -0
- package/android/.gradle/5.6.4/fileChanges/last-build.bin +0 -0
- package/android/.gradle/5.6.4/fileHashes/fileHashes.bin +0 -0
- package/android/.gradle/5.6.4/fileHashes/fileHashes.lock +0 -0
- package/android/.gradle/5.6.4/gc.properties +0 -0
- package/android/.gradle/buildOutputCleanup/buildOutputCleanup.lock +0 -0
- package/android/.gradle/buildOutputCleanup/cache.properties +2 -0
- package/android/.gradle/buildOutputCleanup/outputFiles.bin +0 -0
- package/android/.gradle/vcs-1/gc.properties +0 -0
- package/android/.idea/compiler.xml +6 -0
- package/android/.idea/gradle.xml +18 -0
- package/android/.idea/jarRepositories.xml +35 -0
- package/android/.idea/misc.xml +10 -0
- package/android/.idea/vcs.xml +6 -0
- package/android/build.gradle +147 -0
- package/android/gradle/wrapper/gradle-wrapper.jar +0 -0
- package/android/gradle/wrapper/gradle-wrapper.properties +6 -0
- package/android/gradle.properties +5 -0
- package/android/gradlew +172 -0
- package/android/gradlew.bat +84 -0
- package/android/local.properties +8 -0
- package/android/src/main/AndroidManifest.xml +4 -0
- package/android/src/main/java/com/reactnativepayengine/PayengineModule.java +33 -0
- package/android/src/main/java/com/reactnativepayengine/PayenginePackage.java +64 -0
- package/android/src/main/java/com/reactnativepayengine/collect/VGSCollectModule.java +148 -0
- package/android/src/main/java/com/reactnativepayengine/collect/VGSCollectOnCreateViewInstanceListener.java +6 -0
- package/android/src/main/java/com/reactnativepayengine/collect/fields/VGSCVCField.java +67 -0
- package/android/src/main/java/com/reactnativepayengine/collect/fields/VGSCardHolderNameField.java +53 -0
- package/android/src/main/java/com/reactnativepayengine/collect/fields/VGSCardNumberField.java +57 -0
- package/android/src/main/java/com/reactnativepayengine/collect/fields/VGSExpDateField.java +54 -0
- package/android/src/main/java/com/reactnativepayengine/collect/fields/VGSTextField.java +57 -0
- package/android/src/main/java/com/reactnativepayengine/collect/fields/VGSZipCodeField.java +62 -0
- package/android/src/main/java/com/reactnativepayengine/util/JSONObjectUtil.java +138 -0
- package/android/src/main/java/com/reactnativepayengine/util/ResourceUtil.java +14 -0
- package/android/vgscollect-1.7.2-debug.aar +0 -0
- package/ios/Payengine-Bridging-Header.h +2 -0
- package/ios/Payengine.m +55 -0
- package/ios/Payengine.swift +637 -0
- package/ios/Payengine.xcodeproj/project.pbxproj +317 -0
- package/ios/Payengine.xcodeproj/project.xcworkspace/contents.xcworkspacedata +7 -0
- package/ios/Payengine.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -0
- package/ios/Payengine.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved +34 -0
- package/ios/Payengine.xcodeproj/project.xcworkspace/xcuserdata/tringuyen.xcuserdatad/UserInterfaceState.xcuserstate +0 -0
- package/ios/Payengine.xcodeproj/xcuserdata/tringuyen.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist +24 -0
- package/ios/Payengine.xcodeproj/xcuserdata/tringuyen.xcuserdatad/xcschemes/xcschememanagement.plist +14 -0
- package/ios/Payengine.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -0
- package/ios/Payengine.xcworkspace/xcuserdata/tringuyen.xcuserdatad/UserInterfaceState.xcuserstate +0 -0
- package/ios/Pods/Pods.xcodeproj/xcuserdata/tringuyen.xcuserdatad/xcschemes/Pods-Payengine.xcscheme +58 -0
- package/ios/Pods/Pods.xcodeproj/xcuserdata/tringuyen.xcuserdatad/xcschemes/VGSCollectSDK-CardIcon.xcscheme +58 -0
- package/ios/Pods/Pods.xcodeproj/xcuserdata/tringuyen.xcuserdatad/xcschemes/VGSCollectSDK.xcscheme +58 -0
- package/ios/Pods/Pods.xcodeproj/xcuserdata/tringuyen.xcuserdatad/xcschemes/xcschememanagement.plist +32 -0
- package/lib/commonjs/components/LoadingIndicator.js +42 -0
- package/lib/commonjs/components/LoadingIndicator.js.map +1 -0
- package/lib/commonjs/components/PayEngine.js +141 -0
- package/lib/commonjs/components/PayEngine.js.map +1 -0
- package/lib/commonjs/components/SecureFields/VGS/CVCField.js +26 -0
- package/lib/commonjs/components/SecureFields/VGS/CVCField.js.map +1 -0
- package/lib/commonjs/components/SecureFields/VGS/CardHolderNameField.js +26 -0
- package/lib/commonjs/components/SecureFields/VGS/CardHolderNameField.js.map +1 -0
- package/lib/commonjs/components/SecureFields/VGS/CardNumberField.js +26 -0
- package/lib/commonjs/components/SecureFields/VGS/CardNumberField.js.map +1 -0
- package/lib/commonjs/components/SecureFields/VGS/CollectManager.js +65 -0
- package/lib/commonjs/components/SecureFields/VGS/CollectManager.js.map +1 -0
- package/lib/commonjs/components/SecureFields/VGS/ExpDateField.js +26 -0
- package/lib/commonjs/components/SecureFields/VGS/ExpDateField.js.map +1 -0
- package/lib/commonjs/components/SecureFields/VGS/TextField.js +30 -0
- package/lib/commonjs/components/SecureFields/VGS/TextField.js.map +1 -0
- package/lib/commonjs/components/SecureFields/VGS/ZipCodeField.js +26 -0
- package/lib/commonjs/components/SecureFields/VGS/ZipCodeField.js.map +1 -0
- package/lib/commonjs/components/SecureFields/index.js +34 -0
- package/lib/commonjs/components/SecureFields/index.js.map +1 -0
- package/lib/commonjs/index.js +42 -0
- package/lib/commonjs/index.js.map +1 -0
- package/lib/commonjs/utils/index.js +112 -0
- package/lib/commonjs/utils/index.js.map +1 -0
- package/lib/module/components/LoadingIndicator.js +28 -0
- package/lib/module/components/LoadingIndicator.js.map +1 -0
- package/lib/module/components/PayEngine.js +124 -0
- package/lib/module/components/PayEngine.js.map +1 -0
- package/lib/module/components/SecureFields/VGS/CVCField.js +14 -0
- package/lib/module/components/SecureFields/VGS/CVCField.js.map +1 -0
- package/lib/module/components/SecureFields/VGS/CardHolderNameField.js +14 -0
- package/lib/module/components/SecureFields/VGS/CardHolderNameField.js.map +1 -0
- package/lib/module/components/SecureFields/VGS/CardNumberField.js +14 -0
- package/lib/module/components/SecureFields/VGS/CardNumberField.js.map +1 -0
- package/lib/module/components/SecureFields/VGS/CollectManager.js +50 -0
- package/lib/module/components/SecureFields/VGS/CollectManager.js.map +1 -0
- package/lib/module/components/SecureFields/VGS/ExpDateField.js +14 -0
- package/lib/module/components/SecureFields/VGS/ExpDateField.js.map +1 -0
- package/lib/module/components/SecureFields/VGS/TextField.js +17 -0
- package/lib/module/components/SecureFields/VGS/TextField.js.map +1 -0
- package/lib/module/components/SecureFields/VGS/ZipCodeField.js +14 -0
- package/lib/module/components/SecureFields/VGS/ZipCodeField.js.map +1 -0
- package/lib/module/components/SecureFields/index.js +17 -0
- package/lib/module/components/SecureFields/index.js.map +1 -0
- package/lib/module/index.js +18 -0
- package/lib/module/index.js.map +1 -0
- package/lib/module/utils/index.js +96 -0
- package/lib/module/utils/index.js.map +1 -0
- package/lib/typescript/components/LoadingIndicator.d.ts +2 -0
- package/lib/typescript/components/PayEngine.d.ts +15 -0
- package/lib/typescript/components/SecureFields/VGS/CVCField.d.ts +10 -0
- package/lib/typescript/components/SecureFields/VGS/CardHolderNameField.d.ts +10 -0
- package/lib/typescript/components/SecureFields/VGS/CardNumberField.d.ts +10 -0
- package/lib/typescript/components/SecureFields/VGS/CollectManager.d.ts +12 -0
- package/lib/typescript/components/SecureFields/VGS/ExpDateField.d.ts +10 -0
- package/lib/typescript/components/SecureFields/VGS/TextField.d.ts +14 -0
- package/lib/typescript/components/SecureFields/VGS/ZipCodeField.d.ts +10 -0
- package/lib/typescript/components/SecureFields/index.d.ts +16 -0
- package/lib/typescript/index.d.ts +5 -0
- package/lib/typescript/utils/index.d.ts +45 -0
- package/package.json +154 -0
- package/react-native-payengine.podspec +38 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2022 PayEngine Team
|
|
4
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
5
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
6
|
+
in the Software without restriction, including without limitation the rights
|
|
7
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
8
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
9
|
+
furnished to do so, subject to the following conditions:
|
|
10
|
+
|
|
11
|
+
The above copyright notice and this permission notice shall be included in all
|
|
12
|
+
copies or substantial portions of the Software.
|
|
13
|
+
|
|
14
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
15
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
16
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
17
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
18
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
19
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
20
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
# react-native-payengine
|
|
2
|
+
|
|
3
|
+
React Native SDK for PayEngine
|
|
4
|
+
|
|
5
|
+
## Installation
|
|
6
|
+
|
|
7
|
+
```sh
|
|
8
|
+
npm install react-native-payengine
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
#### Expo managed project
|
|
12
|
+
|
|
13
|
+
To be updated
|
|
14
|
+
|
|
15
|
+
#### Install dependencies into a bare React Native project
|
|
16
|
+
|
|
17
|
+
In your project directory, run:
|
|
18
|
+
|
|
19
|
+
```sh
|
|
20
|
+
npm install react-native-webview
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
Visit https://github.com/react-native-webview/react-native-webview to view additional installation step if you're using manually linking.
|
|
24
|
+
|
|
25
|
+
From React Native 0.6.0 and higher, linking is automatic. So you don't need to run `react-native link`
|
|
26
|
+
|
|
27
|
+
If you're on a Mac and developing for iOS, you need to install the pods (via Cocoapods) to complete the linking.
|
|
28
|
+
|
|
29
|
+
```
|
|
30
|
+
npx pod-install ios
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
## Usage
|
|
34
|
+
|
|
35
|
+
#### Configuration
|
|
36
|
+
|
|
37
|
+
```
|
|
38
|
+
const configuration = {
|
|
39
|
+
publicKey: "pk_dev_lQm6u1h9yaSPO6qGJaAt4lTf5GBlehCI",
|
|
40
|
+
scriptURL: "http://localhost:3000/js/1.0.0/embed.js",
|
|
41
|
+
logLevel: 1
|
|
42
|
+
}
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
#### Embedded UI
|
|
46
|
+
|
|
47
|
+
```js
|
|
48
|
+
import { PayEngine } from 'react-native-payengine';
|
|
49
|
+
|
|
50
|
+
<PayEngine
|
|
51
|
+
type="boarding"
|
|
52
|
+
merchant-id="07f6ee61-1548-4ffa-a1dc-f671c837ceb9"
|
|
53
|
+
events={{
|
|
54
|
+
stepChange: (eventData: any) => {
|
|
55
|
+
console.log({ eventData });
|
|
56
|
+
},
|
|
57
|
+
}}
|
|
58
|
+
config={configuration}
|
|
59
|
+
/>;
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
#### Secure Fields
|
|
63
|
+
|
|
64
|
+
```js
|
|
65
|
+
import * as React from 'react';
|
|
66
|
+
import { View, Text, StyleSheet, Button, ScrollView } from 'react-native';
|
|
67
|
+
import { SecureFields } from 'react-native-payengine';
|
|
68
|
+
|
|
69
|
+
export function Payment() {
|
|
70
|
+
const secureFieldRef = React.createRef<any>()
|
|
71
|
+
const [secureFieldsResult, setSecureFieldsResult] = React.useState('')
|
|
72
|
+
const [submitting, setSubmitting] = React.useState(false)
|
|
73
|
+
|
|
74
|
+
const createCard = async () => {
|
|
75
|
+
try {
|
|
76
|
+
setSubmitting(true)
|
|
77
|
+
const result = await secureFieldRef.current?.createCard()
|
|
78
|
+
setSecureFieldsResult(result)
|
|
79
|
+
} catch (err: any) {
|
|
80
|
+
setSecureFieldsResult(err.message)
|
|
81
|
+
} finally {
|
|
82
|
+
setSubmitting(false)
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
|
|
87
|
+
return (
|
|
88
|
+
<View style={styles.container}>
|
|
89
|
+
<Text>Welcome to PayEngine React Native SDK example</Text>
|
|
90
|
+
<Text>Click the hamburger menu above to browse our examples</Text>
|
|
91
|
+
|
|
92
|
+
<View style={{ height: 30 }} />
|
|
93
|
+
<Text style={{ fontSize: 18, fontWeight: '600' }}>Secure Fields</Text>
|
|
94
|
+
<SecureFields.CollectManager ref={secureFieldRef} config={configuration}>
|
|
95
|
+
<SecureFields.CardHolderNameField style={styles.field} />
|
|
96
|
+
<SecureFields.CardNumberField placeholder="Card number" style={styles.field} />
|
|
97
|
+
<View style={{ display: 'flex', flexDirection: "row", width: '100%', height: 50, margin: 8 }}>
|
|
98
|
+
<SecureFields.ExpDateTextField style={[styles.field, { flex: 1, margin: 0, marginRight: 10 }]} />
|
|
99
|
+
<SecureFields.CVCField style={[styles.field, { flex: 1, margin: 0 }]} />
|
|
100
|
+
</View>
|
|
101
|
+
<SecureFields.ZipCodeField placeholder="Zip code" style={styles.field} />
|
|
102
|
+
|
|
103
|
+
<Button disabled={submitting} onPress={() => createCard()} title="Create Card" />
|
|
104
|
+
|
|
105
|
+
</SecureFields.CollectManager>
|
|
106
|
+
<ScrollView scrollEnabled={true} style={{ flex: 1, width: '100%', backgroundColor: 'lightyellow', padding: 10, marginVertical: 20 }}>
|
|
107
|
+
<Text>{JSON.stringify(secureFieldsResult, null, 4)}</Text>
|
|
108
|
+
</ScrollView>
|
|
109
|
+
</View>
|
|
110
|
+
);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
const styles = StyleSheet.create({
|
|
114
|
+
container: {
|
|
115
|
+
flex: 1,
|
|
116
|
+
display: 'flex',
|
|
117
|
+
padding: 20,
|
|
118
|
+
alignItems: 'center',
|
|
119
|
+
justifyContent: 'center'
|
|
120
|
+
},
|
|
121
|
+
field: {
|
|
122
|
+
width: '100%',
|
|
123
|
+
height: 50,
|
|
124
|
+
margin: 8,
|
|
125
|
+
padding: 5
|
|
126
|
+
}
|
|
127
|
+
})
|
|
128
|
+
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
|
|
132
|
+
## Troubleshooting
|
|
133
|
+
|
|
134
|
+
If your android Emulator can't connect to metro bundler
|
|
135
|
+
|
|
136
|
+
*android/src/debug/res/xml/network.xml*
|
|
137
|
+
```
|
|
138
|
+
<?xml version="1.0" encoding="utf-8"?>
|
|
139
|
+
<network-security-config>
|
|
140
|
+
<domain-config cleartextTrafficPermitted="true">
|
|
141
|
+
<domain includeSubdomains="true">localhost</domain>
|
|
142
|
+
<domain includeSubdomains="true">10.0.2.2</domain>
|
|
143
|
+
</domain-config>
|
|
144
|
+
</network-security-config>
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
*android/src/debug/AndroidManifest.xml*
|
|
148
|
+
```
|
|
149
|
+
...
|
|
150
|
+
android:networkSecurityConfig="@xml/network"
|
|
151
|
+
...
|
|
152
|
+
```
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
File without changes
|
|
Binary file
|
|
Binary file
|
|
File without changes
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<project version="4">
|
|
3
|
+
<component name="GradleMigrationSettings" migrationVersion="1" />
|
|
4
|
+
<component name="GradleSettings">
|
|
5
|
+
<option name="linkedExternalProjectsSettings">
|
|
6
|
+
<GradleProjectSettings>
|
|
7
|
+
<option name="testRunner" value="GRADLE" />
|
|
8
|
+
<option name="distributionType" value="DEFAULT_WRAPPED" />
|
|
9
|
+
<option name="externalProjectPath" value="$PROJECT_DIR$" />
|
|
10
|
+
<option name="modules">
|
|
11
|
+
<set>
|
|
12
|
+
<option value="$PROJECT_DIR$" />
|
|
13
|
+
</set>
|
|
14
|
+
</option>
|
|
15
|
+
</GradleProjectSettings>
|
|
16
|
+
</option>
|
|
17
|
+
</component>
|
|
18
|
+
</project>
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<project version="4">
|
|
3
|
+
<component name="RemoteRepositoriesConfiguration">
|
|
4
|
+
<remote-repository>
|
|
5
|
+
<option name="id" value="central" />
|
|
6
|
+
<option name="name" value="Maven Central repository" />
|
|
7
|
+
<option name="url" value="https://repo1.maven.org/maven2" />
|
|
8
|
+
</remote-repository>
|
|
9
|
+
<remote-repository>
|
|
10
|
+
<option name="id" value="jboss.community" />
|
|
11
|
+
<option name="name" value="JBoss Community repository" />
|
|
12
|
+
<option name="url" value="https://repository.jboss.org/nexus/content/repositories/public/" />
|
|
13
|
+
</remote-repository>
|
|
14
|
+
<remote-repository>
|
|
15
|
+
<option name="id" value="MavenRepo" />
|
|
16
|
+
<option name="name" value="MavenRepo" />
|
|
17
|
+
<option name="url" value="https://repo.maven.apache.org/maven2/" />
|
|
18
|
+
</remote-repository>
|
|
19
|
+
<remote-repository>
|
|
20
|
+
<option name="id" value="React Native sources" />
|
|
21
|
+
<option name="name" value="React Native sources" />
|
|
22
|
+
<option name="url" value="file:$PROJECT_DIR$/../node_modules/react-native/android/" />
|
|
23
|
+
</remote-repository>
|
|
24
|
+
<remote-repository>
|
|
25
|
+
<option name="id" value="Google" />
|
|
26
|
+
<option name="name" value="Google" />
|
|
27
|
+
<option name="url" value="https://dl.google.com/dl/android/maven2/" />
|
|
28
|
+
</remote-repository>
|
|
29
|
+
<remote-repository>
|
|
30
|
+
<option name="id" value="com.verygoodsecurity" />
|
|
31
|
+
<option name="name" value="com.verygoodsecurity" />
|
|
32
|
+
<option name="url" value="https://mvnrepository.com/artifact/com.verygoodsecurity/vgscollect" />
|
|
33
|
+
</remote-repository>
|
|
34
|
+
</component>
|
|
35
|
+
</project>
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<project version="4">
|
|
3
|
+
<component name="ExternalStorageConfigurationManager" enabled="true" />
|
|
4
|
+
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_8" default="true" project-jdk-name="1.8" project-jdk-type="JavaSDK">
|
|
5
|
+
<output url="file://$PROJECT_DIR$/build/classes" />
|
|
6
|
+
</component>
|
|
7
|
+
<component name="ProjectType">
|
|
8
|
+
<option name="id" value="Android" />
|
|
9
|
+
</component>
|
|
10
|
+
</project>
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
buildscript {
|
|
2
|
+
repositories {
|
|
3
|
+
google()
|
|
4
|
+
mavenCentral()
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
dependencies {
|
|
8
|
+
classpath 'com.android.tools.build:gradle:3.5.3'
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
def isNewArchitectureEnabled() {
|
|
13
|
+
return rootProject.hasProperty("newArchEnabled") && rootProject.getProperty("newArchEnabled") == "true"
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
apply plugin: 'com.android.library'
|
|
17
|
+
|
|
18
|
+
if (isNewArchitectureEnabled()) {
|
|
19
|
+
apply plugin: 'com.facebook.react'
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
def getExtOrDefault(name) {
|
|
23
|
+
return rootProject.ext.has(name) ? rootProject.ext.get(name) : project.properties['Payengine_' + name]
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
def getExtOrIntegerDefault(name) {
|
|
27
|
+
return rootProject.ext.has(name) ? rootProject.ext.get(name) : (project.properties['Payengine_' + name]).toInteger()
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
android {
|
|
31
|
+
compileSdkVersion getExtOrIntegerDefault('compileSdkVersion')
|
|
32
|
+
|
|
33
|
+
defaultConfig {
|
|
34
|
+
minSdkVersion getExtOrIntegerDefault('minSdkVersion')
|
|
35
|
+
targetSdkVersion getExtOrIntegerDefault('targetSdkVersion')
|
|
36
|
+
buildConfigField "boolean", "IS_NEW_ARCHITECTURE_ENABLED", isNewArchitectureEnabled().toString()
|
|
37
|
+
}
|
|
38
|
+
buildTypes {
|
|
39
|
+
release {
|
|
40
|
+
minifyEnabled false
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
lintOptions {
|
|
45
|
+
disable 'GradleCompatible'
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
compileOptions {
|
|
49
|
+
sourceCompatibility JavaVersion.VERSION_1_8
|
|
50
|
+
targetCompatibility JavaVersion.VERSION_1_8
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
repositories {
|
|
55
|
+
mavenCentral()
|
|
56
|
+
google()
|
|
57
|
+
|
|
58
|
+
def found = false
|
|
59
|
+
def defaultDir = null
|
|
60
|
+
def androidSourcesName = 'React Native sources'
|
|
61
|
+
|
|
62
|
+
if (rootProject.ext.has('reactNativeAndroidRoot')) {
|
|
63
|
+
defaultDir = rootProject.ext.get('reactNativeAndroidRoot')
|
|
64
|
+
} else {
|
|
65
|
+
defaultDir = new File(
|
|
66
|
+
projectDir,
|
|
67
|
+
'/../../../node_modules/react-native/android'
|
|
68
|
+
)
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
if (defaultDir.exists()) {
|
|
72
|
+
maven {
|
|
73
|
+
url defaultDir.toString()
|
|
74
|
+
name androidSourcesName
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
logger.info(":${project.name}:reactNativeAndroidRoot ${defaultDir.canonicalPath}")
|
|
78
|
+
found = true
|
|
79
|
+
} else {
|
|
80
|
+
def parentDir = rootProject.projectDir
|
|
81
|
+
|
|
82
|
+
1.upto(5, {
|
|
83
|
+
if (found) return true
|
|
84
|
+
parentDir = parentDir.parentFile
|
|
85
|
+
|
|
86
|
+
def androidSourcesDir = new File(
|
|
87
|
+
parentDir,
|
|
88
|
+
'node_modules/react-native'
|
|
89
|
+
)
|
|
90
|
+
|
|
91
|
+
def androidPrebuiltBinaryDir = new File(
|
|
92
|
+
parentDir,
|
|
93
|
+
'node_modules/react-native/android'
|
|
94
|
+
)
|
|
95
|
+
|
|
96
|
+
if (androidPrebuiltBinaryDir.exists()) {
|
|
97
|
+
maven {
|
|
98
|
+
url androidPrebuiltBinaryDir.toString()
|
|
99
|
+
name androidSourcesName
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
logger.info(":${project.name}:reactNativeAndroidRoot ${androidPrebuiltBinaryDir.canonicalPath}")
|
|
103
|
+
found = true
|
|
104
|
+
} else if (androidSourcesDir.exists()) {
|
|
105
|
+
maven {
|
|
106
|
+
url androidSourcesDir.toString()
|
|
107
|
+
name androidSourcesName
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
logger.info(":${project.name}:reactNativeAndroidRoot ${androidSourcesDir.canonicalPath}")
|
|
111
|
+
found = true
|
|
112
|
+
}
|
|
113
|
+
})
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
if (!found) {
|
|
117
|
+
throw new GradleException(
|
|
118
|
+
"${project.name}: unable to locate React Native android sources. " +
|
|
119
|
+
"Ensure you have you installed React Native as a dependency in your project and try again."
|
|
120
|
+
)
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
|
|
125
|
+
dependencies {
|
|
126
|
+
//noinspection GradleDynamicVersion
|
|
127
|
+
implementation "com.facebook.react:react-native:+"
|
|
128
|
+
|
|
129
|
+
implementation "com.google.android.material:material:1.6.1"
|
|
130
|
+
|
|
131
|
+
// https://mvnrepository.com/artifact/com.verygoodsecurity/vgscollect
|
|
132
|
+
// releaseImplementation 'com.verygoodsecurity:vgscollect:1.7.2'
|
|
133
|
+
releaseImplementation files('./vgscollect-1.7.2-debug.aar')
|
|
134
|
+
debugImplementation files('./vgscollect-1.7.2-debug.aar')
|
|
135
|
+
|
|
136
|
+
|
|
137
|
+
|
|
138
|
+
// From node_modules
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
if (isNewArchitectureEnabled()) {
|
|
142
|
+
react {
|
|
143
|
+
jsRootDir = file("../src/")
|
|
144
|
+
libraryName = "Payengine"
|
|
145
|
+
codegenJavaPackageName = "com.reactnativepayengine"
|
|
146
|
+
}
|
|
147
|
+
}
|
|
Binary file
|
package/android/gradlew
ADDED
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
#!/usr/bin/env sh
|
|
2
|
+
|
|
3
|
+
##############################################################################
|
|
4
|
+
##
|
|
5
|
+
## Gradle start up script for UN*X
|
|
6
|
+
##
|
|
7
|
+
##############################################################################
|
|
8
|
+
|
|
9
|
+
# Attempt to set APP_HOME
|
|
10
|
+
# Resolve links: $0 may be a link
|
|
11
|
+
PRG="$0"
|
|
12
|
+
# Need this for relative symlinks.
|
|
13
|
+
while [ -h "$PRG" ] ; do
|
|
14
|
+
ls=`ls -ld "$PRG"`
|
|
15
|
+
link=`expr "$ls" : '.*-> \(.*\)$'`
|
|
16
|
+
if expr "$link" : '/.*' > /dev/null; then
|
|
17
|
+
PRG="$link"
|
|
18
|
+
else
|
|
19
|
+
PRG=`dirname "$PRG"`"/$link"
|
|
20
|
+
fi
|
|
21
|
+
done
|
|
22
|
+
SAVED="`pwd`"
|
|
23
|
+
cd "`dirname \"$PRG\"`/" >/dev/null
|
|
24
|
+
APP_HOME="`pwd -P`"
|
|
25
|
+
cd "$SAVED" >/dev/null
|
|
26
|
+
|
|
27
|
+
APP_NAME="Gradle"
|
|
28
|
+
APP_BASE_NAME=`basename "$0"`
|
|
29
|
+
|
|
30
|
+
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
|
31
|
+
DEFAULT_JVM_OPTS=""
|
|
32
|
+
|
|
33
|
+
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
|
34
|
+
MAX_FD="maximum"
|
|
35
|
+
|
|
36
|
+
warn () {
|
|
37
|
+
echo "$*"
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
die () {
|
|
41
|
+
echo
|
|
42
|
+
echo "$*"
|
|
43
|
+
echo
|
|
44
|
+
exit 1
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
# OS specific support (must be 'true' or 'false').
|
|
48
|
+
cygwin=false
|
|
49
|
+
msys=false
|
|
50
|
+
darwin=false
|
|
51
|
+
nonstop=false
|
|
52
|
+
case "`uname`" in
|
|
53
|
+
CYGWIN* )
|
|
54
|
+
cygwin=true
|
|
55
|
+
;;
|
|
56
|
+
Darwin* )
|
|
57
|
+
darwin=true
|
|
58
|
+
;;
|
|
59
|
+
MINGW* )
|
|
60
|
+
msys=true
|
|
61
|
+
;;
|
|
62
|
+
NONSTOP* )
|
|
63
|
+
nonstop=true
|
|
64
|
+
;;
|
|
65
|
+
esac
|
|
66
|
+
|
|
67
|
+
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
|
|
68
|
+
|
|
69
|
+
# Determine the Java command to use to start the JVM.
|
|
70
|
+
if [ -n "$JAVA_HOME" ] ; then
|
|
71
|
+
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
|
72
|
+
# IBM's JDK on AIX uses strange locations for the executables
|
|
73
|
+
JAVACMD="$JAVA_HOME/jre/sh/java"
|
|
74
|
+
else
|
|
75
|
+
JAVACMD="$JAVA_HOME/bin/java"
|
|
76
|
+
fi
|
|
77
|
+
if [ ! -x "$JAVACMD" ] ; then
|
|
78
|
+
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
|
|
79
|
+
|
|
80
|
+
Please set the JAVA_HOME variable in your environment to match the
|
|
81
|
+
location of your Java installation."
|
|
82
|
+
fi
|
|
83
|
+
else
|
|
84
|
+
JAVACMD="java"
|
|
85
|
+
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
|
86
|
+
|
|
87
|
+
Please set the JAVA_HOME variable in your environment to match the
|
|
88
|
+
location of your Java installation."
|
|
89
|
+
fi
|
|
90
|
+
|
|
91
|
+
# Increase the maximum file descriptors if we can.
|
|
92
|
+
if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
|
|
93
|
+
MAX_FD_LIMIT=`ulimit -H -n`
|
|
94
|
+
if [ $? -eq 0 ] ; then
|
|
95
|
+
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
|
|
96
|
+
MAX_FD="$MAX_FD_LIMIT"
|
|
97
|
+
fi
|
|
98
|
+
ulimit -n $MAX_FD
|
|
99
|
+
if [ $? -ne 0 ] ; then
|
|
100
|
+
warn "Could not set maximum file descriptor limit: $MAX_FD"
|
|
101
|
+
fi
|
|
102
|
+
else
|
|
103
|
+
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
|
|
104
|
+
fi
|
|
105
|
+
fi
|
|
106
|
+
|
|
107
|
+
# For Darwin, add options to specify how the application appears in the dock
|
|
108
|
+
if $darwin; then
|
|
109
|
+
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
|
|
110
|
+
fi
|
|
111
|
+
|
|
112
|
+
# For Cygwin, switch paths to Windows format before running java
|
|
113
|
+
if $cygwin ; then
|
|
114
|
+
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
|
|
115
|
+
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
|
|
116
|
+
JAVACMD=`cygpath --unix "$JAVACMD"`
|
|
117
|
+
|
|
118
|
+
# We build the pattern for arguments to be converted via cygpath
|
|
119
|
+
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
|
|
120
|
+
SEP=""
|
|
121
|
+
for dir in $ROOTDIRSRAW ; do
|
|
122
|
+
ROOTDIRS="$ROOTDIRS$SEP$dir"
|
|
123
|
+
SEP="|"
|
|
124
|
+
done
|
|
125
|
+
OURCYGPATTERN="(^($ROOTDIRS))"
|
|
126
|
+
# Add a user-defined pattern to the cygpath arguments
|
|
127
|
+
if [ "$GRADLE_CYGPATTERN" != "" ] ; then
|
|
128
|
+
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
|
|
129
|
+
fi
|
|
130
|
+
# Now convert the arguments - kludge to limit ourselves to /bin/sh
|
|
131
|
+
i=0
|
|
132
|
+
for arg in "$@" ; do
|
|
133
|
+
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
|
|
134
|
+
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
|
|
135
|
+
|
|
136
|
+
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
|
|
137
|
+
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
|
|
138
|
+
else
|
|
139
|
+
eval `echo args$i`="\"$arg\""
|
|
140
|
+
fi
|
|
141
|
+
i=$((i+1))
|
|
142
|
+
done
|
|
143
|
+
case $i in
|
|
144
|
+
(0) set -- ;;
|
|
145
|
+
(1) set -- "$args0" ;;
|
|
146
|
+
(2) set -- "$args0" "$args1" ;;
|
|
147
|
+
(3) set -- "$args0" "$args1" "$args2" ;;
|
|
148
|
+
(4) set -- "$args0" "$args1" "$args2" "$args3" ;;
|
|
149
|
+
(5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
|
|
150
|
+
(6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
|
|
151
|
+
(7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
|
|
152
|
+
(8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
|
|
153
|
+
(9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
|
|
154
|
+
esac
|
|
155
|
+
fi
|
|
156
|
+
|
|
157
|
+
# Escape application args
|
|
158
|
+
save () {
|
|
159
|
+
for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
|
|
160
|
+
echo " "
|
|
161
|
+
}
|
|
162
|
+
APP_ARGS=$(save "$@")
|
|
163
|
+
|
|
164
|
+
# Collect all arguments for the java command, following the shell quoting and substitution rules
|
|
165
|
+
eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
|
|
166
|
+
|
|
167
|
+
# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
|
|
168
|
+
if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
|
|
169
|
+
cd "$(dirname "$0")"
|
|
170
|
+
fi
|
|
171
|
+
|
|
172
|
+
exec "$JAVACMD" "$@"
|