@bifold/core 2.4.6 → 2.6.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 (461) hide show
  1. package/lib/commonjs/components/listItems/ContactCredentialListItem.js +9 -8
  2. package/lib/commonjs/components/listItems/ContactCredentialListItem.js.map +1 -1
  3. package/lib/commonjs/components/misc/CredentialCard11Logo.js +8 -7
  4. package/lib/commonjs/components/misc/CredentialCard11Logo.js.map +1 -1
  5. package/lib/commonjs/components/misc/PINHeader.js +5 -3
  6. package/lib/commonjs/components/misc/PINHeader.js.map +1 -1
  7. package/lib/commonjs/contexts/network.js +10 -9
  8. package/lib/commonjs/contexts/network.js.map +1 -1
  9. package/lib/commonjs/contexts/reducers/store.js +3 -2
  10. package/lib/commonjs/contexts/reducers/store.js.map +1 -1
  11. package/lib/commonjs/contexts/theme.js +7 -6
  12. package/lib/commonjs/contexts/theme.js.map +1 -1
  13. package/lib/commonjs/index.js +127 -104
  14. package/lib/commonjs/index.js.map +1 -1
  15. package/lib/commonjs/modules/openid/components/CredentialRowCard.js +9 -7
  16. package/lib/commonjs/modules/openid/components/CredentialRowCard.js.map +1 -1
  17. package/lib/commonjs/modules/openid/context/OpenIDCredentialRecordProvider.js +9 -8
  18. package/lib/commonjs/modules/openid/context/OpenIDCredentialRecordProvider.js.map +1 -1
  19. package/lib/commonjs/screens/AttemptLockout.js +27 -35
  20. package/lib/commonjs/screens/AttemptLockout.js.map +1 -1
  21. package/lib/commonjs/screens/ConfigureMediator.js +22 -21
  22. package/lib/commonjs/screens/ConfigureMediator.js.map +1 -1
  23. package/lib/commonjs/screens/JSONDetails.js +16 -15
  24. package/lib/commonjs/screens/JSONDetails.js.map +1 -1
  25. package/lib/commonjs/screens/MobileVerifierLoading.js +4 -3
  26. package/lib/commonjs/screens/MobileVerifierLoading.js.map +1 -1
  27. package/lib/commonjs/screens/PINCreate.js +3 -10
  28. package/lib/commonjs/screens/PINCreate.js.map +1 -1
  29. package/lib/commonjs/screens/WhatAreContacts.js +3 -2
  30. package/lib/commonjs/screens/WhatAreContacts.js.map +1 -1
  31. package/lib/commonjs/services/logger.js +35 -27
  32. package/lib/commonjs/services/logger.js.map +1 -1
  33. package/lib/module/components/listItems/ContactCredentialListItem.js +3 -3
  34. package/lib/module/components/listItems/ContactCredentialListItem.js.map +1 -1
  35. package/lib/module/components/misc/CredentialCard11Logo.js +5 -4
  36. package/lib/module/components/misc/CredentialCard11Logo.js.map +1 -1
  37. package/lib/module/components/misc/PINHeader.js +2 -1
  38. package/lib/module/components/misc/PINHeader.js.map +1 -1
  39. package/lib/module/contexts/network.js +3 -3
  40. package/lib/module/contexts/network.js.map +1 -1
  41. package/lib/module/contexts/reducers/store.js +3 -2
  42. package/lib/module/contexts/reducers/store.js.map +1 -1
  43. package/lib/module/contexts/theme.js +2 -2
  44. package/lib/module/contexts/theme.js.map +1 -1
  45. package/lib/module/index.js +43 -45
  46. package/lib/module/index.js.map +1 -1
  47. package/lib/module/modules/openid/components/CredentialRowCard.js +2 -1
  48. package/lib/module/modules/openid/components/CredentialRowCard.js.map +1 -1
  49. package/lib/module/modules/openid/context/OpenIDCredentialRecordProvider.js +5 -5
  50. package/lib/module/modules/openid/context/OpenIDCredentialRecordProvider.js.map +1 -1
  51. package/lib/module/screens/AttemptLockout.js +28 -36
  52. package/lib/module/screens/AttemptLockout.js.map +1 -1
  53. package/lib/module/screens/ConfigureMediator.js +10 -10
  54. package/lib/module/screens/ConfigureMediator.js.map +1 -1
  55. package/lib/module/screens/JSONDetails.js +9 -8
  56. package/lib/module/screens/JSONDetails.js.map +1 -1
  57. package/lib/module/screens/MobileVerifierLoading.js +4 -3
  58. package/lib/module/screens/MobileVerifierLoading.js.map +1 -1
  59. package/lib/module/screens/PINCreate.js +3 -10
  60. package/lib/module/screens/PINCreate.js.map +1 -1
  61. package/lib/module/screens/WhatAreContacts.js +3 -2
  62. package/lib/module/screens/WhatAreContacts.js.map +1 -1
  63. package/lib/module/services/logger.js +37 -28
  64. package/lib/module/services/logger.js.map +1 -1
  65. package/lib/typescript/src/components/listItems/ContactCredentialListItem.d.ts +2 -1
  66. package/lib/typescript/src/components/listItems/ContactCredentialListItem.d.ts.map +1 -1
  67. package/lib/typescript/src/components/misc/CredentialCard11Logo.d.ts +1 -0
  68. package/lib/typescript/src/components/misc/CredentialCard11Logo.d.ts.map +1 -1
  69. package/lib/typescript/src/components/misc/PINHeader.d.ts +2 -1
  70. package/lib/typescript/src/components/misc/PINHeader.d.ts.map +1 -1
  71. package/lib/typescript/src/contexts/network.d.ts +3 -3
  72. package/lib/typescript/src/contexts/network.d.ts.map +1 -1
  73. package/lib/typescript/src/contexts/reducers/store.d.ts.map +1 -1
  74. package/lib/typescript/src/contexts/theme.d.ts +2 -1
  75. package/lib/typescript/src/contexts/theme.d.ts.map +1 -1
  76. package/lib/typescript/src/index.d.ts +58 -61
  77. package/lib/typescript/src/index.d.ts.map +1 -1
  78. package/lib/typescript/src/modules/openid/components/CredentialRowCard.d.ts +2 -1
  79. package/lib/typescript/src/modules/openid/components/CredentialRowCard.d.ts.map +1 -1
  80. package/lib/typescript/src/modules/openid/context/OpenIDCredentialRecordProvider.d.ts +3 -3
  81. package/lib/typescript/src/modules/openid/context/OpenIDCredentialRecordProvider.d.ts.map +1 -1
  82. package/lib/typescript/src/screens/AttemptLockout.d.ts.map +1 -1
  83. package/lib/typescript/src/screens/ConfigureMediator.d.ts +2 -1
  84. package/lib/typescript/src/screens/ConfigureMediator.d.ts.map +1 -1
  85. package/lib/typescript/src/screens/JSONDetails.d.ts +2 -1
  86. package/lib/typescript/src/screens/JSONDetails.d.ts.map +1 -1
  87. package/lib/typescript/src/screens/MobileVerifierLoading.d.ts.map +1 -1
  88. package/lib/typescript/src/screens/PINCreate.d.ts.map +1 -1
  89. package/lib/typescript/src/screens/WhatAreContacts.d.ts.map +1 -1
  90. package/lib/typescript/src/services/logger.d.ts +7 -8
  91. package/lib/typescript/src/services/logger.d.ts.map +1 -1
  92. package/package.json +5 -6
  93. package/src/App.tsx +0 -79
  94. package/src/animated-components.ts +0 -30
  95. package/src/assets/fonts/MaterialIcons.ttf +0 -0
  96. package/src/assets/icons/code.svg +0 -4
  97. package/src/assets/icons/large-arrow.svg +0 -5
  98. package/src/assets/icons/pencil.svg +0 -15
  99. package/src/assets/icons/trash.svg +0 -31
  100. package/src/assets/img/Artwork_1024x1024.png +0 -0
  101. package/src/assets/img/HistoryCardAcceptedIcon.svg +0 -4
  102. package/src/assets/img/HistoryCardExpiredIcon.svg +0 -4
  103. package/src/assets/img/HistoryCardRevokedIcon.svg +0 -4
  104. package/src/assets/img/HistoryInformationSentIcon.svg +0 -4
  105. package/src/assets/img/HistoryPinUpdatedIcon.svg +0 -4
  106. package/src/assets/img/IconChevronRight.svg +0 -5
  107. package/src/assets/img/activity-indicator-circle.svg +0 -90
  108. package/src/assets/img/app-lockout.svg +0 -1
  109. package/src/assets/img/biometrics.svg +0 -74
  110. package/src/assets/img/chat-loading.svg +0 -1
  111. package/src/assets/img/check-in-circle.svg +0 -18
  112. package/src/assets/img/connection-pending.svg +0 -112
  113. package/src/assets/img/contact-book.svg +0 -21
  114. package/src/assets/img/credential-card.svg +0 -18
  115. package/src/assets/img/credential-declined.svg +0 -28
  116. package/src/assets/img/credential-in-hand.svg +0 -48
  117. package/src/assets/img/credential-list.svg +0 -60
  118. package/src/assets/img/credential-pending.svg +0 -96
  119. package/src/assets/img/credential-success.svg +0 -48
  120. package/src/assets/img/delete-notification.svg +0 -1
  121. package/src/assets/img/empty-wallet.svg +0 -23
  122. package/src/assets/img/error-filled.svg +0 -12
  123. package/src/assets/img/exclamation-mark.svg +0 -17
  124. package/src/assets/img/home-center-img.svg +0 -71
  125. package/src/assets/img/icon-credential-offer-dark.svg +0 -7
  126. package/src/assets/img/icon-credential-offer-light.svg +0 -7
  127. package/src/assets/img/icon-info-recieved-dark.svg +0 -8
  128. package/src/assets/img/icon-info-recieved-light.svg +0 -8
  129. package/src/assets/img/icon-info-sent-dark.svg +0 -8
  130. package/src/assets/img/icon-info-sent-light.svg +0 -8
  131. package/src/assets/img/icon-proof-request-dark.svg +0 -11
  132. package/src/assets/img/icon-proof-request-light.svg +0 -11
  133. package/src/assets/img/information-received.svg +0 -1
  134. package/src/assets/img/logo-large.png +0 -0
  135. package/src/assets/img/logo-large@2x.png +0 -0
  136. package/src/assets/img/logo-large@3x.png +0 -0
  137. package/src/assets/img/logo.svg +0 -15
  138. package/src/assets/img/message-text-icon-outline.svg +0 -1
  139. package/src/assets/img/message-text-icon.svg +0 -1
  140. package/src/assets/img/no_information_shared.svg +0 -36
  141. package/src/assets/img/preface.svg +0 -15
  142. package/src/assets/img/proof-declined.svg +0 -66
  143. package/src/assets/img/proof-pending.svg +0 -61
  144. package/src/assets/img/proof-success.svg +0 -72
  145. package/src/assets/img/push-notifications.svg +0 -1
  146. package/src/assets/img/qrcode-scan-icon.svg +0 -1
  147. package/src/assets/img/scan-share.svg +0 -102
  148. package/src/assets/img/secure-check.svg +0 -4
  149. package/src/assets/img/secure-image.svg +0 -64
  150. package/src/assets/img/update-available.svg +0 -26
  151. package/src/assets/img/verifier-request-declined.svg +0 -34
  152. package/src/assets/img/wallet-back.svg +0 -20
  153. package/src/assets/img/wallet-front.svg +0 -32
  154. package/src/assets/img/wallet-icon-outline.svg +0 -1
  155. package/src/assets/img/wallet-icon.svg +0 -1
  156. package/src/assets/img/wallet.svg +0 -43
  157. package/src/assets/oca-bundles.json +0 -174
  158. package/src/components/animated/ButtonLoading.tsx +0 -32
  159. package/src/components/animated/ConnectionLoading.tsx +0 -53
  160. package/src/components/animated/CredentialAdded.tsx +0 -72
  161. package/src/components/animated/CredentialPending.tsx +0 -63
  162. package/src/components/animated/LoadingIndicator.tsx +0 -49
  163. package/src/components/animated/PresentationLoading.tsx +0 -52
  164. package/src/components/animated/RecordLoading.tsx +0 -75
  165. package/src/components/animated/SendingProof.tsx +0 -53
  166. package/src/components/animated/SentProof.tsx +0 -72
  167. package/src/components/buttons/Button-api.tsx +0 -46
  168. package/src/components/buttons/Button.tsx +0 -125
  169. package/src/components/buttons/HeaderHome.tsx +0 -25
  170. package/src/components/buttons/IconButton.tsx +0 -93
  171. package/src/components/buttons/InfoIcon.tsx +0 -35
  172. package/src/components/buttons/SettingsMenu.tsx +0 -26
  173. package/src/components/buttons/ToggleButton.tsx +0 -93
  174. package/src/components/buttons/index.ts +0 -4
  175. package/src/components/chat/ActionSlider.tsx +0 -104
  176. package/src/components/chat/ChatActions.tsx +0 -33
  177. package/src/components/chat/ChatBubble.tsx +0 -20
  178. package/src/components/chat/ChatEvent.tsx +0 -31
  179. package/src/components/chat/ChatMessage.tsx +0 -142
  180. package/src/components/chat/MessageInput.tsx +0 -46
  181. package/src/components/chat/index.ts +0 -4
  182. package/src/components/forms/WalletNameForm.tsx +0 -148
  183. package/src/components/index.ts +0 -4
  184. package/src/components/inputs/BiometryControl.tsx +0 -190
  185. package/src/components/inputs/BulletPoint.tsx +0 -32
  186. package/src/components/inputs/CheckBoxRow.tsx +0 -67
  187. package/src/components/inputs/InlineErrorText.tsx +0 -60
  188. package/src/components/inputs/LimitedTextInput.tsx +0 -71
  189. package/src/components/inputs/PINInput.tsx +0 -175
  190. package/src/components/inputs/SingleSelectBlock.tsx +0 -53
  191. package/src/components/listItems/ContactCredentialListItem.tsx +0 -79
  192. package/src/components/listItems/ContactListItem.tsx +0 -121
  193. package/src/components/listItems/NotificationListItem.tsx +0 -514
  194. package/src/components/misc/AvatarView.tsx +0 -33
  195. package/src/components/misc/CardWatermark.tsx +0 -52
  196. package/src/components/misc/ConnectionAlert.tsx +0 -123
  197. package/src/components/misc/ConnectionImage.tsx +0 -45
  198. package/src/components/misc/ContentGradient.tsx +0 -40
  199. package/src/components/misc/CredentialCard.tsx +0 -161
  200. package/src/components/misc/CredentialCard10.tsx +0 -329
  201. package/src/components/misc/CredentialCard11.tsx +0 -701
  202. package/src/components/misc/CredentialCard11ActionFooter.tsx +0 -55
  203. package/src/components/misc/CredentialCard11Issuer.tsx +0 -74
  204. package/src/components/misc/CredentialCard11Logo.tsx +0 -61
  205. package/src/components/misc/EmptyList.tsx +0 -27
  206. package/src/components/misc/EmptyListContacts.tsx +0 -55
  207. package/src/components/misc/ErrorBoundary.tsx +0 -200
  208. package/src/components/misc/FauxHeader.tsx +0 -75
  209. package/src/components/misc/InfoBox.tsx +0 -283
  210. package/src/components/misc/NoNewUpdates.tsx +0 -38
  211. package/src/components/misc/PINHeader.tsx +0 -25
  212. package/src/components/misc/PINValidationHelper.tsx +0 -48
  213. package/src/components/misc/Pagination.tsx +0 -114
  214. package/src/components/misc/QRRenderer.tsx +0 -53
  215. package/src/components/misc/QRScanner.tsx +0 -395
  216. package/src/components/misc/QRScannerTorch.tsx +0 -74
  217. package/src/components/misc/ScanCamera.tsx +0 -86
  218. package/src/components/misc/ScanTab.tsx +0 -45
  219. package/src/components/misc/SharedProofData.tsx +0 -98
  220. package/src/components/misc/UnorderedList.tsx +0 -28
  221. package/src/components/misc/VerifierCredentialCard.tsx +0 -378
  222. package/src/components/misc/index.ts +0 -2
  223. package/src/components/modals/AlertModal.tsx +0 -42
  224. package/src/components/modals/AppGuideModal.tsx +0 -142
  225. package/src/components/modals/CameraDisclosureModal.tsx +0 -126
  226. package/src/components/modals/CommonRemoveModal.tsx +0 -337
  227. package/src/components/modals/DeveloperModal.tsx +0 -32
  228. package/src/components/modals/DismissiblePopupModal.tsx +0 -169
  229. package/src/components/modals/ErrorModal.tsx +0 -107
  230. package/src/components/modals/ImageModal.tsx +0 -80
  231. package/src/components/modals/NetInfoModal.tsx +0 -35
  232. package/src/components/modals/PopupModal.tsx +0 -56
  233. package/src/components/modals/ProofCancelModal.tsx +0 -79
  234. package/src/components/modals/SafeAreaModal.tsx +0 -17
  235. package/src/components/record/Record.tsx +0 -100
  236. package/src/components/record/RecordBinaryField.tsx +0 -55
  237. package/src/components/record/RecordDateIntField.tsx +0 -63
  238. package/src/components/record/RecordField.tsx +0 -154
  239. package/src/components/record/RecordFooter.tsx +0 -17
  240. package/src/components/record/RecordHeader.tsx +0 -17
  241. package/src/components/record/RecordRemove.tsx +0 -66
  242. package/src/components/texts/HeaderTitle.tsx +0 -25
  243. package/src/components/texts/HighlightTextBox.tsx +0 -41
  244. package/src/components/texts/InfoTextBox.tsx +0 -129
  245. package/src/components/texts/Link.tsx +0 -41
  246. package/src/components/texts/Text.tsx +0 -21
  247. package/src/components/texts/ThemedText.tsx +0 -24
  248. package/src/components/toast/BaseToast.tsx +0 -128
  249. package/src/components/toast/ToastConfig.tsx +0 -21
  250. package/src/components/tour/AttachTourStep.tsx +0 -73
  251. package/src/components/tour/CredentialOfferTourSteps.tsx +0 -41
  252. package/src/components/tour/CredentialsTourSteps.tsx +0 -41
  253. package/src/components/tour/HomeTourSteps.tsx +0 -104
  254. package/src/components/tour/ProofRequestTourSteps.tsx +0 -41
  255. package/src/components/tour/SpotCutout.tsx +0 -65
  256. package/src/components/tour/TourBox.tsx +0 -255
  257. package/src/components/tour/TourOverlay.tsx +0 -134
  258. package/src/components/views/Banner.tsx +0 -181
  259. package/src/components/views/CredentialCardLogo.tsx +0 -77
  260. package/src/components/views/CredentialDetailPrimaryHeader.tsx +0 -107
  261. package/src/components/views/CredentialDetailSecondaryHeader.tsx +0 -60
  262. package/src/components/views/HeaderWithBanner.tsx +0 -17
  263. package/src/components/views/HomeFooterView.tsx +0 -110
  264. package/src/components/views/HomeHeaderView.tsx +0 -12
  265. package/src/components/views/KeyboardView.tsx +0 -41
  266. package/src/components/views/LoadingPlaceholder.tsx +0 -168
  267. package/src/components/views/LoadingView.tsx +0 -29
  268. package/src/components/views/ProgressBar.tsx +0 -53
  269. package/src/components/views/PushNotificationsContent.tsx +0 -51
  270. package/src/components/views/PushNotificationsDisabledContent.tsx +0 -47
  271. package/src/configs/ledgers/indy/index.ts +0 -8
  272. package/src/configs/ledgers/indy/ledgers.json +0 -51
  273. package/src/constants.ts +0 -107
  274. package/src/container-api.ts +0 -247
  275. package/src/container-impl.ts +0 -243
  276. package/src/contexts/activity.tsx +0 -145
  277. package/src/contexts/animated-components.ts +0 -9
  278. package/src/contexts/auth.tsx +0 -240
  279. package/src/contexts/index.ts +0 -3
  280. package/src/contexts/navigation.tsx +0 -19
  281. package/src/contexts/network.tsx +0 -125
  282. package/src/contexts/reducers/index.ts +0 -3
  283. package/src/contexts/reducers/store.ts +0 -754
  284. package/src/contexts/store.tsx +0 -103
  285. package/src/contexts/theme.tsx +0 -51
  286. package/src/contexts/tour/tour-context.tsx +0 -160
  287. package/src/contexts/tour/tour-provider.tsx +0 -160
  288. package/src/hooks/bundle-resolver.ts +0 -95
  289. package/src/hooks/chat-messages.tsx +0 -263
  290. package/src/hooks/connections.ts +0 -37
  291. package/src/hooks/credential-card-styles.ts +0 -144
  292. package/src/hooks/credentials.ts +0 -11
  293. package/src/hooks/deep-links.ts +0 -49
  294. package/src/hooks/developer-mode.ts +0 -25
  295. package/src/hooks/lockout.ts +0 -77
  296. package/src/hooks/notifications.ts +0 -108
  297. package/src/hooks/oob.ts +0 -17
  298. package/src/hooks/proof-request-templates.ts +0 -40
  299. package/src/hooks/proofs.ts +0 -32
  300. package/src/hooks/screen-capture.ts +0 -52
  301. package/src/hooks/useBifoldAgentSetup.ts +0 -169
  302. package/src/hooks/useOnboardingState.ts +0 -53
  303. package/src/hooks/usePINValidation.ts +0 -98
  304. package/src/index.ts +0 -239
  305. package/src/layout/ScreenLayout.tsx +0 -53
  306. package/src/localization/en/en.json +0 -951
  307. package/src/localization/en/index.ts +0 -3
  308. package/src/localization/fr/fr.json +0 -933
  309. package/src/localization/fr/index.ts +0 -3
  310. package/src/localization/index.ts +0 -66
  311. package/src/localization/pt-br/index.ts +0 -3
  312. package/src/localization/pt-br/pt-br.json +0 -911
  313. package/src/modules/history/context/historyManager.tsx +0 -247
  314. package/src/modules/history/index.ts +0 -2
  315. package/src/modules/history/navigation/HistoryStack.tsx +0 -29
  316. package/src/modules/history/services/queue.service.tsx +0 -31
  317. package/src/modules/history/types/index.ts +0 -92
  318. package/src/modules/history/ui/HistoryPage.tsx +0 -133
  319. package/src/modules/history/ui/HistorySettings.tsx +0 -183
  320. package/src/modules/history/ui/assets/img/HistoryCardAcceptedIcon.svg +0 -4
  321. package/src/modules/history/ui/assets/img/HistoryCardExpiredIcon.svg +0 -4
  322. package/src/modules/history/ui/assets/img/HistoryCardRevokedIcon.svg +0 -4
  323. package/src/modules/history/ui/assets/img/HistoryInformationSentIcon.svg +0 -4
  324. package/src/modules/history/ui/assets/img/HistoryPinUpdatedIcon.svg +0 -4
  325. package/src/modules/history/ui/assets/img/IconChevronRight.svg +0 -3
  326. package/src/modules/history/ui/components/BulletPoint.tsx +0 -49
  327. package/src/modules/history/ui/components/HistoryListItem.tsx +0 -251
  328. package/src/modules/history/ui/components/HistoryMenu.tsx +0 -25
  329. package/src/modules/history/ui/components/SingleSelectBlock.tsx +0 -72
  330. package/src/modules/openid/components/CredentialRowCard.tsx +0 -64
  331. package/src/modules/openid/components/OpenIDCredentialCard.tsx +0 -276
  332. package/src/modules/openid/context/OpenIDCredentialRecordProvider.tsx +0 -296
  333. package/src/modules/openid/display.tsx +0 -467
  334. package/src/modules/openid/displayProof.tsx +0 -86
  335. package/src/modules/openid/hooks/openid.tsx +0 -111
  336. package/src/modules/openid/metadata.tsx +0 -59
  337. package/src/modules/openid/offerResolve.tsx +0 -281
  338. package/src/modules/openid/resolverProof.tsx +0 -286
  339. package/src/modules/openid/screens/OpenIDCredentialDetails.tsx +0 -214
  340. package/src/modules/openid/screens/OpenIDCredentialOffer.tsx +0 -192
  341. package/src/modules/openid/screens/OpenIDProofChangeCredential.tsx +0 -133
  342. package/src/modules/openid/screens/OpenIDProofPresentation.tsx +0 -423
  343. package/src/modules/openid/types.tsx +0 -111
  344. package/src/modules/openid/utils/utils.tsx +0 -119
  345. package/src/navigators/ConnectStack.tsx +0 -68
  346. package/src/navigators/ContactStack.tsx +0 -91
  347. package/src/navigators/CredentialStack.tsx +0 -48
  348. package/src/navigators/DeliveryStack.tsx +0 -76
  349. package/src/navigators/HomeStack.tsx +0 -37
  350. package/src/navigators/MainStack.tsx +0 -146
  351. package/src/navigators/NotificationStack.tsx +0 -56
  352. package/src/navigators/OnboardingScreens.ts +0 -142
  353. package/src/navigators/OnboardingStack.tsx +0 -205
  354. package/src/navigators/ProofRequestStack.tsx +0 -113
  355. package/src/navigators/RootStack.tsx +0 -71
  356. package/src/navigators/SettingStack.tsx +0 -174
  357. package/src/navigators/TabStack.tsx +0 -304
  358. package/src/navigators/defaultLayoutOptions.tsx +0 -17
  359. package/src/navigators/defaultStackOptions.tsx +0 -102
  360. package/src/navigators/index.ts +0 -27
  361. package/src/onboarding.ts +0 -90
  362. package/src/screens/AttemptLockout.tsx +0 -153
  363. package/src/screens/AutoLock.tsx +0 -140
  364. package/src/screens/Biometry.tsx +0 -54
  365. package/src/screens/Chat.tsx +0 -141
  366. package/src/screens/ConfigureMediator.tsx +0 -160
  367. package/src/screens/Connection.tsx +0 -394
  368. package/src/screens/ContactDetails.tsx +0 -350
  369. package/src/screens/CredentialDetails.tsx +0 -473
  370. package/src/screens/CredentialOffer.tsx +0 -334
  371. package/src/screens/CredentialOfferAccept.tsx +0 -189
  372. package/src/screens/DataRetention.tsx +0 -91
  373. package/src/screens/Developer.tsx +0 -289
  374. package/src/screens/Home.tsx +0 -173
  375. package/src/screens/JSONDetails.tsx +0 -104
  376. package/src/screens/Language.tsx +0 -97
  377. package/src/screens/ListContacts.tsx +0 -112
  378. package/src/screens/ListCredentials.tsx +0 -135
  379. package/src/screens/ListProofRequests.tsx +0 -148
  380. package/src/screens/MobileVerifierLoading.tsx +0 -106
  381. package/src/screens/NameWallet.tsx +0 -9
  382. package/src/screens/Onboarding.tsx +0 -162
  383. package/src/screens/OnboardingPages.tsx +0 -160
  384. package/src/screens/PINChange.tsx +0 -249
  385. package/src/screens/PINCreate.tsx +0 -185
  386. package/src/screens/PINEnter.tsx +0 -432
  387. package/src/screens/PINExplainer.tsx +0 -85
  388. package/src/screens/PINVerify.tsx +0 -195
  389. package/src/screens/PasteUrl.tsx +0 -140
  390. package/src/screens/Preface.tsx +0 -78
  391. package/src/screens/ProofChangeCredential.tsx +0 -179
  392. package/src/screens/ProofDetails.tsx +0 -348
  393. package/src/screens/ProofRequest.tsx +0 -999
  394. package/src/screens/ProofRequestAccept.tsx +0 -133
  395. package/src/screens/ProofRequestDetails.tsx +0 -270
  396. package/src/screens/ProofRequestUsageHistory.tsx +0 -152
  397. package/src/screens/ProofRequesting.tsx +0 -245
  398. package/src/screens/PushNotifications.tsx +0 -59
  399. package/src/screens/RenameContact.tsx +0 -155
  400. package/src/screens/RenameWallet.tsx +0 -26
  401. package/src/screens/Scan.tsx +0 -145
  402. package/src/screens/ScanHelp.tsx +0 -48
  403. package/src/screens/Settings.tsx +0 -415
  404. package/src/screens/Splash.tsx +0 -80
  405. package/src/screens/Terms.tsx +0 -127
  406. package/src/screens/ToggleBiometry.tsx +0 -153
  407. package/src/screens/TogglePushNotifications.tsx +0 -118
  408. package/src/screens/Tours.tsx +0 -93
  409. package/src/screens/UpdateAvailable.tsx +0 -119
  410. package/src/screens/WhatAreContacts.tsx +0 -71
  411. package/src/services/bifoldLogger.ts +0 -3
  412. package/src/services/keychain.ts +0 -184
  413. package/src/services/logger.ts +0 -89
  414. package/src/services/storage.ts +0 -136
  415. package/src/theme-builder.ts +0 -157
  416. package/src/theme.interface.ts +0 -580
  417. package/src/theme.ts +0 -1346
  418. package/src/types/attempt-lockout-config.ts +0 -8
  419. package/src/types/attestation.ts +0 -17
  420. package/src/types/chat.ts +0 -4
  421. package/src/types/config.ts +0 -64
  422. package/src/types/contact-details.ts +0 -5
  423. package/src/types/credential-list-footer.ts +0 -3
  424. package/src/types/credential-status.ts +0 -3
  425. package/src/types/credentials.ts +0 -7
  426. package/src/types/decline.ts +0 -5
  427. package/src/types/error.ts +0 -40
  428. package/src/types/fn.ts +0 -2
  429. package/src/types/genesis.ts +0 -35
  430. package/src/types/index.ts +0 -2
  431. package/src/types/metadata.ts +0 -16
  432. package/src/types/navigators.ts +0 -239
  433. package/src/types/notification.ts +0 -24
  434. package/src/types/permissions.ts +0 -2
  435. package/src/types/proof-items.ts +0 -32
  436. package/src/types/react-i18next.d.ts +0 -10
  437. package/src/types/remove.ts +0 -8
  438. package/src/types/security.ts +0 -32
  439. package/src/types/settings.ts +0 -28
  440. package/src/types/state.ts +0 -97
  441. package/src/types/tour.ts +0 -20
  442. package/src/types/version-check.ts +0 -18
  443. package/src/utils/PINValidation.ts +0 -98
  444. package/src/utils/agent.ts +0 -128
  445. package/src/utils/anonCredsProofRequestMapper.ts +0 -205
  446. package/src/utils/contacts.ts +0 -59
  447. package/src/utils/cred-def.ts +0 -33
  448. package/src/utils/credential.ts +0 -37
  449. package/src/utils/crypto.ts +0 -12
  450. package/src/utils/fileCache.ts +0 -152
  451. package/src/utils/helpers.ts +0 -1292
  452. package/src/utils/ledger.ts +0 -212
  453. package/src/utils/luminance.ts +0 -40
  454. package/src/utils/mediatorhelpers.ts +0 -71
  455. package/src/utils/migration.ts +0 -40
  456. package/src/utils/network.tsx +0 -55
  457. package/src/utils/oca.ts +0 -173
  458. package/src/utils/parsers.tsx +0 -111
  459. package/src/utils/proofBundle.ts +0 -220
  460. package/src/utils/schema.ts +0 -28
  461. package/src/utils/testable.ts +0 -17
