ordering-ui-react-native 0.17.9 → 0.17.10-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 (214) hide show
  1. package/package.json +5 -5
  2. package/src/DeliveryApp.tsx +43 -1
  3. package/src/components/BusinessInformation/index.tsx +11 -4
  4. package/src/components/BusinessInformation/styles.tsx +2 -2
  5. package/src/components/BusinessesListing/index.tsx +1 -1
  6. package/src/components/OrderCreating/index.tsx +1 -21
  7. package/src/components/PaymentOptionsWebView/index.tsx +119 -120
  8. package/src/components/SingleProductReview/index.tsx +0 -24
  9. package/src/components/SingleProductReview/styles.tsx +0 -12
  10. package/src/components/StripeMethodForm/index.tsx +6 -14
  11. package/src/components/VerifyPhone/styles.tsx +1 -2
  12. package/src/components/shared/OToast.tsx +4 -4
  13. package/src/utils/index.tsx +7 -1
  14. package/themes/business/index.tsx +2 -0
  15. package/themes/business/src/components/AcceptOrRejectOrder/index.tsx +265 -240
  16. package/themes/business/src/components/AcceptOrRejectOrder/styles.tsx +6 -4
  17. package/themes/business/src/components/BusinessController/index.tsx +0 -1
  18. package/themes/business/src/components/Chat/index.tsx +118 -107
  19. package/themes/business/src/components/DriverMap/index.tsx +22 -9
  20. package/themes/business/src/components/GoogleMap/index.tsx +58 -57
  21. package/themes/business/src/components/LoginForm/Otp/index.tsx +120 -0
  22. package/themes/business/src/components/LoginForm/Otp/styles.tsx +7 -0
  23. package/themes/business/src/components/LoginForm/index.tsx +238 -80
  24. package/themes/business/src/components/LoginForm/styles.tsx +10 -0
  25. package/themes/business/src/components/MapView/index.tsx +18 -7
  26. package/themes/business/src/components/NewOrderNotification/index.tsx +43 -50
  27. package/themes/business/src/components/OrderDetails/Delivery.tsx +4 -3
  28. package/themes/business/src/components/OrderDetails/OrderContentComponent.tsx +98 -50
  29. package/themes/business/src/components/OrderDetails/OrderHeaderComponent.tsx +59 -62
  30. package/themes/business/src/components/OrderDetailsLogistic/index.tsx +195 -0
  31. package/themes/business/src/components/OrderDetailsLogistic/styles.tsx +5 -0
  32. package/themes/business/src/components/OrderMessage/index.tsx +18 -17
  33. package/themes/business/src/components/OrderSummary/index.tsx +113 -121
  34. package/themes/business/src/components/OrdersOption/index.tsx +32 -75
  35. package/themes/business/src/components/PreviousOrders/OrderItem.tsx +250 -0
  36. package/themes/business/src/components/PreviousOrders/OrdersGroupedItem.tsx +115 -0
  37. package/themes/business/src/components/PreviousOrders/index.tsx +445 -243
  38. package/themes/business/src/components/PreviousOrders/styles.tsx +31 -3
  39. package/themes/business/src/components/ProductItemAccordion/index.tsx +27 -3
  40. package/themes/business/src/components/ReviewCustomer/index.tsx +41 -24
  41. package/themes/business/src/components/StoresList/index.tsx +2 -2
  42. package/themes/business/src/components/shared/OLink.tsx +33 -13
  43. package/themes/business/src/components/shared/OModal.tsx +16 -9
  44. package/themes/business/src/components/shared/OText.tsx +8 -2
  45. package/themes/business/src/types/index.tsx +33 -2
  46. package/themes/business/src/utils/index.tsx +51 -0
  47. package/themes/doordash/src/components/BusinessesListing/index.tsx +1 -1
  48. package/themes/doordash/src/components/LoginForm/index.tsx +1 -2
  49. package/themes/instacart/src/components/BusinessesListing/index.tsx +1 -1
  50. package/themes/kiosk/src/components/BusinessesListing/index.tsx +2 -1
  51. package/themes/kiosk/src/components/Checkout/index.tsx +6 -0
  52. package/themes/kiosk/src/components/LoginForm/Otp/index.tsx +92 -0
  53. package/themes/kiosk/src/components/LoginForm/Otp/styles.tsx +7 -0
  54. package/themes/kiosk/src/components/LoginForm/index.tsx +473 -151
  55. package/themes/kiosk/src/components/LoginForm/styles.tsx +14 -1
  56. package/themes/kiosk/src/components/NavBar/index.tsx +14 -14
  57. package/themes/kiosk/src/components/OptionCard/index.tsx +1 -1
  58. package/themes/kiosk/src/components/OrderTypeCardSelector/index.tsx +8 -10
  59. package/themes/kiosk/src/components/PhoneInputNumber/index.tsx +3 -2
  60. package/themes/kiosk/src/components/PhoneInputNumber/styles.tsx +1 -3
  61. package/themes/kiosk/src/components/ProductForm/index.tsx +1 -14
  62. package/themes/kiosk/src/components/shared/OButton.tsx +5 -18
  63. package/themes/kiosk/src/components/shared/OModal.tsx +14 -11
  64. package/themes/kiosk/src/layouts/Container.tsx +7 -1
  65. package/themes/kiosk/src/types/index.d.ts +13 -0
  66. package/themes/kiosk/src/utils/index.tsx +15 -0
  67. package/themes/original/index.tsx +8 -0
  68. package/themes/original/src/components/AddressDetails/index.tsx +29 -11
  69. package/themes/original/src/components/AddressForm/index.tsx +41 -16
  70. package/themes/original/src/components/AddressList/index.tsx +26 -21
  71. package/themes/original/src/components/AddressList/styles.tsx +4 -2
  72. package/themes/original/src/components/AnalyticsSegment/index.tsx +189 -9
  73. package/themes/original/src/components/AppleLogin/index.tsx +4 -4
  74. package/themes/original/src/components/BusinessBasicInformation/index.tsx +125 -82
  75. package/themes/original/src/components/BusinessBasicInformation/styles.tsx +9 -4
  76. package/themes/original/src/components/BusinessController/index.tsx +145 -68
  77. package/themes/original/src/components/BusinessController/styles.tsx +22 -9
  78. package/themes/original/src/components/BusinessFeaturedController/index.tsx +21 -54
  79. package/themes/original/src/components/BusinessFeaturedController/styles.tsx +8 -0
  80. package/themes/original/src/components/BusinessInformation/index.tsx +10 -31
  81. package/themes/original/src/components/BusinessItemAccordion/index.tsx +24 -23
  82. package/themes/original/src/components/BusinessListingSearch/index.tsx +52 -24
  83. package/themes/original/src/components/BusinessPreorder/index.tsx +97 -16
  84. package/themes/original/src/components/BusinessProductsList/index.tsx +20 -11
  85. package/themes/original/src/components/BusinessProductsList/styles.tsx +8 -3
  86. package/themes/original/src/components/BusinessProductsListing/index.tsx +617 -492
  87. package/themes/original/src/components/BusinessProductsListing/styles.tsx +7 -13
  88. package/themes/original/src/components/BusinessReviews/index.tsx +3 -1
  89. package/themes/original/src/components/BusinessTypeFilter/index.tsx +3 -3
  90. package/themes/original/src/components/BusinessesListing/Layout/Appointment/index.tsx +1 -1
  91. package/themes/original/src/components/BusinessesListing/Layout/Original/index.tsx +98 -78
  92. package/themes/original/src/components/BusinessesListing/Layout/Original/styles.tsx +1 -9
  93. package/themes/original/src/components/BusinessesListing/index.tsx +5 -3
  94. package/themes/original/src/components/Cart/index.tsx +88 -43
  95. package/themes/original/src/components/CartContent/index.tsx +110 -19
  96. package/themes/original/src/components/CartContent/styles.tsx +15 -1
  97. package/themes/original/src/components/Checkout/index.tsx +311 -178
  98. package/themes/original/src/components/Checkout/styles.tsx +4 -2
  99. package/themes/original/src/components/CitiesControl/index.tsx +89 -0
  100. package/themes/original/src/components/CitiesControl/styles.tsx +17 -0
  101. package/themes/original/src/components/CouponControl/index.tsx +10 -3
  102. package/themes/original/src/components/DriverTips/index.tsx +52 -37
  103. package/themes/original/src/components/DriverTips/styles.tsx +2 -1
  104. package/themes/original/src/components/Favorite/index.tsx +7 -4
  105. package/themes/original/src/components/Favorite/styles.tsx +1 -1
  106. package/themes/original/src/components/FavoriteList/index.tsx +51 -80
  107. package/themes/original/src/components/FloatingButton/index.tsx +1 -2
  108. package/themes/original/src/components/FloatingButton/styles.tsx +1 -1
  109. package/themes/original/src/components/GPSButton/styles.ts +3 -3
  110. package/themes/original/src/components/GiftCard/GiftCardUI/index.tsx +96 -0
  111. package/themes/original/src/components/GiftCard/GiftCardUI/styles.tsx +5 -0
  112. package/themes/original/src/components/GiftCard/PurchaseGiftCard/index.tsx +100 -0
  113. package/themes/original/src/components/GiftCard/PurchaseGiftCard/styles.tsx +8 -0
  114. package/themes/original/src/components/GiftCard/RedeemGiftCard/index.tsx +178 -0
  115. package/themes/original/src/components/GiftCard/RedeemGiftCard/styles.tsx +8 -0
  116. package/themes/original/src/components/GiftCard/SendGiftCard/index.tsx +165 -0
  117. package/themes/original/src/components/GiftCard/SendGiftCard/styles.tsx +9 -0
  118. package/themes/original/src/components/Help/index.tsx +8 -8
  119. package/themes/original/src/components/HelpAccountAndPayment/index.tsx +11 -22
  120. package/themes/original/src/components/HelpAccountAndPayment/styles.tsx +6 -0
  121. package/themes/original/src/components/HelpGuide/index.tsx +12 -16
  122. package/themes/original/src/components/HelpGuide/styles.tsx +6 -0
  123. package/themes/original/src/components/HelpOrder/index.tsx +12 -25
  124. package/themes/original/src/components/HelpOrder/styles.tsx +8 -1
  125. package/themes/original/src/components/Home/index.tsx +13 -4
  126. package/themes/original/src/components/LanguageSelector/index.tsx +19 -14
  127. package/themes/original/src/components/LastOrder/index.tsx +1 -34
  128. package/themes/original/src/components/LoginForm/Otp/index.tsx +89 -73
  129. package/themes/original/src/components/LoginForm/Otp/styles.tsx +0 -1
  130. package/themes/original/src/components/LoginForm/index.tsx +43 -19
  131. package/themes/original/src/components/LottieAnimation/index.tsx +78 -0
  132. package/themes/original/src/components/MessageListing/index.tsx +16 -42
  133. package/themes/original/src/components/Messages/index.tsx +32 -10
  134. package/themes/original/src/components/MomentOption/index.tsx +195 -88
  135. package/themes/original/src/components/MultiCart/index.tsx +50 -0
  136. package/themes/original/src/components/MultiCartsPaymethodsAndWallets/index.tsx +117 -96
  137. package/themes/original/src/components/MultiCheckout/index.tsx +248 -83
  138. package/themes/original/src/components/MultiOrdersDetails/SingleOrderCard.tsx +37 -224
  139. package/themes/original/src/components/MultiOrdersDetails/index.tsx +67 -20
  140. package/themes/original/src/components/MultiOrdersDetails/styles.tsx +1 -1
  141. package/themes/original/src/components/MyOrders/index.tsx +66 -17
  142. package/themes/original/src/components/NavBar/index.tsx +6 -11
  143. package/themes/original/src/components/Notifications/index.tsx +144 -0
  144. package/themes/original/src/components/Notifications/styles.tsx +20 -0
  145. package/themes/original/src/components/OrderDetails/OrderEta.tsx +61 -0
  146. package/themes/original/src/components/OrderDetails/OrderHistory.tsx +10 -3
  147. package/themes/original/src/components/OrderDetails/index.tsx +262 -347
  148. package/themes/original/src/components/OrderDetails/styles.tsx +10 -1
  149. package/themes/original/src/components/OrderItAgain/index.tsx +47 -43
  150. package/themes/original/src/components/OrderProgress/index.tsx +74 -112
  151. package/themes/original/src/components/OrderProgress/styles.tsx +5 -0
  152. package/themes/original/src/components/OrderSummary/index.tsx +67 -29
  153. package/themes/original/src/components/OrderTypeSelector/index.tsx +3 -2
  154. package/themes/original/src/components/OrdersOption/PreviousBusinessOrdered/index.tsx +28 -19
  155. package/themes/original/src/components/OrdersOption/index.tsx +99 -89
  156. package/themes/original/src/components/PageBanner/index.tsx +171 -0
  157. package/themes/original/src/components/PageBanner/styles.tsx +11 -0
  158. package/themes/original/src/components/PaymentOptionStripe/styles.tsx +1 -1
  159. package/themes/original/src/components/PaymentOptionWallet/index.tsx +56 -56
  160. package/themes/original/src/components/PaymentOptions/index.tsx +3 -3
  161. package/themes/original/src/components/PhoneInputNumber/index.tsx +3 -3
  162. package/themes/original/src/components/PlaceSpot/index.tsx +12 -6
  163. package/themes/original/src/components/PreviousOrders/index.tsx +3 -2
  164. package/themes/original/src/components/ProductForm/index.tsx +231 -253
  165. package/themes/original/src/components/ProductForm/styles.tsx +4 -7
  166. package/themes/original/src/components/ProductItemAccordion/index.tsx +197 -138
  167. package/themes/original/src/components/ProductOptionSubOption/index.tsx +18 -10
  168. package/themes/original/src/components/ProductOptionSubOption/styles.tsx +1 -2
  169. package/themes/original/src/components/ProfessionalFilter/SingleProfessionalCard/index.tsx +108 -0
  170. package/themes/original/src/components/ProfessionalFilter/index.tsx +20 -49
  171. package/themes/original/src/components/ProfessionalProfile/index.tsx +54 -14
  172. package/themes/original/src/components/Promotions/index.tsx +234 -220
  173. package/themes/original/src/components/Promotions/styles.tsx +10 -3
  174. package/themes/original/src/components/ReviewDriver/index.tsx +3 -3
  175. package/themes/original/src/components/ReviewOrder/index.tsx +26 -9
  176. package/themes/original/src/components/ReviewOrder/styles.tsx +7 -0
  177. package/themes/original/src/components/ReviewProducts/index.tsx +7 -4
  178. package/themes/original/src/components/ReviewTrigger/index.tsx +27 -9
  179. package/themes/original/src/components/ReviewTrigger/styles.tsx +8 -1
  180. package/themes/original/src/components/ScheduleAccordion/index.tsx +68 -0
  181. package/themes/original/src/components/ScheduleAccordion/styles.tsx +14 -0
  182. package/themes/original/src/components/ServiceForm/index.tsx +377 -270
  183. package/themes/original/src/components/Sessions/index.tsx +11 -8
  184. package/themes/original/src/components/Sessions/styles.tsx +5 -0
  185. package/themes/original/src/components/SignupForm/index.tsx +82 -67
  186. package/themes/original/src/components/SingleOrderCard/index.tsx +148 -62
  187. package/themes/original/src/components/SingleOrderCard/styles.tsx +11 -9
  188. package/themes/original/src/components/SingleProductCard/index.tsx +99 -55
  189. package/themes/original/src/components/SingleProductCard/styles.tsx +27 -13
  190. package/themes/original/src/components/SingleProductReview/index.tsx +38 -5
  191. package/themes/original/src/components/SingleProductReview/styles.tsx +12 -0
  192. package/themes/original/src/components/StripeCardsList/index.tsx +9 -2
  193. package/themes/original/src/components/StripeElementsForm/index.tsx +4 -1
  194. package/themes/original/src/components/UpsellingProducts/index.tsx +238 -218
  195. package/themes/original/src/components/UpsellingProducts/styles.tsx +12 -1
  196. package/themes/original/src/components/UserDetails/index.tsx +8 -4
  197. package/themes/original/src/components/UserFormDetails/index.tsx +53 -54
  198. package/themes/original/src/components/UserProfile/index.tsx +58 -35
  199. package/themes/original/src/components/UserProfile/styles.ts +17 -0
  200. package/themes/original/src/components/UserProfileForm/index.tsx +21 -28
  201. package/themes/original/src/components/UserProfileForm/styles.tsx +7 -0
  202. package/themes/original/src/components/Wallets/index.tsx +31 -17
  203. package/themes/original/src/components/Wallets/styles.tsx +2 -0
  204. package/themes/original/src/components/shared/CardAnimation.tsx +47 -0
  205. package/themes/original/src/components/shared/HeaderTitle.tsx +8 -3
  206. package/themes/original/src/components/shared/OBottomPopup.tsx +1 -1
  207. package/themes/original/src/components/shared/OButton.tsx +6 -2
  208. package/themes/original/src/components/shared/OIcon.tsx +8 -1
  209. package/themes/original/src/components/shared/OInput.tsx +10 -1
  210. package/themes/original/src/components/shared/OModal.tsx +3 -3
  211. package/themes/original/src/layouts/Container.tsx +13 -9
  212. package/themes/original/src/types/index.tsx +43 -9
  213. package/themes/original/src/utils/index.tsx +375 -58
  214. package/themes/uber-eats/src/components/BusinessesListing/index.tsx +1 -1
