ordering-ui-react-native 0.16.50 → 0.16.51-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 (205) 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 +33 -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 +120 -121
  16. package/src/components/ReviewProducts/index.tsx +11 -0
  17. package/src/components/SingleProductReview/index.tsx +8 -5
  18. package/src/components/StripeElementsForm/index.tsx +25 -16
  19. package/src/components/VerifyPhone/styles.tsx +1 -2
  20. package/src/components/shared/OBottomPopup.tsx +6 -2
  21. package/src/components/shared/OToast.tsx +4 -4
  22. package/src/index.tsx +2 -0
  23. package/src/types/@fatnlazycat/react-native-recaptcha-v3/index.d.ts +1 -0
  24. package/src/utils/index.tsx +2 -1
  25. package/themes/business/src/components/AcceptOrRejectOrder/index.tsx +259 -238
  26. package/themes/business/src/components/AcceptOrRejectOrder/styles.tsx +6 -4
  27. package/themes/business/src/components/BusinessController/index.tsx +2 -2
  28. package/themes/business/src/components/Chat/index.tsx +40 -32
  29. package/themes/business/src/components/DriverMap/index.tsx +7 -5
  30. package/themes/business/src/components/DriverSchedule/index.tsx +36 -19
  31. package/themes/business/src/components/LoginForm/index.tsx +111 -74
  32. package/themes/business/src/components/MapView/index.tsx +12 -1
  33. package/themes/business/src/components/MessagesOption/index.tsx +11 -1
  34. package/themes/business/src/components/NewOrderNotification/index.tsx +26 -41
  35. package/themes/business/src/components/OrderDetails/OrderContentComponent.tsx +40 -30
  36. package/themes/business/src/components/OrderDetails/OrderHeaderComponent.tsx +3 -3
  37. package/themes/business/src/components/OrdersListManager/index.tsx +10 -3
  38. package/themes/business/src/components/OrdersOption/index.tsx +76 -77
  39. package/themes/business/src/components/OrdersOption/styles.tsx +5 -1
  40. package/themes/business/src/components/OrdersOptionBusiness/index.tsx +15 -1
  41. package/themes/business/src/components/OrdersOptionCity/index.tsx +15 -1
  42. package/themes/business/src/components/OrdersOptionDate/index.tsx +19 -6
  43. package/themes/business/src/components/OrdersOptionDelivery/index.tsx +15 -1
  44. package/themes/business/src/components/OrdersOptionDriver/index.tsx +15 -1
  45. package/themes/business/src/components/OrdersOptionPaymethod/index.tsx +15 -1
  46. package/themes/business/src/components/OrdersOptionStatus/index.tsx +10 -1
  47. package/themes/business/src/components/PreviousMessages/index.tsx +17 -18
  48. package/themes/business/src/components/PreviousOrders/OrderItem.tsx +250 -0
  49. package/themes/business/src/components/PreviousOrders/OrdersGroupedItem.tsx +115 -0
  50. package/themes/business/src/components/PreviousOrders/index.tsx +332 -244
  51. package/themes/business/src/components/PreviousOrders/styles.tsx +30 -2
  52. package/themes/business/src/components/ProductItemAccordion/index.tsx +3 -2
  53. package/themes/business/src/components/ReviewCustomer/index.tsx +39 -15
  54. package/themes/business/src/components/ScheduleBlocked/index.tsx +2 -2
  55. package/themes/business/src/components/UserFormDetails/index.tsx +5 -2
  56. package/themes/business/src/components/UserProfileForm/index.tsx +2 -0
  57. package/themes/business/src/components/shared/ODropDown.tsx +42 -8
  58. package/themes/business/src/components/shared/ODropDownCalendar.tsx +36 -7
  59. package/themes/business/src/components/shared/OLink.tsx +24 -12
  60. package/themes/business/src/components/shared/OText.tsx +3 -2
  61. package/themes/business/src/types/index.tsx +25 -11
  62. package/themes/business/src/utils/index.tsx +10 -0
  63. package/themes/doordash/src/components/BusinessesListing/index.tsx +1 -1
  64. package/themes/doordash/src/components/LoginForm/index.tsx +1 -2
  65. package/themes/instacart/src/components/BusinessesListing/index.tsx +1 -1
  66. package/themes/kiosk/src/components/BusinessesListing/index.tsx +2 -1
  67. package/themes/kiosk/src/components/Checkout/index.tsx +6 -0
  68. package/themes/kiosk/src/components/LoginForm/index.tsx +121 -10
  69. package/themes/kiosk/src/components/LoginForm/styles.tsx +5 -0
  70. package/themes/kiosk/src/components/NavBar/index.tsx +14 -14
  71. package/themes/kiosk/src/components/OptionCard/index.tsx +1 -1
  72. package/themes/kiosk/src/components/OrderTypeCardSelector/index.tsx +8 -10
  73. package/themes/kiosk/src/components/ProductForm/index.tsx +1 -14
  74. package/themes/kiosk/src/components/shared/OButton.tsx +5 -18
  75. package/themes/kiosk/src/types/index.d.ts +2 -0
  76. package/themes/original/index.tsx +8 -0
  77. package/themes/original/src/components/AddressDetails/index.tsx +10 -8
  78. package/themes/original/src/components/AddressForm/index.tsx +157 -140
  79. package/themes/original/src/components/AddressList/index.tsx +1 -1
  80. package/themes/original/src/components/AppleLogin/index.tsx +4 -4
  81. package/themes/original/src/components/BusinessBasicInformation/index.tsx +218 -147
  82. package/themes/original/src/components/BusinessBasicInformation/styles.tsx +2 -2
  83. package/themes/original/src/components/BusinessController/index.tsx +192 -91
  84. package/themes/original/src/components/BusinessController/styles.tsx +14 -9
  85. package/themes/original/src/components/BusinessInformation/index.tsx +10 -31
  86. package/themes/original/src/components/BusinessItemAccordion/index.tsx +12 -6
  87. package/themes/original/src/components/BusinessListingSearch/BusinessControllerSkeletons/index.tsx +57 -0
  88. package/themes/original/src/components/BusinessListingSearch/MaxSectionItem/index.tsx +59 -0
  89. package/themes/original/src/components/BusinessListingSearch/MaxSectionItem/styles.tsx +13 -0
  90. package/themes/original/src/components/BusinessListingSearch/index.tsx +85 -137
  91. package/themes/original/src/components/BusinessListingSearch/styles.tsx +10 -12
  92. package/themes/original/src/components/BusinessProductsList/SubcategoriesComponent/index.tsx +87 -0
  93. package/themes/original/src/components/BusinessProductsList/SubcategoriesComponent/styles.tsx +12 -0
  94. package/themes/original/src/components/BusinessProductsList/index.tsx +59 -61
  95. package/themes/original/src/components/BusinessProductsList/styles.tsx +0 -3
  96. package/themes/original/src/components/BusinessProductsListing/index.tsx +179 -83
  97. package/themes/original/src/components/BusinessProductsListing/styles.tsx +19 -12
  98. package/themes/original/src/components/BusinessTypeFilter/index.tsx +3 -2
  99. package/themes/original/src/components/BusinessesListing/Layout/Appointment/index.tsx +37 -30
  100. package/themes/original/src/components/BusinessesListing/Layout/Appointment/styles.tsx +3 -2
  101. package/themes/original/src/components/BusinessesListing/Layout/Original/index.tsx +299 -148
  102. package/themes/original/src/components/BusinessesListing/Layout/Original/styles.tsx +47 -11
  103. package/themes/original/src/components/BusinessesListing/index.tsx +80 -25
  104. package/themes/original/src/components/Cart/index.tsx +82 -15
  105. package/themes/original/src/components/Cart/styles.tsx +4 -0
  106. package/themes/original/src/components/CartContent/index.tsx +27 -17
  107. package/themes/original/src/components/CartContent/styles.tsx +1 -1
  108. package/themes/original/src/components/Checkout/index.tsx +114 -118
  109. package/themes/original/src/components/Checkout/styles.tsx +4 -3
  110. package/themes/original/src/components/CitiesControl/index.tsx +89 -0
  111. package/themes/original/src/components/CitiesControl/styles.tsx +17 -0
  112. package/themes/original/src/components/DriverTips/index.tsx +4 -4
  113. package/themes/original/src/components/DriverTips/styles.tsx +2 -1
  114. package/themes/original/src/components/FavoriteList/index.tsx +69 -45
  115. package/themes/original/src/components/FloatingButton/index.tsx +13 -11
  116. package/themes/original/src/components/FloatingButton/styles.tsx +1 -1
  117. package/themes/original/src/components/GPSButton/index.tsx +20 -19
  118. package/themes/original/src/components/GPSButton/styles.ts +3 -3
  119. package/themes/original/src/components/GoogleMap/index.tsx +20 -12
  120. package/themes/original/src/components/HelpAccountAndPayment/index.tsx +25 -10
  121. package/themes/original/src/components/HelpAccountAndPayment/styles.tsx +4 -0
  122. package/themes/original/src/components/HelpGuide/index.tsx +9 -8
  123. package/themes/original/src/components/HelpOrder/index.tsx +9 -8
  124. package/themes/original/src/components/LanguageSelector/index.tsx +19 -14
  125. package/themes/original/src/components/LoginForm/Otp/index.tsx +89 -73
  126. package/themes/original/src/components/LoginForm/Otp/styles.tsx +0 -1
  127. package/themes/original/src/components/LoginForm/index.tsx +98 -41
  128. package/themes/original/src/components/LottieAnimation/index.tsx +69 -0
  129. package/themes/original/src/components/Messages/index.tsx +35 -20
  130. package/themes/original/src/components/MomentOption/index.tsx +8 -6
  131. package/themes/original/src/components/MultiCart/index.tsx +63 -0
  132. package/themes/original/src/components/MultiCartsPaymethodsAndWallets/index.tsx +92 -93
  133. package/themes/original/src/components/MultiCheckout/index.tsx +10 -2
  134. package/themes/original/src/components/MultiOrdersDetails/index.tsx +34 -16
  135. package/themes/original/src/components/MyOrders/index.tsx +88 -24
  136. package/themes/original/src/components/NavBar/index.tsx +11 -5
  137. package/themes/original/src/components/NetworkError/index.tsx +5 -3
  138. package/themes/original/src/components/NotFoundSource/index.tsx +2 -1
  139. package/themes/original/src/components/Notifications/index.tsx +148 -0
  140. package/themes/original/src/components/Notifications/styles.tsx +17 -0
  141. package/themes/original/src/components/OrderDetails/index.tsx +162 -50
  142. package/themes/original/src/components/OrderDetails/styles.tsx +15 -2
  143. package/themes/original/src/components/OrderItAgain/index.tsx +75 -0
  144. package/themes/original/src/components/OrderItAgain/styles.tsx +10 -0
  145. package/themes/original/src/components/OrderProgress/index.tsx +77 -66
  146. package/themes/original/src/components/OrderProgress/styles.tsx +5 -0
  147. package/themes/original/src/components/OrderSummary/index.tsx +2 -35
  148. package/themes/original/src/components/OrderTypeSelector/index.tsx +85 -36
  149. package/themes/original/src/components/OrderTypeSelector/styles.tsx +19 -1
  150. package/themes/original/src/components/OrdersOption/PreviousBusinessOrdered/index.tsx +94 -98
  151. package/themes/original/src/components/OrdersOption/PreviousProductsOrdered/index.tsx +3 -0
  152. package/themes/original/src/components/OrdersOption/index.tsx +91 -53
  153. package/themes/original/src/components/PaymentOptionWallet/index.tsx +56 -56
  154. package/themes/original/src/components/PaymentOptions/index.tsx +1 -2
  155. package/themes/original/src/components/PhoneInputNumber/index.tsx +1 -1
  156. package/themes/original/src/components/PlaceSpot/index.tsx +249 -47
  157. package/themes/original/src/components/PlaceSpot/styles.tsx +0 -2
  158. package/themes/original/src/components/PreviousOrders/index.tsx +3 -2
  159. package/themes/original/src/components/ProductForm/index.tsx +365 -384
  160. package/themes/original/src/components/ProductForm/styles.tsx +7 -12
  161. package/themes/original/src/components/ProductItemAccordion/index.tsx +199 -128
  162. package/themes/original/src/components/ProductOption/index.tsx +1 -1
  163. package/themes/original/src/components/ProductOptionSubOption/index.tsx +16 -8
  164. package/themes/original/src/components/ProductOptionSubOption/styles.tsx +0 -1
  165. package/themes/original/src/components/ProfessionalFilter/index.tsx +2 -1
  166. package/themes/original/src/components/ProfessionalProfile/index.tsx +19 -8
  167. package/themes/original/src/components/Promotions/index.tsx +232 -219
  168. package/themes/original/src/components/Promotions/styles.tsx +7 -2
  169. package/themes/original/src/components/ReviewDriver/index.tsx +3 -3
  170. package/themes/original/src/components/ReviewOrder/index.tsx +120 -108
  171. package/themes/original/src/components/ReviewOrder/styles.tsx +5 -7
  172. package/themes/original/src/components/ReviewProducts/index.tsx +8 -5
  173. package/themes/original/src/components/ReviewTrigger/index.tsx +136 -0
  174. package/themes/original/src/components/ReviewTrigger/styles.tsx +41 -0
  175. package/themes/original/src/components/ScheduleAccordion/index.tsx +68 -0
  176. package/themes/original/src/components/ScheduleAccordion/styles.tsx +14 -0
  177. package/themes/original/src/components/ServiceForm/index.tsx +341 -267
  178. package/themes/original/src/components/SignupForm/index.tsx +160 -113
  179. package/themes/original/src/components/SingleOrderCard/index.tsx +219 -129
  180. package/themes/original/src/components/SingleOrderCard/styles.tsx +10 -8
  181. package/themes/original/src/components/SingleProductCard/index.tsx +180 -104
  182. package/themes/original/src/components/SingleProductCard/styles.tsx +3 -10
  183. package/themes/original/src/components/SingleProductReview/index.tsx +38 -5
  184. package/themes/original/src/components/SingleProductReview/styles.tsx +12 -0
  185. package/themes/original/src/components/StripeElementsForm/index.tsx +13 -2
  186. package/themes/original/src/components/UpsellingProducts/index.tsx +15 -5
  187. package/themes/original/src/components/UserDetails/index.tsx +5 -3
  188. package/themes/original/src/components/UserFormDetails/index.tsx +6 -48
  189. package/themes/original/src/components/UserProfile/index.tsx +58 -35
  190. package/themes/original/src/components/UserProfile/styles.ts +17 -0
  191. package/themes/original/src/components/WalletTransactions/index.tsx +76 -0
  192. package/themes/original/src/components/WalletTransactions/styles.tsx +13 -0
  193. package/themes/original/src/components/Wallets/index.tsx +176 -164
  194. package/themes/original/src/components/Wallets/styles.tsx +12 -8
  195. package/themes/original/src/components/shared/CardAnimation.tsx +47 -0
  196. package/themes/original/src/components/shared/HeaderTitle.tsx +8 -3
  197. package/themes/original/src/components/shared/OBottomPopup.tsx +48 -15
  198. package/themes/original/src/components/shared/OButton.tsx +10 -3
  199. package/themes/original/src/components/shared/OIcon.tsx +8 -1
  200. package/themes/original/src/components/shared/OInput.tsx +10 -1
  201. package/themes/original/src/layouts/Container.tsx +13 -9
  202. package/themes/original/src/layouts/FloatingBottomContainer.tsx +5 -1
  203. package/themes/original/src/types/index.tsx +79 -23
  204. package/themes/original/src/utils/index.tsx +103 -58
  205. package/themes/uber-eats/src/components/BusinessesListing/index.tsx +1 -1
