@tap-payments/auth-jsconnect 2.7.11-test → 2.7.11

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 (566) hide show
  1. package/build/@types/app.d.ts +47 -4
  2. package/build/@types/app.js +22 -0
  3. package/build/@types/config.d.ts +4 -0
  4. package/build/@types/form.d.ts +11 -1
  5. package/build/@types/redux.d.ts +1 -0
  6. package/build/api/account.d.ts +4 -1
  7. package/build/api/account.js +15 -1
  8. package/build/api/auth.d.ts +35 -20
  9. package/build/api/auth.js +1 -1
  10. package/build/api/axios.js +1 -2
  11. package/build/api/data.d.ts +4 -17
  12. package/build/api/data.js +5 -45
  13. package/build/api/entity.d.ts +3 -2
  14. package/build/api/entity.js +12 -4
  15. package/build/api/firebase.js +68 -8
  16. package/build/api/index.d.ts +14 -25
  17. package/build/api/lead.d.ts +16 -3
  18. package/build/api/lead.js +16 -0
  19. package/build/api/user.d.ts +7 -0
  20. package/build/api/user.js +9 -1
  21. package/build/app/rootReducer.d.ts +1 -0
  22. package/build/app/rootReducer.js +3 -1
  23. package/build/app/settings.d.ts +1 -0
  24. package/build/app/settings.js +16 -11
  25. package/build/app/store.d.ts +2 -0
  26. package/build/assets/currencies/SARSymbol.d.ts +7 -0
  27. package/build/assets/currencies/SARSymbol.js +28 -0
  28. package/build/assets/currencies/index.d.ts +2 -0
  29. package/build/assets/currencies/index.js +2 -0
  30. package/build/assets/currencies/utils.d.ts +4 -0
  31. package/build/assets/currencies/utils.js +4 -0
  32. package/build/assets/locales/ar.json +358 -151
  33. package/build/assets/locales/en.json +354 -150
  34. package/build/components/AnimationFlow/AnimationFlow.d.ts +9 -5
  35. package/build/components/AnimationFlow/AnimationFlow.js +5 -5
  36. package/build/components/AnimationFlow/BottomSheet.d.ts +3 -1
  37. package/build/components/AnimationFlow/BottomSheet.js +42 -14
  38. package/build/components/AnimationFlow/Dialog.d.ts +4 -3
  39. package/build/components/AnimationFlow/Dialog.js +5 -3
  40. package/build/components/ArabicDatePicker/ArabicDatePicker.d.ts +1 -1
  41. package/build/components/ArabicDatePicker/ArabicDatePicker.js +2 -2
  42. package/build/components/ArabicDatePicker/style.css +32 -3
  43. package/build/components/DatePicker/DatePicker.d.ts +1 -1
  44. package/build/components/DatePicker/DatePicker.js +2 -2
  45. package/build/components/Footer/Footer.js +2 -1
  46. package/build/components/Input/Input.js +1 -1
  47. package/build/components/Providers/ThemeProvider.js +3 -3
  48. package/build/components/TextWithCurrency/TextWithCurrency.d.ts +7 -0
  49. package/build/components/TextWithCurrency/TextWithCurrency.js +14 -0
  50. package/build/components/TextWithCurrency/index.d.ts +2 -0
  51. package/build/components/TextWithCurrency/index.js +2 -0
  52. package/build/components/Tooltip/Tooltip.js +1 -1
  53. package/build/constants/api.d.ts +5 -7
  54. package/build/constants/api.js +11 -15
  55. package/build/constants/app.d.ts +41 -0
  56. package/build/constants/app.js +369 -36
  57. package/build/constants/assets.d.ts +7 -0
  58. package/build/constants/assets.js +11 -1
  59. package/build/constants/dummy.d.ts +4 -219
  60. package/build/constants/dummy.js +64 -6194
  61. package/build/constants/flows.d.ts +26 -0
  62. package/build/constants/flows.js +27 -0
  63. package/build/constants/index.d.ts +1 -0
  64. package/build/constants/index.js +1 -0
  65. package/build/constants/validation.d.ts +2 -0
  66. package/build/constants/validation.js +2 -0
  67. package/build/features/app/auth/authStore.d.ts +29 -8
  68. package/build/features/app/auth/authStore.js +495 -149
  69. package/build/features/app/bank/bankStore.d.ts +13 -18
  70. package/build/features/app/bank/bankStore.js +186 -153
  71. package/build/features/app/board/boardStore.d.ts +5 -1
  72. package/build/features/app/board/boardStore.js +82 -51
  73. package/build/features/app/brand/brandStore.d.ts +17 -33
  74. package/build/features/app/brand/brandStore.js +254 -257
  75. package/build/features/app/business/businessStore.d.ts +37 -15
  76. package/build/features/app/business/businessStore.js +443 -235
  77. package/build/features/app/connect/connectStore.d.ts +33 -5
  78. package/build/features/app/connect/connectStore.js +355 -120
  79. package/build/features/app/connectExpress/connectExpressStore.d.ts +64 -27
  80. package/build/features/app/connectExpress/connectExpressStore.js +826 -394
  81. package/build/features/app/entity/entityStore.d.ts +20 -36
  82. package/build/features/app/entity/entityStore.js +204 -238
  83. package/build/features/app/individual/individualStore.d.ts +18 -34
  84. package/build/features/app/individual/individualStore.js +269 -292
  85. package/build/features/app/kyc/kycStore.d.ts +67 -0
  86. package/build/features/app/kyc/kycStore.js +432 -0
  87. package/build/features/app/password/passwordStore.d.ts +33 -18
  88. package/build/features/app/password/passwordStore.js +260 -219
  89. package/build/features/app/signIn/signInStore.js +19 -15
  90. package/build/features/app/tax/taxStore.d.ts +13 -7
  91. package/build/features/app/tax/taxStore.js +170 -136
  92. package/build/features/auth/Auth.d.ts +5 -6
  93. package/build/features/auth/Auth.js +40 -15
  94. package/build/features/auth/screens/AccountNotFound/AccountNotFound.js +2 -5
  95. package/build/features/auth/screens/AuthSwitch/AuthSwitch.d.ts +5 -0
  96. package/build/features/auth/screens/AuthSwitch/AuthSwitch.js +58 -0
  97. package/build/features/auth/screens/AuthSwitch/index.d.ts +3 -0
  98. package/build/features/auth/screens/AuthSwitch/index.js +2 -0
  99. package/build/features/auth/screens/AuthenticationList/AuthenticationList.js +2 -8
  100. package/build/features/auth/screens/AuthenticationList/LicenseNumber.js +2 -2
  101. package/build/features/auth/screens/BusinessCountry/BusinessCountry.js +8 -2
  102. package/build/features/auth/screens/CivilID/CivilID.js +4 -35
  103. package/build/features/auth/screens/{NID → DOB}/DOB.js +3 -3
  104. package/build/features/auth/screens/DOB/DOBForm.d.ts +5 -0
  105. package/build/features/auth/screens/DOB/DOBForm.js +59 -0
  106. package/build/features/auth/screens/DOB/index.d.ts +3 -0
  107. package/build/features/auth/screens/DOB/index.js +2 -0
  108. package/build/features/{connectExpress/screens/IdentityOTP → auth/screens/DOB}/validation.d.ts +4 -4
  109. package/build/features/auth/screens/DOB/validation.js +4 -0
  110. package/build/features/auth/screens/Email/Email.d.ts +5 -0
  111. package/build/features/auth/screens/Email/Email.js +57 -0
  112. package/build/features/auth/screens/Email/EmailField.d.ts +8 -0
  113. package/build/features/auth/screens/Email/EmailField.js +52 -0
  114. package/build/features/auth/screens/Email/index.d.ts +3 -0
  115. package/build/features/auth/screens/Email/index.js +2 -0
  116. package/build/features/auth/screens/Email/validation.d.ts +8 -0
  117. package/build/features/auth/screens/Email/validation.js +4 -0
  118. package/build/features/auth/screens/EmailSent/EmailSent.d.ts +5 -0
  119. package/build/features/auth/screens/EmailSent/EmailSent.js +79 -0
  120. package/build/features/auth/screens/EmailSent/index.d.ts +2 -0
  121. package/build/features/auth/screens/EmailSent/index.js +2 -0
  122. package/build/features/auth/screens/MigratingData/MigratingData.d.ts +5 -0
  123. package/build/features/auth/screens/MigratingData/MigratingData.js +44 -0
  124. package/build/features/auth/screens/MigratingData/index.d.ts +2 -0
  125. package/build/features/auth/screens/MigratingData/index.js +2 -0
  126. package/build/features/auth/screens/Mobile/Mobile.js +6 -38
  127. package/build/features/auth/screens/Mobile/MobileNumber.js +13 -15
  128. package/build/features/auth/screens/Mobile/validation.js +11 -3
  129. package/build/features/auth/screens/NID/IDNumber.js +1 -1
  130. package/build/features/auth/screens/NID/NID.js +7 -43
  131. package/build/features/auth/screens/NID/validation.d.ts +0 -3
  132. package/build/features/auth/screens/NID/validation.js +0 -1
  133. package/build/features/auth/screens/OTP/OTP.js +41 -10
  134. package/build/features/auth/screens/OTP/OTPInput.js +23 -6
  135. package/build/features/auth/screens/OperatorError/OperatorError.d.ts +5 -0
  136. package/build/features/auth/screens/OperatorError/OperatorError.js +9 -0
  137. package/build/features/auth/screens/OperatorError/index.d.ts +3 -0
  138. package/build/features/auth/screens/OperatorError/index.js +2 -0
  139. package/build/features/auth/screens/Password/Password.d.ts +5 -0
  140. package/build/features/auth/screens/Password/Password.js +61 -0
  141. package/build/features/auth/screens/Password/PasswordField.d.ts +5 -0
  142. package/build/features/auth/screens/Password/PasswordField.js +28 -0
  143. package/build/features/auth/screens/Password/index.d.ts +3 -0
  144. package/build/features/auth/screens/Password/index.js +2 -0
  145. package/build/features/auth/screens/Password/validation.d.ts +8 -0
  146. package/build/features/auth/screens/Password/validation.js +4 -0
  147. package/build/features/auth/screens/PreparingData/PreparingData.js +3 -0
  148. package/build/features/auth/screens/ResetPasswordMessage/ResetPasswordMessage.d.ts +5 -0
  149. package/build/features/auth/screens/ResetPasswordMessage/ResetPasswordMessage.js +21 -0
  150. package/build/features/auth/screens/ResetPasswordMessage/index.d.ts +3 -0
  151. package/build/features/auth/screens/ResetPasswordMessage/index.js +2 -0
  152. package/build/features/auth/screens/VerifyNafath/VerifyNafath.d.ts +5 -0
  153. package/build/features/auth/screens/VerifyNafath/VerifyNafath.js +35 -0
  154. package/build/features/auth/screens/VerifyNafath/index.d.ts +3 -0
  155. package/build/features/auth/screens/VerifyNafath/index.js +2 -0
  156. package/build/features/bank/Bank.d.ts +5 -1
  157. package/build/features/bank/Bank.js +22 -9
  158. package/build/features/bank/screens/BankDetails/BankDetails.js +18 -5
  159. package/build/features/bank/screens/OperatorError/OperatorError.d.ts +5 -0
  160. package/build/features/bank/screens/OperatorError/OperatorError.js +9 -0
  161. package/build/features/bank/screens/OperatorError/index.d.ts +3 -0
  162. package/build/features/bank/screens/OperatorError/index.js +2 -0
  163. package/build/features/bank/screens/SuccessWithFlowButtons/SuccessWithFlowButtons.js +2 -2
  164. package/build/features/bank/screens/Verify/Verify.js +7 -6
  165. package/build/features/board/Board.d.ts +2 -0
  166. package/build/features/board/Board.js +24 -13
  167. package/build/features/board/screens/OperatorError/OperatorError.d.ts +5 -0
  168. package/build/features/board/screens/OperatorError/OperatorError.js +9 -0
  169. package/build/features/board/screens/OperatorError/index.d.ts +3 -0
  170. package/build/features/board/screens/OperatorError/index.js +2 -0
  171. package/build/features/board/screens/PrepareDataLoading/PrepareDataLoading.d.ts +4 -0
  172. package/build/features/board/screens/PrepareDataLoading/PrepareDataLoading.js +10 -0
  173. package/build/features/board/screens/PrepareDataLoading/index.d.ts +2 -0
  174. package/build/features/board/screens/PrepareDataLoading/index.js +2 -0
  175. package/build/features/board/screens/SuccessWithFlowButtons/SuccessWithFlowButtons.js +13 -4
  176. package/build/features/board/screens/Verify/Verify.js +3 -2
  177. package/build/features/brand/Brand.d.ts +5 -1
  178. package/build/features/brand/Brand.js +22 -9
  179. package/build/features/brand/screens/BrandActivities/ActivitiesList.d.ts +5 -5
  180. package/build/features/brand/screens/BrandActivities/BrandActivities.js +48 -11
  181. package/build/features/brand/screens/BrandActivities/CustomerBase.d.ts +6 -6
  182. package/build/features/brand/screens/BrandActivities/CustomerBase.js +1 -1
  183. package/build/features/brand/screens/BrandActivities/ExpectedSalesRange.js +3 -5
  184. package/build/features/brand/screens/BrandActivities/RefundPolicy.d.ts +4 -4
  185. package/build/features/brand/screens/BrandActivities/RefundPolicy.js +1 -1
  186. package/build/features/brand/screens/BrandActivities/TAC.d.ts +1 -1
  187. package/build/features/brand/screens/BrandActivities/TAC.js +1 -1
  188. package/build/features/brand/screens/BrandActivities/TransactionPolicy.js +1 -1
  189. package/build/features/brand/screens/BrandInfo/BrandInfo.js +22 -4
  190. package/build/features/brand/screens/BrandInfo/BrandName.js +2 -2
  191. package/build/features/brand/screens/BrandSegmentInfo/BrandSegmentInfo.js +22 -6
  192. package/build/features/brand/screens/OperatorError/OperatorError.d.ts +5 -0
  193. package/build/features/brand/screens/OperatorError/OperatorError.js +9 -0
  194. package/build/features/brand/screens/OperatorError/index.d.ts +3 -0
  195. package/build/features/brand/screens/OperatorError/index.js +2 -0
  196. package/build/features/brand/screens/SuccessWithFlowButtons/SuccessWithFlowButtons.js +2 -2
  197. package/build/features/brand/screens/Verify/Verify.js +3 -2
  198. package/build/features/business/Business.js +20 -12
  199. package/build/features/business/screens/Activities/Activities.js +26 -9
  200. package/build/features/business/screens/Activities/ActivitiesList.d.ts +4 -4
  201. package/build/features/business/screens/Activities/ActivitiesList.js +1 -1
  202. package/build/features/business/screens/Activities/OperationStartDate.d.ts +5 -3
  203. package/build/features/business/screens/Activities/OperationStartDate.js +2 -2
  204. package/build/features/business/screens/BrandDetails/SalesChannel.d.ts +2 -2
  205. package/build/features/business/screens/BusinessType/BusinessType.js +11 -3
  206. package/build/features/business/screens/BusinessType/LicenseNumber.js +3 -3
  207. package/build/features/business/screens/Customers/CustomerLocations.d.ts +10 -8
  208. package/build/features/business/screens/Customers/CustomerLocations.js +5 -3
  209. package/build/features/business/screens/Customers/Customers.js +50 -10
  210. package/build/features/business/screens/Customers/ExpectedCustomers.d.ts +3 -1
  211. package/build/features/business/screens/Customers/ExpectedCustomers.js +5 -3
  212. package/build/features/business/screens/Customers/ExpectedSalesRange.d.ts +3 -1
  213. package/build/features/business/screens/Customers/ExpectedSalesRange.js +7 -6
  214. package/build/features/business/screens/Customers/RefundPolicy.d.ts +12 -5
  215. package/build/features/business/screens/Customers/RefundPolicy.js +13 -13
  216. package/build/features/business/screens/Customers/TransactionPolicy.d.ts +4 -1
  217. package/build/features/business/screens/Customers/TransactionPolicy.js +8 -5
  218. package/build/features/business/screens/Customers/validation.d.ts +6 -6
  219. package/build/features/business/screens/Customers/validation.js +3 -8
  220. package/build/features/business/screens/DOB/DOB.d.ts +6 -0
  221. package/build/features/business/screens/DOB/DOB.js +45 -0
  222. package/build/features/business/screens/DOB/DOBForm.d.ts +5 -0
  223. package/build/features/business/screens/DOB/DOBForm.js +72 -0
  224. package/build/features/business/screens/DOB/index.d.ts +3 -0
  225. package/build/features/business/screens/DOB/index.js +2 -0
  226. package/build/features/business/screens/DOB/validation.d.ts +8 -0
  227. package/build/features/business/screens/DOB/validation.js +4 -0
  228. package/build/features/business/screens/IDBOD/IDBOD.js +10 -2
  229. package/build/features/business/screens/IDBOD/validation.d.ts +0 -3
  230. package/build/features/business/screens/IDBOD/validation.js +0 -1
  231. package/build/features/business/screens/MobileOwnership/CollectMobileOwnership.d.ts +3 -0
  232. package/build/features/business/screens/MobileOwnership/CollectMobileOwnership.js +103 -0
  233. package/build/features/{connectExpress/screens/IdentityOTP/OTP.d.ts → business/screens/MobileOwnership/MobileNumber.d.ts} +0 -2
  234. package/build/features/business/screens/MobileOwnership/MobileNumber.js +72 -0
  235. package/build/features/business/screens/MobileOwnership/index.d.ts +2 -0
  236. package/build/features/business/screens/MobileOwnership/index.js +2 -0
  237. package/build/features/business/screens/MobileOwnership/validation.d.ts +8 -0
  238. package/build/features/business/screens/MobileOwnership/validation.js +38 -0
  239. package/build/features/business/screens/OperatorError/OperatorError.d.ts +5 -0
  240. package/build/features/business/screens/OperatorError/OperatorError.js +9 -0
  241. package/build/features/business/screens/OperatorError/index.d.ts +3 -0
  242. package/build/features/business/screens/OperatorError/index.js +2 -0
  243. package/build/features/business/screens/SuccessWithFlowButtons/SuccessWithFlowButtons.js +14 -3
  244. package/build/features/business/screens/Verify/Verify.js +15 -4
  245. package/build/features/business/screens/VerifyNafath/VerifyNafath.d.ts +5 -0
  246. package/build/features/business/screens/VerifyNafath/VerifyNafath.js +35 -0
  247. package/build/features/business/screens/VerifyNafath/index.d.ts +3 -0
  248. package/build/features/business/screens/VerifyNafath/index.js +2 -0
  249. package/build/features/connect/Connect.d.ts +5 -1
  250. package/build/features/connect/Connect.js +16 -9
  251. package/build/features/connect/screens/BusinessCountry/BusinessCountry.js +7 -1
  252. package/build/features/connect/screens/CivilID/CivilID.js +6 -1
  253. package/build/features/{auth/screens/NID → connect/screens/DOB}/DOB.d.ts +1 -2
  254. package/build/features/connect/screens/{NID → DOB}/DOB.js +2 -2
  255. package/build/features/connect/screens/DOB/DOBForm.d.ts +5 -0
  256. package/build/features/connect/screens/DOB/DOBForm.js +59 -0
  257. package/build/features/connect/screens/DOB/index.d.ts +3 -0
  258. package/build/features/connect/screens/DOB/index.js +2 -0
  259. package/build/features/connect/screens/DOB/validation.d.ts +8 -0
  260. package/build/features/connect/screens/DOB/validation.js +4 -0
  261. package/build/features/connect/screens/Individual/Email.js +1 -3
  262. package/build/features/connect/screens/Individual/Individual.js +11 -5
  263. package/build/features/connect/screens/Individual/MobileNumber.js +8 -7
  264. package/build/features/connect/screens/Individual/validation.js +11 -3
  265. package/build/features/connect/screens/Merchant/BrandName.js +2 -2
  266. package/build/features/connect/screens/Mobile/Mobile.js +12 -9
  267. package/build/features/connect/screens/Mobile/MobileNumber.js +8 -7
  268. package/build/features/connect/screens/Mobile/validation.js +11 -3
  269. package/build/features/connect/screens/MobileOwnership/CollectMobileOwnership.d.ts +3 -0
  270. package/build/features/connect/screens/MobileOwnership/CollectMobileOwnership.js +104 -0
  271. package/build/features/connect/screens/MobileOwnership/MobileNumber.d.ts +3 -0
  272. package/build/features/connect/screens/MobileOwnership/MobileNumber.js +72 -0
  273. package/build/features/connect/screens/MobileOwnership/index.d.ts +2 -0
  274. package/build/features/connect/screens/MobileOwnership/index.js +2 -0
  275. package/build/features/connect/screens/MobileOwnership/validation.d.ts +8 -0
  276. package/build/features/connect/screens/MobileOwnership/validation.js +38 -0
  277. package/build/features/connect/screens/NID/IDNumber.d.ts +1 -0
  278. package/build/features/connect/screens/NID/IDNumber.js +2 -2
  279. package/build/features/connect/screens/NID/NID.js +5 -11
  280. package/build/features/connect/screens/NID/validation.d.ts +0 -3
  281. package/build/features/connect/screens/NID/validation.js +0 -1
  282. package/build/features/connect/screens/OTP/OTP.js +6 -6
  283. package/build/features/connect/screens/OTP/OTPInput.js +3 -11
  284. package/build/features/connect/screens/OperatorError/OperatorError.js +1 -1
  285. package/build/features/connect/screens/VerifyNafath/VerifyNafath.d.ts +5 -0
  286. package/build/features/connect/screens/VerifyNafath/VerifyNafath.js +35 -0
  287. package/build/features/connect/screens/VerifyNafath/index.d.ts +3 -0
  288. package/build/features/connect/screens/VerifyNafath/index.js +2 -0
  289. package/build/features/connectExpress/ConnectExpress.d.ts +5 -2
  290. package/build/features/connectExpress/ConnectExpress.js +62 -39
  291. package/build/features/connectExpress/screens/AuthenticationList/LicenseNumber.js +2 -2
  292. package/build/features/connectExpress/screens/BusinessCountry/BusinessCountry.js +7 -1
  293. package/build/features/connectExpress/screens/CivilID/CivilID.js +6 -1
  294. package/build/features/connectExpress/screens/CollectBusinessInfo/BrandName.js +2 -2
  295. package/build/features/connectExpress/screens/CollectBusinessInfo/CollectBusinessInfo.js +8 -1
  296. package/build/features/connectExpress/screens/CollectBusinessInfo/LicenseNumber.js +2 -2
  297. package/build/features/connectExpress/screens/CollectBusinessInfo/TAC.d.ts +1 -1
  298. package/build/features/connectExpress/screens/CollectIndividualInfo/CollectIndividualInfo.js +30 -7
  299. package/build/features/connectExpress/screens/CollectIndividualInfo/Email.js +1 -3
  300. package/build/features/connectExpress/screens/CollectIndividualInfo/MobileNumber.js +9 -8
  301. package/build/features/connectExpress/screens/CollectIndividualInfo/validation.js +11 -3
  302. package/build/features/connectExpress/screens/CreateAccountLoader/CreateAccountLoader.js +14 -24
  303. package/build/features/connectExpress/screens/{NID → DOB}/DOB.d.ts +1 -2
  304. package/build/features/connectExpress/screens/{NID → DOB}/DOB.js +3 -3
  305. package/build/features/connectExpress/screens/DOB/DOBForm.d.ts +5 -0
  306. package/build/features/connectExpress/screens/DOB/DOBForm.js +63 -0
  307. package/build/features/connectExpress/screens/DOB/index.d.ts +3 -0
  308. package/build/features/connectExpress/screens/DOB/index.js +2 -0
  309. package/build/features/connectExpress/screens/DOB/validation.d.ts +8 -0
  310. package/build/features/connectExpress/screens/DOB/validation.js +4 -0
  311. package/build/features/connectExpress/screens/GenericPrepareDataLoading/GenericPrepareDataLoading.d.ts +3 -0
  312. package/build/features/connectExpress/screens/GenericPrepareDataLoading/GenericPrepareDataLoading.js +9 -0
  313. package/build/features/connectExpress/screens/GenericPrepareDataLoading/index.d.ts +2 -0
  314. package/build/features/connectExpress/screens/GenericPrepareDataLoading/index.js +2 -0
  315. package/build/features/connectExpress/screens/IdentityVerifyNafath/IdentityVerifyNafath.d.ts +5 -0
  316. package/build/features/connectExpress/screens/IdentityVerifyNafath/IdentityVerifyNafath.js +35 -0
  317. package/build/features/connectExpress/screens/IdentityVerifyNafath/index.d.ts +3 -0
  318. package/build/features/connectExpress/screens/IdentityVerifyNafath/index.js +2 -0
  319. package/build/features/connectExpress/screens/Mobile/Mobile.js +10 -3
  320. package/build/features/connectExpress/screens/Mobile/MobileNumber.js +9 -8
  321. package/build/features/connectExpress/screens/Mobile/validation.js +21 -6
  322. package/build/features/connectExpress/screens/MobileOwnership/CollectMobileOwnership.d.ts +3 -0
  323. package/build/features/connectExpress/screens/MobileOwnership/CollectMobileOwnership.js +106 -0
  324. package/build/features/connectExpress/screens/MobileOwnership/MobileNumber.d.ts +3 -0
  325. package/build/features/connectExpress/screens/MobileOwnership/MobileNumber.js +72 -0
  326. package/build/features/connectExpress/screens/MobileOwnership/index.d.ts +2 -0
  327. package/build/features/connectExpress/screens/MobileOwnership/index.js +2 -0
  328. package/build/features/connectExpress/screens/MobileOwnership/validation.d.ts +8 -0
  329. package/build/features/connectExpress/screens/MobileOwnership/validation.js +38 -0
  330. package/build/features/connectExpress/screens/NID/IDNumber.d.ts +1 -0
  331. package/build/features/connectExpress/screens/NID/IDNumber.js +2 -2
  332. package/build/features/connectExpress/screens/NID/NID.js +10 -10
  333. package/build/features/connectExpress/screens/NID/TAC.d.ts +1 -1
  334. package/build/features/connectExpress/screens/NID/TAC.js +2 -2
  335. package/build/features/connectExpress/screens/NID/validation.d.ts +0 -3
  336. package/build/features/connectExpress/screens/NID/validation.js +0 -2
  337. package/build/features/connectExpress/screens/NIDMissed/NID.js +3 -3
  338. package/build/features/connectExpress/screens/NIDMissed/validation.d.ts +0 -3
  339. package/build/features/connectExpress/screens/NIDMissed/validation.js +0 -1
  340. package/build/features/connectExpress/screens/OTP/OTP.js +13 -15
  341. package/build/features/connectExpress/screens/OTP/OTPInput.js +12 -10
  342. package/build/features/connectExpress/screens/OperatorError/OperatorError.d.ts +5 -0
  343. package/build/features/connectExpress/screens/OperatorError/OperatorError.js +9 -0
  344. package/build/features/connectExpress/screens/OperatorError/index.d.ts +3 -0
  345. package/build/features/connectExpress/screens/OperatorError/index.js +2 -0
  346. package/build/features/connectExpress/screens/PrepareDataLoading/PrepareDataLoading.d.ts +5 -0
  347. package/build/features/connectExpress/screens/PrepareDataLoading/PrepareDataLoading.js +34 -0
  348. package/build/features/connectExpress/screens/PrepareDataLoading/index.d.ts +2 -0
  349. package/build/features/connectExpress/screens/PrepareDataLoading/index.js +2 -0
  350. package/build/features/connectExpress/screens/SuccessWithFlowButtons/SuccessWithFlowButtons.js +3 -3
  351. package/build/features/{business/screens/OTP → connectExpress/screens/VerifyMobileAuthOTP}/OTPInput.js +3 -3
  352. package/build/features/connectExpress/screens/VerifyMobileAuthOTP/VerifyMobileAuthOTP.d.ts +5 -0
  353. package/build/features/connectExpress/screens/{IdentityOTP/OTP.js → VerifyMobileAuthOTP/VerifyMobileAuthOTP.js} +22 -21
  354. package/build/features/connectExpress/screens/VerifyMobileAuthOTP/index.d.ts +3 -0
  355. package/build/features/connectExpress/screens/VerifyMobileAuthOTP/index.js +2 -0
  356. package/build/features/connectExpress/screens/VerifyNafath/VerifyNafath.d.ts +5 -0
  357. package/build/features/connectExpress/screens/VerifyNafath/VerifyNafath.js +41 -0
  358. package/build/features/connectExpress/screens/VerifyNafath/index.d.ts +3 -0
  359. package/build/features/connectExpress/screens/VerifyNafath/index.js +2 -0
  360. package/build/features/entity/Entity.d.ts +4 -1
  361. package/build/features/entity/Entity.js +22 -9
  362. package/build/features/entity/screens/EntityCapital/ActivityList.d.ts +4 -4
  363. package/build/features/entity/screens/EntityCapital/CapitalPaid.js +5 -5
  364. package/build/features/entity/screens/EntityCapital/CapitalShareValue.js +5 -5
  365. package/build/features/entity/screens/EntityCapital/EntityCapital.js +33 -9
  366. package/build/features/entity/screens/EntityName/EntityName.js +31 -14
  367. package/build/features/entity/screens/EntityName/EntityTypeList.d.ts +5 -5
  368. package/build/features/entity/screens/EntityName/EntityTypeList.js +2 -3
  369. package/build/features/entity/screens/EntityName/ExpiryDate.d.ts +2 -2
  370. package/build/features/entity/screens/EntityName/ExpiryDate.js +13 -8
  371. package/build/features/entity/screens/EntityName/IssuingDate.d.ts +2 -2
  372. package/build/features/entity/screens/EntityName/IssuingDate.js +15 -8
  373. package/build/features/entity/screens/EntityName/LegalName.js +1 -13
  374. package/build/features/entity/screens/EntityName/LicenseNumber.js +6 -8
  375. package/build/features/entity/screens/EntityName/UnifiedNumber.js +4 -6
  376. package/build/features/entity/screens/EntityName/validation.d.ts +3 -3
  377. package/build/features/entity/screens/EntityName/validation.js +1 -10
  378. package/build/features/entity/screens/OperatorError/OperatorError.d.ts +5 -0
  379. package/build/features/entity/screens/OperatorError/OperatorError.js +9 -0
  380. package/build/features/entity/screens/OperatorError/index.d.ts +3 -0
  381. package/build/features/entity/screens/OperatorError/index.js +2 -0
  382. package/build/features/entity/screens/SuccessWithFlowButtons/SuccessWithFlowButtons.js +2 -2
  383. package/build/features/entity/screens/Verify/Verify.js +3 -2
  384. package/build/features/featuresScreens.d.ts +1 -0
  385. package/build/features/featuresScreens.js +216 -13
  386. package/build/features/individual/Individual.d.ts +4 -1
  387. package/build/features/individual/Individual.js +22 -9
  388. package/build/features/individual/screens/AdditionalIndividualInfo/AdditionalIndividualInfo.d.ts +2 -2
  389. package/build/features/individual/screens/AdditionalIndividualInfo/AdditionalIndividualInfo.js +44 -11
  390. package/build/features/individual/screens/AdditionalIndividualInfo/MonthlyIncome.js +2 -4
  391. package/build/features/individual/screens/AdditionalIndividualInfo/ShareValue.js +4 -4
  392. package/build/features/individual/screens/IndividualList/Email.js +2 -3
  393. package/build/features/individual/screens/IndividualList/IndividualList.d.ts +4 -4
  394. package/build/features/individual/screens/IndividualList/IndividualList.js +18 -5
  395. package/build/features/individual/screens/IndividualList/MobileNumber.js +8 -10
  396. package/build/features/individual/screens/IndividualList/UserList.js +7 -7
  397. package/build/features/individual/screens/IndividualList/validation.js +11 -4
  398. package/build/features/individual/screens/IndividualPersonalInfo/Email.js +2 -4
  399. package/build/features/individual/screens/IndividualPersonalInfo/IndividualPersonalInfo.d.ts +2 -2
  400. package/build/features/individual/screens/IndividualPersonalInfo/IndividualPersonalInfo.js +73 -18
  401. package/build/features/individual/screens/IndividualPersonalInfo/MobileNumber.js +6 -5
  402. package/build/features/individual/screens/IndividualPersonalInfo/validation.js +11 -3
  403. package/build/features/individual/screens/IndividualPhoneInfo/MobileNumber.js +9 -11
  404. package/build/features/individual/screens/IndividualPhoneInfo/validation.js +11 -3
  405. package/build/features/individual/screens/OperatorError/OperatorError.d.ts +5 -0
  406. package/build/features/individual/screens/OperatorError/OperatorError.js +9 -0
  407. package/build/features/individual/screens/OperatorError/index.d.ts +3 -0
  408. package/build/features/individual/screens/OperatorError/index.js +2 -0
  409. package/build/features/individual/screens/SuccessWithFlowButtons/SuccessWithFlowButtons.js +2 -2
  410. package/build/features/individual/screens/Verify/Verify.js +3 -2
  411. package/build/features/kyc/KYC.d.ts +11 -0
  412. package/build/features/kyc/KYC.js +99 -0
  413. package/build/features/kyc/index.d.ts +1 -0
  414. package/build/features/kyc/index.js +1 -0
  415. package/build/features/kyc/screens/AlreadySubmitted/AlreadySubmitted.d.ts +5 -0
  416. package/build/features/kyc/screens/AlreadySubmitted/AlreadySubmitted.js +19 -0
  417. package/build/features/kyc/screens/AlreadySubmitted/index.d.ts +2 -0
  418. package/build/features/kyc/screens/AlreadySubmitted/index.js +2 -0
  419. package/build/features/kyc/screens/Loading/Loading.d.ts +4 -0
  420. package/build/features/kyc/screens/Loading/Loading.js +10 -0
  421. package/build/features/kyc/screens/Loading/index.d.ts +2 -0
  422. package/build/features/kyc/screens/Loading/index.js +2 -0
  423. package/build/features/kyc/screens/OperatorError/OperatorError.d.ts +5 -0
  424. package/build/features/kyc/screens/OperatorError/OperatorError.js +9 -0
  425. package/build/features/kyc/screens/OperatorError/index.d.ts +2 -0
  426. package/build/features/kyc/screens/OperatorError/index.js +2 -0
  427. package/build/features/kyc/screens/Success/Success.d.ts +5 -0
  428. package/build/features/kyc/screens/Success/Success.js +32 -0
  429. package/build/features/kyc/screens/Success/index.d.ts +2 -0
  430. package/build/features/kyc/screens/Success/index.js +2 -0
  431. package/build/features/kyc/screens/Terms/Header.d.ts +6 -0
  432. package/build/features/kyc/screens/Terms/Header.js +36 -0
  433. package/build/features/kyc/screens/Terms/Terms.d.ts +4 -0
  434. package/build/features/kyc/screens/Terms/Terms.js +87 -0
  435. package/build/features/kyc/screens/Terms/index.d.ts +2 -0
  436. package/build/features/kyc/screens/Terms/index.js +2 -0
  437. package/build/features/kyc/screens/TokenError/TokenError.d.ts +5 -0
  438. package/build/features/kyc/screens/TokenError/TokenError.js +9 -0
  439. package/build/features/kyc/screens/TokenError/index.d.ts +2 -0
  440. package/build/features/kyc/screens/TokenError/index.js +2 -0
  441. package/build/features/kyc/screens/Users/Users.d.ts +3 -0
  442. package/build/features/kyc/screens/Users/Users.js +76 -0
  443. package/build/features/kyc/screens/Users/index.d.ts +2 -0
  444. package/build/features/kyc/screens/Users/index.js +2 -0
  445. package/build/features/kyc/screens/VerifyNafath/VerifyNafath.d.ts +5 -0
  446. package/build/features/kyc/screens/VerifyNafath/VerifyNafath.js +45 -0
  447. package/build/features/kyc/screens/VerifyNafath/index.d.ts +3 -0
  448. package/build/features/kyc/screens/VerifyNafath/index.js +2 -0
  449. package/build/features/kyc/screens/VerifyPaci/VerifyPACI.d.ts +5 -0
  450. package/build/features/kyc/screens/VerifyPaci/VerifyPACI.js +44 -0
  451. package/build/features/kyc/screens/VerifyPaci/index.d.ts +3 -0
  452. package/build/features/kyc/screens/VerifyPaci/index.js +2 -0
  453. package/build/features/password/Password.d.ts +4 -1
  454. package/build/features/password/Password.js +88 -31
  455. package/build/features/password/screens/CreatePassword/CreatePassword.js +8 -4
  456. package/build/features/password/screens/OTP/OTP.js +3 -3
  457. package/build/features/password/screens/OperatorError/OperatorError.d.ts +5 -0
  458. package/build/features/password/screens/OperatorError/OperatorError.js +9 -0
  459. package/build/features/password/screens/OperatorError/index.d.ts +3 -0
  460. package/build/features/password/screens/OperatorError/index.js +2 -0
  461. package/build/features/password/screens/PrepareDataLoading/PrepareDataLoading.d.ts +4 -0
  462. package/build/features/password/screens/PrepareDataLoading/PrepareDataLoading.js +10 -0
  463. package/build/features/password/screens/PrepareDataLoading/index.d.ts +2 -0
  464. package/build/features/password/screens/PrepareDataLoading/index.js +2 -0
  465. package/build/features/password/screens/SuccessWithFlowButtons/SuccessWithFlowButtons.js +2 -2
  466. package/build/features/password/screens/Verify/Verify.js +7 -6
  467. package/build/features/shared/Address/CountryList.d.ts +5 -5
  468. package/build/features/shared/Address/InputSelect.d.ts +5 -5
  469. package/build/features/shared/Background/Background.js +1 -1
  470. package/build/features/shared/Background/LogoBackground.js +5 -17
  471. package/build/features/shared/BusinessCountry/BusinessCountry.js +1 -1
  472. package/build/features/shared/Button/Button.js +3 -1
  473. package/build/features/shared/Button/EmailProvidersButtons.js +2 -0
  474. package/build/features/shared/Button/FlowsButtons.js +18 -4
  475. package/build/features/shared/Button/NafathButton.d.ts +8 -0
  476. package/build/features/shared/Button/{AbsherButton.js → NafathButton.js} +12 -3
  477. package/build/features/shared/Button/index.d.ts +2 -2
  478. package/build/features/shared/Button/index.js +2 -2
  479. package/build/features/shared/Calender/Calender.d.ts +2 -1
  480. package/build/features/shared/Calender/Calender.js +3 -3
  481. package/build/features/shared/Containers/FeatureContainer.d.ts +2 -1
  482. package/build/features/shared/Containers/FeatureContainer.js +5 -3
  483. package/build/features/shared/Containers/ScreenContainer.d.ts +1 -1
  484. package/build/features/shared/Dialog/DialogContainer.js +5 -4
  485. package/build/features/shared/Input/Input.d.ts +3 -3
  486. package/build/features/shared/NafathVerification/NafathVerification.d.ts +14 -0
  487. package/build/features/shared/NafathVerification/NafathVerification.js +92 -0
  488. package/build/features/shared/NafathVerification/VerifyNafathLoading.d.ts +8 -0
  489. package/build/features/shared/NafathVerification/VerifyNafathLoading.js +53 -0
  490. package/build/features/shared/NafathVerification/VerifyNafathSuccess.d.ts +5 -0
  491. package/build/features/shared/NafathVerification/VerifyNafathSuccess.js +8 -0
  492. package/build/features/shared/NafathVerification/index.d.ts +2 -0
  493. package/build/features/shared/NafathVerification/index.js +2 -0
  494. package/build/features/shared/SuccessFlowButtons/SuccessFlowButtons.d.ts +6 -1
  495. package/build/features/shared/SuccessFlowButtons/SuccessFlowButtons.js +10 -13
  496. package/build/features/shared/SuccessScreen/SuccessScreen.js +1 -1
  497. package/build/features/shared/UploadFile/FileUpload.d.ts +1 -1
  498. package/build/features/shared/UploadFile/UploadFile.d.ts +1 -1
  499. package/build/features/shared/UploadFile/UploadWrapper.d.ts +1 -1
  500. package/build/features/shared/UploadMultipleFile/UploadFile.d.ts +1 -1
  501. package/build/features/shared/UploadMultipleFile/UploadMultipleFile.d.ts +1 -1
  502. package/build/features/signIn/SignIn.js +18 -7
  503. package/build/features/signIn/screens/Mobile/MobileNumber.js +8 -7
  504. package/build/features/signIn/screens/Mobile/validation.js +11 -3
  505. package/build/features/signIn/screens/OTP/OTP.js +5 -4
  506. package/build/features/signIn/screens/OperatorError/OperatorError.d.ts +5 -0
  507. package/build/features/signIn/screens/OperatorError/OperatorError.js +9 -0
  508. package/build/features/signIn/screens/OperatorError/index.d.ts +3 -0
  509. package/build/features/signIn/screens/OperatorError/index.js +2 -0
  510. package/build/features/tax/Tax.d.ts +4 -1
  511. package/build/features/tax/Tax.js +22 -9
  512. package/build/features/tax/screens/OperatorError/OperatorError.d.ts +5 -0
  513. package/build/features/tax/screens/OperatorError/OperatorError.js +9 -0
  514. package/build/features/tax/screens/OperatorError/index.d.ts +3 -0
  515. package/build/features/tax/screens/OperatorError/index.js +2 -0
  516. package/build/features/tax/screens/SuccessWithFlowButtons/SuccessWithFlowButtons.js +2 -2
  517. package/build/features/tax/screens/TaxDetails/TaxDetails.js +7 -2
  518. package/build/features/tax/screens/Verify/Verify.js +7 -6
  519. package/build/hooks/index.d.ts +3 -0
  520. package/build/hooks/index.js +3 -0
  521. package/build/hooks/useAppConfig.d.ts +1 -1
  522. package/build/hooks/useAppConfig.js +2 -2
  523. package/build/hooks/useAppDispatch.d.ts +1 -0
  524. package/build/hooks/useAppTheme.js +4 -3
  525. package/build/hooks/useCountDown.d.ts +10 -0
  526. package/build/hooks/useCountDown.js +17 -0
  527. package/build/hooks/useFormDirtyCheck.d.ts +10 -0
  528. package/build/hooks/useFormDirtyCheck.js +66 -0
  529. package/build/hooks/useSanitizedTranslation.d.ts +2 -0
  530. package/build/hooks/useSanitizedTranslation.js +15 -0
  531. package/build/hooks/useVerifyToken.d.ts +4 -2
  532. package/build/hooks/useVerifyToken.js +9 -4
  533. package/build/index.css +360 -120
  534. package/build/index.d.ts +3 -2
  535. package/build/index.js +4 -2
  536. package/build/theme/components.js +7 -0
  537. package/build/theme/palette.js +2 -1
  538. package/build/theme/shadows.js +1 -1
  539. package/build/theme/theme.d.ts +1 -1
  540. package/build/theme/theme.js +2 -2
  541. package/build/utils/array.js +2 -2
  542. package/build/utils/common.d.ts +1 -0
  543. package/build/utils/common.js +16 -3
  544. package/build/utils/error.d.ts +1 -0
  545. package/build/utils/error.js +3 -0
  546. package/build/utils/object.d.ts +1 -0
  547. package/build/utils/object.js +3 -0
  548. package/build/utils/string.d.ts +6 -2
  549. package/build/utils/string.js +28 -3
  550. package/build/utils/validation.d.ts +2 -0
  551. package/build/utils/validation.js +6 -0
  552. package/package.json +3 -4
  553. package/build/features/business/screens/OTP/OTP.d.ts +0 -8
  554. package/build/features/business/screens/OTP/OTP.js +0 -90
  555. package/build/features/business/screens/OTP/index.d.ts +0 -3
  556. package/build/features/business/screens/OTP/index.js +0 -2
  557. package/build/features/connectExpress/screens/IdentityOTP/OTPInput.d.ts +0 -5
  558. package/build/features/connectExpress/screens/IdentityOTP/OTPInput.js +0 -54
  559. package/build/features/connectExpress/screens/IdentityOTP/index.d.ts +0 -3
  560. package/build/features/connectExpress/screens/IdentityOTP/index.js +0 -2
  561. package/build/features/connectExpress/screens/IdentityOTP/validation.js +0 -4
  562. package/build/features/shared/Button/AbsherButton.d.ts +0 -8
  563. /package/build/features/{connect/screens/NID → auth/screens/DOB}/DOB.d.ts +0 -0
  564. /package/build/features/{business/screens/OTP → connectExpress/screens/VerifyMobileAuthOTP}/OTPInput.d.ts +0 -0
  565. /package/build/features/{business/screens/OTP → connectExpress/screens/VerifyMobileAuthOTP}/validation.d.ts +0 -0
  566. /package/build/features/{business/screens/OTP → connectExpress/screens/VerifyMobileAuthOTP}/validation.js +0 -0
