ordering-ui-react-native 0.14.98 → 0.15.0-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 (126) hide show
  1. package/package.json +6 -3
  2. package/src/DeliveryApp.tsx +32 -1
  3. package/src/components/BusinessTypeFilter/index.tsx +9 -2
  4. package/src/components/BusinessTypeFilter/styles.tsx +1 -1
  5. package/src/components/BusinessesListing/index.tsx +1 -1
  6. package/src/components/Checkout/index.tsx +0 -1
  7. package/src/components/Home/index.tsx +3 -5
  8. package/src/components/LanguageSelector/index.tsx +65 -97
  9. package/src/components/LanguageSelector/styles.tsx +4 -17
  10. package/src/components/Messages/index.tsx +38 -30
  11. package/src/components/MomentOption/index.tsx +3 -1
  12. package/src/components/OrderDetails/index.tsx +25 -4
  13. package/src/components/PaymentOptions/index.tsx +7 -16
  14. package/src/components/PaymentOptionsWebView/index.tsx +123 -124
  15. package/src/components/ProductForm/index.tsx +1 -1
  16. package/src/components/ProductForm/styles.tsx +1 -0
  17. package/src/components/StripeElementsForm/index.tsx +27 -48
  18. package/src/components/UserProfileForm/index.tsx +35 -1
  19. package/src/components/VerifyPhone/styles.tsx +1 -2
  20. package/src/config.json +0 -2
  21. package/src/pages/Checkout.tsx +1 -1
  22. package/src/types/index.tsx +2 -9
  23. package/src/utils/index.tsx +2 -1
  24. package/themes/business/index.tsx +2 -0
  25. package/themes/business/src/components/Chat/index.tsx +32 -31
  26. package/themes/business/src/components/OrderDetails/Business.tsx +1 -0
  27. package/themes/business/src/components/OrderDetails/OrderHeaderComponent.tsx +85 -17
  28. package/themes/business/src/components/OrdersListManager/index.tsx +874 -0
  29. package/themes/business/src/components/OrdersListManager/styles.tsx +123 -0
  30. package/themes/business/src/components/OrdersListManager/utils.tsx +216 -0
  31. package/themes/business/src/components/OrdersOption/index.tsx +70 -116
  32. package/themes/business/src/components/OrdersOption/styles.tsx +2 -5
  33. package/themes/business/src/components/PreviousOrders/index.tsx +82 -23
  34. package/themes/doordash/src/components/BusinessesListing/index.tsx +1 -1
  35. package/themes/doordash/src/components/LoginForm/index.tsx +1 -2
  36. package/themes/instacart/src/components/BusinessesListing/index.tsx +1 -1
  37. package/themes/kiosk/src/components/BusinessController/index.tsx +27 -6
  38. package/themes/kiosk/src/components/BusinessController/styles.tsx +1 -1
  39. package/themes/kiosk/src/components/BusinessProductsListing/index.tsx +51 -24
  40. package/themes/kiosk/src/components/Cart/index.tsx +1 -1
  41. package/themes/kiosk/src/components/CartBottomSheet/index.tsx +1 -1
  42. package/themes/kiosk/src/components/CartBottomSheet/styles.tsx +1 -1
  43. package/themes/kiosk/src/components/CartContent/index.tsx +13 -3
  44. package/themes/kiosk/src/components/CartItem/index.tsx +20 -8
  45. package/themes/kiosk/src/components/CategoriesMenu/index.tsx +7 -5
  46. package/themes/kiosk/src/components/CustomerName/index.tsx +89 -88
  47. package/themes/kiosk/src/components/Intro/index.tsx +13 -13
  48. package/themes/kiosk/src/components/LanguageSelector/index.tsx +12 -8
  49. package/themes/kiosk/src/components/NavBar/index.tsx +14 -14
  50. package/themes/kiosk/src/components/OptionCard/index.tsx +1 -1
  51. package/themes/kiosk/src/components/OrderDetails/index.tsx +2 -2
  52. package/themes/kiosk/src/components/OrderSummary/index.tsx +1 -1
  53. package/themes/kiosk/src/components/OrderTypeCardSelector/index.tsx +10 -12
  54. package/themes/kiosk/src/components/ProductForm/index.tsx +172 -124
  55. package/themes/kiosk/src/components/ProductForm/styles.tsx +1 -1
  56. package/themes/kiosk/src/components/ProductOption/index.tsx +1 -0
  57. package/themes/kiosk/src/components/ProductOption/styles.tsx +1 -0
  58. package/themes/kiosk/src/components/UpsellingProducts/index.tsx +48 -34
  59. package/themes/kiosk/src/components/shared/OButton.tsx +5 -18
  60. package/themes/kiosk/src/components/shared/OCard.tsx +112 -78
  61. package/themes/original/index.tsx +179 -2
  62. package/themes/original/src/components/AddressForm/index.tsx +15 -10
  63. package/themes/original/src/components/AddressList/index.tsx +27 -1
  64. package/themes/original/src/components/AnalyticsSegment/index.tsx +127 -0
  65. package/themes/original/src/components/BusinessBasicInformation/index.tsx +100 -45
  66. package/themes/original/src/components/BusinessBasicInformation/styles.tsx +28 -1
  67. package/themes/original/src/components/BusinessController/index.tsx +36 -22
  68. package/themes/original/src/components/BusinessMenuList/index.tsx +14 -5
  69. package/themes/original/src/components/BusinessPreorder/index.tsx +142 -121
  70. package/themes/original/src/components/BusinessProductsCategories/index.tsx +7 -5
  71. package/themes/original/src/components/BusinessProductsList/index.tsx +3 -3
  72. package/themes/original/src/components/BusinessProductsListing/index.tsx +23 -30
  73. package/themes/original/src/components/BusinessReviews/index.tsx +4 -3
  74. package/themes/original/src/components/BusinessTypeFilter/index.tsx +2 -13
  75. package/themes/original/src/components/BusinessesListing/index.tsx +41 -58
  76. package/themes/original/src/components/Cart/index.tsx +40 -7
  77. package/themes/original/src/components/CartContent/index.tsx +2 -2
  78. package/themes/original/src/components/Checkout/index.tsx +58 -33
  79. package/themes/original/src/components/Checkout/styles.tsx +7 -0
  80. package/themes/original/src/components/CouponControl/index.tsx +1 -0
  81. package/themes/original/src/components/DriverTips/index.tsx +1 -1
  82. package/themes/original/src/components/ForgotPasswordForm/index.tsx +8 -12
  83. package/themes/original/src/components/HighestRatedBusinesses/index.tsx +105 -90
  84. package/themes/original/src/components/LoginForm/index.tsx +83 -68
  85. package/themes/original/src/components/Messages/index.tsx +52 -45
  86. package/themes/original/src/components/Messages/styles.tsx +1 -3
  87. package/themes/original/src/components/MomentOption/index.tsx +127 -152
  88. package/themes/original/src/components/MomentOption/styles.tsx +42 -18
  89. package/themes/original/src/components/OrderDetails/index.tsx +102 -123
  90. package/themes/original/src/components/OrderDetails/styles.tsx +3 -1
  91. package/themes/original/src/components/OrderProgress/index.tsx +6 -7
  92. package/themes/original/src/components/OrderProgress/styles.tsx +1 -0
  93. package/themes/original/src/components/OrderSummary/index.tsx +34 -1
  94. package/themes/original/src/components/OrdersOption/index.tsx +15 -46
  95. package/themes/original/src/components/OrdersOption/styles.tsx +0 -6
  96. package/themes/original/src/components/PaymentOptionWallet/index.tsx +6 -2
  97. package/themes/original/src/components/PaymentOptions/index.tsx +24 -25
  98. package/themes/original/src/components/PhoneInputNumber/index.tsx +15 -8
  99. package/themes/original/src/components/PlaceSpot/index.tsx +114 -0
  100. package/themes/original/src/components/PlaceSpot/styles.tsx +11 -0
  101. package/themes/original/src/components/PreviousOrders/index.tsx +19 -13
  102. package/themes/original/src/components/ProductForm/index.tsx +153 -104
  103. package/themes/original/src/components/ProductForm/styles.tsx +5 -3
  104. package/themes/original/src/components/ProductOptionSubOption/index.tsx +6 -1
  105. package/themes/original/src/components/ReviewOrder/index.tsx +10 -9
  106. package/themes/original/src/components/ReviewProducts/index.tsx +1 -1
  107. package/themes/original/src/components/SearchBar/index.tsx +4 -10
  108. package/themes/original/src/components/SignupForm/index.tsx +173 -154
  109. package/themes/original/src/components/SingleProductCard/index.tsx +2 -10
  110. package/themes/original/src/components/StripeElementsForm/index.tsx +55 -72
  111. package/themes/original/src/components/UpsellingProducts/index.tsx +6 -6
  112. package/themes/original/src/components/UserDetails/index.tsx +4 -95
  113. package/themes/original/src/components/UserFormDetails/index.tsx +2 -14
  114. package/themes/original/src/components/UserProfile/index.tsx +16 -11
  115. package/themes/original/src/components/UserProfileForm/index.tsx +16 -8
  116. package/themes/original/src/components/VerifyPhone/index.tsx +10 -7
  117. package/themes/original/src/components/VerifyPhone/styles.tsx +2 -1
  118. package/themes/original/src/components/shared/HeaderTitle.tsx +21 -0
  119. package/themes/original/src/components/shared/OInput.tsx +1 -2
  120. package/themes/original/src/components/shared/index.tsx +2 -0
  121. package/themes/original/src/types/index.tsx +25 -28
  122. package/themes/single-business/src/components/OrderTypeSelector/index.tsx +5 -5
  123. package/themes/uber-eats/src/components/BusinessesListing/index.tsx +1 -1
  124. package/src/components/StripeMethodForm/index.tsx +0 -163
  125. package/themes/original/src/components/BusinessListingSearch/index.tsx +0 -469
  126. package/themes/original/src/components/BusinessListingSearch/styles.tsx +0 -76