@@ -1,15 +1,17 @@
1
1
  import React, { useState } from 'react'
2
2
  import { PromotionsController, useLanguage, useUtils } from 'ordering-components/native'
3
+ import FastImage from 'react-native-fast-image'
3
4
  import {
4
- PromotionsContainer,
5
- SingleOfferContainer,
6
- OfferInformation,
7
- SearchBarContainer,
8
- SingleBusinessOffer,
9
- AvailableBusinesses,
10
- OfferData,
11
- Code,
12
- BusinessInfo
5
+ PromotionsContainer,
6
+ SingleOfferContainer,
7
+ OfferInformation,
8
+ SearchBarContainer,
9
+ SingleBusinessOffer,
10
+ AvailableBusinesses,
11
+ OfferData,
12
+ Code,
13
+ BusinessInfo,
14
+ WrapperSingleOffer
13
15
  } from './styles'
14
16
  import { SearchBar } from '../SearchBar'
15
17
  import NavBar from '../NavBar'
@@ -18,233 +20,244 @@ import { OButton, OIcon, OModal, OText } from '../shared'
18
20
  import { Placeholder, PlaceholderLine } from 'rn-placeholder'
19
21
  import { NotFoundSource } from '../NotFoundSource'
20
22
  import { View, StyleSheet, ScrollView, Platform, RefreshControl } from 'react-native'
