ordering-ui-react-native 0.16.60 → 0.16.61-release

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 (199) hide show
  1. package/package.json +6 -5
  2. package/src/DeliveryApp.tsx +43 -1
  3. package/src/components/ActiveOrders/index.tsx +61 -63
  4. package/src/components/ActiveOrders/styles.tsx +8 -14
  5. package/src/components/BusinessInformation/index.tsx +19 -4
  6. package/src/components/BusinessInformation/styles.tsx +2 -2
  7. package/src/components/BusinessProductsList/index.tsx +10 -10
  8. package/src/components/BusinessesListing/index.tsx +1 -1
  9. package/src/components/Checkout/index.tsx +2 -1
  10. package/src/components/LanguageSelector/index.tsx +21 -16
  11. package/src/components/Messages/index.tsx +2 -2
  12. package/src/components/NotificationSetting/index.tsx +85 -0
  13. package/src/components/OrdersOption/index.tsx +54 -56
  14. package/src/components/PaymentOptions/index.tsx +298 -345
  15. package/src/components/PaymentOptionsWebView/index.tsx +119 -120
  16. package/src/components/SingleProductReview/index.tsx +7 -4
  17. package/src/components/StripeElementsForm/index.tsx +25 -16
  18. package/src/components/VerifyPhone/styles.tsx +1 -2
  19. package/src/components/shared/OBottomPopup.tsx +6 -2
  20. package/src/components/shared/OToast.tsx +4 -4
  21. package/src/index.tsx +2 -0
  22. package/src/types/@fatnlazycat/react-native-recaptcha-v3/index.d.ts +1 -0
  23. package/src/utils/index.tsx +2 -1
  24. package/themes/business/src/components/AcceptOrRejectOrder/index.tsx +260 -238
  25. package/themes/business/src/components/AcceptOrRejectOrder/styles.tsx +6 -4
  26. package/themes/business/src/components/BusinessController/index.tsx +2 -2
  27. package/themes/business/src/components/Chat/index.tsx +40 -32
  28. package/themes/business/src/components/DriverMap/index.tsx +7 -5
  29. package/themes/business/src/components/LoginForm/index.tsx +111 -74
  30. package/themes/business/src/components/MapView/index.tsx +12 -1
  31. package/themes/business/src/components/MessagesOption/index.tsx +11 -1
  32. package/themes/business/src/components/NewOrderNotification/index.tsx +31 -41
  33. package/themes/business/src/components/OrderDetails/OrderContentComponent.tsx +70 -43
  34. package/themes/business/src/components/OrderDetails/OrderHeaderComponent.tsx +3 -3
  35. package/themes/business/src/components/OrdersListManager/index.tsx +10 -3
  36. package/themes/business/src/components/OrdersOption/index.tsx +76 -77
  37. package/themes/business/src/components/OrdersOption/styles.tsx +5 -1
  38. package/themes/business/src/components/OrdersOptionBusiness/index.tsx +15 -1
  39. package/themes/business/src/components/OrdersOptionCity/index.tsx +15 -1
  40. package/themes/business/src/components/OrdersOptionDate/index.tsx +19 -6
  41. package/themes/business/src/components/OrdersOptionDelivery/index.tsx +15 -1
  42. package/themes/business/src/components/OrdersOptionDriver/index.tsx +15 -1
  43. package/themes/business/src/components/OrdersOptionPaymethod/index.tsx +15 -1
  44. package/themes/business/src/components/OrdersOptionStatus/index.tsx +10 -1
  45. package/themes/business/src/components/PreviousMessages/index.tsx +17 -18
  46. package/themes/business/src/components/PreviousOrders/OrderItem.tsx +250 -0
  47. package/themes/business/src/components/PreviousOrders/OrdersGroupedItem.tsx +115 -0
  48. package/themes/business/src/components/PreviousOrders/index.tsx +440 -245
  49. package/themes/business/src/components/PreviousOrders/styles.tsx +31 -3
  50. package/themes/business/src/components/ProductItemAccordion/index.tsx +3 -2
  51. package/themes/business/src/components/ReviewCustomer/index.tsx +39 -15
  52. package/themes/business/src/components/shared/ODropDown.tsx +42 -8
  53. package/themes/business/src/components/shared/ODropDownCalendar.tsx +36 -7
  54. package/themes/business/src/components/shared/OLink.tsx +33 -13
  55. package/themes/business/src/components/shared/OText.tsx +8 -2
  56. package/themes/business/src/types/index.tsx +24 -11
  57. package/themes/business/src/utils/index.tsx +10 -0
  58. package/themes/doordash/src/components/BusinessesListing/index.tsx +1 -1
  59. package/themes/doordash/src/components/LoginForm/index.tsx +1 -2
  60. package/themes/instacart/src/components/BusinessesListing/index.tsx +1 -1
  61. package/themes/kiosk/src/components/BusinessesListing/index.tsx +2 -1
  62. package/themes/kiosk/src/components/Checkout/index.tsx +6 -0
  63. package/themes/kiosk/src/components/LoginForm/index.tsx +121 -10
  64. package/themes/kiosk/src/components/LoginForm/styles.tsx +5 -0
  65. package/themes/kiosk/src/components/NavBar/index.tsx +14 -14
  66. package/themes/kiosk/src/components/OptionCard/index.tsx +1 -1
  67. package/themes/kiosk/src/components/OrderTypeCardSelector/index.tsx +8 -10
  68. package/themes/kiosk/src/components/ProductForm/index.tsx +1 -14
  69. package/themes/kiosk/src/components/shared/OButton.tsx +5 -18
  70. package/themes/kiosk/src/types/index.d.ts +2 -0
  71. package/themes/original/index.tsx +8 -0
  72. package/themes/original/src/components/AddressDetails/index.tsx +10 -8
  73. package/themes/original/src/components/AddressForm/index.tsx +153 -137
  74. package/themes/original/src/components/AddressList/index.tsx +1 -1
  75. package/themes/original/src/components/AppleLogin/index.tsx +4 -4
  76. package/themes/original/src/components/BusinessBasicInformation/index.tsx +53 -37
  77. package/themes/original/src/components/BusinessController/index.tsx +112 -48
  78. package/themes/original/src/components/BusinessController/styles.tsx +14 -9
  79. package/themes/original/src/components/BusinessInformation/index.tsx +10 -31
  80. package/themes/original/src/components/BusinessItemAccordion/index.tsx +12 -6
  81. package/themes/original/src/components/BusinessListingSearch/BusinessControllerSkeletons/index.tsx +57 -0
  82. package/themes/original/src/components/BusinessListingSearch/MaxSectionItem/index.tsx +59 -0
  83. package/themes/original/src/components/BusinessListingSearch/MaxSectionItem/styles.tsx +13 -0
  84. package/themes/original/src/components/BusinessListingSearch/index.tsx +87 -142
  85. package/themes/original/src/components/BusinessListingSearch/styles.tsx +10 -12
  86. package/themes/original/src/components/BusinessProductsList/SubcategoriesComponent/index.tsx +87 -0
  87. package/themes/original/src/components/BusinessProductsList/SubcategoriesComponent/styles.tsx +12 -0
  88. package/themes/original/src/components/BusinessProductsList/index.tsx +59 -61
  89. package/themes/original/src/components/BusinessProductsList/styles.tsx +0 -3
  90. package/themes/original/src/components/BusinessProductsListing/index.tsx +177 -93
  91. package/themes/original/src/components/BusinessProductsListing/styles.tsx +14 -12
  92. package/themes/original/src/components/BusinessTypeFilter/index.tsx +3 -2
  93. package/themes/original/src/components/BusinessesListing/Layout/Appointment/index.tsx +2 -1
  94. package/themes/original/src/components/BusinessesListing/Layout/Original/index.tsx +112 -107
  95. package/themes/original/src/components/BusinessesListing/Layout/Original/styles.tsx +1 -9
  96. package/themes/original/src/components/BusinessesListing/index.tsx +16 -9
  97. package/themes/original/src/components/Cart/index.tsx +77 -24
  98. package/themes/original/src/components/Cart/styles.tsx +4 -0
  99. package/themes/original/src/components/CartContent/index.tsx +77 -18
  100. package/themes/original/src/components/CartContent/styles.tsx +11 -1
  101. package/themes/original/src/components/Checkout/index.tsx +115 -118
  102. package/themes/original/src/components/Checkout/styles.tsx +4 -3
  103. package/themes/original/src/components/CitiesControl/index.tsx +89 -0
  104. package/themes/original/src/components/CitiesControl/styles.tsx +17 -0
  105. package/themes/original/src/components/DriverTips/index.tsx +4 -4
  106. package/themes/original/src/components/DriverTips/styles.tsx +2 -1
  107. package/themes/original/src/components/FavoriteList/index.tsx +69 -45
  108. package/themes/original/src/components/FloatingButton/index.tsx +0 -1
  109. package/themes/original/src/components/FloatingButton/styles.tsx +1 -1
  110. package/themes/original/src/components/GPSButton/index.tsx +20 -19
  111. package/themes/original/src/components/GPSButton/styles.ts +3 -3
  112. package/themes/original/src/components/GoogleMap/index.tsx +10 -1
  113. package/themes/original/src/components/HelpAccountAndPayment/index.tsx +25 -10
  114. package/themes/original/src/components/HelpAccountAndPayment/styles.tsx +4 -0
  115. package/themes/original/src/components/HelpGuide/index.tsx +9 -8
  116. package/themes/original/src/components/HelpOrder/index.tsx +9 -8
  117. package/themes/original/src/components/LanguageSelector/index.tsx +19 -14
  118. package/themes/original/src/components/LoginForm/Otp/index.tsx +89 -73
  119. package/themes/original/src/components/LoginForm/Otp/styles.tsx +0 -1
  120. package/themes/original/src/components/LoginForm/index.tsx +98 -41
  121. package/themes/original/src/components/LottieAnimation/index.tsx +69 -0
  122. package/themes/original/src/components/Messages/index.tsx +35 -20
  123. package/themes/original/src/components/MomentOption/index.tsx +8 -6
  124. package/themes/original/src/components/MultiCart/index.tsx +50 -0
  125. package/themes/original/src/components/MultiCartsPaymethodsAndWallets/index.tsx +92 -93
  126. package/themes/original/src/components/MultiCheckout/index.tsx +96 -71
  127. package/themes/original/src/components/MultiOrdersDetails/index.tsx +34 -16
  128. package/themes/original/src/components/MyOrders/index.tsx +89 -25
  129. package/themes/original/src/components/NavBar/index.tsx +11 -5
  130. package/themes/original/src/components/NetworkError/index.tsx +5 -3
  131. package/themes/original/src/components/NotFoundSource/index.tsx +2 -1
  132. package/themes/original/src/components/Notifications/index.tsx +148 -0
  133. package/themes/original/src/components/Notifications/styles.tsx +20 -0
  134. package/themes/original/src/components/OrderDetails/index.tsx +114 -15
  135. package/themes/original/src/components/OrderDetails/styles.tsx +15 -2
  136. package/themes/original/src/components/OrderItAgain/index.tsx +75 -0
  137. package/themes/original/src/components/OrderItAgain/styles.tsx +10 -0
  138. package/themes/original/src/components/OrderProgress/index.tsx +77 -66
  139. package/themes/original/src/components/OrderProgress/styles.tsx +5 -0
  140. package/themes/original/src/components/OrderSummary/index.tsx +2 -35
  141. package/themes/original/src/components/OrderTypeSelector/index.tsx +12 -5
  142. package/themes/original/src/components/OrdersOption/PreviousBusinessOrdered/index.tsx +94 -98
  143. package/themes/original/src/components/OrdersOption/PreviousProductsOrdered/index.tsx +3 -0
  144. package/themes/original/src/components/OrdersOption/index.tsx +95 -55
  145. package/themes/original/src/components/PaymentOptionStripe/styles.tsx +1 -1
  146. package/themes/original/src/components/PaymentOptionWallet/index.tsx +56 -56
  147. package/themes/original/src/components/PaymentOptions/index.tsx +1 -2
  148. package/themes/original/src/components/PhoneInputNumber/index.tsx +1 -1
  149. package/themes/original/src/components/PlaceSpot/index.tsx +249 -47
  150. package/themes/original/src/components/PlaceSpot/styles.tsx +0 -2
  151. package/themes/original/src/components/PreviousOrders/index.tsx +3 -2
  152. package/themes/original/src/components/ProductForm/index.tsx +379 -396
  153. package/themes/original/src/components/ProductForm/styles.tsx +7 -12
  154. package/themes/original/src/components/ProductItemAccordion/index.tsx +199 -128
  155. package/themes/original/src/components/ProductOption/index.tsx +1 -1
  156. package/themes/original/src/components/ProductOptionSubOption/index.tsx +16 -8
  157. package/themes/original/src/components/ProductOptionSubOption/styles.tsx +0 -1
  158. package/themes/original/src/components/ProfessionalFilter/index.tsx +2 -1
  159. package/themes/original/src/components/ProfessionalProfile/index.tsx +19 -8
  160. package/themes/original/src/components/Promotions/index.tsx +232 -219
  161. package/themes/original/src/components/Promotions/styles.tsx +7 -2
  162. package/themes/original/src/components/ReviewDriver/index.tsx +3 -3
  163. package/themes/original/src/components/ReviewOrder/index.tsx +43 -11
  164. package/themes/original/src/components/ReviewOrder/styles.tsx +7 -0
  165. package/themes/original/src/components/ReviewProducts/index.tsx +8 -5
  166. package/themes/original/src/components/ReviewTrigger/index.tsx +27 -9
  167. package/themes/original/src/components/ReviewTrigger/styles.tsx +8 -1
  168. package/themes/original/src/components/ScheduleAccordion/index.tsx +68 -0
  169. package/themes/original/src/components/ScheduleAccordion/styles.tsx +14 -0
  170. package/themes/original/src/components/ServiceForm/index.tsx +328 -264
  171. package/themes/original/src/components/SignupForm/index.tsx +134 -89
  172. package/themes/original/src/components/SingleOrderCard/index.tsx +240 -130
  173. package/themes/original/src/components/SingleOrderCard/styles.tsx +10 -8
  174. package/themes/original/src/components/SingleProductCard/index.tsx +116 -72
  175. package/themes/original/src/components/SingleProductCard/styles.tsx +2 -9
  176. package/themes/original/src/components/SingleProductReview/index.tsx +38 -5
  177. package/themes/original/src/components/SingleProductReview/styles.tsx +12 -0
  178. package/themes/original/src/components/StripeCardsList/index.tsx +1 -1
  179. package/themes/original/src/components/StripeElementsForm/index.tsx +13 -2
  180. package/themes/original/src/components/UpsellingProducts/index.tsx +244 -215
  181. package/themes/original/src/components/UpsellingProducts/styles.tsx +12 -1
  182. package/themes/original/src/components/UserDetails/index.tsx +5 -3
  183. package/themes/original/src/components/UserFormDetails/index.tsx +6 -48
  184. package/themes/original/src/components/UserProfile/index.tsx +58 -35
  185. package/themes/original/src/components/UserProfile/styles.ts +17 -0
  186. package/themes/original/src/components/WalletTransactions/index.tsx +76 -0
  187. package/themes/original/src/components/WalletTransactions/styles.tsx +13 -0
  188. package/themes/original/src/components/Wallets/index.tsx +176 -164
  189. package/themes/original/src/components/Wallets/styles.tsx +12 -8
  190. package/themes/original/src/components/shared/CardAnimation.tsx +47 -0
  191. package/themes/original/src/components/shared/HeaderTitle.tsx +8 -3
  192. package/themes/original/src/components/shared/OBottomPopup.tsx +6 -4
  193. package/themes/original/src/components/shared/OButton.tsx +8 -3
  194. package/themes/original/src/components/shared/OIcon.tsx +8 -1
  195. package/themes/original/src/components/shared/OInput.tsx +10 -1
  196. package/themes/original/src/layouts/Container.tsx +13 -9
  197. package/themes/original/src/types/index.tsx +61 -7
  198. package/themes/original/src/utils/index.tsx +103 -58
  199. package/themes/uber-eats/src/components/BusinessesListing/index.tsx +1 -1
