ordering-ui-react-native 0.14.91 → 0.14.92-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 (130) hide show
  1. package/package.json +6 -3
  2. package/src/DeliveryApp.tsx +34 -2
  3. package/src/assets/images/no-network.png +0 -0
  4. package/src/components/BusinessTypeFilter/index.tsx +9 -2
  5. package/src/components/BusinessTypeFilter/styles.tsx +1 -1
  6. package/src/components/BusinessesListing/index.tsx +1 -1
  7. package/src/components/Cart/index.tsx +1 -1
  8. package/src/components/Checkout/index.tsx +0 -1
  9. package/src/components/Home/index.tsx +3 -5
  10. package/src/components/LanguageSelector/index.tsx +65 -97
  11. package/src/components/LanguageSelector/styles.tsx +4 -17
  12. package/src/components/Messages/index.tsx +38 -30
  13. package/src/components/MomentOption/index.tsx +3 -1
  14. package/src/components/OrderDetails/index.tsx +26 -5
  15. package/src/components/PaymentOptions/index.tsx +7 -16
  16. package/src/components/PaymentOptionsWebView/index.tsx +123 -124
  17. package/src/components/ProductForm/index.tsx +1 -1
  18. package/src/components/ProductForm/styles.tsx +1 -0
  19. package/src/components/StripeElementsForm/index.tsx +27 -48
  20. package/src/components/UserProfileForm/index.tsx +35 -1
  21. package/src/components/VerifyPhone/styles.tsx +1 -2
  22. package/src/config.json +0 -2
  23. package/src/pages/Checkout.tsx +1 -1
  24. package/src/providers/AlertProvider.tsx +4 -1
  25. package/src/theme.json +2 -1
  26. package/src/types/index.tsx +2 -9
  27. package/src/utils/index.tsx +2 -1
  28. package/themes/business/index.tsx +4 -0
  29. package/themes/business/src/components/Chat/index.tsx +32 -31
  30. package/themes/business/src/components/NetworkError/index.tsx +61 -0
  31. package/themes/business/src/components/NetworkError/styles.tsx +11 -0
  32. package/themes/business/src/components/OrderDetails/Business.tsx +1 -0
  33. package/themes/business/src/components/OrderDetails/OrderHeaderComponent.tsx +85 -17
  34. package/themes/business/src/components/OrdersListManager/index.tsx +871 -0
  35. package/themes/business/src/components/OrdersListManager/styles.tsx +123 -0
  36. package/themes/business/src/components/OrdersListManager/utils.tsx +216 -0
  37. package/themes/business/src/components/OrdersOption/index.tsx +18 -68
  38. package/themes/business/src/components/OrdersOption/styles.tsx +2 -5
  39. package/themes/business/src/components/PreviousOrders/index.tsx +80 -23
  40. package/themes/business/src/types/index.tsx +4 -0
  41. package/themes/doordash/src/components/BusinessesListing/index.tsx +1 -1
  42. package/themes/doordash/src/components/LoginForm/index.tsx +1 -2
  43. package/themes/instacart/src/components/BusinessesListing/index.tsx +1 -1
  44. package/themes/kiosk/index.tsx +2 -0
  45. package/themes/kiosk/src/components/BusinessController/index.tsx +27 -6
  46. package/themes/kiosk/src/components/BusinessController/styles.tsx +1 -1
  47. package/themes/kiosk/src/components/BusinessProductsListing/index.tsx +51 -24
  48. package/themes/kiosk/src/components/Cart/index.tsx +1 -1
  49. package/themes/kiosk/src/components/CartBottomSheet/index.tsx +1 -1
  50. package/themes/kiosk/src/components/CartBottomSheet/styles.tsx +1 -1
  51. package/themes/kiosk/src/components/CartContent/index.tsx +13 -3
  52. package/themes/kiosk/src/components/CartItem/index.tsx +20 -8
  53. package/themes/kiosk/src/components/CategoriesMenu/index.tsx +7 -5
  54. package/themes/kiosk/src/components/CustomerName/index.tsx +89 -88
  55. package/themes/kiosk/src/components/Intro/index.tsx +13 -13
  56. package/themes/kiosk/src/components/LanguageSelector/index.tsx +12 -8
  57. package/themes/kiosk/src/components/NavBar/index.tsx +14 -14
  58. package/themes/kiosk/src/components/NetworkError/index.tsx +60 -0
  59. package/themes/kiosk/src/components/NetworkError/styles.tsx +11 -0
  60. package/themes/kiosk/src/components/OptionCard/index.tsx +1 -1
  61. package/themes/kiosk/src/components/OrderDetails/index.tsx +2 -2
  62. package/themes/kiosk/src/components/OrderSummary/index.tsx +1 -1
  63. package/themes/kiosk/src/components/OrderTypeCardSelector/index.tsx +10 -12
  64. package/themes/kiosk/src/components/ProductForm/index.tsx +172 -124
  65. package/themes/kiosk/src/components/ProductForm/styles.tsx +1 -1
  66. package/themes/kiosk/src/components/ProductOption/index.tsx +1 -0
  67. package/themes/kiosk/src/components/ProductOption/styles.tsx +1 -0
  68. package/themes/kiosk/src/components/UpsellingProducts/index.tsx +48 -34
  69. package/themes/kiosk/src/components/shared/OButton.tsx +5 -18
  70. package/themes/kiosk/src/components/shared/OCard.tsx +112 -78
  71. package/themes/kiosk/src/types/index.d.ts +4 -0
  72. package/themes/original/index.tsx +36 -6
  73. package/themes/original/src/components/AddressForm/index.tsx +15 -10
  74. package/themes/original/src/components/AddressList/index.tsx +27 -1
  75. package/themes/original/src/components/AnalyticsSegment/index.tsx +127 -0
  76. package/themes/original/src/components/BusinessBasicInformation/index.tsx +75 -40
  77. package/themes/original/src/components/BusinessController/index.tsx +5 -4
  78. package/themes/original/src/components/BusinessMenuList/index.tsx +4 -2
  79. package/themes/original/src/components/BusinessPreorder/index.tsx +142 -121
  80. package/themes/original/src/components/BusinessProductsCategories/index.tsx +7 -5
  81. package/themes/original/src/components/BusinessProductsList/index.tsx +51 -7
  82. package/themes/original/src/components/BusinessProductsListing/index.tsx +20 -15
  83. package/themes/original/src/components/BusinessReviews/index.tsx +4 -3
  84. package/themes/original/src/components/BusinessesListing/index.tsx +23 -22
  85. package/themes/original/src/components/Cart/index.tsx +42 -9
  86. package/themes/original/src/components/CartContent/index.tsx +2 -2
  87. package/themes/original/src/components/Checkout/index.tsx +54 -30
  88. package/themes/original/src/components/Checkout/styles.tsx +7 -0
  89. package/themes/original/src/components/CouponControl/index.tsx +1 -0
  90. package/themes/original/src/components/DriverTips/index.tsx +1 -1
  91. package/themes/original/src/components/ForgotPasswordForm/index.tsx +8 -12
  92. package/themes/original/src/components/HighestRatedBusinesses/index.tsx +9 -2
  93. package/themes/original/src/components/LoginForm/index.tsx +83 -68
  94. package/themes/original/src/components/Messages/index.tsx +24 -21
  95. package/themes/original/src/components/Messages/styles.tsx +1 -3
  96. package/themes/original/src/components/MomentOption/index.tsx +127 -152
  97. package/themes/original/src/components/MomentOption/styles.tsx +42 -18
  98. package/themes/original/src/components/NetworkError/index.tsx +61 -0
  99. package/themes/original/src/components/NetworkError/styles.tsx +11 -0
  100. package/themes/original/src/components/OrderDetails/index.tsx +103 -124
  101. package/themes/original/src/components/OrderDetails/styles.tsx +3 -1
  102. package/themes/original/src/components/OrderProgress/index.tsx +2 -3
  103. package/themes/original/src/components/OrderSummary/index.tsx +34 -1
  104. package/themes/original/src/components/OrdersOption/index.tsx +16 -40
  105. package/themes/original/src/components/OrdersOption/styles.tsx +0 -5
  106. package/themes/original/src/components/PaymentOptions/index.tsx +24 -25
  107. package/themes/original/src/components/PhoneInputNumber/index.tsx +15 -8
  108. package/themes/original/src/components/PlaceSpot/index.tsx +114 -0
  109. package/themes/original/src/components/PlaceSpot/styles.tsx +11 -0
  110. package/themes/original/src/components/PreviousOrders/index.tsx +4 -0
  111. package/themes/original/src/components/ProductForm/index.tsx +154 -105
  112. package/themes/original/src/components/ProductForm/styles.tsx +5 -3
  113. package/themes/original/src/components/ProductOptionSubOption/index.tsx +6 -1
  114. package/themes/original/src/components/SignupForm/index.tsx +173 -154
  115. package/themes/original/src/components/SingleProductCard/index.tsx +6 -13
  116. package/themes/original/src/components/SingleProductCard/styles.tsx +1 -1
  117. package/themes/original/src/components/StripeElementsForm/index.tsx +55 -72
  118. package/themes/original/src/components/UpsellingProducts/index.tsx +6 -6
  119. package/themes/original/src/components/UserDetails/index.tsx +4 -95
  120. package/themes/original/src/components/UserFormDetails/index.tsx +2 -14
  121. package/themes/original/src/components/UserProfile/index.tsx +16 -9
  122. package/themes/original/src/components/UserProfileForm/index.tsx +16 -8
  123. package/themes/original/src/components/VerifyPhone/index.tsx +10 -7
  124. package/themes/original/src/components/VerifyPhone/styles.tsx +2 -1
  125. package/themes/original/src/components/shared/HeaderTitle.tsx +20 -0
  126. package/themes/original/src/components/shared/index.tsx +2 -0
  127. package/themes/original/src/types/index.tsx +18 -8
  128. package/themes/single-business/src/components/OrderTypeSelector/index.tsx +5 -5
  129. package/themes/uber-eats/src/components/BusinessesListing/index.tsx +1 -1
  130. package/src/components/StripeMethodForm/index.tsx +0 -163
