@regulaforensics/idv 3.2.1-nightly

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 (140) hide show
  1. package/README.md +30 -0
  2. package/RNIDV.podspec +21 -0
  3. package/android/CVDIDV.kt +48 -0
  4. package/android/build.gradle +32 -0
  5. package/android/cordova.gradle +20 -0
  6. package/android/src/main/java/com/regula/plugin/idv/JSONConstructor.kt +135 -0
  7. package/android/src/main/java/com/regula/plugin/idv/Main.kt +124 -0
  8. package/android/src/main/java/com/regula/plugin/idv/RNIDVModule.kt +71 -0
  9. package/android/src/main/java/com/regula/plugin/idv/Utils.kt +60 -0
  10. package/examples/capacitor/README.md +15 -0
  11. package/examples/capacitor/android/app/build.gradle +50 -0
  12. package/examples/capacitor/android/app/capacitor.build.gradle +22 -0
  13. package/examples/capacitor/android/app/proguard-rules.pro +21 -0
  14. package/examples/capacitor/android/app/src/main/AndroidManifest.xml +26 -0
  15. package/examples/capacitor/android/app/src/main/assets/Regula/.gitkeep +0 -0
  16. package/examples/capacitor/android/app/src/main/java/com/regula/example/idv/capacitor/MainActivity.java +5 -0
  17. package/examples/capacitor/android/app/src/main/res/drawable/ic_launcher.png +0 -0
  18. package/examples/capacitor/android/app/src/main/res/drawable/ic_launcher_foreground.png +0 -0
  19. package/examples/capacitor/android/app/src/main/res/drawable/ic_launcher_round.png +0 -0
  20. package/examples/capacitor/android/app/src/main/res/drawable/launcher.xml +4 -0
  21. package/examples/capacitor/android/app/src/main/res/drawable/launcher_round.xml +4 -0
  22. package/examples/capacitor/android/app/src/main/res/drawable/splash.png +0 -0
  23. package/examples/capacitor/android/app/src/main/res/layout/activity_main.xml +12 -0
  24. package/examples/capacitor/android/app/src/main/res/values/styles.xml +22 -0
  25. package/examples/capacitor/android/build.gradle +30 -0
  26. package/examples/capacitor/android/capacitor.settings.gradle +15 -0
  27. package/examples/capacitor/android/gradle/wrapper/gradle-wrapper.jar +0 -0
  28. package/examples/capacitor/android/gradle/wrapper/gradle-wrapper.properties +7 -0
  29. package/examples/capacitor/android/gradle.properties +22 -0
  30. package/examples/capacitor/android/gradlew +252 -0
  31. package/examples/capacitor/android/gradlew.bat +94 -0
  32. package/examples/capacitor/android/settings.gradle +5 -0
  33. package/examples/capacitor/android/variables.gradle +16 -0
  34. package/examples/capacitor/index.html +5 -0
  35. package/examples/capacitor/index.tsx +16 -0
  36. package/examples/capacitor/ionic.config.json +7 -0
  37. package/examples/capacitor/ios/App/App/App.entitlements +10 -0
  38. package/examples/capacitor/ios/App/App/AppDelegate.swift +49 -0
  39. package/examples/capacitor/ios/App/App/Assets.xcassets/AppIcon.appiconset/AppIcon-512@2x.png +0 -0
  40. package/examples/capacitor/ios/App/App/Assets.xcassets/AppIcon.appiconset/Contents.json +14 -0
  41. package/examples/capacitor/ios/App/App/Assets.xcassets/Contents.json +6 -0
  42. package/examples/capacitor/ios/App/App/Assets.xcassets/Splash.imageset/Contents.json +23 -0
  43. package/examples/capacitor/ios/App/App/Assets.xcassets/Splash.imageset/splash-2732x2732-1.png +0 -0
  44. package/examples/capacitor/ios/App/App/Assets.xcassets/Splash.imageset/splash-2732x2732-2.png +0 -0
  45. package/examples/capacitor/ios/App/App/Assets.xcassets/Splash.imageset/splash-2732x2732.png +0 -0
  46. package/examples/capacitor/ios/App/App/Base.lproj/LaunchScreen.storyboard +32 -0
  47. package/examples/capacitor/ios/App/App/Base.lproj/Main.storyboard +19 -0
  48. package/examples/capacitor/ios/App/App/Info.plist +65 -0
  49. package/examples/capacitor/ios/App/App.xcodeproj/project.pbxproj +418 -0
  50. package/examples/capacitor/ios/App/App.xcodeproj/project.xcworkspace/contents.xcworkspacedata +7 -0
  51. package/examples/capacitor/ios/App/App.xcworkspace/contents.xcworkspacedata +10 -0
  52. package/examples/capacitor/ios/App/App.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -0
  53. package/examples/capacitor/ios/App/Podfile +26 -0
  54. package/examples/capacitor/package-lock.json +3350 -0
  55. package/examples/capacitor/package.json +27 -0
  56. package/examples/capacitor/public/assets/.gitkeep +0 -0
  57. package/examples/capacitor/scripts/android.sh +9 -0
  58. package/examples/capacitor/scripts/ios.sh +8 -0
  59. package/examples/capacitor/scripts/setup.sh +14 -0
  60. package/examples/capacitor/src/main.css +148 -0
  61. package/examples/capacitor/src/main.html +17 -0
  62. package/examples/capacitor/src/main.tsx +124 -0
  63. package/examples/capacitor/tsconfig.json +5 -0
  64. package/examples/capacitor/vite.config.ts +17 -0
  65. package/examples/ionic/README.md +15 -0
  66. package/examples/ionic/angular.json +39 -0
  67. package/examples/ionic/assets/.gitkeep +0 -0
  68. package/examples/ionic/config.xml +60 -0
  69. package/examples/ionic/images/icon.png +0 -0
  70. package/examples/ionic/index.html +19 -0
  71. package/examples/ionic/index.tsx +32 -0
  72. package/examples/ionic/ionic.config.json +7 -0
  73. package/examples/ionic/package-lock.json +14261 -0
  74. package/examples/ionic/package.json +46 -0
  75. package/examples/ionic/scripts/android.sh +8 -0
  76. package/examples/ionic/scripts/ios.sh +8 -0
  77. package/examples/ionic/scripts/setup.sh +8 -0
  78. package/examples/ionic/src/main.css +148 -0
  79. package/examples/ionic/src/main.html +17 -0
  80. package/examples/ionic/src/main.tsx +124 -0
  81. package/examples/ionic/tsconfig.json +14 -0
  82. package/examples/react_native/README.md +15 -0
  83. package/examples/react_native/app.config.ts +46 -0
  84. package/examples/react_native/assets/.gitkeep +0 -0
  85. package/examples/react_native/images/icon.png +0 -0
  86. package/examples/react_native/index.html +12 -0
  87. package/examples/react_native/index.tsx +63 -0
  88. package/examples/react_native/metro.config.js +7 -0
  89. package/examples/react_native/package-lock.json +8996 -0
  90. package/examples/react_native/package.json +29 -0
  91. package/examples/react_native/scripts/android.sh +13 -0
  92. package/examples/react_native/scripts/ios.sh +12 -0
  93. package/examples/react_native/scripts/setup.sh +12 -0
  94. package/examples/react_native/src/main.css +148 -0
  95. package/examples/react_native/src/main.html +17 -0
  96. package/examples/react_native/src/main.tsx +124 -0
  97. package/ios/CVDIDV.swift +51 -0
  98. package/ios/JSONConstructor.swift +132 -0
  99. package/ios/Main.swift +91 -0
  100. package/ios/RNIDV.m +11 -0
  101. package/ios/RNIDV.swift +47 -0
  102. package/ios/Utils.swift +52 -0
  103. package/package.json +38 -0
  104. package/plugin.xml +46 -0
  105. package/test/json.tsx +40 -0
  106. package/test/package-lock.json +584 -0
  107. package/test/package.json +9 -0
  108. package/test/test.tsx +13 -0
  109. package/test/utils.tsx +38 -0
  110. package/www/capacitor/config/api_key_connection_config.js +32 -0
  111. package/www/capacitor/config/credentials_connection_config.js +32 -0
  112. package/www/capacitor/config/prepare_workflow_config.js +20 -0
  113. package/www/capacitor/config/start_workflow_config.js +24 -0
  114. package/www/capacitor/config/token_connection_config.js +20 -0
  115. package/www/capacitor/index.js +110 -0
  116. package/www/capacitor/internal/bridge.js +30 -0
  117. package/www/capacitor/internal/cordova.js +17 -0
  118. package/www/capacitor/model/workflow.js +28 -0
  119. package/www/capacitor/model/workflow_result.js +21 -0
  120. package/www/capacitor/model/workflow_step.js +19 -0
  121. package/www/cordova.js +595 -0
  122. package/www/react-native/config/api_key_connection_config.js +32 -0
  123. package/www/react-native/config/credentials_connection_config.js +32 -0
  124. package/www/react-native/config/prepare_workflow_config.js +20 -0
  125. package/www/react-native/config/start_workflow_config.js +24 -0
  126. package/www/react-native/config/token_connection_config.js +20 -0
  127. package/www/react-native/index.js +110 -0
  128. package/www/react-native/internal/bridge.js +30 -0
  129. package/www/react-native/model/workflow.js +28 -0
  130. package/www/react-native/model/workflow_result.js +21 -0
  131. package/www/react-native/model/workflow_step.js +19 -0
  132. package/www/types/config/api_key_connection_config.d.ts +6 -0
  133. package/www/types/config/credentials_connection_config.d.ts +6 -0
  134. package/www/types/config/prepare_workflow_config.d.ts +3 -0
  135. package/www/types/config/start_workflow_config.d.ts +4 -0
  136. package/www/types/config/token_connection_config.d.ts +3 -0
  137. package/www/types/index.d.ts +62 -0
  138. package/www/types/model/workflow.d.ts +9 -0
  139. package/www/types/model/workflow_result.d.ts +8 -0
  140. package/www/types/model/workflow_step.d.ts +6 -0
