@bifold/core 2.4.6 → 2.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (401) hide show
  1. package/lib/commonjs/contexts/reducers/store.js +3 -2
  2. package/lib/commonjs/contexts/reducers/store.js.map +1 -1
  3. package/lib/commonjs/index.js +119 -104
  4. package/lib/commonjs/index.js.map +1 -1
  5. package/lib/commonjs/screens/AttemptLockout.js +27 -35
  6. package/lib/commonjs/screens/AttemptLockout.js.map +1 -1
  7. package/lib/commonjs/screens/MobileVerifierLoading.js +4 -3
  8. package/lib/commonjs/screens/MobileVerifierLoading.js.map +1 -1
  9. package/lib/commonjs/screens/PINCreate.js +3 -10
  10. package/lib/commonjs/screens/PINCreate.js.map +1 -1
  11. package/lib/commonjs/screens/WhatAreContacts.js +3 -2
  12. package/lib/commonjs/screens/WhatAreContacts.js.map +1 -1
  13. package/lib/module/contexts/reducers/store.js +3 -2
  14. package/lib/module/contexts/reducers/store.js.map +1 -1
  15. package/lib/module/index.js +42 -45
  16. package/lib/module/index.js.map +1 -1
  17. package/lib/module/screens/AttemptLockout.js +28 -36
  18. package/lib/module/screens/AttemptLockout.js.map +1 -1
  19. package/lib/module/screens/MobileVerifierLoading.js +4 -3
  20. package/lib/module/screens/MobileVerifierLoading.js.map +1 -1
  21. package/lib/module/screens/PINCreate.js +3 -10
  22. package/lib/module/screens/PINCreate.js.map +1 -1
  23. package/lib/module/screens/WhatAreContacts.js +3 -2
  24. package/lib/module/screens/WhatAreContacts.js.map +1 -1
  25. package/lib/typescript/src/contexts/reducers/store.d.ts.map +1 -1
  26. package/lib/typescript/src/index.d.ts +57 -61
  27. package/lib/typescript/src/index.d.ts.map +1 -1
  28. package/lib/typescript/src/screens/AttemptLockout.d.ts.map +1 -1
  29. package/lib/typescript/src/screens/MobileVerifierLoading.d.ts.map +1 -1
  30. package/lib/typescript/src/screens/PINCreate.d.ts.map +1 -1
  31. package/lib/typescript/src/screens/WhatAreContacts.d.ts.map +1 -1
  32. package/package.json +3 -4
  33. package/src/App.tsx +0 -79
  34. package/src/animated-components.ts +0 -30
  35. package/src/assets/fonts/MaterialIcons.ttf +0 -0
  36. package/src/assets/icons/code.svg +0 -4
  37. package/src/assets/icons/large-arrow.svg +0 -5
  38. package/src/assets/icons/pencil.svg +0 -15
  39. package/src/assets/icons/trash.svg +0 -31
  40. package/src/assets/img/Artwork_1024x1024.png +0 -0
  41. package/src/assets/img/HistoryCardAcceptedIcon.svg +0 -4
  42. package/src/assets/img/HistoryCardExpiredIcon.svg +0 -4
  43. package/src/assets/img/HistoryCardRevokedIcon.svg +0 -4
  44. package/src/assets/img/HistoryInformationSentIcon.svg +0 -4
  45. package/src/assets/img/HistoryPinUpdatedIcon.svg +0 -4
  46. package/src/assets/img/IconChevronRight.svg +0 -5
  47. package/src/assets/img/activity-indicator-circle.svg +0 -90
  48. package/src/assets/img/app-lockout.svg +0 -1
  49. package/src/assets/img/biometrics.svg +0 -74
  50. package/src/assets/img/chat-loading.svg +0 -1
  51. package/src/assets/img/check-in-circle.svg +0 -18
  52. package/src/assets/img/connection-pending.svg +0 -112
  53. package/src/assets/img/contact-book.svg +0 -21
  54. package/src/assets/img/credential-card.svg +0 -18
  55. package/src/assets/img/credential-declined.svg +0 -28
  56. package/src/assets/img/credential-in-hand.svg +0 -48
  57. package/src/assets/img/credential-list.svg +0 -60
  58. package/src/assets/img/credential-pending.svg +0 -96
  59. package/src/assets/img/credential-success.svg +0 -48
  60. package/src/assets/img/delete-notification.svg +0 -1
  61. package/src/assets/img/empty-wallet.svg +0 -23
  62. package/src/assets/img/error-filled.svg +0 -12
  63. package/src/assets/img/exclamation-mark.svg +0 -17
  64. package/src/assets/img/home-center-img.svg +0 -71
  65. package/src/assets/img/icon-credential-offer-dark.svg +0 -7
  66. package/src/assets/img/icon-credential-offer-light.svg +0 -7
  67. package/src/assets/img/icon-info-recieved-dark.svg +0 -8
  68. package/src/assets/img/icon-info-recieved-light.svg +0 -8
  69. package/src/assets/img/icon-info-sent-dark.svg +0 -8
  70. package/src/assets/img/icon-info-sent-light.svg +0 -8
  71. package/src/assets/img/icon-proof-request-dark.svg +0 -11
  72. package/src/assets/img/icon-proof-request-light.svg +0 -11
  73. package/src/assets/img/information-received.svg +0 -1
  74. package/src/assets/img/logo-large.png +0 -0
  75. package/src/assets/img/logo-large@2x.png +0 -0
  76. package/src/assets/img/logo-large@3x.png +0 -0
  77. package/src/assets/img/logo.svg +0 -15
  78. package/src/assets/img/message-text-icon-outline.svg +0 -1
  79. package/src/assets/img/message-text-icon.svg +0 -1
  80. package/src/assets/img/no_information_shared.svg +0 -36
  81. package/src/assets/img/preface.svg +0 -15
  82. package/src/assets/img/proof-declined.svg +0 -66
  83. package/src/assets/img/proof-pending.svg +0 -61
  84. package/src/assets/img/proof-success.svg +0 -72
  85. package/src/assets/img/push-notifications.svg +0 -1
  86. package/src/assets/img/qrcode-scan-icon.svg +0 -1
  87. package/src/assets/img/scan-share.svg +0 -102
  88. package/src/assets/img/secure-check.svg +0 -4
  89. package/src/assets/img/secure-image.svg +0 -64
  90. package/src/assets/img/update-available.svg +0 -26
  91. package/src/assets/img/verifier-request-declined.svg +0 -34
  92. package/src/assets/img/wallet-back.svg +0 -20
  93. package/src/assets/img/wallet-front.svg +0 -32
  94. package/src/assets/img/wallet-icon-outline.svg +0 -1
  95. package/src/assets/img/wallet-icon.svg +0 -1
  96. package/src/assets/img/wallet.svg +0 -43
  97. package/src/assets/oca-bundles.json +0 -174
  98. package/src/components/animated/ButtonLoading.tsx +0 -32
  99. package/src/components/animated/ConnectionLoading.tsx +0 -53
  100. package/src/components/animated/CredentialAdded.tsx +0 -72
  101. package/src/components/animated/CredentialPending.tsx +0 -63
  102. package/src/components/animated/LoadingIndicator.tsx +0 -49
  103. package/src/components/animated/PresentationLoading.tsx +0 -52
  104. package/src/components/animated/RecordLoading.tsx +0 -75
  105. package/src/components/animated/SendingProof.tsx +0 -53
  106. package/src/components/animated/SentProof.tsx +0 -72
  107. package/src/components/buttons/Button-api.tsx +0 -46
  108. package/src/components/buttons/Button.tsx +0 -125
  109. package/src/components/buttons/HeaderHome.tsx +0 -25
  110. package/src/components/buttons/IconButton.tsx +0 -93
  111. package/src/components/buttons/InfoIcon.tsx +0 -35
  112. package/src/components/buttons/SettingsMenu.tsx +0 -26
  113. package/src/components/buttons/ToggleButton.tsx +0 -93
  114. package/src/components/buttons/index.ts +0 -4
  115. package/src/components/chat/ActionSlider.tsx +0 -104
  116. package/src/components/chat/ChatActions.tsx +0 -33
  117. package/src/components/chat/ChatBubble.tsx +0 -20
  118. package/src/components/chat/ChatEvent.tsx +0 -31
  119. package/src/components/chat/ChatMessage.tsx +0 -142
  120. package/src/components/chat/MessageInput.tsx +0 -46
  121. package/src/components/chat/index.ts +0 -4
  122. package/src/components/forms/WalletNameForm.tsx +0 -148
  123. package/src/components/index.ts +0 -4
  124. package/src/components/inputs/BiometryControl.tsx +0 -190
  125. package/src/components/inputs/BulletPoint.tsx +0 -32
  126. package/src/components/inputs/CheckBoxRow.tsx +0 -67
  127. package/src/components/inputs/InlineErrorText.tsx +0 -60
  128. package/src/components/inputs/LimitedTextInput.tsx +0 -71
  129. package/src/components/inputs/PINInput.tsx +0 -175
  130. package/src/components/inputs/SingleSelectBlock.tsx +0 -53
  131. package/src/components/listItems/ContactCredentialListItem.tsx +0 -79
  132. package/src/components/listItems/ContactListItem.tsx +0 -121
  133. package/src/components/listItems/NotificationListItem.tsx +0 -514
  134. package/src/components/misc/AvatarView.tsx +0 -33
  135. package/src/components/misc/CardWatermark.tsx +0 -52
  136. package/src/components/misc/ConnectionAlert.tsx +0 -123
  137. package/src/components/misc/ConnectionImage.tsx +0 -45
  138. package/src/components/misc/ContentGradient.tsx +0 -40
  139. package/src/components/misc/CredentialCard.tsx +0 -161
  140. package/src/components/misc/CredentialCard10.tsx +0 -329
  141. package/src/components/misc/CredentialCard11.tsx +0 -701
  142. package/src/components/misc/CredentialCard11ActionFooter.tsx +0 -55
  143. package/src/components/misc/CredentialCard11Issuer.tsx +0 -74
  144. package/src/components/misc/CredentialCard11Logo.tsx +0 -61
  145. package/src/components/misc/EmptyList.tsx +0 -27
  146. package/src/components/misc/EmptyListContacts.tsx +0 -55
  147. package/src/components/misc/ErrorBoundary.tsx +0 -200
  148. package/src/components/misc/FauxHeader.tsx +0 -75
  149. package/src/components/misc/InfoBox.tsx +0 -283
  150. package/src/components/misc/NoNewUpdates.tsx +0 -38
  151. package/src/components/misc/PINHeader.tsx +0 -25
  152. package/src/components/misc/PINValidationHelper.tsx +0 -48
  153. package/src/components/misc/Pagination.tsx +0 -114
  154. package/src/components/misc/QRRenderer.tsx +0 -53
  155. package/src/components/misc/QRScanner.tsx +0 -395
  156. package/src/components/misc/QRScannerTorch.tsx +0 -74
  157. package/src/components/misc/ScanCamera.tsx +0 -86
  158. package/src/components/misc/ScanTab.tsx +0 -45
  159. package/src/components/misc/SharedProofData.tsx +0 -98
  160. package/src/components/misc/UnorderedList.tsx +0 -28
  161. package/src/components/misc/VerifierCredentialCard.tsx +0 -378
  162. package/src/components/misc/index.ts +0 -2
  163. package/src/components/modals/AlertModal.tsx +0 -42
  164. package/src/components/modals/AppGuideModal.tsx +0 -142
  165. package/src/components/modals/CameraDisclosureModal.tsx +0 -126
  166. package/src/components/modals/CommonRemoveModal.tsx +0 -337
  167. package/src/components/modals/DeveloperModal.tsx +0 -32
  168. package/src/components/modals/DismissiblePopupModal.tsx +0 -169
  169. package/src/components/modals/ErrorModal.tsx +0 -107
  170. package/src/components/modals/ImageModal.tsx +0 -80
  171. package/src/components/modals/NetInfoModal.tsx +0 -35
  172. package/src/components/modals/PopupModal.tsx +0 -56
  173. package/src/components/modals/ProofCancelModal.tsx +0 -79
  174. package/src/components/modals/SafeAreaModal.tsx +0 -17
  175. package/src/components/record/Record.tsx +0 -100
  176. package/src/components/record/RecordBinaryField.tsx +0 -55
  177. package/src/components/record/RecordDateIntField.tsx +0 -63
  178. package/src/components/record/RecordField.tsx +0 -154
  179. package/src/components/record/RecordFooter.tsx +0 -17
  180. package/src/components/record/RecordHeader.tsx +0 -17
  181. package/src/components/record/RecordRemove.tsx +0 -66
  182. package/src/components/texts/HeaderTitle.tsx +0 -25
  183. package/src/components/texts/HighlightTextBox.tsx +0 -41
  184. package/src/components/texts/InfoTextBox.tsx +0 -129
  185. package/src/components/texts/Link.tsx +0 -41
  186. package/src/components/texts/Text.tsx +0 -21
  187. package/src/components/texts/ThemedText.tsx +0 -24
  188. package/src/components/toast/BaseToast.tsx +0 -128
  189. package/src/components/toast/ToastConfig.tsx +0 -21
  190. package/src/components/tour/AttachTourStep.tsx +0 -73
  191. package/src/components/tour/CredentialOfferTourSteps.tsx +0 -41
  192. package/src/components/tour/CredentialsTourSteps.tsx +0 -41
  193. package/src/components/tour/HomeTourSteps.tsx +0 -104
  194. package/src/components/tour/ProofRequestTourSteps.tsx +0 -41
  195. package/src/components/tour/SpotCutout.tsx +0 -65
  196. package/src/components/tour/TourBox.tsx +0 -255
  197. package/src/components/tour/TourOverlay.tsx +0 -134
  198. package/src/components/views/Banner.tsx +0 -181
  199. package/src/components/views/CredentialCardLogo.tsx +0 -77
  200. package/src/components/views/CredentialDetailPrimaryHeader.tsx +0 -107
  201. package/src/components/views/CredentialDetailSecondaryHeader.tsx +0 -60
  202. package/src/components/views/HeaderWithBanner.tsx +0 -17
  203. package/src/components/views/HomeFooterView.tsx +0 -110
  204. package/src/components/views/HomeHeaderView.tsx +0 -12
  205. package/src/components/views/KeyboardView.tsx +0 -41
  206. package/src/components/views/LoadingPlaceholder.tsx +0 -168
  207. package/src/components/views/LoadingView.tsx +0 -29
  208. package/src/components/views/ProgressBar.tsx +0 -53
  209. package/src/components/views/PushNotificationsContent.tsx +0 -51
  210. package/src/components/views/PushNotificationsDisabledContent.tsx +0 -47
  211. package/src/configs/ledgers/indy/index.ts +0 -8
  212. package/src/configs/ledgers/indy/ledgers.json +0 -51
  213. package/src/constants.ts +0 -107
  214. package/src/container-api.ts +0 -247
  215. package/src/container-impl.ts +0 -243
  216. package/src/contexts/activity.tsx +0 -145
  217. package/src/contexts/animated-components.ts +0 -9
  218. package/src/contexts/auth.tsx +0 -240
  219. package/src/contexts/index.ts +0 -3
  220. package/src/contexts/navigation.tsx +0 -19
  221. package/src/contexts/network.tsx +0 -125
  222. package/src/contexts/reducers/index.ts +0 -3
  223. package/src/contexts/reducers/store.ts +0 -754
  224. package/src/contexts/store.tsx +0 -103
  225. package/src/contexts/theme.tsx +0 -51
  226. package/src/contexts/tour/tour-context.tsx +0 -160
  227. package/src/contexts/tour/tour-provider.tsx +0 -160
  228. package/src/hooks/bundle-resolver.ts +0 -95
  229. package/src/hooks/chat-messages.tsx +0 -263
  230. package/src/hooks/connections.ts +0 -37
  231. package/src/hooks/credential-card-styles.ts +0 -144
  232. package/src/hooks/credentials.ts +0 -11
  233. package/src/hooks/deep-links.ts +0 -49
  234. package/src/hooks/developer-mode.ts +0 -25
  235. package/src/hooks/lockout.ts +0 -77
  236. package/src/hooks/notifications.ts +0 -108
  237. package/src/hooks/oob.ts +0 -17
  238. package/src/hooks/proof-request-templates.ts +0 -40
  239. package/src/hooks/proofs.ts +0 -32
  240. package/src/hooks/screen-capture.ts +0 -52
  241. package/src/hooks/useBifoldAgentSetup.ts +0 -169
  242. package/src/hooks/useOnboardingState.ts +0 -53
  243. package/src/hooks/usePINValidation.ts +0 -98
  244. package/src/index.ts +0 -239
  245. package/src/layout/ScreenLayout.tsx +0 -53
  246. package/src/localization/en/en.json +0 -951
  247. package/src/localization/en/index.ts +0 -3
  248. package/src/localization/fr/fr.json +0 -933
  249. package/src/localization/fr/index.ts +0 -3
  250. package/src/localization/index.ts +0 -66
  251. package/src/localization/pt-br/index.ts +0 -3
  252. package/src/localization/pt-br/pt-br.json +0 -911
  253. package/src/modules/history/context/historyManager.tsx +0 -247
  254. package/src/modules/history/index.ts +0 -2
  255. package/src/modules/history/navigation/HistoryStack.tsx +0 -29
  256. package/src/modules/history/services/queue.service.tsx +0 -31
  257. package/src/modules/history/types/index.ts +0 -92
  258. package/src/modules/history/ui/HistoryPage.tsx +0 -133
  259. package/src/modules/history/ui/HistorySettings.tsx +0 -183
  260. package/src/modules/history/ui/assets/img/HistoryCardAcceptedIcon.svg +0 -4
  261. package/src/modules/history/ui/assets/img/HistoryCardExpiredIcon.svg +0 -4
  262. package/src/modules/history/ui/assets/img/HistoryCardRevokedIcon.svg +0 -4
  263. package/src/modules/history/ui/assets/img/HistoryInformationSentIcon.svg +0 -4
  264. package/src/modules/history/ui/assets/img/HistoryPinUpdatedIcon.svg +0 -4
  265. package/src/modules/history/ui/assets/img/IconChevronRight.svg +0 -3
  266. package/src/modules/history/ui/components/BulletPoint.tsx +0 -49
  267. package/src/modules/history/ui/components/HistoryListItem.tsx +0 -251
  268. package/src/modules/history/ui/components/HistoryMenu.tsx +0 -25
  269. package/src/modules/history/ui/components/SingleSelectBlock.tsx +0 -72
  270. package/src/modules/openid/components/CredentialRowCard.tsx +0 -64
  271. package/src/modules/openid/components/OpenIDCredentialCard.tsx +0 -276
  272. package/src/modules/openid/context/OpenIDCredentialRecordProvider.tsx +0 -296
  273. package/src/modules/openid/display.tsx +0 -467
  274. package/src/modules/openid/displayProof.tsx +0 -86
  275. package/src/modules/openid/hooks/openid.tsx +0 -111
  276. package/src/modules/openid/metadata.tsx +0 -59
  277. package/src/modules/openid/offerResolve.tsx +0 -281
  278. package/src/modules/openid/resolverProof.tsx +0 -286
  279. package/src/modules/openid/screens/OpenIDCredentialDetails.tsx +0 -214
  280. package/src/modules/openid/screens/OpenIDCredentialOffer.tsx +0 -192
  281. package/src/modules/openid/screens/OpenIDProofChangeCredential.tsx +0 -133
  282. package/src/modules/openid/screens/OpenIDProofPresentation.tsx +0 -423
  283. package/src/modules/openid/types.tsx +0 -111
  284. package/src/modules/openid/utils/utils.tsx +0 -119
  285. package/src/navigators/ConnectStack.tsx +0 -68
  286. package/src/navigators/ContactStack.tsx +0 -91
  287. package/src/navigators/CredentialStack.tsx +0 -48
  288. package/src/navigators/DeliveryStack.tsx +0 -76
  289. package/src/navigators/HomeStack.tsx +0 -37
  290. package/src/navigators/MainStack.tsx +0 -146
  291. package/src/navigators/NotificationStack.tsx +0 -56
  292. package/src/navigators/OnboardingScreens.ts +0 -142
  293. package/src/navigators/OnboardingStack.tsx +0 -205
  294. package/src/navigators/ProofRequestStack.tsx +0 -113
  295. package/src/navigators/RootStack.tsx +0 -71
  296. package/src/navigators/SettingStack.tsx +0 -174
  297. package/src/navigators/TabStack.tsx +0 -304
  298. package/src/navigators/defaultLayoutOptions.tsx +0 -17
  299. package/src/navigators/defaultStackOptions.tsx +0 -102
  300. package/src/navigators/index.ts +0 -27
  301. package/src/onboarding.ts +0 -90
  302. package/src/screens/AttemptLockout.tsx +0 -153
  303. package/src/screens/AutoLock.tsx +0 -140
  304. package/src/screens/Biometry.tsx +0 -54
  305. package/src/screens/Chat.tsx +0 -141
  306. package/src/screens/ConfigureMediator.tsx +0 -160
  307. package/src/screens/Connection.tsx +0 -394
  308. package/src/screens/ContactDetails.tsx +0 -350
  309. package/src/screens/CredentialDetails.tsx +0 -473
  310. package/src/screens/CredentialOffer.tsx +0 -334
  311. package/src/screens/CredentialOfferAccept.tsx +0 -189
  312. package/src/screens/DataRetention.tsx +0 -91
  313. package/src/screens/Developer.tsx +0 -289
  314. package/src/screens/Home.tsx +0 -173
  315. package/src/screens/JSONDetails.tsx +0 -104
  316. package/src/screens/Language.tsx +0 -97
  317. package/src/screens/ListContacts.tsx +0 -112
  318. package/src/screens/ListCredentials.tsx +0 -135
  319. package/src/screens/ListProofRequests.tsx +0 -148
  320. package/src/screens/MobileVerifierLoading.tsx +0 -106
  321. package/src/screens/NameWallet.tsx +0 -9
  322. package/src/screens/Onboarding.tsx +0 -162
  323. package/src/screens/OnboardingPages.tsx +0 -160
  324. package/src/screens/PINChange.tsx +0 -249
  325. package/src/screens/PINCreate.tsx +0 -185
  326. package/src/screens/PINEnter.tsx +0 -432
  327. package/src/screens/PINExplainer.tsx +0 -85
  328. package/src/screens/PINVerify.tsx +0 -195
  329. package/src/screens/PasteUrl.tsx +0 -140
  330. package/src/screens/Preface.tsx +0 -78
  331. package/src/screens/ProofChangeCredential.tsx +0 -179
  332. package/src/screens/ProofDetails.tsx +0 -348
  333. package/src/screens/ProofRequest.tsx +0 -999
  334. package/src/screens/ProofRequestAccept.tsx +0 -133
  335. package/src/screens/ProofRequestDetails.tsx +0 -270
  336. package/src/screens/ProofRequestUsageHistory.tsx +0 -152
  337. package/src/screens/ProofRequesting.tsx +0 -245
  338. package/src/screens/PushNotifications.tsx +0 -59
  339. package/src/screens/RenameContact.tsx +0 -155
  340. package/src/screens/RenameWallet.tsx +0 -26
  341. package/src/screens/Scan.tsx +0 -145
  342. package/src/screens/ScanHelp.tsx +0 -48
  343. package/src/screens/Settings.tsx +0 -415
  344. package/src/screens/Splash.tsx +0 -80
  345. package/src/screens/Terms.tsx +0 -127
  346. package/src/screens/ToggleBiometry.tsx +0 -153
  347. package/src/screens/TogglePushNotifications.tsx +0 -118
  348. package/src/screens/Tours.tsx +0 -93
  349. package/src/screens/UpdateAvailable.tsx +0 -119
  350. package/src/screens/WhatAreContacts.tsx +0 -71
  351. package/src/services/bifoldLogger.ts +0 -3
  352. package/src/services/keychain.ts +0 -184
  353. package/src/services/logger.ts +0 -89
  354. package/src/services/storage.ts +0 -136
  355. package/src/theme-builder.ts +0 -157
  356. package/src/theme.interface.ts +0 -580
  357. package/src/theme.ts +0 -1346
  358. package/src/types/attempt-lockout-config.ts +0 -8
  359. package/src/types/attestation.ts +0 -17
  360. package/src/types/chat.ts +0 -4
  361. package/src/types/config.ts +0 -64
  362. package/src/types/contact-details.ts +0 -5
  363. package/src/types/credential-list-footer.ts +0 -3
  364. package/src/types/credential-status.ts +0 -3
  365. package/src/types/credentials.ts +0 -7
  366. package/src/types/decline.ts +0 -5
  367. package/src/types/error.ts +0 -40
  368. package/src/types/fn.ts +0 -2
  369. package/src/types/genesis.ts +0 -35
  370. package/src/types/index.ts +0 -2
  371. package/src/types/metadata.ts +0 -16
  372. package/src/types/navigators.ts +0 -239
  373. package/src/types/notification.ts +0 -24
  374. package/src/types/permissions.ts +0 -2
  375. package/src/types/proof-items.ts +0 -32
  376. package/src/types/react-i18next.d.ts +0 -10
  377. package/src/types/remove.ts +0 -8
  378. package/src/types/security.ts +0 -32
  379. package/src/types/settings.ts +0 -28
  380. package/src/types/state.ts +0 -97
  381. package/src/types/tour.ts +0 -20
  382. package/src/types/version-check.ts +0 -18
  383. package/src/utils/PINValidation.ts +0 -98
  384. package/src/utils/agent.ts +0 -128
  385. package/src/utils/anonCredsProofRequestMapper.ts +0 -205
  386. package/src/utils/contacts.ts +0 -59
  387. package/src/utils/cred-def.ts +0 -33
  388. package/src/utils/credential.ts +0 -37
  389. package/src/utils/crypto.ts +0 -12
  390. package/src/utils/fileCache.ts +0 -152
  391. package/src/utils/helpers.ts +0 -1292
  392. package/src/utils/ledger.ts +0 -212
  393. package/src/utils/luminance.ts +0 -40
  394. package/src/utils/mediatorhelpers.ts +0 -71
  395. package/src/utils/migration.ts +0 -40
  396. package/src/utils/network.tsx +0 -55
  397. package/src/utils/oca.ts +0 -173
  398. package/src/utils/parsers.tsx +0 -111
  399. package/src/utils/proofBundle.ts +0 -220
  400. package/src/utils/schema.ts +0 -28
  401. package/src/utils/testable.ts +0 -17