@@ -6,37 +6,61 @@ export const Container = styled.ScrollView`
6
6
  padding: 0 20px;
7
7
  padding-bottom: 20px;
8
8
  `
9
-
9
+ export const HeaderTitle = styled.View`
10
+ flex-direction: column;
11
+ margin-bottom: 20px;
12
+ `
10
13
  export const WrapSelectOption = styled.TouchableOpacity`
11
14
  flex-direction: row;
12
15
  align-items: center;
13
16
  margin-vertical: 5px;
14
17
  `
15
- export const OrderTimeWrapper = styled.View`
16
- margin-top: 34px;
18
+ export const Days = styled.View`
19
+ flex-wrap: wrap;
20
+ flex-direction: row;
21
+ margin-vertical: 10px;
17
22
  `
23
+ export const Day = styled.TouchableOpacity`
24
+ display: flex;
25
+ flex-direction: column;
26
+ align-items: center;
27
+ justify-content: center;
28
+ border-right-width: 1px;
29
+ width: 25%;
30
+ margin-vertical: 10px;
31
+ border-color: ${(props: any) => props.theme.colors.textSecondary};
18
32
 
19
- export const TimeListWrapper = styled.ScrollView`
20
- margin-top: 30px;
21
- max-height: 160px;
33
+ ${(props: any) => props.borderLeftShow && css`
34
+ border-left-width: 1px;
35
+ `}
22
36
  `
