@onairos/react-native 3.1.11 → 3.1.13

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 (598) hide show
  1. package/lib/commonjs/api/index.js +75 -1
  2. package/lib/commonjs/api/index.js.map +1 -1
  3. package/lib/commonjs/assets/fonts/EBGaramond-VariableFont_wght.ttf +0 -0
  4. package/lib/commonjs/assets/fonts/IBMPlexSans-VariableFont_wdth,wght.ttf +0 -0
  5. package/lib/commonjs/assets/icons/Facebookicon.png +0 -0
  6. package/lib/commonjs/assets/icons/Gmail.png +0 -0
  7. package/lib/commonjs/assets/icons/Linkedinicon.png +0 -0
  8. package/lib/commonjs/assets/icons/Redditicon.png +0 -0
  9. package/lib/commonjs/assets/icons/YouTubeicon2.png +0 -0
  10. package/lib/commonjs/assets/icons/YouTubeicon3.png +0 -0
  11. package/lib/commonjs/assets/icons/farcaster.png +0 -0
  12. package/lib/commonjs/assets/icons/instagram.png +0 -0
  13. package/lib/commonjs/assets/icons/pinterest.png +0 -0
  14. package/lib/commonjs/assets/icons/swerv_logo.png +0 -0
  15. package/lib/commonjs/assets/icons/twitter.jpg +0 -0
  16. package/lib/commonjs/assets/images/Checkbox.svg +3 -0
  17. package/lib/commonjs/assets/images/EnochE.svg +19 -0
  18. package/lib/commonjs/assets/images/Enochicon1.png +0 -0
  19. package/lib/commonjs/assets/images/Face_ID_logo.png +0 -0
  20. package/lib/commonjs/assets/images/Facebookicon.png +0 -0
  21. package/lib/commonjs/assets/images/Gmail.png +0 -0
  22. package/lib/commonjs/assets/images/Googlelogo.png +0 -0
  23. package/lib/commonjs/assets/images/Linkedinicon.png +0 -0
  24. package/lib/commonjs/assets/images/Onairoslogo.png +0 -0
  25. package/lib/commonjs/assets/images/Personalityprofile.svg +3 -0
  26. package/lib/commonjs/assets/images/Personalitytraits.svg +3 -0
  27. package/lib/commonjs/assets/images/Redditicon.png +0 -0
  28. package/lib/commonjs/assets/images/Userpreferences.svg +3 -0
  29. package/lib/commonjs/assets/images/YouTubeicon3.png +0 -0
  30. package/lib/commonjs/assets/images/arrow.svg +20 -0
  31. package/lib/commonjs/assets/images/basicproficon.svg +43 -0
  32. package/lib/commonjs/assets/images/basicprofile.svg +3 -0
  33. package/lib/commonjs/assets/images/checkmark.svg +4 -0
  34. package/lib/commonjs/assets/images/contentanalysis.svg +3 -0
  35. package/lib/commonjs/assets/images/contenticon.svg +23 -0
  36. package/lib/commonjs/assets/images/persona1.png +0 -0
  37. package/lib/commonjs/assets/images/persona2.png +0 -0
  38. package/lib/commonjs/assets/images/persona3.png +0 -0
  39. package/lib/commonjs/assets/images/persona4.png +0 -0
  40. package/lib/commonjs/assets/images/persona5.png +0 -0
  41. package/lib/commonjs/assets/images/personalityicon.svg +18 -0
  42. package/lib/commonjs/assets/images/x-close.svg +3 -0
  43. package/lib/commonjs/components/BodyText.js +27 -0
  44. package/lib/commonjs/components/BodyText.js.map +1 -0
  45. package/lib/commonjs/components/BrandMark.js +44 -0
  46. package/lib/commonjs/components/BrandMark.js.map +1 -0
  47. package/lib/commonjs/components/CodeInput.js +30 -0
  48. package/lib/commonjs/components/CodeInput.js.map +1 -0
  49. package/lib/commonjs/components/EmailInput.js +30 -0
  50. package/lib/commonjs/components/EmailInput.js.map +1 -0
  51. package/lib/commonjs/components/ExistingUserDataConfirmation.js +474 -0
  52. package/lib/commonjs/components/ExistingUserDataConfirmation.js.map +1 -0
  53. package/lib/commonjs/components/GoogleButton.js +55 -0
  54. package/lib/commonjs/components/GoogleButton.js.map +1 -0
  55. package/lib/commonjs/components/HeadingGroup.js +43 -0
  56. package/lib/commonjs/components/HeadingGroup.js.map +1 -0
  57. package/lib/commonjs/components/ModalHeader.js +99 -0
  58. package/lib/commonjs/components/ModalHeader.js.map +1 -0
  59. package/lib/commonjs/components/ModalSheet.js +41 -0
  60. package/lib/commonjs/components/ModalSheet.js.map +1 -0
  61. package/lib/commonjs/components/Onairos.js +1 -3
  62. package/lib/commonjs/components/Onairos.js.map +1 -1
  63. package/lib/commonjs/components/OnairosButton.js +171 -190
  64. package/lib/commonjs/components/OnairosButton.js.map +1 -1
  65. package/lib/commonjs/components/OnairosSignInButton.js +169 -0
  66. package/lib/commonjs/components/OnairosSignInButton.js.map +1 -0
  67. package/lib/commonjs/components/Overlay.js +5 -5
  68. package/lib/commonjs/components/Overlay.js.map +1 -1
  69. package/lib/commonjs/components/PersonaImage.js +60 -0
  70. package/lib/commonjs/components/PersonaImage.js.map +1 -0
  71. package/lib/commonjs/components/PersonaLoadingScreen.js +156 -0
  72. package/lib/commonjs/components/PersonaLoadingScreen.js.map +1 -0
  73. package/lib/commonjs/components/PersonalizationConsentScreen.js +316 -0
  74. package/lib/commonjs/components/PersonalizationConsentScreen.js.map +1 -0
  75. package/lib/commonjs/components/PinCreationScreen.js +393 -0
  76. package/lib/commonjs/components/PinCreationScreen.js.map +1 -0
  77. package/lib/commonjs/components/PinInput.js +282 -120
  78. package/lib/commonjs/components/PinInput.js.map +1 -1
  79. package/lib/commonjs/components/PlatformConnectorsStep.js +828 -0
  80. package/lib/commonjs/components/PlatformConnectorsStep.js.map +1 -0
  81. package/lib/commonjs/components/PlatformToggle.js +180 -0
  82. package/lib/commonjs/components/PlatformToggle.js.map +1 -0
  83. package/lib/commonjs/components/PrimaryButton.js +180 -0
  84. package/lib/commonjs/components/PrimaryButton.js.map +1 -0
  85. package/lib/commonjs/components/SignInMatchAnimation.js +197 -0
  86. package/lib/commonjs/components/SignInMatchAnimation.js.map +1 -0
  87. package/lib/commonjs/components/SignInStep.js +179 -0
  88. package/lib/commonjs/components/SignInStep.js.map +1 -0
  89. package/lib/commonjs/components/TrainingModal.js +808 -563
  90. package/lib/commonjs/components/TrainingModal.js.map +1 -1
  91. package/lib/commonjs/components/UniversalOnboarding.js +2304 -1283
  92. package/lib/commonjs/components/UniversalOnboarding.js.map +1 -1
  93. package/lib/commonjs/components/VerificationStep.js +154 -0
  94. package/lib/commonjs/components/VerificationStep.js.map +1 -0
  95. package/lib/commonjs/components/WelcomeScreen.js +385 -0
  96. package/lib/commonjs/components/WelcomeScreen.js.map +1 -0
  97. package/lib/commonjs/components/icons/Basicproficon.js +37 -0
  98. package/lib/commonjs/components/icons/Basicproficon.js.map +1 -0
  99. package/lib/commonjs/components/icons/Basicprofile.js +21 -0
  100. package/lib/commonjs/components/icons/Basicprofile.js.map +1 -0
  101. package/lib/commonjs/components/icons/Checkbox.js +21 -0
  102. package/lib/commonjs/components/icons/Checkbox.js.map +1 -0
  103. package/lib/commonjs/components/icons/Checkmark.js +27 -0
  104. package/lib/commonjs/components/icons/Checkmark.js.map +1 -0
  105. package/lib/commonjs/components/icons/Contentanalysis.js +21 -0
  106. package/lib/commonjs/components/icons/Contentanalysis.js.map +1 -0
  107. package/lib/commonjs/components/icons/Contenticon.js +39 -0
  108. package/lib/commonjs/components/icons/Contenticon.js.map +1 -0
  109. package/lib/commonjs/components/icons/EnochE.js +41 -0
  110. package/lib/commonjs/components/icons/EnochE.js.map +1 -0
  111. package/lib/commonjs/components/icons/Personalityicon.js +30 -0
  112. package/lib/commonjs/components/icons/Personalityicon.js.map +1 -0
  113. package/lib/commonjs/components/icons/Personalityprofile.js +21 -0
  114. package/lib/commonjs/components/icons/Personalityprofile.js.map +1 -0
  115. package/lib/commonjs/components/icons/Personalitytraits.js +21 -0
  116. package/lib/commonjs/components/icons/Personalitytraits.js.map +1 -0
  117. package/lib/commonjs/components/icons/Userpreferences.js +21 -0
  118. package/lib/commonjs/components/icons/Userpreferences.js.map +1 -0
  119. package/lib/commonjs/components/icons/index.js +84 -0
  120. package/lib/commonjs/components/icons/index.js.map +1 -0
  121. package/lib/commonjs/components/onboarding/OAuthWebView.js +134 -743
  122. package/lib/commonjs/components/onboarding/OAuthWebView.js.map +1 -1
  123. package/lib/commonjs/config/api.js +34 -0
  124. package/lib/commonjs/config/api.js.map +1 -0
  125. package/lib/commonjs/context/AuthContext.js +345 -0
  126. package/lib/commonjs/context/AuthContext.js.map +1 -0
  127. package/lib/commonjs/hooks/useConnectedAccounts.js +111 -0
  128. package/lib/commonjs/hooks/useConnectedAccounts.js.map +1 -0
  129. package/lib/commonjs/hooks/useConnections.js +120 -125
  130. package/lib/commonjs/hooks/useConnections.js.map +1 -1
  131. package/lib/commonjs/hooks/useUserConnections.js +148 -0
  132. package/lib/commonjs/hooks/useUserConnections.js.map +1 -0
  133. package/lib/commonjs/index.js +149 -27
  134. package/lib/commonjs/index.js.map +1 -1
  135. package/lib/commonjs/services/apiClient.js +302 -0
  136. package/lib/commonjs/services/apiClient.js.map +1 -0
  137. package/lib/commonjs/services/authService.js +935 -0
  138. package/lib/commonjs/services/authService.js.map +1 -0
  139. package/lib/commonjs/services/biometricPinService.js +184 -0
  140. package/lib/commonjs/services/biometricPinService.js.map +1 -0
  141. package/lib/commonjs/services/connectedAccountsService.js +268 -0
  142. package/lib/commonjs/services/connectedAccountsService.js.map +1 -0
  143. package/lib/commonjs/services/googleAuthService.js +268 -0
  144. package/lib/commonjs/services/googleAuthService.js.map +1 -0
  145. package/lib/commonjs/services/imageCompressionService.js +260 -0
  146. package/lib/commonjs/services/imageCompressionService.js.map +1 -0
  147. package/lib/commonjs/services/jwtStorageService.js +256 -0
  148. package/lib/commonjs/services/jwtStorageService.js.map +1 -0
  149. package/lib/commonjs/services/mobileTrainingService.js +185 -0
  150. package/lib/commonjs/services/mobileTrainingService.js.map +1 -0
  151. package/lib/commonjs/services/pinEncryptionService.js +84 -0
  152. package/lib/commonjs/services/pinEncryptionService.js.map +1 -0
  153. package/lib/commonjs/services/pinStorageUtils.js +105 -0
  154. package/lib/commonjs/services/pinStorageUtils.js.map +1 -0
  155. package/lib/commonjs/services/platformAuthService.js +956 -722
  156. package/lib/commonjs/services/platformAuthService.js.map +1 -1
  157. package/lib/commonjs/services/storageService.js +404 -0
  158. package/lib/commonjs/services/storageService.js.map +1 -0
  159. package/lib/commonjs/services/trainingApiHelpers.js +73 -0
  160. package/lib/commonjs/services/trainingApiHelpers.js.map +1 -0
  161. package/lib/commonjs/services/userConnectionsService.js +486 -0
  162. package/lib/commonjs/services/userConnectionsService.js.map +1 -0
  163. package/lib/commonjs/services/youtubeMigrationService.js +415 -0
  164. package/lib/commonjs/services/youtubeMigrationService.js.map +1 -0
  165. package/lib/commonjs/theme/index.js +249 -0
  166. package/lib/commonjs/theme/index.js.map +1 -0
  167. package/lib/commonjs/utils/eventUtils.js +288 -0
  168. package/lib/commonjs/utils/eventUtils.js.map +1 -0
  169. package/lib/commonjs/utils/haptics.js +66 -0
  170. package/lib/commonjs/utils/haptics.js.map +1 -0
  171. package/lib/commonjs/utils/imagePreloader.js +6 -0
  172. package/lib/commonjs/utils/imagePreloader.js.map +1 -0
  173. package/lib/module/api/index.js +72 -0
  174. package/lib/module/api/index.js.map +1 -1
  175. package/lib/module/assets/fonts/EBGaramond-VariableFont_wght.ttf +0 -0
  176. package/lib/module/assets/fonts/IBMPlexSans-VariableFont_wdth,wght.ttf +0 -0
  177. package/lib/module/assets/icons/Facebookicon.png +0 -0
  178. package/lib/module/assets/icons/Gmail.png +0 -0
  179. package/lib/module/assets/icons/Linkedinicon.png +0 -0
  180. package/lib/module/assets/icons/Redditicon.png +0 -0
  181. package/lib/module/assets/icons/YouTubeicon2.png +0 -0
  182. package/lib/module/assets/icons/YouTubeicon3.png +0 -0
  183. package/lib/module/assets/icons/farcaster.png +0 -0
  184. package/lib/module/assets/icons/instagram.png +0 -0
  185. package/lib/module/assets/icons/pinterest.png +0 -0
  186. package/lib/module/assets/icons/swerv_logo.png +0 -0
  187. package/lib/module/assets/icons/twitter.jpg +0 -0
  188. package/lib/module/assets/images/Checkbox.svg +3 -0
  189. package/lib/module/assets/images/EnochE.svg +19 -0
  190. package/lib/module/assets/images/Enochicon1.png +0 -0
  191. package/lib/module/assets/images/Face_ID_logo.png +0 -0
  192. package/lib/module/assets/images/Facebookicon.png +0 -0
  193. package/lib/module/assets/images/Gmail.png +0 -0
  194. package/lib/module/assets/images/Googlelogo.png +0 -0
  195. package/lib/module/assets/images/Linkedinicon.png +0 -0
  196. package/lib/module/assets/images/Onairoslogo.png +0 -0
  197. package/lib/module/assets/images/Personalityprofile.svg +3 -0
  198. package/lib/module/assets/images/Personalitytraits.svg +3 -0
  199. package/lib/module/assets/images/Redditicon.png +0 -0
  200. package/lib/module/assets/images/Userpreferences.svg +3 -0
  201. package/lib/module/assets/images/YouTubeicon3.png +0 -0
  202. package/lib/module/assets/images/arrow.svg +20 -0
  203. package/lib/module/assets/images/basicproficon.svg +43 -0
  204. package/lib/module/assets/images/basicprofile.svg +3 -0
  205. package/lib/module/assets/images/checkmark.svg +4 -0
  206. package/lib/module/assets/images/contentanalysis.svg +3 -0
  207. package/lib/module/assets/images/contenticon.svg +23 -0
  208. package/lib/module/assets/images/persona1.png +0 -0
  209. package/lib/module/assets/images/persona2.png +0 -0
  210. package/lib/module/assets/images/persona3.png +0 -0
  211. package/lib/module/assets/images/persona4.png +0 -0
  212. package/lib/module/assets/images/persona5.png +0 -0
  213. package/lib/module/assets/images/personalityicon.svg +18 -0
  214. package/lib/module/assets/images/x-close.svg +3 -0
  215. package/lib/module/components/BodyText.js +20 -0
  216. package/lib/module/components/BodyText.js.map +1 -0
  217. package/lib/module/components/BrandMark.js +37 -0
  218. package/lib/module/components/BrandMark.js.map +1 -0
  219. package/lib/module/components/CodeInput.js +23 -0
  220. package/lib/module/components/CodeInput.js.map +1 -0
  221. package/lib/module/components/EmailInput.js +23 -0
  222. package/lib/module/components/EmailInput.js.map +1 -0
  223. package/lib/module/components/ExistingUserDataConfirmation.js +465 -0
  224. package/lib/module/components/ExistingUserDataConfirmation.js.map +1 -0
  225. package/lib/module/components/GoogleButton.js +48 -0
  226. package/lib/module/components/GoogleButton.js.map +1 -0
  227. package/lib/module/components/HeadingGroup.js +36 -0
  228. package/lib/module/components/HeadingGroup.js.map +1 -0
  229. package/lib/module/components/ModalHeader.js +92 -0
  230. package/lib/module/components/ModalHeader.js.map +1 -0
  231. package/lib/module/components/ModalSheet.js +34 -0
  232. package/lib/module/components/ModalSheet.js.map +1 -0
  233. package/lib/module/components/Onairos.js +1 -3
  234. package/lib/module/components/Onairos.js.map +1 -1
  235. package/lib/module/components/OnairosButton.js +172 -192
  236. package/lib/module/components/OnairosButton.js.map +1 -1
  237. package/lib/module/components/OnairosSignInButton.js +160 -0
  238. package/lib/module/components/OnairosSignInButton.js.map +1 -0
  239. package/lib/module/components/Overlay.js +5 -5
  240. package/lib/module/components/Overlay.js.map +1 -1
  241. package/lib/module/components/PersonaImage.js +53 -0
  242. package/lib/module/components/PersonaImage.js.map +1 -0
  243. package/lib/module/components/PersonaLoadingScreen.js +148 -0
  244. package/lib/module/components/PersonaLoadingScreen.js.map +1 -0
  245. package/lib/module/components/PersonalizationConsentScreen.js +309 -0
  246. package/lib/module/components/PersonalizationConsentScreen.js.map +1 -0
  247. package/lib/module/components/PinCreationScreen.js +386 -0
  248. package/lib/module/components/PinCreationScreen.js.map +1 -0
  249. package/lib/module/components/PinInput.js +283 -120
  250. package/lib/module/components/PinInput.js.map +1 -1
  251. package/lib/module/components/PlatformConnectorsStep.js +820 -0
  252. package/lib/module/components/PlatformConnectorsStep.js.map +1 -0
  253. package/lib/module/components/PlatformToggle.js +173 -0
  254. package/lib/module/components/PlatformToggle.js.map +1 -0
  255. package/lib/module/components/PrimaryButton.js +172 -0
  256. package/lib/module/components/PrimaryButton.js.map +1 -0
  257. package/lib/module/components/SignInMatchAnimation.js +189 -0
  258. package/lib/module/components/SignInMatchAnimation.js.map +1 -0
  259. package/lib/module/components/SignInStep.js +171 -0
  260. package/lib/module/components/SignInStep.js.map +1 -0
  261. package/lib/module/components/TrainingModal.js +809 -565
  262. package/lib/module/components/TrainingModal.js.map +1 -1
  263. package/lib/module/components/UniversalOnboarding.js +2307 -1284
  264. package/lib/module/components/UniversalOnboarding.js.map +1 -1
  265. package/lib/module/components/VerificationStep.js +146 -0
  266. package/lib/module/components/VerificationStep.js.map +1 -0
  267. package/lib/module/components/WelcomeScreen.js +378 -0
  268. package/lib/module/components/WelcomeScreen.js.map +1 -0
  269. package/lib/module/components/icons/Basicproficon.js +30 -0
  270. package/lib/module/components/icons/Basicproficon.js.map +1 -0
  271. package/lib/module/components/icons/Basicprofile.js +14 -0
  272. package/lib/module/components/icons/Basicprofile.js.map +1 -0
  273. package/lib/module/components/icons/Checkbox.js +14 -0
  274. package/lib/module/components/icons/Checkbox.js.map +1 -0
  275. package/lib/module/components/icons/Checkmark.js +20 -0
  276. package/lib/module/components/icons/Checkmark.js.map +1 -0
  277. package/lib/module/components/icons/Contentanalysis.js +14 -0
  278. package/lib/module/components/icons/Contentanalysis.js.map +1 -0
  279. package/lib/module/components/icons/Contenticon.js +32 -0
  280. package/lib/module/components/icons/Contenticon.js.map +1 -0
  281. package/lib/module/components/icons/EnochE.js +34 -0
  282. package/lib/module/components/icons/EnochE.js.map +1 -0
  283. package/lib/module/components/icons/Personalityicon.js +23 -0
  284. package/lib/module/components/icons/Personalityicon.js.map +1 -0
  285. package/lib/module/components/icons/Personalityprofile.js +14 -0
  286. package/lib/module/components/icons/Personalityprofile.js.map +1 -0
  287. package/lib/module/components/icons/Personalitytraits.js +14 -0
  288. package/lib/module/components/icons/Personalitytraits.js.map +1 -0
  289. package/lib/module/components/icons/Userpreferences.js +14 -0
  290. package/lib/module/components/icons/Userpreferences.js.map +1 -0
  291. package/lib/module/components/icons/index.js +13 -0
  292. package/lib/module/components/icons/index.js.map +1 -0
  293. package/lib/module/components/onboarding/OAuthWebView.js +136 -744
  294. package/lib/module/components/onboarding/OAuthWebView.js.map +1 -1
  295. package/lib/module/config/api.js +26 -0
  296. package/lib/module/config/api.js.map +1 -0
  297. package/lib/module/context/AuthContext.js +335 -0
  298. package/lib/module/context/AuthContext.js.map +1 -0
  299. package/lib/module/hooks/useConnectedAccounts.js +106 -0
  300. package/lib/module/hooks/useConnectedAccounts.js.map +1 -0
  301. package/lib/module/hooks/useConnections.js +119 -125
  302. package/lib/module/hooks/useConnections.js.map +1 -1
  303. package/lib/module/hooks/useUserConnections.js +140 -0
  304. package/lib/module/hooks/useUserConnections.js.map +1 -0
  305. package/lib/module/index.js +51 -15
  306. package/lib/module/index.js.map +1 -1
  307. package/lib/module/services/apiClient.js +298 -0
  308. package/lib/module/services/apiClient.js.map +1 -0
  309. package/lib/module/services/authService.js +905 -0
  310. package/lib/module/services/authService.js.map +1 -0
  311. package/lib/module/services/biometricPinService.js +173 -0
  312. package/lib/module/services/biometricPinService.js.map +1 -0
  313. package/lib/module/services/connectedAccountsService.js +255 -0
  314. package/lib/module/services/connectedAccountsService.js.map +1 -0
  315. package/lib/module/services/googleAuthService.js +258 -0
  316. package/lib/module/services/googleAuthService.js.map +1 -0
  317. package/lib/module/services/imageCompressionService.js +250 -0
  318. package/lib/module/services/imageCompressionService.js.map +1 -0
  319. package/lib/module/services/jwtStorageService.js +239 -0
  320. package/lib/module/services/jwtStorageService.js.map +1 -0
  321. package/lib/module/services/mobileTrainingService.js +172 -0
  322. package/lib/module/services/mobileTrainingService.js.map +1 -0
  323. package/lib/module/services/pinEncryptionService.js +75 -0
  324. package/lib/module/services/pinEncryptionService.js.map +1 -0
  325. package/lib/module/services/pinStorageUtils.js +93 -0
  326. package/lib/module/services/pinStorageUtils.js.map +1 -0
  327. package/lib/module/services/platformAuthService.js +943 -704
  328. package/lib/module/services/platformAuthService.js.map +1 -1
  329. package/lib/module/services/storageService.js +383 -0
  330. package/lib/module/services/storageService.js.map +1 -0
  331. package/lib/module/services/trainingApiHelpers.js +67 -0
  332. package/lib/module/services/trainingApiHelpers.js.map +1 -0
  333. package/lib/module/services/userConnectionsService.js +476 -0
  334. package/lib/module/services/userConnectionsService.js.map +1 -0
  335. package/lib/module/services/youtubeMigrationService.js +404 -0
  336. package/lib/module/services/youtubeMigrationService.js.map +1 -0
  337. package/lib/module/theme/index.js +244 -0
  338. package/lib/module/theme/index.js.map +1 -0
  339. package/lib/module/utils/eventUtils.js +270 -0
  340. package/lib/module/utils/eventUtils.js.map +1 -0
  341. package/lib/module/utils/haptics.js +59 -0
  342. package/lib/module/utils/haptics.js.map +1 -0
  343. package/lib/module/utils/imagePreloader.js +3 -0
  344. package/lib/module/utils/imagePreloader.js.map +1 -0
  345. package/lib/typescript/api/index.d.ts +8 -0
  346. package/lib/typescript/api/index.d.ts.map +1 -1
  347. package/lib/typescript/components/BodyText.d.ts +10 -0
  348. package/lib/typescript/components/BodyText.d.ts.map +1 -0
  349. package/lib/typescript/components/BrandMark.d.ts +11 -0
  350. package/lib/typescript/components/BrandMark.d.ts.map +1 -0
  351. package/lib/typescript/components/CodeInput.d.ts +10 -0
  352. package/lib/typescript/components/CodeInput.d.ts.map +1 -0
  353. package/lib/typescript/components/EmailInput.d.ts +8 -0
  354. package/lib/typescript/components/EmailInput.d.ts.map +1 -0
  355. package/lib/typescript/components/ExistingUserDataConfirmation.d.ts +12 -0
  356. package/lib/typescript/components/ExistingUserDataConfirmation.d.ts.map +1 -0
  357. package/lib/typescript/components/GoogleButton.d.ts +11 -0
  358. package/lib/typescript/components/GoogleButton.d.ts.map +1 -0
  359. package/lib/typescript/components/HeadingGroup.d.ts +11 -0
  360. package/lib/typescript/components/HeadingGroup.d.ts.map +1 -0
  361. package/lib/typescript/components/ModalHeader.d.ts +11 -0
  362. package/lib/typescript/components/ModalHeader.d.ts.map +1 -0
  363. package/lib/typescript/components/ModalSheet.d.ts +13 -0
  364. package/lib/typescript/components/ModalSheet.d.ts.map +1 -0
  365. package/lib/typescript/components/Onairos.d.ts.map +1 -1
  366. package/lib/typescript/components/OnairosButton.d.ts +29 -4
  367. package/lib/typescript/components/OnairosButton.d.ts.map +1 -1
  368. package/lib/typescript/components/OnairosSignInButton.d.ts +14 -0
  369. package/lib/typescript/components/OnairosSignInButton.d.ts.map +1 -0
  370. package/lib/typescript/components/PersonaImage.d.ts +8 -0
  371. package/lib/typescript/components/PersonaImage.d.ts.map +1 -0
  372. package/lib/typescript/components/PersonaLoadingScreen.d.ts +10 -0
  373. package/lib/typescript/components/PersonaLoadingScreen.d.ts.map +1 -0
  374. package/lib/typescript/components/PersonalizationConsentScreen.d.ts +10 -0
  375. package/lib/typescript/components/PersonalizationConsentScreen.d.ts.map +1 -0
  376. package/lib/typescript/components/PinCreationScreen.d.ts +10 -0
  377. package/lib/typescript/components/PinCreationScreen.d.ts.map +1 -0
  378. package/lib/typescript/components/PinInput.d.ts +11 -1
  379. package/lib/typescript/components/PinInput.d.ts.map +1 -1
  380. package/lib/typescript/components/PlatformConnectorsStep.d.ts +11 -0
  381. package/lib/typescript/components/PlatformConnectorsStep.d.ts.map +1 -0
  382. package/lib/typescript/components/PlatformToggle.d.ts +20 -0
  383. package/lib/typescript/components/PlatformToggle.d.ts.map +1 -0
  384. package/lib/typescript/components/PrimaryButton.d.ts +22 -0
  385. package/lib/typescript/components/PrimaryButton.d.ts.map +1 -0
  386. package/lib/typescript/components/SignInMatchAnimation.d.ts +9 -0
  387. package/lib/typescript/components/SignInMatchAnimation.d.ts.map +1 -0
  388. package/lib/typescript/components/SignInStep.d.ts +12 -0
  389. package/lib/typescript/components/SignInStep.d.ts.map +1 -0
  390. package/lib/typescript/components/TrainingModal.d.ts +12 -1
  391. package/lib/typescript/components/TrainingModal.d.ts.map +1 -1
  392. package/lib/typescript/components/UniversalOnboarding.d.ts +14 -1
  393. package/lib/typescript/components/UniversalOnboarding.d.ts.map +1 -1
  394. package/lib/typescript/components/VerificationStep.d.ts +13 -0
  395. package/lib/typescript/components/VerificationStep.d.ts.map +1 -0
  396. package/lib/typescript/components/WelcomeScreen.d.ts +9 -0
  397. package/lib/typescript/components/WelcomeScreen.d.ts.map +1 -0
  398. package/lib/typescript/components/icons/Basicproficon.d.ts +5 -0
  399. package/lib/typescript/components/icons/Basicproficon.d.ts.map +1 -0
  400. package/lib/typescript/components/icons/Basicprofile.d.ts +5 -0
  401. package/lib/typescript/components/icons/Basicprofile.d.ts.map +1 -0
  402. package/lib/typescript/components/icons/Checkbox.d.ts +5 -0
  403. package/lib/typescript/components/icons/Checkbox.d.ts.map +1 -0
  404. package/lib/typescript/components/icons/Checkmark.d.ts +5 -0
  405. package/lib/typescript/components/icons/Checkmark.d.ts.map +1 -0
  406. package/lib/typescript/components/icons/Contentanalysis.d.ts +5 -0
  407. package/lib/typescript/components/icons/Contentanalysis.d.ts.map +1 -0
  408. package/lib/typescript/components/icons/Contenticon.d.ts +5 -0
  409. package/lib/typescript/components/icons/Contenticon.d.ts.map +1 -0
  410. package/lib/typescript/components/icons/EnochE.d.ts +5 -0
  411. package/lib/typescript/components/icons/EnochE.d.ts.map +1 -0
  412. package/lib/typescript/components/icons/Personalityicon.d.ts +5 -0
  413. package/lib/typescript/components/icons/Personalityicon.d.ts.map +1 -0
  414. package/lib/typescript/components/icons/Personalityprofile.d.ts +5 -0
  415. package/lib/typescript/components/icons/Personalityprofile.d.ts.map +1 -0
  416. package/lib/typescript/components/icons/Personalitytraits.d.ts +5 -0
  417. package/lib/typescript/components/icons/Personalitytraits.d.ts.map +1 -0
  418. package/lib/typescript/components/icons/Userpreferences.d.ts +5 -0
  419. package/lib/typescript/components/icons/Userpreferences.d.ts.map +1 -0
  420. package/lib/typescript/components/icons/index.d.ts +12 -0
  421. package/lib/typescript/components/icons/index.d.ts.map +1 -0
  422. package/lib/typescript/components/onboarding/OAuthWebView.d.ts.map +1 -1
  423. package/lib/typescript/config/api.d.ts +24 -0
  424. package/lib/typescript/config/api.d.ts.map +1 -0
  425. package/lib/typescript/context/AuthContext.d.ts +34 -0
  426. package/lib/typescript/context/AuthContext.d.ts.map +1 -0
  427. package/lib/typescript/hooks/useConnectedAccounts.d.ts +11 -0
  428. package/lib/typescript/hooks/useConnectedAccounts.d.ts.map +1 -0
  429. package/lib/typescript/hooks/useConnections.d.ts +10 -5
  430. package/lib/typescript/hooks/useConnections.d.ts.map +1 -1
  431. package/lib/typescript/hooks/useUserConnections.d.ts +12 -0
  432. package/lib/typescript/hooks/useUserConnections.d.ts.map +1 -0
  433. package/lib/typescript/index.d.ts +24 -6
  434. package/lib/typescript/index.d.ts.map +1 -1
  435. package/lib/typescript/services/apiClient.d.ts +91 -0
  436. package/lib/typescript/services/apiClient.d.ts.map +1 -0
  437. package/lib/typescript/services/authService.d.ts +216 -0
  438. package/lib/typescript/services/authService.d.ts.map +1 -0
  439. package/lib/typescript/services/biometricPinService.d.ts +29 -0
  440. package/lib/typescript/services/biometricPinService.d.ts.map +1 -0
  441. package/lib/typescript/services/connectedAccountsService.d.ts +56 -0
  442. package/lib/typescript/services/connectedAccountsService.d.ts.map +1 -0
  443. package/lib/typescript/services/googleAuthService.d.ts +63 -0
  444. package/lib/typescript/services/googleAuthService.d.ts.map +1 -0
  445. package/lib/typescript/services/imageCompressionService.d.ts +37 -0
  446. package/lib/typescript/services/imageCompressionService.d.ts.map +1 -0
  447. package/lib/typescript/services/jwtStorageService.d.ts +86 -0
  448. package/lib/typescript/services/jwtStorageService.d.ts.map +1 -0
  449. package/lib/typescript/services/mobileTrainingService.d.ts +45 -0
  450. package/lib/typescript/services/mobileTrainingService.d.ts.map +1 -0
  451. package/lib/typescript/services/pinEncryptionService.d.ts +17 -0
  452. package/lib/typescript/services/pinEncryptionService.d.ts.map +1 -0
  453. package/lib/typescript/services/pinStorageUtils.d.ts +25 -0
  454. package/lib/typescript/services/pinStorageUtils.d.ts.map +1 -0
  455. package/lib/typescript/services/platformAuthService.d.ts +34 -109
  456. package/lib/typescript/services/platformAuthService.d.ts.map +1 -1
  457. package/lib/typescript/services/storageService.d.ts +128 -0
  458. package/lib/typescript/services/storageService.d.ts.map +1 -0
  459. package/lib/typescript/services/trainingApiHelpers.d.ts +38 -0
  460. package/lib/typescript/services/trainingApiHelpers.d.ts.map +1 -0
  461. package/lib/typescript/services/userConnectionsService.d.ts +90 -0
  462. package/lib/typescript/services/userConnectionsService.d.ts.map +1 -0
  463. package/lib/typescript/services/youtubeMigrationService.d.ts +12 -0
  464. package/lib/typescript/services/youtubeMigrationService.d.ts.map +1 -0
  465. package/lib/typescript/theme/index.d.ts +416 -0
  466. package/lib/typescript/theme/index.d.ts.map +1 -0
  467. package/lib/typescript/types/index.d.ts +39 -0
  468. package/lib/typescript/types/index.d.ts.map +1 -1
  469. package/lib/typescript/utils/eventUtils.d.ts +108 -0
  470. package/lib/typescript/utils/eventUtils.d.ts.map +1 -0
  471. package/lib/typescript/utils/haptics.d.ts +11 -0
  472. package/lib/typescript/utils/haptics.d.ts.map +1 -0
  473. package/lib/typescript/utils/imagePreloader.d.ts +2 -0
  474. package/lib/typescript/utils/imagePreloader.d.ts.map +1 -0
  475. package/package.json +158 -145
  476. package/src/api/index.ts +41 -0
  477. package/src/assets/fonts/EBGaramond-VariableFont_wght.ttf +0 -0
  478. package/src/assets/fonts/IBMPlexSans-VariableFont_wdth,wght.ttf +0 -0
  479. package/src/assets/icons/Facebookicon.png +0 -0
  480. package/src/assets/icons/Gmail.png +0 -0
  481. package/src/assets/icons/Linkedinicon.png +0 -0
  482. package/src/assets/icons/Redditicon.png +0 -0
  483. package/src/assets/icons/YouTubeicon2.png +0 -0
  484. package/src/assets/icons/YouTubeicon3.png +0 -0
  485. package/src/assets/icons/farcaster.png +0 -0
  486. package/src/assets/icons/instagram.png +0 -0
  487. package/src/assets/icons/pinterest.png +0 -0
  488. package/src/assets/icons/swerv_logo.png +0 -0
  489. package/src/assets/icons/twitter.jpg +0 -0
  490. package/src/assets/images/Checkbox.svg +3 -0
  491. package/src/assets/images/EnochE.svg +19 -0
  492. package/src/assets/images/Enochicon1.png +0 -0
  493. package/src/assets/images/Face_ID_logo.png +0 -0
  494. package/src/assets/images/Facebookicon.png +0 -0
  495. package/src/assets/images/Gmail.png +0 -0
  496. package/src/assets/images/Googlelogo.png +0 -0
  497. package/src/assets/images/Linkedinicon.png +0 -0
  498. package/src/assets/images/Onairoslogo.png +0 -0
  499. package/src/assets/images/Personalityprofile.svg +3 -0
  500. package/src/assets/images/Personalitytraits.svg +3 -0
  501. package/src/assets/images/Redditicon.png +0 -0
  502. package/src/assets/images/Userpreferences.svg +3 -0
  503. package/src/assets/images/YouTubeicon3.png +0 -0
  504. package/src/assets/images/arrow.svg +20 -0
  505. package/src/assets/images/basicproficon.svg +43 -0
  506. package/src/assets/images/basicprofile.svg +3 -0
  507. package/src/assets/images/checkmark.svg +4 -0
  508. package/src/assets/images/contentanalysis.svg +3 -0
  509. package/src/assets/images/contenticon.svg +23 -0
  510. package/src/assets/images/persona1.png +0 -0
  511. package/src/assets/images/persona2.png +0 -0
  512. package/src/assets/images/persona3.png +0 -0
  513. package/src/assets/images/persona4.png +0 -0
  514. package/src/assets/images/persona5.png +0 -0
  515. package/src/assets/images/personalityicon.svg +18 -0
  516. package/src/assets/images/x-close.svg +3 -0
  517. package/src/components/BodyText.tsx +33 -0
  518. package/src/components/BrandMark.tsx +62 -0
  519. package/src/components/CodeInput.tsx +32 -0
  520. package/src/components/EmailInput.tsx +31 -0
  521. package/src/components/ExistingUserDataConfirmation.tsx +507 -0
  522. package/src/components/GoogleButton.tsx +55 -0
  523. package/src/components/HeadingGroup.tsx +49 -0
  524. package/src/components/ModalHeader.tsx +125 -0
  525. package/src/components/ModalSheet.tsx +57 -0
  526. package/src/components/Onairos.tsx +422 -424
  527. package/src/components/OnairosButton.tsx +339 -359
  528. package/src/components/OnairosSignInButton.tsx +166 -0
  529. package/src/components/Overlay.tsx +506 -506
  530. package/src/components/PersonaImage.tsx +79 -0
  531. package/src/components/PersonaLoadingScreen.tsx +201 -0
  532. package/src/components/PersonalizationConsentScreen.tsx +410 -0
  533. package/src/components/PinCreationScreen.tsx +492 -0
  534. package/src/components/PinInput.tsx +555 -343
  535. package/src/components/PlatformConnectorsStep.tsx +892 -0
  536. package/src/components/PlatformToggle.tsx +226 -0
  537. package/src/components/PrimaryButton.tsx +214 -0
  538. package/src/components/SignInMatchAnimation.tsx +225 -0
  539. package/src/components/SignInStep.tsx +217 -0
  540. package/src/components/TrainingModal.tsx +1047 -737
  541. package/src/components/UniversalOnboarding.tsx +2888 -1820
  542. package/src/components/VerificationStep.tsx +198 -0
  543. package/src/components/WelcomeScreen.tsx +473 -0
  544. package/src/components/icons/Basicproficon.tsx +30 -0
  545. package/src/components/icons/Basicprofile.tsx +17 -0
  546. package/src/components/icons/Checkbox.tsx +17 -0
  547. package/src/components/icons/Checkmark.tsx +24 -0
  548. package/src/components/icons/Contentanalysis.tsx +17 -0
  549. package/src/components/icons/Contenticon.tsx +30 -0
  550. package/src/components/icons/EnochE.tsx +39 -0
  551. package/src/components/icons/Personalityicon.tsx +22 -0
  552. package/src/components/icons/Personalityprofile.tsx +17 -0
  553. package/src/components/icons/Personalitytraits.tsx +17 -0
  554. package/src/components/icons/Userpreferences.tsx +17 -0
  555. package/src/components/icons/index.ts +12 -0
  556. package/src/components/onboarding/OAuthWebView.tsx +232 -838
  557. package/src/config/api.ts +25 -0
  558. package/src/context/AuthContext.tsx +393 -0
  559. package/src/hooks/useConnectedAccounts.ts +139 -0
  560. package/src/hooks/useConnections.ts +129 -131
  561. package/src/hooks/useUserConnections.ts +166 -0
  562. package/src/index.ts +94 -49
  563. package/src/services/apiClient.ts +337 -0
  564. package/src/services/authService.ts +1008 -0
  565. package/src/services/biometricPinService.ts +193 -0
  566. package/src/services/connectedAccountsService.ts +290 -0
  567. package/src/services/googleAuthService.ts +279 -0
  568. package/src/services/imageCompressionService.ts +303 -0
  569. package/src/services/jwtStorageService.ts +257 -0
  570. package/src/services/mobileTrainingService.ts +204 -0
  571. package/src/services/pinEncryptionService.ts +76 -0
  572. package/src/services/pinStorageUtils.ts +97 -0
  573. package/src/services/platformAuthService.ts +1346 -1113
  574. package/src/services/storageService.ts +452 -0
  575. package/src/services/trainingApiHelpers.ts +67 -0
  576. package/src/services/userConnectionsService.ts +557 -0
  577. package/src/services/youtubeMigrationService.ts +454 -0
  578. package/src/theme/index.ts +239 -0
  579. package/src/types/index.ts +265 -238
  580. package/src/utils/eventUtils.ts +303 -0
  581. package/src/utils/haptics.ts +59 -0
  582. package/src/utils/imagePreloader.ts +2 -0
  583. package/README.md +0 -375
  584. package/lib/commonjs/assets/images/email.png +0 -0
  585. package/lib/commonjs/assets/images/linkedin.png +0 -0
  586. package/lib/commonjs/assets/images/reddit.png +0 -0
  587. package/lib/commonjs/assets/images/youtube.png +0 -0
  588. package/lib/commonjs/components/UniversalOnboarding.tsx.new +0 -455
  589. package/lib/module/assets/images/email.png +0 -0
  590. package/lib/module/assets/images/linkedin.png +0 -0
  591. package/lib/module/assets/images/reddit.png +0 -0
  592. package/lib/module/assets/images/youtube.png +0 -0
  593. package/lib/module/components/UniversalOnboarding.tsx.new +0 -455
  594. package/src/assets/images/email.png +0 -0
  595. package/src/assets/images/linkedin.png +0 -0
  596. package/src/assets/images/reddit.png +0 -0
  597. package/src/assets/images/youtube.png +0 -0
  598. package/src/components/UniversalOnboarding.tsx.new +0 -455
