@bifold/core 2.4.5 → 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 (416) 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/ContactDetails.js +1 -1
  8. package/lib/commonjs/screens/ContactDetails.js.map +1 -1
  9. package/lib/commonjs/screens/CredentialDetails.js +1 -1
  10. package/lib/commonjs/screens/CredentialDetails.js.map +1 -1
  11. package/lib/commonjs/screens/JSONDetails.js +6 -3
  12. package/lib/commonjs/screens/JSONDetails.js.map +1 -1
  13. package/lib/commonjs/screens/MobileVerifierLoading.js +4 -3
  14. package/lib/commonjs/screens/MobileVerifierLoading.js.map +1 -1
  15. package/lib/commonjs/screens/PINCreate.js +3 -10
  16. package/lib/commonjs/screens/PINCreate.js.map +1 -1
  17. package/lib/commonjs/screens/WhatAreContacts.js +3 -2
  18. package/lib/commonjs/screens/WhatAreContacts.js.map +1 -1
  19. package/lib/module/contexts/reducers/store.js +3 -2
  20. package/lib/module/contexts/reducers/store.js.map +1 -1
  21. package/lib/module/index.js +42 -45
  22. package/lib/module/index.js.map +1 -1
  23. package/lib/module/screens/AttemptLockout.js +28 -36
  24. package/lib/module/screens/AttemptLockout.js.map +1 -1
  25. package/lib/module/screens/ContactDetails.js +1 -1
  26. package/lib/module/screens/ContactDetails.js.map +1 -1
  27. package/lib/module/screens/CredentialDetails.js +1 -1
  28. package/lib/module/screens/CredentialDetails.js.map +1 -1
  29. package/lib/module/screens/JSONDetails.js +6 -3
  30. package/lib/module/screens/JSONDetails.js.map +1 -1
  31. package/lib/module/screens/MobileVerifierLoading.js +4 -3
  32. package/lib/module/screens/MobileVerifierLoading.js.map +1 -1
  33. package/lib/module/screens/PINCreate.js +3 -10
  34. package/lib/module/screens/PINCreate.js.map +1 -1
  35. package/lib/module/screens/WhatAreContacts.js +3 -2
  36. package/lib/module/screens/WhatAreContacts.js.map +1 -1
  37. package/lib/typescript/src/contexts/reducers/store.d.ts.map +1 -1
  38. package/lib/typescript/src/index.d.ts +57 -61
  39. package/lib/typescript/src/index.d.ts.map +1 -1
  40. package/lib/typescript/src/screens/AttemptLockout.d.ts.map +1 -1
  41. package/lib/typescript/src/screens/JSONDetails.d.ts.map +1 -1
  42. package/lib/typescript/src/screens/MobileVerifierLoading.d.ts.map +1 -1
  43. package/lib/typescript/src/screens/PINCreate.d.ts.map +1 -1
  44. package/lib/typescript/src/screens/WhatAreContacts.d.ts.map +1 -1
  45. package/lib/typescript/src/types/navigators.d.ts +1 -1
  46. package/lib/typescript/src/types/navigators.d.ts.map +1 -1
  47. package/package.json +3 -4
  48. package/src/App.tsx +0 -79
  49. package/src/animated-components.ts +0 -30
  50. package/src/assets/fonts/MaterialIcons.ttf +0 -0
  51. package/src/assets/icons/code.svg +0 -4
  52. package/src/assets/icons/large-arrow.svg +0 -5
  53. package/src/assets/icons/pencil.svg +0 -15
  54. package/src/assets/icons/trash.svg +0 -31
  55. package/src/assets/img/Artwork_1024x1024.png +0 -0
  56. package/src/assets/img/HistoryCardAcceptedIcon.svg +0 -4
  57. package/src/assets/img/HistoryCardExpiredIcon.svg +0 -4
  58. package/src/assets/img/HistoryCardRevokedIcon.svg +0 -4
  59. package/src/assets/img/HistoryInformationSentIcon.svg +0 -4
  60. package/src/assets/img/HistoryPinUpdatedIcon.svg +0 -4
  61. package/src/assets/img/IconChevronRight.svg +0 -5
  62. package/src/assets/img/activity-indicator-circle.svg +0 -90
  63. package/src/assets/img/app-lockout.svg +0 -1
  64. package/src/assets/img/biometrics.svg +0 -74
  65. package/src/assets/img/chat-loading.svg +0 -1
  66. package/src/assets/img/check-in-circle.svg +0 -18
  67. package/src/assets/img/connection-pending.svg +0 -112
  68. package/src/assets/img/contact-book.svg +0 -21
  69. package/src/assets/img/credential-card.svg +0 -18
  70. package/src/assets/img/credential-declined.svg +0 -28
  71. package/src/assets/img/credential-in-hand.svg +0 -48
  72. package/src/assets/img/credential-list.svg +0 -60
  73. package/src/assets/img/credential-pending.svg +0 -96
  74. package/src/assets/img/credential-success.svg +0 -48
  75. package/src/assets/img/delete-notification.svg +0 -1
  76. package/src/assets/img/empty-wallet.svg +0 -23
  77. package/src/assets/img/error-filled.svg +0 -12
  78. package/src/assets/img/exclamation-mark.svg +0 -17
  79. package/src/assets/img/home-center-img.svg +0 -71
  80. package/src/assets/img/icon-credential-offer-dark.svg +0 -7
  81. package/src/assets/img/icon-credential-offer-light.svg +0 -7
  82. package/src/assets/img/icon-info-recieved-dark.svg +0 -8
  83. package/src/assets/img/icon-info-recieved-light.svg +0 -8
  84. package/src/assets/img/icon-info-sent-dark.svg +0 -8
  85. package/src/assets/img/icon-info-sent-light.svg +0 -8
  86. package/src/assets/img/icon-proof-request-dark.svg +0 -11
  87. package/src/assets/img/icon-proof-request-light.svg +0 -11
  88. package/src/assets/img/information-received.svg +0 -1
  89. package/src/assets/img/logo-large.png +0 -0
  90. package/src/assets/img/logo-large@2x.png +0 -0
  91. package/src/assets/img/logo-large@3x.png +0 -0
  92. package/src/assets/img/logo.svg +0 -15
  93. package/src/assets/img/message-text-icon-outline.svg +0 -1
  94. package/src/assets/img/message-text-icon.svg +0 -1
  95. package/src/assets/img/no_information_shared.svg +0 -36
  96. package/src/assets/img/preface.svg +0 -15
  97. package/src/assets/img/proof-declined.svg +0 -66
  98. package/src/assets/img/proof-pending.svg +0 -61
  99. package/src/assets/img/proof-success.svg +0 -72
  100. package/src/assets/img/push-notifications.svg +0 -1
  101. package/src/assets/img/qrcode-scan-icon.svg +0 -1
  102. package/src/assets/img/scan-share.svg +0 -102
  103. package/src/assets/img/secure-check.svg +0 -4
  104. package/src/assets/img/secure-image.svg +0 -64
  105. package/src/assets/img/update-available.svg +0 -26
  106. package/src/assets/img/verifier-request-declined.svg +0 -34
  107. package/src/assets/img/wallet-back.svg +0 -20
  108. package/src/assets/img/wallet-front.svg +0 -32
  109. package/src/assets/img/wallet-icon-outline.svg +0 -1
  110. package/src/assets/img/wallet-icon.svg +0 -1
  111. package/src/assets/img/wallet.svg +0 -43
  112. package/src/assets/oca-bundles.json +0 -174
  113. package/src/components/animated/ButtonLoading.tsx +0 -32
  114. package/src/components/animated/ConnectionLoading.tsx +0 -53
  115. package/src/components/animated/CredentialAdded.tsx +0 -72
  116. package/src/components/animated/CredentialPending.tsx +0 -63
  117. package/src/components/animated/LoadingIndicator.tsx +0 -49
  118. package/src/components/animated/PresentationLoading.tsx +0 -52
  119. package/src/components/animated/RecordLoading.tsx +0 -75
  120. package/src/components/animated/SendingProof.tsx +0 -53
  121. package/src/components/animated/SentProof.tsx +0 -72
  122. package/src/components/buttons/Button-api.tsx +0 -46
  123. package/src/components/buttons/Button.tsx +0 -125
  124. package/src/components/buttons/HeaderHome.tsx +0 -25
  125. package/src/components/buttons/IconButton.tsx +0 -93
  126. package/src/components/buttons/InfoIcon.tsx +0 -35
  127. package/src/components/buttons/SettingsMenu.tsx +0 -26
  128. package/src/components/buttons/ToggleButton.tsx +0 -93
  129. package/src/components/buttons/index.ts +0 -4
  130. package/src/components/chat/ActionSlider.tsx +0 -104
  131. package/src/components/chat/ChatActions.tsx +0 -33
  132. package/src/components/chat/ChatBubble.tsx +0 -20
  133. package/src/components/chat/ChatEvent.tsx +0 -31
  134. package/src/components/chat/ChatMessage.tsx +0 -142
  135. package/src/components/chat/MessageInput.tsx +0 -46
  136. package/src/components/chat/index.ts +0 -4
  137. package/src/components/forms/WalletNameForm.tsx +0 -148
  138. package/src/components/index.ts +0 -4
  139. package/src/components/inputs/BiometryControl.tsx +0 -190
  140. package/src/components/inputs/BulletPoint.tsx +0 -32
  141. package/src/components/inputs/CheckBoxRow.tsx +0 -67
  142. package/src/components/inputs/InlineErrorText.tsx +0 -60
  143. package/src/components/inputs/LimitedTextInput.tsx +0 -71
  144. package/src/components/inputs/PINInput.tsx +0 -175
  145. package/src/components/inputs/SingleSelectBlock.tsx +0 -53
  146. package/src/components/listItems/ContactCredentialListItem.tsx +0 -79
  147. package/src/components/listItems/ContactListItem.tsx +0 -121
  148. package/src/components/listItems/NotificationListItem.tsx +0 -514
  149. package/src/components/misc/AvatarView.tsx +0 -33
  150. package/src/components/misc/CardWatermark.tsx +0 -52
  151. package/src/components/misc/ConnectionAlert.tsx +0 -123
  152. package/src/components/misc/ConnectionImage.tsx +0 -45
  153. package/src/components/misc/ContentGradient.tsx +0 -40
  154. package/src/components/misc/CredentialCard.tsx +0 -161
  155. package/src/components/misc/CredentialCard10.tsx +0 -329
  156. package/src/components/misc/CredentialCard11.tsx +0 -701
  157. package/src/components/misc/CredentialCard11ActionFooter.tsx +0 -55
  158. package/src/components/misc/CredentialCard11Issuer.tsx +0 -74
  159. package/src/components/misc/CredentialCard11Logo.tsx +0 -61
  160. package/src/components/misc/EmptyList.tsx +0 -27
  161. package/src/components/misc/EmptyListContacts.tsx +0 -55
  162. package/src/components/misc/ErrorBoundary.tsx +0 -200
  163. package/src/components/misc/FauxHeader.tsx +0 -75
  164. package/src/components/misc/InfoBox.tsx +0 -283
  165. package/src/components/misc/NoNewUpdates.tsx +0 -38
  166. package/src/components/misc/PINHeader.tsx +0 -25
  167. package/src/components/misc/PINValidationHelper.tsx +0 -48
  168. package/src/components/misc/Pagination.tsx +0 -114
  169. package/src/components/misc/QRRenderer.tsx +0 -53
  170. package/src/components/misc/QRScanner.tsx +0 -395
  171. package/src/components/misc/QRScannerTorch.tsx +0 -74
  172. package/src/components/misc/ScanCamera.tsx +0 -86
  173. package/src/components/misc/ScanTab.tsx +0 -45
  174. package/src/components/misc/SharedProofData.tsx +0 -98
  175. package/src/components/misc/UnorderedList.tsx +0 -28
  176. package/src/components/misc/VerifierCredentialCard.tsx +0 -378
  177. package/src/components/misc/index.ts +0 -2
  178. package/src/components/modals/AlertModal.tsx +0 -42
  179. package/src/components/modals/AppGuideModal.tsx +0 -142
  180. package/src/components/modals/CameraDisclosureModal.tsx +0 -126
  181. package/src/components/modals/CommonRemoveModal.tsx +0 -337
  182. package/src/components/modals/DeveloperModal.tsx +0 -32
  183. package/src/components/modals/DismissiblePopupModal.tsx +0 -169
  184. package/src/components/modals/ErrorModal.tsx +0 -107
  185. package/src/components/modals/ImageModal.tsx +0 -80
  186. package/src/components/modals/NetInfoModal.tsx +0 -35
  187. package/src/components/modals/PopupModal.tsx +0 -56
  188. package/src/components/modals/ProofCancelModal.tsx +0 -79
  189. package/src/components/modals/SafeAreaModal.tsx +0 -17
  190. package/src/components/record/Record.tsx +0 -100
  191. package/src/components/record/RecordBinaryField.tsx +0 -55
  192. package/src/components/record/RecordDateIntField.tsx +0 -63
  193. package/src/components/record/RecordField.tsx +0 -154
  194. package/src/components/record/RecordFooter.tsx +0 -17
  195. package/src/components/record/RecordHeader.tsx +0 -17
  196. package/src/components/record/RecordRemove.tsx +0 -66
  197. package/src/components/texts/HeaderTitle.tsx +0 -25
  198. package/src/components/texts/HighlightTextBox.tsx +0 -41
  199. package/src/components/texts/InfoTextBox.tsx +0 -129
  200. package/src/components/texts/Link.tsx +0 -41
  201. package/src/components/texts/Text.tsx +0 -21
  202. package/src/components/texts/ThemedText.tsx +0 -24
  203. package/src/components/toast/BaseToast.tsx +0 -128
  204. package/src/components/toast/ToastConfig.tsx +0 -21
  205. package/src/components/tour/AttachTourStep.tsx +0 -73
  206. package/src/components/tour/CredentialOfferTourSteps.tsx +0 -41
  207. package/src/components/tour/CredentialsTourSteps.tsx +0 -41
  208. package/src/components/tour/HomeTourSteps.tsx +0 -104
  209. package/src/components/tour/ProofRequestTourSteps.tsx +0 -41
  210. package/src/components/tour/SpotCutout.tsx +0 -65
  211. package/src/components/tour/TourBox.tsx +0 -255
  212. package/src/components/tour/TourOverlay.tsx +0 -134
  213. package/src/components/views/Banner.tsx +0 -181
  214. package/src/components/views/CredentialCardLogo.tsx +0 -77
  215. package/src/components/views/CredentialDetailPrimaryHeader.tsx +0 -107
  216. package/src/components/views/CredentialDetailSecondaryHeader.tsx +0 -60
  217. package/src/components/views/HeaderWithBanner.tsx +0 -17
  218. package/src/components/views/HomeFooterView.tsx +0 -110
  219. package/src/components/views/HomeHeaderView.tsx +0 -12
  220. package/src/components/views/KeyboardView.tsx +0 -41
  221. package/src/components/views/LoadingPlaceholder.tsx +0 -168
  222. package/src/components/views/LoadingView.tsx +0 -29
  223. package/src/components/views/ProgressBar.tsx +0 -53
  224. package/src/components/views/PushNotificationsContent.tsx +0 -51
  225. package/src/components/views/PushNotificationsDisabledContent.tsx +0 -47
  226. package/src/configs/ledgers/indy/index.ts +0 -8
  227. package/src/configs/ledgers/indy/ledgers.json +0 -51
  228. package/src/constants.ts +0 -107
  229. package/src/container-api.ts +0 -247
  230. package/src/container-impl.ts +0 -243
  231. package/src/contexts/activity.tsx +0 -145
  232. package/src/contexts/animated-components.ts +0 -9
  233. package/src/contexts/auth.tsx +0 -240
  234. package/src/contexts/index.ts +0 -3
  235. package/src/contexts/navigation.tsx +0 -19
  236. package/src/contexts/network.tsx +0 -125
  237. package/src/contexts/reducers/index.ts +0 -3
  238. package/src/contexts/reducers/store.ts +0 -754
  239. package/src/contexts/store.tsx +0 -103
  240. package/src/contexts/theme.tsx +0 -51
  241. package/src/contexts/tour/tour-context.tsx +0 -160
  242. package/src/contexts/tour/tour-provider.tsx +0 -160
  243. package/src/hooks/bundle-resolver.ts +0 -95
  244. package/src/hooks/chat-messages.tsx +0 -263
  245. package/src/hooks/connections.ts +0 -37
  246. package/src/hooks/credential-card-styles.ts +0 -144
  247. package/src/hooks/credentials.ts +0 -11
  248. package/src/hooks/deep-links.ts +0 -49
  249. package/src/hooks/developer-mode.ts +0 -25
  250. package/src/hooks/lockout.ts +0 -77
  251. package/src/hooks/notifications.ts +0 -108
  252. package/src/hooks/oob.ts +0 -17
  253. package/src/hooks/proof-request-templates.ts +0 -40
  254. package/src/hooks/proofs.ts +0 -32
  255. package/src/hooks/screen-capture.ts +0 -52
  256. package/src/hooks/useBifoldAgentSetup.ts +0 -169
  257. package/src/hooks/useOnboardingState.ts +0 -53
  258. package/src/hooks/usePINValidation.ts +0 -98
  259. package/src/index.ts +0 -239
  260. package/src/layout/ScreenLayout.tsx +0 -53
  261. package/src/localization/en/en.json +0 -951
  262. package/src/localization/en/index.ts +0 -3
  263. package/src/localization/fr/fr.json +0 -933
  264. package/src/localization/fr/index.ts +0 -3
  265. package/src/localization/index.ts +0 -66
  266. package/src/localization/pt-br/index.ts +0 -3
  267. package/src/localization/pt-br/pt-br.json +0 -911
  268. package/src/modules/history/context/historyManager.tsx +0 -247
  269. package/src/modules/history/index.ts +0 -2
  270. package/src/modules/history/navigation/HistoryStack.tsx +0 -29
  271. package/src/modules/history/services/queue.service.tsx +0 -31
  272. package/src/modules/history/types/index.ts +0 -92
  273. package/src/modules/history/ui/HistoryPage.tsx +0 -133
  274. package/src/modules/history/ui/HistorySettings.tsx +0 -183
  275. package/src/modules/history/ui/assets/img/HistoryCardAcceptedIcon.svg +0 -4
  276. package/src/modules/history/ui/assets/img/HistoryCardExpiredIcon.svg +0 -4
  277. package/src/modules/history/ui/assets/img/HistoryCardRevokedIcon.svg +0 -4
  278. package/src/modules/history/ui/assets/img/HistoryInformationSentIcon.svg +0 -4
  279. package/src/modules/history/ui/assets/img/HistoryPinUpdatedIcon.svg +0 -4
  280. package/src/modules/history/ui/assets/img/IconChevronRight.svg +0 -3
  281. package/src/modules/history/ui/components/BulletPoint.tsx +0 -49
  282. package/src/modules/history/ui/components/HistoryListItem.tsx +0 -251
  283. package/src/modules/history/ui/components/HistoryMenu.tsx +0 -25
  284. package/src/modules/history/ui/components/SingleSelectBlock.tsx +0 -72
  285. package/src/modules/openid/components/CredentialRowCard.tsx +0 -64
  286. package/src/modules/openid/components/OpenIDCredentialCard.tsx +0 -276
  287. package/src/modules/openid/context/OpenIDCredentialRecordProvider.tsx +0 -296
  288. package/src/modules/openid/display.tsx +0 -467
  289. package/src/modules/openid/displayProof.tsx +0 -86
  290. package/src/modules/openid/hooks/openid.tsx +0 -111
  291. package/src/modules/openid/metadata.tsx +0 -59
  292. package/src/modules/openid/offerResolve.tsx +0 -281
  293. package/src/modules/openid/resolverProof.tsx +0 -286
  294. package/src/modules/openid/screens/OpenIDCredentialDetails.tsx +0 -214
  295. package/src/modules/openid/screens/OpenIDCredentialOffer.tsx +0 -192
  296. package/src/modules/openid/screens/OpenIDProofChangeCredential.tsx +0 -133
  297. package/src/modules/openid/screens/OpenIDProofPresentation.tsx +0 -423
  298. package/src/modules/openid/types.tsx +0 -111
  299. package/src/modules/openid/utils/utils.tsx +0 -119
  300. package/src/navigators/ConnectStack.tsx +0 -68
  301. package/src/navigators/ContactStack.tsx +0 -91
  302. package/src/navigators/CredentialStack.tsx +0 -48
  303. package/src/navigators/DeliveryStack.tsx +0 -76
  304. package/src/navigators/HomeStack.tsx +0 -37
  305. package/src/navigators/MainStack.tsx +0 -146
  306. package/src/navigators/NotificationStack.tsx +0 -56
  307. package/src/navigators/OnboardingScreens.ts +0 -142
  308. package/src/navigators/OnboardingStack.tsx +0 -205
  309. package/src/navigators/ProofRequestStack.tsx +0 -113
  310. package/src/navigators/RootStack.tsx +0 -71
  311. package/src/navigators/SettingStack.tsx +0 -174
  312. package/src/navigators/TabStack.tsx +0 -304
  313. package/src/navigators/defaultLayoutOptions.tsx +0 -17
  314. package/src/navigators/defaultStackOptions.tsx +0 -102
  315. package/src/navigators/index.ts +0 -27
  316. package/src/onboarding.ts +0 -90
  317. package/src/screens/AttemptLockout.tsx +0 -153
  318. package/src/screens/AutoLock.tsx +0 -140
  319. package/src/screens/Biometry.tsx +0 -54
  320. package/src/screens/Chat.tsx +0 -141
  321. package/src/screens/ConfigureMediator.tsx +0 -160
  322. package/src/screens/Connection.tsx +0 -394
  323. package/src/screens/ContactDetails.tsx +0 -350
  324. package/src/screens/CredentialDetails.tsx +0 -473
  325. package/src/screens/CredentialOffer.tsx +0 -334
  326. package/src/screens/CredentialOfferAccept.tsx +0 -189
  327. package/src/screens/DataRetention.tsx +0 -91
  328. package/src/screens/Developer.tsx +0 -289
  329. package/src/screens/Home.tsx +0 -173
  330. package/src/screens/JSONDetails.tsx +0 -102
  331. package/src/screens/Language.tsx +0 -97
  332. package/src/screens/ListContacts.tsx +0 -112
  333. package/src/screens/ListCredentials.tsx +0 -135
  334. package/src/screens/ListProofRequests.tsx +0 -148
  335. package/src/screens/MobileVerifierLoading.tsx +0 -106
  336. package/src/screens/NameWallet.tsx +0 -9
  337. package/src/screens/Onboarding.tsx +0 -162
  338. package/src/screens/OnboardingPages.tsx +0 -160
  339. package/src/screens/PINChange.tsx +0 -249
  340. package/src/screens/PINCreate.tsx +0 -185
  341. package/src/screens/PINEnter.tsx +0 -432
  342. package/src/screens/PINExplainer.tsx +0 -85
  343. package/src/screens/PINVerify.tsx +0 -195
  344. package/src/screens/PasteUrl.tsx +0 -140
  345. package/src/screens/Preface.tsx +0 -78
  346. package/src/screens/ProofChangeCredential.tsx +0 -179
  347. package/src/screens/ProofDetails.tsx +0 -348
  348. package/src/screens/ProofRequest.tsx +0 -999
  349. package/src/screens/ProofRequestAccept.tsx +0 -133
  350. package/src/screens/ProofRequestDetails.tsx +0 -270
  351. package/src/screens/ProofRequestUsageHistory.tsx +0 -152
  352. package/src/screens/ProofRequesting.tsx +0 -245
  353. package/src/screens/PushNotifications.tsx +0 -59
  354. package/src/screens/RenameContact.tsx +0 -155
  355. package/src/screens/RenameWallet.tsx +0 -26
  356. package/src/screens/Scan.tsx +0 -145
  357. package/src/screens/ScanHelp.tsx +0 -48
  358. package/src/screens/Settings.tsx +0 -415
  359. package/src/screens/Splash.tsx +0 -80
  360. package/src/screens/Terms.tsx +0 -127
  361. package/src/screens/ToggleBiometry.tsx +0 -153
  362. package/src/screens/TogglePushNotifications.tsx +0 -118
  363. package/src/screens/Tours.tsx +0 -93
  364. package/src/screens/UpdateAvailable.tsx +0 -119
  365. package/src/screens/WhatAreContacts.tsx +0 -71
  366. package/src/services/bifoldLogger.ts +0 -3
  367. package/src/services/keychain.ts +0 -184
  368. package/src/services/logger.ts +0 -89
  369. package/src/services/storage.ts +0 -136
  370. package/src/theme-builder.ts +0 -157
  371. package/src/theme.interface.ts +0 -580
  372. package/src/theme.ts +0 -1346
  373. package/src/types/attempt-lockout-config.ts +0 -8
  374. package/src/types/attestation.ts +0 -17
  375. package/src/types/chat.ts +0 -4
  376. package/src/types/config.ts +0 -64
  377. package/src/types/contact-details.ts +0 -5
  378. package/src/types/credential-list-footer.ts +0 -3
  379. package/src/types/credential-status.ts +0 -3
  380. package/src/types/credentials.ts +0 -7
  381. package/src/types/decline.ts +0 -5
  382. package/src/types/error.ts +0 -40
  383. package/src/types/fn.ts +0 -2
  384. package/src/types/genesis.ts +0 -35
  385. package/src/types/index.ts +0 -2
  386. package/src/types/metadata.ts +0 -16
  387. package/src/types/navigators.ts +0 -239
  388. package/src/types/notification.ts +0 -24
  389. package/src/types/permissions.ts +0 -2
  390. package/src/types/proof-items.ts +0 -32
  391. package/src/types/react-i18next.d.ts +0 -10
  392. package/src/types/remove.ts +0 -8
  393. package/src/types/security.ts +0 -32
  394. package/src/types/settings.ts +0 -28
  395. package/src/types/state.ts +0 -97
  396. package/src/types/tour.ts +0 -20
  397. package/src/types/version-check.ts +0 -18
  398. package/src/utils/PINValidation.ts +0 -98
  399. package/src/utils/agent.ts +0 -128
  400. package/src/utils/anonCredsProofRequestMapper.ts +0 -205
  401. package/src/utils/contacts.ts +0 -59
  402. package/src/utils/cred-def.ts +0 -33
  403. package/src/utils/credential.ts +0 -37
  404. package/src/utils/crypto.ts +0 -12
  405. package/src/utils/fileCache.ts +0 -152
  406. package/src/utils/helpers.ts +0 -1292
  407. package/src/utils/ledger.ts +0 -212
  408. package/src/utils/luminance.ts +0 -40
  409. package/src/utils/mediatorhelpers.ts +0 -71
  410. package/src/utils/migration.ts +0 -40
  411. package/src/utils/network.tsx +0 -55
  412. package/src/utils/oca.ts +0 -173
  413. package/src/utils/parsers.tsx +0 -111
  414. package/src/utils/proofBundle.ts +0 -220
  415. package/src/utils/schema.ts +0 -28
  416. 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