@@ -1,28 +0,0 @@
1
- import React from 'react'
2
- import { View } from 'react-native'
3
-
4
- import { useTheme } from '../../contexts/theme'
5
- import { ThemedText } from '../texts/ThemedText'
6
-
7
- type UnorderedListProps = {
8
- unorderedListItems: string[]
9
- }
10
-
11
- const UnorderedList: React.FC<UnorderedListProps> = ({ unorderedListItems }) => {
12
- const { ColorPalette } = useTheme()
13
-
14
- return (
15
- <>
16
- {unorderedListItems.map((item: string, i: number) => {
17
- return (
18
- <View key={i} style={{ display: 'flex', flexDirection: 'row', marginBottom: 5 }}>
19
- <ThemedText style={{ color: ColorPalette.brand.unorderedList, paddingLeft: 5 }}>{`\u2022`}</ThemedText>
20
- <ThemedText style={{ color: ColorPalette.brand.unorderedList, paddingLeft: 5, flex: 1 }}>{item}</ThemedText>
21
- </View>
22
- )
23
- })}
24
- </>
25
- )
26
- }
27
-
28
- export default UnorderedList
@@ -1,378 +0,0 @@
1
- import { BrandingOverlay } from '@bifold/oca'
2
- import { Attribute, CredentialOverlay, Predicate, Field, BrandingOverlayType } from '@bifold/oca/build/legacy'
3
- import startCase from 'lodash.startcase'
4
- import React, { useEffect, useState } from 'react'
5
- import { useTranslation } from 'react-i18next'
6
- import {
7
- FlatList,
8
- Image,
9
- ImageBackground,
10
- StyleSheet,
11
- View,
12
- ViewStyle,
13
- TextInput,
14
- TouchableOpacity,
15
- } from 'react-native'
16
- import Icon from 'react-native-vector-icons/MaterialIcons'
17
-
18
- import ImageModal from '../../components/modals/ImageModal'
19
- import { TOKENS, useServices } from '../../container-api'
20
- import { useTheme } from '../../contexts/theme'
21
- import { toImageSource } from '../../utils/credential'
22
- import { formatIfDate, isDataUrl, pTypeToText } from '../../utils/helpers'
23
- import { testIdWithKey } from '../../utils/testable'
24
-
25
- import CardWatermark from './CardWatermark'
26
- import CredentialCard11Logo from './CredentialCard11Logo'
27
- import useCredentialCardStyles from '../../hooks/credential-card-styles'
28
- import { Shade, shadeIsLightOrDark } from '../../utils/luminance'
29
- import CredentialIssuerBody from './CredentialCard11Issuer'
30
- import { ThemedText } from '../texts/ThemedText'
31
-
32
- interface VerifierCredentialCardProps {
33
- style?: ViewStyle
34
- displayItems?: Field[]
35
- elevated?: boolean
36
- credDefId?: string
37
- schemaId: string
38
- preview?: boolean
39
- onChangeValue?: (schema: string, label: string, name: string, value: string) => void
40
- brandingOverlayType?: BrandingOverlayType
41
- }
42
-
43
- /**
44
- * This component is meant to be used in the ProofRequestDetails screen to show what
45
- * a proof request will look like with proper branding etc. and allow for the changing
46
- * of predicate values. It is a greatly trimmed-down version of the CredentialCard11.
47
- */
48
- const VerifierCredentialCard: React.FC<VerifierCredentialCardProps> = ({
49
- style = {},
50
- displayItems = [],
51
- elevated = false,
52
- credDefId,
53
- schemaId,
54
- preview,
55
- onChangeValue,
56
- brandingOverlayType = BrandingOverlayType.Branding10,
57
- }) => {
58
- const [dimensions, setDimensions] = useState({ cardWidth: 0, cardHeight: 0 })
59
- const { i18n, t } = useTranslation()
60
- const { ColorPalette, TextTheme } = useTheme()
61
- const [bundleResolver] = useServices([TOKENS.UTIL_OCA_RESOLVER])
62
- const [overlay, setOverlay] = useState<CredentialOverlay<BrandingOverlay>>({})
63
- const isBranding10 = brandingOverlayType === BrandingOverlayType.Branding10
64
- const isBranding11 = brandingOverlayType === BrandingOverlayType.Branding11
65
- const { styles, borderRadius } = useCredentialCardStyles(overlay, brandingOverlayType, isBranding10)
66
-
67
- const attributeTypes = overlay.bundle?.captureBase.attributes
68
- const attributeFormats: Record<string, string | undefined> = (overlay.bundle as any)?.bundle.attributes
69
- .map((attr: any) => {
70
- return { name: attr.name, format: attr.format }
71
- })
72
- .reduce((prev: { [key: string]: string }, curr: { name: string; format?: string }) => {
73
- return { ...prev, [curr.name]: curr.format }
74
- }, {})
75
-
76
- const getCardWatermarkTextColor = (background?: string) => {
77
- if (isBranding10) return ColorPalette.grayscale.mediumGrey
78
- const shade = shadeIsLightOrDark(background ?? ColorPalette.grayscale.lightGrey)
79
- return shade == Shade.Light ? ColorPalette.grayscale.darkGrey : ColorPalette.grayscale.lightGrey
80
- }
81
-
82
- const parseAttribute = (item: (Attribute & Predicate) | undefined) => {
83
- let parsedItem = item
84
- if (item && !item.value) {
85
- parsedItem = pTypeToText(item, t, attributeTypes) as Attribute & Predicate
86
- }
87
- const parsedValue = formatIfDate(
88
- attributeFormats?.[item?.name ?? ''],
89
- parsedItem?.value ?? parsedItem?.pValue ?? null
90
- )
91
- return {
92
- label: item?.label ?? item?.name ?? '',
93
- value: item?.value ? parsedValue : `${parsedItem?.pType} ${parsedValue}`,
94
- }
95
- }
96
-
97
- useEffect(() => {
98
- const params = {
99
- identifiers: { schemaId, credentialDefinitionId: credDefId },
100
- attributes: displayItems,
101
- language: i18n.language,
102
- }
103
- bundleResolver.resolveAllBundles(params).then((bundle) => {
104
- setOverlay((o) => ({
105
- ...o,
106
- ...bundle,
107
- brandingOverlay: bundle.brandingOverlay as BrandingOverlay,
108
- }))
109
- })
110
- }, [schemaId, credDefId, displayItems, i18n.language, bundleResolver])
111
-
112
- const AttributeItem: React.FC<{ item: Attribute }> = ({ item }) => {
113
- const label = (item.name || item.label)!
114
- const ylabel = overlay.bundle?.labelOverlay?.attributeLabels[label] ?? startCase(label)
115
- const [value, setValue] = useState(item.value)
116
- const [showImageModal, setShowImageModal] = useState(false)
117
-
118
- useEffect(() => {
119
- setValue((v) => formatIfDate(item.format, v))
120
- }, [item.format])
121
-
122
- return (
123
- <View>
124
- <ThemedText
125
- variant="labelSubtitle"
126
- style={[
127
- styles.textContainer,
128
- {
129
- lineHeight: 19,
130
- opacity: 0.8,
131
- },
132
- ]}
133
- testID={testIdWithKey('AttributeName')}
134
- >
135
- {ylabel}
136
- </ThemedText>
137
- {value && (
138
- <View>
139
- {isDataUrl(value) ? (
140
- <TouchableOpacity
141
- accessibilityLabel={t('Record.Zoom')}
142
- accessibilityRole="imagebutton"
143
- testID={testIdWithKey('zoom')}
144
- onPress={() => setShowImageModal(true)}
145
- >
146
- <Image style={styles.imageAttr} source={{ uri: value as string }} />
147
- </TouchableOpacity>
148
- ) : (
149
- <ThemedText variant="bold" style={styles.textContainer} testID={testIdWithKey('AttributeValue')}>
150
- {value}
151
- </ThemedText>
152
- )}
153
- </View>
154
- )}
155
- {showImageModal && <ImageModal uri={value as string} onDismissPressed={() => setShowImageModal(false)} />}
156
- </View>
157
- )
158
- }
159
-
160
- const PredicateItem: React.FC<{
161
- item: Predicate
162
- }> = ({ item }) => {
163
- const { ColorPalette } = useTheme()
164
- const label = (item.label || item.name)!
165
- const ylabel = overlay.bundle?.labelOverlay?.attributeLabels[label] ?? startCase(label)
166
- const [currentValue, setCurrentValue] = useState(`${item.pValue ?? ''}`)
167
-
168
- const predicateStyles = StyleSheet.create({
169
- input: {
170
- textAlign: 'center',
171
- textAlignVertical: 'bottom',
172
- borderBottomColor: ColorPalette.grayscale.black,
173
- backgroundColor: 'rgba(255, 255, 255, 0.2)',
174
- borderBottomWidth: 1,
175
- lineHeight: 19,
176
- padding: 0,
177
- },
178
- predicateLabel: {
179
- lineHeight: 19,
180
- opacity: 0.8,
181
- },
182
- predicateType: {
183
- lineHeight: isBranding10 ? 19 : styles.textContainer.lineHeight,
184
- marginRight: 5,
185
- },
186
- })
187
-
188
- return (
189
- <View>
190
- <ThemedText
191
- variant="labelSubtitle"
192
- style={[styles.textContainer, predicateStyles.predicateLabel]}
193
- testID={testIdWithKey('PredicateName')}
194
- >
195
- {ylabel}
196
- </ThemedText>
197
- <View style={{ flexDirection: 'row', flexWrap: 'wrap', alignItems: 'flex-end' }}>
198
- {item.satisfied && !preview ? (
199
- <Icon style={{ marginRight: 5 }} size={24} name={'check-circle'} color={ColorPalette.semantic.success} />
200
- ) : null}
201
- <ThemedText variant="bold" style={[styles.textContainer, predicateStyles.predicateType]}>
202
- {item.pType}
203
- </ThemedText>
204
- {/* Only allow editing parametrizable predicates in preview mode */}
205
- {item.parameterizable && preview && onChangeValue ? (
206
- <TextInput
207
- keyboardType="numeric"
208
- style={[TextTheme.bold, predicateStyles.input]}
209
- onChangeText={(value) => setCurrentValue(value)}
210
- onBlur={() => {
211
- onChangeValue(schemaId, item.label || item.name || '', item.name || '', currentValue)
212
- }}
213
- testID={testIdWithKey('PredicateInput')}
214
- >
215
- {currentValue}
216
- </TextInput>
217
- ) : (
218
- <ThemedText variant="bold" style={styles.textContainer} testID={testIdWithKey('PredicateValue')}>
219
- {item.pValue}
220
- </ThemedText>
221
- )}
222
- </View>
223
- </View>
224
- )
225
- }
226
-
227
- const CardAttribute: React.FC<{ item: Attribute & Predicate }> = ({ item }) => {
228
- item.format = attributeFormats?.[item.name ?? '']
229
- let parsedPredicate: Predicate | undefined = undefined
230
- if (item instanceof Predicate) {
231
- parsedPredicate = pTypeToText(item, t, attributeTypes) as Predicate
232
- if (!parsedPredicate.parameterizable) {
233
- parsedPredicate.pValue = formatIfDate(parsedPredicate.format, parsedPredicate.pValue)
234
- }
235
- }
236
-
237
- return (
238
- <View style={styles.cardAttributeContainer}>
239
- {item instanceof Attribute && <AttributeItem item={item as Attribute} />}
240
- {item instanceof Predicate && <PredicateItem item={parsedPredicate as Predicate} />}
241
- </View>
242
- )
243
- }
244
-
245
- const renderCardAttribute = (item: Attribute & Predicate) => {
246
- return <CardAttribute item={item} />
247
- }
248
-
249
- const CredentialCardPrimaryBody: React.FC = () => {
250
- return (
251
- <View testID={testIdWithKey('CredentialCardPrimaryBody')} style={styles.primaryBodyContainer}>
252
- <View>
253
- {isBranding10 && (
254
- <CredentialIssuerBody
255
- overlay={overlay}
256
- overlayType={brandingOverlayType}
257
- hasBody={overlay.metaOverlay?.issuer !== 'Unknown Contact'}
258
- proof
259
- />
260
- )}
261
- <View style={styles.primaryBodyNameContainer}>
262
- <ThemedText
263
- variant="bold"
264
- testID={testIdWithKey('CredentialName')}
265
- style={[styles.textContainer, styles.credentialName]}
266
- >
267
- {overlay.metaOverlay?.name}
268
- </ThemedText>
269
- </View>
270
- </View>
271
- <FlatList
272
- data={displayItems}
273
- scrollEnabled={false}
274
- initialNumToRender={displayItems?.length}
275
- keyExtractor={({ name }) => name}
276
- renderItem={({ item }) => {
277
- return renderCardAttribute(item as Attribute & Predicate)
278
- }}
279
- />
280
- {brandingOverlayType === BrandingOverlayType.Branding11 && (
281
- <CredentialIssuerBody
282
- overlay={overlay}
283
- overlayType={brandingOverlayType}
284
- hasBody={overlay.metaOverlay?.issuer !== 'Unknown Contact'}
285
- />
286
- )}
287
- </View>
288
- )
289
- }
290
-
291
- const CredentialCardSecondaryBody: React.FC = () => {
292
- return (
293
- <View testID={testIdWithKey('CredentialCardSecondaryBody')} style={styles.secondaryBodyContainer}>
294
- {overlay.brandingOverlay?.backgroundImageSlice &&
295
- (!displayItems || brandingOverlayType === BrandingOverlayType.Branding11) ? (
296
- <ImageBackground
297
- source={toImageSource(overlay.brandingOverlay?.backgroundImageSlice)}
298
- style={{ flexGrow: 1 }}
299
- imageStyle={{
300
- borderTopLeftRadius: borderRadius,
301
- borderBottomLeftRadius: borderRadius,
302
- }}
303
- >
304
- {null}
305
- </ImageBackground>
306
- ) : null}
307
- </View>
308
- )
309
- }
310
-
311
- const CredentialCard: React.FC = () => {
312
- const watermarkLabel = overlay.metaOverlay?.watermark ? overlay.metaOverlay?.watermark + ',' : ''
313
- const issuerAccessibilityLabel = overlay.metaOverlay?.issuer
314
- ? `${t('Credentials.IssuedBy')} ${overlay.metaOverlay?.issuer}`
315
- : ''
316
- const accessibilityLabel = isBranding11
317
- ? `${watermarkLabel} ${overlay.metaOverlay?.name ?? ''} ${t('Credentials.Credential')}${
318
- displayItems.length > 0 ? ',' : ''
319
- }` +
320
- displayItems.map((item) => {
321
- const { label, value } = parseAttribute(item as Attribute & Predicate)
322
- if (label && value) {
323
- return ` ${label}, ${value}`
324
- }
325
- }) +
326
- `, ${issuerAccessibilityLabel}`
327
- : `${issuerAccessibilityLabel}, ${overlay.metaOverlay?.watermark ?? ''} ${overlay.metaOverlay?.name ?? ''} ${t(
328
- 'Credentials.Credential'
329
- )}.` +
330
- displayItems.map((item) => {
331
- const { label, value } = parseAttribute(item as (Attribute & Predicate) | undefined)
332
- if (label) {
333
- return value ? ` ${label}, ${value}` : ` ${label}`
334
- }
335
- })
336
- return (
337
- <View style={styles.cardContainer} accessible={true} accessibilityLabel={accessibilityLabel}>
338
- <CredentialCardSecondaryBody />
339
- <CredentialCard11Logo
340
- noLogoText={overlay.metaOverlay?.name ?? overlay.metaOverlay?.issuer ?? 'C'}
341
- overlay={overlay}
342
- elevated={elevated}
343
- />
344
- <CredentialCardPrimaryBody />
345
- </View>
346
- )
347
- }
348
-
349
- return overlay.bundle ? (
350
- <View
351
- style={[
352
- styles.container,
353
- style,
354
- {
355
- elevation: elevated ? 5 : 0,
356
- overflow: elevated ? 'visible' : 'hidden',
357
- },
358
- ]}
359
- onLayout={(event) => {
360
- setDimensions({ cardHeight: event.nativeEvent.layout.height, cardWidth: event.nativeEvent.layout.width })
361
- }}
362
- >
363
- <View testID={testIdWithKey('CredentialCard')} style={{ overflow: 'hidden' }}>
364
- {overlay.metaOverlay?.watermark && (
365
- <CardWatermark
366
- width={dimensions.cardWidth}
367
- height={dimensions.cardHeight}
368
- style={{ color: getCardWatermarkTextColor(overlay.brandingOverlay?.primaryBackgroundColor) }}
369
- watermark={overlay.metaOverlay?.watermark}
370
- />
371
- )}
372
- <CredentialCard />
373
- </View>
374
- </View>
375
- ) : null
376
- }
377
-
378
- export default VerifierCredentialCard
@@ -1,2 +0,0 @@
1
- import CredentialCard from './CredentialCard'
2
- export { CredentialCard }
@@ -1,42 +0,0 @@
1
- import React from 'react'
2
- import { useTranslation } from 'react-i18next'
3
- import { StyleSheet, useWindowDimensions } from 'react-native'
4
- import { SafeAreaView } from 'react-native-safe-area-context'
5
-
6
- import { InfoBoxType } from '../misc/InfoBox'
7
-
8
- import PopupModal from './PopupModal'
9
-
10
- interface AlertModalProps {
11
- title: string
12
- message: string
13
- submit?: () => void
14
- }
15
-
16
- const AlertModal: React.FC<AlertModalProps> = ({ title, message, submit }) => {
17
- const { t } = useTranslation()
18
- const { height } = useWindowDimensions()
19
-
20
- const styles = StyleSheet.create({
21
- container: {
22
- minHeight: height,
23
- flexDirection: 'column',
24
- justifyContent: 'center',
25
- alignItems: 'center',
26
- },
27
- })
28
-
29
- return (
30
- <SafeAreaView style={styles.container}>
31
- <PopupModal
32
- notificationType={InfoBoxType.Info}
33
- title={title}
34
- description={message}
35
- onCallToActionLabel={t('Global.Okay')}
36
- onCallToActionPressed={submit ? () => submit() : () => undefined}
37
- ></PopupModal>
38
- </SafeAreaView>
39
- )
40
- }
41
-
42
- export default AlertModal
@@ -1,142 +0,0 @@
1
- import React from 'react'
2
- import { useTranslation } from 'react-i18next'
3
- import { StyleSheet, View, TouchableOpacity, useWindowDimensions } from 'react-native'
4
- import Icon from 'react-native-vector-icons/MaterialIcons'
5
-
6
- import { hitSlop } from '../../constants'
7
- import { useTheme } from '../../contexts/theme'
8
- import { GenericFn } from '../../types/fn'
9
- import { testIdWithKey } from '../../utils/testable'
10
- import Button, { ButtonType } from '../buttons/Button'
11
- import { ThemedText } from '../texts/ThemedText'
12
- import SafeAreaModal from './SafeAreaModal'
13
-
14
- interface AppGuideModalProps {
15
- title: string
16
- description?: string
17
- onCallToActionPressed?: GenericFn
18
- onCallToActionLabel?: string
19
- onSecondCallToActionPressed?: GenericFn
20
- onSecondCallToActionLabel?: string
21
- onDismissPressed: GenericFn
22
- }
23
-
24
- const AppGuideModal: React.FC<AppGuideModalProps> = ({
25
- title,
26
- description,
27
- onCallToActionPressed,
28
- onCallToActionLabel,
29
- onSecondCallToActionPressed,
30
- onSecondCallToActionLabel,
31
- onDismissPressed,
32
- }) => {
33
- const { height, width } = useWindowDimensions()
34
- const { t } = useTranslation()
35
- const { ColorPalette } = useTheme()
36
- const iconSize = 30
37
- const dismissIconName = 'clear'
38
- const iconColor = ColorPalette.notification.infoIcon
39
-
40
- const styles = StyleSheet.create({
41
- modalCenter: {
42
- flex: 1,
43
- justifyContent: 'center',
44
- alignItems: 'center',
45
- backgroundColor: ColorPalette.notification.popupOverlay,
46
- padding: 10,
47
- minHeight: height,
48
- minWidth: width,
49
- },
50
- container: {
51
- backgroundColor: ColorPalette.notification.info,
52
- borderColor: ColorPalette.notification.infoBorder,
53
- borderRadius: 5,
54
- borderWidth: 1,
55
- padding: 20,
56
- width: width - 50,
57
- },
58
- headerContainer: {
59
- flexDirection: 'row',
60
- justifyContent: 'space-between',
61
- },
62
- headerTextContainer: {
63
- flex: 1,
64
- flexWrap: 'wrap',
65
- },
66
- headerText: {
67
- alignSelf: 'flex-start',
68
- flexWrap: 'wrap',
69
- color: ColorPalette.notification.infoText,
70
- },
71
- bodyText: {
72
- flexShrink: 1,
73
- marginVertical: 16,
74
- color: ColorPalette.notification.infoText,
75
- },
76
- dismissIcon: {
77
- alignSelf: 'center',
78
- },
79
- })
80
-
81
- return (
82
- <SafeAreaModal transparent accessibilityViewIsModal>
83
- <View style={styles.modalCenter}>
84
- <View style={styles.container}>
85
- <View style={styles.headerContainer}>
86
- <View style={styles.headerTextContainer}>
87
- <ThemedText
88
- maxFontSizeMultiplier={1.5}
89
- variant="headingThree"
90
- style={styles.headerText}
91
- testID={testIdWithKey('HeaderText')}
92
- accessibilityRole="header"
93
- >
94
- {title}
95
- </ThemedText>
96
- </View>
97
- <View style={styles.dismissIcon}>
98
- <TouchableOpacity
99
- onPress={onDismissPressed}
100
- testID={testIdWithKey('Dismiss')}
101
- accessibilityLabel={t('Global.Dismiss')}
102
- accessibilityRole={'button'}
103
- hitSlop={hitSlop}
104
- >
105
- <Icon name={dismissIconName} size={iconSize} color={iconColor} />
106
- </TouchableOpacity>
107
- </View>
108
- </View>
109
- <View>
110
- <ThemedText maxFontSizeMultiplier={1.5} style={styles.bodyText} testID={testIdWithKey('BodyText')}>
111
- {description}
112
- </ThemedText>
113
- {onCallToActionPressed && (
114
- <View style={{ width: '100%', marginBottom: 10 }}>
115
- <Button
116
- title={onCallToActionLabel || t('Global.Okay')}
117
- accessibilityLabel={onCallToActionLabel || t('Global.Okay')}
118
- testID={testIdWithKey('Primary')}
119
- buttonType={ButtonType.Primary}
120
- onPress={onCallToActionPressed}
121
- maxfontSizeMultiplier={1.5}
122
- />
123
- </View>
124
- )}
125
- {onSecondCallToActionPressed && (
126
- <Button
127
- title={onSecondCallToActionLabel || t('Global.Dismiss')}
128
- accessibilityLabel={onSecondCallToActionLabel || t('Global.Dismiss')}
129
- testID={testIdWithKey('Secondary')}
130
- buttonType={ButtonType.Secondary}
131
- onPress={onSecondCallToActionPressed}
132
- maxfontSizeMultiplier={1.5}
133
- />
134
- )}
135
- </View>
136
- </View>
137
- </View>
138
- </SafeAreaModal>
139
- )
140
- }
141
-
142
- export default AppGuideModal