@@ -0,0 +1,123 @@
1
+ import styled, { css } from 'styled-components/native';
2
+
3
+ export const FiltersTab = styled.View`
4
+ margin-bottom: 20px;
5
+ min-height: 30px;
6
+ max-height: 35px;
7
+ flex: 1;
8
+ width: 100%;
9
+ `
10
+
11
+ export const TabsContainer = styled.View`
12
+ display: flex;
13
+ flex-direction: row;
14
+ justify-content: space-between;
15
+ border-bottom-width: 1px;
16
+ flex: 1;
17
+ width: 100%;
18
+ border-bottom-color: ${(props: any) => props.theme.colors.tabBar};
19
+ `
20
+
21
+ export const Tag = styled.Pressable`
22
+ background-color: ${({ isSelected }: { isSelected: string }) => isSelected};
23
+ justify-content: center;
24
+ align-items: center;
25
+ min-height: 34px;
26
+ padding: 4px 10px;
27
+ border-radius: 50px;
28
+ margin-right: 15px;
29
+ `
30
+
31
+ export const IconWrapper = styled.View`
32
+ flex-direction: row;
33
+ align-items: center;
34
+ background: #fff;
35
+ `
36
+
37
+ export const ModalContainer = styled.ScrollView`
38
+ padding: 0px 30px;
39
+ `
40
+
41
+ export const ModalTitle = styled.Text`
42
+ font-family: Poppins;
43
+ font-style: normal;
44
+ font-weight: bold;
45
+ font-size: 20px;
46
+ color: ${(props: any) => props.theme.colors.textGray};
47
+ margin-bottom: 24px;
48
+ `
49
+
50
+ export const FilterBtnWrapper = styled.TouchableOpacity`
51
+ background-color: ${(props: any) => props.theme.colors.inputDisabled};
52
+ border-radius: 7.6px;
53
+ margin-vertical: 5px;
54
+ padding: 15px 20px;
55
+ flex-direction: row;
56
+ align-items: center;
57
+ justify-content: space-between;
58
+ margin-bottom: 24px;
59
+ `
60
+
61
+ export const TabPressable = styled.Pressable`
62
+ align-items: center;
63
+ border-color: ${(props: any) => props.theme.colors.textGray};
64
+ border-bottom-width: ${(props: any) => props.isSelected ? '1px' : '0px'};
65
+ padding-horizontal: 10px;
66
+ `
67
+ export const OrderStatus = styled.View`
68
+ margin-right: 5px;
69
+ width: 3px;
70
+ height: 90%;
71
+ border-radius: 6px;
72
+
73
+ ${(props: any) => props.timeState === 'in_time' && css`
74
+ background-color: #00D27A;
75
+ `}
76
+
77
+ ${(props: any) => props.timeState === 'at_risk' && css`
78
+ background-color: #FFC700;
79
+ `}
80
+
81
+ ${(props: any) => props.timeState === 'delayed' && css`
82
+ background-color: #E63757;
83
+ `}
84
+ `
85
+
86
+ export const SlaOption = styled.View`
87
+ flex-direction: row;
88
+ align-items: center;
89
+ `
90
+
91
+ export const SearchModalContent = styled.View``
92
+
93
+ export const SlaSettingModalContent = styled.View``
94
+
95
+ export const DeliveryStatusWrapper = styled.View`
96
+ position: relative;
97
+ `
98
+ export const VerticalLine = styled.View`
99
+ position: absolute;
100
+ background: #E9ECEF;
101
+ position: absolute;
102
+ width: 1px;
103
+ height: 100%;
104
+ top: 7px;
105
+ left: 7px;
106
+ `
107
+
108
+ export const Actions = styled.View``
109
+
110
+ export const Sides = styled.View`
111
+ flex-direction: row;
112
+ height: 100%;
113
+ `
114
+
115
+ export const LeftSide = styled.View`
116
+ width: 30%;
117
+ `
118
+
119
+ export const RightSide = styled.View`
120
+ width: 70%;
121
+ border-width: 2px;
122
+ border-color: ${(props: any) => props.theme.colors.gray100};
123
+ `
@@ -0,0 +1,216 @@
1
+ import React, { useState, useEffect } from 'react'
2
+ import { StyleSheet, Pressable } from 'react-native'
3
+ import { useLanguage, useUtils, useConfig } from 'ordering-components/native'
4
+ import styled, { useTheme } from 'styled-components/native'
5
+
6
+ import { OText, OIcon } from '../shared';
7
+
8
+ export const useOrderUtils = () => {
9
+ const theme = useTheme();
10
+ const [, t] = useLanguage();
11
+ const [{ parseDate }] = useUtils()
12
+
13
+ const calculateDate = (type: any, from: any, to: any) => {
14
+ switch (type) {
15
+ case 'today':
16
+ const date = parseDate(new Date(), { outputFormat: 'MM/DD/YYYY' })
17
+ return { from: `${date} 00:00:00`, to: `${date} 23:59:59` }
18
+ case 'yesterday':
19
+ const yesterday = new Date()
20
+ yesterday.setDate(yesterday.getDate() - 1)
21
+ const start1 = parseDate(yesterday, { outputFormat: 'MM/DD/YYYY' })
22
+ const end1 = parseDate(new Date(), { outputFormat: 'MM/DD/YYYY' })
23
+ return { from: `${start1} 00:00:00`, to: `${end1} 23:59:59` }
24
+ case 'last_7days':
25
+ const last_7days = new Date()
26
+ last_7days.setDate(last_7days.getDate() - 6)
27
+ const start7 = parseDate(last_7days, { outputFormat: 'MM/DD/YYYY' })
28
+ const end7 = parseDate(new Date(), { outputFormat: 'MM/DD/YYYY' })
29
+ return { from: `${start7} 00:00:00`, to: `${end7} 23:59:59` }
30
+ case 'last_30days':
31
+ const last_30days = new Date()
32
+ last_30days.setDate(last_30days.getDate() - 29)
33
+ const start30 = parseDate(last_30days, { outputFormat: 'MM/DD/YYYY' })
34
+ const end30 = parseDate(new Date(), { outputFormat: 'MM/DD/YYYY' })
35
+ return { from: `${start30} 00:00:00`, to: `${end30} 23:59:59` }
36
+ default:
37
+ const start = from ? `${parseDate(from, { outputFormat: 'MM/DD/YYYY' })} 00:00:00` : ''
38
+ const end = to ? `${parseDate(to, { outputFormat: 'MM/DD/YYYY' })} 23:59:59` : ''
39
+ return { from: start, to: end }
40
+ }
41
+ }
42
+
43
+ const preorderTypeList = [
44
+ { key: null, name: t('SLA', 'SLA\'s') },
45
+ { key: 'in_time', name: t('OK', 'Ok') },
46
+ { key: 'at_risk', name: t('AT_RISK', 'At Risk') },
47
+ { key: 'delayed', name: t('DELAYED', 'Delayed') }
48
+ ]
49
+ const defaultOrderTypes = [
50
+ { key: 1, name: t('DELIVERY', 'Delivery') },
51
+ { key: 2, name: t('PICKUP', 'Pickup') },
52
+ { key: 3, name: t('EAT_IN', 'Eat in') },
53
+ { key: 4, name: t('CURBSIDE', 'Curbside') },
54
+ { key: 5, name: t('DRIVE_THRU', 'Drive thru') }
55
+ ]
56
+
57
+ const deliveryStatus = [
58
+ {
59
+ key: t('OK', 'Ok'),
60
+ des: t('DELIVERY_OK_STATUS_DESC', 'Get delivery time from the businesses.'),
61
+ timmer: false,
62
+ icon: theme.images.general?.clock1,
63
+ backColor: '#00D27A'
64
+ },
65
+ {
66
+ key: t('AT_RISK', 'At risk'),
67
+ des: t('DELIVERY_ATRISK_STATUS_DESC', 'Is the time between delivery time of busines and the delayed time.'),
68
+ timmer: false,
69
+ icon: theme.images.general?.clockRisk,
70
+ backColor: '#FFC700'
71
+ },
72
+ {
73
+ key: t('DELAYED', 'Delayed'),
74
+ des: t('DELIVERY_DELAYED_STATUS_DESC', 'If this time is exceeded, the order will be delayed.'),
75
+ timmer: true,
76
+ icon: theme.images.general?.clockDelayed,
77
+ backColor: '#E63757'
78
+ }
79
+ ]
80
+
81
+ const defaultSearchList = {
82
+ id: '',
83
+ state: '',
84
+ city: '',
85
+ business: '',
86
+ delivery_type: '',
87
+ paymethod: '',
88
+ driver: '',
89
+ timeStatus: '',
90
+ date: {
91
+ from: '',
92
+ to: '',
93
+ type: ''
94
+ }
95
+ }
96
+
97
+ const constants = {
98
+ preorderTypeList,
99
+ defaultOrderTypes,
100
+ deliveryStatus,
101
+ defaultSearchList,
102
+ calculateDate
103
+ }
104
+
105
+ return [constants];
106
+ }
107
+
108
+ export const StatusBlock = (props: any) => {
109
+ const { item, last } = props
110
+ const [showTime, setShowTime] = useState(false)
111
+
112
+ useEffect(() => {
113
+ if (last) {
114
+ setShowTime(true)
115
+ }
116
+ }, [last])
117
+
118
+ const StatusItems = styled.View`
119
+ position: relative;
120
+ margin-bottom: 20px;
121
+ z-index: 2;
122
+ `
123
+ const ItemHeader = styled.View`
124
+ flex-direction: row;
125
+ margin-bottom: 5px;
126
+ `
127
+
128
+ const IconWrapper = styled.View`
129
+ flex-direction: row;
130
+ align-items: center;
131
+ background: #fff;
132
+ `
133
+
134
+ const ItemStatus = styled.View`
135
+ width: 4px;
136
+ height: 22px;
137
+ margin: 0 15px;
138
+ border-radius: 4px;
139
+ background: ${(props: any) => props.backColor};
140
+ `
141
+
142
+ const ItemContent = styled.View`
143
+ display: flex;
144
+ padding: 0 30px;
145
+ `
146
+
147
+ const OverLine = styled.View`
148
+ position: absolute;
149
+ height: 100%;
150
+ width: 15px;
151
+ top: 20px;
152
+ left: 0;
153
+ background-color: #fff;
154
+ z-index: 2;
155
+ `
156
+
157
+ return (
158
+ <StatusItems>
159
+ <Pressable style={{ marginBottom: 10 }}>
160
+ <ItemHeader>
161
+ <IconWrapper>
162
+ <OIcon
163
+ src={item?.icon}
164
+ width={16}
165
+ height={16}
166
+ color={item?.backColor}
167
+ />
168
+ </IconWrapper>
169
+ <ItemStatus backColor={item?.backColor} />
170
+ <OText>{item?.key}</OText>
171
+ </ItemHeader>
172
+ </Pressable>
173
+ <ItemContent>
174
+ <OText>{item?.des}</OText>
175
+ </ItemContent>
176
+ {showTime && ( <Timer /> )}
177
+ {last && ( <OverLine /> )}
178
+ </StatusItems>
179
+ )
180
+ }
181
+
182
+ export const Timer = () => {
183
+ const [, t] = useLanguage()
184
+ const theme = useTheme()
185
+ const [{ configs }] = useConfig();
186
+
187
+ const styles = StyleSheet.create({
188
+ settingTime: {
189
+ fontSize: 14,
190
+ borderWidth: 1,
191
+ borderRadius: 7.6,
192
+ margin: 0,
193
+ marginRight: 10,
194
+ paddingHorizontal: 10,
195
+ paddingTop: 5,
196
+ borderColor: theme.colors.disabled
197
+ }
198
+ })
199
+
200
+ const TimerInputWrapper = styled.View`
201
+ color: ${(props: any) => props.theme.colors.disabled};
202
+ margin-top: 15px;
203
+ margin-left: 30px;
204
+ margin-right: 30px;
205
+ flex-direction: row;
206
+ align-items: flex-end;
207
+ `
208
+
209
+ return (
210
+ <TimerInputWrapper>
211
+ <OText style={styles.settingTime} color={theme.colors.disabled}>{configs?.order_deadlines_delayed_time?.value}</OText>
212
+ <OText>{t('MIN', 'min')}</OText>
213
+ </TimerInputWrapper>
214
+ )
215
+ }
216
+
@@ -1,6 +1,6 @@
1
1
  import React, { useEffect, useState, useRef } from 'react';