@@ -1,5 +1,18 @@
1
1
  import styled from 'styled-components/native';
2
2
 
3
+ export const LoginWith = styled.View`
4
+ display: flex;
5
+ width: 100%;
6
+ margin-bottom: 30px;
7
+ `;
8
+
9
+ export const TabsContainer = styled.View`
10
+ min-width: ${({ width }: { width: number }) => `${width}px`};
11
+ width: auto;
12
+ display: flex;
13
+ flex-direction: row;
14
+ `;
15
+
3
16
  export const LogoWrapper = styled.View`
4
17
  align-items: center;
5
18
  `;
@@ -11,4 +24,4 @@ export const RecaptchaButton = styled.View`
11
24
  flex-direction: row;
12
25
  align-items: center;
13
26
  margin-bottom: 10px;
14
- `
27
+ `
@@ -4,6 +4,7 @@ import { OIcon, OButton, OText } from '../shared'
4
4
  import { ImageStyle, TextStyle, View, Platform, TouchableOpacity } from 'react-native'
5
5
  import { useConfig, useLanguage, useOrder } from 'ordering-components/native'
6
6
  import { useTheme } from 'styled-components/native'
7
+
7
8
  const Wrapper = styled.View`
8
9
  background-color: ${(props: any) => props.theme.colors.white};
