@bifold/core 2.4.6 → 2.5.0

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 (401) hide show
  1. package/lib/commonjs/contexts/reducers/store.js +3 -2
  2. package/lib/commonjs/contexts/reducers/store.js.map +1 -1
  3. package/lib/commonjs/index.js +119 -104
  4. package/lib/commonjs/index.js.map +1 -1
  5. package/lib/commonjs/screens/AttemptLockout.js +27 -35
  6. package/lib/commonjs/screens/AttemptLockout.js.map +1 -1
  7. package/lib/commonjs/screens/MobileVerifierLoading.js +4 -3
  8. package/lib/commonjs/screens/MobileVerifierLoading.js.map +1 -1
  9. package/lib/commonjs/screens/PINCreate.js +3 -10
  10. package/lib/commonjs/screens/PINCreate.js.map +1 -1
  11. package/lib/commonjs/screens/WhatAreContacts.js +3 -2
  12. package/lib/commonjs/screens/WhatAreContacts.js.map +1 -1
  13. package/lib/module/contexts/reducers/store.js +3 -2
  14. package/lib/module/contexts/reducers/store.js.map +1 -1
  15. package/lib/module/index.js +42 -45
  16. package/lib/module/index.js.map +1 -1
  17. package/lib/module/screens/AttemptLockout.js +28 -36
  18. package/lib/module/screens/AttemptLockout.js.map +1 -1
  19. package/lib/module/screens/MobileVerifierLoading.js +4 -3
  20. package/lib/module/screens/MobileVerifierLoading.js.map +1 -1
  21. package/lib/module/screens/PINCreate.js +3 -10
  22. package/lib/module/screens/PINCreate.js.map +1 -1
  23. package/lib/module/screens/WhatAreContacts.js +3 -2
  24. package/lib/module/screens/WhatAreContacts.js.map +1 -1
  25. package/lib/typescript/src/contexts/reducers/store.d.ts.map +1 -1
  26. package/lib/typescript/src/index.d.ts +57 -61
  27. package/lib/typescript/src/index.d.ts.map +1 -1
  28. package/lib/typescript/src/screens/AttemptLockout.d.ts.map +1 -1
  29. package/lib/typescript/src/screens/MobileVerifierLoading.d.ts.map +1 -1
  30. package/lib/typescript/src/screens/PINCreate.d.ts.map +1 -1
  31. package/lib/typescript/src/screens/WhatAreContacts.d.ts.map +1 -1
  32. package/package.json +3 -4
  33. package/src/App.tsx +0 -79
  34. package/src/animated-components.ts +0 -30
  35. package/src/assets/fonts/MaterialIcons.ttf +0 -0
  36. package/src/assets/icons/code.svg +0 -4
  37. package/src/assets/icons/large-arrow.svg +0 -5
  38. package/src/assets/icons/pencil.svg +0 -15
  39. package/src/assets/icons/trash.svg +0 -31
  40. package/src/assets/img/Artwork_1024x1024.png +0 -0
  41. package/src/assets/img/HistoryCardAcceptedIcon.svg +0 -4
  42. package/src/assets/img/HistoryCardExpiredIcon.svg +0 -4
  43. package/src/assets/img/HistoryCardRevokedIcon.svg +0 -4
  44. package/src/assets/img/HistoryInformationSentIcon.svg +0 -4
  45. package/src/assets/img/HistoryPinUpdatedIcon.svg +0 -4
  46. package/src/assets/img/IconChevronRight.svg +0 -5
  47. package/src/assets/img/activity-indicator-circle.svg +0 -90
  48. package/src/assets/img/app-lockout.svg +0 -1
  49. package/src/assets/img/biometrics.svg +0 -74
  50. package/src/assets/img/chat-loading.svg +0 -1
  51. package/src/assets/img/check-in-circle.svg +0 -18
  52. package/src/assets/img/connection-pending.svg +0 -112
  53. package/src/assets/img/contact-book.svg +0 -21
  54. package/src/assets/img/credential-card.svg +0 -18
  55. package/src/assets/img/credential-declined.svg +0 -28
  56. package/src/assets/img/credential-in-hand.svg +0 -48
  57. package/src/assets/img/credential-list.svg +0 -60
  58. package/src/assets/img/credential-pending.svg +0 -96
  59. package/src/assets/img/credential-success.svg +0 -48
  60. package/src/assets/img/delete-notification.svg +0 -1
  61. package/src/assets/img/empty-wallet.svg +0 -23
  62. package/src/assets/img/error-filled.svg +0 -12
  63. package/src/assets/img/exclamation-mark.svg +0 -17
  64. package/src/assets/img/home-center-img.svg +0 -71
  65. package/src/assets/img/icon-credential-offer-dark.svg +0 -7
  66. package/src/assets/img/icon-credential-offer-light.svg +0 -7
  67. package/src/assets/img/icon-info-recieved-dark.svg +0 -8
  68. package/src/assets/img/icon-info-recieved-light.svg +0 -8
  69. package/src/assets/img/icon-info-sent-dark.svg +0 -8
  70. package/src/assets/img/icon-info-sent-light.svg +0 -8
  71. package/src/assets/img/icon-proof-request-dark.svg +0 -11
  72. package/src/assets/img/icon-proof-request-light.svg +0 -11
  73. package/src/assets/img/information-received.svg +0 -1
  74. package/src/assets/img/logo-large.png +0 -0
  75. package/src/assets/img/logo-large@2x.png +0 -0
  76. package/src/assets/img/logo-large@3x.png +0 -0
  77. package/src/assets/img/logo.svg +0 -15
  78. package/src/assets/img/message-text-icon-outline.svg +0 -1
  79. package/src/assets/img/message-text-icon.svg +0 -1
  80. package/src/assets/img/no_information_shared.svg +0 -36
  81. package/src/assets/img/preface.svg +0 -15
  82. package/src/assets/img/proof-declined.svg +0 -66
  83. package/src/assets/img/proof-pending.svg +0 -61
  84. package/src/assets/img/proof-success.svg +0 -72
  85. package/src/assets/img/push-notifications.svg +0 -1
  86. package/src/assets/img/qrcode-scan-icon.svg +0 -1
  87. package/src/assets/img/scan-share.svg +0 -102
  88. package/src/assets/img/secure-check.svg +0 -4
  89. package/src/assets/img/secure-image.svg +0 -64
  90. package/src/assets/img/update-available.svg +0 -26
  91. package/src/assets/img/verifier-request-declined.svg +0 -34
  92. package/src/assets/img/wallet-back.svg +0 -20
  93. package/src/assets/img/wallet-front.svg +0 -32
  94. package/src/assets/img/wallet-icon-outline.svg +0 -1
  95. package/src/assets/img/wallet-icon.svg +0 -1
  96. package/src/assets/img/wallet.svg +0 -43
  97. package/src/assets/oca-bundles.json +0 -174
  98. package/src/components/animated/ButtonLoading.tsx +0 -32
  99. package/src/components/animated/ConnectionLoading.tsx +0 -53
  100. package/src/components/animated/CredentialAdded.tsx +0 -72
  101. package/src/components/animated/CredentialPending.tsx +0 -63
  102. package/src/components/animated/LoadingIndicator.tsx +0 -49
  103. package/src/components/animated/PresentationLoading.tsx +0 -52
  104. package/src/components/animated/RecordLoading.tsx +0 -75
  105. package/src/components/animated/SendingProof.tsx +0 -53
  106. package/src/components/animated/SentProof.tsx +0 -72
  107. package/src/components/buttons/Button-api.tsx +0 -46
  108. package/src/components/buttons/Button.tsx +0 -125
  109. package/src/components/buttons/HeaderHome.tsx +0 -25
  110. package/src/components/buttons/IconButton.tsx +0 -93
  111. package/src/components/buttons/InfoIcon.tsx +0 -35
  112. package/src/components/buttons/SettingsMenu.tsx +0 -26
  113. package/src/components/buttons/ToggleButton.tsx +0 -93
  114. package/src/components/buttons/index.ts +0 -4
  115. package/src/components/chat/ActionSlider.tsx +0 -104
  116. package/src/components/chat/ChatActions.tsx +0 -33
  117. package/src/components/chat/ChatBubble.tsx +0 -20
  118. package/src/components/chat/ChatEvent.tsx +0 -31
  119. package/src/components/chat/ChatMessage.tsx +0 -142
  120. package/src/components/chat/MessageInput.tsx +0 -46
  121. package/src/components/chat/index.ts +0 -4
  122. package/src/components/forms/WalletNameForm.tsx +0 -148
  123. package/src/components/index.ts +0 -4
  124. package/src/components/inputs/BiometryControl.tsx +0 -190
  125. package/src/components/inputs/BulletPoint.tsx +0 -32
  126. package/src/components/inputs/CheckBoxRow.tsx +0 -67
  127. package/src/components/inputs/InlineErrorText.tsx +0 -60
  128. package/src/components/inputs/LimitedTextInput.tsx +0 -71
  129. package/src/components/inputs/PINInput.tsx +0 -175
  130. package/src/components/inputs/SingleSelectBlock.tsx +0 -53
  131. package/src/components/listItems/ContactCredentialListItem.tsx +0 -79
  132. package/src/components/listItems/ContactListItem.tsx +0 -121
  133. package/src/components/listItems/NotificationListItem.tsx +0 -514
  134. package/src/components/misc/AvatarView.tsx +0 -33
  135. package/src/components/misc/CardWatermark.tsx +0 -52
  136. package/src/components/misc/ConnectionAlert.tsx +0 -123
  137. package/src/components/misc/ConnectionImage.tsx +0 -45
  138. package/src/components/misc/ContentGradient.tsx +0 -40
  139. package/src/components/misc/CredentialCard.tsx +0 -161
  140. package/src/components/misc/CredentialCard10.tsx +0 -329
  141. package/src/components/misc/CredentialCard11.tsx +0 -701
  142. package/src/components/misc/CredentialCard11ActionFooter.tsx +0 -55
  143. package/src/components/misc/CredentialCard11Issuer.tsx +0 -74
  144. package/src/components/misc/CredentialCard11Logo.tsx +0 -61
  145. package/src/components/misc/EmptyList.tsx +0 -27
  146. package/src/components/misc/EmptyListContacts.tsx +0 -55
  147. package/src/components/misc/ErrorBoundary.tsx +0 -200
  148. package/src/components/misc/FauxHeader.tsx +0 -75
  149. package/src/components/misc/InfoBox.tsx +0 -283
  150. package/src/components/misc/NoNewUpdates.tsx +0 -38
  151. package/src/components/misc/PINHeader.tsx +0 -25
  152. package/src/components/misc/PINValidationHelper.tsx +0 -48
  153. package/src/components/misc/Pagination.tsx +0 -114
  154. package/src/components/misc/QRRenderer.tsx +0 -53
  155. package/src/components/misc/QRScanner.tsx +0 -395
  156. package/src/components/misc/QRScannerTorch.tsx +0 -74
  157. package/src/components/misc/ScanCamera.tsx +0 -86
  158. package/src/components/misc/ScanTab.tsx +0 -45
  159. package/src/components/misc/SharedProofData.tsx +0 -98
  160. package/src/components/misc/UnorderedList.tsx +0 -28
  161. package/src/components/misc/VerifierCredentialCard.tsx +0 -378
  162. package/src/components/misc/index.ts +0 -2
  163. package/src/components/modals/AlertModal.tsx +0 -42
  164. package/src/components/modals/AppGuideModal.tsx +0 -142
  165. package/src/components/modals/CameraDisclosureModal.tsx +0 -126
  166. package/src/components/modals/CommonRemoveModal.tsx +0 -337
  167. package/src/components/modals/DeveloperModal.tsx +0 -32
  168. package/src/components/modals/DismissiblePopupModal.tsx +0 -169
  169. package/src/components/modals/ErrorModal.tsx +0 -107
  170. package/src/components/modals/ImageModal.tsx +0 -80
  171. package/src/components/modals/NetInfoModal.tsx +0 -35
  172. package/src/components/modals/PopupModal.tsx +0 -56
  173. package/src/components/modals/ProofCancelModal.tsx +0 -79
  174. package/src/components/modals/SafeAreaModal.tsx +0 -17
  175. package/src/components/record/Record.tsx +0 -100
  176. package/src/components/record/RecordBinaryField.tsx +0 -55
  177. package/src/components/record/RecordDateIntField.tsx +0 -63
  178. package/src/components/record/RecordField.tsx +0 -154
  179. package/src/components/record/RecordFooter.tsx +0 -17
  180. package/src/components/record/RecordHeader.tsx +0 -17
  181. package/src/components/record/RecordRemove.tsx +0 -66
  182. package/src/components/texts/HeaderTitle.tsx +0 -25
  183. package/src/components/texts/HighlightTextBox.tsx +0 -41
  184. package/src/components/texts/InfoTextBox.tsx +0 -129
  185. package/src/components/texts/Link.tsx +0 -41
  186. package/src/components/texts/Text.tsx +0 -21
  187. package/src/components/texts/ThemedText.tsx +0 -24
  188. package/src/components/toast/BaseToast.tsx +0 -128
  189. package/src/components/toast/ToastConfig.tsx +0 -21
  190. package/src/components/tour/AttachTourStep.tsx +0 -73
  191. package/src/components/tour/CredentialOfferTourSteps.tsx +0 -41
  192. package/src/components/tour/CredentialsTourSteps.tsx +0 -41
  193. package/src/components/tour/HomeTourSteps.tsx +0 -104
  194. package/src/components/tour/ProofRequestTourSteps.tsx +0 -41
  195. package/src/components/tour/SpotCutout.tsx +0 -65
  196. package/src/components/tour/TourBox.tsx +0 -255
  197. package/src/components/tour/TourOverlay.tsx +0 -134
  198. package/src/components/views/Banner.tsx +0 -181
  199. package/src/components/views/CredentialCardLogo.tsx +0 -77
  200. package/src/components/views/CredentialDetailPrimaryHeader.tsx +0 -107
  201. package/src/components/views/CredentialDetailSecondaryHeader.tsx +0 -60
  202. package/src/components/views/HeaderWithBanner.tsx +0 -17
  203. package/src/components/views/HomeFooterView.tsx +0 -110
  204. package/src/components/views/HomeHeaderView.tsx +0 -12
  205. package/src/components/views/KeyboardView.tsx +0 -41
  206. package/src/components/views/LoadingPlaceholder.tsx +0 -168
  207. package/src/components/views/LoadingView.tsx +0 -29
  208. package/src/components/views/ProgressBar.tsx +0 -53
  209. package/src/components/views/PushNotificationsContent.tsx +0 -51
  210. package/src/components/views/PushNotificationsDisabledContent.tsx +0 -47
  211. package/src/configs/ledgers/indy/index.ts +0 -8
  212. package/src/configs/ledgers/indy/ledgers.json +0 -51
  213. package/src/constants.ts +0 -107
  214. package/src/container-api.ts +0 -247
  215. package/src/container-impl.ts +0 -243
  216. package/src/contexts/activity.tsx +0 -145
  217. package/src/contexts/animated-components.ts +0 -9
  218. package/src/contexts/auth.tsx +0 -240
  219. package/src/contexts/index.ts +0 -3
  220. package/src/contexts/navigation.tsx +0 -19
  221. package/src/contexts/network.tsx +0 -125
  222. package/src/contexts/reducers/index.ts +0 -3
  223. package/src/contexts/reducers/store.ts +0 -754
  224. package/src/contexts/store.tsx +0 -103
  225. package/src/contexts/theme.tsx +0 -51
  226. package/src/contexts/tour/tour-context.tsx +0 -160
  227. package/src/contexts/tour/tour-provider.tsx +0 -160
  228. package/src/hooks/bundle-resolver.ts +0 -95
  229. package/src/hooks/chat-messages.tsx +0 -263
  230. package/src/hooks/connections.ts +0 -37
  231. package/src/hooks/credential-card-styles.ts +0 -144
  232. package/src/hooks/credentials.ts +0 -11
  233. package/src/hooks/deep-links.ts +0 -49
  234. package/src/hooks/developer-mode.ts +0 -25
  235. package/src/hooks/lockout.ts +0 -77
  236. package/src/hooks/notifications.ts +0 -108
  237. package/src/hooks/oob.ts +0 -17
  238. package/src/hooks/proof-request-templates.ts +0 -40
  239. package/src/hooks/proofs.ts +0 -32
  240. package/src/hooks/screen-capture.ts +0 -52
  241. package/src/hooks/useBifoldAgentSetup.ts +0 -169
  242. package/src/hooks/useOnboardingState.ts +0 -53
  243. package/src/hooks/usePINValidation.ts +0 -98
  244. package/src/index.ts +0 -239
  245. package/src/layout/ScreenLayout.tsx +0 -53
  246. package/src/localization/en/en.json +0 -951
  247. package/src/localization/en/index.ts +0 -3
  248. package/src/localization/fr/fr.json +0 -933
  249. package/src/localization/fr/index.ts +0 -3
  250. package/src/localization/index.ts +0 -66
  251. package/src/localization/pt-br/index.ts +0 -3
  252. package/src/localization/pt-br/pt-br.json +0 -911
  253. package/src/modules/history/context/historyManager.tsx +0 -247
  254. package/src/modules/history/index.ts +0 -2
  255. package/src/modules/history/navigation/HistoryStack.tsx +0 -29
  256. package/src/modules/history/services/queue.service.tsx +0 -31
  257. package/src/modules/history/types/index.ts +0 -92
  258. package/src/modules/history/ui/HistoryPage.tsx +0 -133
  259. package/src/modules/history/ui/HistorySettings.tsx +0 -183
  260. package/src/modules/history/ui/assets/img/HistoryCardAcceptedIcon.svg +0 -4
  261. package/src/modules/history/ui/assets/img/HistoryCardExpiredIcon.svg +0 -4
  262. package/src/modules/history/ui/assets/img/HistoryCardRevokedIcon.svg +0 -4
  263. package/src/modules/history/ui/assets/img/HistoryInformationSentIcon.svg +0 -4
  264. package/src/modules/history/ui/assets/img/HistoryPinUpdatedIcon.svg +0 -4
  265. package/src/modules/history/ui/assets/img/IconChevronRight.svg +0 -3
  266. package/src/modules/history/ui/components/BulletPoint.tsx +0 -49
  267. package/src/modules/history/ui/components/HistoryListItem.tsx +0 -251
  268. package/src/modules/history/ui/components/HistoryMenu.tsx +0 -25
  269. package/src/modules/history/ui/components/SingleSelectBlock.tsx +0 -72
  270. package/src/modules/openid/components/CredentialRowCard.tsx +0 -64
  271. package/src/modules/openid/components/OpenIDCredentialCard.tsx +0 -276
  272. package/src/modules/openid/context/OpenIDCredentialRecordProvider.tsx +0 -296
  273. package/src/modules/openid/display.tsx +0 -467
  274. package/src/modules/openid/displayProof.tsx +0 -86
  275. package/src/modules/openid/hooks/openid.tsx +0 -111
  276. package/src/modules/openid/metadata.tsx +0 -59
  277. package/src/modules/openid/offerResolve.tsx +0 -281
  278. package/src/modules/openid/resolverProof.tsx +0 -286
  279. package/src/modules/openid/screens/OpenIDCredentialDetails.tsx +0 -214
  280. package/src/modules/openid/screens/OpenIDCredentialOffer.tsx +0 -192
  281. package/src/modules/openid/screens/OpenIDProofChangeCredential.tsx +0 -133
  282. package/src/modules/openid/screens/OpenIDProofPresentation.tsx +0 -423
  283. package/src/modules/openid/types.tsx +0 -111
  284. package/src/modules/openid/utils/utils.tsx +0 -119
  285. package/src/navigators/ConnectStack.tsx +0 -68
  286. package/src/navigators/ContactStack.tsx +0 -91
  287. package/src/navigators/CredentialStack.tsx +0 -48
  288. package/src/navigators/DeliveryStack.tsx +0 -76
  289. package/src/navigators/HomeStack.tsx +0 -37
  290. package/src/navigators/MainStack.tsx +0 -146
  291. package/src/navigators/NotificationStack.tsx +0 -56
  292. package/src/navigators/OnboardingScreens.ts +0 -142
  293. package/src/navigators/OnboardingStack.tsx +0 -205
  294. package/src/navigators/ProofRequestStack.tsx +0 -113
  295. package/src/navigators/RootStack.tsx +0 -71
  296. package/src/navigators/SettingStack.tsx +0 -174
  297. package/src/navigators/TabStack.tsx +0 -304
  298. package/src/navigators/defaultLayoutOptions.tsx +0 -17
  299. package/src/navigators/defaultStackOptions.tsx +0 -102
  300. package/src/navigators/index.ts +0 -27
  301. package/src/onboarding.ts +0 -90
  302. package/src/screens/AttemptLockout.tsx +0 -153
  303. package/src/screens/AutoLock.tsx +0 -140
  304. package/src/screens/Biometry.tsx +0 -54
  305. package/src/screens/Chat.tsx +0 -141
  306. package/src/screens/ConfigureMediator.tsx +0 -160
  307. package/src/screens/Connection.tsx +0 -394
  308. package/src/screens/ContactDetails.tsx +0 -350
  309. package/src/screens/CredentialDetails.tsx +0 -473
  310. package/src/screens/CredentialOffer.tsx +0 -334
  311. package/src/screens/CredentialOfferAccept.tsx +0 -189
  312. package/src/screens/DataRetention.tsx +0 -91
  313. package/src/screens/Developer.tsx +0 -289
  314. package/src/screens/Home.tsx +0 -173
  315. package/src/screens/JSONDetails.tsx +0 -104
  316. package/src/screens/Language.tsx +0 -97
  317. package/src/screens/ListContacts.tsx +0 -112
  318. package/src/screens/ListCredentials.tsx +0 -135
  319. package/src/screens/ListProofRequests.tsx +0 -148
  320. package/src/screens/MobileVerifierLoading.tsx +0 -106
  321. package/src/screens/NameWallet.tsx +0 -9
  322. package/src/screens/Onboarding.tsx +0 -162
  323. package/src/screens/OnboardingPages.tsx +0 -160
  324. package/src/screens/PINChange.tsx +0 -249
  325. package/src/screens/PINCreate.tsx +0 -185
  326. package/src/screens/PINEnter.tsx +0 -432
  327. package/src/screens/PINExplainer.tsx +0 -85
  328. package/src/screens/PINVerify.tsx +0 -195
  329. package/src/screens/PasteUrl.tsx +0 -140
  330. package/src/screens/Preface.tsx +0 -78
  331. package/src/screens/ProofChangeCredential.tsx +0 -179
  332. package/src/screens/ProofDetails.tsx +0 -348
  333. package/src/screens/ProofRequest.tsx +0 -999
  334. package/src/screens/ProofRequestAccept.tsx +0 -133
  335. package/src/screens/ProofRequestDetails.tsx +0 -270
  336. package/src/screens/ProofRequestUsageHistory.tsx +0 -152
  337. package/src/screens/ProofRequesting.tsx +0 -245
  338. package/src/screens/PushNotifications.tsx +0 -59
  339. package/src/screens/RenameContact.tsx +0 -155
  340. package/src/screens/RenameWallet.tsx +0 -26
  341. package/src/screens/Scan.tsx +0 -145
  342. package/src/screens/ScanHelp.tsx +0 -48
  343. package/src/screens/Settings.tsx +0 -415
  344. package/src/screens/Splash.tsx +0 -80
  345. package/src/screens/Terms.tsx +0 -127
  346. package/src/screens/ToggleBiometry.tsx +0 -153
  347. package/src/screens/TogglePushNotifications.tsx +0 -118
  348. package/src/screens/Tours.tsx +0 -93
  349. package/src/screens/UpdateAvailable.tsx +0 -119
  350. package/src/screens/WhatAreContacts.tsx +0 -71
  351. package/src/services/bifoldLogger.ts +0 -3
  352. package/src/services/keychain.ts +0 -184
  353. package/src/services/logger.ts +0 -89
  354. package/src/services/storage.ts +0 -136
  355. package/src/theme-builder.ts +0 -157
  356. package/src/theme.interface.ts +0 -580
  357. package/src/theme.ts +0 -1346
  358. package/src/types/attempt-lockout-config.ts +0 -8
  359. package/src/types/attestation.ts +0 -17
  360. package/src/types/chat.ts +0 -4
  361. package/src/types/config.ts +0 -64
  362. package/src/types/contact-details.ts +0 -5
  363. package/src/types/credential-list-footer.ts +0 -3
  364. package/src/types/credential-status.ts +0 -3
  365. package/src/types/credentials.ts +0 -7
  366. package/src/types/decline.ts +0 -5
  367. package/src/types/error.ts +0 -40
  368. package/src/types/fn.ts +0 -2
  369. package/src/types/genesis.ts +0 -35
  370. package/src/types/index.ts +0 -2
  371. package/src/types/metadata.ts +0 -16
  372. package/src/types/navigators.ts +0 -239
  373. package/src/types/notification.ts +0 -24
  374. package/src/types/permissions.ts +0 -2
  375. package/src/types/proof-items.ts +0 -32
  376. package/src/types/react-i18next.d.ts +0 -10
  377. package/src/types/remove.ts +0 -8
  378. package/src/types/security.ts +0 -32
  379. package/src/types/settings.ts +0 -28
  380. package/src/types/state.ts +0 -97
  381. package/src/types/tour.ts +0 -20
  382. package/src/types/version-check.ts +0 -18
  383. package/src/utils/PINValidation.ts +0 -98
  384. package/src/utils/agent.ts +0 -128
  385. package/src/utils/anonCredsProofRequestMapper.ts +0 -205
  386. package/src/utils/contacts.ts +0 -59
  387. package/src/utils/cred-def.ts +0 -33
  388. package/src/utils/credential.ts +0 -37
  389. package/src/utils/crypto.ts +0 -12
  390. package/src/utils/fileCache.ts +0 -152
  391. package/src/utils/helpers.ts +0 -1292
  392. package/src/utils/ledger.ts +0 -212
  393. package/src/utils/luminance.ts +0 -40
  394. package/src/utils/mediatorhelpers.ts +0 -71
  395. package/src/utils/migration.ts +0 -40
  396. package/src/utils/network.tsx +0 -55
  397. package/src/utils/oca.ts +0 -173
  398. package/src/utils/parsers.tsx +0 -111
  399. package/src/utils/proofBundle.ts +0 -220
  400. package/src/utils/schema.ts +0 -28
  401. package/src/utils/testable.ts +0 -17