23
-
24
- export const TimeContentWrapper = styled.View`
37
+ export const WrapHours = styled.ScrollView`
38
+ border-width: 1px;
39
+ border-color: ${(props: any) => props.theme.colors.border};
40
+ border-radius: 7.6px;
41
+ margin-top: 6px;
42
+ height: 140px;
43
+ max-height: 140px;
44
+ `
45
+ export const Hours = styled.View`
25
46
  flex: 1;
26
47
  flex-wrap: wrap;
27
48
  flex-direction: row;
28
49
  justify-content: space-between;
50
+ margin: 0 20px;
29
51
  `
30
-
31
- export const TimeItem = styled.View`
32
- width: 86px;
33
- height: 34px;
34
- background: #E9ECEF;
35
- border-radius: 7.6px;
52
+ export const Hour = styled.TouchableOpacity`
53
+ flex-direction: row;
36
54
  justify-content: center;
37
55
  align-items: center;
38
- margin: 10px 0px;
39
- ${({ active }: any) => active && css`
40
- background: #F5F9FF;
41
- `}
56
+ padding: 5px;
57
+ border-width: 1px;
58
+ border-radius: 7.6px;
59
+ border-color: ${(props: any) => props.theme.colors.border};
60
+ width: 90px;
61
+ margin-vertical: 7px;
62
+ `
63
+
64
+ export const WrapDelveryTime = styled.View`
65
+ flex: 1;
42
66
  `