@@ -0,0 +1,46 @@
1
+ {
2
+ "name": "idv",
3
+ "scripts": {
4
+ "setup": "scripts/setup.sh",
5
+ "ios": "scripts/ios.sh",
6
+ "android": "scripts/android.sh"
7
+ },
8
+ "dependencies": {
9
+ "@angular-devkit/build-angular": "^20.3.1",
10
+ "@angular/cli": "^20.3.1",
11
+ "@angular/common": "^20.3.0",
12
+ "@angular/compiler-cli": "^20.3.0",
13
+ "@angular/core": "^20.3.0",
14
+ "@angular/forms": "^20.3.0",
15
+ "@angular/platform-browser-dynamic": "^20.3.0",
16
+ "@angular/router": "^20.3.0",
17
+ "@ionic/angular": "^8.7.3",
18
+ "@ionic/cordova-builders": "^12.3.0",
19
+ "@regulaforensics/idv": "3.2.1-nightly",
20
+ "@regulaforensics/document-reader": "8.4.2-nightly",
21
+ "@regulaforensics/face-sdk": "8.1.1-nightly",
22
+ "@regulaforensics/document-reader-core-fullauthrfid": "8.4.7-nightly",
23
+ "@regulaforensics/face-core-basic": "8.1.1-nightly",
24
+ "@regulaforensics/idv-module-document-reader": "file:../ftp_5",
25
+ "@regulaforensics/idv-module-face": "file:../ftp_6",
26
+ "cordova-android": "^14.0.1",
27
+ "cordova-ios": "^7.1.1",
28
+ "cordova-plugin-ionic-webview": "^5.0.1"
29
+ },
30
+ "cordova": {
31
+ "plugins": {
32
+ "@regulaforensics/document-reader": {},
33
+ "@regulaforensics/document-reader-core-fullauthrfid": {},
34
+ "@regulaforensics/face-sdk": {},
35
+ "@regulaforensics/face-core-basic": {},
36
+ "@regulaforensics/idv": {},
37
+ "@regulaforensics/idv-module-face": {},
38
+ "@regulaforensics/idv-module-document-reader": {},
39
+ "cordova-plugin-ionic-webview": {}
40
+ },
41
+ "platforms": [
42
+ "android",
43
+ "ios"
44
+ ]
45
+ }
46
+ }
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+
3
+ if [[ $npm_config_o || $npm_config_open ]]; then
4
+ ionic cordova build android
5
+ studio platforms/android || open -a 'Android Studio' platforms/android
6
+ else
7
+ ionic cordova run android
8
+ fi
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+
3
+ if [[ $npm_config_o || $npm_config_open ]]; then
4
+ ionic cordova prepare ios
5
+ open platforms/ios/IDV.xcworkspace
6
+ else
7
+ ionic cordova run ios
8
+ fi
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+ set -e
3
+
4
+ npm install
5
+ ionic cordova prepare || {
6
+ pod repo update
7
+ ionic cordova prepare
8
+ }
@@ -0,0 +1,148 @@
1
+ html,
2
+ body {
3
+ margin: 0;
4
+ width: 100%;
5
+ height: 99vh;
6
+ display: flex;
7
+ overflow: hidden;
8
+ flex-direction: column;
9
+ }
10
+
11
+ /* Prevent text selection */
12
+ * {
13
+ user-select: none !important;
14
+ -webkit-user-select: none !important;
15
+ -webkit-user-drag: none !important;
16
+ -webkit-touch-callout: none !important;
17
+ }
18
+
19
+ .column {
20
+ display: flex;
21
+ flex-direction: column;
22
+ align-items: center;
23
+ justify-content: center;
24
+ width: 100%;
25
+ }
26
+
27
+ .row {
28
+ display: flex;
29
+ flex-direction: row;
30
+ align-items: center;
31
+ justify-content: center;
32
+ }
33
+
34
+ .header {
35
+ text-align: center;
36
+ padding-top: 80px;
37
+ margin-top: -10px;
38
+ background-color: rgba(0, 0, 0, 0.03);
39
+ font-weight: 600;
40
+ font-size: 18px;
41
+ font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
42
+ }
43
+
44
+ .sub-header {
45
+ background-color: rgba(0, 0, 0, 0.03);
46
+ width: 100%;
47
+ padding-top: 13px;
48
+ text-align: center;
49
+ font-weight: 550;
50
+ font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
51
+ }
52
+
53
+ .divider {
54
+ height: 1px;
55
+ background-color: rgba(0, 0, 0, 0.075);
56
+ margin-top: 13px;
57
+ }
58
+
59
+ .scroll {
60
+ flex-grow: 1;
61
+ overflow-y: auto;
62
+ }
63
+
64
+ .no-scroll {
65
+ flex-grow: 1;
66
+ overflow-y: hidden;
67
+ }
68
+
69
+ .button {
70
+ width: 175px;
71
+ height: 40px;
72
+ margin: 5px;
73
+ margin-top: 10px;
74
+ background-color: #4285F4;
75
+ color: white;
76
+ border: none;
77
+ padding: 10px 20px;
78
+ justify-content: center;
79
+ font-size: 16px;
80
+ border-radius: 100px;
81
+ cursor: pointer;
82
+ transition: all 0.3s ease;
83
+ user-select: none;
84
+ -webkit-user-select: none;
85
+ -moz-user-select: none;
86
+ -ms-user-select: none;
87
+ }
88
+
89
+ .button:active {
90
+ position: relative;
91
+ top: 1px;
92
+ }
93
+
94
+ .text-button {
95
+ background: none;
96
+ border: none;
97
+ color: #2196f3;
98
+ font-size: 20px;
99
+ font-weight: bold;
100
+ padding: 5px;
101
+ }
102
+
103
+ .text-button:active {
104
+ position: relative;
105
+ top: 1px;
106
+ }
107
+
108
+ .radio {
109
+ align-items: baseline;
110
+ padding: 15px;
111
+ }
112
+
113
+ input[type="checkbox"] {
114
+ width: 20px;
115
+ height: 20px;
116
+ border: 2px solid black;
117
+ background-color: white;
118
+ display: inline-block;
119
+ position: relative;
120
+ cursor: pointer;
121
+ }
122
+
123
+ input[type="text"] {
124
+ width: 173px;
125
+ height: 40px;
126
+ font-size: 15px;
127
+ margin: 5px;
128
+ border-radius: 100px;
129
+ padding-left: 10px;
130
+ padding-right: 10px;
131
+ margin-top: 10px;
132
+ }
133
+
134
+ .progress-bar {
135
+ width: 75%;
136
+ padding: 3px;
137
+ margin-top: 40px;
138
+ background-color: #eee;
139
+ border-radius: 8px;
140
+ box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
141
+ }
142
+
143
+ #progress {
144
+ width: 0%;
145
+ height: 20px;
146
+ background-color: #4285F4;
147
+ border-radius: 5px;
148
+ }
@@ -0,0 +1,17 @@
1
+ <div class="column" style="height: 100%">
2
+ <div class="column header">
3
+ <span id="status">Initializing...</span>
4
+ <div class="column divider"></div>
5
+ </div>
6
+ <div id="sub-header" class="column sub-header" style="display: none;">
7
+ <span id="description"></span>
8
+ <div class="column divider"></div>
9
+ </div>
10
+ <div id="main" class="column no-scroll">
11
+ <div class="column no-scroll" style="padding-top: 15px; background-color: rgba(0, 0, 0, 0.03);">
12
+ <div id="radio-group" class="scroll"></div>
13
+ </div>
14
+ <button id="start-workflow" class="button" style="width: 360px">Start Workflow</button>
15
+ <div style="padding-top: 30px"></div>
16
+ </div>
17
+ </div>
@@ -0,0 +1,124 @@
1
+ import { IDV, Workflow } from '@regulaforensics/idv'
2
+
3
+ enum Configuration { credentials, token, apiKey }
4
+
5
+ const loginType: Configuration = Configuration.credentials
6
+ const baseUrl = "https://idv.regula.app"
7
+ const username = "username_placeholder"
8
+ const password = "password_placeholder"
9
+ const tokenUrl = "token_placeholder"
10
+ const apiKey = "api_key_placeholder"
11
+
12
+ var idv = IDV.instance
13
+ var selectedWorkflow = ""
14
+ var workflowIds: string[] = []
15
+
16
+ async function init() {
17
+ var [_, iError] = await idv.initialize()
18
+ if (handleException(iError, "initialize")) return
19
+
20
+ var success = ({
21
+ [Configuration.credentials]: async () => await configureWithCredentials(),
22
+ [Configuration.token]: async () => await configureWithToken(),
23
+ [Configuration.apiKey]: async () => await configureApiKey(),
24
+ })[loginType]!
25
+ if (!await success()) return
26
+
27
+ var [wfs, error] = await idv.getWorkflows()
28
+ if (handleException(error, "getWorkflows")) return
29
+ if (loginType == Configuration.token) {
30
+ wfs = wfs!.filter((wf: any) => workflowIds.includes(wf.id))
31
+ }
32
+
33
+ setWorkflows(wfs!)
34
+ setStatus("Ready")
35
+ }
36
+
37
+ async function configureWithCredentials(): Promise<boolean> {
38
+ var [success, error] = await idv.configureWithCredentials({
39
+ baseUrl: baseUrl,
40
+ userName: username,
41
+ password: password
42
+ })
43
+ handleException(error, "configureWithCredentials")
44
+ return success
45
+ }
46
+
47
+ async function configureWithToken(): Promise<boolean> {
48
+ var [wfIds, error] = await idv.configureWithToken({ url: tokenUrl })
49
+ if (handleException(error, "configureWithToken")) return false
50
+ workflowIds = wfIds!
51
+ return true
52
+ }
53
+
54
+ async function configureApiKey(): Promise<boolean> {
55
+ var [success, error] = await idv.configureWithApiKey({ baseUrl, apiKey })
56
+ handleException(error, "configureWithApiKey")
57
+ return success
58
+ }
59
+
60
+ async function startWorkflow(): Promise<void> {
61
+ if (selectedWorkflow.length == 0) return
62
+ setStatus("Preparing Workflow...")
63
+
64
+ var [_, prepareError] = await idv.prepareWorkflow({ workflowId: selectedWorkflow })
65
+ if (handleException(prepareError, "prepareWorkflow")) return
66
+
67
+ var [result, error] = await idv.startWorkflow()
68
+ if (handleException(error, "startWorkflow")) return
69
+
70
+ setStatus("Success")
71
+ setDescription(`SessionID: ${result?.sessionId}`)
72
+ }
73
+
74
+ function handleException(error?: string | null, tag?: string): boolean {
75
+ if (error == null) return false
76
+ setStatus(`Error - IDV.${tag}()`)
77
+ setDescription(error)
78
+ console.log(error)
79
+ return true
80
+ }
81
+
82
+ // --------------------------------------------------------------------------------------------------------------------
83
+
84
+ export function main() {
85
+ document.getElementById("start-workflow")!.onclick = () => startWorkflow()
86
+
87
+ init()
88
+ }
89
+
90
+ var setStatus = (data: string) => document.getElementById("status")!.innerHTML = data
91
+ var setDescription = (data: string) => {
92
+ document.getElementById("description")!.innerHTML = data
93
+ document.getElementById("sub-header")!.style.display = data.length > 0 ? "block" : "none"
94
+ }
95
+
96
+ var workflows: Workflow[] = []
97
+ function setWorkflows(data: Workflow[]) {
98
+ var radioGroup = document.getElementById("radio-group")!
99
+ workflows = data
100
+ if (workflows.length != 0) {
101
+ selectedWorkflow = workflows[0].id
102
+ }
103
+
104
+ data.forEach(item => {
105
+ var checked = selectedWorkflow == item.id ? "checked" : ""
106
+ var radioElement = `
107
+ <div class="row radio">
108
+ <input type="radio" name="radio" id="${item.id}" value="${item.id}" ${checked}>
109
+ <span id="${item.id}-caption" style="width: 200px; padding-left: 5px;">${item.name}</span>
110
+ </div>`
111
+ radioGroup.insertAdjacentHTML("beforeend", radioElement)
112
+ })
113
+
114
+ data.forEach(item => {
115
+ var element = document.getElementById(item.id) as HTMLInputElement
116
+ var elementCaption = document.getElementById(item.id + "-caption")!
117
+ var onclick = () => {
118
+ selectedWorkflow = item.id
119
+ element.checked = true
120
+ }
121
+ element.onclick = onclick
122
+ elementCaption.onclick = onclick
123
+ })
124
+ }
@@ -0,0 +1,14 @@
1
+ {
2
+ "include": [
3
+ "*.tsx"
4
+ ],
5
+ "compilerOptions": {
6
+ "types": [],
7
+ "module": "esnext",
8
+ "moduleResolution": "node",
9
+ "experimentalDecorators": true,
10
+ "target": "es2022",
11
+ "jsx": "react-jsx",
12
+ "skipLibCheck": true, // Temp fix for https://github.com/ionic-team/ionic-framework/issues/30650
13
+ }
14
+ }
@@ -0,0 +1,15 @@
1
+ # Regula IDV React Native demo application
2
+
3
+ ## How to build demo application
4
+ 1. Download or the clone current repository using the command `git clone https://github.com/regulaforensics/npm-idv.git`.
5
+ 2. Put `regula.license` file at `assets/` (you can get a trial license [here](https://client.regulaforensics.com)).
6
+ 3. Put `db.dat` file at `assets/` (you can get a trial database [here](https://client.regulaforensics.com/customer/databases))
7
+ 4. Execute `npm run setup` within this directory.
8
+ 5. In `src/main.tsx` choose prefered login configuration(`loginType` variable) and provide your login data according to it: username and password for `credentials`, tokenUrl for `token`, apiKey for `apiKey`.
9
+ 6. Run the app:
10
+ * IOS: `npm run ios`.
11
+ * Android: `npm run android`.
12
+ 7. After initialization choose **General KYC - AP** from workflows list and click **Start Workflow** button.
13
+ 8. Complete workflow and get your session id.
14
+
15
+ **Note**: `npm run ios`/`npm run android` is just one way of running the app. You can also pass `-o` or `--open` argument to the command, and this will open Xcode/Android Studio, then run the app directly from the IDE. Overall, this is a more consistent way, so if you're having troubles running the app from terminal, try running it from the IDE. Just don't forget to make sure that Metro Bundler is running(`npm start`).
@@ -0,0 +1,46 @@
1
+ import { ExpoConfig, ConfigContext } from 'expo/config'
2
+
3
+ export default ({ config }: ConfigContext): ExpoConfig => ({
4
+ ...config,
5
+ slug: 'idv',
6
+ name: 'IDV',
7
+ orientation: 'portrait',
8
+ icon: 'images/icon.png',
9
+ ios: {
10
+ bundleIdentifier: 'com.regula.example.idv.react',
11
+ infoPlist: {
12
+ NSCameraUsageDescription: 'To use camera',
13
+ NSPhotoLibraryUsageDescription: 'To use gallery',
14
+ NFCReaderUsageDescription: 'To use NFC',
15
+ 'com.apple.developer.nfc.readersession.iso7816.select-identifiers': [
16
+ 'A0000002471001',
17
+ 'E80704007F00070302',
18
+ 'A000000167455349474E',
19
+ 'A0000002480100',
20
+ 'A0000002480200',
21
+ 'A0000002480300',
22
+ 'A00000045645444C2D3031'
23
+ ]
24
+ },
25
+ entitlements: { 'com.apple.developer.nfc.readersession.formats': ['TAG'] },
26
+ appleTeamId: ''
27
+ },
28
+ android: {
29
+ package: 'com.regula.example.idv.react',
30
+ permissions: ['android.permission.NFC'],
31
+ edgeToEdgeEnabled: true
32
+ },
33
+ plugins: [
34
+ ['expo-custom-assets', { assetsPaths: ['./assets'] }],
35
+ ['expo-build-properties', {
36
+ android: {
37
+ extraMavenRepos: [
38
+ { url: 'https://maven.regulaforensics.com/RegulaDocumentReader' },
39
+ { url: 'https://maven.regulaforensics.com/RegulaDocumentReader/Beta' },
40
+ { url: 'https://maven.regulaforensics.com/RegulaDocumentReader/Nightly' },
41
+ { url: 'https://maven.regulaforensics.com/RegulaDocumentReader/Stage' }
42
+ ]
43
+ }
44
+ }]
45
+ ]
46
+ })
File without changes
@@ -0,0 +1,12 @@
1
+ <meta name="viewport" content="initial-scale=1, user-scalable=no, viewport-fit=cover">
2
+ <link rel="stylesheet" href="src/main.css">
3
+
4
+ <div id="content" style="height: 100%"></div>
5
+
6
+ <script>
7
+ (async () => {
8
+ document.getElementById("content").innerHTML = await fetch("src/main.html").then(r => r.text())
9
+ await new Promise(resolve => requestAnimationFrame(() => requestAnimationFrame(resolve)))
10
+ window.ReactNativeWebView.postMessage(JSON.stringify({ id: "ready" }))
11
+ })()
12
+ </script>
@@ -0,0 +1,63 @@
1
+ import { registerRootComponent } from 'expo'
2
+ import WebView from 'react-native-webview'
3
+ import React from 'react'
4
+ import { main } from './src/main'
5
+
6
+ var webViewRef: any
7
+ const onclicks: any = {}
8
+ const onMessage = (json: any) => {
9
+ const event = JSON.parse(json.nativeEvent.data)
10
+ if (event.id === "ready") main()
11
+ if (event.id === "onclick") {
12
+ onclicks[event.value]()
13
+ }
14
+ }
15
+
16
+ const document = {
17
+ getElementById(id: string): any {
18
+ return new Proxy({}, {
19
+ set(_, prop: string, value) {
20
+ if (prop == "onclick") {
21
+ onclicks[id] = value
22
+ webViewRef.injectJavaScript(`
23
+ document.getElementById("${id}").onclick = () => {
24
+ window.ReactNativeWebView.postMessage(JSON.stringify({ id: "onclick", value: "${id}" }));
25
+ }; true
26
+ `)
27
+ } else
28
+ webViewRef.injectJavaScript(`document.getElementById("${id}").${prop} = ${parseValue(value)}; true`)
29
+ return true
30
+ },
31
+ get(_, prop: string) {
32
+ if (prop === "style") return new Proxy({}, {
33
+ set(_, styleProp: string, value) {
34
+ webViewRef.injectJavaScript(`document.getElementById("${id}").style.${styleProp} = ${parseValue(value)}; true`)
35
+ return true
36
+ }
37
+ })
38
+ if (prop === "insertAdjacentHTML") return (position: string, html: string) => {
39
+ webViewRef.injectJavaScript(`document.getElementById("${id}").insertAdjacentHTML('${position}', \`${html}\`); true`)
40
+ return true
41
+ }
42
+ return undefined
43
+ }
44
+ }
45
+ )
46
+ }
47
+ }
48
+
49
+ function parseValue(value: any) {
50
+ if (value !== true && value !== false) return `"${value}"`
51
+ return value
52
+ }
53
+
54
+ (globalThis as any).document = document;
55
+ registerRootComponent(() =>
56
+ <WebView
57
+ ref={ref => { webViewRef = ref }}
58
+ onMessage={onMessage}
59
+ source={require("./index.html")}
60
+ scrollEnabled={false}
61
+ overScrollMode={'content'}
62
+ />
63
+ )
@@ -0,0 +1,7 @@
1
+ const config = require('expo/metro-config').getDefaultConfig(__dirname)
2
+ config.watchFolders = [
3
+ __dirname + '/node_modules'
4
+ ]
5
+ config.resolver.nodeModulesPaths = config.watchFolders
6
+ config.resolver.assetExts.push('css')
7
+ module.exports = config