@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,123 +0,0 @@
1
- import { useNavigation } from '@react-navigation/native'
2
- import { StackNavigationProp } from '@react-navigation/stack'
3
- import React, { useState } from 'react'
4
- import { useTranslation } from 'react-i18next'
5
- import { StyleSheet, TouchableOpacity, View } from 'react-native'
6
- import Icon from 'react-native-vector-icons/MaterialCommunityIcons'
7
-
8
- import { hitSlop } from '../../constants'
9
- import { useTheme } from '../../contexts/theme'
10
- import { RootStackParams, Screens, Stacks } from '../../types/navigators'
11
- import PopupModal from '../modals/PopupModal'
12
- import Link from '../texts/Link'
13
-
14
- import { InfoBoxType } from './InfoBox'
15
- import UnorderedList from './UnorderedList'
16
- import { ThemedText } from '../texts/ThemedText'
17
-
18
- interface ConnectionAlertProps {
19
- connectionLabel?: string
20
- }
21
-
22
- const ConnectionAlert: React.FC<ConnectionAlertProps> = ({ connectionLabel }) => {
23
- const { t } = useTranslation()
24
- const { ColorPalette } = useTheme()
25
- const [infoCardVisible, setInfoCardVisible] = useState(false)
26
-
27
- const settingsNavigation = useNavigation<StackNavigationProp<RootStackParams>>()
28
-
29
- const styles = StyleSheet.create({
30
- modalCenter: {
31
- flex: 1,
32
- justifyContent: 'center',
33
- alignItems: 'center',
34
- backgroundColor: ColorPalette.notification.popupOverlay,
35
- padding: 20,
36
- },
37
- notifyTextContainer: {
38
- borderLeftColor: ColorPalette.brand.highlight,
39
- backgroundColor: ColorPalette.brand.secondaryBackground,
40
- borderLeftWidth: 10,
41
- flex: 1,
42
- paddingLeft: 10,
43
- paddingVertical: 15,
44
- marginVertical: 15,
45
- },
46
- row: {
47
- flexDirection: 'row',
48
- },
49
- notifyTitle: {
50
- marginBottom: 5,
51
- },
52
- notifyText: {
53
- marginVertical: 5,
54
- },
55
- notifyTextList: {
56
- marginVertical: 6,
57
- },
58
- informationIcon: {
59
- color: ColorPalette.notification.infoIcon,
60
- marginLeft: 10,
61
- },
62
- })
63
-
64
- const toggleInfoCard = () => setInfoCardVisible(!infoCardVisible)
65
-
66
- const navigateToSettings = () => {
67
- toggleInfoCard()
68
- settingsNavigation.navigate(Stacks.SettingStack, { screen: Screens.Settings })
69
- }
70
-
71
- return (
72
- <View style={styles.notifyTextContainer}>
73
- <View style={styles.row}>
74
- <ThemedText variant="title" style={styles.notifyTitle}>
75
- {t('ConnectionAlert.AddedContacts')}
76
- </ThemedText>
77
- <TouchableOpacity
78
- testID={t('Global.Info')}
79
- accessibilityLabel={t('ConnectionAlert.WhatAreContacts')}
80
- accessibilityRole={'button'}
81
- onPress={toggleInfoCard}
82
- hitSlop={hitSlop}
83
- >
84
- <Icon name={'information-outline'} size={30} style={styles.informationIcon} />
85
- </TouchableOpacity>
86
- </View>
87
- {infoCardVisible && (
88
- <PopupModal
89
- notificationType={InfoBoxType.Info}
90
- title={t('ConnectionAlert.WhatAreContacts')}
91
- bodyContent={
92
- <View>
93
- <ThemedText variant="popupModalText">{t('ConnectionAlert.PopupIntro')}</ThemedText>
94
- <UnorderedList
95
- unorderedListItems={[
96
- t('ConnectionAlert.PopupPoint1'),
97
- t('ConnectionAlert.PopupPoint2'),
98
- t('ConnectionAlert.PopupPoint3'),
99
- ]}
100
- />
101
- <ThemedText variant="popupModalText">{t('ConnectionAlert.SettingsInstruction')}</ThemedText>
102
- <Link
103
- style={{ marginBottom: 8 }}
104
- onPress={navigateToSettings}
105
- linkText={t('ConnectionAlert.SettingsLink')}
106
- />
107
- <ThemedText variant="popupModalText">{t('ConnectionAlert.PrivacyMessage')}</ThemedText>
108
- </View>
109
- }
110
- onCallToActionLabel={t('ConnectionAlert.PopupExit')}
111
- onCallToActionPressed={toggleInfoCard}
112
- />
113
- )}
114
- <ThemedText style={styles.notifyText}>
115
- {t('ConnectionAlert.NotificationBodyUpper') +
116
- (connectionLabel ?? t('ContactDetails.AContact').toLowerCase()) +
117
- t('ConnectionAlert.NotificationBodyLower')}
118
- </ThemedText>
119
- </View>
120
- )
121
- }
122
-
123
- export default ConnectionAlert
@@ -1,45 +0,0 @@
1
- import React from 'react'
2
- import { Image, StyleSheet, View } from 'react-native'
3
-
4
- import { useTheme } from '../../contexts/theme'
5
- import { toImageSource } from '../../utils/credential'
6
- import { useConnectionImageUrl } from '../../utils/helpers'
7
-
8
- interface ConnectionImageProps {
9
- connectionId?: string
10
- imageUri?: string
11
- marginTop?: number
12
- }
13
-
14
- const ConnectionImage: React.FC<ConnectionImageProps> = ({ connectionId, imageUri, marginTop }) => {
15
- const { ColorPalette } = useTheme()
16
- const styles = StyleSheet.create({
17
- connectionImageContainer: {
18
- backgroundColor: ColorPalette.brand.secondaryBackground,
19
- width: 90,
20
- height: 90,
21
- alignItems: 'center',
22
- justifyContent: 'center',
23
- borderRadius: 45,
24
- marginTop: marginTop ?? 15,
25
- borderColor: ColorPalette.grayscale.lightGrey,
26
- borderWidth: 3,
27
- alignSelf: 'center',
28
- },
29
- connectionImage: {
30
- width: 55,
31
- height: 55,
32
- },
33
- })
34
-
35
- const anonCredsImageUri = useConnectionImageUrl(connectionId ?? '')
36
- const connectionImage = imageUri ? imageUri : anonCredsImageUri
37
-
38
- return connectionImage ? (
39
- <View style={styles.connectionImageContainer}>
40
- <Image style={styles.connectionImage} source={toImageSource(connectionImage)} />
41
- </View>
42
- ) : null
43
- }
44
-
45
- export default ConnectionImage
@@ -1,40 +0,0 @@
1
- import React from 'react'
2
- import { View, StyleSheet } from 'react-native'
3
- import Svg, { Defs, Rect, LinearGradient, Stop } from 'react-native-svg'
4
-
5
- type ContentGradientProps = {
6
- backgroundColor: string
7
- height?: number
8
- }
9
-
10
- /**
11
- * To be used in a relative position controlsContainer that is below (and not in) scrollview content
12
- */
13
- const ContentGradient: React.FC<ContentGradientProps> = ({ backgroundColor, height = 30 }) => {
14
- const id = 'gradient'
15
-
16
- const styles = StyleSheet.create({
17
- container: {
18
- position: 'absolute',
19
- height,
20
- width: '100%',
21
- top: -height,
22
- },
23
- })
24
-
25
- return (
26
- <View style={styles.container}>
27
- <Svg height={`${height}`} width="100%" style={StyleSheet.absoluteFill}>
28
- <Defs>
29
- <LinearGradient id={id} x1="0%" y1="0%" x2="0%" y2="100%">
30
- <Stop offset="0%" stopColor={backgroundColor} stopOpacity={0} />
31
- <Stop offset="100%" stopColor={backgroundColor} stopOpacity={1} />
32
- </LinearGradient>
33
- </Defs>
34
- <Rect height={`${height}`} width="100%" fill={`url(#${id})`} />
35
- </Svg>
36
- </View>
37
- )
38
- }
39
-
40
- export default ContentGradient
@@ -1,161 +0,0 @@
1
- import { CredentialExchangeRecord, MdocRecord, SdJwtVcRecord, W3cCredentialRecord } from '@credo-ts/core'
2
- import { Attribute, BrandingOverlayType, CredentialOverlay, Predicate } from '@bifold/oca/build/legacy'
3
- import React, { useEffect, useState } from 'react'
4
- import { ViewStyle } from 'react-native'
5
-
6
- import { TOKENS, useServices } from '../../container-api'
7
- import { useTheme } from '../../contexts/theme'
8
- import { GenericFn } from '../../types/fn'
9
-
10
- import CredentialCard10 from './CredentialCard10'
11
- import CredentialCard11, { CredentialErrors } from './CredentialCard11'
12
- import { GenericCredentialExchangeRecord } from '../../types/credentials'
13
- import { BrandingOverlay } from '@bifold/oca'
14
- import { useOpenIDCredentials } from '../../modules/openid/context/OpenIDCredentialRecordProvider'
15
- import { getCredentialForDisplay } from '../../modules/openid/display'
16
- import { getAttributeField } from '../../utils/oca'
17
-
18
- interface CredentialCardProps {
19
- credential?: GenericCredentialExchangeRecord
20
- credDefId?: string
21
- schemaId?: string
22
- credName?: string
23
- onPress?: GenericFn
24
- style?: ViewStyle
25
- proof?: boolean
26
- displayItems?: (Attribute | Predicate)[]
27
- hasAltCredentials?: boolean
28
- credentialErrors?: CredentialErrors[]
29
- handleAltCredChange?: () => void
30
- brandingOverlay?: CredentialOverlay<BrandingOverlay>
31
- }
32
-
33
- const CredentialCard: React.FC<CredentialCardProps> = ({
34
- credential,
35
- credDefId,
36
- schemaId,
37
- proof,
38
- displayItems,
39
- credName,
40
- hasAltCredentials,
41
- handleAltCredChange,
42
- style = {},
43
- onPress = undefined,
44
- credentialErrors,
45
- brandingOverlay,
46
- }) => {
47
- // add ability to reference credential by ID, allows us to get past react hook restrictions
48
- const [bundleResolver] = useServices([TOKENS.UTIL_OCA_RESOLVER])
49
- const { ColorPalette } = useTheme()
50
- const [overlay, setOverlay] = useState<CredentialOverlay<BrandingOverlay>>({})
51
- const { resolveBundleForCredential } = useOpenIDCredentials()
52
- const [extraOverlayAttribute, setExtraOverlayAttribute] = useState<Attribute | undefined>()
53
-
54
- useEffect(() => {
55
- if (brandingOverlay) {
56
- setOverlay(brandingOverlay as unknown as CredentialOverlay<BrandingOverlay>)
57
- return
58
- }
59
-
60
- const resolveOverlay = async (w3cCred: W3cCredentialRecord | SdJwtVcRecord | MdocRecord) => {
61
- const brandingOverlay = await resolveBundleForCredential(w3cCred)
62
- setOverlay(brandingOverlay)
63
- }
64
-
65
- if (
66
- credential instanceof W3cCredentialRecord ||
67
- credential instanceof SdJwtVcRecord ||
68
- credential instanceof MdocRecord
69
- ) {
70
- resolveOverlay(credential)
71
- const credentialDisplay = getCredentialForDisplay(credential)
72
- if (credentialDisplay.display.primary_overlay_attribute) {
73
- const attributeValue = getAttributeField(
74
- credentialDisplay,
75
- credentialDisplay.display.primary_overlay_attribute
76
- )?.field
77
- setExtraOverlayAttribute(attributeValue)
78
- }
79
- }
80
- }, [credential, brandingOverlay, resolveBundleForCredential])
81
-
82
- const getCredOverlayType = (type: BrandingOverlayType) => {
83
- const isBranding10 = bundleResolver.getBrandingOverlayType() === BrandingOverlayType.Branding10
84
- if (proof) {
85
- return (
86
- <CredentialCard11
87
- displayItems={displayItems}
88
- style={isBranding10 ? { backgroundColor: ColorPalette.brand.secondaryBackground } : undefined}
89
- credName={credName}
90
- credDefId={credDefId}
91
- schemaId={schemaId}
92
- credential={credential as CredentialExchangeRecord}
93
- handleAltCredChange={handleAltCredChange}
94
- hasAltCredentials={hasAltCredentials}
95
- proof
96
- elevated
97
- credentialErrors={credentialErrors ?? []}
98
- brandingOverlayType={bundleResolver.getBrandingOverlayType()}
99
- />
100
- )
101
- }
102
-
103
- if (credential) {
104
- if (type === BrandingOverlayType.Branding01) {
105
- return <CredentialCard10 credential={credential as CredentialExchangeRecord} style={style} onPress={onPress} />
106
- } else {
107
- return (
108
- <CredentialCard11
109
- credential={credential as CredentialExchangeRecord}
110
- style={style}
111
- onPress={onPress}
112
- credentialErrors={credentialErrors ?? []}
113
- brandingOverlayType={bundleResolver.getBrandingOverlayType()}
114
- elevated={bundleResolver.getBrandingOverlayType() === BrandingOverlayType.Branding11}
115
- />
116
- )
117
- }
118
- } else {
119
- return (
120
- <CredentialCard11
121
- credDefId={credDefId}
122
- schemaId={schemaId}
123
- credName={credName}
124
- displayItems={displayItems}
125
- style={style}
126
- onPress={onPress}
127
- credentialErrors={credentialErrors ?? []}
128
- brandingOverlayType={bundleResolver.getBrandingOverlayType()}
129
- />
130
- )
131
- }
132
- }
133
-
134
- if (
135
- credential instanceof W3cCredentialRecord ||
136
- credential instanceof SdJwtVcRecord ||
137
- credential instanceof MdocRecord
138
- ) {
139
- return (
140
- <CredentialCard11
141
- credential={undefined}
142
- style={style}
143
- onPress={onPress}
144
- brandingOverlay={overlay}
145
- credentialErrors={credentialErrors ?? []}
146
- proof={proof}
147
- elevated={proof}
148
- displayItems={displayItems}
149
- hideSlice={true}
150
- hasAltCredentials={hasAltCredentials}
151
- handleAltCredChange={handleAltCredChange}
152
- extraOverlayParameter={extraOverlayAttribute}
153
- brandingOverlayType={bundleResolver.getBrandingOverlayType()}
154
- />
155
- )
156
- } else {
157
- return getCredOverlayType(bundleResolver.getBrandingOverlayType())
158
- }
159
- }
160
-
161
- export default CredentialCard
@@ -1,329 +0,0 @@
1
- import { CredentialExchangeRecord } from '@credo-ts/core'
2
- import { LegacyBrandingOverlay } from '@bifold/oca'
3
- import { CredentialOverlay } from '@bifold/oca/build/legacy'
4
- import React, { useEffect, useState } from 'react'
5
- import { useTranslation } from 'react-i18next'
6
- import {
7
- Image,
8
- ImageBackground,
9
- StyleSheet,
10
- Text,
11
- View,
12
- ViewStyle,
13
- useWindowDimensions,
14
- TouchableOpacity,
15
- } from 'react-native'
16
-
17
- import { TOKENS, useServices } from '../../container-api'
18
- import { useTheme } from '../../contexts/theme'
19
- import { GenericFn } from '../../types/fn'
20
- import {
21
- credentialTextColor,
22
- getCredentialIdentifiers,
23
- isValidAnonCredsCredential,
24
- toImageSource,
25
- } from '../../utils/credential'
26
- import { formatTime, useCredentialConnectionLabel } from '../../utils/helpers'
27
- import { buildFieldsFromAnonCredsCredential } from '../../utils/oca'
28
- import { testIdWithKey } from '../../utils/testable'
29
-
30
- import CardWatermark from './CardWatermark'
31
-
32
- interface CredentialCard10Props {
33
- credential: CredentialExchangeRecord
34
- onPress?: GenericFn
35
- style?: ViewStyle
36
- }
37
-
38
- const paddingVertical = 10
39
- const paddingHorizontal = 10
40
- const transparent = 'rgba(0,0,0,0)'
41
- const borderRadius = 15
42
- const borderPadding = 8
43
-
44
- /**
45
- * A card is defined as a 4x8 (height/rows x width/columns) grid.
46
- | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
47
- | 2 | | | | | | | |
48
- | 3 | | | | | | | |
49
- | 4 | | | | | | | |
50
-
51
- The card width is the full screen width, and the card height is half of the screen width
52
-
53
- Variation 1:
54
- Header: Small Logo (1x1) + Issuer Name (1x3) + Credential Name (1x4)
55
- Body: Reserved for Future Use (2x4)
56
- Footer: Issued or Expired Date (1x4)
57
-
58
- | L | Issuer | Cred Name |
59
- | Body |
60
- | Body |
61
- | Issued/Expired Date |
62
-
63
- Variation 2:
64
- Header: Large Logo (1x4) + Credential Name (1x4)
65
- Body: Reserved for Future Use (2x4)
66
- Footer: Issued or Expired Date (1x4)
67
-
68
- | Logo | Cred Name |
69
- | Body |
70
- | Body |
71
- | Issued/Expired Date |
72
-
73
-
74
- Note: The small logo MUST be provided as 1x1 (height/width) ratio, while the large logo MUST be provided as 1x4 (height/width) ratio
75
- */
76
-
77
- const CredentialCard10: React.FC<CredentialCard10Props> = ({ credential, style = {}, onPress = undefined }) => {
78
- const { width } = useWindowDimensions()
79
- const cardHeight = width / 2 // a card height is half of the screen width
80
- const cardHeaderHeight = cardHeight / 4 // a card has a total of 4 rows, and the header occupy 1 row
81
- const { t, i18n } = useTranslation()
82
- const { ColorPalette, TextTheme } = useTheme()
83
- const [overlay, setOverlay] = useState<CredentialOverlay<LegacyBrandingOverlay>>({})
84
- const [isRevoked, setIsRevoked] = useState<boolean>(false)
85
- const credentialConnectionLabel = useCredentialConnectionLabel(credential)
86
- const [bundleResolver] = useServices([TOKENS.UTIL_OCA_RESOLVER])
87
-
88
- const styles = StyleSheet.create({
89
- container: {
90
- backgroundColor: overlay?.brandingOverlay?.imageSource ? transparent : overlay?.brandingOverlay?.backgroundColor,
91
- height: cardHeight,
92
- borderRadius: borderRadius,
93
- },
94
- outerHeaderContainer: {
95
- flexDirection: 'column',
96
- backgroundColor: overlay?.brandingOverlay?.header?.backgroundColor ?? transparent,
97
- height: cardHeaderHeight + borderPadding,
98
- borderTopLeftRadius: borderRadius,
99
- borderTopRightRadius: borderRadius,
100
- },
101
- innerHeaderContainer: {
102
- flexDirection: 'row',
103
- height: cardHeaderHeight,
104
- marginLeft: borderPadding,
105
- marginRight: borderPadding,
106
- marginTop: borderPadding,
107
- marginBottom: borderPadding,
108
- backgroundColor: overlay?.brandingOverlay?.header?.backgroundColor ?? transparent,
109
- },
110
- bodyContainer: {
111
- flexGrow: 1,
112
- },
113
- footerContainer: {
114
- flexDirection: 'row',
115
- backgroundColor: overlay?.brandingOverlay?.footer?.backgroundColor ?? transparent,
116
- paddingHorizontal,
117
- paddingVertical,
118
- borderBottomLeftRadius: borderRadius,
119
- borderBottomRightRadius: borderRadius,
120
- },
121
- revokedFooter: {
122
- backgroundColor: ColorPalette.notification.error,
123
- flexGrow: 1,
124
- marginHorizontal: -1 * paddingHorizontal,
125
- marginVertical: -1 * paddingVertical,
126
- paddingHorizontal: paddingHorizontal,
127
- paddingVertical: paddingVertical,
128
- borderBottomLeftRadius: borderRadius,
129
- borderBottomRightRadius: borderRadius,
130
- },
131
- flexGrow: {
132
- flexGrow: 1,
133
- },
134
- watermark: {
135
- opacity: 0.16,
136
- fontSize: 22,
137
- transform: [{ rotate: '-30deg' }],
138
- },
139
- })
140
-
141
- useEffect(() => {
142
- if (!(credential && isValidAnonCredsCredential(credential))) {
143
- return
144
- }
145
-
146
- const params = {
147
- identifiers: getCredentialIdentifiers(credential),
148
- attributes: buildFieldsFromAnonCredsCredential(credential),
149
- meta: {
150
- credConnectionId: credential?.connectionId,
151
- alias: credentialConnectionLabel,
152
- },
153
- language: i18n.language,
154
- }
155
- bundleResolver.resolveAllBundles(params).then((bundle) => {
156
- setOverlay((o) => ({
157
- ...o,
158
- ...bundle,
159
- brandingOverlay: bundle.brandingOverlay as LegacyBrandingOverlay,
160
- }))
161
- })
162
- }, [credential, credentialConnectionLabel, i18n.language, bundleResolver])
163
-
164
- useEffect(() => {
165
- setIsRevoked(credential.revocationNotification !== undefined)
166
- }, [credential.revocationNotification])
167
-
168
- const CredentialCardHeader: React.FC = () => {
169
- return (
170
- <View style={styles.outerHeaderContainer}>
171
- <View testID={testIdWithKey('CredentialCardHeader')} style={styles.innerHeaderContainer}>
172
- {overlay?.brandingOverlay?.header?.imageSource && (
173
- <Image
174
- source={toImageSource(overlay?.brandingOverlay?.header?.imageSource)}
175
- style={{
176
- flex: !overlay?.brandingOverlay?.header?.hideIssuer ? 1 : 4,
177
- resizeMode: 'contain',
178
- maxHeight: styles.outerHeaderContainer.height - borderPadding,
179
- }}
180
- />
181
- )}
182
- {overlay?.brandingOverlay?.header?.hideIssuer ? null : (
183
- <Text
184
- numberOfLines={1}
185
- ellipsizeMode="tail"
186
- style={[
187
- TextTheme.label,
188
- {
189
- color:
190
- overlay?.brandingOverlay?.header?.color ??
191
- credentialTextColor(
192
- ColorPalette,
193
- overlay?.brandingOverlay?.header?.backgroundColor || overlay?.brandingOverlay?.backgroundColor
194
- ),
195
- paddingHorizontal: 0.5 * paddingHorizontal,
196
- flex: !overlay?.brandingOverlay?.header?.imageSource ? 4 : 3,
197
- textAlignVertical: 'center',
198
- },
199
- ]}
200
- testID={testIdWithKey('CredentialIssuer')}
201
- maxFontSizeMultiplier={1}
202
- >
203
- {overlay?.metaOverlay?.issuer}
204
- </Text>
205
- )}
206
- <Text
207
- numberOfLines={1}
208
- ellipsizeMode="tail"
209
- style={[
210
- TextTheme.label,
211
- {
212
- color:
213
- overlay?.brandingOverlay?.header?.color ??
214
- credentialTextColor(
215
- ColorPalette,
216
- overlay?.brandingOverlay?.header?.backgroundColor || overlay?.brandingOverlay?.backgroundColor
217
- ),
218
- textAlign: 'right',
219
- paddingHorizontal: 0.5 * paddingHorizontal,
220
- flex: 4,
221
- textAlignVertical: 'center',
222
- },
223
- ]}
224
- testID={testIdWithKey('CredentialName')}
225
- maxFontSizeMultiplier={1}
226
- >
227
- {overlay?.metaOverlay?.name}
228
- </Text>
229
- </View>
230
- </View>
231
- )
232
- }
233
-
234
- const CredentialCardBody: React.FC = () => {
235
- return <View style={styles.bodyContainer} testID={testIdWithKey('CredentialCardBody')}></View>
236
- }
237
-
238
- const CredentialCardFooter: React.FC<{ revoked: boolean }> = ({ revoked = false }) => {
239
- return (
240
- <View testID={testIdWithKey('CredentialCardFooter')} style={styles.footerContainer}>
241
- {revoked ? (
242
- <View style={styles.revokedFooter}>
243
- <Text
244
- style={[TextTheme.label, { color: ColorPalette.semantic.error }]}
245
- testID={testIdWithKey('CredentialRevoked')}
246
- >
247
- {t('CredentialDetails.Revoked')}
248
- </Text>
249
- </View>
250
- ) : (
251
- <Text
252
- style={[
253
- TextTheme.caption,
254
- {
255
- color:
256
- overlay?.brandingOverlay?.footer?.color ??
257
- credentialTextColor(
258
- ColorPalette,
259
- overlay?.brandingOverlay?.footer?.backgroundColor || overlay?.brandingOverlay?.backgroundColor
260
- ),
261
- },
262
- ]}
263
- testID={testIdWithKey('CredentialIssued')}
264
- maxFontSizeMultiplier={1}
265
- >
266
- {t('CredentialDetails.Issued')}: {formatTime(credential.createdAt, { shortMonth: true })}
267
- </Text>
268
- )}
269
- </View>
270
- )
271
- }
272
-
273
- const CredentialCard: React.FC<{ revoked?: boolean }> = ({ revoked = false }) => {
274
- return (
275
- <>
276
- <CredentialCardHeader />
277
- <CredentialCardBody />
278
- <CredentialCardFooter revoked={revoked} />
279
- </>
280
- )
281
- }
282
-
283
- return (
284
- <TouchableOpacity
285
- accessible={true}
286
- accessibilityLabel={`${
287
- overlay.metaOverlay?.issuer ? `${t('Credentials.IssuedBy')} ${overlay.metaOverlay?.issuer}` : ''
288
- }, ${overlay.metaOverlay?.watermark ?? ''} ${overlay.metaOverlay?.name ?? ''} ${t('Credentials.Credential')}.`}
289
- disabled={typeof onPress === 'undefined' ? true : false}
290
- onPress={onPress}
291
- style={[styles.container, style]}
292
- testID={testIdWithKey('ShowCredentialDetails')}
293
- >
294
- <View style={[styles.flexGrow, { overflow: 'hidden' }]} testID={testIdWithKey('CredentialCard')}>
295
- {overlay?.brandingOverlay?.imageSource ? (
296
- <ImageBackground
297
- source={toImageSource(overlay?.brandingOverlay?.imageSource)}
298
- style={styles.flexGrow}
299
- imageStyle={{ borderRadius }}
300
- >
301
- {overlay.metaOverlay?.watermark && (
302
- <CardWatermark
303
- width={width}
304
- height={cardHeight}
305
- style={styles.watermark}
306
- watermark={overlay.metaOverlay?.watermark}
307
- />
308
- )}
309
- <CredentialCard revoked={isRevoked} />
310
- </ImageBackground>
311
- ) : (
312
- <>
313
- {overlay.metaOverlay?.watermark && (
314
- <CardWatermark
315
- width={width}
316
- height={cardHeight}
317
- style={styles.watermark}
318
- watermark={overlay.metaOverlay?.watermark}
319
- />
320
- )}
321
- <CredentialCard revoked={isRevoked} />
322
- </>
323
- )}
324
- </View>
325
- </TouchableOpacity>
326
- )
327
- }
328
-
329
- export default CredentialCard10