@@ -0,0 +1,61 @@
1
+ import React from 'react'
2
+ import { useLanguage } from 'ordering-components/native'
3
+ import { Dimensions } from 'react-native'
4
+ import RNRestart from 'react-native-restart'
5
+ import { OText, OIcon, OButton } from '../shared'
6
+ import { useTheme } from 'styled-components/native'
7
+ import { NoNetworkParams } from '../../types'
8
+ import {
9
+ Container,
10
+ ImageContainer
11
+ } from './styles'
12
+
13
+ export const NetworkError = (props: NoNetworkParams) => {
14
+ const {
15
+ image
16
+ } = props
17
+ const theme = useTheme()
18
+ const [, t] = useLanguage()
19
+
20
+ const noNetworkImage = image || theme.images.general.noNetwork
21
+ const deviceWidth = Dimensions.get('screen').width
22
+
23
+ return (
24
+ <Container>
25
+ <OText
26
+ color={theme.colors.textNormal}
27
+ size={20}
28
+ weight='700'
29
+ style={{ marginBottom: 14 }}
30
+ >
31
+ {t('MOBILE_NO_INTERNET', 'No internet connection')}
32
+ </OText>
33
+ <OText
34
+ color={theme.colors.textNormal}
35
+ size={14}
36
+ >
37
+ {t('NETWORK_OFFLINE_MESSAGE', 'Your connection appears to be off-line. Try to refresh the page')}
38
+ </OText>
39
+ <ImageContainer>
40
+ <OIcon
41
+ src={noNetworkImage}
42
+ width={(deviceWidth - 80) * 0.9}
43
+ height={(deviceWidth - 80) * 0.8}
44
+ />
45
+ <OButton
46
+ text={t('REFRESH', 'Refresh')}
47
+ bgColor={theme.colors.primary}
48
+ borderColor={theme.colors.primary}
49
+ style={{
50
+ borderRadius: 8,
51
+ marginTop: 45
52
+ }}
53
+ textStyle={{
54
+ color: theme.colors.white
55
+ }}
56
+ onClick={() => RNRestart.Restart()}
57
+ />
58
+ </ImageContainer>
59
+ </Container>
60
+ )
61
+ }
@@ -0,0 +1,11 @@
1
+ import styled from 'styled-components/native'
2
+
3
+ export const Container = styled.View`
4
+ flex: 1;
5
+ padding: 20px 40px;
6
+ `
7
+ export const ImageContainer = styled.View`
8
+ flex: 1;
9
+ align-items: center;
10
+ justify-content: center;
11
+ `
@@ -1,14 +1,11 @@
1
1
  import React, { useState, useEffect } from 'react';
2
- import { View, StyleSheet, BackHandler, KeyboardAvoidingView, Platform, Linking } from 'react-native';
3
- import Spinner from 'react-native-loading-spinner-overlay';
2
+ import { View, StyleSheet, BackHandler, Platform, Linking } from 'react-native';
4
3
  import LinearGradient from 'react-native-linear-gradient';
5
- import { Messages } from '../Messages';
6
4
  import {
7
5
  useLanguage,
8
6
  OrderDetails as OrderDetailsConTableoller,
9
7
  useUtils,
10
- useConfig,
11
- useSession,
8
+ useConfig
12
9
  } from 'ordering-components/native';
13
10
  import { useTheme } from 'styled-components/native';
14
11
  import {
@@ -16,14 +13,10 @@ import {
16
13
  Header,
17
14
  OrderContent,
18
15
  OrderBusiness,
19
- Logo,
20
16
  OrderData,
21
17
  OrderInfo,
22
- OrderStatus,
23
18
  StaturBar,
24
- StatusImage,
25
19
  OrderCustomer,
26
- CustomerPhoto,
27
20
  InfoBlock,
28
21
  HeaderInfo,
29
22
  Customer,
@@ -31,17 +24,16 @@ import {
31
24
  Table,
32
25
  OrderBill,
33
26
  Total,
34
- NavBack,
35
27
  Icons,
36
28
  OrderDriver,
37
29
  Map,
38
30
  Divider,
31
+ OrderAction
39
32
  } from './styles';
40
33
  import { OButton, OIcon, OModal, OText } from '../shared';
41
34
  import { ProductItemAccordion } from '../ProductItemAccordion';
42
35
  import { TouchableOpacity } from 'react-native-gesture-handler';
43
36
  import { OrderDetailsParams } from '../../types';
44
- import { USER_TYPE } from '../../config/constants';
45
37
  import { GoogleMap } from '../GoogleMap';
46
38
  import { verifyDecimals } from '../../utils';
47
39
  import { OSRow } from '../OrderSummary/styles';
@@ -55,9 +47,11 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
55
47
  messages,
56
48
  setMessages,
57
49
  readMessages,
58
- messagesReadList,
59
50
  isFromCheckout,
60
51
  driverLocation,
52
+ onNavigationRedirect,
53
+ reorderState,
54
+ handleReorder
61
55
  } = props;
62
56
 
63
57
  const theme = useTheme();
@@ -92,16 +86,8 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
92
86
 
93
87
  const [, t] = useLanguage();
94
88
  const [{ parsePrice, parseNumber, parseDate }] = useUtils();
95
- const [{ user }] = useSession();
96
89
  const [{ configs }] = useConfig();
97
-
98
- const [openModalForBusiness, setOpenModalForBusiness] = useState(false);
99
- const [openModalForDriver, setOpenModalForDriver] = useState(false);
100
90
  const [isReviewed, setIsReviewed] = useState(false)
101
- const [unreadAlert, setUnreadAlert] = useState({
102
- business: false,
103
- driver: false,
104
- });
105
91
  const [openTaxModal, setOpenTaxModal] = useState<any>({ open: false, tax: null, type: '' })
106
92
 
107
93
  const { order, businessData } = props.order;
@@ -293,18 +279,18 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
293
279
  percentage: 95,
294
280
  image: theme.images.order.status7,
295
281
  },