@@ -17,8 +17,8 @@ import { useTranslation } from 'react-i18next';
17
17
  import { handleCurrentActiveScreen, handlePrevScreenStep, settingsSelector } from '../../../../app/settings';
18
18
  import Box from '@mui/material/Box';
19
19
  import { alpha, styled } from '@mui/material/styles';
20
- import { useAppDispatch, useAppSelector, useSetFromDefaultValues, useLanguage, useFormReadOnly, useDataNoneEditable, useFormErrorAndUpdateReadOnly, useExcludeReadOnlyFelids, useDataVerified } from '../../../../hooks';
21
- import { convertToEnglishDateFormat, deepCopy, getUserName, isKWOrSA, isOtherThanKWOrSA } from '../../../../utils';
20
+ import { useAppDispatch, useAppSelector, useSetFromDefaultValues, useLanguage, useFormReadOnly, useDataNoneEditable, useFormErrorAndUpdateReadOnly, useExcludeReadOnlyFelids, useDataVerified, useFormDirtyCheck } from '../../../../hooks';
21
+ import { convertToEnglishDateFormat, deepCopy, findCountryByIddPrefix, findCountryByIso2, getUserName, isKWOrSA, isOtherThanKWOrSA, sendCustomEventToGTM } from '../../../../utils';
22
22
  import Form from '../../../../components/Form';