21
- import FastImage from 'react-native-fast-image'
22
23
  import { PromotionParams } from '../../types'
23
24
  import { Container } from '../../layouts/Container'
24
25
 
25
26
  const PromotionsUI = (props: PromotionParams) => {
26
- const {
27
- navigation,
28
- offersState,
29
- handleSearchValue,
30
- searchValue,
31
- loadOffers,
32
- offerSelected,
33
- setOfferSelected
34
- } = props
27
+ const {
28
+ navigation,
29
+ offersState,
30
+ handleSearchValue,
31
+ searchValue,
32
+ loadOffers,
33
+ offerSelected,
34
+ setOfferSelected
35
+ } = props
35
36
 
36
- const theme = useTheme();
37
+ const theme = useTheme();
37
38
 
38
- const styles = StyleSheet.create({
39
- productStyle: {
40
- width: 75,
41
- height: 75,
42
- borderRadius: 7.6
43
- },
44
- buttonStyle: {
45
- width: 55,
46
- height: 25,
47
- paddingLeft: 0,
48
- paddingRight: 0
49
- },
50
- offerTitle: {
51
- fontSize: 12
52
- },
53
- offerDescription: {
54
- color: '#909BA9',
55
- fontSize: 10
56
- },
57
- offerExtraInfo: {
58
- fontSize: 10
59
- },
60
- modalButtonStyle: {
61
- width: 100,
62
- height: 35,
63
- paddingLeft: 0,
64
- paddingRight: 0,
65
- borderRadius: 7.6
66
- }
67
- });
39
+ const styles = StyleSheet.create({
40
+ productStyle: {
41
+ width: 75,
42
+ height: 75,
43
+ borderRadius: 7.6
44
+ },
45
+ buttonStyle: {
46
+ width: '100%',
47
+ height: 35,
48
+ paddingLeft: 0,
49
+ paddingRight: 0,
50
+ borderRadius: 8
51
+ },
52
+ offerTitle: {
53
+ fontSize: 14
54
+ },
55
+ offerDescription: {
56
+ color: '#909BA9',
57
+ fontSize: 12
58
+ },
59
+ offerExtraInfo: {
60
+ fontSize: 12
61
+ },
62
+ modalButtonStyle: {
63
+ width: 100,
64
+ height: 35,
65
+ paddingLeft: 0,
66
+ paddingRight: 0,
67
+ borderRadius: 7.6
68
+ }
69
+ });
68
70
 
69
- const [, t] = useLanguage()
70
- const [{ parseDate, parsePrice, optimizeImage }] = useUtils()
71
- const [openModal, setOpenModal] = useState(false)
72
- const [refreshing] = useState(false);
71
+ const [, t] = useLanguage()
72
+ const [{ parseDate, parsePrice, optimizeImage }] = useUtils()
73
+ const [openModal, setOpenModal] = useState(false)
74
+ const [refreshing] = useState(false);
73
75
 
74
- const handleClickOffer = (offer: any) => {
75
- setOpenModal(true)
76
- setOfferSelected(offer)
77
- }
76
+ const handleClickOffer = (offer: any) => {
77
+ setOpenModal(true)
78
+ setOfferSelected(offer)
79
+ }
78
80
 
79
- const handleBusinessClick = (store: any) => {
80
- setOpenModal(false)
81
- navigation.navigate('Business', { store: store.slug })
82
- }
81
+ const handleBusinessClick = (store: any) => {
82
+ setOpenModal(false)
83
+ navigation.navigate('Business', { store: store.slug })
84
+ }
83
85
 
84
- const handleOnRefresh = () => {
85
- if (!offersState.loading) {
86
- loadOffers();
87
- }
86
+ const handleOnRefresh = () => {
87
+ if (!offersState.loading) {
88
+ loadOffers();
88
89
  }
90
+ }
89
91
 
90
- const filteredOffers = offersState?.offers?.filter((offer: any) => offer.name.toLowerCase().includes(searchValue.toLowerCase()))
91
- const targetString = offerSelected?.target === 1
92
- ? t('SUBTOTAL', 'Subtotal')
93
- : offerSelected?.target === 2
94
- ? t('DELIVERY_FEE', 'Delivery fee')
95
- : t('SERVICE_FEE', 'Service fee')
92
+ const filteredOffers = offersState?.offers?.filter((offer: any) => offer.name.toLowerCase().includes(searchValue.toLowerCase()))
93
+ const targetString = offerSelected?.target === 1
94
+ ? t('SUBTOTAL', 'Subtotal')
95
+ : offerSelected?.target === 2
96
+ ? t('DELIVERY_FEE', 'Delivery fee')
97
+ : t('SERVICE_FEE', 'Service fee')
96
98
 
97
- return (
98
- <Container
99
- noPadding
100
- refreshControl={
101
- <RefreshControl
102
- refreshing={refreshing}
103
- onRefresh={() => handleOnRefresh()}
99
+ return (
100
+ <Container
101
+ noPadding
102
+ refreshControl={
103
+ <RefreshControl
104
+ refreshing={refreshing}
105
+ onRefresh={() => handleOnRefresh()}
106
+ />
107
+ }
108
+ >
109
+ <NavBar
110
+ title={t('PROMOTIONS', 'Promotions')}
111
+ titleAlign={'center'}
112
+ onActionLeft={() => navigation.goBack()}
113
+ showCall={false}
114
+ style={{ paddingVertical: Platform.OS === 'ios' ? 0 : 20, marginLeft: 20 }}
115
+ />
116
+ <PromotionsContainer>
117
+ <SearchBarContainer>
118
+ <SearchBar
119
+ placeholder={t('SEARCH_OFFERS', 'Search offers')}
120
+ onSearch={handleSearchValue}
121
+ />
122
+ </SearchBarContainer>
123
+
124
+ {offersState?.loading && (
125
+ <>
126
+ {[...Array(5).keys()].map((key, i) => (
127
+ <Placeholder key={i} style={{ flexDirection: 'row', marginBottom: 20 }}>
128
+ <PlaceholderLine height={10} width={45} />
129
+ <PlaceholderLine height={10} width={60} />
130
+ <PlaceholderLine height={10} width={75} />
131
+ </Placeholder>
132
+ ))}
133
+ </>
134
+ )}
135
+ {((!offersState?.loading && filteredOffers?.length === 0) || offersState?.error) && (
136
+ <NotFoundSource
137
+ content={offersState?.error || t('NOT_FOUND_OFFERS', 'Not found offers')}
138
+ />
139
+ )}
140
+ <ScrollView>
141
+ {!offersState?.loading && offersState.offers?.length > 0 && filteredOffers?.map((offer: any) => (
142
+ <WrapperSingleOffer key={offer.id}>
143
+ <SingleOfferContainer>
144
+ <FastImage
145
+ style={{ height: 80, width: 80, aspectRatio: 3 / 2, borderRadius: 8 }}
146
+ source={typeof offer?.image !== 'number' ? {
147
+ uri: optimizeImage(offer?.image, 'h_1024,c_limit'),
148
+ priority: FastImage.priority.normal,
149
+ } : theme.images?.dummies?.businessLogo}
104
150
  />
105
- }
151
+ <OfferInformation>
152
+ <OText style={styles.offerTitle} numberOfLines={2}>{offer?.name}</OText>
153
+ {!!offer?.description && (
154
+ <OText style={styles.offerDescription} numberOfLines={2}>{offer?.description}</OText>
155
+ )}
156
+ <OText style={styles.offerExtraInfo}>
157
+ {t('EXPIRES', 'Expires')} {parseDate(offer?.end, { outputFormat: 'MMM DD, YYYY' })}
158
+ </OText>
159
+ <AvailableBusinesses>
160
+ <OText style={styles.offerExtraInfo} numberOfLines={1}>
161
+ {t('APPLY_FOR', 'Apply for')}:
162
+ {offer.businesses.map((business: any, i: number) => (
163
+ <React.Fragment key={i}>{' '}{business?.name}{i + 1 < offer.businesses?.length ? ',' : ''}</React.Fragment>
164
+ ))}
165
+ </OText>
166
+ </AvailableBusinesses>
167
+ </OfferInformation>
168
+ </SingleOfferContainer>
169
+ <OButton
170
+ onClick={() => handleClickOffer(offer)}
171
+ text={t('VIEW', 'View')}
172
+ style={styles.buttonStyle}
173
+ textStyle={{ fontSize: 14, color: '#fff', flexWrap: 'nowrap' }}
174
+ />
175
+ </WrapperSingleOffer>
176
+ ))}
177
+ </ScrollView>
178
+ <OModal
179
+ open={openModal}
180
+ entireModal
181
+ title={``}
182
+ onClose={() => setOpenModal(false)}
106
183
  >
107
- <NavBar
108
- title={t('PROMOTIONS', 'Promotions')}
109
- titleAlign={'center'}
110
- onActionLeft={() => navigation.goBack()}
111
- showCall={false}
112
- style={{ paddingVertical: Platform.OS === 'ios' ? 0 : 20, marginLeft: 20 }}
113
- />
114
- <PromotionsContainer>
115
- <SearchBarContainer>
116
- <SearchBar
117
- placeholder={t('SEARCH_OFFERS', 'Search offers')}
118
- onSearch={handleSearchValue}
119
- />
120
- </SearchBarContainer>
121
-
122
- {offersState?.loading && (
123
- <>
124
- {[...Array(5).keys()].map((key, i) => (
125
- <Placeholder key={i} style={{ flexDirection: 'row', marginBottom: 20 }}>
126
- <PlaceholderLine height={10} width={45} />
127
- <PlaceholderLine height={10} width={60} />
128
- <PlaceholderLine height={10} width={75} />
129
- </Placeholder>
130
- ))}
131
- </>
132
- )}
133
- {((!offersState?.loading && filteredOffers?.length === 0) || offersState?.error) && (
134
- <NotFoundSource
135
- content={offersState?.error || t('NOT_FOUND_OFFERS', 'Not found offers')}
136
- />
137
- )}
138
- <ScrollView>
139
- {!offersState?.loading && offersState.offers?.length > 0 && filteredOffers?.map((offer: any) => (
140
- <SingleOfferContainer key={offer.id}>
141
- <OfferInformation>
142
- <OText style={styles.offerTitle} numberOfLines={2}>{offer?.name}</OText>
143
- {!!offer?.description && (
144
- <OText style={styles.offerDescription} numberOfLines={2}>{offer?.description}</OText>
145
- )}
146
- <OText style={styles.offerExtraInfo}>
147
- {t('EXPIRES', 'Expires')} {parseDate(offer?.end, { outputFormat: 'MMM DD, YYYY' })}
148
- </OText>
149
- <AvailableBusinesses>
150
- <OText style={styles.offerExtraInfo} numberOfLines={1}>
151
- {t('APPLY_FOR', 'Apply for')}:
152
- {offer.businesses.map((business: any, i: number) => (
153
- <React.Fragment key={i}>{' '}{business?.name}{i + 1 < offer.businesses?.length ? ',' : ''}</React.Fragment>
154
- ))}
155
- </OText>
156
- </AvailableBusinesses>
157
- </OfferInformation>
158
- <OButton
159
- onClick={() => handleClickOffer(offer)}
160
- text={t('VIEW', 'View')}
161
- style={styles.buttonStyle}
162
- textStyle={{ fontSize: 10, color: '#fff', flexWrap: 'nowrap' }}
163
- />
164
- </SingleOfferContainer>
165
- ))}
166
- </ScrollView>
167
- <OModal
168
- open={openModal}
169
- onClose={() => setOpenModal(false)}
170
- entireModal
171
-
172
- title={``}
173
- >
174
- <View style={{ padding: 20 }}>
175
- <OText style={{ alignSelf: 'center', fontWeight: '700' }} mBottom={20}>
176
- {offerSelected?.name} / {t('VALUE_OF_OFFER', 'Value of offer')}: {offerSelected?.rate_type === 1 ? `${offerSelected?.rate}%` : `${parsePrice(offerSelected?.rate)}`}
177
- </OText>
178
- <OfferData>
179
- {offerSelected?.type === 2 && (
180
- <Code>
181
- <OText>{t('YOUR_CODE', 'Your code')}</OText>
182
- <OText color={theme.colors.primary}>{offerSelected.coupon}</OText>
183
- </Code>
184
- )}
185
- <OText>{t('APPLIES_TO', 'Applies to')}: {targetString}</OText>
186
- {offerSelected?.auto && (
187
- <OText>{t('OFFER_AUTOMATIC', 'This offer applies automatic')}</OText>
188
- )}
189
- {!!offerSelected?.minimum && (
190
- <OText>{t('MINIMUM_PURCHASE_FOR_OFFER', 'Minimum purchase for use this offer')}: {parsePrice(offerSelected?.minimum)}</OText>
191
- )}
192
- {!!offerSelected?.max_discount && (
193
- <OText>{t('MAX_DISCOUNT_ALLOWED', 'Max discount allowed')}: {parsePrice(offerSelected?.max_discount)}</OText>
194
- )}
195
- {!!offerSelected?.description && (
196
- <OText>{offerSelected?.description}</OText>
197
- )}
198
- </OfferData>
199
- <OText style={{ marginTop: 10, marginBottom: 10 }}>
200
- {t('AVAILABLE_BUSINESSES_FOR_OFFER', 'Available businesses for this offer')}:
201
- </OText>
202
- <ScrollView style={{ height: '75%' }}>
203
- {offerSelected?.businesses?.map((business: any) => {
204
- return (
205
- <SingleBusinessOffer key={business.id}>
206
- {business?.logo ? (
207
- <FastImage
208
- style={styles.productStyle}
209
- source={{
210
- uri: optimizeImage(business?.logo, 'h_250,c_limit'),
211
- priority: FastImage.priority.normal,
212
- }}
213
- resizeMode={FastImage.resizeMode.cover}
214
- />
215
- ) : (
216
- <OIcon
217
- src={theme?.images?.dummies?.product}
218
- style={styles.productStyle}
219
- />
220
- )}
221
- <BusinessInfo>
222
- <OText style={{ maxWidth: '60%' }}>{business.name}</OText>
223
- <OButton
224
- onClick={() => handleBusinessClick(business)}
225
- text={t('GO_TO_BUSINESSS', 'Go to business')}
226
- style={styles.modalButtonStyle}
227
- textStyle={{ fontSize: 10, color: '#fff' }}
228
- />
229
- </BusinessInfo>
230
- </SingleBusinessOffer>
231
- )
232
- })}
233
- </ScrollView>
234
- </View>
235
- </OModal>
236
- </PromotionsContainer>
237
- </Container>
238
- )
184
+ <View style={{ padding: 20 }}>
185
+ <OText style={{ alignSelf: 'center', fontWeight: '700' }} mBottom={20}>
186
+ {offerSelected?.name} / {t('VALUE_OF_OFFER', 'Value of offer')}: {offerSelected?.rate_type === 1 ? `${offerSelected?.rate}%` : `${parsePrice(offerSelected?.rate)}`}
187
+ </OText>
188
+ <OfferData>
189
+ {offerSelected?.type === 2 && (
190
+ <Code>
191
+ <OText>{t('YOUR_CODE', 'Your code')}</OText>
192
+ <OText color={theme.colors.primary}>{offerSelected.coupon}</OText>
193
+ </Code>
194
+ )}
195
+ <OText>{t('APPLIES_TO', 'Applies to')}: {targetString}</OText>
196
+ {offerSelected?.auto && (
197
+ <OText>{t('OFFER_AUTOMATIC', 'This offer applies automatic')}</OText>
198
+ )}
199
+ {!!offerSelected?.minimum && (
200
+ <OText>{t('MINIMUM_PURCHASE_FOR_OFFER', 'Minimum purchase for use this offer')}: {parsePrice(offerSelected?.minimum)}</OText>
201
+ )}
202
+ {!!offerSelected?.max_discount && (
203
+ <OText>{t('MAX_DISCOUNT_ALLOWED', 'Max discount allowed')}: {parsePrice(offerSelected?.max_discount)}</OText>
204
+ )}
205
+ {!!offerSelected?.description && (
206
+ <OText>{offerSelected?.description}</OText>
207
+ )}
208
+ </OfferData>
209
+ <OText style={{ marginTop: 10, marginBottom: 10 }}>
210
+ {t('AVAILABLE_BUSINESSES_FOR_OFFER', 'Available businesses for this offer')}:
211
+ </OText>
212
+ <ScrollView
213
+ showsVerticalScrollIndicator={false}
214
+ style={{ height: '75%' }}
215
+ >
216
+ {offerSelected?.businesses?.map((business: any) => {
217
+ return (
218
+ <SingleBusinessOffer key={business.id}>
219
+ {business?.logo ? (
220
+ <FastImage
221
+ style={styles.productStyle}
222
+ source={{
223
+ uri: optimizeImage(business?.logo, 'h_250,c_limit'),
224
+ priority: FastImage.priority.normal,
225
+ }}
226
+ resizeMode={FastImage.resizeMode.cover}
227
+ />
228
+ ) : (
229
+ <OIcon
230
+ src={theme?.images?.dummies?.product}
231
+ style={styles.productStyle}
232
+ />
233
+ )}
234
+ <BusinessInfo>
235
+ <OText style={{ maxWidth: '60%' }}>{business.name}</OText>
236
+ <OButton
237
+ onClick={() => handleBusinessClick(business)}
238
+ text={t('GO_TO_BUSINESSS', 'Go to business')}
239
+ style={styles.modalButtonStyle}
240
+ textStyle={{ fontSize: 10, color: '#fff' }}
241
+ />
242
+ </BusinessInfo>
243
+ </SingleBusinessOffer>
244
+ )
245
+ })}
246
+ </ScrollView>
247
+ </View>
248
+ </OModal>
249
+ </PromotionsContainer>
250
+ </Container>
251
+ )
239
252
  }
240
253
 
241
254
  export const Promotions = (props: PromotionParams) => {
242
- const PromotionsProps = {
243
- ...props,
244
- UIComponent: PromotionsUI
245
- }
255
+ const PromotionsProps = {
256
+ ...props,
257
+ UIComponent: PromotionsUI
258
+ }
246
259
 
247
- return (
248
- <PromotionsController {...PromotionsProps} />
249
- )
260
+ return (
261
+ <PromotionsController {...PromotionsProps} />
262
+ )
250
263
  }
@@ -6,18 +6,22 @@ export const PromotionsContainer = styled.View`
6
6
  padding-right: 40px;
7
7
  `
8
8
 
9
+ export const WrapperSingleOffer = styled.View`
10
+ flex-direction: column;
11
+ width: 100%;
12
+ `
13
+
9
14
  export const SingleOfferContainer = styled.View`
10
15
  flex-direction: row;
11
16
  width: 100%;
12
17
  justify-content: space-between;
13
18
  align-items: center;
14
19
  margin-bottom: 20px;
15
-
16
20
  `
17
21
 
18
22
  export const OfferInformation = styled.View`
19
23
  justify-content: space-between;
20
- max-width: 75%;
24
+ max-width: 70%;
21
25
  `
22
26
 
23
27
  export const SearchBarContainer = styled.View`
@@ -29,6 +33,7 @@ export const SearchBarContainer = styled.View`
29
33
 
30
34
  export const SingleBusinessOffer = styled.View`
31
35
  flex-direction: row;
36
+ margin-bottom: 10px;
32
37
  `
33
38
 
34
39
  export const AvailableBusinesses = styled.View`
@@ -131,7 +131,7 @@ const ReviewDriverUI = (props: ReviewDriverParams) => {
131
131
  if (!order?.user_review && !isDriverReviewed) {
132
132
  onSubmit()
133
133
  } else {
134
- onNavigationRedirect && onNavigationRedirect('MyOrders')
134
+ onNavigationRedirect('BottomTab', { screen: 'MyOrders' })
135
135
  }
136
136
  }
137
137
 
@@ -145,7 +145,7 @@ const ReviewDriverUI = (props: ReviewDriverParams) => {
145
145
  }
146
146
  if (!formState.loading && !formState.result?.error && alertState.success) {
147
147
  setIsDriverReviewed && setIsDriverReviewed(true)
148
- onNavigationRedirect('MyOrders')
148
+ onNavigationRedirect('BottomTab', { screen: 'MyOrders' })
149
149
  }
150
150
  }, [formState])
151
151
 
@@ -186,7 +186,7 @@ const ReviewDriverUI = (props: ReviewDriverParams) => {
186
186
  <NavBar
187
187
  title={t('REVIEW_DRIVER', 'Review driver')}
188
188
  titleAlign={'center'}
189
- onActionLeft={() => navigation?.canGoBack() && navigation.goBack()}
189
+ onActionLeft={() => onNavigationRedirect('BottomTab', { screen: 'MyOrders' })}
190
190
  showCall={false}
191
191
  btnStyle={{ paddingLeft: 0 }}
192
192
  style={{ flexDirection: 'column', alignItems: 'flex-start' }}