296
- {
297
- key: 22,
298
- value: t('ORDER_LOOKING_FOR_DRIVER', 'Looking for driver'),
299
- slug: 'ORDER_LOOKING_FOR_DRIVER',
300
- percentage: 35,
301
- image: theme.images.order.status8
282
+ {
283
+ key: 22,
284
+ value: t('ORDER_LOOKING_FOR_DRIVER', 'Looking for driver'),
285
+ slug: 'ORDER_LOOKING_FOR_DRIVER',
286
+ percentage: 35,
287
+ image: theme.images.order.status8
302
288
  },
303
- {
304
- key: 23,
305
- value: t('ORDER_DRIVER_ON_WAY', 'Driver on way'),
306
- slug: 'ORDER_DRIVER_ON_WAY',
307
- percentage: 45,
289
+ {
290
+ key: 23,
291
+ value: t('ORDER_DRIVER_ON_WAY', 'Driver on way'),
292
+ slug: 'ORDER_DRIVER_ON_WAY',
293
+ percentage: 45,
308
294
  image: theme.images.order.status8
309
295
  }
310
296
  ];
@@ -314,38 +300,24 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
314
300
  return objectStatus && objectStatus;
315
301
  };
316
302
 
317
- const handleOpenMessagesForBusiness = () => {
318
- setOpenModalForBusiness(true);
319
- readMessages && readMessages();
320
- setUnreadAlert({ ...unreadAlert, business: false });
321
- };
322
-
323
- const handleOpenMessagesForDriver = () => {
324
- setOpenModalForDriver(true);
303
+ const handleGoToMessages = (type: string) => {
325
304
  readMessages && readMessages();
326
- setUnreadAlert({ ...unreadAlert, driver: false });
327
- };
328
-
329
- const unreadMessages = () => {
330
- const length = messages?.messages.length;
331
- const unreadLength = order?.unread_count;
332
- const unreadedMessages = messages.messages.slice(
333
- length - unreadLength,
334
- length,
335
- );
336
- const business = unreadedMessages.some((message: any) =>
337
- message?.can_see?.includes(2),
338
- );
339
- const driver = unreadedMessages.some((message: any) =>
340
- message?.can_see?.includes(4),
341
- );
342
- setUnreadAlert({ business, driver });
343
- };
344
-
345
- const handleCloseModal = () => {
346
- setOpenModalForBusiness(false);
347
- setOpenModalForDriver(false);
348
- };
305
+ navigation.navigate(
306
+ 'MessageDetails',
307
+ {
308
+ type,
309
+ order,
310
+ messages,
311
+ setMessages,
312
+ orderId: order?.id,
313
+ business: type === 'business',
314
+ driver: type === 'driver',
315
+ onClose: () => navigation?.canGoBack()
316
+ ? navigation.goBack()
317
+ : navigation.navigate('BottomTab', { screen: 'MyOrders' }),
318
+ }
319
+ )
320
+ }
349
321
 
350
322
  const handleArrowBack: any = () => {
351
323
  if (!isFromCheckout) {
@@ -387,6 +359,16 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
387
359
  )
388
360
  }
389
361
 
362
+
363
+ useEffect(() => {
364
+ if (reorderState?.error) {
365
+ navigation.navigate('Business', { store: businessData?.slug })
366
+ }
367
+ if (!reorderState?.error && reorderState?.result?.uuid) {
368
+ onNavigationRedirect && onNavigationRedirect('CheckoutNavigator', { cartUuid: reorderState?.result.uuid })
369
+ }
370
+ }, [reorderState])
371
+
390
372
  useEffect(() => {
391
373
  BackHandler.addEventListener('hardwareBackPress', handleArrowBack);
392
374
  return () => {
@@ -394,14 +376,6 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
394
376
  };
395
377
  }, []);
396
378
 
397
- useEffect(() => {
398
- if (messagesReadList?.length) {
399
- openModalForBusiness
400
- ? setUnreadAlert({ ...unreadAlert, business: false })
401
- : setUnreadAlert({ ...unreadAlert, driver: false });
402
- }
403
- }, [messagesReadList]);
404
-
405
379
  const locations = [
406
380
  {
407
381
  ...order?.driver?.location,
@@ -430,10 +404,6 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
430
404
  }
431
405
  }, [driverLocation]);
