@onairos/react-native 3.1.12 → 3.1.14

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 (604) hide show
  1. package/README.md +403 -374
  2. package/lib/commonjs/api/index.js +75 -1
  3. package/lib/commonjs/api/index.js.map +1 -1
  4. package/lib/commonjs/assets/fonts/EBGaramond-VariableFont_wght.ttf +0 -0
  5. package/lib/commonjs/assets/fonts/IBMPlexSans-VariableFont_wdth,wght.ttf +0 -0
  6. package/lib/commonjs/assets/icons/Facebookicon.png +0 -0
  7. package/lib/commonjs/assets/icons/Gmail.png +0 -0
  8. package/lib/commonjs/assets/icons/Linkedinicon.png +0 -0
  9. package/lib/commonjs/assets/icons/Redditicon.png +0 -0
  10. package/lib/commonjs/assets/icons/YouTubeicon2.png +0 -0
  11. package/lib/commonjs/assets/icons/YouTubeicon3.png +0 -0
  12. package/lib/commonjs/assets/icons/farcaster.png +0 -0
  13. package/lib/commonjs/assets/icons/instagram.png +0 -0
  14. package/lib/commonjs/assets/icons/pinterest.png +0 -0
  15. package/lib/commonjs/assets/icons/swerv_logo.png +0 -0
  16. package/lib/commonjs/assets/icons/twitter.jpg +0 -0
  17. package/lib/commonjs/assets/images/Checkbox.svg +3 -0
  18. package/lib/commonjs/assets/images/EnochE.svg +19 -0
  19. package/lib/commonjs/assets/images/Enochicon1.png +0 -0
  20. package/lib/commonjs/assets/images/Face_ID_logo.png +0 -0
  21. package/lib/commonjs/assets/images/Facebookicon.png +0 -0
  22. package/lib/commonjs/assets/images/Gmail.png +0 -0
  23. package/lib/commonjs/assets/images/Googlelogo.png +0 -0
  24. package/lib/commonjs/assets/images/Linkedinicon.png +0 -0
  25. package/lib/commonjs/assets/images/Onairoslogo.png +0 -0
  26. package/lib/commonjs/assets/images/Personalityprofile.svg +3 -0
  27. package/lib/commonjs/assets/images/Personalitytraits.svg +3 -0
  28. package/lib/commonjs/assets/images/Redditicon.png +0 -0
  29. package/lib/commonjs/assets/images/Userpreferences.svg +3 -0
  30. package/lib/commonjs/assets/images/YouTubeicon3.png +0 -0
  31. package/lib/commonjs/assets/images/arrow.svg +20 -0
  32. package/lib/commonjs/assets/images/basicproficon.svg +43 -0
  33. package/lib/commonjs/assets/images/basicprofile.svg +3 -0
  34. package/lib/commonjs/assets/images/checkmark.svg +4 -0
  35. package/lib/commonjs/assets/images/contentanalysis.svg +3 -0
  36. package/lib/commonjs/assets/images/contenticon.svg +23 -0
  37. package/lib/commonjs/assets/images/persona1.png +0 -0
  38. package/lib/commonjs/assets/images/persona2.png +0 -0
  39. package/lib/commonjs/assets/images/persona3.png +0 -0
  40. package/lib/commonjs/assets/images/persona4.png +0 -0
  41. package/lib/commonjs/assets/images/persona5.png +0 -0
  42. package/lib/commonjs/assets/images/personalityicon.svg +18 -0
  43. package/lib/commonjs/assets/images/x-close.svg +3 -0
  44. package/lib/commonjs/components/BodyText.js +27 -0
  45. package/lib/commonjs/components/BodyText.js.map +1 -0
  46. package/lib/commonjs/components/BrandMark.js +44 -0
  47. package/lib/commonjs/components/BrandMark.js.map +1 -0
  48. package/lib/commonjs/components/CodeInput.js +30 -0
  49. package/lib/commonjs/components/CodeInput.js.map +1 -0
  50. package/lib/commonjs/components/EmailInput.js +30 -0
  51. package/lib/commonjs/components/EmailInput.js.map +1 -0
  52. package/lib/commonjs/components/ExistingUserDataConfirmation.js +474 -0
  53. package/lib/commonjs/components/ExistingUserDataConfirmation.js.map +1 -0
  54. package/lib/commonjs/components/GoogleButton.js +55 -0
  55. package/lib/commonjs/components/GoogleButton.js.map +1 -0
  56. package/lib/commonjs/components/HeadingGroup.js +43 -0
  57. package/lib/commonjs/components/HeadingGroup.js.map +1 -0
  58. package/lib/commonjs/components/ModalHeader.js +99 -0
  59. package/lib/commonjs/components/ModalHeader.js.map +1 -0
  60. package/lib/commonjs/components/ModalSheet.js +41 -0
  61. package/lib/commonjs/components/ModalSheet.js.map +1 -0
  62. package/lib/commonjs/components/Onairos.js +1 -3
  63. package/lib/commonjs/components/Onairos.js.map +1 -1
  64. package/lib/commonjs/components/OnairosButton.js +171 -190
  65. package/lib/commonjs/components/OnairosButton.js.map +1 -1
  66. package/lib/commonjs/components/OnairosSignInButton.js +169 -0
  67. package/lib/commonjs/components/OnairosSignInButton.js.map +1 -0
  68. package/lib/commonjs/components/Overlay.js +5 -5
  69. package/lib/commonjs/components/Overlay.js.map +1 -1
  70. package/lib/commonjs/components/PersonaImage.js +60 -0
  71. package/lib/commonjs/components/PersonaImage.js.map +1 -0
  72. package/lib/commonjs/components/PersonaLoadingScreen.js +156 -0
  73. package/lib/commonjs/components/PersonaLoadingScreen.js.map +1 -0
  74. package/lib/commonjs/components/PersonalizationConsentScreen.js +316 -0
  75. package/lib/commonjs/components/PersonalizationConsentScreen.js.map +1 -0
  76. package/lib/commonjs/components/PinCreationScreen.js +393 -0
  77. package/lib/commonjs/components/PinCreationScreen.js.map +1 -0
  78. package/lib/commonjs/components/PinInput.js +282 -120
  79. package/lib/commonjs/components/PinInput.js.map +1 -1
  80. package/lib/commonjs/components/PlatformConnectorsStep.js +828 -0
  81. package/lib/commonjs/components/PlatformConnectorsStep.js.map +1 -0
  82. package/lib/commonjs/components/PlatformToggle.js +180 -0
  83. package/lib/commonjs/components/PlatformToggle.js.map +1 -0
  84. package/lib/commonjs/components/PrimaryButton.js +180 -0
  85. package/lib/commonjs/components/PrimaryButton.js.map +1 -0
  86. package/lib/commonjs/components/SignInMatchAnimation.js +197 -0
  87. package/lib/commonjs/components/SignInMatchAnimation.js.map +1 -0
  88. package/lib/commonjs/components/SignInStep.js +179 -0
  89. package/lib/commonjs/components/SignInStep.js.map +1 -0
  90. package/lib/commonjs/components/TrainingModal.js +808 -563
  91. package/lib/commonjs/components/TrainingModal.js.map +1 -1
  92. package/lib/commonjs/components/UniversalOnboarding.js +2304 -1283
  93. package/lib/commonjs/components/UniversalOnboarding.js.map +1 -1
  94. package/lib/commonjs/components/VerificationStep.js +154 -0
  95. package/lib/commonjs/components/VerificationStep.js.map +1 -0
  96. package/lib/commonjs/components/WelcomeScreen.js +385 -0
  97. package/lib/commonjs/components/WelcomeScreen.js.map +1 -0
  98. package/lib/commonjs/components/icons/Basicproficon.js +37 -0
  99. package/lib/commonjs/components/icons/Basicproficon.js.map +1 -0
  100. package/lib/commonjs/components/icons/Basicprofile.js +21 -0
  101. package/lib/commonjs/components/icons/Basicprofile.js.map +1 -0
  102. package/lib/commonjs/components/icons/Checkbox.js +21 -0
  103. package/lib/commonjs/components/icons/Checkbox.js.map +1 -0
  104. package/lib/commonjs/components/icons/Checkmark.js +27 -0
  105. package/lib/commonjs/components/icons/Checkmark.js.map +1 -0
  106. package/lib/commonjs/components/icons/Contentanalysis.js +21 -0
  107. package/lib/commonjs/components/icons/Contentanalysis.js.map +1 -0
  108. package/lib/commonjs/components/icons/Contenticon.js +39 -0
  109. package/lib/commonjs/components/icons/Contenticon.js.map +1 -0
  110. package/lib/commonjs/components/icons/EnochE.js +41 -0
  111. package/lib/commonjs/components/icons/EnochE.js.map +1 -0
  112. package/lib/commonjs/components/icons/Personalityicon.js +30 -0
  113. package/lib/commonjs/components/icons/Personalityicon.js.map +1 -0
  114. package/lib/commonjs/components/icons/Personalityprofile.js +21 -0
  115. package/lib/commonjs/components/icons/Personalityprofile.js.map +1 -0
  116. package/lib/commonjs/components/icons/Personalitytraits.js +21 -0
  117. package/lib/commonjs/components/icons/Personalitytraits.js.map +1 -0
  118. package/lib/commonjs/components/icons/Userpreferences.js +21 -0
  119. package/lib/commonjs/components/icons/Userpreferences.js.map +1 -0
  120. package/lib/commonjs/components/icons/index.js +84 -0
  121. package/lib/commonjs/components/icons/index.js.map +1 -0
  122. package/lib/commonjs/components/onboarding/OAuthWebView.js +134 -743
  123. package/lib/commonjs/components/onboarding/OAuthWebView.js.map +1 -1
  124. package/lib/commonjs/config/api.js +34 -0
  125. package/lib/commonjs/config/api.js.map +1 -0
  126. package/lib/commonjs/context/AuthContext.js +345 -0
  127. package/lib/commonjs/context/AuthContext.js.map +1 -0
  128. package/lib/commonjs/hooks/useConnectedAccounts.js +111 -0
  129. package/lib/commonjs/hooks/useConnectedAccounts.js.map +1 -0
  130. package/lib/commonjs/hooks/useConnections.js +120 -125
  131. package/lib/commonjs/hooks/useConnections.js.map +1 -1
  132. package/lib/commonjs/hooks/useUserConnections.js +148 -0
  133. package/lib/commonjs/hooks/useUserConnections.js.map +1 -0
  134. package/lib/commonjs/index.js +12 -100
  135. package/lib/commonjs/index.js.map +1 -1
  136. package/lib/commonjs/services/apiClient.js +302 -0
  137. package/lib/commonjs/services/apiClient.js.map +1 -0
  138. package/lib/commonjs/services/apiKeyService.js +8 -9
  139. package/lib/commonjs/services/apiKeyService.js.map +1 -1
  140. package/lib/commonjs/services/authService.js +935 -0
  141. package/lib/commonjs/services/authService.js.map +1 -0
  142. package/lib/commonjs/services/biometricPinService.js +184 -0
  143. package/lib/commonjs/services/biometricPinService.js.map +1 -0
  144. package/lib/commonjs/services/connectedAccountsService.js +268 -0
  145. package/lib/commonjs/services/connectedAccountsService.js.map +1 -0
  146. package/lib/commonjs/services/googleAuthService.js +268 -0
  147. package/lib/commonjs/services/googleAuthService.js.map +1 -0
  148. package/lib/commonjs/services/imageCompressionService.js +260 -0
  149. package/lib/commonjs/services/imageCompressionService.js.map +1 -0
  150. package/lib/commonjs/services/jwtStorageService.js +256 -0
  151. package/lib/commonjs/services/jwtStorageService.js.map +1 -0
  152. package/lib/commonjs/services/mobileTrainingService.js +185 -0
  153. package/lib/commonjs/services/mobileTrainingService.js.map +1 -0
  154. package/lib/commonjs/services/pinEncryptionService.js +84 -0
  155. package/lib/commonjs/services/pinEncryptionService.js.map +1 -0
  156. package/lib/commonjs/services/pinStorageUtils.js +105 -0
  157. package/lib/commonjs/services/pinStorageUtils.js.map +1 -0
  158. package/lib/commonjs/services/platformAuthService.js +956 -722
  159. package/lib/commonjs/services/platformAuthService.js.map +1 -1
  160. package/lib/commonjs/services/storageService.js +404 -0
  161. package/lib/commonjs/services/storageService.js.map +1 -0
  162. package/lib/commonjs/services/trainingApiHelpers.js +73 -0
  163. package/lib/commonjs/services/trainingApiHelpers.js.map +1 -0
  164. package/lib/commonjs/services/userConnectionsService.js +486 -0
  165. package/lib/commonjs/services/userConnectionsService.js.map +1 -0
  166. package/lib/commonjs/services/youtubeMigrationService.js +415 -0
  167. package/lib/commonjs/services/youtubeMigrationService.js.map +1 -0
  168. package/lib/commonjs/theme/index.js +249 -0
  169. package/lib/commonjs/theme/index.js.map +1 -0
  170. package/lib/commonjs/utils/eventUtils.js +288 -0
  171. package/lib/commonjs/utils/eventUtils.js.map +1 -0
  172. package/lib/commonjs/utils/haptics.js +66 -0
  173. package/lib/commonjs/utils/haptics.js.map +1 -0
  174. package/lib/commonjs/utils/imagePreloader.js +6 -0
  175. package/lib/commonjs/utils/imagePreloader.js.map +1 -0
  176. package/lib/module/api/index.js +72 -0
  177. package/lib/module/api/index.js.map +1 -1
  178. package/lib/module/assets/fonts/EBGaramond-VariableFont_wght.ttf +0 -0
  179. package/lib/module/assets/fonts/IBMPlexSans-VariableFont_wdth,wght.ttf +0 -0
  180. package/lib/module/assets/icons/Facebookicon.png +0 -0
  181. package/lib/module/assets/icons/Gmail.png +0 -0
  182. package/lib/module/assets/icons/Linkedinicon.png +0 -0
  183. package/lib/module/assets/icons/Redditicon.png +0 -0
  184. package/lib/module/assets/icons/YouTubeicon2.png +0 -0
  185. package/lib/module/assets/icons/YouTubeicon3.png +0 -0
  186. package/lib/module/assets/icons/farcaster.png +0 -0
  187. package/lib/module/assets/icons/instagram.png +0 -0
  188. package/lib/module/assets/icons/pinterest.png +0 -0
  189. package/lib/module/assets/icons/swerv_logo.png +0 -0
  190. package/lib/module/assets/icons/twitter.jpg +0 -0
  191. package/lib/module/assets/images/Checkbox.svg +3 -0
  192. package/lib/module/assets/images/EnochE.svg +19 -0
  193. package/lib/module/assets/images/Enochicon1.png +0 -0
  194. package/lib/module/assets/images/Face_ID_logo.png +0 -0
  195. package/lib/module/assets/images/Facebookicon.png +0 -0
  196. package/lib/module/assets/images/Gmail.png +0 -0
  197. package/lib/module/assets/images/Googlelogo.png +0 -0
  198. package/lib/module/assets/images/Linkedinicon.png +0 -0
  199. package/lib/module/assets/images/Onairoslogo.png +0 -0
  200. package/lib/module/assets/images/Personalityprofile.svg +3 -0
  201. package/lib/module/assets/images/Personalitytraits.svg +3 -0
  202. package/lib/module/assets/images/Redditicon.png +0 -0
  203. package/lib/module/assets/images/Userpreferences.svg +3 -0
  204. package/lib/module/assets/images/YouTubeicon3.png +0 -0
  205. package/lib/module/assets/images/arrow.svg +20 -0
  206. package/lib/module/assets/images/basicproficon.svg +43 -0
  207. package/lib/module/assets/images/basicprofile.svg +3 -0
  208. package/lib/module/assets/images/checkmark.svg +4 -0
  209. package/lib/module/assets/images/contentanalysis.svg +3 -0
  210. package/lib/module/assets/images/contenticon.svg +23 -0
  211. package/lib/module/assets/images/persona1.png +0 -0
  212. package/lib/module/assets/images/persona2.png +0 -0
  213. package/lib/module/assets/images/persona3.png +0 -0
  214. package/lib/module/assets/images/persona4.png +0 -0
  215. package/lib/module/assets/images/persona5.png +0 -0
  216. package/lib/module/assets/images/personalityicon.svg +18 -0
  217. package/lib/module/assets/images/x-close.svg +3 -0
  218. package/lib/module/components/BodyText.js +20 -0
  219. package/lib/module/components/BodyText.js.map +1 -0
  220. package/lib/module/components/BrandMark.js +37 -0
  221. package/lib/module/components/BrandMark.js.map +1 -0
  222. package/lib/module/components/CodeInput.js +23 -0
  223. package/lib/module/components/CodeInput.js.map +1 -0
  224. package/lib/module/components/EmailInput.js +23 -0
  225. package/lib/module/components/EmailInput.js.map +1 -0
  226. package/lib/module/components/ExistingUserDataConfirmation.js +465 -0
  227. package/lib/module/components/ExistingUserDataConfirmation.js.map +1 -0
  228. package/lib/module/components/GoogleButton.js +48 -0
  229. package/lib/module/components/GoogleButton.js.map +1 -0
  230. package/lib/module/components/HeadingGroup.js +36 -0
  231. package/lib/module/components/HeadingGroup.js.map +1 -0
  232. package/lib/module/components/ModalHeader.js +92 -0
  233. package/lib/module/components/ModalHeader.js.map +1 -0
  234. package/lib/module/components/ModalSheet.js +34 -0
  235. package/lib/module/components/ModalSheet.js.map +1 -0
  236. package/lib/module/components/Onairos.js +1 -3
  237. package/lib/module/components/Onairos.js.map +1 -1
  238. package/lib/module/components/OnairosButton.js +172 -192
  239. package/lib/module/components/OnairosButton.js.map +1 -1
  240. package/lib/module/components/OnairosSignInButton.js +160 -0
  241. package/lib/module/components/OnairosSignInButton.js.map +1 -0
  242. package/lib/module/components/Overlay.js +5 -5
  243. package/lib/module/components/Overlay.js.map +1 -1
  244. package/lib/module/components/PersonaImage.js +53 -0
  245. package/lib/module/components/PersonaImage.js.map +1 -0
  246. package/lib/module/components/PersonaLoadingScreen.js +148 -0
  247. package/lib/module/components/PersonaLoadingScreen.js.map +1 -0
  248. package/lib/module/components/PersonalizationConsentScreen.js +309 -0
  249. package/lib/module/components/PersonalizationConsentScreen.js.map +1 -0
  250. package/lib/module/components/PinCreationScreen.js +386 -0
  251. package/lib/module/components/PinCreationScreen.js.map +1 -0
  252. package/lib/module/components/PinInput.js +283 -120
  253. package/lib/module/components/PinInput.js.map +1 -1
  254. package/lib/module/components/PlatformConnectorsStep.js +820 -0
  255. package/lib/module/components/PlatformConnectorsStep.js.map +1 -0
  256. package/lib/module/components/PlatformToggle.js +173 -0
  257. package/lib/module/components/PlatformToggle.js.map +1 -0
  258. package/lib/module/components/PrimaryButton.js +172 -0
  259. package/lib/module/components/PrimaryButton.js.map +1 -0
  260. package/lib/module/components/SignInMatchAnimation.js +189 -0
  261. package/lib/module/components/SignInMatchAnimation.js.map +1 -0
  262. package/lib/module/components/SignInStep.js +171 -0
  263. package/lib/module/components/SignInStep.js.map +1 -0
  264. package/lib/module/components/TrainingModal.js +809 -565
  265. package/lib/module/components/TrainingModal.js.map +1 -1
  266. package/lib/module/components/UniversalOnboarding.js +2307 -1284
  267. package/lib/module/components/UniversalOnboarding.js.map +1 -1
  268. package/lib/module/components/VerificationStep.js +146 -0
  269. package/lib/module/components/VerificationStep.js.map +1 -0
  270. package/lib/module/components/WelcomeScreen.js +378 -0
  271. package/lib/module/components/WelcomeScreen.js.map +1 -0
  272. package/lib/module/components/icons/Basicproficon.js +30 -0
  273. package/lib/module/components/icons/Basicproficon.js.map +1 -0
  274. package/lib/module/components/icons/Basicprofile.js +14 -0
  275. package/lib/module/components/icons/Basicprofile.js.map +1 -0
  276. package/lib/module/components/icons/Checkbox.js +14 -0
  277. package/lib/module/components/icons/Checkbox.js.map +1 -0
  278. package/lib/module/components/icons/Checkmark.js +20 -0
  279. package/lib/module/components/icons/Checkmark.js.map +1 -0
  280. package/lib/module/components/icons/Contentanalysis.js +14 -0
  281. package/lib/module/components/icons/Contentanalysis.js.map +1 -0
  282. package/lib/module/components/icons/Contenticon.js +32 -0
  283. package/lib/module/components/icons/Contenticon.js.map +1 -0
  284. package/lib/module/components/icons/EnochE.js +34 -0
  285. package/lib/module/components/icons/EnochE.js.map +1 -0
  286. package/lib/module/components/icons/Personalityicon.js +23 -0
  287. package/lib/module/components/icons/Personalityicon.js.map +1 -0
  288. package/lib/module/components/icons/Personalityprofile.js +14 -0
  289. package/lib/module/components/icons/Personalityprofile.js.map +1 -0
  290. package/lib/module/components/icons/Personalitytraits.js +14 -0
  291. package/lib/module/components/icons/Personalitytraits.js.map +1 -0
  292. package/lib/module/components/icons/Userpreferences.js +14 -0
  293. package/lib/module/components/icons/Userpreferences.js.map +1 -0
  294. package/lib/module/components/icons/index.js +13 -0
  295. package/lib/module/components/icons/index.js.map +1 -0
  296. package/lib/module/components/onboarding/OAuthWebView.js +136 -744
  297. package/lib/module/components/onboarding/OAuthWebView.js.map +1 -1
  298. package/lib/module/config/api.js +26 -0
  299. package/lib/module/config/api.js.map +1 -0
  300. package/lib/module/context/AuthContext.js +335 -0
  301. package/lib/module/context/AuthContext.js.map +1 -0
  302. package/lib/module/hooks/useConnectedAccounts.js +106 -0
  303. package/lib/module/hooks/useConnectedAccounts.js.map +1 -0
  304. package/lib/module/hooks/useConnections.js +119 -125
  305. package/lib/module/hooks/useConnections.js.map +1 -1
  306. package/lib/module/hooks/useUserConnections.js +140 -0
  307. package/lib/module/hooks/useUserConnections.js.map +1 -0
  308. package/lib/module/index.js +51 -15
  309. package/lib/module/index.js.map +1 -1
  310. package/lib/module/services/apiClient.js +298 -0
  311. package/lib/module/services/apiClient.js.map +1 -0
  312. package/lib/module/services/apiKeyService.js +8 -9
  313. package/lib/module/services/apiKeyService.js.map +1 -1
  314. package/lib/module/services/authService.js +905 -0
  315. package/lib/module/services/authService.js.map +1 -0
  316. package/lib/module/services/biometricPinService.js +173 -0
  317. package/lib/module/services/biometricPinService.js.map +1 -0
  318. package/lib/module/services/connectedAccountsService.js +255 -0
  319. package/lib/module/services/connectedAccountsService.js.map +1 -0
  320. package/lib/module/services/googleAuthService.js +258 -0
  321. package/lib/module/services/googleAuthService.js.map +1 -0
  322. package/lib/module/services/imageCompressionService.js +250 -0
  323. package/lib/module/services/imageCompressionService.js.map +1 -0
  324. package/lib/module/services/jwtStorageService.js +239 -0
  325. package/lib/module/services/jwtStorageService.js.map +1 -0
  326. package/lib/module/services/mobileTrainingService.js +172 -0
  327. package/lib/module/services/mobileTrainingService.js.map +1 -0
  328. package/lib/module/services/pinEncryptionService.js +75 -0
  329. package/lib/module/services/pinEncryptionService.js.map +1 -0
  330. package/lib/module/services/pinStorageUtils.js +93 -0
  331. package/lib/module/services/pinStorageUtils.js.map +1 -0
  332. package/lib/module/services/platformAuthService.js +943 -704
  333. package/lib/module/services/platformAuthService.js.map +1 -1
  334. package/lib/module/services/storageService.js +383 -0
  335. package/lib/module/services/storageService.js.map +1 -0
  336. package/lib/module/services/trainingApiHelpers.js +67 -0
  337. package/lib/module/services/trainingApiHelpers.js.map +1 -0
  338. package/lib/module/services/userConnectionsService.js +476 -0
  339. package/lib/module/services/userConnectionsService.js.map +1 -0
  340. package/lib/module/services/youtubeMigrationService.js +404 -0
  341. package/lib/module/services/youtubeMigrationService.js.map +1 -0
  342. package/lib/module/theme/index.js +244 -0
  343. package/lib/module/theme/index.js.map +1 -0
  344. package/lib/module/utils/eventUtils.js +270 -0
  345. package/lib/module/utils/eventUtils.js.map +1 -0
  346. package/lib/module/utils/haptics.js +59 -0
  347. package/lib/module/utils/haptics.js.map +1 -0
  348. package/lib/module/utils/imagePreloader.js +3 -0
  349. package/lib/module/utils/imagePreloader.js.map +1 -0
  350. package/lib/typescript/api/index.d.ts +8 -0
  351. package/lib/typescript/api/index.d.ts.map +1 -1
  352. package/lib/typescript/components/BodyText.d.ts +10 -0
  353. package/lib/typescript/components/BodyText.d.ts.map +1 -0
  354. package/lib/typescript/components/BrandMark.d.ts +11 -0
  355. package/lib/typescript/components/BrandMark.d.ts.map +1 -0
  356. package/lib/typescript/components/CodeInput.d.ts +10 -0
  357. package/lib/typescript/components/CodeInput.d.ts.map +1 -0
  358. package/lib/typescript/components/EmailInput.d.ts +8 -0
  359. package/lib/typescript/components/EmailInput.d.ts.map +1 -0
  360. package/lib/typescript/components/ExistingUserDataConfirmation.d.ts +12 -0
  361. package/lib/typescript/components/ExistingUserDataConfirmation.d.ts.map +1 -0
  362. package/lib/typescript/components/GoogleButton.d.ts +11 -0
  363. package/lib/typescript/components/GoogleButton.d.ts.map +1 -0
  364. package/lib/typescript/components/HeadingGroup.d.ts +11 -0
  365. package/lib/typescript/components/HeadingGroup.d.ts.map +1 -0
  366. package/lib/typescript/components/ModalHeader.d.ts +11 -0
  367. package/lib/typescript/components/ModalHeader.d.ts.map +1 -0
  368. package/lib/typescript/components/ModalSheet.d.ts +13 -0
  369. package/lib/typescript/components/ModalSheet.d.ts.map +1 -0
  370. package/lib/typescript/components/Onairos.d.ts.map +1 -1
  371. package/lib/typescript/components/OnairosButton.d.ts +29 -4
  372. package/lib/typescript/components/OnairosButton.d.ts.map +1 -1
  373. package/lib/typescript/components/OnairosSignInButton.d.ts +14 -0
  374. package/lib/typescript/components/OnairosSignInButton.d.ts.map +1 -0
  375. package/lib/typescript/components/PersonaImage.d.ts +8 -0
  376. package/lib/typescript/components/PersonaImage.d.ts.map +1 -0
  377. package/lib/typescript/components/PersonaLoadingScreen.d.ts +10 -0
  378. package/lib/typescript/components/PersonaLoadingScreen.d.ts.map +1 -0
  379. package/lib/typescript/components/PersonalizationConsentScreen.d.ts +10 -0
  380. package/lib/typescript/components/PersonalizationConsentScreen.d.ts.map +1 -0
  381. package/lib/typescript/components/PinCreationScreen.d.ts +10 -0
  382. package/lib/typescript/components/PinCreationScreen.d.ts.map +1 -0
  383. package/lib/typescript/components/PinInput.d.ts +11 -1
  384. package/lib/typescript/components/PinInput.d.ts.map +1 -1
  385. package/lib/typescript/components/PlatformConnectorsStep.d.ts +11 -0
  386. package/lib/typescript/components/PlatformConnectorsStep.d.ts.map +1 -0
  387. package/lib/typescript/components/PlatformToggle.d.ts +20 -0
  388. package/lib/typescript/components/PlatformToggle.d.ts.map +1 -0
  389. package/lib/typescript/components/PrimaryButton.d.ts +22 -0
  390. package/lib/typescript/components/PrimaryButton.d.ts.map +1 -0
  391. package/lib/typescript/components/SignInMatchAnimation.d.ts +9 -0
  392. package/lib/typescript/components/SignInMatchAnimation.d.ts.map +1 -0
  393. package/lib/typescript/components/SignInStep.d.ts +12 -0
  394. package/lib/typescript/components/SignInStep.d.ts.map +1 -0
  395. package/lib/typescript/components/TrainingModal.d.ts +12 -1
  396. package/lib/typescript/components/TrainingModal.d.ts.map +1 -1
  397. package/lib/typescript/components/UniversalOnboarding.d.ts +14 -1
  398. package/lib/typescript/components/UniversalOnboarding.d.ts.map +1 -1
  399. package/lib/typescript/components/VerificationStep.d.ts +13 -0
  400. package/lib/typescript/components/VerificationStep.d.ts.map +1 -0
  401. package/lib/typescript/components/WelcomeScreen.d.ts +9 -0
  402. package/lib/typescript/components/WelcomeScreen.d.ts.map +1 -0
  403. package/lib/typescript/components/icons/Basicproficon.d.ts +5 -0
  404. package/lib/typescript/components/icons/Basicproficon.d.ts.map +1 -0
  405. package/lib/typescript/components/icons/Basicprofile.d.ts +5 -0
  406. package/lib/typescript/components/icons/Basicprofile.d.ts.map +1 -0
  407. package/lib/typescript/components/icons/Checkbox.d.ts +5 -0
  408. package/lib/typescript/components/icons/Checkbox.d.ts.map +1 -0
  409. package/lib/typescript/components/icons/Checkmark.d.ts +5 -0
  410. package/lib/typescript/components/icons/Checkmark.d.ts.map +1 -0
  411. package/lib/typescript/components/icons/Contentanalysis.d.ts +5 -0
  412. package/lib/typescript/components/icons/Contentanalysis.d.ts.map +1 -0
  413. package/lib/typescript/components/icons/Contenticon.d.ts +5 -0
  414. package/lib/typescript/components/icons/Contenticon.d.ts.map +1 -0
  415. package/lib/typescript/components/icons/EnochE.d.ts +5 -0
  416. package/lib/typescript/components/icons/EnochE.d.ts.map +1 -0
  417. package/lib/typescript/components/icons/Personalityicon.d.ts +5 -0
  418. package/lib/typescript/components/icons/Personalityicon.d.ts.map +1 -0
  419. package/lib/typescript/components/icons/Personalityprofile.d.ts +5 -0
  420. package/lib/typescript/components/icons/Personalityprofile.d.ts.map +1 -0
  421. package/lib/typescript/components/icons/Personalitytraits.d.ts +5 -0
  422. package/lib/typescript/components/icons/Personalitytraits.d.ts.map +1 -0
  423. package/lib/typescript/components/icons/Userpreferences.d.ts +5 -0
  424. package/lib/typescript/components/icons/Userpreferences.d.ts.map +1 -0
  425. package/lib/typescript/components/icons/index.d.ts +12 -0
  426. package/lib/typescript/components/icons/index.d.ts.map +1 -0
  427. package/lib/typescript/components/onboarding/OAuthWebView.d.ts.map +1 -1
  428. package/lib/typescript/config/api.d.ts +24 -0
  429. package/lib/typescript/config/api.d.ts.map +1 -0
  430. package/lib/typescript/context/AuthContext.d.ts +34 -0
  431. package/lib/typescript/context/AuthContext.d.ts.map +1 -0
  432. package/lib/typescript/hooks/useConnectedAccounts.d.ts +11 -0
  433. package/lib/typescript/hooks/useConnectedAccounts.d.ts.map +1 -0
  434. package/lib/typescript/hooks/useConnections.d.ts +10 -5
  435. package/lib/typescript/hooks/useConnections.d.ts.map +1 -1
  436. package/lib/typescript/hooks/useUserConnections.d.ts +12 -0
  437. package/lib/typescript/hooks/useUserConnections.d.ts.map +1 -0
  438. package/lib/typescript/index.d.ts +24 -6
  439. package/lib/typescript/index.d.ts.map +1 -1
  440. package/lib/typescript/services/apiClient.d.ts +91 -0
  441. package/lib/typescript/services/apiClient.d.ts.map +1 -0
  442. package/lib/typescript/services/apiKeyService.d.ts.map +1 -1
  443. package/lib/typescript/services/authService.d.ts +216 -0
  444. package/lib/typescript/services/authService.d.ts.map +1 -0
  445. package/lib/typescript/services/biometricPinService.d.ts +29 -0
  446. package/lib/typescript/services/biometricPinService.d.ts.map +1 -0
  447. package/lib/typescript/services/connectedAccountsService.d.ts +56 -0
  448. package/lib/typescript/services/connectedAccountsService.d.ts.map +1 -0
  449. package/lib/typescript/services/googleAuthService.d.ts +63 -0
  450. package/lib/typescript/services/googleAuthService.d.ts.map +1 -0
  451. package/lib/typescript/services/imageCompressionService.d.ts +37 -0
  452. package/lib/typescript/services/imageCompressionService.d.ts.map +1 -0
  453. package/lib/typescript/services/jwtStorageService.d.ts +86 -0
  454. package/lib/typescript/services/jwtStorageService.d.ts.map +1 -0
  455. package/lib/typescript/services/mobileTrainingService.d.ts +45 -0
  456. package/lib/typescript/services/mobileTrainingService.d.ts.map +1 -0
  457. package/lib/typescript/services/pinEncryptionService.d.ts +17 -0
  458. package/lib/typescript/services/pinEncryptionService.d.ts.map +1 -0
  459. package/lib/typescript/services/pinStorageUtils.d.ts +25 -0
  460. package/lib/typescript/services/pinStorageUtils.d.ts.map +1 -0
  461. package/lib/typescript/services/platformAuthService.d.ts +34 -109
  462. package/lib/typescript/services/platformAuthService.d.ts.map +1 -1
  463. package/lib/typescript/services/storageService.d.ts +128 -0
  464. package/lib/typescript/services/storageService.d.ts.map +1 -0
  465. package/lib/typescript/services/trainingApiHelpers.d.ts +38 -0
  466. package/lib/typescript/services/trainingApiHelpers.d.ts.map +1 -0
  467. package/lib/typescript/services/userConnectionsService.d.ts +90 -0
  468. package/lib/typescript/services/userConnectionsService.d.ts.map +1 -0
  469. package/lib/typescript/services/youtubeMigrationService.d.ts +12 -0
  470. package/lib/typescript/services/youtubeMigrationService.d.ts.map +1 -0
  471. package/lib/typescript/theme/index.d.ts +416 -0
  472. package/lib/typescript/theme/index.d.ts.map +1 -0
  473. package/lib/typescript/types/index.d.ts +39 -0
  474. package/lib/typescript/types/index.d.ts.map +1 -1
  475. package/lib/typescript/utils/eventUtils.d.ts +108 -0
  476. package/lib/typescript/utils/eventUtils.d.ts.map +1 -0
  477. package/lib/typescript/utils/haptics.d.ts +11 -0
  478. package/lib/typescript/utils/haptics.d.ts.map +1 -0
  479. package/lib/typescript/utils/imagePreloader.d.ts +2 -0
  480. package/lib/typescript/utils/imagePreloader.d.ts.map +1 -0
  481. package/package.json +163 -145
  482. package/src/api/index.ts +41 -0
  483. package/src/assets/fonts/EBGaramond-VariableFont_wght.ttf +0 -0
  484. package/src/assets/fonts/IBMPlexSans-VariableFont_wdth,wght.ttf +0 -0
  485. package/src/assets/icons/Facebookicon.png +0 -0
  486. package/src/assets/icons/Gmail.png +0 -0
  487. package/src/assets/icons/Linkedinicon.png +0 -0
  488. package/src/assets/icons/Redditicon.png +0 -0
  489. package/src/assets/icons/YouTubeicon2.png +0 -0
  490. package/src/assets/icons/YouTubeicon3.png +0 -0
  491. package/src/assets/icons/farcaster.png +0 -0
  492. package/src/assets/icons/instagram.png +0 -0
  493. package/src/assets/icons/pinterest.png +0 -0
  494. package/src/assets/icons/swerv_logo.png +0 -0
  495. package/src/assets/icons/twitter.jpg +0 -0
  496. package/src/assets/images/Checkbox.svg +3 -0
  497. package/src/assets/images/EnochE.svg +19 -0
  498. package/src/assets/images/Enochicon1.png +0 -0
  499. package/src/assets/images/Face_ID_logo.png +0 -0
  500. package/src/assets/images/Facebookicon.png +0 -0
  501. package/src/assets/images/Gmail.png +0 -0
  502. package/src/assets/images/Googlelogo.png +0 -0
  503. package/src/assets/images/Linkedinicon.png +0 -0
  504. package/src/assets/images/Onairoslogo.png +0 -0
  505. package/src/assets/images/Personalityprofile.svg +3 -0
  506. package/src/assets/images/Personalitytraits.svg +3 -0
  507. package/src/assets/images/Redditicon.png +0 -0
  508. package/src/assets/images/Userpreferences.svg +3 -0
  509. package/src/assets/images/YouTubeicon3.png +0 -0
  510. package/src/assets/images/arrow.svg +20 -0
  511. package/src/assets/images/basicproficon.svg +43 -0
  512. package/src/assets/images/basicprofile.svg +3 -0
  513. package/src/assets/images/checkmark.svg +4 -0
  514. package/src/assets/images/contentanalysis.svg +3 -0
  515. package/src/assets/images/contenticon.svg +23 -0
  516. package/src/assets/images/persona1.png +0 -0
  517. package/src/assets/images/persona2.png +0 -0
  518. package/src/assets/images/persona3.png +0 -0
  519. package/src/assets/images/persona4.png +0 -0
  520. package/src/assets/images/persona5.png +0 -0
  521. package/src/assets/images/personalityicon.svg +18 -0
  522. package/src/assets/images/x-close.svg +3 -0
  523. package/src/components/BodyText.tsx +33 -0
  524. package/src/components/BrandMark.tsx +62 -0
  525. package/src/components/CodeInput.tsx +32 -0
  526. package/src/components/EmailInput.tsx +31 -0
  527. package/src/components/ExistingUserDataConfirmation.tsx +507 -0
  528. package/src/components/GoogleButton.tsx +55 -0
  529. package/src/components/HeadingGroup.tsx +49 -0
  530. package/src/components/ModalHeader.tsx +125 -0
  531. package/src/components/ModalSheet.tsx +57 -0
  532. package/src/components/Onairos.tsx +422 -424
  533. package/src/components/OnairosButton.tsx +339 -359
  534. package/src/components/OnairosSignInButton.tsx +166 -0
  535. package/src/components/Overlay.tsx +506 -506
  536. package/src/components/PersonaImage.tsx +79 -0
  537. package/src/components/PersonaLoadingScreen.tsx +201 -0
  538. package/src/components/PersonalizationConsentScreen.tsx +410 -0
  539. package/src/components/PinCreationScreen.tsx +492 -0
  540. package/src/components/PinInput.tsx +555 -343
  541. package/src/components/PlatformConnectorsStep.tsx +892 -0
  542. package/src/components/PlatformToggle.tsx +226 -0
  543. package/src/components/PrimaryButton.tsx +214 -0
  544. package/src/components/SignInMatchAnimation.tsx +225 -0
  545. package/src/components/SignInStep.tsx +217 -0
  546. package/src/components/TrainingModal.tsx +1047 -737
  547. package/src/components/UniversalOnboarding.tsx +2888 -1820
  548. package/src/components/VerificationStep.tsx +198 -0
  549. package/src/components/WelcomeScreen.tsx +473 -0
  550. package/src/components/icons/Basicproficon.tsx +30 -0
  551. package/src/components/icons/Basicprofile.tsx +17 -0
  552. package/src/components/icons/Checkbox.tsx +17 -0
  553. package/src/components/icons/Checkmark.tsx +24 -0
  554. package/src/components/icons/Contentanalysis.tsx +17 -0
  555. package/src/components/icons/Contenticon.tsx +30 -0
  556. package/src/components/icons/EnochE.tsx +39 -0
  557. package/src/components/icons/Personalityicon.tsx +22 -0
  558. package/src/components/icons/Personalityprofile.tsx +17 -0
  559. package/src/components/icons/Personalitytraits.tsx +17 -0
  560. package/src/components/icons/Userpreferences.tsx +17 -0
  561. package/src/components/icons/index.ts +12 -0
  562. package/src/components/onboarding/OAuthWebView.tsx +232 -838
  563. package/src/config/api.ts +25 -0
  564. package/src/context/AuthContext.tsx +393 -0
  565. package/src/hooks/useConnectedAccounts.ts +139 -0
  566. package/src/hooks/useConnections.ts +129 -131
  567. package/src/hooks/useUserConnections.ts +166 -0
  568. package/src/index.ts +94 -49
  569. package/src/services/apiClient.ts +337 -0
  570. package/src/services/apiKeyService.ts +9 -11
  571. package/src/services/authService.ts +1008 -0
  572. package/src/services/biometricPinService.ts +193 -0
  573. package/src/services/connectedAccountsService.ts +290 -0
  574. package/src/services/googleAuthService.ts +279 -0
  575. package/src/services/imageCompressionService.ts +303 -0
  576. package/src/services/jwtStorageService.ts +257 -0
  577. package/src/services/mobileTrainingService.ts +204 -0
  578. package/src/services/pinEncryptionService.ts +76 -0
  579. package/src/services/pinStorageUtils.ts +97 -0
  580. package/src/services/platformAuthService.ts +1346 -1113
  581. package/src/services/storageService.ts +452 -0
  582. package/src/services/trainingApiHelpers.ts +67 -0
  583. package/src/services/userConnectionsService.ts +557 -0
  584. package/src/services/youtubeMigrationService.ts +454 -0
  585. package/src/theme/index.ts +239 -0
  586. package/src/types/index.ts +265 -238
  587. package/src/utils/eventUtils.ts +303 -0
  588. package/src/utils/haptics.ts +59 -0
  589. package/src/utils/imagePreloader.ts +2 -0
  590. package/lib/commonjs/assets/images/email.png +0 -0
  591. package/lib/commonjs/assets/images/linkedin.png +0 -0
  592. package/lib/commonjs/assets/images/reddit.png +0 -0
  593. package/lib/commonjs/assets/images/youtube.png +0 -0
  594. package/lib/commonjs/components/UniversalOnboarding.tsx.new +0 -455
  595. package/lib/module/assets/images/email.png +0 -0
  596. package/lib/module/assets/images/linkedin.png +0 -0
  597. package/lib/module/assets/images/reddit.png +0 -0
  598. package/lib/module/assets/images/youtube.png +0 -0
  599. package/lib/module/components/UniversalOnboarding.tsx.new +0 -455
  600. package/src/assets/images/email.png +0 -0
  601. package/src/assets/images/linkedin.png +0 -0
  602. package/src/assets/images/reddit.png +0 -0
  603. package/src/assets/images/youtube.png +0 -0
  604. package/src/components/UniversalOnboarding.tsx.new +0 -455
