ordering-ui-react-native 0.17.42 → 0.17.43-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.
- package/package.json +8 -7
- package/src/DeliveryApp.tsx +43 -1
- package/src/components/BusinessesListing/index.tsx +1 -1
- package/src/components/OrderCreating/index.tsx +1 -21
- package/src/components/PaymentOptionsWebView/index.tsx +29 -8
- package/src/components/StripeMethodForm/index.tsx +136 -102
- package/src/components/VerifyPhone/styles.tsx +1 -2
- package/src/components/shared/OToast.tsx +4 -4
- package/src/types/index.tsx +5 -0
- package/src/utils/index.tsx +7 -1
- package/themes/business/index.tsx +2 -0
- package/themes/business/src/components/AcceptOrRejectOrder/index.tsx +265 -240
- package/themes/business/src/components/AcceptOrRejectOrder/styles.tsx +6 -4
- package/themes/business/src/components/BusinessController/index.tsx +0 -1
- package/themes/business/src/components/Chat/index.tsx +125 -113
- package/themes/business/src/components/DriverMap/index.tsx +17 -6
- package/themes/business/src/components/GoogleMap/index.tsx +58 -57
- package/themes/business/src/components/LoginForm/Otp/index.tsx +120 -0
- package/themes/business/src/components/LoginForm/Otp/styles.tsx +7 -0
- package/themes/business/src/components/LoginForm/index.tsx +238 -80
- package/themes/business/src/components/LoginForm/styles.tsx +10 -0
- package/themes/business/src/components/MapView/index.tsx +10 -10
- package/themes/business/src/components/NewOrderNotification/index.tsx +49 -50
- package/themes/business/src/components/OrderDetails/Delivery.tsx +4 -3
- package/themes/business/src/components/OrderDetails/OrderContentComponent.tsx +92 -49
- package/themes/business/src/components/OrderDetails/OrderHeaderComponent.tsx +59 -62
- package/themes/business/src/components/OrderDetailsLogistic/index.tsx +195 -0
- package/themes/business/src/components/OrderDetailsLogistic/styles.tsx +5 -0
- package/themes/business/src/components/OrderMessage/index.tsx +18 -17
- package/themes/business/src/components/OrderSummary/index.tsx +113 -121
- package/themes/business/src/components/OrdersOption/index.tsx +32 -75
- package/themes/business/src/components/PreviousOrders/OrderItem.tsx +250 -0
- package/themes/business/src/components/PreviousOrders/OrdersGroupedItem.tsx +115 -0
- package/themes/business/src/components/PreviousOrders/index.tsx +445 -243
- package/themes/business/src/components/PreviousOrders/styles.tsx +31 -3
- package/themes/business/src/components/ProductItemAccordion/index.tsx +27 -3
- package/themes/business/src/components/ReviewCustomer/index.tsx +35 -18
- package/themes/business/src/components/StoresList/index.tsx +2 -2
- package/themes/business/src/components/shared/OLink.tsx +33 -13
- package/themes/business/src/components/shared/OModal.tsx +16 -9
- package/themes/business/src/components/shared/OText.tsx +8 -2
- package/themes/business/src/types/index.tsx +32 -2
- package/themes/business/src/utils/index.tsx +44 -1
- package/themes/doordash/src/components/BusinessesListing/index.tsx +1 -1
- package/themes/doordash/src/components/LoginForm/index.tsx +1 -2
- package/themes/instacart/src/components/BusinessesListing/index.tsx +1 -1
- package/themes/kiosk/src/components/BusinessesListing/index.tsx +2 -1
- package/themes/kiosk/src/components/Checkout/index.tsx +6 -0
- package/themes/kiosk/src/components/LoginForm/Otp/index.tsx +92 -0
- package/themes/kiosk/src/components/LoginForm/Otp/styles.tsx +7 -0
- package/themes/kiosk/src/components/LoginForm/index.tsx +473 -151
- package/themes/kiosk/src/components/LoginForm/styles.tsx +14 -1
- package/themes/kiosk/src/components/NavBar/index.tsx +14 -14
- package/themes/kiosk/src/components/OptionCard/index.tsx +1 -1
- package/themes/kiosk/src/components/OrderTypeCardSelector/index.tsx +8 -10
- package/themes/kiosk/src/components/PhoneInputNumber/index.tsx +3 -2
- package/themes/kiosk/src/components/PhoneInputNumber/styles.tsx +1 -3
- package/themes/kiosk/src/components/ProductForm/index.tsx +1 -14
- package/themes/kiosk/src/components/shared/OButton.tsx +5 -18
- package/themes/kiosk/src/components/shared/OModal.tsx +14 -11
- package/themes/kiosk/src/layouts/Container.tsx +7 -1
- package/themes/kiosk/src/types/index.d.ts +13 -0
- package/themes/kiosk/src/utils/index.tsx +15 -0
- package/themes/original/index.tsx +6 -0
- package/themes/original/src/components/AddressDetails/index.tsx +29 -11
- package/themes/original/src/components/AddressForm/index.tsx +79 -44
- package/themes/original/src/components/AddressList/index.tsx +26 -21
- package/themes/original/src/components/AddressList/styles.tsx +4 -2
- package/themes/original/src/components/AnalyticsSegment/index.tsx +193 -10
- package/themes/original/src/components/AppleLogin/index.tsx +4 -4
- package/themes/original/src/components/BusinessBasicInformation/index.tsx +160 -91
- package/themes/original/src/components/BusinessBasicInformation/styles.tsx +9 -7
- package/themes/original/src/components/BusinessController/index.tsx +141 -67
- package/themes/original/src/components/BusinessController/styles.tsx +22 -2
- package/themes/original/src/components/BusinessFeaturedController/index.tsx +21 -54
- package/themes/original/src/components/BusinessFeaturedController/styles.tsx +8 -0
- package/themes/original/src/components/BusinessInformation/index.tsx +10 -31
- package/themes/original/src/components/BusinessItemAccordion/index.tsx +23 -22
- package/themes/original/src/components/BusinessListingSearch/index.tsx +351 -326
- package/themes/original/src/components/BusinessPreorder/index.tsx +97 -16
- package/themes/original/src/components/BusinessProductsList/index.tsx +20 -11
- package/themes/original/src/components/BusinessProductsList/styles.tsx +8 -3
- package/themes/original/src/components/BusinessProductsListing/UpsellingRedirect.tsx +1 -1
- package/themes/original/src/components/BusinessProductsListing/index.tsx +684 -524
- package/themes/original/src/components/BusinessProductsListing/styles.tsx +2 -4
- package/themes/original/src/components/BusinessReviews/index.tsx +3 -1
- package/themes/original/src/components/BusinessesListing/Layout/Appointment/index.tsx +1 -1
- package/themes/original/src/components/BusinessesListing/Layout/Original/index.tsx +106 -79
- package/themes/original/src/components/BusinessesListing/Layout/Original/styles.tsx +1 -9
- package/themes/original/src/components/BusinessesListing/index.tsx +0 -1
- package/themes/original/src/components/Cart/index.tsx +102 -69
- package/themes/original/src/components/CartContent/index.tsx +115 -19
- package/themes/original/src/components/CartContent/styles.tsx +17 -7
- package/themes/original/src/components/Checkout/index.tsx +375 -179
- package/themes/original/src/components/Checkout/styles.tsx +4 -2
- package/themes/original/src/components/CitiesControl/index.tsx +89 -0
- package/themes/original/src/components/CitiesControl/styles.tsx +17 -0
- package/themes/original/src/components/CouponControl/index.tsx +10 -3
- package/themes/original/src/components/DriverTips/index.tsx +52 -34
- package/themes/original/src/components/Favorite/index.tsx +8 -9
- package/themes/original/src/components/Favorite/styles.tsx +1 -1
- package/themes/original/src/components/FavoriteList/index.tsx +51 -80
- package/themes/original/src/components/FloatingButton/index.tsx +1 -2
- package/themes/original/src/components/FloatingButton/styles.tsx +1 -1
- package/themes/original/src/components/GPSButton/index.tsx +6 -4
- package/themes/original/src/components/GPSButton/styles.ts +3 -3
- package/themes/original/src/components/GiftCard/GiftCardUI/index.tsx +96 -0
- package/themes/original/src/components/GiftCard/GiftCardUI/styles.tsx +5 -0
- package/themes/original/src/components/GiftCard/PurchaseGiftCard/index.tsx +100 -0
- package/themes/original/src/components/GiftCard/PurchaseGiftCard/styles.tsx +8 -0
- package/themes/original/src/components/GiftCard/RedeemGiftCard/index.tsx +191 -0
- package/themes/original/src/components/GiftCard/RedeemGiftCard/styles.tsx +8 -0
- package/themes/original/src/components/GiftCard/SendGiftCard/index.tsx +165 -0
- package/themes/original/src/components/GiftCard/SendGiftCard/styles.tsx +9 -0
- package/themes/original/src/components/GoogleMap/index.tsx +15 -4
- package/themes/original/src/components/Help/index.tsx +8 -8
- package/themes/original/src/components/HelpAccountAndPayment/index.tsx +11 -22
- package/themes/original/src/components/HelpAccountAndPayment/styles.tsx +6 -0
- package/themes/original/src/components/HelpGuide/index.tsx +12 -16
- package/themes/original/src/components/HelpGuide/styles.tsx +6 -0
- package/themes/original/src/components/HelpOrder/index.tsx +12 -25
- package/themes/original/src/components/HelpOrder/styles.tsx +8 -1
- package/themes/original/src/components/Home/index.tsx +13 -4
- package/themes/original/src/components/LastOrder/index.tsx +1 -34
- package/themes/original/src/components/LoginForm/Otp/index.tsx +139 -75
- package/themes/original/src/components/LoginForm/Otp/styles.tsx +0 -1
- package/themes/original/src/components/LoginForm/index.tsx +71 -28
- package/themes/original/src/components/LottieAnimation/index.tsx +89 -55
- package/themes/original/src/components/MessageListing/index.tsx +16 -42
- package/themes/original/src/components/Messages/index.tsx +32 -10
- package/themes/original/src/components/MomentOption/index.tsx +195 -88
- package/themes/original/src/components/MultiCart/index.tsx +50 -0
- package/themes/original/src/components/MultiCartsPaymethodsAndWallets/index.tsx +151 -49
- package/themes/original/src/components/MultiCheckout/index.tsx +308 -88
- package/themes/original/src/components/MultiCheckout/styles.tsx +3 -1
- package/themes/original/src/components/MultiOrdersDetails/SingleOrderCard.tsx +37 -224
- package/themes/original/src/components/MultiOrdersDetails/index.tsx +68 -21
- package/themes/original/src/components/MultiOrdersDetails/styles.tsx +1 -1
- package/themes/original/src/components/MyOrders/index.tsx +53 -51
- package/themes/original/src/components/NavBar/index.tsx +18 -18
- package/themes/original/src/components/NotFoundSource/index.tsx +14 -10
- package/themes/original/src/components/Notifications/index.tsx +46 -50
- package/themes/original/src/components/Notifications/styles.tsx +6 -3
- package/themes/original/src/components/OrderDetails/OrderEta.tsx +76 -0
- package/themes/original/src/components/OrderDetails/OrderHistory.tsx +15 -3
- package/themes/original/src/components/OrderDetails/index.tsx +199 -359
- package/themes/original/src/components/OrderDetails/styles.tsx +0 -1
- package/themes/original/src/components/OrderItAgain/index.tsx +3 -1
- package/themes/original/src/components/OrderProgress/index.tsx +93 -114
- package/themes/original/src/components/OrderProgress/styles.tsx +5 -0
- package/themes/original/src/components/OrderSummary/index.tsx +87 -59
- package/themes/original/src/components/OrderTypeSelector/index.tsx +1 -1
- package/themes/original/src/components/OrdersOption/PreviousBusinessOrdered/index.tsx +24 -19
- package/themes/original/src/components/OrdersOption/PreviousProductsOrdered/index.tsx +14 -14
- package/themes/original/src/components/OrdersOption/index.tsx +70 -65
- package/themes/original/src/components/OrdersOption/styles.tsx +1 -1
- package/themes/original/src/components/PageBanner/index.tsx +171 -0
- package/themes/original/src/components/PageBanner/styles.tsx +11 -0
- package/themes/original/src/components/PaymentOptionCard/index.tsx +180 -0
- package/themes/original/src/components/PaymentOptionStripe/styles.tsx +1 -1
- package/themes/original/src/components/PaymentOptionWallet/index.tsx +56 -56
- package/themes/original/src/components/PaymentOptions/index.tsx +64 -7
- package/themes/original/src/components/PhoneInputNumber/index.tsx +4 -4
- package/themes/original/src/components/PlaceSpot/index.tsx +12 -6
- package/themes/original/src/components/ProductForm/index.tsx +116 -37
- package/themes/original/src/components/ProductForm/styles.tsx +5 -7
- package/themes/original/src/components/ProductItemAccordion/index.tsx +14 -13
- package/themes/original/src/components/ProductOptionSubOption/index.tsx +19 -11
- package/themes/original/src/components/ProductOptionSubOption/styles.tsx +1 -2
- package/themes/original/src/components/ProfessionalFilter/SingleProfessionalCard/index.tsx +108 -0
- package/themes/original/src/components/ProfessionalFilter/index.tsx +20 -50
- package/themes/original/src/components/ProfessionalProfile/index.tsx +36 -7
- package/themes/original/src/components/Promotions/index.tsx +234 -220
- package/themes/original/src/components/Promotions/styles.tsx +10 -3
- package/themes/original/src/components/ReviewDriver/index.tsx +3 -3
- package/themes/original/src/components/ReviewOrder/index.tsx +26 -9
- package/themes/original/src/components/ReviewOrder/styles.tsx +7 -0
- package/themes/original/src/components/ReviewProducts/index.tsx +23 -11
- package/themes/original/src/components/ReviewTrigger/index.tsx +27 -9
- package/themes/original/src/components/ReviewTrigger/styles.tsx +8 -1
- package/themes/original/src/components/ScheduleAccordion/index.tsx +68 -0
- package/themes/original/src/components/ScheduleAccordion/styles.tsx +14 -0
- package/themes/original/src/components/ServiceForm/index.tsx +74 -19
- package/themes/original/src/components/Sessions/index.tsx +11 -8
- package/themes/original/src/components/Sessions/styles.tsx +5 -0
- package/themes/original/src/components/SignupForm/index.tsx +42 -19
- package/themes/original/src/components/SingleOrderCard/index.tsx +130 -52
- package/themes/original/src/components/SingleOrderCard/styles.tsx +11 -2
- package/themes/original/src/components/SingleProductCard/index.tsx +72 -34
- package/themes/original/src/components/SingleProductCard/styles.tsx +22 -4
- package/themes/original/src/components/SingleProductReview/styles.tsx +1 -1
- package/themes/original/src/components/StripeCardsList/index.tsx +13 -3
- package/themes/original/src/components/StripeElementsForm/index.tsx +51 -34
- package/themes/original/src/components/UpsellingProducts/index.tsx +238 -224
- package/themes/original/src/components/UpsellingProducts/styles.tsx +12 -1
- package/themes/original/src/components/UserDetails/index.tsx +8 -4
- package/themes/original/src/components/UserFormDetails/index.tsx +47 -7
- package/themes/original/src/components/UserProfile/index.tsx +5 -7
- package/themes/original/src/components/UserProfileForm/index.tsx +25 -28
- package/themes/original/src/components/UserProfileForm/styles.tsx +7 -0
- package/themes/original/src/components/WalletTransactionItem/index.tsx +2 -2
- package/themes/original/src/components/WalletTransactions/index.tsx +3 -3
- package/themes/original/src/components/Wallets/index.tsx +67 -24
- package/themes/original/src/components/Wallets/styles.tsx +5 -4
- package/themes/original/src/components/shared/HeaderTitle.tsx +8 -3
- package/themes/original/src/components/shared/OButton.tsx +6 -2
- package/themes/original/src/components/shared/OInput.tsx +16 -2
- package/themes/original/src/components/shared/OModal.tsx +3 -3
- package/themes/original/src/layouts/Container.tsx +1 -1
- package/themes/original/src/types/index.tsx +38 -9
- package/themes/original/src/utils/index.tsx +364 -58
- package/themes/uber-eats/src/components/BusinessesListing/index.tsx +1 -1
|
@@ -56,7 +56,7 @@ const ReviewProductsUI = (props: ReviewProductParams) => {
|
|
|
56
56
|
if (order?.driver && !order?.user_review) {
|
|
57
57
|
onNavigationRedirect('ReviewDriver', { order: order })
|
|
58
58
|
} else {
|
|
59
|
-
onNavigationRedirect('MyOrders')
|
|
59
|
+
onNavigationRedirect('BottomTab', { screen: 'MyOrders' })
|
|
60
60
|
}
|
|
61
61
|
}
|
|
62
62
|
}, [formState])
|
|
@@ -67,27 +67,39 @@ const ReviewProductsUI = (props: ReviewProductParams) => {
|
|
|
67
67
|
<NavBar
|
|
68
68
|
title={t('REVIEW_PRODUCT', 'Review product')}
|
|
69
69
|
titleAlign={'center'}
|
|
70
|
-
onActionLeft={() => onNavigationRedirect('MyOrders')}
|
|
70
|
+
onActionLeft={() => onNavigationRedirect('BottomTab', { screen: 'MyOrders' })}
|
|
71
71
|
showCall={false}
|
|
72
72
|
btnStyle={{ paddingLeft: 0 }}
|
|
73
73
|
style={{ flexDirection: 'column', alignItems: 'flex-start' }}
|
|
74
74
|
titleWrapStyle={{ paddingHorizontal: 0 }}
|
|
75
75
|
titleStyle={{ marginRight: 0, marginLeft: 0 }}
|
|
76
76
|
/>
|
|
77
|
-
{order?.products
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
77
|
+
{order?.products && order.products.length > 0 && order?.products.map(productsOrder => (
|
|
78
|
+
productsOrder?.length ? productsOrder?.map((product: any, i: any) => !product?.deleted ?
|
|
79
|
+
<SingleProductReview
|
|
80
|
+
key={i}
|
|
81
|
+
product={product}
|
|
82
|
+
formState={formState}
|
|
83
|
+
handleChangeFormState={handleChangeFormState}
|
|
84
|
+
/> : null
|
|
85
|
+
) : (!productsOrder?.deleted ? (
|
|
86
|
+
<SingleProductReview
|
|
87
|
+
product={productsOrder}
|
|
88
|
+
formState={formState}
|
|
89
|
+
handleChangeFormState={handleChangeFormState}
|
|
90
|
+
/>
|
|
91
|
+
) : null
|
|
92
|
+
)
|
|
84
93
|
))}
|
|
85
94
|
</ReviewProductsContainer>
|
|
86
95
|
|
|
87
96
|
<FloatingBottomContainer>
|
|
88
97
|
<ActionContainer>
|
|
89
98
|
<SkipButton
|
|
90
|
-
onPress={() => (order?.driver && !order?.user_review) ?
|
|
99
|
+
onPress={() => (order?.driver && !order?.user_review) ?
|
|
100
|
+
onNavigationRedirect('ReviewDriver', { order: order }) :
|
|
101
|
+
onNavigationRedirect('BottomTab', { screen: 'MyOrders' })
|
|
102
|
+
}
|
|
91
103
|
>
|
|
92
104
|
<OText weight={700} size={18} color={theme.colors.textNormal}>{t('FRONT_VISUALS_SKIP', 'Skip')}</OText>
|
|
93
105
|
</SkipButton>
|
|
@@ -95,7 +107,7 @@ const ReviewProductsUI = (props: ReviewProductParams) => {
|
|
|
95
107
|
textStyle={{ color: theme.colors.white, paddingRight: 10 }}
|
|
96
108
|
text={order?.driver && !order?.user_review ? t('CONTINUE', 'Continue') : t('SEND_REVIEW', 'Send Review')}
|
|
97
109
|
style={{ borderRadius: 8 }}
|
|
98
|
-
|
|
110
|
+
imgRightSrc={theme.images.general.arrow_right}
|
|
99
111
|
imgRightStyle={{ tintColor: theme.colors.white, right: 5, margin: 5 }}
|
|
100
112
|
isDisabled={formState.loading || formState?.changes?.length === 0}
|
|
101
113
|
onClick={() => handleContinueClick()}
|
|
@@ -8,7 +8,8 @@ import {
|
|
|
8
8
|
FormReviews,
|
|
9
9
|
ActionContainer,
|
|
10
10
|
RatingStarContainer,
|
|
11
|
-
PlacedDate
|
|
11
|
+
PlacedDate,
|
|
12
|
+
MultiLogosContainer
|
|
12
13
|
} from './styles'
|
|
13
14
|
import { OButton, OIcon, OText } from '../shared'
|
|
14
15
|
import { StyleSheet, View, I18nManager } from 'react-native';
|
|
@@ -79,13 +80,30 @@ export const ReviewTrigger = (props: any) => {
|
|
|
79
80
|
<>
|
|
80
81
|
<ReviewOrderContainer>
|
|
81
82
|
<BusinessLogo>
|
|
82
|
-
|
|
83
|
-
<
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
83
|
+
{typeof order?.logo === 'string' || !order?.logo ? (
|
|
84
|
+
<View style={styles.logoWrapper}>
|
|
85
|
+
<OIcon
|
|
86
|
+
url={order?.logo}
|
|
87
|
+
width={80}
|
|
88
|
+
height={80}
|
|
89
|
+
/>
|
|
90
|
+
</View>
|
|
91
|
+
) : (
|
|
92
|
+
<MultiLogosContainer>
|
|
93
|
+
{order?.logo?.map((logo : string, i : number) => (
|
|
94
|
+
<React.Fragment key={logo}>
|
|
95
|
+
<View style={styles.logoWrapper}>
|
|
96
|
+
<OIcon
|
|
97
|
+
url={logo}
|
|
98
|
+
width={80}
|
|
99
|
+
height={80}
|
|
100
|
+
/>
|
|
101
|
+
</View>
|
|
102
|
+
</React.Fragment>
|
|
103
|
+
))}
|
|
104
|
+
</MultiLogosContainer>
|
|
105
|
+
|
|
106
|
+
)}
|
|
89
107
|
</BusinessLogo>
|
|
90
108
|
{!!order?.business_name && <OText style={{ textAlign: 'center', marginTop: 15 }} color={theme.colors.textNormal}>{order?.business_name}</OText>}
|
|
91
109
|
<View style={{ flex: 1, justifyContent: 'flex-end' }}>
|
|
@@ -115,4 +133,4 @@ export const ReviewTrigger = (props: any) => {
|
|
|
115
133
|
</FloatingBottomContainer>
|
|
116
134
|
</>
|
|
117
135
|
)
|
|
118
|
-
}
|
|
136
|
+
}
|
|
@@ -31,4 +31,11 @@ export const RatingStarContainer = styled.View`
|
|
|
31
31
|
`
|
|
32
32
|
export const PlacedDate = styled.View`
|
|
33
33
|
margin-top: 30px;
|
|
34
|
-
`
|
|
34
|
+
`
|
|
35
|
+
|
|
36
|
+
export const MultiLogosContainer = styled.View`
|
|
37
|
+
display: flex;
|
|
38
|
+
justify-content: space-around;
|
|
39
|
+
flex-direction: row;
|
|
40
|
+
width: 100%;
|
|
41
|
+
`
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import React, { useState } from 'react'
|
|
2
|
+
import { Platform, View } from 'react-native'
|
|
3
|
+
import { useLanguage } from 'ordering-components/native';
|
|
4
|
+
import { useTheme } from 'styled-components/native';
|
|
5
|
+
|
|
6
|
+
import {
|
|
7
|
+
Accordion,
|
|
8
|
+
AccordionSection,
|
|
9
|
+
DropdownWrapper,
|
|
10
|
+
} from './styles'
|
|
11
|
+
import { OIcon, OText } from '../shared';
|
|
12
|
+
|
|
13
|
+
export const ScheduleAccordion = (props: any) => {
|
|
14
|
+
|
|
15
|
+
const {
|
|
16
|
+
scheduleFormatted,
|
|
17
|
+
schedule,
|
|
18
|
+
weekIndex
|
|
19
|
+
} = props
|
|
20
|
+
|
|
21
|
+
const [isActive, setActiveState] = useState(false)
|
|
22
|
+
const [, t] = useLanguage()
|
|
23
|
+
const theme = useTheme();
|
|
24
|
+
|
|
25
|
+
const daysOfWeek = [
|
|
26
|
+
t('DAY7', 'Sunday'),
|
|
27
|
+
t('DAY1', 'Monday'),
|
|
28
|
+
t('DAY2', 'Tuesday'),
|
|
29
|
+
t('DAY3', 'Wednesday'),
|
|
30
|
+
t('DAY4', 'Thursday'),
|
|
31
|
+
t('DAY5', 'Friday'),
|
|
32
|
+
t('DAY6', 'Saturday'),
|
|
33
|
+
];
|
|
34
|
+
|
|
35
|
+
return (
|
|
36
|
+
<AccordionSection>
|
|
37
|
+
<Accordion
|
|
38
|
+
onPress={() => setActiveState(!isActive)}
|
|
39
|
+
activeOpacity={1}
|
|
40
|
+
>
|
|
41
|
+
<DropdownWrapper>
|
|
42
|
+
<OText
|
|
43
|
+
mBottom={16}
|
|
44
|
+
mRight={8}
|
|
45
|
+
lineHeight={21}
|
|
46
|
+
size={14}
|
|
47
|
+
weight={Platform.OS === 'android' ? 'bold' : '600'}
|
|
48
|
+
>{daysOfWeek[weekIndex]}</OText>
|
|
49
|
+
<OIcon src={theme.images.general.arrow_down} color={theme.colors.textNormal} width={8} />
|
|
50
|
+
</DropdownWrapper>
|
|
51
|
+
<View style={{ display: isActive ? 'flex' : 'none', paddingStart: 20 }}>
|
|
52
|
+
{schedule?.lapses?.map((lapse: any) => (
|
|
53
|
+
schedule?.enabled ?
|
|
54
|
+
<OText mBottom={16}>
|
|
55
|
+
{scheduleFormatted(lapse.open) +
|
|
56
|
+
' - ' +
|
|
57
|
+
scheduleFormatted(lapse.close)}
|
|
58
|
+
</OText>
|
|
59
|
+
:
|
|
60
|
+
<OText color={theme.colors.red} mBottom={16}>
|
|
61
|
+
{t('CLOSED', 'Closed')}
|
|
62
|
+
</OText>
|
|
63
|
+
))}
|
|
64
|
+
</View>
|
|
65
|
+
</Accordion>
|
|
66
|
+
</AccordionSection>
|
|
67
|
+
)
|
|
68
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import styled from 'styled-components/native'
|
|
2
|
+
|
|
3
|
+
export const AccordionSection = styled.View`
|
|
4
|
+
background: #FFF;
|
|
5
|
+
`
|
|
6
|
+
|
|
7
|
+
export const Accordion = styled.TouchableOpacity`
|
|
8
|
+
flex-direction: column;
|
|
9
|
+
justify-content: space-between;
|
|
10
|
+
`
|
|
11
|
+
|
|
12
|
+
export const DropdownWrapper = styled.View`
|
|
13
|
+
flex-direction: row;
|
|
14
|
+
`
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import React, { useState, useEffect, useRef } from 'react'
|
|
2
2
|
import { useTheme } from 'styled-components/native'
|
|
3
|
-
import { Platform, View, StyleSheet, Dimensions, ScrollView, TouchableOpacity } from 'react-native'
|
|
3
|
+
import { Platform, View, StyleSheet, Dimensions, ScrollView, TouchableOpacity, Text } from 'react-native'
|
|
4
4
|
import { OText, OButton, OModal, OIcon } from '../shared'
|
|
5
5
|
import FastImage from 'react-native-fast-image'
|
|
6
6
|
import IconAntDesign from 'react-native-vector-icons/AntDesign'
|
|
@@ -11,6 +11,8 @@ import FeatherIcon from 'react-native-vector-icons/Feather';
|
|
|
11
11
|
import { useSafeAreaInsets } from 'react-native-safe-area-context'
|
|
12
12
|
import { ServiceFormParams } from '../../types'
|
|
13
13
|
import { Placeholder, PlaceholderLine, Fade } from 'rn-placeholder';
|
|
14
|
+
import uuid from 'react-native-uuid';
|
|
15
|
+
import { orderTypeList } from '../../utils'
|
|
14
16
|
|
|
15
17
|
import {
|
|
16
18
|
ProductForm as ProductFormController,
|
|
@@ -45,7 +47,9 @@ const ServiceFormUI = (props: ServiceFormParams) => {
|
|
|
45
47
|
maxProductQuantity,
|
|
46
48
|
onClose,
|
|
47
49
|
professionalListState,
|
|
48
|
-
isCartProduct
|
|
50
|
+
isCartProduct,
|
|
51
|
+
actionStatus,
|
|
52
|
+
handleCreateGuestUser
|
|
49
53
|
} = props
|
|
50
54
|
|
|
51
55
|
const theme = useTheme()
|
|
@@ -60,11 +64,14 @@ const ServiceFormUI = (props: ServiceFormParams) => {
|
|
|
60
64
|
const [selectDate, setSelectedDate] = useState<any>(new Date())
|
|
61
65
|
const [timeList, setTimeList] = useState<any>([])
|
|
62
66
|
const [isEnabled, setIsEnabled] = useState(false)
|
|
63
|
-
const [timeSelected, setTimeSelected] = useState(null)
|
|
67
|
+
const [timeSelected, setTimeSelected] = useState<string | null>(null)
|
|
64
68
|
const [dateSelected, setDateSelected] = useState<any>(null)
|
|
65
69
|
const [isOpen, setIsOpen] = useState(false)
|
|
66
70
|
const [currentProfessional, setCurrentProfessional] = useState<any>(null)
|
|
67
71
|
|
|
72
|
+
const guestCheckoutEnabled = configs?.guest_checkout_enabled?.value === '1'
|
|
73
|
+
const orderTypeEnabled = !orderTypeList[orderState?.options?.type - 1] || configs?.allowed_order_types_guest_checkout?.value?.includes(orderTypeList[orderState?.options?.type - 1])
|
|
74
|
+
|
|
68
75
|
const dropdownRef = useRef<any>(null)
|
|
69
76
|
|
|
70
77
|
const styles = StyleSheet.create({
|
|
@@ -103,17 +110,41 @@ const ServiceFormUI = (props: ServiceFormParams) => {
|
|
|
103
110
|
height: 40,
|
|
104
111
|
marginBottom: 30
|
|
105
112
|
},
|
|
113
|
+
dropDownRow: {
|
|
114
|
+
color: theme.colors.primary,
|
|
115
|
+
fontSize: 14,
|
|
116
|
+
marginHorizontal: 0
|
|
117
|
+
},
|
|
106
118
|
professionalList: {
|
|
107
119
|
paddingHorizontal: 40,
|
|
108
|
-
paddingVertical: 30
|
|
120
|
+
paddingVertical: 30,
|
|
109
121
|
}
|
|
110
122
|
})
|
|
111
123
|
|
|
112
|
-
const
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
124
|
+
const getMomentTime = (time) => {
|
|
125
|
+
const _moment = moment(`${moment(selectDate).format('YYYY-MM-DD')} ${time}`, 'YYYY-MM-DD HH:mm').toDate()
|
|
126
|
+
return _moment
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
const isBusyTime = (professional, selectedMoment) => {
|
|
130
|
+
if (!selectedMoment) return false
|
|
131
|
+
const startDay = moment(selectedMoment).utc().format('d')
|
|
132
|
+
const isStartScheduleEnabled = professional?.schedule?.[startDay]?.enabled
|
|
133
|
+
const duration = product?.duration ?? 0
|
|
134
|
+
const endDay = moment(selectedMoment).add(duration - 1, 'minutes').utc().format('d')
|
|
135
|
+
const isEndScheduleEnabled = professional?.schedule?.[endDay]?.enabled
|
|
136
|
+
if (!isStartScheduleEnabled || !isEndScheduleEnabled) return true
|
|
137
|
+
|
|
138
|
+
if (professional?.busy_times?.length === 0) return false
|
|
139
|
+
|
|
140
|
+
const busyTimes = isCartProduct
|
|
141
|
+
? professional?.busy_times.filter(item => !(item.start === productCart?.calendar_event?.start && item.end === productCart?.calendar_event?.end))
|
|
142
|
+
: [...professional?.busy_times]
|
|
143
|
+
const valid = busyTimes.some(item => {
|
|
144
|
+
return (moment.utc(item?.start).local().valueOf() <= moment(selectedMoment).valueOf() &&
|
|
145
|
+
moment(selectedMoment).valueOf() < moment.utc(item?.end).local().valueOf()) ||
|
|
146
|
+
(moment.utc(item?.start).local().valueOf() < moment(selectedMoment).add(duration, 'minutes').valueOf() &&
|
|
147
|
+
moment(selectedMoment).add(duration, 'minutes').valueOf() < moment.utc(item?.end).local().valueOf())
|
|
117
148
|
})
|
|
118
149
|
return valid
|
|
119
150
|
}
|
|
@@ -134,6 +165,11 @@ const ServiceFormUI = (props: ServiceFormParams) => {
|
|
|
134
165
|
)
|
|
135
166
|
}
|
|
136
167
|
|
|
168
|
+
const handleUpdateGuest = () => {
|
|
169
|
+
const guestToken = uuid.v4()
|
|
170
|
+
if (guestToken) handleCreateGuestUser({ guest_token: guestToken })
|
|
171
|
+
}
|
|
172
|
+
|
|
137
173
|
const customDayHeaderStylesCallback = () => {
|
|
138
174
|
return {
|
|
139
175
|
textStyle: {
|
|
@@ -248,6 +284,12 @@ const ServiceFormUI = (props: ServiceFormParams) => {
|
|
|
248
284
|
setCurrentProfessional(professional)
|
|
249
285
|
}
|
|
250
286
|
}, [isCartProduct, professionalListState?.professionals])
|
|
287
|
+
|
|
288
|
+
useEffect(() => {
|
|
289
|
+
if (!productCart?.calendar_event?.start) return
|
|
290
|
+
setSelectedDate(moment.utc(productCart?.calendar_event?.start).local())
|
|
291
|
+
setTimeSelected(moment.utc(productCart?.calendar_event?.start).local().format('HH:mm'))
|
|
292
|
+
}, [productCart])
|
|
251
293
|
|
|
252
294
|
return (
|
|
253
295
|
<>
|
|
@@ -359,9 +401,9 @@ const ServiceFormUI = (props: ServiceFormParams) => {
|
|
|
359
401
|
size={12}
|
|
360
402
|
weight={'400'}
|
|
361
403
|
lineHeight={17}
|
|
362
|
-
color={isBusyTime(currentProfessional) ? theme.colors.danger5 : theme.colors.success500}
|
|
404
|
+
color={isBusyTime(currentProfessional, dateSelected) ? theme.colors.danger5 : theme.colors.success500}
|
|
363
405
|
>
|
|
364
|
-
{isBusyTime(currentProfessional)
|
|
406
|
+
{isBusyTime(currentProfessional, dateSelected)
|
|
365
407
|
? t('BUSY_ON_SELECTED_TIME', 'Busy on selected time')
|
|
366
408
|
: t('AVAILABLE', 'Available')
|
|
367
409
|
}
|
|
@@ -409,7 +451,7 @@ const ServiceFormUI = (props: ServiceFormParams) => {
|
|
|
409
451
|
{(timeList?.length > 0 && isEnabled) ? (
|
|
410
452
|
<SelectDropdown
|
|
411
453
|
ref={dropdownRef}
|
|
412
|
-
|
|
454
|
+
defaultValueByIndex={timeList.findIndex((item: any) => item.value === timeSelected)}
|
|
413
455
|
data={timeList}
|
|
414
456
|
onSelect={(selectedItem, index) => {
|
|
415
457
|
setTimeSelected(selectedItem?.value)
|
|
@@ -441,10 +483,12 @@ const ServiceFormUI = (props: ServiceFormParams) => {
|
|
|
441
483
|
paddingTop: 8,
|
|
442
484
|
paddingHorizontal: 12
|
|
443
485
|
}}
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
486
|
+
renderCustomizedRowChild={(item, index) => {
|
|
487
|
+
return (
|
|
488
|
+
<Text style={[styles.dropDownRow, { color: isBusyTime(currentProfessional, getMomentTime(item.value)) ? theme.colors.lightGray : theme.colors.primary } ]}>
|
|
489
|
+
{item.text}
|
|
490
|
+
</Text>
|
|
491
|
+
)
|
|
448
492
|
}}
|
|
449
493
|
renderDropdownIcon={() => dropDownIcon()}
|
|
450
494
|
dropdownOverlayColor='transparent'
|
|
@@ -517,7 +561,7 @@ const ServiceFormUI = (props: ServiceFormParams) => {
|
|
|
517
561
|
? t('SOLD_OUT', 'Sold out')
|
|
518
562
|
: t('BOOK', 'Book'))}
|
|
519
563
|
style={styles.buttonStyle}
|
|
520
|
-
isDisabled={isSoldOut || maxProductQuantity <= 0 || !currentProfessional?.id || !dateSelected}
|
|
564
|
+
isDisabled={isSoldOut || maxProductQuantity <= 0 || !currentProfessional?.id || !dateSelected || isBusyTime(currentProfessional, dateSelected)}
|
|
521
565
|
textStyle={{ fontSize: 14, color: theme.colors.white }}
|
|
522
566
|
/>
|
|
523
567
|
)}
|
|
@@ -551,6 +595,17 @@ const ServiceFormUI = (props: ServiceFormParams) => {
|
|
|
551
595
|
}}
|
|
552
596
|
/>
|
|
553
597
|
)}
|
|
598
|
+
{!auth && guestCheckoutEnabled && orderTypeEnabled && (
|
|
599
|
+
<TouchableOpacity style={{ marginTop: 10 }} onPress={handleUpdateGuest}>
|
|
600
|
+
{actionStatus?.loading ? (
|
|
601
|
+
<Placeholder Animation={Fade}>
|
|
602
|
+
<PlaceholderLine width={60} height={20} />
|
|
603
|
+
</Placeholder>
|
|
604
|
+
) : (
|
|
605
|
+
<OText color={theme.colors.primary} size={13}>{t('WITH_GUEST_USER', 'With Guest user')}</OText>
|
|
606
|
+
)}
|
|
607
|
+
</TouchableOpacity>
|
|
608
|
+
)}
|
|
554
609
|
</ButtonWrapper>
|
|
555
610
|
</Container>
|
|
556
611
|
)}
|
|
@@ -604,9 +659,9 @@ const ServiceFormUI = (props: ServiceFormParams) => {
|
|
|
604
659
|
size={12}
|
|
605
660
|
weight={'400'}
|
|
606
661
|
lineHeight={17}
|
|
607
|
-
color={isBusyTime(professional) ? theme.colors.danger5 : theme.colors.success500}
|
|
662
|
+
color={isBusyTime(professional, dateSelected) ? theme.colors.danger5 : theme.colors.success500}
|
|
608
663
|
>
|
|
609
|
-
{isBusyTime(professional)
|
|
664
|
+
{isBusyTime(professional, dateSelected)
|
|
610
665
|
? t('BUSY_ON_SELECTED_TIME', 'Busy on selected time')
|
|
611
666
|
: t('AVAILABLE', 'Available')
|
|
612
667
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React, { useState } from 'react'
|
|
2
|
-
import { View, TouchableOpacity } from 'react-native'
|
|
2
|
+
import { View, TouchableOpacity, Platform } from 'react-native'
|
|
3
3
|
import { useLanguage, useSession, useUtils, Sessions as SessionsController } from 'ordering-components/native'
|
|
4
4
|
import NavBar from '../NavBar'
|
|
5
5
|
import { SessionsParams } from '../../types'
|
|
@@ -12,7 +12,8 @@ import AntIcon from 'react-native-vector-icons/AntDesign'
|
|
|
12
12
|
import {
|
|
13
13
|
SessionsWrapper,
|
|
14
14
|
SessionItem,
|
|
15
|
-
DurationWrapper
|
|
15
|
+
DurationWrapper,
|
|
16
|
+
Container
|
|
16
17
|
} from './styles'
|
|
17
18
|
|
|
18
19
|
export const SessionsUI = (props: SessionsParams) => {
|
|
@@ -27,7 +28,7 @@ export const SessionsUI = (props: SessionsParams) => {
|
|
|
27
28
|
const [, t] = useLanguage()
|
|
28
29
|
const [{ user }] = useSession()
|
|
29
30
|
const [{ parseDate }] = useUtils()
|
|
30
|
-
|
|
31
|
+
const theme = useTheme()
|
|
31
32
|
const [confirm, setConfirm] = useState<any>({ open: false, content: null, handleOnAccept: null, id: null, title: null })
|
|
32
33
|
const goToBack = () => navigation?.canGoBack() && navigation.goBack()
|
|
33
34
|
|
|
@@ -61,7 +62,9 @@ export const SessionsUI = (props: SessionsParams) => {
|
|
|
61
62
|
}
|
|
62
63
|
|
|
63
64
|
return (
|
|
64
|
-
|
|
65
|
+
<Container
|
|
66
|
+
pdng={Platform.OS === 'ios' ? '10px' : '0'}
|
|
67
|
+
>
|
|
65
68
|
<NavBar
|
|
66
69
|
title={t('SESSIONS', 'Sessions')}
|
|
67
70
|
titleAlign={'center'}
|
|
@@ -77,11 +80,11 @@ export const SessionsUI = (props: SessionsParams) => {
|
|
|
77
80
|
<SessionItem key={i}>
|
|
78
81
|
<Placeholder Animation={Fade}>
|
|
79
82
|
<View style={{ flexDirection: 'row', alignItems: 'center' }}>
|
|
80
|
-
<View style={{ flex: 1}}>
|
|
83
|
+
<View style={{ flex: 1 }}>
|
|
81
84
|
<PlaceholderLine width={40} />
|
|
82
85
|
<PlaceholderLine width={40} />
|
|
83
86
|
</View>
|
|
84
|
-
<PlaceholderLine width={5}/>
|
|
87
|
+
<PlaceholderLine width={5} />
|
|
85
88
|
</View>
|
|
86
89
|
</Placeholder>
|
|
87
90
|
</SessionItem>
|
|
@@ -120,7 +123,7 @@ export const SessionsUI = (props: SessionsParams) => {
|
|
|
120
123
|
style={{ borderRadius: 7.6, marginTop: 20 }}
|
|
121
124
|
/>
|
|
122
125
|
</SessionsWrapper>
|
|
123
|
-
|
|
126
|
+
) : (
|
|
124
127
|
<OText>{t('YOU_DONT_HAVE_ANY_SESSIONS', 'You don\'t have any sessions')}</OText>
|
|
125
128
|
)
|
|
126
129
|
)}
|
|
@@ -147,7 +150,7 @@ export const SessionsUI = (props: SessionsParams) => {
|
|
|
147
150
|
onCancel={() => setConfirm({ ...confirm, open: false, title: null })}
|
|
148
151
|
onClose={() => setConfirm({ ...confirm, open: false, title: null })}
|
|
149
152
|
/>
|
|
150
|
-
|
|
153
|
+
</Container>
|
|
151
154
|
)
|
|
152
155
|
}
|
|
153
156
|
|
|
@@ -8,6 +8,7 @@ import { PhoneInputNumber } from '../PhoneInputNumber';
|
|
|
8
8
|
import { FacebookLogin } from '../FacebookLogin';
|
|
9
9
|
import Recaptcha from 'react-native-recaptcha-that-works'
|
|
10
10
|
import ReCaptcha from '@fatnlazycat/react-native-recaptcha-v3'
|
|
11
|
+
import ReactNativeHapticFeedback from "react-native-haptic-feedback";
|
|
11
12
|
|
|
12
13
|
import {
|
|
13
14
|
SignupForm as SignUpController,
|
|
@@ -83,7 +84,8 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
83
84
|
signUpTab,
|
|
84
85
|
useSignUpFullDetails,
|
|
85
86
|
useSignUpOtpEmail,
|
|
86
|
-
useSignUpOtpCellphone
|
|
87
|
+
useSignUpOtpCellphone,
|
|
88
|
+
isGuest
|
|
87
89
|
} = props;
|
|
88
90
|
|
|
89
91
|
const theme = useTheme();
|
|
@@ -163,6 +165,14 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
163
165
|
})
|
|
164
166
|
}
|
|
165
167
|
|
|
168
|
+
const vibrateApp = (impact?: string) => {
|
|
169
|
+
const options = {
|
|
170
|
+
enableVibrateFallback: true,
|
|
171
|
+
ignoreAndroidSystemSettings: false
|
|
172
|
+
};
|
|
173
|
+
ReactNativeHapticFeedback.trigger(impact || "impactLight", options);
|
|
174
|
+
}
|
|
175
|
+
|
|
166
176
|
const handleRefs = (ref: any, code: string) => {
|
|
167
177
|
switch (code) {
|
|
168
178
|
case 'name': {
|
|
@@ -245,6 +255,7 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
245
255
|
const onSubmit = (values?: any) => {
|
|
246
256
|
if (phoneInputData.error && signUpTab !== 'otpEmail') {
|
|
247
257
|
showToast(ToastType.Error, phoneInputData.error);
|
|
258
|
+
vibrateApp()
|
|
248
259
|
return;
|
|
249
260
|
}
|
|
250
261
|
if (
|
|
@@ -262,6 +273,7 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
262
273
|
'The field Mobile phone is required.',
|
|
263
274
|
),
|
|
264
275
|
);
|
|
276
|
+
vibrateApp()
|
|
265
277
|
return;
|
|
266
278
|
}
|
|
267
279
|
if (signUpTab === 'otpEmail' || signUpTab === 'otpCellphone') {
|
|
@@ -320,7 +332,7 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
320
332
|
};
|
|
321
333
|
|
|
322
334
|
const handleChangeInputEmail = (value: string, onChange: any) => {
|
|
323
|
-
onChange(value.toLowerCase().replace(/[&,()%";:ç?<>{}\\[\]\s]/g, ''));
|
|
335
|
+
onChange(value.toLowerCase().trim().replace(/[&,()%";:ç?<>{}\\[\]\s]/g, ''));
|
|
324
336
|
};
|
|
325
337
|
|
|
326
338
|
const handleOpenTermsUrl = async (url: any) => {
|
|
@@ -330,6 +342,7 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
330
342
|
await Linking.openURL(url);
|
|
331
343
|
} else {
|
|
332
344
|
showToast(ToastType.Error, t('VALIDATION_ERROR_ACTIVE_URL', 'The _attribute_ is not a valid URL.').replace('_attribute_', t('URL', 'URL')))
|
|
345
|
+
vibrateApp()
|
|
333
346
|
}
|
|
334
347
|
}
|
|
335
348
|
|
|
@@ -337,10 +350,12 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
337
350
|
setRecaptchaVerified(false)
|
|
338
351
|
if (!recaptchaConfig?.siteKey) {
|
|
339
352
|
showToast(ToastType.Error, t('NO_RECAPTCHA_SITE_KEY', 'The config doesn\'t have recaptcha site key'));
|
|
353
|
+
vibrateApp()
|
|
340
354
|
return
|
|
341
355
|
}
|
|
342
356
|
if (!recaptchaConfig?.baseUrl) {
|
|
343
357
|
showToast(ToastType.Error, t('NO_RECAPTCHA_BASE_URL', 'The config doesn\'t have recaptcha base url'));
|
|
358
|
+
vibrateApp()
|
|
344
359
|
return
|
|
345
360
|
}
|
|
346
361
|
recaptchaRef.current.open()
|
|
@@ -384,10 +399,13 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
384
399
|
baseUrl: configs?.security_recaptcha_base_url?.value || null
|
|
385
400
|
})
|
|
386
401
|
showToast(ToastType.Info, t('TRY_AGAIN', 'Please try again'))
|
|
402
|
+
vibrateApp()
|
|
387
403
|
return
|
|
388
404
|
}
|
|
389
|
-
formState.result?.result &&
|
|
390
|
-
showToast(ToastType.Error, formState.result?.result[0])
|
|
405
|
+
formState.result?.result && formState.result?.result[0]?.includes("_") ?
|
|
406
|
+
showToast(ToastType.Error, t(`${formState.result?.result[0]}`, 'Phone number already used')) :
|
|
407
|
+
showToast(ToastType.Error, formState.result?.result[0])
|
|
408
|
+
formState.result?.result && vibrateApp()
|
|
391
409
|
setIsLoadingVerifyModal(false);
|
|
392
410
|
}
|
|
393
411
|
}, [formState]);
|
|
@@ -395,6 +413,7 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
395
413
|
useEffect(() => {
|
|
396
414
|
if (Object.keys(errors).length > 0) {
|
|
397
415
|
setIsLoadingVerifyModal(false);
|
|
416
|
+
vibrateApp()
|
|
398
417
|
}
|
|
399
418
|
}, [errors])
|
|
400
419
|
|
|
@@ -423,6 +442,7 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
423
442
|
? verifyPhoneState?.result?.result
|
|
424
443
|
: verifyPhoneState?.result?.result[0];
|
|
425
444
|
verifyPhoneState.result?.result && showToast(ToastType.Error, message);
|
|
445
|
+
verifyPhoneState.result?.result && vibrateApp()
|
|
426
446
|
setIsLoadingVerifyModal(false);
|
|
427
447
|
return;
|
|
428
448
|
}
|
|
@@ -457,16 +477,19 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
457
477
|
|
|
458
478
|
return (
|
|
459
479
|
<View>
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
480
|
+
{isGuest ? (
|
|
481
|
+
<OText style={{ textAlign: 'center', marginBottom: 10 }} size={18}>{t('SIGNUP', 'Signup')}</OText>
|
|
482
|
+
) : (
|
|
483
|
+
<NavBar
|
|
484
|
+
title={t('SIGNUP', 'Signup')}
|
|
485
|
+
titleAlign={'center'}
|
|
486
|
+
onActionLeft={() => navigation?.canGoBack() && navigation.goBack()}
|
|
487
|
+
showCall={false}
|
|
488
|
+
btnStyle={{ paddingLeft: 0 }}
|
|
489
|
+
titleWrapStyle={{ paddingHorizontal: 0 }}
|
|
490
|
+
titleStyle={{ marginLeft: 0, marginRight: 0 }}
|
|
491
|
+
/>
|
|
492
|
+
)}
|
|
470
493
|
<FormSide>
|
|
471
494
|
{((Number(useSignUpFullDetails) + Number(useSignUpOtpEmail) + Number(useSignUpOtpCellphone)) > 1) && (
|
|
472
495
|
<SignupWith>
|
|
@@ -579,7 +602,7 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
579
602
|
control={control}
|
|
580
603
|
render={({ onChange, value }: any) => (
|
|
581
604
|
<OInput
|
|
582
|
-
placeholder={t(field.name)}
|
|
605
|
+
placeholder={t(field.name?.replace(/\s/g, '_')?.toUpperCase(), field.name)}
|
|
583
606
|
style={style.inputStyle}
|
|
584
607
|
icon={
|
|
585
608
|
field.code === 'email'
|
|
@@ -886,7 +909,7 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
886
909
|
</View>
|
|
887
910
|
)
|
|
888
911
|
}
|
|
889
|
-
{configs && Object.keys(configs).length > 0 && (
|
|
912
|
+
{configs && Object.keys(configs).length > 0 && !isGuest && (
|
|
890
913
|
(((configs?.facebook_login?.value === 'true' || configs?.facebook_login?.value === '1') && configs?.facebook_id?.value && facebookLoginEnabled) ||
|
|
891
914
|
((configs?.google_login_client_id?.value !== '' && configs?.google_login_client_id?.value !== null) && googleLoginEnabled) ||
|
|
892
915
|
((configs?.apple_login_client_id?.value !== '' && configs?.apple_login_client_id?.value !== null) && appleLoginEnabled)) &&
|
|
@@ -918,7 +941,7 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
918
941
|
(
|
|
919
942
|
<FacebookLogin
|
|
920
943
|
notificationState={notificationState}
|
|
921
|
-
handleErrors={(err: any) => showToast(ToastType.Error, err)}
|
|
944
|
+
handleErrors={(err: any) => { showToast(ToastType.Error, err), vibrateApp() }}
|
|
922
945
|
handleLoading={(val: boolean) => setIsFBLoading(val)}
|
|
923
946
|
handleSuccessFacebookLogin={handleSuccessFacebook}
|
|
924
947
|
/>
|
|
@@ -927,7 +950,7 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
927
950
|
<GoogleLogin
|
|
928
951
|
notificationState={notificationState}
|
|
929
952
|
webClientId={configs?.google_login_client_id?.value}
|
|
930
|
-
handleErrors={(err: any) => showToast(ToastType.Error, err)}
|
|
953
|
+
handleErrors={(err: any) => { showToast(ToastType.Error, err), vibrateApp() }}
|
|
931
954
|
handleLoading={(val: boolean) => setIsFBLoading(val)}
|
|
932
955
|
handleSuccessGoogleLogin={handleSuccessFacebook}
|
|
933
956
|
/>
|
|
@@ -935,7 +958,7 @@ const SignupFormUI = (props: SignupParams) => {
|
|
|
935
958
|
{(configs?.apple_login_client_id?.value !== '' && configs?.apple_login_client_id?.value !== null) && appleLoginEnabled && (
|
|
936
959
|
<AppleLogin
|
|
937
960
|
notificationState={notificationState}
|
|
938
|
-
handleErrors={(err: any) => showToast(ToastType.Error, err)}
|
|
961
|
+
handleErrors={(err: any) => { showToast(ToastType.Error, err), vibrateApp() }}
|
|
939
962
|
handleLoading={(val: boolean) => setIsFBLoading(val)}
|
|
940
963
|
handleSuccessAppleLogin={handleSuccessFacebook}
|
|
941
964
|
/>
|