@@ -1,359 +1,339 @@
1
- import React, { useState, useCallback, forwardRef, useImperativeHandle } from 'react';
2
- import {
3
- TouchableOpacity,
4
- Text,
5
- StyleSheet,
6
- View,
7
- ViewStyle,
8
- TextStyle,
9
- ActivityIndicator,
10
- Image,
11
- } from 'react-native';
12
- import { UniversalOnboarding } from './UniversalOnboarding';
13
- import { Overlay } from './Overlay';
14
- import { COLORS } from '../constants';
15
- import type { OnairosButtonProps } from '../types';
16
- import { hasCredentials, getCredentials, deleteCredentials as clearCredentials } from '../utils/secureStorage';
17
- import { onairosApi } from '../api';
18
-
19
- export interface OnairosButtonRef {
20
- trigger: () => Promise<void>;
21
- reset: () => Promise<void>;
22
- }
23
-
24
- /**
25
- * OnairosButton Component - A sign-in button similar to Google/Apple sign-in
26
- */
27
- export const OnairosButton = forwardRef<OnairosButtonRef, OnairosButtonProps>(({
28
- AppName,
29
- appIcon,
30
- requestData,
31
- returnLink,
32
- prefillUrl,
33
- buttonType = 'normal',
34
- buttonWidth = 180,
35
- buttonHeight = 48,
36
- hasStroke = false,
37
- enabled = true,
38
- buttonForm = 'default',
39
- auto = false,
40
- onRejection,
41
- onResolved,
42
- preCheck,
43
- color,
44
- swerv = false,
45
- debug = false,
46
- preferredPlatform,
47
- testMode = false,
48
- darkMode = false,
49
- }, ref) => {
50
- const [showOnboarding, setShowOnboarding] = useState(false);
51
- const [showOverlay, setShowOverlay] = useState(false);
52
- const [storedCredentials, setStoredCredentials] = useState<any>(null);
53
- const [isLoading, setIsLoading] = useState(false);
54
- const [isPressed, setIsPressed] = useState(false);
55
-
56
- // Expose methods via ref
57
- useImperativeHandle(ref, () => ({
58
- trigger: async () => {
59
- await handlePress();
60
- },
61
- reset: async () => {
62
- await clearCredentials();
63
- }
64
- }));
65
-
66
- // Compute button text based on buttonForm
67
- const getButtonText = () => {
68
- if (buttonForm === 'connect' || buttonForm === 'signup') {
69
- return 'Connect with Onairos';
70
- } else {
71
- return 'Sign in with Onairos';
72
- }
73
- };
74
-
75
- // Calculate background color based on props and state
76
- const getBackgroundColor = (): string => {
77
- if (!enabled) {
78
- return darkMode ? '#3A3A3A' : '#e0e0e0';
79
- }
80
-
81
- if (isPressed) {
82
- return color ?
83
- (typeof color === 'string' ? `${color}80` : color) :
84
- (darkMode ? '#32323280' : '#f5f5f580');
85
- }
86
-
87
- return color || (darkMode ? '#2A2A2A' : '#ffffff');
88
- };
89
-
90
- // Calculate text color based on background luminance
91
- const getTextColor = (): string => {
92
- if (!enabled) {
93
- return darkMode ? '#777777' : '#AAAAAA';
94
- }
95
-
96
- if (darkMode) {
97
- return '#FFFFFF';
98
- }
99
-
100
- const bgColor = getBackgroundColor();
101
- // Simple luminance check
102
- return bgColor === '#ffffff' || bgColor === '#f5f5f580' || bgColor.includes('#f') ? '#000000' : '#FFFFFF';
103
- };
104
-
105
- const handlePress = async () => {
106
- if (!enabled || isLoading) return;
107
-
108
- setIsLoading(true);
109
-
110
- try {
111
- // If auto is enabled, make API call automatically and return result
112
- if (auto) {
113
- try {
114
- // Check if credentials exist
115
- const hasStoredCreds = await hasCredentials();
116
-
117
- if (hasStoredCreds) {
118
- const credentials = await getCredentials();
119
-
120
- if (!credentials || !credentials.username) {
121
- throw new Error('Invalid credentials');
122
- }
123
-
124
- // Call the API directly and return result
125
- const result = await fetch(`https://api2.onairos.uk/api/inference`, {
126
- method: 'POST',
127
- headers: {
128
- 'Content-Type': 'application/json',
129
- 'Authorization': `Bearer ${credentials.userPin || ''}`
130
- },
131
- body: JSON.stringify({
132
- username: credentials.username,
133
- modelKey: credentials.userPin || '',
134
- requestData: requestData || {},
135
- appName: AppName
136
- })
137
- }).then(res => res.json());
138
-
139
- if (result && result.success) {
140
- if (onResolved) {
141
- onResolved(result.apiUrl || 'https://api2.onairos.uk', result.token || '', result.data || {});
142
- }
143
- setIsLoading(false);
144
- return;
145
- } else {
146
- throw new Error(result?.error || 'API call failed');
147
- }
148
- } else {
149
- // No credentials, proceed with normal flow
150
- console.log('No credentials found, proceeding with normal flow');
151
- }
152
- } catch (automaticError) {
153
- console.error('Automatic API call error:', automaticError);
154
- // Fall back to normal flow on error
155
- }
156
- }
157
-
158
- if (preCheck) {
159
- const shouldProceed = await preCheck();
160
- if (!shouldProceed) {
161
- onRejection?.('Precheck validation failed');
162
- setIsLoading(false);
163
- return;
164
- }
165
- }
166
-
167
- // Check if credentials exist
168
- const hasStoredCreds = await hasCredentials();
169
-
170
- if (hasStoredCreds) {
171
- // If credentials exist, fetch them and verify
172
- const credentials = await getCredentials();
173
-
174
- if (!credentials || !credentials.username) {
175
- // Invalid credentials, clear and start fresh
176
- await clearCredentials();
177
- setShowOnboarding(true);
178
- setIsLoading(false);
179
- return;
180
- }
181
-
182
- try {
183
- // Validate credentials with server
184
- const isValid = await onairosApi.validateCredentials(credentials.username);
185
-
186
- if (!isValid) {
187
- // Clear invalid credentials
188
- await clearCredentials();
189
- setShowOnboarding(true);
190
- setIsLoading(false);
191
- return;
192
- }
193
-
194
- // Store and display overlay with valid credentials
195
- setStoredCredentials(credentials);
196
- setShowOverlay(true);
197
- } catch (validationError) {
198
- console.warn('Validation error, proceeding to onboarding:', validationError);
199
- setShowOnboarding(true);
200
- }
201
- } else {
202
- // If no credentials, show onboarding
203
- setShowOnboarding(true);
204
- }
205
- } catch (error) {
206
- console.error('Error during button press flow:', error);
207
- // Only call onRejection for actual errors, not when user cancels
208
- // The onboarding component will handle user cancellation separately
209
- setShowOnboarding(true);
210
- } finally {
211
- setIsLoading(false);
212
- }
213
- };
214
-
215
- const handleOnboardingComplete = useCallback((apiUrl: string, token: string, data: any) => {
216
- setShowOnboarding(false);
217
- if (onResolved) {
218
- onResolved(apiUrl, token, data);
219
- }
220
- }, [onResolved]);
221
-
222
- const handleOverlayResolved = useCallback((apiUrl: string, token: string, data: any) => {
223
- setShowOverlay(false);
224
- if (onResolved) {
225
- onResolved(apiUrl, token, data);
226
- }
227
- }, [onResolved]);
228
-
229
- // Calculate button styles based on props
230
- const buttonStyle: ViewStyle[] = [
231
- styles.button,
232
- buttonType === 'pill' && styles.pillButton,
233
- hasStroke && styles.strokedButton,
234
- {
235
- width: buttonWidth,
236
- height: buttonHeight,
237
- backgroundColor: getBackgroundColor(),
238
- borderColor: darkMode ? '#555555' : '#000000',
239
- },
240
- swerv && styles.swervButton,
241
- !enabled && styles.disabledButton
242
- ].filter(Boolean) as ViewStyle[];
243
-
244
- // Calculate button text color
245
- const buttonTextColor = getTextColor();
246
-
247
- // Render components
248
- return (
249
- <>
250
- <TouchableOpacity
251
- style={buttonStyle}
252
- onPress={handlePress}
253
- disabled={!enabled || isLoading}
254
- accessibilityLabel={`Sign in with Onairos`}
255
- onPressIn={() => setIsPressed(true)}
256
- onPressOut={() => setIsPressed(false)}
257
- >
258
- {isLoading ? (
259
- <ActivityIndicator
260
- size="small"
261
- color={buttonTextColor}
262
- />
263
- ) : (
264
- <View style={styles.buttonContent}>
265
- <Image
266
- source={require('../assets/images/onairos_logo.png')}
267
- style={styles.logo}
268
- resizeMode="contain"
269
- />
270
- <Text style={[styles.buttonText, { color: buttonTextColor }]}>
271
- {getButtonText()}
272
- </Text>
273
- </View>
274
- )}
275
- </TouchableOpacity>
276
-
277
- {/* Overlay and Onboarding components rendered outside the button */}
278
- {showOnboarding && (
279
- <UniversalOnboarding
280
- visible={showOnboarding}
281
- onClose={() => {
282
- setShowOnboarding(false);
283
- onRejection?.('User closed onboarding');
284
- }}
285
- AppName={AppName}
286
- appIcon={appIcon}
287
- requestData={requestData as any}
288
- returnLink={returnLink || ''}
289
- onComplete={handleOnboardingComplete}
290
- debug={debug}
291
- testMode={testMode}
292
- preferredPlatform={preferredPlatform}
293
- />
294
- )}
295
-
296
- {/* Overlay rendered directly without Portal */}
297
- {showOverlay && storedCredentials && (
298
- <Overlay
299
- data={requestData || {}}
300
- username={storedCredentials.username}
301
- modelKey={storedCredentials.userPin || ''}
302
- onResolved={handleOverlayResolved}
303
- appName={AppName}
304
- darkMode={darkMode}
305
- />
306
- )}
307
- </>
308
- );
309
- });
310
-
311
- const styles = StyleSheet.create({
312
- button: {
313
- flexDirection: 'row',
314
- alignItems: 'center',
315
- justifyContent: 'center',
316
- paddingVertical: 12,
317
- paddingHorizontal: 16,
318
- borderRadius: 8,
319
- shadowColor: '#000',
320
- shadowOffset: { width: 0, height: 2 },
321
- shadowOpacity: 0.1,
322
- shadowRadius: 4,
323
- elevation: 2,
324
- },
325
- buttonContent: {
326
- flexDirection: 'row',
327
- alignItems: 'center',
328
- justifyContent: 'center',
329
- },
330
- logo: {
331
- width: 24,
332
- height: 24,
333
- marginRight: 8,
334
- },
335
- pillButton: {
336
- borderRadius: 24,
337
- },
338
- strokedButton: {
339
- backgroundColor: 'transparent',
340
- borderWidth: 1,
341
- },
342
- swervButton: {
343
- transform: [{ rotate: '0deg' }],
344
- },
345
- disabledButton: {
346
- opacity: 0.6,
347
- },
348
- buttonText: {
349
- fontSize: 16,
350
- fontWeight: '600',
351
- textAlign: 'center',
352
- },
353
- });
354
-
355
- // Add displayName for better debugging
356
- OnairosButton.displayName = 'OnairosButton';
357
-
358
- // Ensure the component is properly exported
359
- export default OnairosButton;
1
+ import React, { useState, useCallback, forwardRef, useImperativeHandle, useEffect } from 'react';
2
+ import {
3
+ TouchableOpacity,
4
+ Text,
5
+ StyleSheet,
6
+ View,
7
+ ActivityIndicator,
8
+ Dimensions,
9
+ Image,
10
+ } from 'react-native';
11
+ import LinearGradient from 'react-native-linear-gradient';
12
+ import { UniversalOnboarding } from './UniversalOnboarding';
13
+ import WelcomeScreen from './WelcomeScreen';
14
+
15
+ export interface OnairosButtonProps {
16
+ AppName: string;
17
+ buttonType?: 'normal' | 'pill';
18
+ buttonWidth?: number;
19
+ buttonHeight?: number;
20
+ hasStroke?: boolean;
21
+ enabled?: boolean;
22
+ buttonForm?: 'default' | 'login' | 'signup' | 'connect';
23
+ onResolved?: (token: string, email?: string) => void;
24
+ onRejection?: (error: any) => void;
25
+ preCheck?: () => Promise<boolean>;
26
+ color?: string;
27
+ swerv?: boolean;
28
+ darkMode?: boolean;
29
+ returnLink?: string;
30
+ preferredPlatform?: string;
31
+ autoFetch?: boolean;
32
+ inferenceData?: any;
33
+ textLayout?: 'left' | 'right' | 'center';
34
+ textColor?: string;
35
+ proofMode?: boolean;
36
+ webpageName?: string;
37
+ debug?: boolean;
38
+ testMode?: boolean;
39
+ requestData?: any;
40
+ onPress?: () => void;
41
+ primaryAuthOnly?: boolean;
42
+ useNewWelcomeFlow?: boolean; // NEW: Enable the refreshed welcome screen experience
43
+ }
44
+
45
+ export interface OnairosButtonRef {
46
+ trigger: () => Promise<void>;
47
+ reset: () => Promise<void>;
48
+ }
49
+
50
+ const { width } = Dimensions.get('window');
51
+
52
+ export const OnairosButton = forwardRef<OnairosButtonRef, OnairosButtonProps>(({
53
+ AppName,
54
+ buttonType = 'normal',
55
+ buttonWidth = 180,
56
+ buttonHeight = 48,
57
+ hasStroke = false,
58
+ enabled = true,
59
+ buttonForm = 'default',
60
+ onResolved,
61
+ onRejection,
62
+ preCheck,
63
+ color = '#1BA9D4',
64
+ swerv = false,
65
+ darkMode = false,
66
+ returnLink,
67
+ preferredPlatform,
68
+ autoFetch = false,
69
+ inferenceData,
70
+ textLayout = 'right',
71
+ textColor = 'black',
72
+ proofMode = false,
73
+ webpageName,
74
+ debug = false,
75
+ testMode = false,
76
+ requestData,
77
+ onPress,
78
+ primaryAuthOnly = false,
79
+ useNewWelcomeFlow = false,
80
+ }, ref) => {
81
+ const [isLoading, setIsLoading] = useState(false);
82
+ const [isPressed, setIsPressed] = useState(false);
83
+ const [showOnboarding, setShowOnboarding] = useState(false);
84
+ console.log('[OnairosButton] Initializing. Initial showOnboarding:', showOnboarding);
85
+
86
+ useEffect(() => {
87
+ console.log('[OnairosButton] LogEffect: showOnboarding state changed to:', showOnboarding);
88
+ }, [showOnboarding]);
89
+
90
+ // Expose methods via ref
91
+ useImperativeHandle(ref, () => ({
92
+ trigger: async () => {
93
+ await handlePress();
94
+ return Promise.resolve();
95
+ },
96
+ reset: async () => {
97
+ return Promise.resolve();
98
+ }
99
+ }));
100
+
101
+ const handlePress = async () => {
102
+ console.log('[OnairosButton] handlePress called.');
103
+ if (!enabled || isLoading) return;
104
+
105
+ setIsLoading(true);
106
+
107
+ try {
108
+ if (preCheck) {
109
+ const shouldProceed = await preCheck();
110
+ if (!shouldProceed) {
111
+ console.log('[OnairosButton] Precheck failed. Setting showOnboarding to false (indirectly, by not setting to true).');
112
+ onRejection?.('Precheck validation failed');
113
+ setIsLoading(false);
114
+ return;
115
+ }
116
+ }
117
+
118
+ console.log('[OnairosButton] handlePress: Setting showOnboarding to true.');
119
+ setShowOnboarding(true);
120
+ setIsLoading(false);
121
+ } catch (error) {
122
+ console.error('[OnairosButton] Error in handlePress:', error);
123
+ onRejection?.(error instanceof Error ? error.message : 'Unknown error');
124
+ setIsLoading(false);
125
+ }
126
+ };
127
+
128
+ // Compute button text based on buttonForm
129
+ const getButtonText = () => {
130
+ switch (buttonForm) {
131
+ case 'connect':
132
+ return 'Connect Onairos';
133
+ case 'login':
134
+ return 'Sign in with Onairos';
135
+ case 'signup':
136
+ return 'Sign up with Onairos';
137
+ default:
138
+ return 'Connect Onairos';
139
+ }
140
+ };
141
+
142
+ // Handle onboarding completion
143
+ const handleOnboardingComplete = useCallback((token: string, email?: string) => {
144
+ console.log('[OnairosButton] handleOnboardingComplete: Setting showOnboarding to false.');
145
+ setShowOnboarding(false);
146
+
147
+ if (onResolved) {
148
+ // Call onResolved with the token and email
149
+ onResolved(token, email);
150
+ }
151
+
152
+ if (onPress) {
153
+ onPress();
154
+ }
155
+ }, [onResolved, onPress]);
156
+
157
+ // Handle onboarding close
158
+ const handleOnboardingClose = useCallback(() => {
159
+ console.log('[OnairosButton] handleOnboardingClose: Setting showOnboarding to false.');
160
+ setShowOnboarding(false);
161
+ if (onRejection) {
162
+ onRejection('User closed onboarding');
163
+ }
164
+ }, [onRejection]);
165
+
166
+ console.log('[OnairosButton] Rendering JSX with props:', {
167
+ AppName,
168
+ buttonType,
169
+ buttonWidth,
170
+ buttonHeight,
171
+ hasStroke,
172
+ enabled,
173
+ buttonForm,
174
+ onResolved,
175
+ onRejection,
176
+ preCheck,
177
+ color,
178
+ swerv,
179
+ darkMode,
180
+ returnLink,
181
+ preferredPlatform,
182
+ autoFetch,
183
+ inferenceData,
184
+ textLayout,
185
+ textColor,
186
+ proofMode,
187
+ webpageName,
188
+ debug,
189
+ testMode,
190
+ requestData,
191
+ onPress,
192
+ primaryAuthOnly,
193
+ useNewWelcomeFlow,
194
+ });
195
+
196
+ return (
197
+ <>
198
+ <View>
199
+ <TouchableOpacity
200
+ style={[
201
+ styles.button,
202
+ buttonType === 'pill' && styles.pillButton,
203
+ hasStroke && styles.strokedButton,
204
+ {
205
+ width: buttonWidth,
206
+ height: buttonHeight,
207
+ },
208
+ swerv && styles.swervButton,
209
+ !enabled && styles.disabledButton
210
+ ]}
211
+ onPress={handlePress}
212
+ disabled={!enabled || isLoading}
213
+ onPressIn={() => setIsPressed(true)}
214
+ onPressOut={() => setIsPressed(false)}
215
+ >
216
+ <LinearGradient
217
+ colors={['#f5e7c1', '#C7A047', '#8B6914']}
218
+ start={{x: 0, y: 0}}
219
+ end={{x: 1, y: 0}}
220
+ style={{
221
+ position: 'absolute',
222
+ left: 0,
223
+ right: 0,
224
+ top: 0,
225
+ bottom: 0,
226
+ borderRadius: buttonType === 'pill' ? 24 : 8,
227
+ }}
228
+ />
229
+
230
+ {isLoading ? (
231
+ <ActivityIndicator
232
+ size="small"
233
+ color="#FFFFFF"
234
+ />
235
+ ) : (
236
+ <View style={styles.buttonContent}>
237
+ <View style={styles.logoContainer}>
238
+ <Image
239
+ source={require('../assets/images/onairos_logo.png')}
240
+ style={styles.logoImage}
241
+ resizeMode="contain"
242
+ />
243
+ </View>
244
+ <Text style={[styles.buttonText, { color: '#FFFFFF' }]}>
245
+ {getButtonText()}
246
+ </Text>
247
+ </View>
248
+ )}
249
+ </TouchableOpacity>
250
+ </View>
251
+
252
+ {/* Onboarding Modal - Choose between new WelcomeScreen or legacy UniversalOnboarding */}
253
+ {useNewWelcomeFlow ? (
254
+ <WelcomeScreen
255
+ visible={showOnboarding}
256
+ onClose={handleOnboardingClose}
257
+ onComplete={handleOnboardingComplete}
258
+ />
259
+ ) : (
260
+ <UniversalOnboarding
261
+ visible={showOnboarding}
262
+ onClose={handleOnboardingClose}
263
+ AppName={AppName}
264
+ requestData={requestData || {
265
+ Small: { type: 'Small', descriptions: 'Basic tier', reward: 'Free access' },
266
+ Medium: { type: 'Medium', descriptions: 'Standard tier', reward: 'Premium features' },
267
+ Large: { type: 'Large', descriptions: 'Premium tier', reward: 'Full personalization' }
268
+ }}
269
+ returnLink={returnLink || 'onairosevents://auth/callback'}
270
+ onComplete={handleOnboardingComplete}
271
+ debug={debug}
272
+ test={testMode}
273
+ preferredPlatform={preferredPlatform}
274
+ primaryAuthOnly={primaryAuthOnly}
275
+ />
276
+ )}
277
+ </>
278
+ );
279
+ });
280
+
281
+ const styles = StyleSheet.create({
282
+ button: {
283
+ flexDirection: 'row',
284
+ alignItems: 'center',
285
+ justifyContent: 'center',
286
+ paddingVertical: 12,
287
+ paddingHorizontal: 16,
288
+ borderRadius: 8,
289
+ shadowColor: '#000',
290
+ shadowOffset: { width: 0, height: 2 },
291
+ shadowOpacity: 0.2,
292
+ shadowRadius: 4,
293
+ elevation: 3,
294
+ overflow: 'hidden',
295
+ },
296
+ buttonContent: {
297
+ flexDirection: 'row',
298
+ alignItems: 'center',
299
+ justifyContent: 'center',
300
+ },
301
+ logoContainer: {
302
+ width: 24,
303
+ height: 24,
304
+ // borderRadius: 12, // Removed to eliminate circle shape
305
+ // backgroundColor: '#FFFFFF', // Removed to eliminate white background
306
+ alignItems: 'center',
307
+ justifyContent: 'center',
308
+ marginRight: 4,
309
+ },
310
+ logoText: {
311
+ color: '#C7A047',
312
+ fontWeight: 'bold',
313
+ fontSize: 14,
314
+ },
315
+ logoImage: {
316
+ width: 20,
317
+ height: 20,
318
+ },
319
+ pillButton: {
320
+ borderRadius: 24,
321
+ },
322
+ strokedButton: {
323
+ backgroundColor: 'transparent',
324
+ borderWidth: 1,
325
+ },
326
+ swervButton: {
327
+ transform: [{ rotate: '-2deg' }],
328
+ },
329
+ disabledButton: {
330
+ opacity: 0.6,
331
+ },
332
+ buttonText: {
333
+ fontSize: 16,
334
+ fontWeight: '600',
335
+ textAlign: 'center',
336
+ },
337
+ });
338
+
339
+ export default OnairosButton;