@@ -1,60 +0,0 @@
1
- import React from 'react'
2
- import { View, StyleSheet } from 'react-native'
3
-
4
- import { useTheme } from '../../contexts/theme'
5
- import { SvgProps } from 'react-native-svg'
6
- import { InlineErrorConfig } from '../../types/error'
7
- import { testIdWithKey } from '../../utils/testable'
8
- import { ThemedText } from '../texts/ThemedText'
9
-
10
- export enum InlineErrorType {
11
- error,
12
- warning,
13
- }
14
-
15
- export interface InlineMessageProps {
16
- message: string
17
- inlineType: InlineErrorType
18
- config: InlineErrorConfig
19
- }
20
-
21
- const InlineErrorText: React.FC<InlineMessageProps> = ({ message, inlineType, config }) => {
22
- const { InputInlineMessage } = useTheme()
23
- const style = StyleSheet.create({
24
- container: {
25
- flexDirection: 'row',
26
- alignContent: 'center',
27
- marginVertical: 5,
28
- paddingRight: 20,
29
- },
30
- icon: { marginRight: 4 },
31
- })
32
-
33
- const color =
34
- inlineType === InlineErrorType.warning
35
- ? InputInlineMessage.inlineWarningText.color
36
- : InputInlineMessage.inlineErrorText.color
37
-
38
- const props: SvgProps = { height: 24, width: 24, color: color, style: style.icon }
39
-
40
- const getInlineErrorIcon = () => {
41
- if (!config.hasErrorIcon) return null
42
-
43
- if (inlineType === InlineErrorType.warning) {
44
- return <InputInlineMessage.InlineWarningIcon {...props} />
45
- } else {
46
- return <InputInlineMessage.InlineErrorIcon {...props} />
47
- }
48
- }
49
-
50
- return (
51
- <View style={[style.container, config.style]}>
52
- {getInlineErrorIcon()}
53
- <ThemedText style={[InputInlineMessage.inlineErrorText]} testID={testIdWithKey('InlineErrorText')}>
54
- {message}
55
- </ThemedText>
56
- </View>
57
- )
58
- }
59
-
60
- export default InlineErrorText
@@ -1,71 +0,0 @@
1
- import React, { useEffect, useState } from 'react'
2
- import { View, StyleSheet, TextInput, TextInputProps } from 'react-native'
3
-
4
- import { useTheme } from '../../contexts/theme'
5
- import { ThemedText } from '../texts/ThemedText'
6
-
7
- interface LimitedTextInputProps extends TextInputProps {
8
- showLimitCounter?: boolean
9
- label: string
10
- limit: number
11
- handleChangeText: (text: string) => void
12
- }
13
-
14
- const LimitedTextInput: React.FC<LimitedTextInputProps> = ({
15
- showLimitCounter = true,
16
- label,
17
- limit,
18
- handleChangeText,
19
- ...textInputProps
20
- }) => {
21
- const [focused, setFocused] = useState(false)
22
- const [characterCount, setCharacterCount] = useState(0)
23
- const { Inputs, TextTheme, maxFontSizeMultiplier } = useTheme()
24
- const styles = StyleSheet.create({
25
- container: {
26
- marginVertical: 10,
27
- width: '100%',
28
- },
29
- textInput: {
30
- ...Inputs.textInput,
31
- },
32
- limitCounter: {
33
- color: TextTheme.normal.color,
34
- alignSelf: 'flex-end',
35
- },
36
- })
37
-
38
- useEffect(() => {
39
- if (textInputProps.defaultValue?.length) {
40
- setCharacterCount(textInputProps.defaultValue.length)
41
- }
42
- }, [textInputProps.defaultValue])
43
-
44
- const onChangeText = (text: string) => {
45
- setCharacterCount(text.length)
46
- handleChangeText(text)
47
- }
48
-
49
- return (
50
- <View style={styles.container}>
51
- <ThemedText style={{ marginBottom: 5 }}>{label}</ThemedText>
52
- <TextInput
53
- maxLength={limit}
54
- maxFontSizeMultiplier={maxFontSizeMultiplier}
55
- style={[styles.textInput, focused && { ...Inputs.inputSelected }]}
56
- selectionColor={Inputs.inputSelected.borderColor}
57
- onFocus={() => setFocused(true)}
58
- onBlur={() => setFocused(false)}
59
- onChangeText={onChangeText}
60
- {...textInputProps}
61
- />
62
- {showLimitCounter && (
63
- <ThemedText style={styles.limitCounter}>
64
- {characterCount}/{limit}
65
- </ThemedText>
66
- )}
67
- </View>
68
- )
69
- }
70
-
71
- export default LimitedTextInput
@@ -1,175 +0,0 @@
1
- import React, { useState, forwardRef, Ref, useMemo } from 'react'
2
- import { useTranslation } from 'react-i18next'
3
- import { StyleSheet, TextInput, TouchableOpacity, View } from 'react-native'
4
- import { CodeField, Cursor, useClearByFocusCell } from 'react-native-confirmation-code-field'
5
- import Icon from 'react-native-vector-icons/MaterialIcons'
6
-
7
- import { hitSlop, minPINLength } from '../../constants'
8
- import { useTheme } from '../../contexts/theme'
9
- import { testIdWithKey } from '../../utils/testable'
10
- import InlineErrorText, { InlineMessageProps } from './InlineErrorText'
11
- import { InlineErrorPosition } from '../../types/error'
12
- import { ThemedText } from '../texts/ThemedText'
13
-
14
- // adjusting for the spaces between numbers
15
- const cellCount = minPINLength * 2 - 1
16
-
17
- interface PINInputProps {
18
- label?: string
19
- onPINChanged?: (PIN: string) => void
20
- testID?: string
21
- accessibilityLabel?: string
22
- autoFocus?: boolean
23
- inlineMessage?: InlineMessageProps
24
- onSubmitEditing?: () => void
25
- }
26
-
27
- const PINInputComponent = (
28
- { label, onPINChanged, testID, accessibilityLabel, autoFocus = false, inlineMessage, onSubmitEditing }: PINInputProps,
29
- ref: Ref<TextInput>
30
- ) => {
31
- const [PIN, setPIN] = useState('')
32
- const [showPIN, setShowPIN] = useState(false)
33
- const { t } = useTranslation()
34
- const { PINInputTheme } = useTheme()
35
- const cellHeight = 48
36
-
37
- // including spaces to prevent screen reader from reading the PIN as a single number
38
- // filling with bullets when masked to prevent screen reader from reading the actual PIN
39
- // and to have the proper appearance when the PIN is masked
40
- const displayValue = useMemo(() => {
41
- if (showPIN) {
42
- return PIN.split('').join(' ')
43
- } else {
44
- return '●'.repeat(PIN.length).split('').join(' ')
45
- }
46
- }, [PIN, showPIN])
47
-
48
- const onChangeText = (value: string) => {
49
- const cleanValue = value.replaceAll(' ', '')
50
- // typed new characters
51
- if (cleanValue.length > PIN.length) {
52
- // add new characters to the actual PIN
53
- const newChars = cleanValue.slice(PIN.length)
54
- const newPIN = PIN + newChars.replace(/●/g, '')
55
- setPIN(newPIN)
56
- onPINChanged && onPINChanged(newPIN)
57
- // characters were removed
58
- } else if (cleanValue.length < displayValue.replaceAll(' ', '').length) {
59
- // remove same number of characters from actual PIN
60
- const newPIN = PIN.slice(0, cleanValue.length)
61
- setPIN(newPIN)
62
- onPINChanged && onPINChanged(newPIN)
63
- }
64
- }
65
-
66
- const [props, getCellOnLayoutHandler] = useClearByFocusCell({
67
- value: displayValue,
68
- setValue: onChangeText,
69
- })
70
-
71
- const allyLabel = useMemo(() => {
72
- return showPIN ? accessibilityLabel : t('PINCreate.Masked')
73
- }, [accessibilityLabel, showPIN, t])
74
-
75
- const style = StyleSheet.create({
76
- container: {
77
- flexDirection: 'column',
78
- marginBottom: 24,
79
- },
80
- codeFieldContainer: {
81
- flex: 1,
82
- },
83
- cell: {
84
- height: cellHeight,
85
- paddingHorizontal: 2,
86
- backgroundColor: PINInputTheme.cell.backgroundColor,
87
- },
88
- cellText: {
89
- color: PINInputTheme.cellText.color,
90
- textAlign: 'center',
91
- lineHeight: cellHeight,
92
- },
93
- hideIcon: {
94
- paddingHorizontal: 10,
95
- },
96
- })
97
-
98
- const content = () => (
99
- <View style={PINInputTheme.labelAndFieldContainer}>
100
- <View style={style.codeFieldContainer}>
101
- <CodeField
102
- {...props}
103
- testID={testID}
104
- accessibilityLabel={allyLabel}
105
- accessibilityRole={'text'}
106
- accessible
107
- value={displayValue}
108
- rootStyle={PINInputTheme.codeFieldRoot}
109
- onChangeText={onChangeText}
110
- cellCount={cellCount}
111
- keyboardType="number-pad"
112
- textContentType="password"
113
- renderCell={({ index, symbol, isFocused }) => {
114
- let child: React.ReactNode | string = ''
115
- // skip spaces
116
- if (symbol && symbol !== ' ') {
117
- child = symbol
118
- } else if (isFocused) {
119
- child = <Cursor />
120
- }
121
- return (
122
- <View key={index} style={style.cell} onLayout={getCellOnLayoutHandler(index)}>
123
- <ThemedText variant="headingThree" style={style.cellText} maxFontSizeMultiplier={1}>
124
- {child}
125
- </ThemedText>
126
- </View>
127
- )
128
- }}
129
- autoFocus={autoFocus}
130
- ref={ref}
131
- onSubmitEditing={onSubmitEditing}
132
- />
133
- </View>
134
- <TouchableOpacity
135
- style={style.hideIcon}
136
- accessibilityLabel={showPIN ? t('PINCreate.Hide') : t('PINCreate.Show')}
137
- accessibilityRole={'button'}
138
- testID={showPIN ? testIdWithKey('Hide') : testIdWithKey('Show')}
139
- onPress={() => setShowPIN(!showPIN)}
140
- hitSlop={hitSlop}
141
- >
142
- <Icon color={PINInputTheme.icon.color} name={showPIN ? 'visibility-off' : 'visibility'} size={30} />
143
- </TouchableOpacity>
144
- </View>
145
- )
146
-
147
- return (
148
- <View style={style.container}>
149
- {label && (
150
- <ThemedText variant="label" style={{ marginBottom: 8 }}>
151
- {label}
152
- </ThemedText>
153
- )}
154
- {inlineMessage?.config.position === InlineErrorPosition.Above ? (
155
- <InlineErrorText
156
- message={inlineMessage.message}
157
- inlineType={inlineMessage.inlineType}
158
- config={inlineMessage.config}
159
- />
160
- ) : null}
161
- {content()}
162
- {inlineMessage?.config.position === InlineErrorPosition.Below ? (
163
- <InlineErrorText
164
- message={inlineMessage.message}
165
- inlineType={inlineMessage.inlineType}
166
- config={inlineMessage.config}
167
- />
168
- ) : null}
169
- </View>
170
- )
171
- }
172
-
173
- const PINInput = forwardRef<TextInput, PINInputProps>(PINInputComponent)
174
-
175
- export default PINInput
@@ -1,53 +0,0 @@
1
- import React, { useState } from 'react'
2
- import { StyleSheet, TouchableOpacity, View } from 'react-native'
3
- import Icon from 'react-native-vector-icons/MaterialIcons'
4
-
5
- import { hitSlop } from '../../constants'
6
- import { useTheme } from '../../contexts/theme'
7
- import { ThemedText } from '../texts/ThemedText'
8
-
9
- export interface BlockSelection {
10
- value: string
11
- id: string
12
- }
13
-
14
- interface Props {
15
- selection: BlockSelection[]
16
- onSelect: (selected: BlockSelection) => void
17
- initialSelect?: BlockSelection
18
- }
19
-
20
- const SingleSelectBlock: React.FC<Props> = ({ selection, onSelect, initialSelect }) => {
21
- const [selected, setSelected] = useState(initialSelect ?? selection[0])
22
- const { Inputs } = useTheme()
23
- const styles = StyleSheet.create({
24
- container: {
25
- width: '100%',
26
- padding: 20,
27
- },
28
- row: {
29
- ...Inputs.singleSelect,
30
- flexDirection: 'row',
31
- alignItems: 'center',
32
- justifyContent: 'space-between',
33
- marginBottom: 8,
34
- },
35
- })
36
- const handleSelect = (selected: BlockSelection) => {
37
- setSelected(selected)
38
- onSelect(selected)
39
- }
40
-
41
- return (
42
- <View style={styles.container}>
43
- {selection.map((item) => (
44
- <TouchableOpacity key={item.id} style={styles.row} onPress={() => handleSelect(item)} hitSlop={hitSlop}>
45
- <ThemedText style={Inputs.singleSelectText}>{item.value}</ThemedText>
46
- {item.id === selected.id ? <Icon name={'check'} size={25} color={Inputs.singleSelectIcon.color} /> : null}
47
- </TouchableOpacity>
48
- ))}
49
- </View>
50
- )
51
- }
52
-
53
- export default SingleSelectBlock
@@ -1,79 +0,0 @@
1
- import { CredentialExchangeRecord } from '@credo-ts/core'
2
- import { useTheme } from '../../contexts/theme'
3
- import { TouchableOpacity, View, StyleSheet } from 'react-native'
4
- import { useBranding } from '../../hooks/bundle-resolver'
5
- import { useTranslation } from 'react-i18next'
6
- import { getCredentialIdentifiers } from '../../utils/credential'
7
- import { useCredentialConnectionLabel } from '../../utils/helpers'
8
- import { CredentialOverlay } from '@bifold/oca/build/legacy'
9
- import { BaseOverlay, BrandingOverlay, LegacyBrandingOverlay } from '@bifold/oca'
10
- import { useMemo } from 'react'
11
- import { ThemedText } from '../texts/ThemedText'
12
-
13
- export type ContactCredentialListItemProps = {
14
- credential: CredentialExchangeRecord
15
- onPress: () => void
16
- }
17
-
18
- const ContactCredentialListItem = ({ credential, onPress }: ContactCredentialListItemProps) => {
19
- const { Assets, ColorPalette } = useTheme()
20
- const { t, i18n } = useTranslation()
21
- const credentialConnectionLabel = useCredentialConnectionLabel(credential)
22
- const params = useMemo(
23
- () => ({
24
- identifiers: getCredentialIdentifiers(credential),
25
- attributes: credential.credentialAttributes,
26
- meta: {
27
- credConnectionId: credential.connectionId,
28
- alias: credentialConnectionLabel,
29
- },
30
- language: i18n.language,
31
- }),
32
- [credential, credentialConnectionLabel, i18n.language]
33
- )
34
- const { overlay } = useBranding<CredentialOverlay<BrandingOverlay | BaseOverlay | LegacyBrandingOverlay>>(params)
35
-
36
- const styles = StyleSheet.create({
37
- container: {
38
- flexDirection: 'row',
39
- alignItems: 'center',
40
- justifyContent: 'space-between',
41
- },
42
- credentialContainer: {
43
- flex: 9,
44
- },
45
- credentialName: {
46
- color: ColorPalette.brand.primary,
47
- fontWeight: '600',
48
- },
49
- iconContainer: {
50
- flex: 1,
51
- padding: 8,
52
- },
53
- })
54
-
55
- const icon = {
56
- color: ColorPalette.brand.primary,
57
- width: 48,
58
- height: 48,
59
- }
60
-
61
- return (
62
- <TouchableOpacity
63
- onPress={onPress}
64
- style={styles.container}
65
- accessibilityHint={t('ContactDetails.GoToCredentialDetail')}
66
- accessibilityLabel={`${t('ContactDetails.CredentialName')}: ${overlay?.metaOverlay?.name}`}
67
- accessibilityRole={'button'}
68
- >
69
- <View style={styles.credentialContainer}>
70
- <ThemedText style={styles.credentialName}>{overlay?.metaOverlay?.name}</ThemedText>
71
- </View>
72
- <View style={styles.iconContainer}>
73
- <Assets.svg.iconChevronRight {...icon} />
74
- </View>
75
- </TouchableOpacity>
76
- )
77
- }
78
-
79
- export default ContactCredentialListItem
@@ -1,121 +0,0 @@
1
- import type { ConnectionRecord } from '@credo-ts/core'
2
-
3
- import { StackNavigationProp } from '@react-navigation/stack'
4
- import React, { useCallback, useMemo } from 'react'
5
- import { View, StyleSheet, TouchableOpacity, Image } from 'react-native'
6
-
7
- import { useStore } from '../../contexts/store'
8
- import { useTheme } from '../../contexts/theme'
9
- import { useChatMessagesByConnection } from '../../hooks/chat-messages'
10
- import { ContactStackParams, Screens, Stacks } from '../../types/navigators'
11
- import { formatTime, getConnectionName } from '../../utils/helpers'
12
- import { testIdWithKey } from '../../utils/testable'
13
- import { TOKENS, useServices } from '../../container-api'
14
- import { ThemedText } from '../texts/ThemedText'
15
-
16
- export interface ContactListItemProps {
17
- contact: ConnectionRecord
18
- navigation: StackNavigationProp<ContactStackParams, Screens.Contacts>
19
- }
20
-
21
- const ContactListItem: React.FC<ContactListItemProps> = ({ contact, navigation }) => {
22
- const { ColorPalette, ListItems } = useTheme()
23
- const messages = useChatMessagesByConnection(contact)
24
- const message = messages[0]
25
- const hasOnlyInitialMessage = messages.length < 2
26
- const [store] = useStore()
27
- const [{ enableChat }] = useServices([TOKENS.CONFIG])
28
-
29
- const styles = StyleSheet.create({
30
- container: {
31
- flexDirection: 'row',
32
- padding: 16,
33
- backgroundColor: ColorPalette.brand.secondaryBackground,
34
- },
35
- avatarContainer: {
36
- alignItems: 'center',
37
- justifyContent: 'center',
38
- width: 50,
39
- height: 50,
40
- borderRadius: 25,
41
- borderColor: ListItems.avatarCircle.borderColor,
42
- borderWidth: 1,
43
- marginRight: 16,
44
- },
45
- avatarPlaceholder: {
46
- textAlign: 'center',
47
- },
48
- avatarImage: {
49
- width: 30,
50
- height: 30,
51
- },
52
- contactNameContainer: {
53
- flex: 1,
54
- paddingVertical: 4,
55
- },
56
- nameAndTimeContainer: {
57
- flexDirection: 'row',
58
- justifyContent: 'space-between',
59
- flex: 1,
60
- },
61
- timeContainer: {
62
- paddingVertical: 4,
63
- alignSelf: 'center',
64
- },
65
- })
66
-
67
- const navigateToContact = useCallback(() => {
68
- navigation.getParent()?.navigate(Stacks.ContactStack, {
69
- screen: enableChat ? Screens.Chat : Screens.ContactDetails,
70
- params: { connectionId: contact.id },
71
- })
72
- }, [navigation, contact, enableChat])
73
-
74
- const contactLabel = useMemo(
75
- () => getConnectionName(contact, store.preferences.alternateContactNames),
76
- [contact, store.preferences.alternateContactNames]
77
- )
78
- const contactLabelAbbr = useMemo(() => contactLabel?.charAt(0).toUpperCase(), [contactLabel])
79
-
80
- return (
81
- <TouchableOpacity
82
- onPress={navigateToContact}
83
- testID={testIdWithKey('Contact')}
84
- accessibilityLabel={contactLabel}
85
- accessibilityRole="button"
86
- >
87
- <View style={styles.container}>
88
- <View style={styles.avatarContainer}>
89
- {contact.imageUrl ? (
90
- <View>
91
- <Image style={styles.avatarImage} source={{ uri: contact.imageUrl }} />
92
- </View>
93
- ) : (
94
- <ThemedText allowFontScaling={false} variant="headingFour" style={styles.avatarPlaceholder}>
95
- {contactLabelAbbr}
96
- </ThemedText>
97
- )}
98
- </View>
99
- <View style={{ flex: 1 }}>
100
- <View style={styles.nameAndTimeContainer}>
101
- <View style={styles.contactNameContainer}>
102
- <ThemedText variant="labelTitle">{contactLabel}</ThemedText>
103
- </View>
104
- <View style={styles.timeContainer}>
105
- {message && <ThemedText>{formatTime(message.createdAt, { shortMonth: true, trim: true })}</ThemedText>}
106
- </View>
107
- </View>
108
- <View>
109
- {message && !hasOnlyInitialMessage && (
110
- <ThemedText numberOfLines={1} ellipsizeMode={'tail'}>
111
- {message.text}
112
- </ThemedText>
113
- )}
114
- </View>
115
- </View>
116
- </View>
117
- </TouchableOpacity>
118
- )
119
- }
120
-
121
- export default ContactListItem