432
406
 
433
- useEffect(() => {
434
- console.log('order: ', order)
435
- }, [order]);
436
-
437
407
  return (
438
408
  <OrderDetailsContainer keyboardShouldPersistTaps="handled">
439
409
  {(!order || Object.keys(order).length === 0) && (
@@ -481,7 +451,7 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
481
451
  <PlaceholderLine width={65} height={10} />
482
452
  <PlaceholderLine width={80} height={10} />
483
453
  <PlaceholderLine width={70} height={10} />
484
- <View style={{marginTop: 10}}>
454
+ <View style={{ marginTop: 10 }}>
485
455
  <PlaceholderLine width={60} height={20} />
486
456
  <PlaceholderLine width={40} height={10} />
487
457
  </View>
@@ -594,21 +564,23 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
594
564
  {order?.business?.name}
595
565
  </OText>
596
566
  <Icons>
597
- <TouchableOpacity
598
- onPress={() => order?.business?.cellphone &&
599
- Linking.openURL(`tel:${order?.business?.cellphone}`)
600
- }
601
- style={{ paddingEnd: 5 }}
602
- >
603
- <OIcon
604
- src={theme.images.general.phone}
605
- width={16}
606
- color={theme.colors.disabled}
607
- />
608
- </TouchableOpacity>
567
+ {!!order?.business?.cellphone && (
568
+ <TouchableOpacity
569
+ onPress={() => order?.business?.cellphone &&
570
+ Linking.openURL(`tel:${order?.business?.cellphone}`)
571
+ }
572
+ style={{ paddingEnd: 5 }}
573
+ >
574
+ <OIcon
575
+ src={theme.images.general.phone}
576
+ width={16}
577
+ color={theme.colors.disabled}
578
+ />
579
+ </TouchableOpacity>
580
+ )}
609
581
  <TouchableOpacity
610
582
  style={{ paddingStart: 5 }}
611
- onPress={() => handleOpenMessagesForBusiness()}>
583
+ onPress={() => handleGoToMessages('business')}>
612
584
  <OIcon
613
585
  src={theme.images.general.chat}
614
586
  width={16}
@@ -624,13 +596,15 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
624
596
  mBottom={2}>
625
597
  {order?.business?.email}
626
598
  </OText>
627
- <OText
628
- size={12}
629
- lineHeight={18}
630
- color={theme.colors.textNormal}
631
- mBottom={2}>
632
- {order?.business?.cellphone}
633
- </OText>
599
+ {!!order?.business?.cellphone && (
600
+ <OText
601
+ size={12}
602
+ lineHeight={18}
603
+ color={theme.colors.textNormal}
604
+ mBottom={2}>
605
+ {order?.business?.cellphone}
606
+ </OText>
607
+ )}
634
608
  <OText size={12} lineHeight={18} color={theme.colors.textNormal}>
635
609
  {order?.business?.address}
636
610
  </OText>
@@ -735,7 +709,7 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
735
709
  </OText>
736
710
  <Icons>
737
711
  <TouchableOpacity
738
- onPress={() => handleOpenMessagesForDriver()}>
712
+ onPress={() => handleGoToMessages('driver')}>
739
713
  <OIcon
740
714
  src={theme.images.general.chat}
741
715
  width={16}
@@ -776,16 +750,37 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
776
750
  'Once business accepts your order, we will send you an email, thank you!',
777
751
  )}
778
752
  </OText>
779
- <OButton
780
- text={t('YOUR_ORDERS', 'Your Orders')}
781
- textStyle={{ fontSize: 14, color: theme.colors.primary }}
782
- imgRightSrc={null}
783
- borderColor={theme.colors.primary}
784
- bgColor={theme.colors.clear}
785
- style={{ borderRadius: 7.6, borderWidth: 1, height: 44, shadowOpacity: 0 }}
786
- parentStyle={{ marginTop: 29, width: '50%' }}
787
- onClick={() => navigation.navigate('BottomTab', { screen: 'MyOrders' })}
788
- />
753
+ <OrderAction>
754
+ <OButton
755
+ text={t('YOUR_ORDERS', 'Your Orders')}
756
+ textStyle={{ fontSize: 14, color: theme.colors.primary }}
757
+ imgRightSrc={null}
758
+ borderColor={theme.colors.primary}
759
+ bgColor={theme.colors.clear}
760
+ style={{ borderRadius: 7.6, borderWidth: 1, height: 44, shadowOpacity: 0 }}
761
+ parentStyle={{ marginTop: 29, marginEnd: 15 }}
762
+ onClick={() => navigation.navigate('BottomTab', { screen: 'MyOrders' })}
763
+ />
764
+ {(
765
+ parseInt(order?.status) === 1 ||
766
+ parseInt(order?.status) === 2 ||
767
+ parseInt(order?.status) === 5 ||
768
+ parseInt(order?.status) === 6 ||
769
+ parseInt(order?.status) === 10 ||
770
+ parseInt(order?.status) === 11 ||
771
+ parseInt(order?.status) === 12
772
+ ) && (
773
+ <OButton
774
+ text={order.id === reorderState?.loading ? t('LOADING', 'Loading..') : t('REORDER', 'Reorder')}
775
+ textStyle={{ fontSize: 14, color: theme.colors.primary }}
776
+ imgRightSrc={null}
777
+ borderColor='transparent'
778
+ bgColor={theme.colors.primary + 10}
779
+ style={{ borderRadius: 7.6, borderWidth: 1, height: 44, shadowOpacity: 0, marginTop: 29 }}
780
+ onClick={() => handleReorder && handleReorder(order.id)}
781
+ />
782
+ )}
783
+ </OrderAction>
789
784
  </HeaderInfo>
790
785
  <OrderProducts>
791
786
  {order?.products?.length &&
@@ -895,7 +890,7 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
895
890
  <OSRow>
896
891
  <OText size={12} lineHeight={18} weight={'400'} color={theme.colors.textNormal} numberOfLines={1}>
897
892
  {fee.name || t('INHERIT_FROM_BUSINESS', 'Inherit from business')}
898
- ({parsePrice(fee?.fixed)} + {fee.percentage}%){' '}
893
+ ({fee?.fixed > 0 && `${parsePrice(fee?.fixed)} + `}{fee.percentage}%){' '}
899
894
  </OText>
900
895
  <TouchableOpacity onPress={() => setOpenTaxModal({ open: true, data: fee, type: 'fee' })}>
901
896
  <AntIcon name='infocirlceo' size={16} color={theme.colors.primary} />
@@ -978,7 +973,7 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
978
973
  marginTop: 10
979
974
  }}