2
2
  import { View, Pressable, StyleSheet, ScrollView, RefreshControl, Linking, Platform, TextInput } from 'react-native';
3
- import { useLanguage, useUtils, useToast, ToastType, OrderListGroups } from 'ordering-components/native';
3
+ import { useLanguage, useUtils, useToast, ToastType, OrderListGroups, useConfig } from 'ordering-components/native';
4
4
  import SelectDropdown from 'react-native-select-dropdown'
5
5
  import { Placeholder, PlaceholderLine, Fade } from 'rn-placeholder';
6
6
  import FeatherIcon from 'react-native-vector-icons/Feather';
@@ -110,6 +110,7 @@ const OrdersOptionUI = (props: OrdersOptionParams) => {
110
110
  const theme = useTheme();
111
111
  const [, t] = useLanguage();
112
112
  const [{ parseDate }] = useUtils()
113
+ const [configState] = useConfig()
113
114
  const [orientationState] = useDeviceOrientation();
114
115
  const [, { showToast }] = useToast();
115
116
  const [openSearchModal, setOpenSearchModal] = useState(false)
@@ -400,20 +401,6 @@ const OrdersOptionUI = (props: OrdersOptionParams) => {
400
401
  setOpenSLASettingModal(false)
401
402
  }
402
403
 
403
- const [settingTimeErrorMessage, setSettingTimeErrorMessage] = useState('')
404
-
405
- const handlSLASettingTime = () => {
406
- if (!hour || !minute) {
407
- setSettingTimeErrorMessage(t('SLA_SETTING_ERROR', 'Time value is invalid'))
408
- return
409
- }
410
- const _settingTimeSecond = hour * 3600 + minute * 60
411
- setSlaSettingTime(_settingTimeSecond)
412
- handleClose()
413
- showToast(ToastType.Success, t('SLA_SETTING_UPDATED', 'SLAs setting updated'))
414
- }
415
-
416
-
417
404
  useEffect(() => {
418
405
  setCurrentFilters(null)
419
406
  onFiltered && onFiltered(null)
@@ -453,55 +440,57 @@ const OrdersOptionUI = (props: OrdersOptionParams) => {
453
440
  />
454
441
  </IconWrapper>
455
442
  </View>
456
- <View style={styles.SLAwrapper}>
457
- <View style={{ flex: 0.5 }}>
458
- <OButton
459
- text={t('SLA_SETTING', 'SLA’s Settings')}
460
- textStyle={{ color: theme.colors.backArrow }}
461
- imgRightSrc={null}
462
- style={{
463
- backgroundColor: theme.colors.inputChat,
464
- borderRadius: 7.6,
465
- zIndex: 10,
466
- borderWidth: 0,
467
- minHeight: 40
468
- }}
469
- onClick={onClickSetting}
470
- />
471
- </View>
472
- <View style={{ width: 10, height: '100%' }} />
473
- <View style={{ flex: 0.5, justifyContent: 'center' }}>
474
- <SelectDropdown
475
- defaultButtonText={t('SLA', 'SLA\'s')}
476
- data={preorderTypeList}
477
- onSelect={(selectedItem, index) => {
478
- onFiltered && onFiltered({ ...search, timeStatus: selectedItem?.key })
479
- }}
480
- buttonTextAfterSelection={(selectedItem, index) => {
481
- return selectedItem.name
482
- }}
483
- rowTextForSelection={(item, index) => {
484
- return item.key
485
- }}
486
- buttonStyle={styles.selectOption}
487
- buttonTextStyle={styles.buttonTextStyle}
488
- renderDropdownIcon={isOpened => {
489
- return <FeatherIcon name={isOpened ? 'chevron-up' : 'chevron-down'} color={'#444'} size={18} />;
490
- }}
491
- dropdownStyle={styles.dropdownStyle}
492
- dropdownOverlayColor='transparent'
493
- rowStyle={styles.rowStyle}
494
- renderCustomizedRowChild={(item, index) => {
495
- return (
496
- <SlaOption>
497
- {index !== 0 && <OrderStatus timeState={item?.key} />}
498
- <View><OText size={14} color={'#748194'} >{item?.name}</OText></View>
499
- </SlaOption>
500
- );
501
- }}
502
- />
443
+ {configState?.configs?.order_deadlines_enabled?.value === '1' && (
444
+ <View style={styles.SLAwrapper}>
445
+ <View style={{ flex: 0.5 }}>
446
+ <OButton
447
+ text={t('SLA_SETTING', 'SLA’s Settings')}
448
+ textStyle={{ color: theme.colors.backArrow }}
449
+ imgRightSrc={null}
450
+ style={{
451
+ backgroundColor: theme.colors.inputChat,
452
+ borderRadius: 7.6,
453
+ zIndex: 10,
454
+ borderWidth: 0,
455
+ minHeight: 40
456
+ }}
457
+ onClick={onClickSetting}
458
+ />
459
+ </View>
460
+ <View style={{ width: 10, height: '100%' }} />
461
+ <View style={{ flex: 0.5, justifyContent: 'center' }}>
462
+ <SelectDropdown
463
+ defaultButtonText={t('SLA', 'SLA\'s')}
464
+ data={preorderTypeList}
465
+ onSelect={(selectedItem, index) => {
466
+ onFiltered && onFiltered({ ...search, timeStatus: selectedItem?.key })
467
+ }}
468
+ buttonTextAfterSelection={(selectedItem, index) => {
469
+ return selectedItem.name
470
+ }}
471
+ rowTextForSelection={(item, index) => {
472
+ return item.key
473
+ }}
474
+ buttonStyle={styles.selectOption}
475
+ buttonTextStyle={styles.buttonTextStyle}
476
+ renderDropdownIcon={isOpened => {
477
+ return <FeatherIcon name={isOpened ? 'chevron-up' : 'chevron-down'} color={'#444'} size={18} />;
478
+ }}
479
+ dropdownStyle={styles.dropdownStyle}
480
+ dropdownOverlayColor='transparent'
481
+ rowStyle={styles.rowStyle}
482
+ renderCustomizedRowChild={(item, index) => {
483
+ return (
484
+ <SlaOption>
485
+ {index !== 0 && <OrderStatus timeState={item?.key} />}
486
+ <View><OText size={14} color={'#748194'} >{item?.name}</OText></View>
487
+ </SlaOption>
488
+ );
489
+ }}
490
+ />
491
+ </View>
503
492
  </View>
504
- </View>
493
+ )}
505
494
  <FiltersTab>
506
495
  <ScrollView
507
496
  ref={scrollRefTab}
@@ -555,7 +544,7 @@ const OrdersOptionUI = (props: OrdersOptionParams) => {
555
544
  </TabsContainer>
556
545
  </ScrollView>
557
546
  </FiltersTab>
558
- <View style={{ flex: 1, minHeight: HEIGHT_SCREEN - 250 }}>
547
+ <View style={{ flex: 1, minHeight: HEIGHT_SCREEN - 450 }}>
559
548
  {currentTabSelected !== 'logisticOrders' && (
560
549
  <View
561
550
  style={{
@@ -645,6 +634,7 @@ const OrdersOptionUI = (props: OrdersOptionParams) => {
645
634
  getOrderStatus={getOrderStatus}
646
635
  handleClickOrder={handleClickOrder}
647
636
  slaSettingTime={slaSettingTime}
637
+ currentTabSelected={currentTabSelected}
648
638
  />
649
639
  )}
650
640
  {!logisticOrders?.error?.length &&
@@ -859,24 +849,10 @@ const OrdersOptionUI = (props: OrdersOptionParams) => {
859
849
  key={i}
860
850
  item={item}
861
851
  last={i + 1 === selectedTabStatus.length}
862
- setHour={setHour}
863
- setMinute={setMinute}
864
- setSettingTimeErrorMessage={setSettingTimeErrorMessage}
865
852
  />
866
853
  ))}
867
854
  <VerticalLine />
868
855
  </DeliveryStatusWrapper>
869
- {settingTimeErrorMessage !== '' && (
870
- <OText style={styles.errorMessage}>{settingTimeErrorMessage}</OText>
871
- )}
872
- <Actions>
873
- <OButton
874
- text={t('ACCEPT', 'Accept')}
875
- textStyle={{ color: 'white', fontSize: 14 }}
876
- onClick={handlSLASettingTime}
877
- style={styles.acceptButtonStyle}
878
- />
879
- </Actions>
880
856
  </SlaSettingModalContent>
881
857
  )}
882
858
  </ModalContainer>
@@ -887,7 +863,7 @@ const OrdersOptionUI = (props: OrdersOptionParams) => {
887
863
  };
888
864
 
889
865
  export const StatusBlock = (props: any) => {
890
- const { item, last, setHour, setMinute, setSettingTimeErrorMessage } = props
866
+ const { item, last } = props
891
867
  const [showTime, setShowTime] = useState(false)
892
868
 
893
869
  useEffect(() => {
@@ -898,7 +874,7 @@ export const StatusBlock = (props: any) => {
898
874
 
899
875
  return (
900
876
  <StatusItems>
901
- <Pressable onPress={() => setShowTime(!showTime)} style={{ marginBottom: 5 }}>
877
+ <Pressable style={{ marginBottom: 10 }}>
902
878
  <ItemHeader>
903
879
  <IconWrapper>
904
880
  <OIcon
@@ -916,11 +892,7 @@ export const StatusBlock = (props: any) => {
916
892
  <OText>{item?.des}</OText>
917
893
  </ItemContent>
918
894
  {showTime && (
919
- <Timer
920
- setHour={setHour}
921
- setMinute={setMinute}
922
- setSettingTimeErrorMessage={setSettingTimeErrorMessage}
923
- />
895
+ <Timer />
924
896
  )}
925
897
  {last && (
926
898
  <OverLine />
@@ -929,53 +901,35 @@ export const StatusBlock = (props: any) => {
929
901
  )
930
902
  }
931
903
 
932
- export const Timer = (props: any) => {
933
- const { setHour, setMinute, setSettingTimeErrorMessage } = props
904
+ export const Timer = () => {
934
905
  const [, t] = useLanguage()
935
906
  const theme = useTheme()
907
+ const [{ configs }] = useConfig();
936
908
 
937
909
  const styles = StyleSheet.create({
938
- inputStyle: {
939
- paddingHorizontal: 7,
940
- paddingVertical: 2,
941
- borderRadius: 0,
910
+ settingTime: {
942
911
  fontSize: 14,
912
+ borderWidth: 1,
913
+ borderRadius: 7.6,
914
+ margin: 0,
915
+ marginRight: 10,
916
+ paddingHorizontal: 10,
917
+ paddingTop: 5,
918
+ borderColor: theme.colors.disabled
943
919
  }
944
920
  })
945
921
 
946
- const handleChangeInput = (val: any, type: string) => {
947
- setSettingTimeErrorMessage('')
948
- if (type === 'hour') {
949
- setHour(val)
950
- }
951
- if (type === 'minute') {
952
- setMinute(val)
953
- }
954
- }
955
-
956
922
  return (
957
923
  <TimerInputWrapper>
958
- <TextInput
959
- placeholder='HH'
960
- keyboardType='number-pad'
961
- maxLength={2}
962
- style={{ ...styles.inputStyle, width: 36 }}
963
- onChangeText={hour => handleChangeInput(hour, 'hour')}
964
- />
965
- <OText color={theme.colors.disabled}>:</OText>
966
- <TextInput
967
- placeholder='MM'
968
- keyboardType='number-pad'
969
- maxLength={2}
970
- style={{ ...styles.inputStyle, width: 40 }}
971
- onChangeText={minute => handleChangeInput(minute, 'minute')}
972
- />
924
+ <OText style={styles.settingTime} color={theme.colors.disabled}>{configs?.order_deadlines_delayed_time?.value}</OText>
925
+ <OText>{t('MIN', 'min')}</OText>
973
926
  </TimerInputWrapper>
974
927
  )
975
928
  }
976
929
 
977
930
  export const OrdersOption = (props: OrdersOptionParams) => {
978
931
  const [, t] = useLanguage();
932
+ const [configState] = useConfig()
979
933
  const theme = useTheme()
980
934
  const ordersProps = {
981
935
  ...props,
@@ -130,15 +130,12 @@ export const ItemContent = styled.View`
130
130
  `
131
131
 
132
132
  export const TimerInputWrapper = styled.View`
133
- border-width: 1px;
134
- border-radius: 7.6px;
135
133
  color: ${(props: any) => props.theme.colors.disabled};
136
- border-color: ${(props: any) => props.theme.colors.disabled};
134
+ margin-top: 15px;
137
135
  margin-left: 30px;
138
136
  margin-right: 30px;
139
137
  flex-direction: row;
140
- align-items: center;
141
- width: 80px;
138
+ align-items: flex-end;
142
139
  `
143
140
  export const OverLine = styled.View`
144
141
  position: absolute;