ordering-ui-admin-external 1.43.18 → 1.43.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/_bundles/{ordering-ui-admin.f259950aaf0e426c1af6.js → ordering-ui-admin.98ea2a4af6a4bdd11f75.js} +2 -2
- package/_modules/components/Orders/AllInOne/index.js +16 -13
- package/_modules/components/Orders/DeliveryDashboard/index.js +1 -8
- package/_modules/components/Orders/OrderDashboardSLASetting/index.js +7 -3
- package/_modules/components/Orders/OrdersCards/index.js +4 -13
- package/_modules/components/Orders/OrdersCards/styles.js +12 -38
- package/_modules/components/Orders/OrdersContentHeader/index.js +14 -7
- package/_modules/components/Orders/OrdersContentHeader/styles.js +18 -11
- package/_modules/components/Orders/OrdersDashboardSLAControls/index.js +22 -2
- package/_modules/components/Orders/OrdersDashboardSLAControls/styles.js +1 -1
- package/_modules/components/Orders/OrdersHeaderFilterGroup/styles.js +3 -4
- package/_modules/components/Orders/OrdersManager/index.js +0 -7
- package/_modules/components/Orders/WebsocketStatus/index.js +1 -1
- package/package.json +2 -2
- package/src/components/Orders/AllInOne/index.js +11 -13
- package/src/components/Orders/DeliveryDashboard/index.js +0 -8
- package/src/components/Orders/OrderDashboardSLASetting/index.js +14 -8
- package/src/components/Orders/OrdersCards/index.js +4 -9
- package/src/components/Orders/OrdersCards/styles.js +2 -22
- package/src/components/Orders/OrdersContentHeader/index.js +18 -9
- package/src/components/Orders/OrdersContentHeader/styles.js +11 -5
- package/src/components/Orders/OrdersDashboardSLAControls/index.js +23 -1
- package/src/components/Orders/OrdersDashboardSLAControls/styles.js +1 -1
- package/src/components/Orders/OrdersHeaderFilterGroup/styles.js +15 -12
- package/src/components/Orders/OrdersManager/index.js +0 -8
- package/src/components/Orders/WebsocketStatus/index.js +1 -1
- /package/_bundles/{ordering-ui-admin.f259950aaf0e426c1af6.js.LICENSE.txt → ordering-ui-admin.98ea2a4af6a4bdd11f75.js.LICENSE.txt} +0 -0
|
@@ -26,10 +26,12 @@ export const OrderDashboardSLASettingUI = (props) => {
|
|
|
26
26
|
const {
|
|
27
27
|
settingsState,
|
|
28
28
|
handleInputChange,
|
|
29
|
-
handleClickUpdate
|
|
29
|
+
handleClickUpdate,
|
|
30
|
+
settingOptionOpen,
|
|
31
|
+
setSettingOptionOpen
|
|
30
32
|
} = props
|
|
31
33
|
const [, t] = useLanguage()
|
|
32
|
-
const [settingOpen, setSettingOpen] = useState(
|
|
34
|
+
const [settingOpen, setSettingOpen] = useState(settingOptionOpen)
|
|
33
35
|
const [currentTabItem, setCurrentTabItem] = useState(1)
|
|
34
36
|
const [selectedTabStatus, setSelectedTabStatus] = useState(null)
|
|
35
37
|
const theme = useTheme()
|
|
@@ -70,12 +72,14 @@ export const OrderDashboardSLASettingUI = (props) => {
|
|
|
70
72
|
|
|
71
73
|
const handleCloseSettings = () => {
|
|
72
74
|
setSettingOpen(false)
|
|
75
|
+
setSettingOptionOpen && setSettingOptionOpen(false)
|
|
73
76
|
}
|
|
74
77
|
|
|
75
78
|
const onSubmit = (data) => {
|
|
76
79
|
if (data && Object.keys(data).length > 0) {
|
|
77
80
|
handleClickUpdate()
|
|
78
81
|
setSettingOpen(false)
|
|
82
|
+
setSettingOptionOpen && setSettingOptionOpen(false)
|
|
79
83
|
}
|
|
80
84
|
}
|
|
81
85
|
|
|
@@ -110,12 +114,14 @@ export const OrderDashboardSLASettingUI = (props) => {
|
|
|
110
114
|
|
|
111
115
|
return (
|
|
112
116
|
<SettingContainer>
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
117
|
+
{!settingOptionOpen && (
|
|
118
|
+
<Button
|
|
119
|
+
color='secundary'
|
|
120
|
+
onClick={() => setSettingOpen(true)}
|
|
121
|
+
>
|
|
122
|
+
{t('SLA_SETTING', 'SLA’s settings')}
|
|
123
|
+
</Button>
|
|
124
|
+
)}
|
|
119
125
|
<Modal
|
|
120
126
|
open={settingOpen}
|
|
121
127
|
onClose={() => handleCloseSettings()}
|
|
@@ -56,11 +56,6 @@ export const OrdersCards = (props) => {
|
|
|
56
56
|
return imageKeys
|
|
57
57
|
}, {})
|
|
58
58
|
|
|
59
|
-
const filterOptions = (configState?.configs?.filter_order_options?.value.split('|').map(value => value) || [])
|
|
60
|
-
const optionsToCheck = ['external_id', 'driver', 'driver_group_general']
|
|
61
|
-
|
|
62
|
-
const matchingFilterOptions = filterOptions.filter(option => optionsToCheck.includes(option)).length
|
|
63
|
-
|
|
64
59
|
const handleChangePage = (page) => {
|
|
65
60
|
getPageOrders(pagination.pageSize, page)
|
|
66
61
|
}
|
|
@@ -185,7 +180,7 @@ export const OrdersCards = (props) => {
|
|
|
185
180
|
|
|
186
181
|
return (
|
|
187
182
|
<>
|
|
188
|
-
<OrdersListContainer
|
|
183
|
+
<OrdersListContainer>
|
|
189
184
|
{orderList.loading ? (
|
|
190
185
|
[...Array(10).keys()].map(i => (
|
|
191
186
|
<OrderCard key={i}>
|
|
@@ -261,15 +256,15 @@ export const OrdersCards = (props) => {
|
|
|
261
256
|
<p className={order?.time_status}>{displayDelayedTime(order)}</p>
|
|
262
257
|
</Timer>
|
|
263
258
|
)}
|
|
264
|
-
{
|
|
265
|
-
<div style={{paddingTop: 50}}>
|
|
259
|
+
{order?.codigoPod && (
|
|
260
|
+
<div style={{ paddingTop: 50 }}>
|
|
266
261
|
<p>
|
|
267
262
|
{
|
|
268
263
|
`${t('PODS', 'Pod')}: ${order?.codigoPod}`
|
|
269
264
|
}
|
|
270
265
|
</p>
|
|
271
266
|
</div>
|
|
272
|
-
|
|
267
|
+
)}
|
|
273
268
|
</CardHeading>
|
|
274
269
|
{isMessagesView && order?.unread_count > 0 && (
|
|
275
270
|
<UnreadMessageCounter>
|
|
@@ -1,33 +1,13 @@
|
|
|
1
1
|
import styled, { css } from 'styled-components'
|
|
2
2
|
|
|
3
|
-
const calculateHeight = (matchingFilterOptions, customMappings) => {
|
|
4
|
-
const defaultMapping = {
|
|
5
|
-
3: 'calc(100% - 410px)',
|
|
6
|
-
2: 'calc(100% - 350px)',
|
|
7
|
-
1: 'calc(100% - 280px)',
|
|
8
|
-
default: 'calc(100% - 200px)'
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
const mappings = { ...defaultMapping, ...customMappings }
|
|
12
|
-
|
|
13
|
-
return mappings[matchingFilterOptions] || mappings.default
|
|
14
|
-
}
|
|
15
|
-
|
|
16
3
|
export const OrdersListContainer = styled.div`
|
|
17
|
-
height:
|
|
4
|
+
height: calc(100% - 200px);
|
|
18
5
|
padding: 0 12px 15px 12px;
|
|
19
6
|
box-sizing: border-box;
|
|
20
7
|
overflow-x: hidden;
|
|
21
8
|
|
|
22
9
|
@media (min-width: 1024px) and (max-width: 1300px) {
|
|
23
|
-
height:
|
|
24
|
-
calculateHeight(matchingFilterOptions, {
|
|
25
|
-
3: 'calc(100% - 400px)',
|
|
26
|
-
2: 'calc(100% - 340px)',
|
|
27
|
-
1: 'calc(100% - 270px)',
|
|
28
|
-
default: 'calc(100% - 230px)'
|
|
29
|
-
}
|
|
30
|
-
)};
|
|
10
|
+
height: calc(100% - 230px);
|
|
31
11
|
}
|
|
32
12
|
`
|
|
33
13
|
export const OrderNunberContainer = styled.div`
|
|
@@ -4,13 +4,13 @@ import { SearchBar } from '../../Shared'
|
|
|
4
4
|
import { OrdersFilterGroup } from '../OrdersFilterGroup'
|
|
5
5
|
import { List as MenuIcon, LifePreserver } from 'react-bootstrap-icons'
|
|
6
6
|
import { OrdersDashboardSLAControls } from '../OrdersDashboardSLAControls'
|
|
7
|
-
import { OrderDashboardSLASetting } from '../OrderDashboardSLASetting'
|
|
8
7
|
import { IconButton } from '../../../styles'
|
|
9
8
|
import { useInfoShare } from '../../../contexts/InfoShareContext'
|
|
10
9
|
import { OverlayTrigger, Tooltip } from 'react-bootstrap'
|
|
11
10
|
import { useWindowSize } from '../../../hooks/useWindowSize'
|
|
12
11
|
import { GoogleMapsApiKeySettingButton } from '../GoogleMapsApiKeySettingButton'
|
|
13
12
|
import { WebsocketStatus } from '../WebsocketStatus'
|
|
13
|
+
import { OrdersHeaderFilterGroup } from '../OrdersHeaderFilterGroup'
|
|
14
14
|
|
|
15
15
|
import {
|
|
16
16
|
OrderContentHeaderContainer,
|
|
@@ -18,10 +18,11 @@ import {
|
|
|
18
18
|
HeaderTitle,
|
|
19
19
|
TopRightSection,
|
|
20
20
|
SLAControlsWrapper,
|
|
21
|
-
WrapperSearchAndFilter
|
|
21
|
+
WrapperSearchAndFilter,
|
|
22
|
+
WrapperHeaderFilterGroup
|
|
22
23
|
} from './styles'
|
|
23
24
|
|
|
24
|
-
export const OrdersContentHeader =
|
|
25
|
+
export const OrdersContentHeader = (props) => {
|
|
25
26
|
const {
|
|
26
27
|
isLateralBar,
|
|
27
28
|
isDisableTitle,
|
|
@@ -91,24 +92,32 @@ export const OrdersContentHeader = memo((props) => {
|
|
|
91
92
|
|
|
92
93
|
</HeaderSection>
|
|
93
94
|
)}
|
|
94
|
-
<TopRightSection isCustomLayout={isSelectedOrders}>
|
|
95
|
+
<TopRightSection isCustomLayout={isSelectedOrders} isCollapse={isCollapse}>
|
|
96
|
+
<WrapperHeaderFilterGroup>
|
|
97
|
+
<OrdersHeaderFilterGroup
|
|
98
|
+
isSelectedOrders={isSelectedOrders}
|
|
99
|
+
driverGroupList={driverGroupList}
|
|
100
|
+
driversList={driversList}
|
|
101
|
+
searchValue={searchValue}
|
|
102
|
+
handleChangeFilterValues={handleChangeFilterValues}
|
|
103
|
+
handleChangeSearch={handleChangeSearch}
|
|
104
|
+
/>
|
|
105
|
+
</WrapperHeaderFilterGroup>
|
|
95
106
|
<WebsocketStatus />
|
|
96
107
|
{isShowMapsKeySettingButton && (
|
|
97
108
|
<GoogleMapsApiKeySettingButton />
|
|
98
109
|
)}
|
|
99
110
|
{(configState?.configs?.order_deadlines_enabled?.value === '1') && (
|
|
100
111
|
<SLAControlsWrapper>
|
|
101
|
-
<OrderDashboardSLASetting
|
|
102
|
-
setSlaSettingTime={setSlaSettingTime}
|
|
103
|
-
/>
|
|
104
112
|
<OrdersDashboardSLAControls
|
|
105
113
|
setTimeStatus={setTimeStatus}
|
|
114
|
+
setSlaSettingTime={setSlaSettingTime}
|
|
106
115
|
/>
|
|
107
116
|
</SLAControlsWrapper>
|
|
108
117
|
)}
|
|
109
118
|
<WrapperSearchAndFilter
|
|
110
119
|
fullWidth={isDisableTitle}
|
|
111
|
-
|
|
120
|
+
>
|
|
112
121
|
{isShowSearchFilters && (
|
|
113
122
|
<SearchBar
|
|
114
123
|
isCustomLayout
|
|
@@ -136,4 +145,4 @@ export const OrdersContentHeader = memo((props) => {
|
|
|
136
145
|
</OrderContentHeaderContainer>
|
|
137
146
|
</>
|
|
138
147
|
)
|
|
139
|
-
}
|
|
148
|
+
}
|
|
@@ -66,8 +66,10 @@ export const HeaderTitle = styled.p`
|
|
|
66
66
|
export const TopRightSection = styled.div`
|
|
67
67
|
width: 100%;
|
|
68
68
|
display: flex;
|
|
69
|
-
flex-direction: column;
|
|
70
|
-
flex-wrap:
|
|
69
|
+
flex-direction: column-reverse;
|
|
70
|
+
flex-wrap: nowrap;
|
|
71
|
+
margin: 5px 0px 10px 15px;
|
|
72
|
+
|
|
71
73
|
${({ isCustomLayout }) => !isCustomLayout && css`
|
|
72
74
|
justify-content: flex-end;
|
|
73
75
|
`}
|
|
@@ -78,12 +80,16 @@ export const TopRightSection = styled.div`
|
|
|
78
80
|
}
|
|
79
81
|
`}
|
|
80
82
|
|
|
81
|
-
@media (min-width:
|
|
82
|
-
flex-direction: row;
|
|
83
|
-
align-items: center;
|
|
83
|
+
@media (min-width: 799px) {
|
|
84
|
+
flex-direction: ${({ isCustomLayout }) => (isCustomLayout) ? 'column-reverse' : 'row'};
|
|
85
|
+
align-items: ${({ isCustomLayout }) => (isCustomLayout) ? 'flex-start' : 'center'};
|
|
84
86
|
}
|
|
85
87
|
`
|
|
86
88
|
|
|
89
|
+
export const WrapperHeaderFilterGroup = styled.div`
|
|
90
|
+
width: 100%;
|
|
91
|
+
max-width: 850px
|
|
92
|
+
`
|
|
87
93
|
export const SLAControlsWrapper = styled.div`
|
|
88
94
|
display: flex;
|
|
89
95
|
align-items: center;
|
|
@@ -2,6 +2,7 @@ import React, { useState, useEffect } from 'react'
|
|
|
2
2
|
import { useLanguage } from 'ordering-components-admin-external'
|
|
3
3
|
|
|
4
4
|
import { Select as FirstSelect } from '../../../styles/Select/FirstSelect'
|
|
5
|
+
import { OrderDashboardSLASetting } from '../OrderDashboardSLASetting'
|
|
5
6
|
|
|
6
7
|
import {
|
|
7
8
|
OrdersDashboardSLAControlsContainer,
|
|
@@ -11,9 +12,10 @@ import {
|
|
|
11
12
|
} from './styles'
|
|
12
13
|
|
|
13
14
|
export const OrdersDashboardSLAControls = (props) => {
|
|
14
|
-
const { setTimeStatus } = props
|
|
15
|
+
const { setTimeStatus, setSlaSettingTime } = props
|
|
15
16
|
const [defaultOptionValue, setDefaultOptionValue] = useState('default')
|
|
16
17
|
const [filteredTimeStatus, setFilteredTimeStatus] = useState([])
|
|
18
|
+
const [settingOptionOpen, setSettingOptionOpen] = useState(false)
|
|
17
19
|
const [, t] = useLanguage()
|
|
18
20
|
|
|
19
21
|
const timeStatus = [
|
|
@@ -56,10 +58,23 @@ export const OrdersDashboardSLAControls = (props) => {
|
|
|
56
58
|
<p>{t('DELAYED', 'Delayed')}</p>
|
|
57
59
|
</Option>
|
|
58
60
|
)
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
value: 'sla_settings',
|
|
64
|
+
name: t('SLA_SETTING', 'SLA’s settings'),
|
|
65
|
+
content: (
|
|
66
|
+
<Option noPadding>
|
|
67
|
+
<p>{t('SLA_SETTING', 'SLA’s settings')}</p>
|
|
68
|
+
</Option>
|
|
69
|
+
)
|
|
59
70
|
}
|
|
60
71
|
]
|
|
61
72
|
|
|
62
73
|
const changeOrderTimeStatus = (val) => {
|
|
74
|
+
if (val === 'sla_settings') {
|
|
75
|
+
setSettingOptionOpen(true)
|
|
76
|
+
return
|
|
77
|
+
}
|
|
63
78
|
setDefaultOptionValue(val)
|
|
64
79
|
if (val === 'default') {
|
|
65
80
|
setTimeStatus(null)
|
|
@@ -92,6 +107,13 @@ export const OrdersDashboardSLAControls = (props) => {
|
|
|
92
107
|
handleChangeSearch={handleChangeSearch}
|
|
93
108
|
/>
|
|
94
109
|
</OrderTimeStatusSelectWrapper>
|
|
110
|
+
{settingOptionOpen && (
|
|
111
|
+
<OrderDashboardSLASetting
|
|
112
|
+
setSlaSettingTime={setSlaSettingTime}
|
|
113
|
+
settingOptionOpen={settingOptionOpen}
|
|
114
|
+
setSettingOptionOpen={setSettingOptionOpen}
|
|
115
|
+
/>
|
|
116
|
+
)}
|
|
95
117
|
</OrdersDashboardSLAControlsContainer>
|
|
96
118
|
)
|
|
97
119
|
}
|
|
@@ -2,10 +2,8 @@ import styled, { css } from 'styled-components'
|
|
|
2
2
|
|
|
3
3
|
export const WrapperRow = styled.div`
|
|
4
4
|
display: flex;
|
|
5
|
-
width: 100
|
|
6
|
-
|
|
7
|
-
justify-content: flex-start;
|
|
8
|
-
padding-top: 10px;
|
|
5
|
+
width: 100%;
|
|
6
|
+
align-items: center;
|
|
9
7
|
padding-bottom: 0px;
|
|
10
8
|
|
|
11
9
|
& > div {
|
|
@@ -13,7 +11,6 @@ export const WrapperRow = styled.div`
|
|
|
13
11
|
height: 47px;
|
|
14
12
|
max-width: 1000px;
|
|
15
13
|
margin-right: 10px;
|
|
16
|
-
margin-bottom: 20px;
|
|
17
14
|
background-color: ${props => props.theme.colors.secundary};
|
|
18
15
|
border: none;
|
|
19
16
|
font-size: 14px;
|
|
@@ -53,18 +50,24 @@ export const WrapperRow = styled.div`
|
|
|
53
50
|
|
|
54
51
|
.external_id {
|
|
55
52
|
@media (max-width: 1200px) {
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
53
|
+
flex: auto;
|
|
54
|
+
}
|
|
59
55
|
}
|
|
60
56
|
|
|
61
|
-
@media (
|
|
62
|
-
flex-direction:
|
|
57
|
+
@media (max-width: 798px) {
|
|
58
|
+
flex-direction: column !important;
|
|
59
|
+
padding: 10px 15px 0 0px;
|
|
60
|
+
& > div {
|
|
61
|
+
margin-top: 15px;
|
|
62
|
+
}
|
|
63
63
|
}
|
|
64
64
|
|
|
65
|
-
${({
|
|
65
|
+
${({ isSelectedOrders }) => isSelectedOrders && css`
|
|
66
66
|
flex-direction: column !important;
|
|
67
|
-
padding: ${!isSelectedOrders && '15px
|
|
67
|
+
padding: ${!isSelectedOrders && '10px 15px 0 0px'};
|
|
68
|
+
& > div {
|
|
69
|
+
margin-top: 15px;
|
|
70
|
+
}
|
|
68
71
|
`}
|
|
69
72
|
`
|
|
70
73
|
export const Option = styled.div`
|
|
@@ -195,14 +195,6 @@ const OrdersManagerUI = (props) => {
|
|
|
195
195
|
setSlaSettingTime={setSlaSettingTime}
|
|
196
196
|
isLateralBar={isLateralBar}
|
|
197
197
|
/>
|
|
198
|
-
<OrdersHeaderFilterGroup
|
|
199
|
-
isSelectedOrders={isSelectedOrders}
|
|
200
|
-
driverGroupList={driverGroupList}
|
|
201
|
-
driversList={driversList}
|
|
202
|
-
searchValue={searchValue}
|
|
203
|
-
handleChangeFilterValues={handleChangeFilterValues}
|
|
204
|
-
handleChangeSearch={handleChangeSearch}
|
|
205
|
-
/>
|
|
206
198
|
<OrderStatusFilterBar
|
|
207
199
|
isUseQuery={isUseQuery}
|
|
208
200
|
selectedOrderStatus={ordersStatusGroup}
|
|
@@ -72,7 +72,7 @@ const SocketStatusUI = (props) => {
|
|
|
72
72
|
onClick={() => setOpenModal(true)}
|
|
73
73
|
>
|
|
74
74
|
<StatusContainer>
|
|
75
|
-
<span>{t('
|
|
75
|
+
<span>{t('CONNECTION', 'Connection')}</span>
|
|
76
76
|
<WebsocketStatusDot
|
|
77
77
|
status={socketStatus}
|
|
78
78
|
/>
|