@@ -0,0 +1,226 @@
1
+ import React from 'react';
2
+ import {
3
+ View,
4
+ Text,
5
+ TouchableOpacity,
6
+ Image,
7
+ StyleSheet,
8
+ Switch,
9
+ Platform,
10
+ } from 'react-native';
11
+ import { COLORS, SPACING } from '../theme';
12
+
13
+ interface PlatformToggleProps {
14
+ platform: {
15
+ id: string;
16
+ name: string;
17
+ icon: any; // require() image
18
+ description: string;
19
+ };
20
+ isEnabled: boolean;
21
+ onToggle: (platformId: string, enabled: boolean) => void;
22
+ compact?: boolean;
23
+ isLast?: boolean;
24
+ fullWidth?: boolean;
25
+ customIconSize?: number;
26
+ onLongPress?: () => void;
27
+ onPressOut?: () => void;
28
+ }
29
+
30
+ const PlatformToggle: React.FC<PlatformToggleProps> = ({
31
+ platform,
32
+ isEnabled,
33
+ onToggle,
34
+ compact = false,
35
+ isLast = false,
36
+ fullWidth = false,
37
+ customIconSize,
38
+ onLongPress,
39
+ onPressOut,
40
+ }) => {
41
+ const handleToggle = () => {
42
+ onToggle(platform.id, !isEnabled);
43
+ };
44
+
45
+ const containerStyle = fullWidth ? styles.fullWidthContainer :
46
+ compact ? styles.compactContainer : styles.container;
47
+
48
+ return (
49
+ <TouchableOpacity
50
+ style={[
51
+ containerStyle,
52
+ !isLast && compact && styles.borderBottom,
53
+ ]}
54
+ onLongPress={onLongPress}
55
+ onPressOut={onPressOut}
56
+ activeOpacity={onLongPress ? 0.7 : 1.0}
57
+ disabled={!onLongPress}
58
+ >
59
+ {/* Top row: Icon + Name + Toggle */}
60
+ <View style={styles.topRow}>
61
+ <View style={styles.leftContent}>
62
+ <Image
63
+ source={platform.icon}
64
+ style={customIconSize ?
65
+ {
66
+ width: customIconSize,
67
+ height: customIconSize,
68
+ marginRight: 12 - (customIconSize - 28) // Reduce margin more to align text properly
69
+ } :
70
+ (fullWidth ? styles.compactIcon : (compact ? styles.compactIcon : styles.icon))
71
+ }
72
+ resizeMode="contain"
73
+ />
74
+ <View style={styles.textContent}>
75
+ <Text style={fullWidth ? styles.compactPlatformName : (compact ? styles.compactPlatformName : styles.platformName)}>{platform.name}</Text>
76
+ </View>
77
+ </View>
78
+
79
+ <Switch
80
+ value={isEnabled}
81
+ onValueChange={handleToggle}
82
+ trackColor={{
83
+ false: '#E5E5E5',
84
+ true: '#4CD964' // Green when enabled
85
+ }}
86
+ thumbColor={Platform.OS === 'ios' ? undefined : (isEnabled ? '#FFFFFF' : '#FFFFFF')}
87
+ ios_backgroundColor="#E5E5E5"
88
+ style={compact ? styles.compactSwitch : undefined}
89
+ />
90
+ </View>
91
+
92
+ {/* Bottom row: Description in rounded box */}
93
+ {fullWidth && (
94
+ <View style={styles.descriptionBox}>
95
+ <Text style={styles.fullWidthDescription}>{platform.description}</Text>
96
+ </View>
97
+ )}
98
+
99
+ {/* Show description inline for non-fullWidth modes */}
100
+ {!fullWidth && (
101
+ <Text style={compact ? styles.compactDescription : styles.description}>{platform.description}</Text>
102
+ )}
103
+ </TouchableOpacity>
104
+ );
105
+ };
106
+
107
+ const styles = StyleSheet.create({
108
+ container: {
109
+ flexDirection: 'row',
110
+ alignItems: 'center',
111
+ justifyContent: 'space-between',
112
+ paddingVertical: 16,
113
+ paddingHorizontal: 16,
114
+ backgroundColor: COLORS.surface,
115
+ borderRadius: 12,
116
+ marginBottom: 12,
117
+ borderWidth: 1,
118
+ borderColor: '#E5E5E5',
119
+ },
120
+
121
+ compactContainer: {
122
+ flexDirection: 'row',
123
+ alignItems: 'center',
124
+ justifyContent: 'space-between',
125
+ paddingVertical: 16,
126
+ paddingHorizontal: 16,
127
+ backgroundColor: COLORS.surface,
128
+ },
129
+
130
+ fullWidthContainer: {
131
+ flexDirection: 'column', // Changed to column to stack rows
132
+ paddingVertical: 8, // Reduced from 16 to bring platforms closer
133
+ paddingHorizontal: 2, // Much closer to edges
134
+ backgroundColor: COLORS.surface,
135
+ marginBottom: 4, // Reduced from 12 to bring platforms closer
136
+ marginHorizontal: 0, // Ensure it spans full width
137
+ },
138
+
139
+ topRow: {
140
+ flexDirection: 'row',
141
+ alignItems: 'center',
142
+ justifyContent: 'space-between',
143
+ marginBottom: 4, // Reduced space between icon row and description box
144
+ },
145
+
146
+ descriptionBox: {
147
+ backgroundColor: '#F5F5F5',
148
+ borderRadius: 8,
149
+ paddingVertical: 8, // Reduced from 10 to make description box smaller
150
+ paddingHorizontal: 4, // Much closer to edges
151
+ marginTop: 2, // Reduced from 4 to bring closer to icon row
152
+ },
153
+
154
+ borderBottom: {
155
+ borderBottomWidth: 1,
156
+ borderBottomColor: '#E5E5E5',
157
+ },
158
+
159
+ leftContent: {
160
+ flexDirection: 'row',
161
+ alignItems: 'center',
162
+ flex: 1,
163
+ },
164
+
165
+ icon: {
166
+ width: 32,
167
+ height: 32,
168
+ marginRight: 12,
169
+ },
170
+
171
+ compactIcon: {
172
+ width: 28,
173
+ height: 28,
174
+ marginRight: 12,
175
+ },
176
+
177
+ textContent: {
178
+ flex: 1,
179
+ },
180
+
181
+ platformName: {
182
+ fontSize: 16,
183
+ fontFamily: 'Inter',
184
+ fontWeight: '600',
185
+ color: COLORS.grey800,
186
+ marginBottom: 2,
187
+ },
188
+
189
+ compactPlatformName: {
190
+ fontSize: 16,
191
+ fontFamily: 'Inter',
192
+ fontWeight: '600',
193
+ color: COLORS.grey800,
194
+ marginBottom: 2,
195
+ },
196
+
197
+ description: {
198
+ fontSize: 14,
199
+ fontFamily: 'Inter',
200
+ fontWeight: '400',
201
+ color: COLORS.grey600,
202
+ lineHeight: 20,
203
+ },
204
+
205
+ compactDescription: {
206
+ fontSize: 12,
207
+ fontFamily: 'Inter',
208
+ fontWeight: '400',
209
+ color: COLORS.grey600,
210
+ lineHeight: 16,
211
+ },
212
+
213
+ fullWidthDescription: {
214
+ fontSize: 13,
215
+ fontFamily: 'Inter',
216
+ fontWeight: '400',
217
+ color: COLORS.grey600,
218
+ lineHeight: 18,
219
+ },
220
+
221
+ compactSwitch: {
222
+ transform: [{ scaleX: 0.9 }, { scaleY: 0.9 }],
223
+ },
224
+ });
225
+
226
+ export default PlatformToggle;
@@ -0,0 +1,214 @@
1
+ import React, { useState } from 'react';
2
+ import {
3
+ View,
4
+ Text,
5
+ TouchableOpacity,
6
+ StyleSheet,
7
+ ViewStyle,
8
+ TextStyle,
9
+ ActivityIndicator,
10
+ } from 'react-native';
11
+ import { Svg, Defs, RadialGradient, Stop, Rect } from 'react-native-svg';
12
+ import LinearGradient from 'react-native-linear-gradient';
13
+ import { COLORS } from '../theme';
14
+
15
+ interface IconCircleProps {
16
+ size?: number;
17
+ children?: React.ReactNode;
18
+ }
19
+
20
+ const IconCircle: React.FC<IconCircleProps> = ({
21
+ size = 40,
22
+ children
23
+ }) => {
24
+ return (
25
+ <View style={[styles.iconCircle, { width: size, height: size, borderRadius: size / 2 }]}>
26
+ {/* IconCircle has its own background - the only child that should */}
27
+ <LinearGradient
28
+ colors={[COLORS.iconCircleGradientStart, COLORS.iconCircleGradientEnd]}
29
+ style={[StyleSheet.absoluteFill, { borderRadius: size / 2 }]}
30
+ start={{ x: 0, y: 0 }}
31
+ end={{ x: 0, y: 1 }}
32
+ />
33
+
34
+ {/* Content */}
35
+ <View style={styles.iconContent}>
36
+ {children || (
37
+ <Text style={styles.arrowText}>→</Text>
38
+ )}
39
+ </View>
40
+ </View>
41
+ );
42
+ };
43
+
44
+ interface PrimaryButtonProps {
45
+ label?: string;
46
+ onPress: () => void;
47
+ iconRight?: React.ReactNode;
48
+ loading?: boolean;
49
+ disabled?: boolean;
50
+ testID?: string;
51
+ style?: ViewStyle;
52
+ textStyle?: TextStyle;
53
+ }
54
+
55
+ const PrimaryButton: React.FC<PrimaryButtonProps> = ({
56
+ label = "Get Started",
57
+ onPress,
58
+ iconRight,
59
+ loading = false,
60
+ disabled = false,
61
+ testID,
62
+ style,
63
+ textStyle,
64
+ }) => {
65
+ const [pressed, setPressed] = useState(false);
66
+
67
+ const handlePressIn = () => setPressed(true);
68
+ const handlePressOut = () => setPressed(false);
69
+
70
+ return (
71
+ <TouchableOpacity
72
+ style={[
73
+ styles.outerPill,
74
+ !disabled && styles.outerShadow,
75
+ disabled && styles.disabled,
76
+ style
77
+ ]}
78
+ onPress={onPress}
79
+ onPressIn={handlePressIn}
80
+ onPressOut={handlePressOut}
81
+ disabled={disabled || loading}
82
+ activeOpacity={1}
83
+ testID={testID}
84
+ accessibilityLabel={label}
85
+ accessibilityRole="button"
86
+ >
87
+ {/* ONLY ONE gradient - no overlays */}
88
+ <LinearGradient
89
+ colors={[COLORS.btnGradStart, COLORS.btnGradEnd]}
90
+ style={styles.baseGradient}
91
+ start={{ x: 0, y: 0 }}
92
+ end={{ x: 0, y: 1 }}
93
+ />
94
+
95
+ {/* Simple pressed state */}
96
+ {pressed && (
97
+ <View style={styles.pressedOverlay} />
98
+ )}
99
+
100
+ {/* Centered text on top */}
101
+ <View style={styles.textContainer}>
102
+ {loading ? (
103
+ <ActivityIndicator color={COLORS.btnLabel} size="small" />
104
+ ) : (
105
+ <Text style={[styles.label, textStyle]}>{label}</Text>
106
+ )}
107
+ </View>
108
+
109
+ {/* Icon in fixed position on right */}
110
+ <View style={styles.iconPosition}>
111
+ {!loading && (iconRight || <IconCircle />)}
112
+ </View>
113
+ </TouchableOpacity>
114
+ );
115
+ };
116
+
117
+ const styles = StyleSheet.create({
118
+ // Outer pill container - owns all backgrounds, border, shadow
119
+ outerPill: {
120
+ height: 48,
121
+ borderRadius: 100,
122
+ borderWidth: 1,
123
+ borderColor: COLORS.btnBorder, // ≈20% black
124
+ overflow: 'hidden',
125
+ width: '100%',
126
+ position: 'relative',
127
+ },
128
+
129
+ outerShadow: {
130
+ // Outer shadow: 20px 30px 40px rgba(0,0,0,0.10)
131
+ shadowColor: '#000000',
132
+ shadowOffset: { width: 20, height: 30 },
133
+ shadowOpacity: 0.10,
134
+ shadowRadius: 40,
135
+ elevation: 8,
136
+ },
137
+
138
+ disabled: {
139
+ opacity: 0.65,
140
+ shadowOpacity: 0,
141
+ elevation: 0,
142
+ },
143
+
144
+ // Single base gradient - fills entire button
145
+ baseGradient: {
146
+ ...StyleSheet.absoluteFillObject,
147
+ borderRadius: 100,
148
+ },
149
+
150
+ pressedOverlay: {
151
+ ...StyleSheet.absoluteFillObject,
152
+ backgroundColor: 'rgba(0,0,0,0.1)',
153
+ borderRadius: 100,
154
+ },
155
+
156
+ // Absolutely centered text container
157
+ textContainer: {
158
+ position: 'absolute',
159
+ left: 0,
160
+ right: 0,
161
+ top: 0,
162
+ bottom: 0,
163
+ justifyContent: 'center',
164
+ alignItems: 'center',
165
+ backgroundColor: 'transparent',
166
+ },
167
+
168
+ // Fixed icon position on right
169
+ iconPosition: {
170
+ position: 'absolute',
171
+ right: 4,
172
+ top: 4,
173
+ bottom: 4,
174
+ width: 40,
175
+ justifyContent: 'center',
176
+ alignItems: 'center',
177
+ backgroundColor: 'transparent',
178
+ },
179
+
180
+ label: {
181
+ fontFamily: 'Inter',
182
+ fontWeight: '600',
183
+ fontSize: 16,
184
+ color: COLORS.btnLabel,
185
+ textAlign: 'center',
186
+ backgroundColor: 'transparent', // Must be transparent
187
+ },
188
+
189
+ // IconCircle styles - ONLY child with background
190
+ iconCircle: {
191
+ justifyContent: 'center',
192
+ alignItems: 'center',
193
+ borderWidth: 1,
194
+ borderColor: 'rgba(0,0,0,0.25)',
195
+ },
196
+
197
+ iconContent: {
198
+ justifyContent: 'center',
199
+ alignItems: 'center',
200
+ backgroundColor: 'transparent',
201
+ },
202
+
203
+ arrowText: {
204
+ fontSize: 20,
205
+ color: COLORS.btnLabel,
206
+ fontWeight: '600',
207
+ opacity: 0.95,
208
+ backgroundColor: 'transparent',
209
+ },
210
+ });
211
+
212
+ export { IconCircle };
213
+ export { PrimaryButton };
214
+ export default PrimaryButton;
@@ -0,0 +1,225 @@
1
+ import React, { useState, useEffect } from 'react';
2
+ import {
3
+ View,
4
+ Text,
5
+ StyleSheet,
6
+ Modal,
7
+ ActivityIndicator,
8
+ Animated,
9
+ Dimensions,
10
+ TouchableOpacity
11
+ } from 'react-native';
12
+ import LinearGradient from 'react-native-linear-gradient';
13
+
14
+ interface SignInMatchAnimationProps {
15
+ email: string;
16
+ visible: boolean;
17
+ onComplete: () => void;
18
+ }
19
+
20
+ const { width, height } = Dimensions.get('window');
21
+
22
+ const SignInMatchAnimation: React.FC<SignInMatchAnimationProps> = ({
23
+ email,
24
+ visible,
25
+ onComplete
26
+ }) => {
27
+ const [step, setStep] = useState<'searching' | 'found' | 'complete'>('searching');
28
+ const [matchCount, setMatchCount] = useState(0);
29
+ const fadeAnim = useState(new Animated.Value(0))[0];
30
+ const scaleAnim = useState(new Animated.Value(0.9))[0];
31
+
32
+ useEffect(() => {
33
+ if (visible) {
34
+ // Start with fade in animation
35
+ Animated.parallel([
36
+ Animated.timing(fadeAnim, {
37
+ toValue: 1,
38
+ duration: 600,
39
+ useNativeDriver: true
40
+ }),
41
+ Animated.timing(scaleAnim, {
42
+ toValue: 1,
43
+ duration: 600,
44
+ useNativeDriver: true
45
+ })
46
+ ]).start();
47
+
48
+ // Simulate search process
49
+ setTimeout(() => {
50
+ // Generate random match count (3-8)
51
+ const randomMatchCount = Math.floor(Math.random() * 6) + 3;
52
+ setMatchCount(randomMatchCount);
53
+ setStep('found');
54
+
55
+ // Auto-proceed to complete after 3 seconds
56
+ setTimeout(() => {
57
+ setStep('complete');
58
+ }, 3000);
59
+ }, 2500);
60
+ }
61
+ }, [visible, fadeAnim, scaleAnim]);
62
+
63
+ const handleContinue = () => {
64
+ // Fade out animation before calling onComplete
65
+ Animated.parallel([
66
+ Animated.timing(fadeAnim, {
67
+ toValue: 0,
68
+ duration: 400,
69
+ useNativeDriver: true
70
+ }),
71
+ Animated.timing(scaleAnim, {
72
+ toValue: 0.9,
73
+ duration: 400,
74
+ useNativeDriver: true
75
+ })
76
+ ]).start(() => {
77
+ onComplete();
78
+ });
79
+ };
80
+
81
+ if (!visible) return null;
82
+
83
+ return (
84
+ <Modal
85
+ visible={visible}
86
+ transparent
87
+ animationType="none"
88
+ >
89
+ <View style={styles.container}>
90
+ <Animated.View
91
+ style={[
92
+ styles.content,
93
+ {
94
+ opacity: fadeAnim,
95
+ transform: [{ scale: scaleAnim }]
96
+ }
97
+ ]}
98
+ >
99
+ {step === 'searching' && (
100
+ <>
101
+ <Text style={styles.title}>Finding Your Matches</Text>
102
+ <ActivityIndicator size="large" color="#E9C46A" style={styles.loader} />
103
+ <Text style={styles.message}>
104
+ Searching for potential connections based on your profile...
105
+ </Text>
106
+ </>
107
+ )}
108
+
109
+ {step === 'found' && (
110
+ <>
111
+ <Text style={styles.title}>Matches Found!</Text>
112
+ <View style={styles.matchCircle}>
113
+ <Text style={styles.matchCount}>{matchCount}</Text>
114
+ </View>
115
+ <Text style={styles.message}>
116
+ We've found {matchCount} potential connections for you!
117
+ </Text>
118
+ <Text style={styles.subMessage}>
119
+ Complete your profile to see who they are.
120
+ </Text>
121
+ </>
122
+ )}
123
+
124
+ {step === 'complete' && (
125
+ <>
126
+ <Text style={styles.title}>Welcome to Enoch!</Text>
127
+ <Text style={styles.message}>
128
+ We'll send match notifications to {email.split('@')[0]}@...
129
+ </Text>
130
+ <TouchableOpacity
131
+ style={styles.button}
132
+ onPress={handleContinue}
133
+ >
134
+ <LinearGradient
135
+ colors={['#f5e7c1', '#E9C46A', '#DDB957']}
136
+ start={{x: 0, y: 0}}
137
+ end={{x: 1, y: 0}}
138
+ style={styles.gradientButton}
139
+ >
140
+ <Text style={styles.buttonText}>Continue</Text>
141
+ </LinearGradient>
142
+ </TouchableOpacity>
143
+ </>
144
+ )}
145
+ </Animated.View>
146
+ </View>
147
+ </Modal>
148
+ );
149
+ };
150
+
151
+ const styles = StyleSheet.create({
152
+ container: {
153
+ flex: 1,
154
+ backgroundColor: 'rgba(0,0,0,0.7)',
155
+ justifyContent: 'center',
156
+ alignItems: 'center',
157
+ },
158
+ content: {
159
+ width: width * 0.85,
160
+ backgroundColor: '#FFFFFF',
161
+ borderRadius: 20,
162
+ padding: 24,
163
+ alignItems: 'center',
164
+ shadowColor: '#000',
165
+ shadowOffset: { width: 0, height: 4 },
166
+ shadowOpacity: 0.3,
167
+ shadowRadius: 8,
168
+ elevation: 10,
169
+ },
170
+ title: {
171
+ fontSize: 24,
172
+ fontWeight: '600',
173
+ color: '#333',
174
+ marginBottom: 20,
175
+ textAlign: 'center',
176
+ },
177
+ loader: {
178
+ marginVertical: 24,
179
+ },
180
+ message: {
181
+ fontSize: 18,
182
+ color: '#555',
183
+ textAlign: 'center',
184
+ marginBottom: 16,
185
+ lineHeight: 24,
186
+ },
187
+ subMessage: {
188
+ fontSize: 16,
189
+ color: '#777',
190
+ textAlign: 'center',
191
+ marginTop: 8,
192
+ },
193
+ matchCircle: {
194
+ width: 100,
195
+ height: 100,
196
+ borderRadius: 50,
197
+ backgroundColor: '#E9C46A',
198
+ justifyContent: 'center',
199
+ alignItems: 'center',
200
+ marginVertical: 20,
201
+ },
202
+ matchCount: {
203
+ fontSize: 40,
204
+ fontWeight: 'bold',
205
+ color: '#FFFFFF',
206
+ },
207
+ button: {
208
+ width: '100%',
209
+ marginTop: 24,
210
+ borderRadius: 8,
211
+ overflow: 'hidden',
212
+ },
213
+ gradientButton: {
214
+ paddingVertical: 14,
215
+ alignItems: 'center',
216
+ justifyContent: 'center',
217
+ },
218
+ buttonText: {
219
+ color: '#333',
220
+ fontSize: 16,
221
+ fontWeight: '600',
222
+ }
223
+ });
224
+
225
+ export default SignInMatchAnimation;