@kmkf-fe-packages/kmkf-work-order-service-component 2.2.4 → 2.2.5-beta.0
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/dist/esm/CustomerServiceToDoList/index.d.ts +3 -0
- package/dist/esm/CustomerServiceToDoList/index.js +155 -0
- package/dist/esm/CustomerServiceToDoList/index.module.less +134 -0
- package/dist/esm/FlowTemplateDetailV2/common.js +1 -0
- package/dist/esm/FlowTemplateDetailV2/components/ActionList/index.d.ts +2 -0
- package/dist/esm/FlowTemplateDetailV2/components/ActionList/index.js +50 -8
- package/dist/esm/FlowTemplateDetailV2/components/FormRender/index.js +66 -17
- package/dist/esm/FlowTemplateDetailV2/components/FormRender/onBlur.d.ts +12 -0
- package/dist/esm/FlowTemplateDetailV2/components/FormRender/onBlur.js +176 -44
- package/dist/esm/FlowTemplateDetailV2/components/Header/index.js +5 -2
- package/dist/esm/FlowTemplateDetailV2/components/ShareLinkModal/index.d.ts +4 -0
- package/dist/esm/FlowTemplateDetailV2/components/ShareLinkModal/index.js +211 -0
- package/dist/esm/FlowTemplateDetailV2/components/ShareLinkModal/index.module.less +29 -0
- package/dist/esm/FlowTemplateDetailV2/constant.js +9 -1
- package/dist/esm/FlowTemplateDetailV2/index.js +151 -78
- package/dist/esm/FlowTemplateDetailV2/store/reducers.d.ts +8 -0
- package/dist/esm/FlowTemplateDetailV2/store/reducers.js +152 -54
- package/dist/esm/FlowTemplateDetailV2/store/selector.d.ts +3 -0
- package/dist/esm/FlowTemplateDetailV2/store/selector.js +9 -0
- package/dist/esm/FlowTemplateDetailV2/type.d.ts +1 -1
- package/dist/esm/Login/index.d.ts +1 -0
- package/dist/esm/Login/index.js +3 -1
- package/dist/esm/LoginNew/index.d.ts +8 -0
- package/dist/esm/LoginNew/index.js +268 -0
- package/dist/esm/LoginNew/index.module.less +45 -0
- package/dist/esm/WorkOrder/components/CustomerServiceToDoCard/index.d.ts +3 -0
- package/dist/esm/WorkOrder/components/CustomerServiceToDoCard/index.js +76 -0
- package/dist/esm/WorkOrder/components/CustomerServiceToDoCard/index.module.less +20 -0
- package/dist/esm/WorkOrder/components/WorkOrderList/components/CustomizeWorkOrderCard/index.js +6 -0
- package/dist/esm/WorkOrder/components/WorkOrderList/index.js +12 -3
- package/dist/esm/WorkOrder/components/WorkOrderList/index.less +4 -3
- package/dist/esm/WorkOrder/index.js +21 -1
- package/dist/esm/common/constant.d.ts +5 -0
- package/dist/esm/common/constant.js +3 -2
- package/dist/esm/common/imgs/ai.png +0 -0
- package/dist/esm/common/imgs/notification.png +0 -0
- package/dist/esm/common/utils/constant.d.ts +3 -0
- package/dist/esm/common/utils/constant.js +33 -2
- package/dist/esm/common/utils/submitDataTransOldFormat.js +146 -79
- package/dist/esm/common/utils/tools.d.ts +1 -0
- package/dist/esm/common/utils/tools.js +145 -48
- package/dist/esm/common/utils/tools_constants.js +21 -2
- package/dist/esm/common/utils/transformWorkOrderData.js +99 -19
- package/dist/esm/common/utils/xzSDK.d.ts +2 -0
- package/dist/esm/common/utils/xzSDK.js +45 -1
- package/dist/esm/index.d.ts +2 -0
- package/dist/esm/index.js +2 -0
- package/dist/esm/model/customizeWorkOrder/index.d.ts +1 -1
- package/dist/esm/model/customizeWorkOrder/index.js +17 -3
- package/dist/esm/model/customizeWorkOrder/types.d.ts +2 -0
- package/dist/esm/model/flowTemplateDetail/api.d.ts +5 -0
- package/dist/esm/model/flowTemplateDetail/api.js +40 -0
- package/dist/esm/model/flowTemplateDetail/types.d.ts +4 -0
- package/dist/esm/model/logicFlow/selector.d.ts +3 -0
- package/dist/esm/model/login.d.ts +10 -0
- package/dist/esm/model/login.js +66 -45
- package/dist/esm/model/paymentWorkOrder/selector.d.ts +9 -0
- package/dist/esm/model/servers/api.d.ts +5 -0
- package/dist/esm/model/servers/api.js +37 -3
- package/dist/esm/model/singleShopWorkOrder/selector.d.ts +5 -0
- package/package.json +6 -5
- package/dist/esm/GlobalContext/hook/dist/useGetHasErpData.js +0 -52
- package/dist/esm/GlobalContext/orderQuery/dist/useGetErpAddressData.js +0 -180
- package/dist/esm/GlobalContext/orderQuery/dist/useGetErpLogisticsCompany.js +0 -186
- package/dist/esm/common/utils/dist/submitDataTransOldFormat.js +0 -899
- package/dist/esm/common/utils/dist/tools.js +0 -1326
- package/dist/esm/common/utils/dist/transformWorkOrderData.js +0 -965
- package/dist/esm/model/customizeWorkOrder/dist/api.js +0 -48
- package/dist/esm/model/customizeWorkOrder/dist/index.js +0 -370
- package/dist/esm/model/customizeWorkOrder/dist/selector.js +0 -63
- package/dist/esm/model/customizeWorkOrder/dist/types.js +0 -3
- package/dist/esm/model/dist/global.js +0 -44
- package/dist/esm/model/dist/hooks.js +0 -15
- package/dist/esm/model/dist/login.js +0 -245
- package/dist/esm/model/dist/store.js +0 -30
- package/dist/esm/model/dist/userData.js +0 -41
- package/dist/esm/model/dist/workOrder.js +0 -329
- package/dist/esm/model/flowTemplateDetail/dist/api.js +0 -192
- package/dist/esm/model/flowTemplateDetail/dist/types.js +0 -48
- package/dist/esm/model/logicFlow/dist/api.js +0 -14
- package/dist/esm/model/logicFlow/dist/index.js +0 -235
- package/dist/esm/model/logicFlow/dist/selector.js +0 -18
- package/dist/esm/model/logicFlow/dist/types.js +0 -3
- package/dist/esm/model/paymentWorkOrder/dist/index.js +0 -77
- package/dist/esm/model/paymentWorkOrder/dist/selector.js +0 -36
- package/dist/esm/model/paymentWorkOrder/dist/types.js +0 -3
- package/dist/esm/model/servers/dist/api.js +0 -545
- package/dist/esm/model/servers/dist/request.js +0 -63
- package/dist/esm/model/singleShopWorkOrder/dist/index.js +0 -216
- package/dist/esm/model/singleShopWorkOrder/dist/selector.js +0 -24
- package/dist/esm/model/singleShopWorkOrder/dist/types.js +0 -3
- package/dist/esm/model/types/dist/login.js +0 -3
- package/dist/esm/model/types/dist/singleWorkOrder.js +0 -3
- package/dist/esm/model/types/dist/workOrder.js +0 -3
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import { Button, Card, Tag, Badge, Spin, Empty } from 'antd';
|
|
2
|
+
import React, { useRef, useEffect } from 'react';
|
|
3
|
+
import { useInfiniteScroll } from 'ahooks';
|
|
4
|
+
import { CloseOutlined } from '@ant-design/icons';
|
|
5
|
+
import { useAppDispatch, useAppSelector } from "../model/hooks";
|
|
6
|
+
import { nodeWorkOrderPending } from "../model/servers/api";
|
|
7
|
+
import moment from 'moment';
|
|
8
|
+
import { setWorkOrderProcessStatus } from "../model/customizeWorkOrder";
|
|
9
|
+
import { WORK_ORDER_STATUS_AI_BUILD } from "../common/constant";
|
|
10
|
+
import styles from "./index.module.less";
|
|
11
|
+
var getTableData = function getTableData(params) {
|
|
12
|
+
return nodeWorkOrderPending(params).then(function (res) {
|
|
13
|
+
var _res$data, _res$data2;
|
|
14
|
+
// console.log('API response:', res?.data);
|
|
15
|
+
return {
|
|
16
|
+
list: (res === null || res === void 0 ? void 0 : (_res$data = res.data) === null || _res$data === void 0 ? void 0 : _res$data.list) || [],
|
|
17
|
+
total: (res === null || res === void 0 ? void 0 : (_res$data2 = res.data) === null || _res$data2 === void 0 ? void 0 : _res$data2.total) || 0
|
|
18
|
+
};
|
|
19
|
+
}).catch(function (error) {
|
|
20
|
+
console.error('API error:', error);
|
|
21
|
+
return {
|
|
22
|
+
list: [],
|
|
23
|
+
total: 0
|
|
24
|
+
};
|
|
25
|
+
});
|
|
26
|
+
};
|
|
27
|
+
var CustomerServiceToDoList = function CustomerServiceToDoList(props) {
|
|
28
|
+
var _ref, _data$list;
|
|
29
|
+
var shopUniqueKey = props.shopUniqueKey;
|
|
30
|
+
var dispatch = useAppDispatch();
|
|
31
|
+
var workOrderProcessStatus = useAppSelector(function (state) {
|
|
32
|
+
var _state$customizeWorkO;
|
|
33
|
+
return (_state$customizeWorkO = state.customizeWorkOrder) === null || _state$customizeWorkO === void 0 ? void 0 : _state$customizeWorkO.workOrderProcessStatus;
|
|
34
|
+
});
|
|
35
|
+
var containerRef = useRef(null);
|
|
36
|
+
var _useInfiniteScroll = useInfiniteScroll(function (d) {
|
|
37
|
+
var page = d ? Math.ceil(d.list.length / 10) + 1 : 1;
|
|
38
|
+
return getTableData({
|
|
39
|
+
pageNo: page,
|
|
40
|
+
pageSize: 10,
|
|
41
|
+
onlyWaitForMe: true,
|
|
42
|
+
onlyCount: false,
|
|
43
|
+
onlyStartNode: true,
|
|
44
|
+
flowTags: ['AI_BUILD'],
|
|
45
|
+
shopUniqueKeyList: [shopUniqueKey]
|
|
46
|
+
});
|
|
47
|
+
}, {
|
|
48
|
+
target: containerRef,
|
|
49
|
+
reloadDeps: [],
|
|
50
|
+
// 添加空的 reloadDeps 避免不必要的重新加载
|
|
51
|
+
isNoMore: function isNoMore(d) {
|
|
52
|
+
var _d$list;
|
|
53
|
+
return (d === null || d === void 0 ? void 0 : d.total) <= (d === null || d === void 0 ? void 0 : (_d$list = d.list) === null || _d$list === void 0 ? void 0 : _d$list.length);
|
|
54
|
+
}
|
|
55
|
+
}),
|
|
56
|
+
data = _useInfiniteScroll.data,
|
|
57
|
+
loading = _useInfiniteScroll.loading,
|
|
58
|
+
reload = _useInfiniteScroll.reload,
|
|
59
|
+
noMore = _useInfiniteScroll.noMore;
|
|
60
|
+
var handleProcess = function handleProcess(item) {
|
|
61
|
+
dispatch({
|
|
62
|
+
type: 'customizeWorkOrder/setCurrentCustomizeRecord',
|
|
63
|
+
payload: {
|
|
64
|
+
flowTemplateName: item === null || item === void 0 ? void 0 : item.flowTemplateName
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
dispatch({
|
|
68
|
+
type: 'customizeWorkOrder/setLogicFlowId',
|
|
69
|
+
payload: item.flowTemplateKey
|
|
70
|
+
});
|
|
71
|
+
dispatch({
|
|
72
|
+
type: 'customizeWorkOrder/setFlowWorkOrderId',
|
|
73
|
+
payload: item.flowWorkOrderId
|
|
74
|
+
});
|
|
75
|
+
dispatch({
|
|
76
|
+
type: 'customizeWorkOrder/setFormModalVisible',
|
|
77
|
+
payload: true
|
|
78
|
+
});
|
|
79
|
+
};
|
|
80
|
+
var onCancel = function onCancel() {
|
|
81
|
+
dispatch({
|
|
82
|
+
type: 'customizeWorkOrder/setCustomerServiceToDoListOpen',
|
|
83
|
+
payload: false
|
|
84
|
+
});
|
|
85
|
+
};
|
|
86
|
+
useEffect(function () {
|
|
87
|
+
reload();
|
|
88
|
+
}, []);
|
|
89
|
+
useEffect(function () {
|
|
90
|
+
if (['submit'].includes(workOrderProcessStatus)) {
|
|
91
|
+
reload();
|
|
92
|
+
dispatch(setWorkOrderProcessStatus(''));
|
|
93
|
+
}
|
|
94
|
+
}, [workOrderProcessStatus, dispatch]);
|
|
95
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
96
|
+
className: styles.container,
|
|
97
|
+
onClick: onCancel
|
|
98
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
99
|
+
className: styles.todoSection,
|
|
100
|
+
onClick: function onClick(e) {
|
|
101
|
+
return e.stopPropagation();
|
|
102
|
+
}
|
|
103
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
104
|
+
className: styles.todoTabs
|
|
105
|
+
}, /*#__PURE__*/React.createElement(Badge, {
|
|
106
|
+
count: data === null || data === void 0 ? void 0 : data.total
|
|
107
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
108
|
+
className: styles.todoTab
|
|
109
|
+
}, "\u5BA2\u670D\u5F85\u529E")), /*#__PURE__*/React.createElement(CloseOutlined, {
|
|
110
|
+
onClick: onCancel
|
|
111
|
+
})), /*#__PURE__*/React.createElement("main", {
|
|
112
|
+
className: styles.todoList,
|
|
113
|
+
ref: containerRef
|
|
114
|
+
}, ((data === null || data === void 0 ? void 0 : data.list) || []).length > 0 ? /*#__PURE__*/React.createElement(Spin, {
|
|
115
|
+
spinning: loading
|
|
116
|
+
}, (_ref = (data === null || data === void 0 ? void 0 : data.list) || []) === null || _ref === void 0 ? void 0 : _ref.map(function (item) {
|
|
117
|
+
var _item$jsonMap;
|
|
118
|
+
return /*#__PURE__*/React.createElement(Card, {
|
|
119
|
+
key: item.id,
|
|
120
|
+
className: "".concat(styles.todoItem),
|
|
121
|
+
bodyStyle: {
|
|
122
|
+
padding: '12px 16px'
|
|
123
|
+
}
|
|
124
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
125
|
+
className: styles.todoContent
|
|
126
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
127
|
+
className: styles.todoMain
|
|
128
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
129
|
+
className: styles.todoDescription
|
|
130
|
+
}, item.buyerNick ? "".concat(item.buyerNick, "\u6709\u4E00\u6761") : '', item === null || item === void 0 ? void 0 : (_item$jsonMap = item.jsonMap) === null || _item$jsonMap === void 0 ? void 0 : _item$jsonMap.scene, " \u5DE5\u5355\u9700\u8981\u5904\u7406\uFF0C\u8BF7\u53CA\u65F6\u5904\u7406"), /*#__PURE__*/React.createElement("div", {
|
|
131
|
+
className: styles.todoMeta
|
|
132
|
+
}, /*#__PURE__*/React.createElement("span", {
|
|
133
|
+
className: styles.timestamp
|
|
134
|
+
}, moment(item.created).format('YYYY-MM-DD HH:mm:ss')))), /*#__PURE__*/React.createElement("div", {
|
|
135
|
+
className: styles.todoAction
|
|
136
|
+
}, /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(Tag, {
|
|
137
|
+
color: "blue",
|
|
138
|
+
className: styles.aiAction
|
|
139
|
+
}, "AI\u81EA\u52A8\u5EFA\u5355-".concat(WORK_ORDER_STATUS_AI_BUILD[item.flowStatus]))), /*#__PURE__*/React.createElement(Button, {
|
|
140
|
+
type: "primary",
|
|
141
|
+
size: "small",
|
|
142
|
+
ghost: true,
|
|
143
|
+
onClick: function onClick() {
|
|
144
|
+
return handleProcess(item);
|
|
145
|
+
}
|
|
146
|
+
}, "\u53BB\u5904\u7406"))));
|
|
147
|
+
})) : /*#__PURE__*/React.createElement("div", {
|
|
148
|
+
className: styles.todoEmpty
|
|
149
|
+
}, /*#__PURE__*/React.createElement(Empty, {
|
|
150
|
+
description: "\u6682\u65E0\u6570\u636E"
|
|
151
|
+
})), noMore && data !== null && data !== void 0 && (_data$list = data.list) !== null && _data$list !== void 0 && _data$list.length ? /*#__PURE__*/React.createElement("p", {
|
|
152
|
+
className: styles.todoNoMore
|
|
153
|
+
}, "\u6CA1\u6709\u66F4\u591A\u6570\u636E\u4E86") : null)));
|
|
154
|
+
};
|
|
155
|
+
export default CustomerServiceToDoList;
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
.container {
|
|
2
|
+
position: fixed;
|
|
3
|
+
top: 0;
|
|
4
|
+
left: 0;
|
|
5
|
+
width: 100%;
|
|
6
|
+
height: 100%;
|
|
7
|
+
background: rgba(0, 0, 0, 0.5);
|
|
8
|
+
z-index: 90;
|
|
9
|
+
}
|
|
10
|
+
.todoTabs {
|
|
11
|
+
display: flex;
|
|
12
|
+
justify-content: space-between;
|
|
13
|
+
align-items: center;
|
|
14
|
+
padding: 0 16px;
|
|
15
|
+
height: 45px;
|
|
16
|
+
.todoTab {
|
|
17
|
+
display: flex;
|
|
18
|
+
align-items: center;
|
|
19
|
+
justify-content: center;
|
|
20
|
+
width: 90px;
|
|
21
|
+
height: 45px;
|
|
22
|
+
font-size: 16px;
|
|
23
|
+
font-weight: 500;
|
|
24
|
+
color: #1890ff;
|
|
25
|
+
border-bottom: 2px solid #1890ff;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
.todoSection {
|
|
29
|
+
position: absolute;
|
|
30
|
+
bottom: 0;
|
|
31
|
+
left: 0;
|
|
32
|
+
right: 0;
|
|
33
|
+
width: 100%;
|
|
34
|
+
height: 80%;
|
|
35
|
+
background: #fff;
|
|
36
|
+
|
|
37
|
+
.todoList {
|
|
38
|
+
height: calc(100% - 50px);
|
|
39
|
+
overflow-y: auto;
|
|
40
|
+
background: #f0f0f0;
|
|
41
|
+
padding-top: 8px;
|
|
42
|
+
.todoItem {
|
|
43
|
+
margin-bottom: 8px;
|
|
44
|
+
border-radius: 6px;
|
|
45
|
+
transition: all 0.3s;
|
|
46
|
+
|
|
47
|
+
&:hover {
|
|
48
|
+
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
&.highlighted {
|
|
52
|
+
border: 2px dashed #ff4d4f;
|
|
53
|
+
background: #fff2f0;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
.todoContent {
|
|
57
|
+
height: 90px;
|
|
58
|
+
|
|
59
|
+
.todoMain {
|
|
60
|
+
flex: 1;
|
|
61
|
+
|
|
62
|
+
.todoDescription {
|
|
63
|
+
display: -webkit-box;
|
|
64
|
+
-webkit-box-orient: vertical;
|
|
65
|
+
-webkit-line-clamp: 2;
|
|
66
|
+
overflow: hidden;
|
|
67
|
+
text-overflow: ellipsis;
|
|
68
|
+
white-space: normal;
|
|
69
|
+
height: 48px;
|
|
70
|
+
font-size: 14px;
|
|
71
|
+
font-weight: 500;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
.todoMeta {
|
|
75
|
+
display: flex;
|
|
76
|
+
align-items: center;
|
|
77
|
+
gap: 12px;
|
|
78
|
+
flex-wrap: wrap;
|
|
79
|
+
|
|
80
|
+
.timestamp {
|
|
81
|
+
font-size: 12px;
|
|
82
|
+
color: #999;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
.source {
|
|
86
|
+
font-size: 12px;
|
|
87
|
+
color: #666;
|
|
88
|
+
background: #f5f5f5;
|
|
89
|
+
padding: 2px 6px;
|
|
90
|
+
border-radius: 3px;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
.aiAction {
|
|
94
|
+
font-size: 11px;
|
|
95
|
+
margin: 0;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
.todoEmpty {
|
|
102
|
+
display: flex;
|
|
103
|
+
justify-content: center;
|
|
104
|
+
align-items: center;
|
|
105
|
+
height: 100%;
|
|
106
|
+
}
|
|
107
|
+
.todoNoMore {
|
|
108
|
+
display: flex;
|
|
109
|
+
justify-content: center;
|
|
110
|
+
align-items: center;
|
|
111
|
+
height: 32px;
|
|
112
|
+
color: #999;
|
|
113
|
+
font-size: 14px;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
// 响应式设计
|
|
119
|
+
@media (max-width: 768px) {
|
|
120
|
+
.filterOptions {
|
|
121
|
+
gap: 8px;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
.todoContent {
|
|
125
|
+
flex-direction: column;
|
|
126
|
+
gap: 12px;
|
|
127
|
+
|
|
128
|
+
.todoAction {
|
|
129
|
+
width: 100%;
|
|
130
|
+
display: flex;
|
|
131
|
+
justify-content: space-between;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
@@ -6,6 +6,8 @@ interface ActionListProps {
|
|
|
6
6
|
nodeType: NodeType;
|
|
7
7
|
handleAction: (s: string) => void;
|
|
8
8
|
hasPreNode: boolean;
|
|
9
|
+
privilege?: string;
|
|
10
|
+
showShareButton: boolean;
|
|
9
11
|
}
|
|
10
12
|
declare const ActionList: (props: ActionListProps) => React.JSX.Element;
|
|
11
13
|
export default ActionList;
|
|
@@ -2,18 +2,39 @@ import React, { useMemo } from 'react';
|
|
|
2
2
|
import { Menu, Button, Space, Dropdown } from 'antd';
|
|
3
3
|
import { DownOutlined } from '@ant-design/icons';
|
|
4
4
|
import { FlowStatus, FlowType } from "../../../model/flowTemplateDetail/types";
|
|
5
|
+
import { reverse } from 'lodash';
|
|
5
6
|
import styles from "./index.module.less";
|
|
7
|
+
// const getActionMap = (nodeStatus: FlowStatus, hasPreNode: boolean, flowType: FlowType) => {
|
|
8
|
+
// // 非开始节点看状态
|
|
9
|
+
// if (nodeStatus === FlowStatus.PROCESSING) {
|
|
10
|
+
// if (hasPreNode) return ['forward', 'save', 'submit', 'rejected', 'close', 'stop', 'share'];
|
|
11
|
+
// return flowType === FlowType.SINGLE_PAGE
|
|
12
|
+
// ? ['save', 'forward', 'close', 'stop', 'share', 'submit']
|
|
13
|
+
// : ['forward', 'save', 'submit', 'close', 'stop', 'share'];
|
|
14
|
+
// } else if (nodeStatus === FlowStatus.STOPPING) {
|
|
15
|
+
// return ['open', 'close', 'share'];
|
|
16
|
+
// } else if (
|
|
17
|
+
// [FlowStatus.CLOSE, FlowStatus.COMPLETED, FlowStatus.RETURNING, FlowStatus.FLOWING].includes(
|
|
18
|
+
// nodeStatus,
|
|
19
|
+
// )
|
|
20
|
+
// ) {
|
|
21
|
+
// return [];
|
|
22
|
+
// } else {
|
|
23
|
+
// return ['save', 'share', 'submit'];
|
|
24
|
+
// }
|
|
25
|
+
// };
|
|
26
|
+
|
|
6
27
|
var getActionMap = function getActionMap(nodeStatus, hasPreNode, flowType) {
|
|
7
28
|
// 非开始节点看状态
|
|
8
29
|
if (nodeStatus === FlowStatus.PROCESSING) {
|
|
9
|
-
if (hasPreNode) return ['
|
|
10
|
-
return flowType === FlowType.SINGLE_PAGE ? ['save', 'forward', 'close', 'stop', 'submit'] : ['
|
|
30
|
+
if (hasPreNode) return ['submit', 'save', 'share', 'forward', 'rejected', 'close', 'stop'];
|
|
31
|
+
return flowType === FlowType.SINGLE_PAGE ? ['save', 'forward', 'close', 'stop', 'share', 'submit'] : ['submit', 'save', 'share', 'forward', 'close', 'stop'];
|
|
11
32
|
} else if (nodeStatus === FlowStatus.STOPPING) {
|
|
12
|
-
return ['open', '
|
|
33
|
+
return ['close', 'open', 'share'];
|
|
13
34
|
} else if ([FlowStatus.CLOSE, FlowStatus.COMPLETED, FlowStatus.RETURNING, FlowStatus.FLOWING].includes(nodeStatus)) {
|
|
14
35
|
return [];
|
|
15
36
|
} else {
|
|
16
|
-
return ['save', '
|
|
37
|
+
return ['submit', 'save', 'share'];
|
|
17
38
|
}
|
|
18
39
|
};
|
|
19
40
|
var buttonMap = function buttonMap(flowType) {
|
|
@@ -26,6 +47,10 @@ var buttonMap = function buttonMap(flowType) {
|
|
|
26
47
|
label: flowType === FlowType.SINGLE_PAGE ? '完结' : '提交',
|
|
27
48
|
type: 'primary'
|
|
28
49
|
},
|
|
50
|
+
share: {
|
|
51
|
+
label: '分享',
|
|
52
|
+
type: 'default'
|
|
53
|
+
},
|
|
29
54
|
forward: {
|
|
30
55
|
label: '转交',
|
|
31
56
|
type: 'default'
|
|
@@ -49,14 +74,31 @@ var buttonMap = function buttonMap(flowType) {
|
|
|
49
74
|
};
|
|
50
75
|
};
|
|
51
76
|
var ActionList = function ActionList(props) {
|
|
52
|
-
var
|
|
77
|
+
var _ref;
|
|
53
78
|
var _props$flowStatus = props.flowStatus,
|
|
54
79
|
flowStatus = _props$flowStatus === void 0 ? FlowStatus.NON_START : _props$flowStatus,
|
|
55
80
|
hasPreNode = props.hasPreNode,
|
|
56
81
|
_props$flowType = props.flowType,
|
|
57
82
|
flowType = _props$flowType === void 0 ? FlowType.SINGLE_PAGE : _props$flowType,
|
|
58
|
-
handleAction = props.handleAction
|
|
59
|
-
|
|
83
|
+
handleAction = props.handleAction,
|
|
84
|
+
_props$privilege = props.privilege,
|
|
85
|
+
privilege = _props$privilege === void 0 ? '' : _props$privilege,
|
|
86
|
+
_props$showShareButto = props.showShareButton,
|
|
87
|
+
showShareButton = _props$showShareButto === void 0 ? false : _props$showShareButto;
|
|
88
|
+
var buttonList = useMemo(function () {
|
|
89
|
+
var button = getActionMap(flowStatus, hasPreNode, flowType);
|
|
90
|
+
//如果是没有按钮权限 || 分享过来的 则不显示分享按钮
|
|
91
|
+
if (!showShareButton || privilege) {
|
|
92
|
+
button = button.filter(function (item) {
|
|
93
|
+
return item !== 'share';
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
//分享新建的只显示提交按钮
|
|
97
|
+
if (privilege === 'created') {
|
|
98
|
+
return ['submit'];
|
|
99
|
+
}
|
|
100
|
+
return button;
|
|
101
|
+
}, [flowStatus, hasPreNode, flowType, privilege, showShareButton]);
|
|
60
102
|
var sliceLen = useMemo(function () {
|
|
61
103
|
return flowType === FlowType.SINGLE_PAGE ? 1 : 3;
|
|
62
104
|
}, [flowType]);
|
|
@@ -86,7 +128,7 @@ var ActionList = function ActionList(props) {
|
|
|
86
128
|
onClick: function onClick(e) {
|
|
87
129
|
return e.preventDefault();
|
|
88
130
|
}
|
|
89
|
-
}, /*#__PURE__*/React.createElement(Space, null, "\u66F4\u591A", /*#__PURE__*/React.createElement(DownOutlined, null)))), (
|
|
131
|
+
}, /*#__PURE__*/React.createElement(Space, null, "\u66F4\u591A", /*#__PURE__*/React.createElement(DownOutlined, null)))), (_ref = reverse(buttonList.slice(0, sliceLen)) || []) === null || _ref === void 0 ? void 0 : _ref.map(function (button, index) {
|
|
90
132
|
var _buttonMap$button, _buttonMap$button2, _buttonMap$button3, _buttonMap$button4;
|
|
91
133
|
return /*#__PURE__*/React.createElement(Button, {
|
|
92
134
|
key: "button".concat(index),
|
|
@@ -29,7 +29,7 @@ import { get, some, set, every, cloneDeep, isEmpty, intersection, throttle, grou
|
|
|
29
29
|
import 'moment/locale/zh-cn';
|
|
30
30
|
import { calcWorkOrderList, orderBack, getReplaceWarnValues, COMPONENT_MAP_NAME, EXCLUDE_REPLACE_TOP_COMPONENT,
|
|
31
31
|
// 重复检验不需要展示在顶部的
|
|
32
|
-
INNER_REPLACE_COMPONENT, reversalFormValues, bsSystemOrderBackValues, kmSystemOrderBackValues, bsE3SystemOrderBackValues, wlnSystemOrderBackValues, gySystemOrderBackValues, jstSystemOrderBackValues, getMappingConfigByTemplateDetail, wdtSystemOrderBackValues, setLogisticsInfo, getMappingTargetValue } from "../../../common/utils/tools";
|
|
32
|
+
INNER_REPLACE_COMPONENT, reversalFormValues, bsSystemOrderBackValues, kmSystemOrderBackValues, bsE3SystemOrderBackValues, wlnSystemOrderBackValues, gySystemOrderBackValues, jstSystemOrderBackValues, jySystemOrderBackValues, getMappingConfigByTemplateDetail, wdtSystemOrderBackValues, setLogisticsInfo, getMappingTargetValue } from "../../../common/utils/tools";
|
|
33
33
|
import { replaceCheck, orderDetail, queryLabelByTradeId, queryMemberLevel } from "../../../model/servers/api";
|
|
34
34
|
import { factory } from '@kmkf-fe-packages/services-components';
|
|
35
35
|
import { getExpression, formatDisplayConfig, isNull, LabelData, setSessionStorage } from '@kmkf-fe-packages/kmkf-utils';
|
|
@@ -43,7 +43,7 @@ import { jsonParseSecurity, findComponentUniqueKeyByType } from "../../../common
|
|
|
43
43
|
import { NEED_CLEAR_FIELDS_WHEN_SHOP_ID_CHANGE } from "../../constant";
|
|
44
44
|
import { Context } from "../../context";
|
|
45
45
|
import { orderBackKmAddress } from "./constants";
|
|
46
|
-
import { onBlurExpressLogisticsCode, onBlurErpAfterSaleTradeId, onBlurSkxOutboundNoticeNo } from "./onBlur";
|
|
46
|
+
import { onBlurExpressLogisticsCode, onBlurErpAfterSaleTradeId, onBlurSkxOutboundNoticeNo, onBlurSkxReturnBillNo, onBlurSkxLogisticsCode } from "./onBlur";
|
|
47
47
|
// 记录显隐触发隐藏的组件。显示后,重新出发一遍映射规则
|
|
48
48
|
// TODO: 用useState会有bug, 不确定是哪里导致的
|
|
49
49
|
var hideByXYComponentsMap = {};
|
|
@@ -815,6 +815,13 @@ var FormRender = function FormRender(props, ref) {
|
|
|
815
815
|
form: form
|
|
816
816
|
});
|
|
817
817
|
}
|
|
818
|
+
if (workOrderComponentType === 'JY_SYSTEM_ORDER') {
|
|
819
|
+
jySystemOrderBackValues({
|
|
820
|
+
templateList: templateDetail,
|
|
821
|
+
value: value,
|
|
822
|
+
form: form
|
|
823
|
+
});
|
|
824
|
+
}
|
|
818
825
|
if (workOrderComponentType === 'JST_SYSTEM_ORDER') {
|
|
819
826
|
jstSystemOrderBackValues({
|
|
820
827
|
templateList: templateDetail,
|
|
@@ -822,6 +829,13 @@ var FormRender = function FormRender(props, ref) {
|
|
|
822
829
|
form: form
|
|
823
830
|
});
|
|
824
831
|
}
|
|
832
|
+
if (workOrderComponentType === 'JY_SYSTEM_ORDER') {
|
|
833
|
+
jySystemOrderBackValues({
|
|
834
|
+
templateList: templateDetail,
|
|
835
|
+
value: value,
|
|
836
|
+
form: form
|
|
837
|
+
});
|
|
838
|
+
}
|
|
825
839
|
if (activeLogisticsComponents && ['INPUT', 'EXPRESS_LOGISTICS_SELECT', 'BS_LOGISTICS'].includes(workOrderComponentType)) {
|
|
826
840
|
setLogisticsInfo({
|
|
827
841
|
logisticsMappingConfig: activeLogisticsComponents,
|
|
@@ -852,11 +866,11 @@ var FormRender = function FormRender(props, ref) {
|
|
|
852
866
|
setKmLoading: setKmLoading
|
|
853
867
|
});
|
|
854
868
|
case 3:
|
|
855
|
-
_context5.next =
|
|
869
|
+
_context5.next = 36;
|
|
856
870
|
break;
|
|
857
871
|
case 5:
|
|
858
872
|
if (!(type === 'expressLogisticsCode')) {
|
|
859
|
-
_context5.next =
|
|
873
|
+
_context5.next = 13;
|
|
860
874
|
break;
|
|
861
875
|
}
|
|
862
876
|
_context5.next = 8;
|
|
@@ -868,26 +882,53 @@ var FormRender = function FormRender(props, ref) {
|
|
|
868
882
|
componentOnBlur: componentOnBlur
|
|
869
883
|
});
|
|
870
884
|
case 8:
|
|
871
|
-
|
|
885
|
+
if (!['TR3E2FYXFZCFANVG6O6AALSM', 'SZF4ZGWZSNW6PYXMCIFEWBXT'].includes(companyKey)) {
|
|
886
|
+
_context5.next = 11;
|
|
887
|
+
break;
|
|
888
|
+
}
|
|
889
|
+
_context5.next = 11;
|
|
890
|
+
return onBlurSkxLogisticsCode({
|
|
891
|
+
form: form,
|
|
892
|
+
value: value,
|
|
893
|
+
templateDetail: templateDetail,
|
|
894
|
+
componentOnBlur: componentOnBlur
|
|
895
|
+
});
|
|
896
|
+
case 11:
|
|
897
|
+
_context5.next = 36;
|
|
872
898
|
break;
|
|
873
|
-
case
|
|
899
|
+
case 13:
|
|
874
900
|
if (!(type === 'skxOutboundNoticeNo')) {
|
|
875
|
-
_context5.next =
|
|
901
|
+
_context5.next = 19;
|
|
876
902
|
break;
|
|
877
903
|
}
|
|
878
904
|
//[SKX]ON出库通知单号 返填
|
|
879
905
|
console.log('skxOutboundNoticeNo', value);
|
|
880
|
-
_context5.next =
|
|
906
|
+
_context5.next = 17;
|
|
881
907
|
return onBlurSkxOutboundNoticeNo({
|
|
882
908
|
form: form,
|
|
883
909
|
value: value,
|
|
884
910
|
templateDetail: templateDetail,
|
|
885
911
|
componentOnBlur: componentOnBlur
|
|
886
912
|
});
|
|
887
|
-
case
|
|
888
|
-
_context5.next =
|
|
913
|
+
case 17:
|
|
914
|
+
_context5.next = 36;
|
|
889
915
|
break;
|
|
890
|
-
case
|
|
916
|
+
case 19:
|
|
917
|
+
if (!(type === 'skxReturnBillNo')) {
|
|
918
|
+
_context5.next = 24;
|
|
919
|
+
break;
|
|
920
|
+
}
|
|
921
|
+
_context5.next = 22;
|
|
922
|
+
return onBlurSkxReturnBillNo({
|
|
923
|
+
form: form,
|
|
924
|
+
value: value,
|
|
925
|
+
templateDetail: templateDetail,
|
|
926
|
+
componentOnBlur: componentOnBlur
|
|
927
|
+
});
|
|
928
|
+
case 22:
|
|
929
|
+
_context5.next = 36;
|
|
930
|
+
break;
|
|
931
|
+
case 24:
|
|
891
932
|
// 收集所有需要执行的异步操作
|
|
892
933
|
promises = [];
|
|
893
934
|
if (type === 'tradeId') {
|
|
@@ -899,7 +940,7 @@ var FormRender = function FormRender(props, ref) {
|
|
|
899
940
|
promises.push(handleChangeTradeId(value));
|
|
900
941
|
}
|
|
901
942
|
if (value) {
|
|
902
|
-
_context5.next =
|
|
943
|
+
_context5.next = 31;
|
|
903
944
|
break;
|
|
904
945
|
}
|
|
905
946
|
setReplaceValue(function (prev) {
|
|
@@ -907,18 +948,18 @@ var FormRender = function FormRender(props, ref) {
|
|
|
907
948
|
});
|
|
908
949
|
replaceValueRef.current = _objectSpread(_objectSpread({}, replaceValue), {}, _defineProperty({}, type, 0));
|
|
909
950
|
return _context5.abrupt("return");
|
|
910
|
-
case
|
|
951
|
+
case 31:
|
|
911
952
|
promises.push(queryReplaceCount(_defineProperty({}, type, value), templateDetail));
|
|
912
953
|
// TODO: ERP不走订单反弹逻辑
|
|
913
954
|
if ((type === 'tradeId' || type === 'enterprisePaymentTid') && !isErpUse) {
|
|
914
955
|
promises.push(changeHandle(value));
|
|
915
956
|
}
|
|
916
957
|
// 等待所有异步操作完成
|
|
917
|
-
_context5.next =
|
|
958
|
+
_context5.next = 35;
|
|
918
959
|
return Promise.all(promises);
|
|
919
|
-
case
|
|
960
|
+
case 35:
|
|
920
961
|
return _context5.abrupt("return", Promise.resolve());
|
|
921
|
-
case
|
|
962
|
+
case 36:
|
|
922
963
|
case "end":
|
|
923
964
|
return _context5.stop();
|
|
924
965
|
}
|
|
@@ -973,7 +1014,7 @@ var FormRender = function FormRender(props, ref) {
|
|
|
973
1014
|
}
|
|
974
1015
|
//如果有bs组件 设置成初始值
|
|
975
1016
|
var hasBs = get(templateDetail, 'componentDtoList', []).some(function (item) {
|
|
976
|
-
return ['BS_LOGISTICS', 'BS_E3_LOGISTICS', 'BS_SEND_GOOD', 'BS_E3_SEND_GOOD', 'WDT_LOGISTICS', 'WDT_SEND_GOOD', 'WLN_LOGISTICS', 'WLN_SEND_GOOD', 'KM_LOGISTICS', 'KM_SEND_GOOD', 'GY_SEND_GOOD', 'GY_LOGISTICS', 'SKX_LOGISTICS'].includes(item.workOrderComponentType);
|
|
1017
|
+
return ['BS_LOGISTICS', 'BS_E3_LOGISTICS', 'BS_SEND_GOOD', 'BS_E3_SEND_GOOD', 'WDT_LOGISTICS', 'WDT_SEND_GOOD', 'WLN_LOGISTICS', 'WLN_SEND_GOOD', 'KM_LOGISTICS', 'KM_SEND_GOOD', 'GY_SEND_GOOD', 'GY_LOGISTICS', 'JY_SEND_GOOD', 'JY_LOGISTICS', 'SKX_LOGISTICS', 'SKX_RETURN_LOGISTICS'].includes(item.workOrderComponentType);
|
|
977
1018
|
});
|
|
978
1019
|
if (hasBs) {
|
|
979
1020
|
var bsValue = get(templateDetail, 'componentDtoList', []).reduce(function (prv, next) {
|
|
@@ -984,18 +1025,26 @@ var FormRender = function FormRender(props, ref) {
|
|
|
984
1025
|
case 'KM_LOGISTICS':
|
|
985
1026
|
case 'BS_E3_LOGISTICS':
|
|
986
1027
|
case 'GY_LOGISTICS':
|
|
1028
|
+
case 'JY_LOGISTICS':
|
|
987
1029
|
case 'SKX_LOGISTICS':
|
|
988
1030
|
prv[next.uniqueKey] = [{
|
|
989
1031
|
logisticsCompany: null,
|
|
990
1032
|
logisticsCode: null
|
|
991
1033
|
}];
|
|
992
1034
|
break;
|
|
1035
|
+
case 'SKX_RETURN_LOGISTICS':
|
|
1036
|
+
prv[next.uniqueKey] = [{
|
|
1037
|
+
skxReturnLogisticsCompany: null,
|
|
1038
|
+
skxReturnLogisticsCode: null
|
|
1039
|
+
}];
|
|
1040
|
+
break;
|
|
993
1041
|
case 'BS_SEND_GOOD':
|
|
994
1042
|
case 'BS_E3_SEND_GOOD':
|
|
995
1043
|
case 'WLN_SEND_GOOD':
|
|
996
1044
|
case 'WDT_SEND_GOOD':
|
|
997
1045
|
case 'KM_SEND_GOOD':
|
|
998
1046
|
case 'GY_SEND_GOOD':
|
|
1047
|
+
case 'JY_SEND_GOOD':
|
|
999
1048
|
prv[next.uniqueKey] = [{
|
|
1000
1049
|
sendName: '',
|
|
1001
1050
|
sendId: ''
|
|
@@ -18,3 +18,15 @@ export declare const onBlurSkxOutboundNoticeNo: ({ form, value, templateDetail,
|
|
|
18
18
|
templateDetail: any;
|
|
19
19
|
componentOnBlur: (value: any, type: string) => Promise<void>;
|
|
20
20
|
}) => Promise<void>;
|
|
21
|
+
export declare const onBlurSkxReturnBillNo: ({ form, value, templateDetail, componentOnBlur, }: {
|
|
22
|
+
form: FormInstance;
|
|
23
|
+
value: string;
|
|
24
|
+
templateDetail: any;
|
|
25
|
+
componentOnBlur: (value: any, type: string) => Promise<void>;
|
|
26
|
+
}) => Promise<void>;
|
|
27
|
+
export declare const onBlurSkxLogisticsCode: ({ form, value, templateDetail, componentOnBlur, }: {
|
|
28
|
+
form: FormInstance;
|
|
29
|
+
value: string;
|
|
30
|
+
templateDetail: any;
|
|
31
|
+
componentOnBlur: (value: any, type: string) => Promise<void>;
|
|
32
|
+
}) => Promise<void>;
|