23
23
  import Collapse from '../../../../components/Collapse';
24
24
  import Text from '../../../../components/Text';
@@ -50,17 +50,17 @@ var ListType;
50
50
  ListType["NationalityList"] = "NationalityList";
51
51
  })(ListType || (ListType = {}));
52
52
  var IndividualPersonalInfo = function (_a) {
53
- var _b, _c, _d, _e, _f, _g, _h, _j, _k;
53
+ var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
54
54
  var t = useTranslation().t;
55
55
  var isAr = useLanguage().isAr;
56
56
  var dispatch = useAppDispatch();
57
- var _l = useAppSelector(individualSelector), data = _l.data, loading = _l.loading, error = _l.error, cityLoading = _l.cityLoading;
57
+ var _p = useAppSelector(individualSelector), data = _p.data, loading = _p.loading, error = _p.error, cityLoading = _p.cityLoading;
58
58
  var settingsData = useAppSelector(settingsSelector).data;
59
59
  var countries = settingsData.countries;
60
60
  var verify = data.verify, individualPersonalData = data.individualPersonalData;
61
- var _m = verify.responseBody || {}, user = _m.user, flows = _m.flows;
61
+ var _q = verify.responseBody || {}, user = _q.user, flows = _q.flows;
62
62
  var name = individualPersonalData.name, email = individualPersonalData.email, mobile = individualPersonalData.mobile, countryCode = individualPersonalData.countryCode, gender = individualPersonalData.gender, nid = individualPersonalData.nid, issuedCountry = individualPersonalData.issuedCountry, expiryDate = individualPersonalData.expiryDate, dob = individualPersonalData.dob, placeOfBirthCountry = individualPersonalData.placeOfBirthCountry, placeOfBirthCity = individualPersonalData.placeOfBirthCity, nationality = individualPersonalData.nationality;
63
- var _o = user || {}, data_status = _o.data_status, is_authorized = _o.is_authorized, data_verification = _o.data_verification, contact = _o.contact, genderRes = _o.gender, identification = _o.identification, birth = _o.birth, nationalityRes = _o.nationality;
63
+ var _r = user || {}, data_status = _r.data_status, is_authorized = _r.is_authorized, data_verification = _r.data_verification, contact = _r.contact, genderRes = _r.gender, identification = _r.identification, birth = _r.birth, nationalityRes = _r.nationality;
64
64
  var isOtherCountry = React.useMemo(function () { return isOtherThanKWOrSA(settingsData.businessCountry.iso2); }, [settingsData.businessCountry.iso2]);
65
65
  var methods = useForm({
66
66
  resolver: yupResolver(IndividualInfoValidationSchema(isOtherCountry)),
@@ -82,9 +82,51 @@ var IndividualPersonalInfo = function (_a) {
82
82
  });
83
83
  var watch = methods.watch;
84
84
  useSetFromDefaultValues(methods, data.individualPersonalData);
85
- var _p = React.useState(), listActive = _p[0], setListActive = _p[1];
86
- var _q = React.useState(false), dobActive = _q[0], setDobActive = _q[1];
87
- var _r = React.useState(false), expiryDateActive = _r[0], setExpiryDateActive = _r[1];
85
+ var _s = React.useState(), listActive = _s[0], setListActive = _s[1];
86
+ var _t = React.useState(false), dobActive = _t[0], setDobActive = _t[1];
87
+ var _u = React.useState(false), expiryDateActive = _u[0], setExpiryDateActive = _u[1];
88
+ var expDateRes = (identification === null || identification === void 0 ? void 0 : identification.expiry) && convertToEnglishDateFormat(new Date(identification === null || identification === void 0 ? void 0 : identification.expiry));
89
+ var dobDateRes = (birth === null || birth === void 0 ? void 0 : birth.date) && convertToEnglishDateFormat(new Date(birth === null || birth === void 0 ? void 0 : birth.date));
90
+ var resCountryCode = React.useMemo(function () {
91
+ var _a;
92
+ if (!((_a = contact === null || contact === void 0 ? void 0 : contact.phone) === null || _a === void 0 ? void 0 : _a.country_code))
93
+ return {};
94
+ return findCountryByIddPrefix(countries, contact.phone.country_code) || {};
95
+ }, [(_b = contact === null || contact === void 0 ? void 0 : contact.phone) === null || _b === void 0 ? void 0 : _b.country_code]);
96
+ var resIssuedCountry = React.useMemo(function () {
97
+ if (!(identification === null || identification === void 0 ? void 0 : identification.issued_country_code))
98
+ return;
99
+ return findCountryByIso2(countries, identification.issued_country_code);
100
+ }, [identification === null || identification === void 0 ? void 0 : identification.issued_country_code]);
101
+ var resPlaceOfBirthCountry = React.useMemo(function () {
102
+ if (!(birth === null || birth === void 0 ? void 0 : birth.country))
103
+ return;
104
+ return findCountryByIso2(countries, birth.country);
105
+ }, [birth === null || birth === void 0 ? void 0 : birth.country]);
106
+ var resNationality = React.useMemo(function () {
107
+ if (!nationalityRes)
108
+ return;
109
+ return findCountryByIso2(countries, nationalityRes);
110
+ }, [nationalityRes]);
111
+ var isDirty = useFormDirtyCheck(methods, {
112
+ name: getUserName(user, false),
113
+ email: contact === null || contact === void 0 ? void 0 : contact.email,
114
+ mobile: (_c = contact === null || contact === void 0 ? void 0 : contact.phone) === null || _c === void 0 ? void 0 : _c.number,
115
+ countryCode: resCountryCode,
116
+ gender: genderRes === null || genderRes === void 0 ? void 0 : genderRes.toLowerCase(),
117
+ nid: identification === null || identification === void 0 ? void 0 : identification.id,
118
+ issuedCountry: resIssuedCountry,
119
+ expiryDate: expDateRes,
120
+ dob: dobDateRes,
121
+ placeOfBirthCountry: resPlaceOfBirthCountry,
122
+ placeOfBirthCity: ((_d = birth === null || birth === void 0 ? void 0 : birth.city) === null || _d === void 0 ? void 0 : _d.cityId) && { id: birth.city.cityId },
123
+ nationality: resNationality
124
+ }, [
125
+ {
126
+ name: 'placeOfBirthCity',
127
+ keys: ['id']
128
+ }
129
+ ]).isDirty;
88
130
  var originalReadOnly = useFormReadOnly(methods);
89
131
  var noneEditable = useDataNoneEditable(data_status, [
90
132
  'name.en',
@@ -120,30 +162,37 @@ var IndividualPersonalInfo = function (_a) {
120
162
  'nationality',
121
163
  'gender'
122
164
  ]);
123
- var expDateRes = (identification === null || identification === void 0 ? void 0 : identification.expiry) && convertToEnglishDateFormat(new Date(identification === null || identification === void 0 ? void 0 : identification.expiry));
124
- var dobDateRes = (birth === null || birth === void 0 ? void 0 : birth.date) && convertToEnglishDateFormat(new Date(birth === null || birth === void 0 ? void 0 : birth.date));
125
165
  var isNameVerified = dataVerified['name.en'] && dataVerified['name.ar'] && getUserName(user, isAr) === watch('name');
126
166
  var isPhoneNumberVerified = dataVerified['contact.phone.number'] &&
127
167
  dataVerified['contact.phone.country_code'] &&
128
- ((_b = contact === null || contact === void 0 ? void 0 : contact.phone) === null || _b === void 0 ? void 0 : _b.number) === watch('mobile') &&
129
- ((_c = contact === null || contact === void 0 ? void 0 : contact.phone) === null || _c === void 0 ? void 0 : _c.country_code) === ((_e = (_d = watch('countryCode')) === null || _d === void 0 ? void 0 : _d.idd_prefix) === null || _e === void 0 ? void 0 : _e.toString());
168
+ ((_e = contact === null || contact === void 0 ? void 0 : contact.phone) === null || _e === void 0 ? void 0 : _e.number) === watch('mobile') &&
169
+ ((_f = contact === null || contact === void 0 ? void 0 : contact.phone) === null || _f === void 0 ? void 0 : _f.country_code) === ((_h = (_g = watch('countryCode')) === null || _g === void 0 ? void 0 : _g.idd_prefix) === null || _h === void 0 ? void 0 : _h.toString());
130
170
  var isEmailVerified = dataVerified['contact.email'] && (contact === null || contact === void 0 ? void 0 : contact.email) === watch('email');
131
171
  var isGenderVerified = dataVerified['gender'] && genderRes === watch('gender');
132
172
  var isIDVerified = dataVerified['identification.id'] && (identification === null || identification === void 0 ? void 0 : identification.id) === watch('nid');
133
- var isIssuedCountryVerified = dataVerified['identification.issuer_country'] && (identification === null || identification === void 0 ? void 0 : identification.issued_country_code) === ((_f = watch('issuedCountry')) === null || _f === void 0 ? void 0 : _f.iso2);
173
+ var isIssuedCountryVerified = dataVerified['identification.issuer_country'] && (identification === null || identification === void 0 ? void 0 : identification.issued_country_code) === ((_j = watch('issuedCountry')) === null || _j === void 0 ? void 0 : _j.iso2);
134
174
  var isExpiryDateVerified = dataVerified['identification.expiry'] && expDateRes === watch('expiryDate');
135
175
  var isDOBVerified = dataVerified['birth.date'] && dobDateRes === watch('dob');
136
- var isBirthCountryVerified = dataVerified['birth.country'] && (birth === null || birth === void 0 ? void 0 : birth.country) === ((_g = watch('placeOfBirthCountry')) === null || _g === void 0 ? void 0 : _g.iso2);
137
- var isBirthCityVerified = dataVerified['birth.city'] && ((_h = birth === null || birth === void 0 ? void 0 : birth.city) === null || _h === void 0 ? void 0 : _h.cityId) === ((_j = watch('placeOfBirthCity')) === null || _j === void 0 ? void 0 : _j.id);
138
- var isNationalityVerified = dataVerified['nationality'] && nationalityRes === ((_k = watch('nationality')) === null || _k === void 0 ? void 0 : _k.iso2);
176
+ var isBirthCountryVerified = dataVerified['birth.country'] && (birth === null || birth === void 0 ? void 0 : birth.country) === ((_k = watch('placeOfBirthCountry')) === null || _k === void 0 ? void 0 : _k.iso2);
177
+ var isBirthCityVerified = dataVerified['birth.city'] && ((_l = birth === null || birth === void 0 ? void 0 : birth.city) === null || _l === void 0 ? void 0 : _l.cityId) === ((_m = watch('placeOfBirthCity')) === null || _m === void 0 ? void 0 : _m.id);
178
+ var isNationalityVerified = dataVerified['nationality'] && nationalityRes === ((_o = watch('nationality')) === null || _o === void 0 ? void 0 : _o.iso2);
139
179
  var isKWOrSaCountry = React.useMemo(function () { return isKWOrSA(settingsData.businessCountry.iso2); }, [settingsData.businessCountry.iso2]);
140
180
  var onSubmit = function (data) {
141
- dispatch(updateIndividualPersonalInfo(deepCopy(getFelids(data))));
181
+ var formData = __assign(__assign({}, deepCopy(getFelids(data))), { isDirty: isDirty });
182
+ dispatch(updateIndividualPersonalInfo(formData));
142
183
  };
143
184
  React.useEffect(function () {
144
185
  if (error)
145
186
  dispatch(clearError());
146
187
  }, [methods.formState.isValid]);
188
+ React.useEffect(function () {
189
+ sendCustomEventToGTM({
190
+ event: 'Send Event',
191
+ event_category: 'Board Flows - Individual',
192
+ event_action: 'Update Personal Data Page',
193
+ event_label: settingsData.businessCountry.iso2
194
+ });
195
+ }, []);
147
196
  var onBack = function () {
148
197
  if (error)
149
198
  dispatch(clearError());
@@ -151,6 +200,12 @@ var IndividualPersonalInfo = function (_a) {
151
200
  dispatch(handleCurrentActiveScreen('INDIVIDUAL_LIST_STEP'));
152
201
  return;
153
202
  }
203
+ sendCustomEventToGTM({
204
+ event: 'Send Event',
205
+ event_category: 'Board Flows - Individual',
206
+ event_action: 'Individual Details Back Button',
207
+ event_label: settingsData.businessCountry.iso2
208
+ });
154
209
  if ((flows === null || flows === void 0 ? void 0 : flows.length) > 0) {
155
210
  dispatch(handlePrevScreenStep('INDIVIDUAL_SUCCESS_FOUR_FLOWS_BUTTONS_STEP'));
156
211
  return;
@@ -26,7 +26,7 @@ import { useTranslation } from 'react-i18next';
26
26
  import { useController, useFormContext } from 'react-hook-form';
27
27
  import Box from '@mui/material/Box';
28
28
  import { styled, alpha } from '@mui/material/styles';
29
- import { removeAllCharsFromNumber } from '../../../../utils';
29
+ import { getMobileNumberLen, removeAllCharsFromNumber } from '../../../../utils';
30
30
  import { useLanguage } from '../../../../hooks';
31
31
  import Text from '../../../../components/Text';
32
32
  import Collapse from '../../../../components/Collapse';
@@ -95,9 +95,10 @@ var MobileNumber = React.forwardRef(function (_a, ref) {
95
95
  var countryName = (isAr ? (_b = countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.name) === null || _b === void 0 ? void 0 : _b.arabic : (_c = countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.name) === null || _c === void 0 ? void 0 : _c.english) || '';
96
96
  var error = !!mobileValue ? (_d = phoneControl.fieldState.error) === null || _d === void 0 ? void 0 : _d.message : '';
97
97
  var isSA = (countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.iso2) === 'SA';
98
- var mobileLen = countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.digits;
99
- var isStartsWith5 = mobileValue.startsWith('5');
100
- var requiredLen = isSA && isStartsWith5 ? mobileLen - 1 : mobileLen;
98
+ var mobileMaxLen = countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.max_digits;
99
+ var mobileMinLen = countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.min_digits;
100
+ var requiredMaxLen = getMobileNumberLen(mobileMaxLen, mobileValue);
101
+ var requiredMinLen = getMobileNumberLen(mobileMinLen, mobileValue);
101
102
  React.useEffect(function () {
102
103
  if (mobileValue)
103
104
  setValue('mobile', mobileValue, { shouldValidate: true });
@@ -135,7 +136,7 @@ var MobileNumber = React.forwardRef(function (_a, ref) {
135
136
  setValue('mobile', '');
136
137
  countryCodeControl.field.onChange(country);
137
138
  };
138
- return (_jsx(Collapse, __assign({ in: rest.show }, { children: _jsxs(ScreenContainer, __assign({ ref: ref, sx: { mb: 3 } }, { children: [_jsx(LabelContainerStyled, { children: _jsx(InputLabelStyled, { children: t('signup_enter_mobile') }) }), _jsx(InputStyled, { readOnly: readOnly, inputProps: { maxLength: requiredLen }, type: 'tel', disabled: !!anchorEl, onClick: onCloseCountryList, onChange: onPhoneNumberChange, value: !!anchorEl ? countryName : mobileValue, startAdornment: _jsxs(CountryCodeStyled, __assign({ onClick: readOnly ? undefined : function () { return toggleCountryList(); } }, { children: ["+".concat(countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.idd_prefix), !anchorEl && _jsx(ExpandIconStyled, { anchorEl: !!anchorEl })] })), endAdornment: !!anchorEl ? (_jsx(ExpandIconStyled, { onClick: function () { return toggleCountryList(); }, anchorEl: !!anchorEl })) : (_jsx(EndAdornment, { value: mobileValue, isVerified: isVerified, onClear: clearMobileNumber, error: error })), placeholder: "".concat(isSA ? '5' : '0', "00000000"), warningType: 'alert', warningMessage: error && t(error, { length: requiredLen, number: '05|5' }) }), _jsx(Collapse, __assign({ in: !!anchorEl }, { children: _jsx(SimpleList, { searchKeyPath: 'name.english', searchValuePath: ['name.arabic', 'name.english'], list: countriesCode, onSelectItem: onSelectItem, renderItem: function (item) {
139
+ return (_jsx(Collapse, __assign({ in: rest.show }, { children: _jsxs(ScreenContainer, __assign({ ref: ref, sx: { mb: 3 } }, { children: [_jsx(LabelContainerStyled, { children: _jsx(InputLabelStyled, { children: t('signup_enter_mobile') }) }), _jsx(InputStyled, { readOnly: readOnly, inputProps: { maxLength: requiredMaxLen }, type: 'tel', disabled: !!anchorEl, onClick: onCloseCountryList, onChange: onPhoneNumberChange, value: !!anchorEl ? countryName : mobileValue, startAdornment: _jsxs(CountryCodeStyled, __assign({ onClick: readOnly ? undefined : function () { return toggleCountryList(); } }, { children: ["+".concat(countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.idd_prefix), !anchorEl && _jsx(ExpandIconStyled, { anchorEl: !!anchorEl })] })), endAdornment: !!anchorEl ? (_jsx(ExpandIconStyled, { onClick: function () { return toggleCountryList(); }, anchorEl: !!anchorEl })) : (_jsx(EndAdornment, { value: mobileValue, isVerified: isVerified, onClear: clearMobileNumber, error: error })), placeholder: "".concat(isSA ? '5' : '0', "00000000"), warningType: 'alert', warningMessage: error && t(error, { minLength: requiredMinLen, length: requiredMaxLen, number: '05|5' }) }), _jsx(Collapse, __assign({ in: !!anchorEl }, { children: _jsx(SimpleList, { searchKeyPath: 'name.english', searchValuePath: ['name.arabic', 'name.english'], list: countriesCode, onSelectItem: onSelectItem, renderItem: function (item) {
139
140
  return (_jsxs(_Fragment, { children: [_jsxs(CountryItemContainer, { children: [_jsxs(CountryCodeText, __assign({ isSelected: (item === null || item === void 0 ? void 0 : item.idd_prefix) === (countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.idd_prefix) }, { children: ["+", item.idd_prefix] })), _jsx(CountryNameText, __assign({ isSelected: (item === null || item === void 0 ? void 0 : item.idd_prefix) === (countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.idd_prefix) }, { children: isAr ? item.name.arabic : item.name.english }))] }), item.idd_prefix === (countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.idd_prefix) && _jsx(CheckIcon, { isVerified: isVerified })] }));
140
141
  } }) }))] })) })));
141
142
  });
@@ -1,5 +1,6 @@
1
1
  import * as yup from 'yup';
2
2
  import { REGEX_FULL_NAME } from '../../../../constants';
3
+ import { getMobileNumberLen } from '../../../../utils';
3
4
  export var IndividualInfoValidationSchema = function (isOtherCountry) {
4
5
  return yup.object().shape({
5
6
  name: yup
@@ -22,7 +23,8 @@ export var IndividualInfoValidationSchema = function (isOtherCountry) {
22
23
  if (((value === null || value === void 0 ? void 0 : value.length) || 0) > 0) {
23
24
  var countryCode = this.parent.countryCode;
24
25
  var isSA = countryCode.iso2 === 'SA';
25
- var digits = countryCode.digits;
26
+ var maxDigits = countryCode.max_digits;
27
+ var minDigits = countryCode.min_digits;
26
28
  var mobileValue = value || '';
27
29
  var valueLen = mobileValue.length;
28
30
  var isNumber = mobileValue.match(/^[0-9]/g);
@@ -34,10 +36,16 @@ export var IndividualInfoValidationSchema = function (isOtherCountry) {
34
36
  if (isSA) {
35
37
  if (!isSaudiNumber)
36
38
  return this.createError({ message: 'start_with_number' });
37
- var requiredLen = isStartWith5 ? digits - 1 : digits;
39
+ var requiredLen = isStartWithZero ? maxDigits + 1 : maxDigits;
38
40
  return valueLen === requiredLen ? true : this.createError({ message: 'enter_valid_mobile_number' });
39
41
  }
40
- return valueLen === digits ? true : this.createError({ message: 'enter_valid_mobile_number' });
42
+ var requiredMaxLen = getMobileNumberLen(maxDigits, mobileValue);
43
+ var requiredMinLen = getMobileNumberLen(minDigits, mobileValue);
44
+ if (valueLen >= requiredMinLen && valueLen <= requiredMaxLen)
45
+ return true;
46
+ if (minDigits === maxDigits)
47
+ return this.createError({ message: 'enter_valid_mobile_number' });
48
+ return this.createError({ message: 'enter_valid_mobile_number_min_max_length' });
41
49
  }
42
50
  return true;
43
51
  }
@@ -26,8 +26,8 @@ import { useTranslation } from 'react-i18next';
26
26
  import { useController, useFormContext } from 'react-hook-form';
27
27
  import Box from '@mui/material/Box';
28
28
  import { styled, alpha } from '@mui/material/styles';
29
- import { removeAllCharsFromNumber } from '../../../../utils';
30
- import { useLanguage, useAppSelector } from '../../../../hooks';
29
+ import { getMobileNumberLen, removeAllCharsFromNumber } from '../../../../utils';
30
+ import { useLanguage } from '../../../../hooks';
31
31
  import Text from '../../../../components/Text';
32
32
  import Collapse from '../../../../components/Collapse';
33
33
  import ExpandIcon from '../../../../components/ExpandIcon';
@@ -36,7 +36,6 @@ import ClearIcon from '../../../shared/ClearIcon';
36
36
  import CheckIcon from '../../../shared/CheckIcon';
37
37
  import ScreenContainer from '../../../shared/Containers/ScreenContainer';
38
38
  import Input from '../../../shared/Input';
39
- import { individualSelector } from '../../../app/individual/individualStore';
40
39
  var LabelContainerStyled = styled(Box)(function (_a) {
41
40
  var theme = _a.theme;
42
41
  return ({
@@ -86,18 +85,17 @@ var MobileNumber = React.forwardRef(function (_a, ref) {
86
85
  var t = useTranslation().t;
87
86
  var isAr = useLanguage().isAr;
88
87
  var _g = useFormContext(), control = _g.control, setValue = _g.setValue;
89
- var data = useAppSelector(individualSelector).data;
90
88
  var phoneControl = useController({ name: 'mobile', control: control });
91
89
  var countryCodeControl = useController({ name: 'countryCode', control: control });
92
90
  var countryCodeValue = countryCodeControl.field.value;
93
- var mobileValue = phoneControl.field.value;
91
+ var mobileValue = phoneControl.field.value || '';
94
92
  var countryName = (isAr ? (_b = countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.name) === null || _b === void 0 ? void 0 : _b.arabic : (_c = countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.name) === null || _c === void 0 ? void 0 : _c.english) || '';
95
93
  var error = !!mobileValue ? (_d = phoneControl.fieldState.error) === null || _d === void 0 ? void 0 : _d.message : '';
96
94
  var isSA = (countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.iso2) === 'SA';
97
- var mobileLen = countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.digits;
98
- var isStartsWith5 = mobileValue.startsWith('5');
99
- var requiredLen = isSA && isStartsWith5 ? mobileLen - 1 : mobileLen;
100
- var verify = data.verify;
95
+ var mobileMaxLen = countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.max_digits;
96
+ var mobileMinLen = countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.min_digits;
97
+ var requiredMaxLen = getMobileNumberLen(mobileMaxLen, mobileValue);
98
+ var requiredMinLen = getMobileNumberLen(mobileMinLen, mobileValue);
101
99
  React.useEffect(function () {
102
100
  if (mobileValue)
103
101
  setValue('mobile', mobileValue, { shouldValidate: true });
@@ -135,11 +133,11 @@ var MobileNumber = React.forwardRef(function (_a, ref) {
135
133
  setValue('mobile', '');
136
134
  countryCodeControl.field.onChange(country);
137
135
  };
138
- return (_jsx(Collapse, __assign({ in: rest.show }, { children: _jsxs(ScreenContainer, __assign({ ref: ref, sx: sx }, { children: [_jsx(LabelContainerStyled, { children: _jsx(InputLabelStyled, { children: t('signup_enter_mobile') }) }), _jsx(InputStyled, { readOnly: readOnly, inputProps: { maxLength: requiredLen }, type: 'tel', disabled: !!anchorEl, onClick: onCloseCountryList, onChange: onPhoneNumberChange, value: !!anchorEl ? countryName : mobileValue, startAdornment: _jsxs(CountryCodeStyled, __assign({ onClick: function () {
136
+ return (_jsx(Collapse, __assign({ in: rest.show }, { children: _jsxs(ScreenContainer, __assign({ ref: ref, sx: sx }, { children: [_jsx(LabelContainerStyled, { children: _jsx(InputLabelStyled, { children: t('signup_enter_mobile') }) }), _jsx(InputStyled, { readOnly: readOnly, inputProps: { maxLength: requiredMaxLen }, type: 'tel', disabled: !!anchorEl, onClick: onCloseCountryList, onChange: onPhoneNumberChange, value: !!anchorEl ? countryName : mobileValue, startAdornment: _jsxs(CountryCodeStyled, __assign({ onClick: function () {
139
137
  if (readOnly)
140
138
  return;
141
139
  toggleCountryList();
142
- } }, { children: ["+".concat(countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.idd_prefix), !anchorEl && _jsx(ExpandIconStyled, { anchorEl: !!anchorEl })] })), endAdornment: !!anchorEl ? (_jsx(ExpandIconStyled, { onClick: function () { return toggleCountryList(); }, anchorEl: !!anchorEl })) : !error && mobileValue ? (_jsx(CheckIcon, {})) : (mobileValue && _jsx(ClearIcon, { onClick: clearMobileNumber })), placeholder: "".concat(isSA ? '5' : '0', "00000000"), warningType: 'alert', warningMessage: error && t(error, { length: requiredLen, number: '05|5' }) }), _jsx(Collapse, __assign({ in: !!anchorEl }, { children: _jsx(SimpleList, { searchKeyPath: 'name.english', searchValuePath: ['name.arabic', 'name.english'], list: countriesCode, onSelectItem: onSelectItem, renderItem: function (item) {
140
+ } }, { children: ["+".concat(countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.idd_prefix), !anchorEl && _jsx(ExpandIconStyled, { anchorEl: !!anchorEl })] })), endAdornment: !!anchorEl ? (_jsx(ExpandIconStyled, { onClick: function () { return toggleCountryList(); }, anchorEl: !!anchorEl })) : !error && mobileValue ? (_jsx(CheckIcon, {})) : (mobileValue && _jsx(ClearIcon, { onClick: clearMobileNumber })), placeholder: "".concat(isSA ? '5' : '0', "00000000"), warningType: 'alert', warningMessage: error && t(error, { minLength: requiredMinLen, length: requiredMaxLen, number: '05|5' }) }), _jsx(Collapse, __assign({ in: !!anchorEl }, { children: _jsx(SimpleList, { searchKeyPath: 'name.english', searchValuePath: ['name.arabic', 'name.english'], list: countriesCode, onSelectItem: onSelectItem, renderItem: function (item) {
143
141
  return (_jsxs(_Fragment, { children: [_jsxs(CountryItemContainer, { children: [_jsxs(CountryCodeText, __assign({ isSelected: (item === null || item === void 0 ? void 0 : item.idd_prefix) === (countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.idd_prefix) }, { children: ["+", item.idd_prefix] })), _jsx(CountryNameText, __assign({ isSelected: (item === null || item === void 0 ? void 0 : item.idd_prefix) === (countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.idd_prefix) }, { children: isAr ? item.name.arabic : item.name.english }))] }), item.idd_prefix === (countryCodeValue === null || countryCodeValue === void 0 ? void 0 : countryCodeValue.idd_prefix) && _jsx(CheckIcon, {})] }));
144
142
  } }) }))] })) })));
145
143
  });
@@ -1,3 +1,4 @@
1
+ import { getMobileNumberLen } from '../../../../utils';
1
2
  import * as yup from 'yup';
2
3
  export var IndividualPhoneInfoValidationSchema = yup.object().shape({
3
4
  mobile: yup
@@ -7,7 +8,8 @@ export var IndividualPhoneInfoValidationSchema = yup.object().shape({
7
8
  if (((value === null || value === void 0 ? void 0 : value.length) || 0) > 0) {
8
9
  var countryCode = this.parent.countryCode;
9
10
  var isSA = countryCode.iso2 === 'SA';
10
- var digits = countryCode.digits;
11
+ var maxDigits = countryCode.max_digits;
12
+ var minDigits = countryCode.min_digits;
11
13
  var mobileValue = value || '';
12
14
  var valueLen = mobileValue.length;
13
15
  var isNumber = mobileValue.match(/^[0-9]/g);
@@ -19,10 +21,16 @@ export var IndividualPhoneInfoValidationSchema = yup.object().shape({
19
21
  if (isSA) {
20
22
  if (!isSaudiNumber)
21
23
  return this.createError({ message: 'start_with_number' });
22
- var requiredLen = isStartWith5 ? digits - 1 : digits;
24
+ var requiredLen = isStartWithZero ? maxDigits + 1 : maxDigits;
23
25
  return valueLen === requiredLen ? true : this.createError({ message: 'enter_valid_mobile_number' });
24
26
  }
25
- return valueLen === digits ? true : this.createError({ message: 'enter_valid_mobile_number' });
27
+ var requiredMaxLen = getMobileNumberLen(maxDigits, mobileValue);
28
+ var requiredMinLen = getMobileNumberLen(minDigits, mobileValue);
29
+ if (valueLen >= requiredMinLen && valueLen <= requiredMaxLen)
30
+ return true;
31
+ if (minDigits === maxDigits)
32
+ return this.createError({ message: 'enter_valid_mobile_number' });
33
+ return this.createError({ message: 'enter_valid_mobile_number_min_max_length' });
26
34
  }
27
35
  return true;
28
36
  }
@@ -0,0 +1,5 @@
1
+ import * as React from 'react';
2
+ export interface OperatorErrorProps {
3
+ }
4
+ declare const _default: React.MemoExoticComponent<({}: OperatorErrorProps) => JSX.Element>;
5
+ export default _default;
@@ -0,0 +1,9 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import * as React from 'react';
3
+ import { useTranslation } from 'react-i18next';
4
+ import GenericError from '../../../shared/GenericError';
5
+ var OperatorError = function (_a) {
6
+ var t = useTranslation().t;
7
+ return _jsx(GenericError, { error: t('operator_is_invalid'), errorTitle: t('oops') });
8
+ };
9
+ export default React.memo(OperatorError);
@@ -0,0 +1,3 @@
1
+ import OperatorError, { OperatorErrorProps } from './OperatorError';
2
+ export type { OperatorErrorProps };
3
+ export default OperatorError;
@@ -0,0 +1,2 @@
1
+ import OperatorError from './OperatorError';
2
+ export default OperatorError;
@@ -21,10 +21,10 @@ var SuccessWithFlowButtons = function () {
21
21
  var _a = useAppSelector(individualSelector), data = _a.data, loading = _a.loading;
22
22
  var settingsData = useAppSelector(settingsSelector).data;
23
23
  var isScopeAuthentication = settingsData.appConfig.scope === SCOPE_AUTH;
24
- var _b = data.verify.responseBody || {}, flows = _b.flows, entity = _b.entity, brand = _b.brand, bank = _b.bank_account, merchant = _b.merchant, user = _b.user, business = _b.business, board_id = _b.board_id, board_info_id = _b.board_info_id, name = _b.name, individuals = _b.individuals;
24
+ var _b = data.verify.responseBody || {}, flows = _b.flows, entity = _b.entity, brand = _b.brand, bank = _b.bank_account, merchant = _b.merchant, user = _b.user, business = _b.business, board_id = _b.board_id, board_info_id = _b.board_info_id, name = _b.name, individuals = _b.individuals, recipient = _b.recipient, board_status = _b.board_status;
25
25
  var onClose = function () {
26
26
  dispatch(onCloseCompleteIndividual());
27
27
  };
28
- return (_jsx(SuccessFlowButtons, { flowName: data.flowName, loading: loading, bank: bank, brand: brand, entity: entity, merchant: merchant, user: __assign({ names: { en: name } }, user), business: business, boardId: board_id, boardInfoId: board_info_id, individuals: individuals, flows: flows || [], onClose: isScopeAuthentication ? onClose : undefined }));
28
+ return (_jsx(SuccessFlowButtons, { flowName: data.flowName, loading: loading, bank: bank, brand: brand, entity: entity, merchant: merchant, user: __assign({ names: { en: name } }, user), business: business, boardId: board_id, boardInfoId: board_info_id, individuals: individuals, flows: flows || [], onClose: isScopeAuthentication ? onClose : undefined, recipient: recipient, status: board_status }));
29
29
  };
30
30
  export default memo(SuccessWithFlowButtons);
@@ -17,7 +17,7 @@ import { useForm, FormProvider } from 'react-hook-form';
17
17
  import { yupResolver } from '@hookform/resolvers/yup';
18
18
  import Box from '@mui/material/Box/Box';
19
19
  import { styled } from '@mui/material/styles';
20
- import { useLanguage, useAppSelector } from '../../../../hooks';
20
+ import { useLanguage, useAppSelector, useSanitizedTranslation } from '../../../../hooks';
21
21
  import { deepCopy, maskPhone } from '../../../../utils';
22
22
  import Form from '../../../../components/Form';
23
23
  import Text from '../../../../components/Text';
@@ -59,6 +59,7 @@ var VerifyNumber = function (_a) {
59
59
  });
60
60
  useSetFromDefaultValues(methods, data.otpData);
61
61
  var t = useTranslation().t;
62
+ var st = useSanitizedTranslation();
62
63
  var isAr = useLanguage().isAr;
63
64
  var _e = React.useState(false), resendLoading = _e[0], setResendLoading = _e[1];
64
65
  var phone = (_c = (_b = data.verify.responseBody) === null || _b === void 0 ? void 0 : _b.verification_by) === null || _c === void 0 ? void 0 : _c.sent_to;
@@ -75,6 +76,6 @@ var VerifyNumber = function (_a) {
75
76
  var disabled = !methods.formState.isValid || !phone || resendLoading;
76
77
  var dataLoading = loading || cityLoading;
77
78
  var showMobileNumber = !loading && !cityLoading && phone;
78
- return (_jsx(ScreenContainer, { children: _jsx(FormProvider, __assign({}, methods, { children: _jsxs(FormStyled, __assign({ onSubmit: methods.handleSubmit(onSubmit) }, { children: [_jsx(OTPTitleContainerStyled, { children: _jsxs(OTPTitleStyled, { children: [dataLoading ? t('ide_otp_waiting_title') : t('ide_opt_sent_title'), showMobileNumber && _jsx("span", __assign({ dir: 'ltr' }, { children: "".concat(maskPhone(phone || '')) }))] }) }), _jsx(OTPInput, { loading: resendLoading, setLoading: setResendLoading }), _jsx(Button, __assign({ disableBack: true, disabled: disabled, isAr: isAr, loading: loading, error: t(error || '') }, { children: t('next') }))] })) })) }));
79
+ return (_jsx(ScreenContainer, { children: _jsx(FormProvider, __assign({}, methods, { children: _jsxs(FormStyled, __assign({ onSubmit: methods.handleSubmit(onSubmit) }, { children: [_jsx(OTPTitleContainerStyled, { children: _jsxs(OTPTitleStyled, { children: [dataLoading ? st('ide_otp_waiting_title') : st('ide_opt_sent_title'), showMobileNumber && _jsx("span", __assign({ dir: 'ltr' }, { children: "".concat(maskPhone(phone || '')) }))] }) }), _jsx(OTPInput, { loading: resendLoading, setLoading: setResendLoading }), _jsx(Button, __assign({ disableBack: true, disabled: disabled, isAr: isAr, loading: loading, error: st(error || '') }, { children: t('next') }))] })) })) }));
79
80
  };
80
81
  export default React.memo(VerifyNumber);
@@ -0,0 +1,11 @@
1
+ /// <reference types="react" />
2
+ import { LibConfig } from '../../@types';
3
+ export interface KYCLibProps extends LibConfig {
4
+ verifyToken?: string;
5
+ configToken?: string;
6
+ loaderColor?: string;
7
+ }
8
+ export declare function KYCElement(props: KYCLibProps): JSX.Element;
9
+ export declare function renderKYCLib(config: KYCLibProps, elementId: string): {
10
+ unmount: () => void;
11
+ };
@@ -0,0 +1,99 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __rest = (this && this.__rest) || function (s, e) {
13
+ var t = {};
14
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
15
+ t[p] = s[p];
16
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
17
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
18
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
19
+ t[p[i]] = s[p[i]];
20
+ }
21
+ return t;
22
+ };
23
+ import { jsx as _jsx } from "react/jsx-runtime";
24
+ import React, { memo } from 'react';
25
+ import { createRoot } from 'react-dom/client';
26
+ import { useAppTheme, useAppSelector, useAppConfig, useErrorListener, useStepStartedListener, useVerifyToken, useAppDispatch } from '../../hooks';
27
+ import { handleCurrentActiveScreen, settingsSelector } from '../../app/settings';
28
+ import { store } from '../../app/store';
29
+ import AnimationFlow from '../../components/AnimationFlow';
30
+ import { ReduxProvider, ThemeProvider } from '../../components/Providers';
31
+ import Collapse from '../../components/Collapse';
32
+ import { findOrCreateElementAndInject, initializeGTM, sendPageView } from '../../utils';
33
+ import { CONNECT_FLOWS, KYC_SCREENS_NAVIGATION } from '../../constants';
34
+ import { FeatureContainer } from '../shared/Containers';
35
+ import { kycSelector, verifyTokenApi } from '../app/kyc/kycStore';
36
+ import { kycFeatureScreens } from '../featuresScreens';
37
+ import Background from '../shared/Background';
38
+ var KYC = memo(function (_a) {
39
+ var _b, _c;
40
+ var configToken = _a.configToken, verifyToken = _a.verifyToken, loaderColor = _a.loaderColor, props = __rest(_a, ["configToken", "verifyToken", "loaderColor"]);
41
+ var theme = useAppTheme().theme;
42
+ var dispatch = useAppDispatch();
43
+ var _d = useAppSelector(settingsSelector), data = _d.data, error = _d.error, settingLoading = _d.loading;
44
+ var _e = useAppSelector(kycSelector), customLoading = _e.customLoading, kycError = _e.error, loading = _e.loading;
45
+ useAppConfig(__assign(__assign({ navigation: KYC_SCREENS_NAVIGATION }, props), { disableSettingFetching: props.mode === 'content' ? false : !!verifyToken }));
46
+ useErrorListener(kycError || error);
47
+ useStepStartedListener();
48
+ var activeScreen = data.activeScreen, isTapOrigin = data.isTapOrigin, open = data.open, featureScreensNavigation = data.featureScreensNavigation, merchant = data.merchant, isMaturityExpress = data.isMaturityExpress, appConfig = data.appConfig;
49
+ var animationDirection = open ? (_b = appConfig.features) === null || _b === void 0 ? void 0 : _b.dialogStartTransition : (_c = appConfig.features) === null || _c === void 0 ? void 0 : _c.dialogEndTransition;
50
+ var verifyTokenAndMoveToNextScreen = function (_a) {
51
+ var token = _a.token;
52
+ return function () {
53
+ dispatch(verifyTokenApi({ token: token }))
54
+ .unwrap()
55
+ .then(function (_a) {
56
+ var nextScreen = _a.nextScreen;
57
+ dispatch(handleCurrentActiveScreen(nextScreen));
58
+ })
59
+ .catch(function (error) {
60
+ if (error.message.toLowerCase() === 'failed to decrypt verify_token') {
61
+ dispatch(handleCurrentActiveScreen(CONNECT_FLOWS.kyc.tokenError));
62
+ }
63
+ });
64
+ };
65
+ };
66
+ useVerifyToken({
67
+ verify: verifyTokenAndMoveToNextScreen,
68
+ loadingScreenName: CONNECT_FLOWS.kyc.loadingData,
69
+ navigation: featureScreensNavigation,
70
+ open: open,
71
+ mode: props.mode,
72
+ internalToken: verifyToken,
73
+ settingLoading: settingLoading,
74
+ operatorErrorScreenName: CONNECT_FLOWS.kyc.operatorError,
75
+ isValidOperator: data.isValidOperator
76
+ });
77
+ React.useEffect(function () {
78
+ initializeGTM();
79
+ sendPageView({
80
+ title: 'KYC'
81
+ });
82
+ }, []);
83
+ var initialLoading = verifyToken && props.mode !== 'content' ? settingLoading : settingLoading || customLoading;
84
+ return (_jsx(ThemeProvider, __assign({ theme: theme }, { children: _jsx(Background, __assign({ mode: props.mode, open: open, isTapOrigin: isTapOrigin, loading: initialLoading }, { children: _jsx(AnimationFlow, __assign({ pointerEvents: loading ? 'none' : 'auto', isTapOrigin: isTapOrigin, animationDirection: animationDirection, open: open, error: error, loading: initialLoading, loaderColor: loaderColor, breakpoint: 'sm', screenId: activeScreen.name, merchantInfo: merchant, isMaturityExpress: isMaturityExpress, type: props.mode === 'content' ? 'CONTENT' : undefined, dialogEdgeFormat: data.appConfig.dialogEdgeFormat, features: appConfig.features }, { children: _jsx(FeatureContainer, __assign({ mode: props.mode, isMaturityExpress: isMaturityExpress }, { children: kycFeatureScreens.map(function (_a, index) {
85
+ var Element = _a.element, name = _a.name;
86
+ var isActive = activeScreen.name === name;
87
+ return (_jsx(Collapse, __assign({ in: isActive, timeout: { enter: 1000, exit: 800 } }, { children: _jsx(Element, {}) }), index));
88
+ }) })) })) })) })));
89
+ });
90
+ export function KYCElement(props) {
91
+ return (_jsx(ReduxProvider, __assign({ store: store }, { children: _jsx(KYC, __assign({}, props)) })));
92
+ }
93
+ export function renderKYCLib(config, elementId) {
94
+ var element = findOrCreateElementAndInject(elementId);
95
+ var root = createRoot(element);
96
+ root.render(_jsx(KYCElement, __assign({}, config)));
97
+ var unmount = function () { return root.unmount(); };
98
+ return { unmount: unmount };
99
+ }
@@ -0,0 +1 @@
1
+ export * from './KYC';
@@ -0,0 +1 @@
1
+ export * from './KYC';
@@ -0,0 +1,5 @@
1
+ import * as React from 'react';
2
+ export interface AlreadySubmittedProps {
3
+ }
4
+ declare const _default: React.MemoExoticComponent<({}: AlreadySubmittedProps) => JSX.Element>;
5
+ export default _default;
@@ -0,0 +1,19 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import * as React from 'react';
3
+ import { useTranslation } from 'react-i18next';
4
+ import SuccessScreen from '../../../shared/SuccessScreen';
5
+ import { useAppSelector } from '../../../../hooks';
6
+ import { kycSelector } from '../../../app/kyc/kycStore';
7
+ var AlreadySubmitted = function (_a) {
8
+ var t = useTranslation().t;
9
+ var _b = useAppSelector(kycSelector), error = _b.error, loading = _b.loading, data = _b.data;
10
+ var redirectToBoard = function () {
11
+ var _a, _b;
12
+ var baseUrl = window.location.origin;
13
+ var boardId = ((_b = (_a = data.responseData) === null || _a === void 0 ? void 0 : _a.verifyTokenData) === null || _b === void 0 ? void 0 : _b.boardId) || '';
14
+ var boardUrl = "".concat(baseUrl, "/board?board_id=").concat(boardId);
15
+ window.open(boardUrl, '_self');
16
+ };
17
+ return (_jsx(SuccessScreen, { title: t('kyc_already_submitted_title'), onSuccess: redirectToBoard, successTitle: t('kyc_success_button'), loading: loading, error: error || '' }));
18
+ };
19
+ export default React.memo(AlreadySubmitted);
@@ -0,0 +1,2 @@
1
+ import AlreadySubmitted from './AlreadySubmitted';
2
+ export default AlreadySubmitted;
@@ -0,0 +1,2 @@
1
+ import AlreadySubmitted from './AlreadySubmitted';
2
+ export default AlreadySubmitted;
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ export declare const Loading: () => JSX.Element;
3
+ declare const _default: React.MemoExoticComponent<() => JSX.Element>;
4
+ export default _default;
@@ -0,0 +1,10 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { memo } from 'react';
3
+ import { useAppSelector } from '../../../../hooks';
4
+ import DataLoading from '../../../shared/DataLoading';
5
+ import { kycSelector } from '../../../app/kyc/kycStore';
6
+ export var Loading = function () {
7
+ var error = useAppSelector(kycSelector).error;
8
+ return _jsx(DataLoading, { error: error });
9
+ };
10
+ export default memo(Loading);
@@ -0,0 +1,2 @@
1
+ import Loading from './Loading';
2
+ export default Loading;
@@ -0,0 +1,2 @@
1
+ import Loading from './Loading';
2
+ export default Loading;
@@ -0,0 +1,5 @@
1
+ import * as React from 'react';
2
+ export interface OperatorErrorProps {
3
+ }
4
+ declare const _default: React.MemoExoticComponent<({}: OperatorErrorProps) => JSX.Element>;
5
+ export default _default;
@@ -0,0 +1,9 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import * as React from 'react';
3
+ import { useTranslation } from 'react-i18next';
4
+ import GenericError from '../../../shared/GenericError';
5
+ var OperatorError = function (_a) {
6
+ var t = useTranslation().t;
7
+ return _jsx(GenericError, { error: t('operator_is_invalid'), errorTitle: t('oops') });
8
+ };
9
+ export default React.memo(OperatorError);
@@ -0,0 +1,2 @@
1
+ import OperatorError from './OperatorError';
2
+ export default OperatorError;
@@ -0,0 +1,2 @@
1
+ import OperatorError from './OperatorError';
2
+ export default OperatorError;
@@ -0,0 +1,5 @@
1
+ import * as React from 'react';
2
+ export interface SuccessProps {
3
+ }
4
+ declare const _default: React.MemoExoticComponent<({}: SuccessProps) => JSX.Element>;
5
+ export default _default;