@@ -1,5 +1,5 @@
1
1
  import React, { useEffect, useRef, useState } from 'react';
2
- import { View, Pressable, StyleSheet, Linking, Platform, TouchableOpacity } from 'react-native';
2
+ import { View, Pressable, StyleSheet, Linking, Platform, TouchableOpacity, Vibration } from 'react-native';
3
3
  import { useForm, Controller } from 'react-hook-form';
4
4
  import Spinner from 'react-native-loading-spinner-overlay';
5
5
  import MaterialCommunityIcons from 'react-native-vector-icons/MaterialCommunityIcons';
@@ -7,6 +7,7 @@ import CheckBox from '@react-native-community/checkbox';
7
7
  import { PhoneInputNumber } from '../PhoneInputNumber';
8
8
  import { FacebookLogin } from '../FacebookLogin';
9
9
  import Recaptcha from 'react-native-recaptcha-that-works'
10
+ import ReCaptcha from '@fatnlazycat/react-native-recaptcha-v3'
10
11
 
11
12
  import {
12
13
  SignupForm as SignUpController,
@@ -244,6 +245,7 @@ const SignupFormUI = (props: SignupParams) => {
244
245
  const onSubmit = (values?: any) => {
245
246
  if (phoneInputData.error && signUpTab !== 'otpEmail') {
246
247
  showToast(ToastType.Error, phoneInputData.error);
248
+ Vibration.vibrate()
247
249
  return;
248
250
  }
249
251
  if (
@@ -261,6 +263,7 @@ const SignupFormUI = (props: SignupParams) => {
261
263
  'The field Mobile phone is required.',
262
264
  ),
263
265
  );
266
+ Vibration.vibrate()
264
267
  return;
265
268
  }
266
269
  if (signUpTab === 'otpEmail' || signUpTab === 'otpCellphone') {
@@ -329,6 +332,7 @@ const SignupFormUI = (props: SignupParams) => {
329
332
  await Linking.openURL(url);
330
333
  } else {
331
334
  showToast(ToastType.Error, t('VALIDATION_ERROR_ACTIVE_URL', 'The _attribute_ is not a valid URL.').replace('_attribute_', t('URL', 'URL')))
335
+ Vibration.vibrate()
332
336
  }
333
337
  }
334
338
 
@@ -336,10 +340,12 @@ const SignupFormUI = (props: SignupParams) => {
336
340
  setRecaptchaVerified(false)
337
341
  if (!recaptchaConfig?.siteKey) {
338
342
  showToast(ToastType.Error, t('NO_RECAPTCHA_SITE_KEY', 'The config doesn\'t have recaptcha site key'));
343
+ Vibration.vibrate()
339
344
  return
340
345
  }
341
346
  if (!recaptchaConfig?.baseUrl) {
342
347
  showToast(ToastType.Error, t('NO_RECAPTCHA_BASE_URL', 'The config doesn\'t have recaptcha base url'));
348
+ Vibration.vibrate()
343
349
  return
344
350
  }
345
351
  recaptchaRef.current.open()
@@ -347,22 +353,47 @@ const SignupFormUI = (props: SignupParams) => {
347
353
 
348
354
  const onRecaptchaVerify = (token: any) => {
349
355
  setRecaptchaVerified(true)
350
- handleReCaptcha && handleReCaptcha(token)
356
+ handleReCaptcha && handleReCaptcha({ code: token, version: recaptchaConfig?.version })
351
357
  }
352
358
 
353
359
  useEffect(() => {
354
360
  if (configs && Object.keys(configs).length > 0 && enableReCaptcha) {
355
- setRecaptchaConfig({
356
- siteKey: configs?.security_recaptcha_site_key?.value || null,
357
- baseUrl: configs?.security_recaptcha_base_url?.value || null
358
- })
361
+ if (configs?.security_recaptcha_type?.value === 'v3' &&
362
+ configs?.security_recaptcha_score_v3?.value > 0 &&
363
+ configs?.security_recaptcha_site_key_v3?.value
364
+ ) {
365
+ setRecaptchaConfig({
366
+ version: 'v3',
367
+ siteKey: configs?.security_recaptcha_site_key_v3?.value || null,
368
+ baseUrl: configs?.security_recaptcha_base_url?.value || null
369
+ })
370
+ return
371
+ }
372
+ if (configs?.security_recaptcha_site_key?.value) {
373
+ setRecaptchaConfig({
374
+ version: 'v2',
375
+ siteKey: configs?.security_recaptcha_site_key?.value || null,
376
+ baseUrl: configs?.security_recaptcha_base_url?.value || null
377
+ })
378
+ }
359
379
  }
360
380
  }, [configs, enableReCaptcha])
361
381
 
362
382
  useEffect(() => {
363
383
  if (!formState.loading && formState.result?.error) {
364
- formState.result?.result &&
365
- showToast(ToastType.Error, formState.result?.result[0]);
384
+ if (formState.result?.result?.[0] === 'ERROR_AUTH_VERIFICATION_CODE') {
385
+ setRecaptchaVerified(false)
386
+ setRecaptchaConfig({
387
+ version: 'v2',
388
+ siteKey: configs?.security_recaptcha_site_key?.value || null,
389
+ baseUrl: configs?.security_recaptcha_base_url?.value || null
390
+ })
391
+ showToast(ToastType.Info, t('TRY_AGAIN', 'Please try again'))
392
+ Vibration.vibrate()
393
+ return
394
+ }
395
+ formState.result?.result && showToast(ToastType.Error, formState.result?.result[0]);
396
+ formState.result?.result && Vibration.vibrate()
366
397
  setIsLoadingVerifyModal(false);
367
398
  }
368
399
  }, [formState]);
@@ -370,6 +401,7 @@ const SignupFormUI = (props: SignupParams) => {
370
401
  useEffect(() => {
371
402
  if (Object.keys(errors).length > 0) {
372
403
  setIsLoadingVerifyModal(false);
404
+ Vibration.vibrate()
373
405
  }
374
406
  }, [errors])
375
407
 
@@ -398,6 +430,7 @@ const SignupFormUI = (props: SignupParams) => {
398
430
  ? verifyPhoneState?.result?.result
399
431
  : verifyPhoneState?.result?.result[0];
400
432
  verifyPhoneState.result?.result && showToast(ToastType.Error, message);
433
+ verifyPhoneState.result?.result && Vibration.vibrate()
401
434
  setIsLoadingVerifyModal(false);
402
435
  return;
403
436
  }
@@ -438,7 +471,6 @@ const SignupFormUI = (props: SignupParams) => {
438
471
  onActionLeft={() => navigation?.canGoBack() && navigation.goBack()}
439
472
  showCall={false}
440
473
  btnStyle={{ paddingLeft: 0 }}
441
- style={{ flexDirection: 'column', alignItems: 'flex-start' }}
442
474
  titleWrapStyle={{ paddingHorizontal: 0 }}
443
475
  titleStyle={{ marginLeft: 0, marginRight: 0 }}
444
476
  />
@@ -610,7 +642,6 @@ const SignupFormUI = (props: SignupParams) => {
610
642
  }
611
643
  })}
612
644
  forwardRef={phoneRef}
613
- defaultCode={formState?.country_code ?? formState?.country_phone_code ?? null}
614
645
  changeCountry={(val: any) => setPhoneInputData({
615
646
  ...phoneInputData,
616
647
  phone: {
@@ -627,36 +658,49 @@ const SignupFormUI = (props: SignupParams) => {
627
658
  </View>
628
659
  )}
629
660
 
630
- {enableReCaptcha && (
661
+ {(enableReCaptcha && recaptchaConfig?.version) && (
631
662
  <>
632
- <TouchableOpacity
633
- onPress={handleOpenRecaptcha}
634
- style={{ marginHorizontal: 4, marginBottom: 10 }}
635
- >
636
- <RecaptchaButton>
637
- {recaptchaVerified ? (
638
- <MaterialCommunityIcons
639
- name="checkbox-marked"
640
- size={23}
641
- color={theme.colors.primary}
642
- />
643
- ) : (
644
- <MaterialCommunityIcons
645
- name="checkbox-blank-outline"
646
- size={23}
647
- color={theme.colors.disabled}
648
- />
649
- )}
650
- <OText size={14} mLeft={8}>{t('VERIFY_ReCAPTCHA', 'Verify reCAPTCHA')}</OText>
651
- </RecaptchaButton>
652
- </TouchableOpacity>
653
- <Recaptcha
654
- ref={recaptchaRef}
655
- siteKey={recaptchaConfig?.siteKey}
656
- baseUrl={recaptchaConfig?.baseUrl}
657
- onVerify={onRecaptchaVerify}
658
- onExpire={() => setRecaptchaVerified(false)}
659
- />
663
+ {recaptchaConfig?.version === 'v3' ? (
664
+ <ReCaptcha
665
+ url={recaptchaConfig?.baseUrl}
666
+ siteKey={recaptchaConfig?.siteKey}
667
+ containerStyle={{ height: 40 }}
668
+ onExecute={onRecaptchaVerify}
669
+ reCaptchaType={1}
670
+ />
671
+ ) : (
672
+ <>
673
+ <TouchableOpacity
674
+ onPress={handleOpenRecaptcha}
675
+ style={{ marginHorizontal: 4, marginBottom: 10 }}
676
+ >
677
+ <RecaptchaButton>
678
+ {recaptchaVerified ? (
679
+ <MaterialCommunityIcons
680
+ name="checkbox-marked"
681
+ size={23}
682
+ color={theme.colors.primary}
683
+ />
684
+ ) : (
685
+ <MaterialCommunityIcons
686
+ name="checkbox-blank-outline"
687
+ size={23}
688
+ color={theme.colors.disabled}
689
+ />
690
+ )}
691
+ <OText size={14} mLeft={8}>{t('VERIFY_ReCAPTCHA', 'Verify reCAPTCHA')}</OText>
692
+ </RecaptchaButton>
693
+ </TouchableOpacity>
694
+ <Recaptcha
695
+ ref={recaptchaRef}
696
+ siteKey={recaptchaConfig?.siteKey}
697
+ baseUrl={recaptchaConfig?.baseUrl}
698
+ onVerify={onRecaptchaVerify}
699
+ onExpire={() => setRecaptchaVerified(false)}
700
+ />
701
+ </>
702
+ )}
703
+
660
704
  </>
661
705
  )}
662
706
  {(signUpTab === 'default') && (
@@ -849,64 +893,65 @@ const SignupFormUI = (props: SignupParams) => {
849
893
  </View>
850
894
  )
851
895
  }
852
- <View
853
- style={{
854
- flexDirection: 'row',
855
- width: '100%',
856
- justifyContent: 'space-between',
857
- alignItems: 'center',
858
- marginVertical: 30,
859
- }}>
860
- <View style={style.line} />
861
- <OText
862
- size={14}
863
- mBottom={10}
864
- style={{ paddingHorizontal: 19 }}
865
- color={theme.colors.disabled}>
866
- {t('OR', 'or')}
867
- </OText>
868
- <View style={style.line} />
869
- </View>
870
-
871
896
  {configs && Object.keys(configs).length > 0 && (
872
- (((configs?.facebook_login?.value === 'true' || configs?.facebook_login?.value === '1') && configs?.facebook_id?.value) ||
873
- (configs?.google_login_client_id?.value !== '' && configs?.google_login_client_id?.value !== null)) &&
897
+ (((configs?.facebook_login?.value === 'true' || configs?.facebook_login?.value === '1') && configs?.facebook_id?.value && facebookLoginEnabled) ||
898
+ ((configs?.google_login_client_id?.value !== '' && configs?.google_login_client_id?.value !== null) && googleLoginEnabled) ||
899
+ ((configs?.apple_login_client_id?.value !== '' && configs?.apple_login_client_id?.value !== null) && appleLoginEnabled)) &&
874
900
  (
875
- <ButtonsWrapper>
876
- <SocialButtons>
877
- {(configs?.facebook_login?.value === 'true' || configs?.facebook_login?.value === '1') &&
878
- configs?.facebook_id?.value &&
879
- facebookLoginEnabled &&
880
- (
881
- <FacebookLogin
901
+ <>
902
+ <View
903
+ style={{
904
+ flexDirection: 'row',
905
+ width: '100%',
906
+ justifyContent: 'space-between',
907
+ alignItems: 'center',
908
+ marginVertical: 30,
909
+ }}>
910
+ <View style={style.line} />
911
+ <OText
912
+ size={14}
913
+ mBottom={10}
914
+ style={{ paddingHorizontal: 19 }}
915
+ color={theme.colors.disabled}>
916
+ {t('OR', 'or')}
917
+ </OText>
918
+ <View style={style.line} />
919
+ </View>
920
+ <ButtonsWrapper>
921
+ <SocialButtons>
922
+ {(configs?.facebook_login?.value === 'true' || configs?.facebook_login?.value === '1') &&
923
+ configs?.facebook_id?.value &&
924
+ facebookLoginEnabled &&
925
+ (
926
+ <FacebookLogin
927
+ notificationState={notificationState}
928
+ handleErrors={(err: any) => { showToast(ToastType.Error, err), Vibration.vibrate() }}
929
+ handleLoading={(val: boolean) => setIsFBLoading(val)}
930
+ handleSuccessFacebookLogin={handleSuccessFacebook}
931
+ />
932
+ )}
933
+ {(configs?.google_login_client_id?.value !== '' && configs?.google_login_client_id?.value !== null) && googleLoginEnabled && (
934
+ <GoogleLogin
882
935
  notificationState={notificationState}
883
- handleErrors={(err: any) => showToast(ToastType.Error, err)}
936
+ webClientId={configs?.google_login_client_id?.value}
937
+ handleErrors={(err: any) => { showToast(ToastType.Error, err), Vibration.vibrate() }}
884
938
  handleLoading={(val: boolean) => setIsFBLoading(val)}
885
- handleSuccessFacebookLogin={handleSuccessFacebook}
939
+ handleSuccessGoogleLogin={handleSuccessFacebook}
886
940
  />
887
941
  )}
888
- {(configs?.google_login_client_id?.value !== '' && configs?.google_login_client_id?.value !== null) && googleLoginEnabled && (
889
- <GoogleLogin
890
- notificationState={notificationState}
891
- webClientId={configs?.google_login_client_id?.value}
892
- handleErrors={(err: any) => showToast(ToastType.Error, err)}
893
- handleLoading={(val: boolean) => setIsFBLoading(val)}
894
- handleSuccessGoogleLogin={handleSuccessFacebook}
895
- />
896
- )}
897
- {(configs?.apple_login_client_id?.value !== '' && configs?.apple_login_client_id?.value !== null) && appleLoginEnabled && (
898
- <AppleLogin
899
- notificationState={notificationState}
900
- handleErrors={(err: any) => showToast(ToastType.Error, err)}
901
- handleLoading={(val: boolean) => setIsFBLoading(val)}
902
- handleSuccessAppleLogin={handleSuccessFacebook}
903
- />
904
- )}
905
- </SocialButtons>
906
- </ButtonsWrapper>
942
+ {(configs?.apple_login_client_id?.value !== '' && configs?.apple_login_client_id?.value !== null) && appleLoginEnabled && (
943
+ <AppleLogin
944
+ notificationState={notificationState}
945
+ handleErrors={(err: any) => { showToast(ToastType.Error, err), Vibration.vibrate() }}
946
+ handleLoading={(val: boolean) => setIsFBLoading(val)}
947
+ handleSuccessAppleLogin={handleSuccessFacebook}
948
+ />
949
+ )}
950
+ </SocialButtons>
951
+ </ButtonsWrapper>
952
+ </>
907
953
  )
908
954
  )}
909
-
910
955
  </FormSide>
911
956
  <OModal
912
957
  open={willVerifyOtpState}