@zgfe/modules-attribution 1.1.6 → 1.1.13-zhongyuan.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/es/components/option/index.js +26 -19
- package/es/components/option/styles/index.less +9 -4
- package/es/components/option/types.d.ts +1 -0
- package/es/components/searchTime/index.js +12 -8
- package/es/components/searchTime/styles/index.less +0 -1
- package/es/components/title/index.js +27 -25
- package/es/components/title/searchTitle.js +8 -8
- package/es/components/title/styles/index.less +2 -2
- package/es/modules/chart/demo/index.d.ts +2 -1
- package/es/modules/chart/index.js +42 -16
- package/es/modules/chart/types.d.ts +2 -0
- package/es/modules/content/index.js +65 -15
- package/es/modules/content/styles/index.less +32 -0
- package/es/modules/content/types.d.ts +1 -0
- package/es/modules/content/utils.js +7 -3
- package/es/modules/home/demo/create.d.ts +2 -1
- package/es/modules/home/demo/create.js +1 -1
- package/es/modules/home/demo/edit.d.ts +2 -1
- package/es/modules/home/demo/edit.js +90 -89
- package/es/modules/home/demo/index.d.ts +2 -1
- package/es/modules/home/demo/index.js +5 -1
- package/es/modules/home/demo/scene.d.ts +2 -1
- package/es/modules/home/demo/scene.js +1 -0
- package/es/modules/home/index.js +53 -36
- package/es/modules/home/styles/index.less +1 -1
- package/es/modules/searchPanel/components/attributableEvents.js +15 -14
- package/es/modules/searchPanel/components/globalAttribute.js +16 -14
- package/es/modules/searchPanel/components/index.js +19 -9
- package/es/modules/searchPanel/components/targetEvent.js +11 -9
- package/es/modules/searchPanel/index.js +24 -14
- package/es/modules/searchPanel/styles/index.less +8 -8
- package/es/types.d.ts +5 -0
- package/package.json +3 -3
package/es/modules/home/index.js
CHANGED
|
@@ -1,22 +1,35 @@
|
|
|
1
|
-
function
|
|
2
|
-
|
|
3
|
-
function
|
|
4
|
-
function
|
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
|
+
var _excluded = ["includeToday"];
|
|
3
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
4
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
5
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
6
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
7
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
8
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
5
9
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
6
|
-
function _unsupportedIterableToArray(
|
|
7
|
-
function _arrayLikeToArray(
|
|
8
|
-
function _iterableToArrayLimit(
|
|
9
|
-
function _arrayWithHoles(
|
|
10
|
-
|
|
10
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
11
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
12
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
13
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
14
|
+
function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); for (r = 0; r < s.length; r++) o = s[r], t.includes(o) || {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
|
|
15
|
+
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.includes(n)) continue; t[n] = r[n]; } return t; }
|
|
16
|
+
import React, { useEffect, useRef, useState, useContext } from 'react';
|
|
11
17
|
import { Spin } from 'antd';
|
|
12
18
|
import './styles/index.less';
|
|
19
|
+
import { BizGlobalDataContext } from '@zgfe/business-lib';
|
|
13
20
|
import { AttributableContext } from '../../types';
|
|
14
21
|
import EditTitle from '../../components/title';
|
|
15
22
|
import { getInitDate, initTarget } from '../../constants/initData';
|
|
16
23
|
import AttributionContent from '../content';
|
|
17
24
|
var classPrefix = 'attribution-container';
|
|
18
|
-
var AttributionHome = function AttributionHome(
|
|
25
|
+
var AttributionHome = function AttributionHome(_ref) {
|
|
19
26
|
var _props$defaultValue;
|
|
27
|
+
var _ref$includeToday = _ref.includeToday,
|
|
28
|
+
includeToday = _ref$includeToday === void 0 ? true : _ref$includeToday,
|
|
29
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
30
|
+
var _useContext = useContext(BizGlobalDataContext),
|
|
31
|
+
currentApp = _useContext.currentApp,
|
|
32
|
+
useBizStoreLoading = _useContext.useBizStoreLoading;
|
|
20
33
|
var _useState = useState(),
|
|
21
34
|
_useState2 = _slicedToArray(_useState, 2),
|
|
22
35
|
searchData = _useState2[0],
|
|
@@ -25,30 +38,34 @@ var AttributionHome = function AttributionHome(props) {
|
|
|
25
38
|
_useState4 = _slicedToArray(_useState3, 2),
|
|
26
39
|
loading = _useState4[0],
|
|
27
40
|
setLoading = _useState4[1];
|
|
28
|
-
var _useState5 = useState(
|
|
41
|
+
var _useState5 = useState(false),
|
|
29
42
|
_useState6 = _slicedToArray(_useState5, 2),
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
var _useState7 = useState(),
|
|
43
|
+
refreshLoading = _useState6[0],
|
|
44
|
+
setRefreshLoading = _useState6[1];
|
|
45
|
+
var _useState7 = useState(true),
|
|
33
46
|
_useState8 = _slicedToArray(_useState7, 2),
|
|
34
|
-
|
|
35
|
-
|
|
47
|
+
pageLoading = _useState8[0],
|
|
48
|
+
setPageLoading = _useState8[1];
|
|
36
49
|
var _useState9 = useState(),
|
|
37
50
|
_useState10 = _slicedToArray(_useState9, 2),
|
|
38
|
-
|
|
39
|
-
|
|
51
|
+
title = _useState10[0],
|
|
52
|
+
setTitle = _useState10[1];
|
|
40
53
|
var _useState11 = useState(),
|
|
41
54
|
_useState12 = _slicedToArray(_useState11, 2),
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
var _useState13 = useState(
|
|
55
|
+
panelId = _useState12[0],
|
|
56
|
+
setPanelId = _useState12[1];
|
|
57
|
+
var _useState13 = useState(),
|
|
45
58
|
_useState14 = _slicedToArray(_useState13, 2),
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
var _useState15 = useState(
|
|
59
|
+
elementId = _useState14[0],
|
|
60
|
+
setElementId = _useState14[1];
|
|
61
|
+
var _useState15 = useState(false),
|
|
49
62
|
_useState16 = _slicedToArray(_useState15, 2),
|
|
50
|
-
|
|
51
|
-
|
|
63
|
+
searching = _useState16[0],
|
|
64
|
+
setSearching = _useState16[1];
|
|
65
|
+
var _useState17 = useState(true),
|
|
66
|
+
_useState18 = _slicedToArray(_useState17, 2),
|
|
67
|
+
buttonDisable = _useState18[0],
|
|
68
|
+
setButtonDisable = _useState18[1];
|
|
52
69
|
var attributionRef = useRef(null);
|
|
53
70
|
useEffect(function () {
|
|
54
71
|
setPageLoading(true);
|
|
@@ -73,7 +90,8 @@ var AttributionHome = function AttributionHome(props) {
|
|
|
73
90
|
setSearchData({
|
|
74
91
|
targetFilters: initTarget,
|
|
75
92
|
sourceFilters: initTarget,
|
|
76
|
-
time: getInitDate(
|
|
93
|
+
time: getInitDate(includeToday),
|
|
94
|
+
platform: 0
|
|
77
95
|
});
|
|
78
96
|
};
|
|
79
97
|
var changeLoading = function changeLoading(flag) {
|
|
@@ -91,7 +109,7 @@ var AttributionHome = function AttributionHome(props) {
|
|
|
91
109
|
attributionRef.current.saveAsPanel();
|
|
92
110
|
}
|
|
93
111
|
};
|
|
94
|
-
if (pageLoading) {
|
|
112
|
+
if (pageLoading || useBizStoreLoading) {
|
|
95
113
|
return /*#__PURE__*/React.createElement(Spin, null);
|
|
96
114
|
}
|
|
97
115
|
return /*#__PURE__*/React.createElement(Spin, {
|
|
@@ -99,6 +117,9 @@ var AttributionHome = function AttributionHome(props) {
|
|
|
99
117
|
wrapperClassName: classPrefix
|
|
100
118
|
}, /*#__PURE__*/React.createElement(AttributableContext.Provider, {
|
|
101
119
|
value: {
|
|
120
|
+
refreshLoading: refreshLoading,
|
|
121
|
+
setRefreshLoading: setRefreshLoading,
|
|
122
|
+
currentApp: currentApp,
|
|
102
123
|
panelId: panelId,
|
|
103
124
|
elementId: elementId,
|
|
104
125
|
panelName: title,
|
|
@@ -106,29 +127,25 @@ var AttributionHome = function AttributionHome(props) {
|
|
|
106
127
|
buttonDisable: buttonDisable,
|
|
107
128
|
setButtonDisable: setButtonDisable,
|
|
108
129
|
panelDisabled: props.panelDisabled,
|
|
109
|
-
includeToday:
|
|
130
|
+
includeToday: includeToday,
|
|
110
131
|
changeLoading: changeLoading,
|
|
111
132
|
afterEditTarget: props.afterEditTarget
|
|
112
133
|
}
|
|
113
|
-
}, panelId && /*#__PURE__*/React.createElement(EditTitle, {
|
|
134
|
+
}, panelId && (/*#__PURE__*/React.createElement(EditTitle, {
|
|
114
135
|
title: title,
|
|
115
136
|
type: (_props$defaultValue = props.defaultValue) === null || _props$defaultValue === void 0 ? void 0 : _props$defaultValue.panelType,
|
|
116
137
|
onSave: onSave,
|
|
117
138
|
onSaveAs: onSaveAs,
|
|
118
139
|
onEditTitle: setTitle
|
|
119
|
-
}),
|
|
120
|
-
className: "".concat(classPrefix, "-header-title")
|
|
121
|
-
}, "\u5F52\u56E0"), /*#__PURE__*/React.createElement("div", {
|
|
140
|
+
})), /*#__PURE__*/React.createElement("div", {
|
|
122
141
|
className: "".concat(classPrefix, "-content ").concat(panelId ? classPrefix + '-content2' : '')
|
|
123
142
|
}, /*#__PURE__*/React.createElement(AttributionContent, {
|
|
124
143
|
ref: attributionRef,
|
|
125
144
|
value: searchData,
|
|
145
|
+
panelId: panelId,
|
|
126
146
|
onSearching: function onSearching(val) {
|
|
127
147
|
return setSearching(val);
|
|
128
148
|
}
|
|
129
149
|
}))));
|
|
130
150
|
};
|
|
131
|
-
AttributionHome.defaultProps = {
|
|
132
|
-
includeToday: true
|
|
133
|
-
};
|
|
134
151
|
export default AttributionHome;
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
function _slicedToArray(
|
|
1
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
2
2
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
3
|
-
function _unsupportedIterableToArray(
|
|
4
|
-
function _arrayLikeToArray(
|
|
5
|
-
function _iterableToArrayLimit(
|
|
6
|
-
function _arrayWithHoles(
|
|
3
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
4
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
5
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
6
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
7
7
|
import React, { useEffect, useRef, useState, useContext } from 'react';
|
|
8
|
-
import { BizAttributeSelector, BizAttrConditionGroup, BizEventSelector, IconFont } from '@zgfe/business-lib';
|
|
8
|
+
import { BizAttributeSelector, BizAttrConditionGroup, BizEventSelector, IconFont, BizGlobalDataContext } from '@zgfe/business-lib';
|
|
9
9
|
import { AttributableContext } from '../../../types';
|
|
10
10
|
import _ from 'lodash';
|
|
11
11
|
import { Tooltip, message } from 'antd';
|
|
@@ -21,6 +21,8 @@ var AttributableEvents = function AttributableEvents(props) {
|
|
|
21
21
|
onDelete = props.onDelete;
|
|
22
22
|
var _useContext = useContext(AttributableContext),
|
|
23
23
|
setButtonDisable = _useContext.setButtonDisable;
|
|
24
|
+
var _useContext2 = useContext(BizGlobalDataContext),
|
|
25
|
+
eventIdMap = _useContext2.eventIdMap;
|
|
24
26
|
var _useState = useState(),
|
|
25
27
|
_useState2 = _slicedToArray(_useState, 2),
|
|
26
28
|
ReasonData = _useState2[0],
|
|
@@ -186,7 +188,7 @@ var AttributableEvents = function AttributableEvents(props) {
|
|
|
186
188
|
});
|
|
187
189
|
}
|
|
188
190
|
var _minceAttr = attr === undefined ? undefined : {
|
|
189
|
-
relation:
|
|
191
|
+
relation: 'and',
|
|
190
192
|
conditions: {
|
|
191
193
|
propCategory: attr.propCategory,
|
|
192
194
|
type: attr.type,
|
|
@@ -205,7 +207,6 @@ var AttributableEvents = function AttributableEvents(props) {
|
|
|
205
207
|
props.onChange(undefined);
|
|
206
208
|
return;
|
|
207
209
|
}
|
|
208
|
-
;
|
|
209
210
|
var event = reason.event;
|
|
210
211
|
var data = {
|
|
211
212
|
eventId: event === null || event === void 0 ? void 0 : event.id,
|
|
@@ -241,7 +242,7 @@ var AttributableEvents = function AttributableEvents(props) {
|
|
|
241
242
|
value: bizEventSelectorDefaultValue,
|
|
242
243
|
selectList: eventIdList,
|
|
243
244
|
placeholder: "\u8BF7\u9009\u62E9\u4E8B\u4EF6"
|
|
244
|
-
}), attrSelectShow && /*#__PURE__*/React.createElement(BizAttributeSelector, {
|
|
245
|
+
}), attrSelectShow && (/*#__PURE__*/React.createElement(BizAttributeSelector, {
|
|
245
246
|
enableEventProp: true,
|
|
246
247
|
enableUserProp: true,
|
|
247
248
|
enableEnvProp: true,
|
|
@@ -253,12 +254,12 @@ var AttributableEvents = function AttributableEvents(props) {
|
|
|
253
254
|
setAttrSelectShow(false);
|
|
254
255
|
onChangeAttr(undefined);
|
|
255
256
|
}
|
|
256
|
-
}), /*#__PURE__*/React.createElement("div", {
|
|
257
|
+
})), /*#__PURE__*/React.createElement("div", {
|
|
257
258
|
className: "button-box"
|
|
258
|
-
}, (notClickable === false || fieldsLength && fieldsLength > 1) && /*#__PURE__*/React.createElement(IconFont, {
|
|
259
|
+
}, (notClickable === false || fieldsLength && fieldsLength > 1) && (/*#__PURE__*/React.createElement(IconFont, {
|
|
259
260
|
type: "qingchu",
|
|
260
261
|
onClick: onEventDelete
|
|
261
|
-
}), /*#__PURE__*/React.createElement(Tooltip, {
|
|
262
|
+
})), /*#__PURE__*/React.createElement(Tooltip, {
|
|
262
263
|
placement: "top",
|
|
263
264
|
title: '添加属性细分'
|
|
264
265
|
}, /*#__PURE__*/React.createElement(IconFont, {
|
|
@@ -274,7 +275,7 @@ var AttributableEvents = function AttributableEvents(props) {
|
|
|
274
275
|
onClick: function onClick() {
|
|
275
276
|
return onAdd();
|
|
276
277
|
}
|
|
277
|
-
})))), /*#__PURE__*/React.createElement("div", null, (filters || isAdd) && /*#__PURE__*/React.createElement("div", {
|
|
278
|
+
})))), /*#__PURE__*/React.createElement("div", null, eventId && eventIdMap && eventIdMap[eventId] && (filters || isAdd) && (/*#__PURE__*/React.createElement("div", {
|
|
278
279
|
className: "".concat(count > 0 ? 'attr-box-show' : '')
|
|
279
280
|
}, /*#__PURE__*/React.createElement(BizAttrConditionGroup, {
|
|
280
281
|
ref: conditionRef,
|
|
@@ -285,6 +286,6 @@ var AttributableEvents = function AttributableEvents(props) {
|
|
|
285
286
|
eventIdList: [eventId],
|
|
286
287
|
onChange: onChangeFilters,
|
|
287
288
|
onConditionsCount: setCount
|
|
288
|
-
}))));
|
|
289
|
+
})))));
|
|
289
290
|
};
|
|
290
291
|
export default AttributableEvents;
|
|
@@ -1,15 +1,20 @@
|
|
|
1
|
-
|
|
1
|
+
var _excluded = ["max"];
|
|
2
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
2
3
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
3
|
-
function _unsupportedIterableToArray(
|
|
4
|
-
function _arrayLikeToArray(
|
|
5
|
-
function _iterableToArrayLimit(
|
|
6
|
-
function _arrayWithHoles(
|
|
4
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
5
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
6
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
7
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
8
|
+
function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); for (r = 0; r < s.length; r++) o = s[r], t.includes(o) || {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
|
|
9
|
+
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.includes(n)) continue; t[n] = r[n]; } return t; }
|
|
7
10
|
import { BizAttrConditionGroup, IconFont } from '@zgfe/business-lib';
|
|
8
11
|
import React, { useEffect, useRef, useState } from 'react';
|
|
9
|
-
var GlobalAttribute = function GlobalAttribute(
|
|
12
|
+
var GlobalAttribute = function GlobalAttribute(_ref) {
|
|
13
|
+
var _ref$max = _ref.max,
|
|
14
|
+
max = _ref$max === void 0 ? 5 : _ref$max,
|
|
15
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
10
16
|
var classPrefix = 'form-box';
|
|
11
|
-
var
|
|
12
|
-
onChange = props.onChange,
|
|
17
|
+
var onChange = props.onChange,
|
|
13
18
|
setAttrGlobalCount = props.setAttrGlobalCount;
|
|
14
19
|
var conditionRef = useRef(null);
|
|
15
20
|
var _useState = useState(0),
|
|
@@ -39,7 +44,7 @@ var GlobalAttribute = function GlobalAttribute(props) {
|
|
|
39
44
|
useEffect(function () {
|
|
40
45
|
setAttrGlobalCount(count);
|
|
41
46
|
}, [count]);
|
|
42
|
-
return /*#__PURE__*/React.createElement("div", null, props.eventIdList && props.eventIdList[0] === -100 ? '' : /*#__PURE__*/React.createElement("div", {
|
|
47
|
+
return /*#__PURE__*/React.createElement("div", null, props.eventIdList && props.eventIdList[0] === -100 ? '' : (/*#__PURE__*/React.createElement("div", {
|
|
43
48
|
className: "".concat(count > 0 ? 'attr-box-show' : '')
|
|
44
49
|
}, /*#__PURE__*/React.createElement(BizAttrConditionGroup, {
|
|
45
50
|
ref: conditionRef,
|
|
@@ -50,15 +55,12 @@ var GlobalAttribute = function GlobalAttribute(props) {
|
|
|
50
55
|
eventIdList: props.eventIdList,
|
|
51
56
|
onChange: onChange,
|
|
52
57
|
onConditionsCount: setCount
|
|
53
|
-
})), count < max && /*#__PURE__*/React.createElement("div", {
|
|
58
|
+
}))), count < max && (/*#__PURE__*/React.createElement("div", {
|
|
54
59
|
className: "".concat(classPrefix, "-add ").concat(props.eventIdList && props.eventIdList.length <= 0 ? 'disabled' : ''),
|
|
55
60
|
onClick: onAdd
|
|
56
61
|
}, /*#__PURE__*/React.createElement(IconFont, {
|
|
57
62
|
className: "".concat(classPrefix, "-add-icon"),
|
|
58
63
|
type: "tianjia1"
|
|
59
|
-
}), "\u6DFB\u52A0\u5C5E\u6027"));
|
|
60
|
-
};
|
|
61
|
-
GlobalAttribute.defaultProps = {
|
|
62
|
-
max: 5
|
|
64
|
+
}), "\u6DFB\u52A0\u5C5E\u6027")));
|
|
63
65
|
};
|
|
64
66
|
export default GlobalAttribute;
|
|
@@ -1,21 +1,31 @@
|
|
|
1
|
-
function
|
|
2
|
-
|
|
3
|
-
function
|
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
|
+
var _excluded = ["eventIdList"];
|
|
3
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
4
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
5
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
6
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
7
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
8
|
+
function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); for (r = 0; r < s.length; r++) o = s[r], t.includes(o) || {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
|
|
9
|
+
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.includes(n)) continue; t[n] = r[n]; } return t; }
|
|
4
10
|
import React from 'react';
|
|
5
11
|
import TargetEvent from './targetEvent';
|
|
6
12
|
import AttributableEvents from './attributableEvents';
|
|
7
|
-
var SearchContent = function SearchContent(
|
|
13
|
+
var SearchContent = function SearchContent(_ref) {
|
|
14
|
+
var _ref$eventIdList = _ref.eventIdList,
|
|
15
|
+
eventIdList = _ref$eventIdList === void 0 ? [] : _ref$eventIdList,
|
|
16
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
8
17
|
var type = props.type;
|
|
9
18
|
if (type === 'targetFilters') {
|
|
10
|
-
return /*#__PURE__*/React.createElement(TargetEvent, _objectSpread({
|
|
19
|
+
return /*#__PURE__*/React.createElement(TargetEvent, _objectSpread({
|
|
20
|
+
eventIdList: eventIdList
|
|
21
|
+
}, props));
|
|
11
22
|
} else if (type === 'sourceFilters') {
|
|
12
23
|
return /*#__PURE__*/React.createElement("div", {
|
|
13
24
|
className: "search-panel-item"
|
|
14
|
-
}, /*#__PURE__*/React.createElement(AttributableEvents, _objectSpread({
|
|
25
|
+
}, /*#__PURE__*/React.createElement(AttributableEvents, _objectSpread({
|
|
26
|
+
eventIdList: eventIdList
|
|
27
|
+
}, props)));
|
|
15
28
|
}
|
|
16
29
|
return /*#__PURE__*/React.createElement("div", null, "\u6682\u65E0\u76F8\u5173\u7EC4\u4EF6");
|
|
17
30
|
};
|
|
18
|
-
SearchContent.defaultProps = {
|
|
19
|
-
eventIdList: []
|
|
20
|
-
};
|
|
21
31
|
export default SearchContent;
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
function _slicedToArray(
|
|
1
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
2
2
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
3
|
-
function _unsupportedIterableToArray(
|
|
4
|
-
function _arrayLikeToArray(
|
|
5
|
-
function _iterableToArrayLimit(
|
|
6
|
-
function _arrayWithHoles(
|
|
7
|
-
import React, { useEffect, useRef, useState } from 'react';
|
|
8
|
-
import { BizAttrConditionGroup, BizEventSelector, IconFont } from '@zgfe/business-lib';
|
|
3
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
4
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
5
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
6
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
7
|
+
import React, { useContext, useEffect, useRef, useState } from 'react';
|
|
8
|
+
import { BizAttrConditionGroup, BizEventSelector, IconFont, BizGlobalDataContext } from '@zgfe/business-lib';
|
|
9
9
|
import { Select, Tooltip, message } from 'antd';
|
|
10
10
|
var TargetEvent = function TargetEvent(props) {
|
|
11
11
|
var _targetData$event2;
|
|
@@ -16,6 +16,8 @@ var TargetEvent = function TargetEvent(props) {
|
|
|
16
16
|
_useState2 = _slicedToArray(_useState, 2),
|
|
17
17
|
targetData = _useState2[0],
|
|
18
18
|
setTargetData = _useState2[1];
|
|
19
|
+
var _useContext = useContext(BizGlobalDataContext),
|
|
20
|
+
eventIdMap = _useContext.eventIdMap;
|
|
19
21
|
var _useState3 = useState(),
|
|
20
22
|
_useState4 = _slicedToArray(_useState3, 2),
|
|
21
23
|
filters = _useState4[0],
|
|
@@ -143,7 +145,7 @@ var TargetEvent = function TargetEvent(props) {
|
|
|
143
145
|
onClick: function onClick() {
|
|
144
146
|
return onAdd();
|
|
145
147
|
}
|
|
146
|
-
}))), /*#__PURE__*/React.createElement("div", null, (filters || isAdd) && /*#__PURE__*/React.createElement("div", {
|
|
148
|
+
}))), /*#__PURE__*/React.createElement("div", null, eventId && eventIdMap && eventIdMap[eventId] && (filters || isAdd) && (/*#__PURE__*/React.createElement("div", {
|
|
147
149
|
className: "".concat(count > 0 ? 'attr-box-show' : '')
|
|
148
150
|
}, /*#__PURE__*/React.createElement(BizAttrConditionGroup, {
|
|
149
151
|
ref: conditionRef,
|
|
@@ -154,6 +156,6 @@ var TargetEvent = function TargetEvent(props) {
|
|
|
154
156
|
eventIdList: [eventId],
|
|
155
157
|
onChange: onChangeFilters,
|
|
156
158
|
onConditionsCount: setCount
|
|
157
|
-
}))));
|
|
159
|
+
})))));
|
|
158
160
|
};
|
|
159
161
|
export default TargetEvent;
|
|
@@ -1,12 +1,15 @@
|
|
|
1
|
-
function
|
|
2
|
-
function
|
|
3
|
-
function
|
|
4
|
-
function
|
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
3
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
4
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
5
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
6
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
7
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
5
8
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
6
|
-
function _unsupportedIterableToArray(
|
|
7
|
-
function _arrayLikeToArray(
|
|
8
|
-
function _iterableToArrayLimit(
|
|
9
|
-
function _arrayWithHoles(
|
|
9
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
10
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
11
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
12
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
10
13
|
import React, { useContext, useEffect, useState, useImperativeHandle } from 'react';
|
|
11
14
|
import { IconFont, BizGlobalDataContext } from '@zgfe/business-lib';
|
|
12
15
|
import { Button, Form, Skeleton, Tooltip, Checkbox, Select, InputNumber } from 'antd';
|
|
@@ -25,7 +28,8 @@ var SearchPanel = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
25
28
|
var _useContext = useContext(AttributableContext),
|
|
26
29
|
buttonDisable = _useContext.buttonDisable,
|
|
27
30
|
setButtonDisable = _useContext.setButtonDisable,
|
|
28
|
-
searching = _useContext.searching
|
|
31
|
+
searching = _useContext.searching,
|
|
32
|
+
setRefreshLoading = _useContext.setRefreshLoading;
|
|
29
33
|
var _useContext2 = useContext(BizGlobalDataContext),
|
|
30
34
|
eventGroupList = _useContext2.eventGroupList;
|
|
31
35
|
var _Form$useForm = Form.useForm(),
|
|
@@ -139,11 +143,13 @@ var SearchPanel = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
139
143
|
setButtonDisable(operableOrNotHandle(formData, attrSourceCount, attrTargetCount, mincePropCount, attrGlobalCount));
|
|
140
144
|
}
|
|
141
145
|
}, [formData, attrSourceCount, attrTargetCount, mincePropCount, attrGlobalCount]);
|
|
142
|
-
var onFinish = function onFinish(isFetchRequest) {
|
|
146
|
+
var onFinish = function onFinish(isFetchRequest, refresh) {
|
|
143
147
|
form.validateFields().then(function (res) {
|
|
144
148
|
res.otherEvent = otherEvent;
|
|
145
149
|
res.windowCnt = windowCnt;
|
|
146
150
|
res.windowType = windowType === 1 ? 'day' : windowTypeUnit;
|
|
151
|
+
res.platform = (defaultValue === null || defaultValue === void 0 ? void 0 : defaultValue.platform) || 0;
|
|
152
|
+
res.refresh = refresh ? true : false;
|
|
147
153
|
props.onChange(res, isFetchRequest);
|
|
148
154
|
}).catch(function (e) {
|
|
149
155
|
console.log('表单检验失败', e);
|
|
@@ -153,6 +159,10 @@ var SearchPanel = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
153
159
|
return {
|
|
154
160
|
onGetSearchData: function onGetSearchData() {
|
|
155
161
|
onFinish(false);
|
|
162
|
+
},
|
|
163
|
+
refresh: function refresh() {
|
|
164
|
+
setRefreshLoading(true);
|
|
165
|
+
onFinish(true, true);
|
|
156
166
|
}
|
|
157
167
|
};
|
|
158
168
|
});
|
|
@@ -253,7 +263,7 @@ var SearchPanel = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
253
263
|
mincePropCount: mincePropCount,
|
|
254
264
|
formData: formData
|
|
255
265
|
}));
|
|
256
|
-
}), fields.length < item.max && /*#__PURE__*/React.createElement("div", {
|
|
266
|
+
}), fields.length < item.max && (/*#__PURE__*/React.createElement("div", {
|
|
257
267
|
className: "".concat(classPrefix, "-add"),
|
|
258
268
|
onClick: function onClick() {
|
|
259
269
|
return add();
|
|
@@ -261,7 +271,7 @@ var SearchPanel = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
261
271
|
}, /*#__PURE__*/React.createElement(IconFont, {
|
|
262
272
|
className: "".concat(classPrefix, "-add-icon"),
|
|
263
273
|
type: "tianjia1"
|
|
264
|
-
}), item.addLabel));
|
|
274
|
+
}), item.addLabel)));
|
|
265
275
|
});
|
|
266
276
|
}), /*#__PURE__*/React.createElement("div", {
|
|
267
277
|
className: "".concat(classPrefix, "-otherEvent")
|
|
@@ -348,7 +358,7 @@ var SearchPanel = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
348
358
|
value: 2,
|
|
349
359
|
label: '自定义'
|
|
350
360
|
}]
|
|
351
|
-
}), windowType === 2 && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(InputNumber, {
|
|
361
|
+
}), windowType === 2 && (/*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(InputNumber, {
|
|
352
362
|
className: "windowCnt",
|
|
353
363
|
style: {
|
|
354
364
|
width: 80
|
|
@@ -381,7 +391,7 @@ var SearchPanel = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
381
391
|
value: 'hour',
|
|
382
392
|
label: '小时'
|
|
383
393
|
}]
|
|
384
|
-
})))), /*#__PURE__*/React.createElement("div", {
|
|
394
|
+
}))))), /*#__PURE__*/React.createElement("div", {
|
|
385
395
|
className: "".concat(classPrefix, "-search-button-box")
|
|
386
396
|
}, /*#__PURE__*/React.createElement(Button, {
|
|
387
397
|
type: "primary",
|
|
@@ -12,10 +12,10 @@
|
|
|
12
12
|
}
|
|
13
13
|
|
|
14
14
|
&-bottom-form-title {
|
|
15
|
-
font-size: 14px;
|
|
16
15
|
margin-bottom: 16px;
|
|
17
16
|
color: #021429;
|
|
18
17
|
font-weight: 500;
|
|
18
|
+
font-size: 14px;
|
|
19
19
|
}
|
|
20
20
|
&-bottom-form {
|
|
21
21
|
display: flex;
|
|
@@ -40,26 +40,26 @@
|
|
|
40
40
|
margin: 0 16px;
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
|
-
|
|
44
|
-
#attribution-type{
|
|
43
|
+
|
|
44
|
+
#attribution-type {
|
|
45
45
|
position: relative;
|
|
46
|
-
.ant-select-dropdown{
|
|
46
|
+
.ant-select-dropdown {
|
|
47
47
|
z-index: 998;
|
|
48
48
|
}
|
|
49
49
|
.attribution-type-tooltip {
|
|
50
|
+
right: 0px !important;
|
|
50
51
|
z-index: 999;
|
|
51
|
-
right: 0px!important;
|
|
52
52
|
// left: 200px!important;
|
|
53
|
-
&-distance{
|
|
53
|
+
&-distance {
|
|
54
54
|
// left: 170px!important;
|
|
55
55
|
}
|
|
56
56
|
}
|
|
57
57
|
}
|
|
58
58
|
|
|
59
59
|
&-otherEvent {
|
|
60
|
+
margin-bottom: 34px;
|
|
60
61
|
color: #021429;
|
|
61
62
|
font-size: 14px;
|
|
62
|
-
margin-bottom: 34px;
|
|
63
63
|
.tishiicon {
|
|
64
64
|
margin-left: 1px;
|
|
65
65
|
color: #9aa1a9;
|
|
@@ -223,4 +223,4 @@
|
|
|
223
223
|
margin-top: -14px;
|
|
224
224
|
color: #fb5547;
|
|
225
225
|
}
|
|
226
|
-
}
|
|
226
|
+
}
|