980
975
  >
981
- {order?.payment_events?.map((event: any) => (
976
+ {order?.payment_events?.map((event: any) => event.amount > 0 && (
982
977
  <View
983
978
  key={event.id}
984
979
  style={{
@@ -1018,22 +1013,6 @@ export const OrderDetailsUI = (props: OrderDetailsParams) => {
1018
1013
  </OrderContent>
1019
1014
  </>
1020
1015
  )}
1021
- <OModal
1022
- open={openModalForBusiness || openModalForDriver}
1023
- entireModal
1024
- customClose
1025
- onClose={() => handleCloseModal()}>
1026
- <Messages
1027
- type={openModalForBusiness ? USER_TYPE.BUSINESS : USER_TYPE.DRIVER}
1028
- orderId={order?.id}
1029
- messages={messages}
1030
- order={order}
1031
- business={openModalForBusiness}
1032
- driver={openModalForDriver}
1033
- setMessages={setMessages}
1034
- onClose={handleCloseModal}
1035
- />
1036
- </OModal>
1037
1016
  <OModal
1038
1017
  open={openTaxModal.open}
1039
1018
  onClose={() => setOpenTaxModal({ open: false, data: null, type: '' })}
@@ -5,7 +5,6 @@ export const OrderDetailsContainer = styled.ScrollView`
5
5
  `
6
6
 
7
7
  export const NavBack = styled.TouchableOpacity`
8
-
9
8
  `
10
9
 
11
10
 
@@ -125,3 +124,6 @@ export const Divider = styled.View`
125
124
  margin-top: 5px;
126
125
  margin-bottom: 5px;
127
126
  `
127
+ export const OrderAction = styled.View`
128
+ flex-direction: row;
129
+ `
@@ -9,7 +9,7 @@ import IconAntDesign from 'react-native-vector-icons/AntDesign'
9
9
  import moment from 'moment';
10
10
  import { OText } from '../shared'
11
11
  import { NotFoundSource } from '../NotFoundSource'
12
- import { View, StyleSheet, TouchableOpacity } from 'react-native'
12
+ import { View, StyleSheet, TouchableOpacity, Platform } from 'react-native'
13
13
  import { Placeholder, Fade, PlaceholderLine } from "rn-placeholder";
14
14
  import FastImage from 'react-native-fast-image'
15
15
  import {
@@ -19,7 +19,6 @@ import {
19
19
  ProgressTextWrapper,
20
20
  OrderInfoWrapper
21
21
  } from './styles'
22
-
23
22
  const OrderProgressUI = (props: any) => {
24
23
  const {
25
24
  orderList,
@@ -139,7 +138,7 @@ const OrderProgressUI = (props: any) => {
139
138
  return (
140
139
  <>
141
140
  {orderList?.loading && (
142
- <Placeholder Animation={Fade} height={158}>
141
+ <Placeholder Animation={Fade} height={Platform.OS === 'ios' ? 147.5 : 158}>
143
142
  <PlaceholderLine height={60} style={{ borderRadius: 8, marginBottom: 10 }} />
144
143
  <PlaceholderLine height={20} style={{ marginBottom: 10 }} />
145
144
  <PlaceholderLine height={40} style={{ borderRadius: 8, marginBottom: 10 }} />
@@ -26,6 +26,7 @@ import AntIcon from 'react-native-vector-icons/AntDesign'
26
26
  import { TaxInformation } from '../TaxInformation';
27
27
  import { TouchableOpacity } from 'react-native';
28
28
  import { OAlert } from '../../../../../src/components/shared'
29
+ import { PlaceSpot } from '../PlaceSpot'
29
30
 
30
31
  const OrderSummaryUI = (props: any) => {
31
32
  const {
@@ -49,7 +50,9 @@ const OrderSummaryUI = (props: any) => {
49
50
  const [validationFields] = useValidationFields();
50
51
  const [openTaxModal, setOpenTaxModal] = useState<any>({ open: false, data: null, type: '' })
51
52
  const [confirm, setConfirm] = useState<any>({ open: false, content: null, handleOnAccept: null, id: null, title: null })
53
+ const [openPlaceModal, setOpenPlaceModal] = useState(false)
52
54
  const isCouponEnabled = validationFields?.fields?.checkout?.coupon?.enabled;
55
+ const placeSpotTypes = [3, 4]
53
56
 
54
57
  const handleDeleteClick = (product: any) => {
55
58
  removeProduct(product, cart)
@@ -199,7 +202,7 @@ const OrderSummaryUI = (props: any) => {
199
202
  <OSRow>
200
203
  <OText size={12} numberOfLines={1}>
201
204
  {fee.name || t('INHERIT_FROM_BUSINESS', 'Inherit from business')}{' '}
202
- ({parsePrice(fee?.fixed)} + {fee?.percentage}%){' '}
205
+ ({fee?.fixed > 0 && `${parsePrice(fee?.fixed)} + `}{fee.percentage}%)
203
206
  </OText>
204
207
  <TouchableOpacity onPress={() => setOpenTaxModal({ open: true, data: fee, type: 'fee' })} >
205
208
  <AntIcon name='infocirlceo' size={16} color={theme.colors.primary} />
@@ -301,6 +304,24 @@ const OrderSummaryUI = (props: any) => {
301
304
  </OSTable>
302
305
  </View>
303
306
  )}
307
+ {placeSpotTypes.includes(orderState?.options?.type) && (
308
+ <OSTable style={{ marginTop: 15 }}>
309
+ <OText size={14} lineHeight={21} weight={'600'}>
310
+ {t('SPOT', 'Spot')}: {cart?.place?.name || t('NO_SELECTED', 'No selected')}
311
+ </OText>
312
+ <TouchableOpacity onPress={() => setOpenPlaceModal(true)}>
313
+ <OText
314
+ size={14}
315
+ lineHeight={21}
316
+ weight={'600'}
317
+ color={theme.colors.primary}
318
+ style={{ textDecorationLine: 'underline' }}
319
+ >
320
+ {t('EDIT', 'Edit')}
321
+ </OText>
322
+ </TouchableOpacity>
323
+ </OSTable>
324
+ )}
304
325
  {cart?.status !== 2 && (
305
326
  <OSTable>
306
327
  <View style={{ width: '100%', marginTop: 20 }}>
@@ -349,6 +370,18 @@ const OrderSummaryUI = (props: any) => {
349
370
  products={cart?.products}
350
371
  />
351
372
  </OModal>
373
+ <OModal
374
+ open={openPlaceModal}
375
+ title={t('CHOOSE_YOUR_SPOT', 'Choose your spot')}
376
+ onClose={() => setOpenPlaceModal(false)}
377
+ entireModal
378
+ >
379
+ <PlaceSpot
380
+ cart={cart}
381
+ isOpenPlaceSpot={openPlaceModal}
382
+ setOpenPlaceModal={setOpenPlaceModal}
383
+ />
384
+ </OModal>
352
385
  <OAlert
353
386
  open={confirm.open}
354
387
  title={confirm.title}