@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,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