@@ -1,134 +0,0 @@
1
- import React, { useCallback, useContext, useRef, useState, useEffect } from 'react'
2
- import { ColorValue, LayoutRectangle, View, ViewStyle, useWindowDimensions } from 'react-native'
3
- import { Defs, Mask, Rect, Svg } from 'react-native-svg'
4
-
5
- import { tourMargin } from '../../constants'
6
- import { BackdropPressBehavior, OSConfig, TourContext, TourStep } from '../../contexts/tour/tour-context'
7
- import { Optional, TourID } from '../../types/tour'
8
- import { testIdWithKey } from '../../utils/testable'
9
-
10
- import { SpotCutout } from './SpotCutout'
11
-
12
- interface TourOverlayProps {
13
- backdropOpacity: number
14
- color: ColorValue
15
- currentTour: TourID
16
- currentStep: Optional<number>
17
- nativeDriver: boolean | OSConfig<boolean>
18
- onBackdropPress: Optional<BackdropPressBehavior>
19
- changeSpot: (spot: LayoutRectangle) => void
20
- spot: LayoutRectangle
21
- tourStep: TourStep
22
- }
23
-
24
- export const TourOverlay = (props: TourOverlayProps) => {
25
- const { width: windowWidth, height: windowHeight } = useWindowDimensions()
26
- const { color, currentTour, currentStep, onBackdropPress, backdropOpacity, changeSpot, spot, tourStep } = props
27
- const [viewBox, setViewBox] = useState(`0 0 ${windowWidth} ${windowHeight}`)
28
- const { next, previous, start, stop } = useContext(TourContext)
29
-
30
- const [tooltipStyle, setTooltipStyle] = useState<ViewStyle>({})
31
-
32
- const tooltipRef = useRef<View>(null)
33
-
34
- const handleBackdropPress = useCallback((): void => {
35
- const handler = tourStep.onBackdropPress ?? onBackdropPress
36
-
37
- if (handler !== undefined && currentStep !== undefined) {
38
- switch (handler) {
39
- case 'continue':
40
- return next()
41
-
42
- case 'stop':
43
- return stop()
44
-
45
- default:
46
- return handler({ currentTour, currentStep, changeSpot, next, previous, start, stop })
47
- }
48
- }
49
- }, [tourStep, onBackdropPress, currentTour, currentStep, changeSpot, next, previous, start, stop])
50
-
51
- useEffect(() => {
52
- const gapBetweenSpotAndTooltip = 50
53
- // if origin spot (ie. no spotlight)
54
- if (spot.x === 0 && spot.y === 0) {
55
- // a relative margin so that the tooltip doesn't start at the very top of the screen
56
- const oneSixthOfScreenHeight = windowHeight / 6
57
- setTooltipStyle({
58
- left: tourMargin,
59
- right: tourMargin,
60
- top: oneSixthOfScreenHeight,
61
- })
62
- // if spot is in the lower half of the screen
63
- } else if (spot.y >= windowHeight / 2) {
64
- const bottom = windowHeight - spot.y + gapBetweenSpotAndTooltip
65
- setTooltipStyle({
66
- left: tourMargin,
67
- right: tourMargin,
68
- bottom,
69
- })
70
- // if spot is in the upper half of the screen
71
- } else {
72
- const top = spot.y + gapBetweenSpotAndTooltip + spot.height
73
- setTooltipStyle({
74
- left: tourMargin,
75
- right: tourMargin,
76
- top,
77
- })
78
- }
79
- }, [windowWidth, windowHeight, spot.width, spot.height, spot.x, spot.y])
80
-
81
- useEffect(() => {
82
- // + 1 pixel to account for an svg size rounding issue that would cause
83
- // a tiny gap around the overlay
84
- setViewBox(`0 0 ${windowWidth + 1} ${windowHeight + 1}`)
85
- }, [windowWidth, windowHeight])
86
-
87
- return currentStep !== undefined ? (
88
- <View
89
- accessibilityViewIsModal
90
- style={{ position: 'absolute', top: 0, left: 0, height: windowHeight + 1, width: windowWidth + 1 }}
91
- testID={testIdWithKey('SpotlightOverlay')}
92
- >
93
- <Svg
94
- testID={testIdWithKey('SpotOverlay')}
95
- height={windowHeight + 1}
96
- width={windowWidth + 1}
97
- viewBox={viewBox}
98
- onPress={handleBackdropPress}
99
- shouldRasterizeIOS={true}
100
- renderToHardwareTextureAndroid={true}
101
- >
102
- <Defs>
103
- <Mask id="mask" x={0} y={0} height={windowHeight + 1} width={windowWidth + 1}>
104
- <Rect height={windowHeight + 1} width={windowWidth + 1} fill="#fff" />
105
- <SpotCutout />
106
- </Mask>
107
- </Defs>
108
-
109
- <Rect
110
- height={windowHeight + 1}
111
- width={windowWidth + 1}
112
- fill={color}
113
- mask="url(#mask)"
114
- opacity={backdropOpacity}
115
- />
116
- </Svg>
117
-
118
- <View
119
- ref={tooltipRef}
120
- testID={testIdWithKey('SpotTooltip')}
121
- style={{ ...tooltipStyle, opacity: 1, position: 'absolute' }}
122
- >
123
- <tourStep.Render
124
- currentTour={currentTour}
125
- currentStep={currentStep}
126
- changeSpot={changeSpot}
127
- next={next}
128
- previous={previous}
129
- stop={stop}
130
- />
131
- </View>
132
- </View>
133
- ) : null
134
- }
@@ -1,181 +0,0 @@
1
- import React, { useState } from 'react'
2
- import { useTranslation } from 'react-i18next'
3
- import { StyleSheet, TouchableOpacity, View } from 'react-native'
4
- import Icon from 'react-native-vector-icons/MaterialCommunityIcons'
5
- import { DispatchAction } from '../../contexts/reducers/store'
6
- import { useStore } from '../../contexts/store'
7
- import { useTheme } from '../../contexts/theme'
8
- import { testIdWithKey } from '../../utils/testable'
9
- import { ThemedText } from '../texts/ThemedText'
10
-
11
- export interface BannerMessage {
12
- id: string
13
- title: string
14
- type: 'error' | 'warning' | 'info' | 'success'
15
- variant: 'summary' | 'detail'
16
- dismissible?: boolean
17
- }
18
-
19
- export interface BannerSectionProps extends BannerMessage {
20
- expanded?: boolean
21
- onDismiss?: () => void
22
- onToggle?: () => void
23
- }
24
-
25
- export const Banner: React.FC = () => {
26
- const { t } = useTranslation()
27
- const { ColorPalette } = useTheme()
28
- const [store, dispatch] = useStore()
29
- const [expanded, setExpanded] = useState(false)
30
-
31
- const bannerMessages = store.preferences.bannerMessages
32
- const alertMessage: BannerMessage = {
33
- id: 'alertMessage',
34
- title: t('Banner.AlertsLength', { alerts: bannerMessages.length }),
35
- type: 'error',
36
- variant: 'summary',
37
- }
38
-
39
- const dismissBanner = (key: string) => {
40
- dispatch({
41
- type: DispatchAction.REMOVE_BANNER_MESSAGE,
42
- payload: [key],
43
- })
44
- }
45
-
46
- if (!bannerMessages || bannerMessages.length == 0) {
47
- return null
48
- }
49
-
50
- if (bannerMessages.length === 1) {
51
- const message = bannerMessages[0]
52
- return (
53
- <BannerSection
54
- id={message.id}
55
- key={message.id}
56
- title={message.title}
57
- type={message.type}
58
- variant="detail"
59
- onDismiss={() => dismissBanner(message.id)}
60
- dismissible={message.dismissible}
61
- />
62
- )
63
- }
64
-
65
- return (
66
- <View>
67
- <BannerSection
68
- id={alertMessage.id}
69
- title={t('Banner.AlertsLength', { alerts: bannerMessages.length })}
70
- type={alertMessage.type}
71
- variant={alertMessage.variant}
72
- expanded={expanded}
73
- onToggle={() => setExpanded(!expanded)}
74
- dismissible={alertMessage.dismissible}
75
- />
76
- {expanded &&
77
- bannerMessages.map((message) => (
78
- <React.Fragment key={message.id}>
79
- {/* Render a divider between the banners when multiple banners exist */}
80
- <View style={{ height: 2, backgroundColor: ColorPalette.brand.primaryBackground }} />
81
- <BannerSection
82
- id={message.id}
83
- key={message.id}
84
- title={message.title}
85
- type={message.type}
86
- variant="detail"
87
- onDismiss={() => dismissBanner(message.id)}
88
- dismissible={message.dismissible}
89
- />
90
- </React.Fragment>
91
- ))}
92
- </View>
93
- )
94
- }
95
-
96
- export const BannerSection: React.FC<BannerSectionProps> = ({
97
- title,
98
- type,
99
- onDismiss,
100
- dismissible = true,
101
- variant,
102
- expanded,
103
- onToggle,
104
- }) => {
105
- const { Spacing, ColorPalette } = useTheme()
106
- const styles = StyleSheet.create({
107
- container: {
108
- backgroundColor: ColorPalette.brand.primary,
109
- flexDirection: 'row',
110
- alignItems: 'center',
111
- padding: Spacing.md,
112
- },
113
- icon: {
114
- marginRight: Spacing.md,
115
- },
116
- })
117
-
118
- const iconName = (type: string): string => {
119
- switch (type) {
120
- case 'error':
121
- return 'alert-circle'
122
- case 'warning':
123
- return 'alert'
124
- case 'info':
125
- return 'information'
126
- case 'success':
127
- return 'check-circle'
128
- default:
129
- return 'information'
130
- }
131
- }
132
-
133
- const bannerColor = (type: string): string => {
134
- switch (type) {
135
- case 'error':
136
- return '#CE3E39'
137
- case 'warning':
138
- return '#F8BB47'
139
- case 'info':
140
- return '#2E5DD7'
141
- case 'success':
142
- return '#42814A'
143
- default:
144
- return '#2E5DD7'
145
- }
146
- }
147
-
148
- // If more details are needed we might need to push the banner down to accommodate the extra information
149
- return (
150
- <TouchableOpacity
151
- style={{ ...styles.container, backgroundColor: bannerColor(type) }}
152
- testID={testIdWithKey(`button-${type}`)}
153
- onPress={() => {
154
- if (variant === 'summary' && onToggle) {
155
- onToggle()
156
- } else if (dismissible && onDismiss) {
157
- onDismiss()
158
- }
159
- }}
160
- >
161
- <Icon
162
- name={iconName(type)}
163
- size={24}
164
- color={type === 'warning' ? ColorPalette.brand.secondaryBackground : ColorPalette.grayscale.white}
165
- style={styles.icon}
166
- testID={testIdWithKey(`icon-${type}`)}
167
- />
168
- <ThemedText
169
- variant={'bold'}
170
- style={{
171
- color: type === 'warning' ? ColorPalette.brand.secondaryBackground : ColorPalette.grayscale.white,
172
- flex: 1,
173
- }}
174
- testID={testIdWithKey(`text-${type}`)}
175
- >
176
- {title}
177
- </ThemedText>
178
- {variant === 'summary' && <Icon name={expanded ? 'chevron-up' : 'chevron-down'} size={24} color="white" />}
179
- </TouchableOpacity>
180
- )
181
- }
@@ -1,77 +0,0 @@
1
- import { Image, StyleSheet, useWindowDimensions, View } from 'react-native'
2
- import { BrandingOverlay } from '@bifold/oca'
3
- import { BrandingOverlayType, CredentialOverlay } from '@bifold/oca/build/legacy'
4
- import { useTheme } from '../../contexts/theme'
5
- import { toImageSource } from '../../utils/credential'
6
- import { useMemo } from 'react'
7
- import { ThemedText } from '../texts/ThemedText'
8
-
9
- type Props = {
10
- overlay: CredentialOverlay<BrandingOverlay>
11
- brandingOverlayType?: BrandingOverlayType
12
- }
13
-
14
- const CredentialCardLogo: React.FC<Props> = ({
15
- overlay,
16
- brandingOverlayType = BrandingOverlayType.Branding10,
17
- }: Props) => {
18
- const { CredentialCardShadowTheme } = useTheme()
19
- const { fontScale } = useWindowDimensions()
20
- const logoHeight = brandingOverlayType === BrandingOverlayType.Branding10 ? 80 : 48
21
- const paddingHorizontal = 24
22
- const isBranding11 = brandingOverlayType === BrandingOverlayType.Branding11
23
- const textColor =
24
- overlay.brandingOverlay?.secondaryBackgroundColor && overlay.brandingOverlay.secondaryBackgroundColor !== ''
25
- ? overlay.brandingOverlay.secondaryBackgroundColor
26
- : overlay.brandingOverlay?.primaryBackgroundColor
27
-
28
- const logoText = useMemo(() => {
29
- if (brandingOverlayType === BrandingOverlayType.Branding11) {
30
- return (overlay.metaOverlay?.issuer ?? 'I').charAt(0).toUpperCase()
31
- }
32
- return (overlay.metaOverlay?.name ?? overlay.metaOverlay?.issuer ?? 'C').charAt(0).toUpperCase()
33
- }, [brandingOverlayType, overlay])
34
-
35
- const styles = StyleSheet.create({
36
- logoContainer: {
37
- width: logoHeight * (fontScale > 1.7 ? 1.2 : 1),
38
- height: logoHeight * (fontScale > 1.7 ? 1.2 : 1),
39
- backgroundColor: '#ffffff',
40
- borderRadius: 8,
41
- justifyContent: 'center',
42
- alignItems: 'center',
43
- ...(brandingOverlayType === BrandingOverlayType.Branding10 && {
44
- top: -0.5 * logoHeight,
45
- left: paddingHorizontal,
46
- marginBottom: -1 * logoHeight,
47
- ...CredentialCardShadowTheme,
48
- }),
49
- },
50
- })
51
-
52
- return (
53
- <View style={styles.logoContainer}>
54
- {overlay.brandingOverlay?.logo ? (
55
- <Image
56
- source={toImageSource(overlay.brandingOverlay?.logo)}
57
- style={{
58
- resizeMode: 'cover',
59
- width: logoHeight,
60
- height: logoHeight,
61
- borderRadius: 8,
62
- }}
63
- />
64
- ) : (
65
- <ThemedText
66
- variant="title"
67
- style={{ fontSize: 0.5 * logoHeight, color: isBranding11 ? textColor : '#000' }}
68
- accessible={false}
69
- >
70
- {logoText}
71
- </ThemedText>
72
- )}
73
- </View>
74
- )
75
- }
76
-
77
- export default CredentialCardLogo
@@ -1,107 +0,0 @@
1
- import { StyleSheet, useWindowDimensions, View } from 'react-native'
2
- import { BrandingOverlay } from '@bifold/oca'
3
- import { BrandingOverlayType, CredentialOverlay } from '@bifold/oca/build/legacy'
4
- import CardWatermark from '../../components/misc/CardWatermark'
5
- import { useTheme } from '../../contexts/theme'
6
- import { credentialTextColor } from '../../utils/credential'
7
- import { testIdWithKey } from '../../utils/testable'
8
- import { CredentialExchangeRecord } from '@credo-ts/core'
9
- import { useTranslation } from 'react-i18next'
10
- import { formatTime } from '../../utils/helpers'
11
- import { ThemedText } from '../texts/ThemedText'
12
-
13
- type CredentialDetailPrimaryHeaderProps = {
14
- overlay: CredentialOverlay<BrandingOverlay>
15
- brandingOverlayType?: BrandingOverlayType
16
- credential?: CredentialExchangeRecord
17
- }
18
-
19
- const paddingHorizontal = 24
20
- const paddingVertical = 16
21
- const logoHeight = 80
22
-
23
- const CredentialDetailPrimaryHeader: React.FC<CredentialDetailPrimaryHeaderProps> = ({
24
- overlay,
25
- brandingOverlayType = BrandingOverlayType.Branding10,
26
- credential,
27
- }: CredentialDetailPrimaryHeaderProps) => {
28
- const { t } = useTranslation()
29
- const { ColorPalette } = useTheme()
30
- const { width, height } = useWindowDimensions()
31
- const isBranding11 = brandingOverlayType === BrandingOverlayType.Branding11
32
- const styles = StyleSheet.create({
33
- primaryHeaderContainer: {
34
- paddingHorizontal: isBranding11 ? 16 : paddingHorizontal,
35
- paddingVertical,
36
- overflow: 'hidden',
37
- },
38
- textContainer: {
39
- color:
40
- brandingOverlayType === BrandingOverlayType.Branding10
41
- ? credentialTextColor(ColorPalette, overlay.brandingOverlay?.primaryBackgroundColor)
42
- : ColorPalette.brand.primary,
43
- },
44
- })
45
-
46
- return (
47
- <View
48
- testID={testIdWithKey('CredentialDetailsPrimaryHeader')}
49
- style={[styles.primaryHeaderContainer, { zIndex: -1 }]}
50
- >
51
- <View>
52
- {overlay.metaOverlay?.watermark && brandingOverlayType === BrandingOverlayType.Branding10 && (
53
- <CardWatermark width={width} height={height} watermark={overlay.metaOverlay?.watermark} />
54
- )}
55
- {brandingOverlayType === BrandingOverlayType.Branding10 && (
56
- <ThemedText
57
- accessibilityLabel={`${t('Credentials.IssuedBy')} ${overlay.metaOverlay?.issuer}`}
58
- testID={testIdWithKey('CredentialIssuer')}
59
- variant="label"
60
- style={[
61
- styles.textContainer,
62
- {
63
- paddingLeft: logoHeight + paddingVertical,
64
- paddingBottom: paddingVertical,
65
- lineHeight: 19,
66
- opacity: 0.8,
67
- },
68
- ]}
69
- numberOfLines={1}
70
- >
71
- {overlay.metaOverlay?.issuer}
72
- </ThemedText>
73
- )}
74
- <ThemedText
75
- accessibilityLabel={`${overlay.metaOverlay?.name} ${t('Credentials.Credential')}`}
76
- testID={testIdWithKey('CredentialName')}
77
- style={[
78
- styles.textContainer,
79
- {
80
- lineHeight: 24,
81
- },
82
- ]}
83
- >
84
- {overlay.metaOverlay?.name}
85
- </ThemedText>
86
- {brandingOverlayType === BrandingOverlayType.Branding11 && credential && (
87
- <ThemedText
88
- testID={testIdWithKey('IssuedOn')}
89
- style={[
90
- styles.textContainer,
91
- {
92
- lineHeight: 24,
93
- marginTop: 8,
94
- fontSize: 14,
95
- color: ColorPalette.grayscale.mediumGrey,
96
- },
97
- ]}
98
- >
99
- {t('CredentialDetails.IssuedOn')} {formatTime(credential.createdAt, { includeHour: true })}
100
- </ThemedText>
101
- )}
102
- </View>
103
- </View>
104
- )
105
- }
106
-
107
- export default CredentialDetailPrimaryHeader
@@ -1,60 +0,0 @@
1
- import React from 'react'
2
- import { BrandingOverlay } from '@bifold/oca'
3
- import { BrandingOverlayType, CredentialOverlay } from '@bifold/oca/build/legacy'
4
- import { ImageBackground, StyleSheet, View } from 'react-native'
5
- import { toImageSource } from '../../utils/credential'
6
- import { testIdWithKey } from '../../utils/testable'
7
-
8
- type CredentialDetailSecondaryHeaderProps = {
9
- overlay: CredentialOverlay<BrandingOverlay>
10
- brandingOverlayType?: BrandingOverlayType
11
- }
12
-
13
- const logoHeight = 80
14
-
15
- const CredentialDetailSecondaryHeader: React.FC<CredentialDetailSecondaryHeaderProps> = ({
16
- overlay,
17
- brandingOverlayType = BrandingOverlayType.Branding10,
18
- }: CredentialDetailSecondaryHeaderProps) => {
19
- const styles = StyleSheet.create({
20
- secondaryHeaderContainer: {
21
- height: 1.5 * logoHeight,
22
- backgroundColor:
23
- (overlay.brandingOverlay?.backgroundImage
24
- ? 'rgba(0, 0, 0, 0)'
25
- : overlay.brandingOverlay?.secondaryBackgroundColor) ?? 'rgba(0, 0, 0, 0.24)',
26
- },
27
- })
28
-
29
- return (
30
- <>
31
- {overlay.brandingOverlay?.backgroundImage ? (
32
- <ImageBackground
33
- source={toImageSource(overlay.brandingOverlay?.backgroundImage)}
34
- imageStyle={{
35
- resizeMode: 'cover',
36
- }}
37
- >
38
- <View testID={testIdWithKey('CredentialDetailsSecondaryHeader')} style={styles.secondaryHeaderContainer} />
39
- </ImageBackground>
40
- ) : (
41
- <View testID={testIdWithKey('CredentialDetailsSecondaryHeader')} style={styles.secondaryHeaderContainer}>
42
- {brandingOverlayType === BrandingOverlayType.Branding11 && (
43
- <View
44
- style={[
45
- {
46
- position: 'absolute',
47
- width: '100%',
48
- height: '100%',
49
- backgroundColor: 'rgba(0,0,0,0.24)',
50
- },
51
- ]}
52
- />
53
- )}
54
- </View>
55
- )}
56
- </>
57
- )
58
- }
59
-
60
- export default CredentialDetailSecondaryHeader
@@ -1,17 +0,0 @@
1
- import React from 'react'
2
- import { View } from 'react-native'
3
- import { StackHeaderProps, Header } from '@react-navigation/stack'
4
- import { useServices, TOKENS } from '../../container-api'
5
-
6
- const HeaderWithBanner: React.FC<StackHeaderProps> = (props) => {
7
- const [NotificationBanner] = useServices([TOKENS.COMPONENT_NOTIFICATION_BANNER])
8
-
9
- return (
10
- <View>
11
- <Header {...props} />
12
- <NotificationBanner />
13
- </View>
14
- )
15
- }
16
-
17
- export default HeaderWithBanner
@@ -1,110 +0,0 @@
1
- import { CredentialState } from '@credo-ts/core'
2
- import { useCredentialByState } from '@credo-ts/react-hooks'
3
- import React from 'react'
4
- import { useTranslation } from 'react-i18next'
5
- import { StyleSheet, View } from 'react-native'
6
- import { useTheme } from '../../contexts/theme'
7
- import { useOpenIDCredentials } from '../../modules/openid/context/OpenIDCredentialRecordProvider'
8
- import { ThemedText } from '../texts/ThemedText'
9
-
10
- const offset = 25
11
-
12
- interface HomeFooterViewProps {
13
- children?: any
14
- }
15
-
16
- const HomeFooterView: React.FC<HomeFooterViewProps> = ({ children }) => {
17
- const { openIdState } = useOpenIDCredentials()
18
- const { w3cCredentialRecords, sdJwtVcRecords } = openIdState
19
- const credentials = [
20
- ...useCredentialByState(CredentialState.CredentialReceived),
21
- ...useCredentialByState(CredentialState.Done),
22
- ...w3cCredentialRecords,
23
- ...sdJwtVcRecords,
24
- ]
25
- const { HomeTheme, TextTheme, Assets } = useTheme()
26
- const { t } = useTranslation()
27
-
28
- const styles = StyleSheet.create({
29
- container: {
30
- paddingHorizontal: offset,
31
- paddingBottom: offset * 3,
32
- },
33
-
34
- messageContainer: {
35
- alignItems: 'center',
36
- justifyContent: 'center',
37
- marginHorizontal: offset,
38
- },
39
-
40
- imageContainer: {
41
- alignItems: 'center',
42
- marginTop: 100,
43
- },
44
- })
45
-
46
- const displayMessage = (credentialCount: number) => {
47
- if (typeof credentialCount === 'undefined' && credentialCount >= 0) {
48
- throw new Error('Credential count cannot be undefined')
49
- }
50
-
51
- let credentialMsg
52
- let scanReminder
53
-
54
- if (credentialCount === 1) {
55
- credentialMsg = (
56
- <ThemedText>
57
- {t('Home.YouHave')}{' '}
58
- <ThemedText style={{ fontWeight: TextTheme.bold.fontWeight }}>{credentialCount}</ThemedText>{' '}
59
- {t('Home.Credential')} {t('Home.InYourWallet')}
60
- </ThemedText>
61
- )
62
- } else if (credentialCount > 1) {
63
- credentialMsg = (
64
- <ThemedText>
65
- {t('Home.YouHave')}{' '}
66
- <ThemedText style={{ fontWeight: TextTheme.bold.fontWeight }}>{credentialCount}</ThemedText>{' '}
67
- {t('Home.Credentials')} {t('Home.InYourWallet')}
68
- </ThemedText>
69
- )
70
- } else {
71
- credentialMsg = <ThemedText variant="bold">{t('Home.NoCredentials')}</ThemedText>
72
- scanReminder = <ThemedText>{t('Home.ScanOfferAddCard')}</ThemedText>
73
- }
74
-
75
- return (
76
- <>
77
- <View style={styles.imageContainer}>
78
- <Assets.svg.homeCenterImg {...{ width: '30%' }} />
79
- </View>
80
-
81
- <View style={styles.messageContainer}>
82
- <ThemedText
83
- adjustsFontSizeToFit
84
- style={[HomeTheme.credentialMsg, { marginTop: offset, textAlign: 'center' }]}
85
- >
86
- {credentialMsg}
87
- </ThemedText>
88
- </View>
89
-
90
- <View style={styles.messageContainer}>
91
- <ThemedText
92
- adjustsFontSizeToFit
93
- style={[HomeTheme.credentialMsg, { marginTop: offset, textAlign: 'center' }]}
94
- >
95
- {scanReminder}
96
- </ThemedText>
97
- </View>
98
- </>
99
- )
100
- }
101
-
102
- return (
103
- <View>
104
- <View style={styles.container}>{displayMessage(credentials.length)}</View>
105
- {children}
106
- </View>
107
- )
108
- }
109
-
110
- export default HomeFooterView