9
10
  padding: 10px 0px 20px 0px;
@@ -65,28 +66,27 @@ const NavBar = (props: Props) => {
65
66
 
66
67
  return (
67
68
  <Wrapper style={{ paddingTop: props.paddingTop, ...props.style }}>
68
- {(props?.onActionLeft) && (
69
+ {(props?.onActionLeft || props?.leftImg) && (
69
70
  <OButton
70
- imgLeftSrc={props.leftImg}
71
+ imgLeftSrc={props.leftImg || theme.images.general.arrow_left}
71
72
  imgRightSrc={null}
72
73
  style={{ ...btnBackArrow, ...props.btnStyle }}
73
74
  onClick={props.onActionLeft}
74
- imgLeftStyle={props.imgLeftStyle}
75
- {...(!props.leftImg && { iconProps: { name: 'arrowleft', size: 28, color: props.btnStyle?.color } })}
75
+ imgLeftStyle= {props.imgLeftStyle}
76
76
  />)
77
77
  }
78
78
  <TitleTopWrapper>
79
79
  {props.withIcon
80
80
  ? (
81
- <OIcon
82
- url={props.icon}
83
- style={{
84
- borderColor: theme.colors.lightGray,
85
- borderRadius: 20,
86
- }}
87
- width={60}
88
- height={60}
89
- />
81
+ <OIcon
82
+ url={props.icon}
83
+ style={{
84
+ borderColor: theme.colors.lightGray,
85
+ borderRadius: 20,
86
+ }}
87
+ width={60}
88
+ height={60}
89
+ />
90
90
  )
91
91
  : null
92
92
  }
@@ -134,7 +134,7 @@ const NavBar = (props: Props) => {
134
134
  </View>
135
135
  )}
136
136
 
137
- {props.rightComponent}
137
+ { props.rightComponent }
138
138
  </Wrapper>
139
139
  )
140
140
  }
@@ -95,7 +95,7 @@ interface Props {
95
95
  style?: ViewStyle;
96
96
  bgImage: ImageSourcePropType;
97
97
  innerStyle?: ViewStyle;
98
- icon?: ImageSourcePropType;
98
+ icon: ImageSourcePropType;
99
99
  iconStyle?: ImageStyle;
100
100
  callToActionText: string;
101
101
  callToActionTextStyle?: TextStyle;
@@ -15,8 +15,6 @@ import { Container } from '../../layouts/Container'
15
15
  import NavBar from '../NavBar'
16
16
  import { LANDSCAPE, PORTRAIT, useDeviceOrientation } from '../../../../../src/hooks/DeviceOrientation'
17
17
  import GridContainer from '../../layouts/GridContainer'
18
- import AntDesignIcon from 'react-native-vector-icons/AntDesign'
19
- import MaterialIcon from 'react-native-vector-icons/MaterialCommunityIcons'
20
18
 
21
19
  const OrderTypeSelectorCardUI = (props: OrderTypeSelectParams) => {
22
20
  const {
@@ -29,7 +27,7 @@ const OrderTypeSelectorCardUI = (props: OrderTypeSelectParams) => {
29
27
  callback
30
28
  } = props
31
29
 
32
- const theme = useTheme();
30
+ const theme = useTheme();
33
31
  const [, t] = useLanguage();
34
32
  const [orientationState] = useDeviceOrientation();
35
33
  const [orderState] = useOrder()
@@ -47,7 +45,7 @@ const OrderTypeSelectorCardUI = (props: OrderTypeSelectParams) => {
47
45
  }
48
46
 
49
47
  useEffect(() => {
50
- if (isCardCliked) {
48
+ if(isCardCliked){
51
49
  callback?.()
52
50
  setIsCardClicked(false)
53
51
  setIsLoadingCard(null)
@@ -85,13 +83,13 @@ const OrderTypeSelectorCardUI = (props: OrderTypeSelectParams) => {
85
83
  style={cardStyle}
86
84
  isDisabled={isCardCliked}
87
85
  isLoading={isLoadingCard === 'Eat In'}
88
- title={t('EAT_IN', 'Eat In')}
86
+ title={t('EAT_IN','Eat In')}
89
87
  description={t('EAT_IN_DESCRIPTION', 'We are very glad to have you here. Bon appetit!')}
90
88
  bgImage={theme.images.general.eatIn}
91
- VectorIcon={() => <MaterialIcon name='pin-outline' size={28} color='white' style={{ marginBottom: 10 }} />}
89
+ icon={theme.images.general.pushPin}
92
90
  callToActionText={t('START_MY_ORDER', 'Start my order')}
93
91
  onClick={() => {
94
- if (_eatIn?.value !== orderState?.options?.type) {
92
+ if(_eatIn?.value !== orderState?.options?.type){
95
93
  handleChangeOrderType(_eatIn?.value);
96
94
  setIsCardClicked(true)
97
95
  setIsLoadingCard('Eat In')
@@ -108,15 +106,15 @@ const OrderTypeSelectorCardUI = (props: OrderTypeSelectParams) => {
108
106
 
109
107
  <OptionCard
110
108
  style={cardStyle}
111
- title={t('TAKE_OUT', 'Take out')}
109
+ title={t('TAKE_OUT','Take out')}
112
110
  isDisabled={isCardCliked}
113
111
  isLoading={isLoadingCard === 'Take out'}
114
112
  description={t('TAKE_OUT_DESCRIPTION', 'You are very welcome anytime you visit us!')}
115
113
  bgImage={theme.images.general.takeOut}
116
- VectorIcon={() => <AntDesignIcon name='shoppingcart' size={28} color='white' style={{ marginBottom: 10 }} />}
114
+ icon={theme.images.general.shoppingCart}
117
115
  callToActionText={t('START_MY_ORDER', 'Start my order')}
118
116
  onClick={() => {
119
- if (_takeOut?.value !== orderState?.options?.type) {
117
+ if(_takeOut?.value !== orderState?.options?.type){
120
118
  handleChangeOrderType(_takeOut?.value);
121
119
  setIsCardClicked(true)
122
120
  setIsLoadingCard('Take out')
@@ -7,7 +7,7 @@ import { Wrapper } from './styles'
7
7
 
8
8
  import { PhoneInputParams } from '../../../../../src/types';
9
9
  import { OText } from '../shared';
10
- import {transformCountryCode} from '../../../../../src/utils'
10
+ import { transformCountryCode, verifyCountryCode } from '../../../../../src/utils'
11
11
  import {I18nManager} from 'react-native'
12
12
  import { useTheme } from 'styled-components/native';
13
13
 
@@ -86,9 +86,10 @@ export const PhoneInputNumber = (props: PhoneInputParams) => {
86
86
  return (
87
87
  <Wrapper>
88
88
  <PhoneInput
89
+ containerStyle={{ width: '100%' }}
89
90
  ref={phoneInput}
90
91
  defaultValue={userphoneNumber || defaultValue}
91
- defaultCode={defaultCode ? transformCountryCode(defaultCode) : configs?.default_country_code?.value}
92
+ defaultCode={defaultCode ? transformCountryCode(defaultCode) : verifyCountryCode(configs?.default_country_code?.value)}
92
93
  onChangeFormattedText={(text : string) => handleChangeNumber(text)}
93
94
  withDarkTheme
94
95
  textInputStyle={{textAlign: I18nManager.isRTL ? 'right' : 'left'}}
@@ -1,5 +1,3 @@
1
1
  import styled from 'styled-components/native';
2
2
 
3
- export const Wrapper = styled.View`
4
- flex: 1
5
- `
3
+ export const Wrapper = styled.View``;
@@ -550,7 +550,7 @@ export const ProductOptionsUI = (props: any) => {
550
550
  </View>
551
551
  )}
552
552
  <View style={{ width: isSoldOut || maxProductQuantity <= 0 ? '100%' : isDrawer ? '70%' : '80%' }}>
553
- {productCart && !isSoldOut && maxProductQuantity > 0 && auth && orderState.options?.address_id && (
553
+ {productCart && !isSoldOut && maxProductQuantity > 0 && auth && (
554
554
  <OButton
555
555
  onClick={() => handleSaveProduct()}
556
556
  imgRightSrc=''
@@ -563,19 +563,6 @@ export const ProductOptionsUI = (props: any) => {
563
563
  }}
564
564
  />
565
565
  )}
566
- {auth && !orderState.options?.address_id && (
567
- orderState.loading ? (
568
- <OButton
569
- isDisabled
570
- text={t('LOADING', 'Loading')}
571
- imgRightSrc=''
572
- />
573
- ) : (
574
- <OButton
575
- onClick={navigation?.navigate('AddressList')}
576
- />
577
- )
578
- )}
579
566
  {(!auth || isSoldOut || maxProductQuantity <= 0) && (
580
567
  <OButton
581
568
  isDisabled={isSoldOut || maxProductQuantity <= 0}
@@ -10,8 +10,6 @@ import {
10
10
 
11
11
  import * as React from 'react';
12
12
  import styled from 'styled-components/native';
13
- import AntDesignIcon from 'react-native-vector-icons/AntDesign'
14
- import { Icon, IconProps } from 'react-native-vector-icons/Icon';
15
13
 
16
14
  const StyledButton = styled.View<Props>`
17
15
  background-color: ${(props: any) => props.theme.colors.primary};
@@ -79,19 +77,17 @@ interface Props {
79
77
  isCircle?: boolean;
80
78
  bgColor?: string;
81
79
  borderColor?: string;
82
- iconProps?: IconProps;
83
- IconCustom?: React.FunctionComponent
84
80
  }
85
81
 
86
82
  const OButton = (props: Props): React.ReactElement => {
87
83
  if (props.isDisabled) {
88
84
  return (
89
85
  <View style={props.parentStyle}>
90
- <StyledButtonDisabled style={props.style}>
91
- <StyledTextDisabled style={props.disabledTextStyle ? props.disabledTextStyle : props.textStyle}>
92
- {props.text}
93
- </StyledTextDisabled>
94
- </StyledButtonDisabled>
86
+ <StyledButtonDisabled style={props.style}>
87
+ <StyledTextDisabled style={props.disabledTextStyle ? props.disabledTextStyle : props.textStyle}>
88
+ {props.text}
89
+ </StyledTextDisabled>
90
+ </StyledButtonDisabled>
95
91
  </View>
96
92
  );
97
93
  }
@@ -115,15 +111,6 @@ const OButton = (props: Props): React.ReactElement => {
115
111
  {props.imgLeftSrc ? (
116
112
  <StyledImage style={props.imgLeftStyle} source={props.imgLeftSrc} />
117
113
  ) : null}
118
- {props.iconProps ? (
119
- <>
120
- {props?.IconCustom ? (
121
- <props.IconCustom {...props.iconProps} />
122
- ) : (
123
- <AntDesignIcon {...props.iconProps} />
124
- )}
125
- </>
126
- ) : null}
127
114
  {props.text ? (
128
115
  <StyledText style={props.textStyle}>{props.text}</StyledText>
129
116
  ) : null}
@@ -95,14 +95,14 @@ const styles = StyleSheet.create({
95
95
  position: 'relative',
96
96
  width: '100%',
97
97
  },
98
- titleSection: {
99
- width: '100%',
100
- height: 30,
101
- display: 'flex',
102
- justifyContent: 'space-between',
103
- alignItems: 'center',
104
- marginBottom: 20,
105
- },
98
+ titleSection: {
99
+ width: '100%',
100
+ justifyContent: 'space-between',
101
+ alignItems: 'flex-start',
102
+ paddingLeft: 40,
103
+ paddingRight: 40,
104
+ marginBottom: 40,
105
+ },
106
106
  cancelBtn: {
107
107
  position: 'absolute',
108
108
  left: 0,
@@ -111,9 +111,12 @@ const styles = StyleSheet.create({
111
111
  },
112
112
  modalText: {
113
113
  marginTop: 15,
114
- fontSize: 25,
115
- textAlign: "center",
116
- zIndex: 10
114
+ fontSize: 20,
115
+ lineHeight: 30,
116
+ fontWeight: '600',
117
+ textAlign: "center",
118
+ zIndex: 10,
119
+ width: '100%'
117
120
  },
118
121
  wrapperIcon: {
119
122
  overflow: 'hidden',
@@ -22,7 +22,13 @@ export const Container = (props: Props) => {
22
22
  <SafeAreStyled
23
23
  nestedScrollEnabled={props.nestedScrollEnabled}
24
24
  >
25
- <ContainerStyled {...props} ref={props?.forwardRef}>{props.children}</ContainerStyled>
25
+ <ContainerStyled
26
+ {...props}
27
+ keyboardShouldPersistTaps="handled"
28
+ ref={props?.forwardRef}
29
+ >
30
+ {props.children}
31
+ </ContainerStyled>
26
32
  </SafeAreStyled>
27
33
  );
28
34
  };
@@ -84,6 +84,12 @@ export interface LoginParams {
84
84
  useRootPoint?: any;
85
85
  enableReCaptcha?: boolean;
86
86
  handleReCaptcha?: (vlaue: any) => void;
87
+ useLoginOtp?: any;
88
+ otpType?: any;
89
+ setOtpType?: any;
90
+ generateOtpCode?: any;
91
+ useLoginOtpEmail?: any;
92
+ useLoginOtpCellphone?: any;
87
93
  }
88
94
 
89
95
  export interface ProductItemAccordionParams {
@@ -482,3 +488,10 @@ export interface Cart {
482
488
  export interface NoNetworkParams {
483
489
  image?: any;
484
490
  }
491
+ export interface otpParams {
492
+ willVerifyOtpState: boolean,
493
+ setWillVerifyOtpState: (val : boolean) => void,
494
+ onSubmit: any,
495
+ handleLoginOtp: (code : string) => void,
496
+ setAlertState: any
497
+ }
@@ -0,0 +1,15 @@
1
+ export const formatSeconds = (seconds : number) => {
2
+ // Hours, minutes and seconds
3
+ const hrs = Math.floor(seconds / 3600)
4
+ const mins = Math.floor((seconds % 3600) / 60)
5
+ const secs = Math.floor(seconds % 60)
6
+
7
+ // Output like '1:01' or '4:03:59' or '123:03:59'
8
+ let ret = ''
9
+ if (hrs > 0) {
10
+ ret += '' + hrs + ':' + (mins < 10 ? '0' : '')
11
+ }
12
+ ret += '' + mins + ':' + (secs < 10 ? '0' : '')
13
+ ret += '' + secs
14
+ return ret
15
+ }
@@ -51,6 +51,7 @@ import { LastOrders } from './src/components/LastOrders';
51
51
  import { MultiCheckout } from './src/components/MultiCheckout'
52
52
  import { MultiOrdersDetails } from './src/components/MultiOrdersDetails'
53
53
  import NavBar from './src/components/NavBar';
54
+ import { NotificationsList } from './src/components/Notifications'
54
55
  import { BusinessTypeFilter } from './src/components/BusinessTypeFilter';
55
56
  import { BusinessController } from './src/components/BusinessController';
56
57
  import { BusinessFeaturedController } from './src/components/BusinessFeaturedController';
@@ -67,6 +68,7 @@ import { SingleProductCard } from './src/components/SingleProductCard';
67
68
  import { SingleOrderCard } from './src/components/SingleOrderCard';
68
69
  import { UpsellingRedirect } from './src/components/BusinessProductsListing/UpsellingRedirect';
69
70
  import { ProductItemAccordion } from './src/components/ProductItemAccordion';
71
+ import { ScheduleAccordion } from './src/components/ScheduleAccordion';
70
72
  import { BusinessItemAccordion } from './src/components/BusinessItemAccordion';
71
73
  import { CouponControl } from './src/components/CouponControl';
72
74
  import { TaxInformation } from './src/components/TaxInformation';
@@ -94,6 +96,8 @@ import { LogoutButton } from './src/components/LogoutButton';
94
96
  import { UserFormDetailsUI } from './src/components/UserFormDetails';
95
97
  import { WalletTransactionItem } from './src/components/WalletTransactionItem';
96
98
  import { Promotions } from './src/components/Promotions'
99
+ import { MultiCart } from './src/components/MultiCart'
100
+ import { PageBanner } from './src/components/PageBanner'
97
101
  import { USER_TYPE, ORDER_TYPES } from './src/config/constants'
98
102
 
99
103
  import { OSBill, OSTable, OSCoupon, OSTotal, OSRow } from './src/components/OrderSummary/styles';
@@ -183,6 +187,7 @@ export {
183
187
  OrderDetails,
184
188
  OrderProgress,
185
189
  BusinessPreorder,
190
+ NotificationsList,
186
191
  UserProfileForm,
187
192
  ReviewOrder,
188
193
  ReviewProducts,
@@ -228,6 +233,7 @@ export {
228
233
  SingleOrderCard,
229
234
  UpsellingRedirect,
230
235
  ProductItemAccordion,
236
+ ScheduleAccordion,
231
237
  BusinessItemAccordion,
232
238
  CouponControl,
233
239
  TaxInformation,
@@ -255,7 +261,9 @@ export {
255
261
  UserFormDetailsUI,
256
262
  WalletTransactionItem,
257
263
  Promotions,
264
+ PageBanner,
258
265
  MyOrders,
266
+ MultiCart,
259
267
  ORDER_TYPES,
260
268
  USER_TYPE,
261
269
 
@@ -1,5 +1,6 @@
1
1
  import React from 'react';
2
- import { TouchableOpacity, View } from 'react-native';
2
+ import FastImage from 'react-native-fast-image'
3
+ import { StyleSheet, TouchableOpacity, View } from 'react-native';
3
4
  import {
4
5
  AddressDetails as AddressDetailsController,
5
6
  useOrder,
@@ -21,21 +22,38 @@ const AddressDetailsUI = (props: any) => {
21
22
  const [, t] = useLanguage();
22
23
  const { width } = useWindowDimensions();
23
24
 
25
+ const styles = StyleSheet.create({
26
+ productStyle: {
27
+ width: width,
28
+ height: 151,
29
+ marginVertical: 10
30
+ }
31
+ })
32
+
24
33
  return (
25
34
  <ADContainer>
26
35
  <ADHeader>
27
- <OText
28
- size={16}
29
- lineHeight={24}
30
- color={theme.colors.textNormal}
31
- weight={'500'}>
32
- {t('DELIVERY_ADDRESS', 'Delivery address')}
33
- </OText>
36
+ {props.HeaderTitle ?? (
37
+ <OText
38
+ size={16}
39
+ lineHeight={24}
40
+ color={theme.colors.textNormal}
41
+ >
42
+ {t('DELIVERY_ADDRESS', 'Delivery address')}
43
+ </OText>
44
+ )}
34
45
  </ADHeader>
35
- {!!apiKey && (
46
+ {!!apiKey && googleMapsUrl && (
36
47
  <ADMap
37
48
  style={{ marginStart: -40, marginEnd: -40, width: width, flex: 1 }}>
38
- <OIcon url={googleMapsUrl} height={151} width={width} />
49
+ <FastImage
50
+ style={styles.productStyle}
51
+ source={{
52
+ uri: googleMapsUrl,
53
+ priority: FastImage.priority.normal,
54
+ }}
55
+ resizeMode={FastImage.resizeMode.cover}
56
+ />
39
57
  </ADMap>
40
58
  )}
41
59
  <ADAddress>
@@ -57,7 +75,7 @@ const AddressDetailsUI = (props: any) => {
57
75
  }>
58
76
  <OText
59
77
  size={12}
60
- color={theme.colors.textSecondary}
78
+ color={theme.colors.primary}
61
79
  style={{ textDecorationLine: 'underline' }}>
62
80
  {t('CHANGE', 'Change')}
63
81
  </OText>
@@ -16,6 +16,8 @@ import {
16
16
  useToast,
17
17
  ToastType
18
18
  } from 'ordering-components/native';
19
+ import { DeviceOrientationMethods } from '../../../../../src/hooks/DeviceOrientation'
20
+
19
21
  import { GooglePlacesAutocomplete } from 'react-native-google-places-autocomplete';
20
22
  import Spinner from 'react-native-loading-spinner-overlay';
21
23
  import { useForm, Controller } from 'react-hook-form';
@@ -38,6 +40,8 @@ import {
38
40
  import { GPSButton } from '../GPSButton';
39
41
  import { ScrollView } from 'react-native-gesture-handler';
40
42
 
43
+ const { useDeviceOrientation } = DeviceOrientationMethods
44
+
41
45
  const inputNames = [
42
46
  { name: 'address', code: 'Address' },
43
47
  { name: 'internal_number', code: 'Internal number' },
@@ -62,9 +66,13 @@ const AddressFormUI = (props: AddressFormParams) => {
62
66
  isFromProductsList,
63
67
  hasAddressDefault,
64
68
  afterSignup,
69
+ businessSlug
65
70
  } = props;
66
71
 
67
72
  const theme = useTheme();
73
+ const [orientationState] = useDeviceOrientation();
74
+
75
+ const [autoCompleteInputFocused, setAutoCompleteInputFocused] = useState(false)
68
76
 
69
77
  const tagsName = [
70
78
  { icon: theme.images.general.tag_home, value: 'home' },
@@ -73,6 +81,8 @@ const AddressFormUI = (props: AddressFormParams) => {
73
81
  { icon: theme.images.general.tag_plus, value: 'other' },
74
82
  ];
75
83
 
84
+ const HEIGHT_SCREEN = orientationState?.dimensions?.height
85
+
76
86
  const styles = StyleSheet.create({
77
87
  iconContainer: {
78
88
  display: 'flex',
@@ -83,7 +93,6 @@ const AddressFormUI = (props: AddressFormParams) => {
83
93
  backgroundColor: theme.colors.clear
84
94
  },
85
95
  inputsStyle: {
86
- borderColor: theme.colors.border,
87
96
  borderRadius: 10,
88
97
  marginBottom: 20,
89
98
  height: 50,
@@ -92,7 +101,6 @@ const AddressFormUI = (props: AddressFormParams) => {
92
101
  flex: 1,
93
102
  },
94
103
  textAreaStyles: {
95
- borderColor: theme.colors.border,
96
104
  borderRadius: 10,
97
105
  marginBottom: 20,
98
106
  height: 104,
@@ -106,6 +114,12 @@ const AddressFormUI = (props: AddressFormParams) => {
106
114
  end: 0,
107
115
  top: 12,
108
116
  zIndex: 1002,
117
+ right: autoCompleteInputFocused && (
118
+ !!address?.address ||
119
+ !!formState.changes?.address ||
120
+ !!addressState.address.address
121
+ ) ? 30 : 15,
122
+ width: 16
109
123
  },
110
124
  wrapperNavbar: Platform.OS === 'ios'
111
125
  ? { paddingVertical: 0, paddingHorizontal: 40 }
@@ -154,8 +168,10 @@ const AddressFormUI = (props: AddressFormParams) => {
154
168
  'true';
155
169
  const maxLimitLocation =
156
170
  configState?.configs?.meters_to_change_address?.value;
157
-
158
- const continueAsGuest = () => navigation.navigate('BusinessList', { isGuestUser: true });
171
+ const countryCode = configState?.configs?.country_autocomplete?.value
172
+ const isHideMap = theme?.address?.components?.map?.hidden
173
+ const isHideIcons = theme?.address?.components?.icons?.hidden
174
+ const continueAsGuest = () => navigation.navigate(!!businessSlug ? 'Business' : 'BusinessList', { isGuestUser: true });
159
175
  const goToBack = () => navigation?.canGoBack() && navigation.goBack();
160
176
 
161
177
  const getAddressFormatted = (address: any) => {
@@ -357,7 +373,7 @@ const AddressFormUI = (props: AddressFormParams) => {
357
373
  if (
358
374
  orderState.loading &&
359
375
  !addressesList &&
360
- orderState.options.address &&
376
+ orderState?.options?.address &&
361
377
  auth &&
362
378
  !afterSignup
363
379
  ) {
@@ -365,7 +381,7 @@ const AddressFormUI = (props: AddressFormParams) => {
365
381
  ? navigation.navigate('BottomTab')
366
382
  : navigation.navigate('Business');
367
383
  }
368
- }, [orderState.options.address]);
384
+ }, [orderState?.options?.address]);
369
385
 
370
386
  useEffect(() => {
371
387
  if (alertState.open && alertState?.key !== 'ERROR_MAX_LIMIT_LOCATION') {
@@ -516,7 +532,7 @@ const AddressFormUI = (props: AddressFormParams) => {
516
532
  />
517
533
  </View>
518
534
  <TouchableWithoutFeedback onPress={Keyboard.dismiss}>
519
- <AddressFormContainer style={{ height: 600, overflow: 'scroll' }}>
535
+ <AddressFormContainer style={{ height: HEIGHT_SCREEN * .78, overflow: 'scroll' }}>
520
536
  <View>
521
537
  <FormInput>
522
538
  <AutocompleteInput>
@@ -544,7 +560,10 @@ const AddressFormUI = (props: AddressFormParams) => {
544
560
  onPress={(data, details: any) => {
545
561
  handleChangeAddress(data, details);
546
562
  }}
547
- query={{ key: googleMapsApiKey }}
563
+ query={{
564
+ key: googleMapsApiKey,
565
+ components: countryCode && countryCode !== '*' ? `country:${countryCode}` : ''
566
+ }}
548
567
  fetchDetails
549
568
  ref={googleInput}
550
569
  textInputProps={{
@@ -563,6 +582,8 @@ const AddressFormUI = (props: AddressFormParams) => {
563
582
  autoCorrect: false,
564
583
  blurOnSubmit: false,
565
584
  returnKeyType: 'next',
585
+ onFocus: () => setAutoCompleteInputFocused(true),
586
+ onBlur: () => setAutoCompleteInputFocused(false)
566
587
  }}
567
588
  onFail={(error) =>
568
589
  setAlertState({
@@ -586,13 +607,14 @@ const AddressFormUI = (props: AddressFormParams) => {
586
607
  textInput: {
587
608
  borderWidth: 1,
588
609
  borderRadius: 7.6,
589
- borderColor: theme.colors.border,
610
+ borderColor: autoCompleteInputFocused ? theme.colors.primary : theme.colors.border,
590
611
  flexGrow: 1,
591
612
  fontSize: 15,
592
- paddingHorizontal: 16,
613
+ paddingLeft: 16,
614
+ paddingRight: 32,
593
615
  minHeight: 50,
594
616
  fontFamily: 'Poppins-Regular',
595
- marginBottom: 24,
617
+ marginBottom: 24
596
618
  },
597
619
  }}
598
620
  />
@@ -600,10 +622,10 @@ const AddressFormUI = (props: AddressFormParams) => {
600
622
  />
601
623
 
602
624
  {(
603
- (!isEditing && !isGuestUser && !formState.changes?.address) ||
604
- (isEditing && !isGuestUser && !formState.changes?.address && formState.changes?.address !== undefined)) ||
605
- (isGuestUser && !formState.changes?.address && formState.changes?.address !== undefined) &&
606
- (
625
+ ((!isEditing && !isGuestUser) ||
626
+ (isEditing && !isGuestUser)) ||
627
+ (isGuestUser)) &&
628
+ (
607
629
  <View style={styles.pinIcon}>
608
630
  <GPSButton
609
631
  apiKey={googleMapsApiKey}
@@ -617,7 +639,7 @@ const AddressFormUI = (props: AddressFormParams) => {
617
639
  IconButton={<OIcon src={theme.images.general.pin} width={16} />}
618
640
  />
619
641
  </View>
620
- )}
642
+ )}
621
643
  </AutocompleteInput>
622
644
 
623
645
  {(locationChange || formState.changes?.location) && (
@@ -675,6 +697,7 @@ const AddressFormUI = (props: AddressFormParams) => {
675
697
  addressState?.address?.internal_number ||
676
698
  ''
677
699
  }
700
+ isFocusHighlight
678
701
  style={{
679
702
  ...styles.inputsStyle,
680
703
  marginRight: showField('internal_number') && showField('zipcode') ? 24 : 0
@@ -721,6 +744,7 @@ const AddressFormUI = (props: AddressFormParams) => {
721
744
  addressState.address.zipcode ||
722
745
  ''
723
746
  }
747
+ isFocusHighlight
724
748
  style={styles.inputsStyle}
725
749
  forwardRef={zipCodeRef}
726
750
  returnKeyType="next"
@@ -766,6 +790,7 @@ const AddressFormUI = (props: AddressFormParams) => {
766
790
  ''
767
791
  }
768
792
  multiline
793
+ isFocusHighlight
769
794
  style={styles.textAreaStyles}
770
795
  returnKeyType="done"
771
796
  forwardRef={addressNotesRef}