@zgfe/modules-attribution 1.0.1

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 (107) hide show
  1. package/README.md +33 -0
  2. package/dist/esm/components/common/index.d.ts +6 -0
  3. package/dist/esm/components/common/index.js +21 -0
  4. package/dist/esm/components/common/styles/index.less +27 -0
  5. package/dist/esm/components/index.d.ts +6 -0
  6. package/dist/esm/components/index.js +6 -0
  7. package/dist/esm/components/option/index.d.ts +5 -0
  8. package/dist/esm/components/option/index.js +199 -0
  9. package/dist/esm/components/option/styles/index.less +17 -0
  10. package/dist/esm/components/option/types.d.ts +9 -0
  11. package/dist/esm/components/option/types.js +1 -0
  12. package/dist/esm/components/renderContent/index.d.ts +5 -0
  13. package/dist/esm/components/renderContent/index.js +92 -0
  14. package/dist/esm/components/renderContent/styles/index.less +21 -0
  15. package/dist/esm/components/renderContent/types.d.ts +15 -0
  16. package/dist/esm/components/renderContent/types.js +1 -0
  17. package/dist/esm/components/searchPanel/index.d.ts +5 -0
  18. package/dist/esm/components/searchPanel/index.js +122 -0
  19. package/dist/esm/components/searchPanel/styles/index.less +38 -0
  20. package/dist/esm/components/searchPanel/types.d.ts +10 -0
  21. package/dist/esm/components/searchPanel/types.js +1 -0
  22. package/dist/esm/components/showList/index.d.ts +10 -0
  23. package/dist/esm/components/showList/index.js +92 -0
  24. package/dist/esm/components/showList/listPanel.d.ts +9 -0
  25. package/dist/esm/components/showList/listPanel.js +118 -0
  26. package/dist/esm/components/showList/styles/index.less +75 -0
  27. package/dist/esm/components/showList/types.d.ts +9 -0
  28. package/dist/esm/components/showList/types.js +1 -0
  29. package/dist/esm/components/table/index.d.ts +5 -0
  30. package/dist/esm/components/table/index.js +194 -0
  31. package/dist/esm/components/table/styles/index.less +12 -0
  32. package/dist/esm/components/table/types.d.ts +11 -0
  33. package/dist/esm/components/table/types.js +1 -0
  34. package/dist/esm/components/title/index.d.ts +5 -0
  35. package/dist/esm/components/title/index.js +184 -0
  36. package/dist/esm/components/title/searchTitle.d.ts +7 -0
  37. package/dist/esm/components/title/searchTitle.js +47 -0
  38. package/dist/esm/components/title/styles/index.less +72 -0
  39. package/dist/esm/components/title/styles/search.less +27 -0
  40. package/dist/esm/components/title/types.d.ts +7 -0
  41. package/dist/esm/components/title/types.js +1 -0
  42. package/dist/esm/constants/apis.d.ts +9 -0
  43. package/dist/esm/constants/apis.js +9 -0
  44. package/dist/esm/constants/chart.d.ts +2 -0
  45. package/dist/esm/constants/chart.js +24 -0
  46. package/dist/esm/constants/color.d.ts +1 -0
  47. package/dist/esm/constants/color.js +1 -0
  48. package/dist/esm/constants/fields.d.ts +218 -0
  49. package/dist/esm/constants/fields.js +242 -0
  50. package/dist/esm/constants/index.d.ts +6 -0
  51. package/dist/esm/constants/index.js +6 -0
  52. package/dist/esm/constants/initData.d.ts +17 -0
  53. package/dist/esm/constants/initData.js +30 -0
  54. package/dist/esm/index.d.ts +2 -0
  55. package/dist/esm/index.js +2 -0
  56. package/dist/esm/modules/content/index.d.ts +5 -0
  57. package/dist/esm/modules/content/index.js +218 -0
  58. package/dist/esm/modules/content/styles/index.less +7 -0
  59. package/dist/esm/modules/content/types.d.ts +8 -0
  60. package/dist/esm/modules/content/types.js +2 -0
  61. package/dist/esm/modules/content/utiles.d.ts +12 -0
  62. package/dist/esm/modules/content/utiles.js +231 -0
  63. package/dist/esm/modules/home/demo/create.d.ts +3 -0
  64. package/dist/esm/modules/home/demo/create.js +54 -0
  65. package/dist/esm/modules/home/demo/edit.d.ts +3 -0
  66. package/dist/esm/modules/home/demo/edit.js +80 -0
  67. package/dist/esm/modules/home/demo/index.d.ts +4 -0
  68. package/dist/esm/modules/home/demo/index.js +52 -0
  69. package/dist/esm/modules/home/demo/scene.d.ts +3 -0
  70. package/dist/esm/modules/home/demo/scene.js +74 -0
  71. package/dist/esm/modules/home/demo/styles/index.less +33 -0
  72. package/dist/esm/modules/home/index.d.ts +5 -0
  73. package/dist/esm/modules/home/index.js +172 -0
  74. package/dist/esm/modules/home/styles/index.less +37 -0
  75. package/dist/esm/modules/home/types.d.ts +19 -0
  76. package/dist/esm/modules/home/types.js +2 -0
  77. package/dist/esm/modules/leftPanel/components/globalAttribute.d.ts +8 -0
  78. package/dist/esm/modules/leftPanel/components/globalAttribute.js +64 -0
  79. package/dist/esm/modules/leftPanel/components/panel.d.ts +4 -0
  80. package/dist/esm/modules/leftPanel/components/panel.js +87 -0
  81. package/dist/esm/modules/leftPanel/demo/index.d.ts +3 -0
  82. package/dist/esm/modules/leftPanel/demo/index.js +28 -0
  83. package/dist/esm/modules/leftPanel/index.d.ts +6 -0
  84. package/dist/esm/modules/leftPanel/index.js +285 -0
  85. package/dist/esm/modules/leftPanel/styles/index.less +55 -0
  86. package/dist/esm/modules/leftPanel/types.d.ts +27 -0
  87. package/dist/esm/modules/leftPanel/types.js +2 -0
  88. package/dist/esm/modules/leftPanel/utils.d.ts +5 -0
  89. package/dist/esm/modules/leftPanel/utils.js +262 -0
  90. package/dist/esm/style/image/noData.png +0 -0
  91. package/dist/esm/style/image/ring.svg +9 -0
  92. package/dist/esm/style/index.less +47 -0
  93. package/dist/esm/style/theme.d.ts +15 -0
  94. package/dist/esm/style/theme.js +16 -0
  95. package/dist/esm/types.d.ts +46 -0
  96. package/dist/esm/types.js +2 -0
  97. package/dist/esm/utils/ajaxConfig.d.ts +8 -0
  98. package/dist/esm/utils/ajaxConfig.js +47 -0
  99. package/dist/esm/utils/base64.d.ts +23 -0
  100. package/dist/esm/utils/base64.js +132 -0
  101. package/dist/esm/utils/formData.d.ts +18 -0
  102. package/dist/esm/utils/formData.js +485 -0
  103. package/dist/esm/utils/transfer.d.ts +65 -0
  104. package/dist/esm/utils/transfer.js +206 -0
  105. package/dist/esm/utils/util.d.ts +32 -0
  106. package/dist/esm/utils/util.js +177 -0
  107. package/package.json +54 -0
@@ -0,0 +1,172 @@
1
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
2
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
3
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
4
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
6
+ function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
7
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
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."); }
9
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
10
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
11
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
12
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
13
+ import React, { useContext, useEffect, useRef, useState } from 'react';
14
+ import { Spin } from 'antd';
15
+ import { BizGlobalDataContext } from '@zgfe/business-lib';
16
+ import "./styles/index.less";
17
+ import { AttributionContext } from "../../types";
18
+ import EditTitle from "../../components/title";
19
+ import { getInitDate, initTarget } from "../../constants/initData";
20
+ import { transferEventSearchData } from "../../utils/transfer";
21
+ import InsightContent from "../content";
22
+ var classPrefix = 'insight-container';
23
+ var ModuleAttribution = function ModuleAttribution(props) {
24
+ var _props$defaultValue;
25
+ // 属性
26
+ var _useContext = useContext(BizGlobalDataContext),
27
+ userPropList = _useContext.userPropList,
28
+ eventGroupList = _useContext.eventGroupList,
29
+ eventEnvList = _useContext.eventEnvList,
30
+ userGroupList = _useContext.userGroupList;
31
+ var _useState = useState(),
32
+ _useState2 = _slicedToArray(_useState, 2),
33
+ searchData = _useState2[0],
34
+ setSearchData = _useState2[1];
35
+ // 初始状态
36
+ var _useState3 = useState(false),
37
+ _useState4 = _slicedToArray(_useState3, 2),
38
+ loading = _useState4[0],
39
+ setLoading = _useState4[1];
40
+ var _useState5 = useState(true),
41
+ _useState6 = _slicedToArray(_useState5, 2),
42
+ pageLoading = _useState6[0],
43
+ setPageLoading = _useState6[1];
44
+ // 指标标题
45
+ var _useState7 = useState(),
46
+ _useState8 = _slicedToArray(_useState7, 2),
47
+ title = _useState8[0],
48
+ setTitle = _useState8[1];
49
+ var _useState9 = useState(),
50
+ _useState10 = _slicedToArray(_useState9, 2),
51
+ panelId = _useState10[0],
52
+ setPanelId = _useState10[1];
53
+ var _useState11 = useState(),
54
+ _useState12 = _slicedToArray(_useState11, 2),
55
+ elementId = _useState12[0],
56
+ setElementId = _useState12[1];
57
+ var _useState13 = useState(),
58
+ _useState14 = _slicedToArray(_useState13, 2),
59
+ showList = _useState14[0],
60
+ setShowList = _useState14[1];
61
+ var _useState15 = useState(false),
62
+ _useState16 = _slicedToArray(_useState15, 2),
63
+ searching = _useState16[0],
64
+ setSearching = _useState16[1];
65
+ var attributionRef = useRef(null);
66
+ // 初始化
67
+ useEffect(function () {
68
+ setPageLoading(true);
69
+ // 设置初始值
70
+ if (!props.defaultValue) {
71
+ initSearch();
72
+ } else {
73
+ setShowList(props.defaultValue.chosen_data);
74
+ setPanelId(props.defaultValue.panelId);
75
+ setElementId(props.defaultValue.id);
76
+ setTitle(props.defaultValue.name);
77
+ var initData = props.defaultValue.data;
78
+ if (!initData) {
79
+ initSearch();
80
+ } else {
81
+ // 老事件分析数据
82
+ if (initData.module) {
83
+ initData = transferEventSearchData(initData, userPropList, eventGroupList, eventEnvList);
84
+ }
85
+ var chartType = initData.chartType ? initData.chartType.split(',')[0] : 'line';
86
+ if (!initData.userGroup || !initData.targets) {
87
+ setSearchData(function (data) {
88
+ return _objectSpread(_objectSpread(_objectSpread({}, data), initData), {}, {
89
+ chartType: chartType
90
+ });
91
+ });
92
+ } else {
93
+ setSearchData(_objectSpread(_objectSpread({}, initData), {}, {
94
+ chartType: chartType
95
+ }));
96
+ }
97
+ }
98
+ }
99
+ setTimeout(function () {
100
+ setPageLoading(false);
101
+ }, 0);
102
+ }, []);
103
+
104
+ // 查询条件初始化
105
+ var initSearch = function initSearch() {
106
+ setSearchData({
107
+ targets: initTarget,
108
+ userGroup: (userGroupList === null || userGroupList === void 0 ? void 0 : userGroupList.length) > 0 ? [userGroupList[0].id] : [0],
109
+ time: getInitDate(props.includeToday),
110
+ chartType: 'line'
111
+ });
112
+ };
113
+
114
+ // 改变loading
115
+ var changeLoading = function changeLoading(flag) {
116
+ setLoading(flag);
117
+ };
118
+
119
+ // 保存
120
+ var onSave = function onSave() {
121
+ if (attributionRef) {
122
+ attributionRef.current.savePanel();
123
+ }
124
+ };
125
+
126
+ // 另存为
127
+ var onSaveAs = function onSaveAs() {
128
+ if (attributionRef) {
129
+ attributionRef.current.saveAsPanel();
130
+ }
131
+ };
132
+ if (pageLoading) {
133
+ return /*#__PURE__*/React.createElement(Spin, null);
134
+ }
135
+ return /*#__PURE__*/React.createElement(Spin, {
136
+ spinning: loading,
137
+ wrapperClassName: classPrefix
138
+ }, /*#__PURE__*/React.createElement(AttributionContext.Provider, {
139
+ value: {
140
+ panelId: panelId,
141
+ elementId: elementId,
142
+ panelName: title,
143
+ searching: searching,
144
+ includeToday: props.includeToday,
145
+ defaultSearch: props.defaultValue,
146
+ enableAddScene: !props.defaultValue,
147
+ enableGenerateReport: props.enableGenerateReport,
148
+ changeLoading: changeLoading,
149
+ afterEditTarget: props.afterEditTarget,
150
+ onUserDrill: props.onUserDrill
151
+ }
152
+ }, panelId && /*#__PURE__*/React.createElement(EditTitle, {
153
+ title: title,
154
+ type: (_props$defaultValue = props.defaultValue) === null || _props$defaultValue === void 0 ? void 0 : _props$defaultValue.panelType,
155
+ onSave: onSave,
156
+ onSaveAs: onSaveAs,
157
+ onEditTitle: setTitle
158
+ }), /*#__PURE__*/React.createElement("div", {
159
+ className: "".concat(classPrefix, "-content ").concat(panelId ? classPrefix + 'content2' : '')
160
+ }, /*#__PURE__*/React.createElement(InsightContent, {
161
+ ref: attributionRef,
162
+ value: searchData,
163
+ show: showList,
164
+ onSearching: function onSearching(val) {
165
+ return setSearching(val);
166
+ }
167
+ }))));
168
+ };
169
+ ModuleAttribution.defaultProps = {
170
+ includeToday: true
171
+ };
172
+ export default ModuleAttribution;
@@ -0,0 +1,37 @@
1
+ .insight-container {
2
+ width: 100%;
3
+ height: 100%;
4
+ overflow: hidden;
5
+
6
+ .ant-spin-container {
7
+ width: 100%;
8
+ height: 100%;
9
+ }
10
+ &-content {
11
+ width: 100%;
12
+ height: 100%;
13
+ overflow: auto;
14
+ border-top: 1px solid #eaeaea;
15
+ }
16
+
17
+ &-content2 {
18
+ height: calc(100% - 56px);
19
+ }
20
+
21
+ .biz-event-select.border .biz-event-select-handle {
22
+ padding: 0;
23
+ border: none;
24
+ }
25
+
26
+ .biz-select-option:not(.biz-select-option-multiple),
27
+ .biz-attr-select-option {
28
+ &.active {
29
+ background: @primary-color !important;
30
+ }
31
+ }
32
+
33
+ // 设置下拉框最大高度
34
+ .biz-select-overlay {
35
+ max-height: 300px;
36
+ }
37
+ }
@@ -0,0 +1,19 @@
1
+ import { SearchValue } from '../../types';
2
+ export declare namespace AttributionProps {
3
+ interface Props {
4
+ defaultValue?: Value;
5
+ includeToday?: boolean;
6
+ enableGenerateReport?: boolean;
7
+ afterEditTarget?: (type: string, value?: any) => void;
8
+ onUserDrill: (data: any, searchData: SearchValue) => void;
9
+ }
10
+ interface Value {
11
+ panelId?: number;
12
+ panelType?: 'edit' | 'add';
13
+ name?: string;
14
+ id?: number;
15
+ data?: any;
16
+ chosen_data?: string[];
17
+ [props: string]: any;
18
+ }
19
+ }
@@ -0,0 +1,2 @@
1
+ export var AttributionProps;
2
+ (function (_AttributionProps) {})(AttributionProps || (AttributionProps = {}));
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ declare const GlobalAttribute: React.FC<{
3
+ value?: any;
4
+ max?: number;
5
+ eventIdList?: number[];
6
+ onChange?: (val: any) => void;
7
+ }>;
8
+ export default GlobalAttribute;
@@ -0,0 +1,64 @@
1
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
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(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
4
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
5
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
6
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
7
+ import { BizConditionGroup, IconFont } from '@zgfe/business-lib';
8
+ import React, { useEffect, useRef, useState } from 'react';
9
+ import { classPrefix } from '..';
10
+ var GlobalAttribute = function GlobalAttribute(props) {
11
+ var max = props.max,
12
+ onChange = props.onChange;
13
+ // 组件ref
14
+ var conditionRef = useRef(null);
15
+ // 条件个数
16
+ var _useState = useState(0),
17
+ _useState2 = _slicedToArray(_useState, 2),
18
+ count = _useState2[0],
19
+ setCount = _useState2[1];
20
+ // 是否初始化
21
+ var _useState3 = useState(true),
22
+ _useState4 = _slicedToArray(_useState3, 2),
23
+ init = _useState4[0],
24
+ setInit = _useState4[1];
25
+ useEffect(function () {
26
+ if (props.value) {
27
+ setCount(props.value.conditions.length || 0);
28
+ }
29
+ setInit(false);
30
+ }, []);
31
+ useEffect(function () {
32
+ if (init || props.eventIdList && props.eventIdList[0] === -100) return;
33
+ // 若值变为空,组件清空
34
+ if (!props.value) {
35
+ conditionRef.current.setValue(props.value);
36
+ }
37
+ }, [props.eventIdList]);
38
+
39
+ // 添加属性
40
+ var onAdd = function onAdd() {
41
+ if (props.eventIdList[0] === -100) return;
42
+ conditionRef.current.add();
43
+ };
44
+ return /*#__PURE__*/React.createElement("div", null, props.eventIdList && props.eventIdList[0] === -100 ? '' : /*#__PURE__*/React.createElement(BizConditionGroup, {
45
+ ref: conditionRef,
46
+ enableEventProp: true,
47
+ eventIdList: props.eventIdList,
48
+ value: props.value,
49
+ enableDelete: true,
50
+ onlyAnd: true,
51
+ onChange: onChange,
52
+ onConditionsCount: setCount
53
+ }), count < max && /*#__PURE__*/React.createElement("div", {
54
+ className: "".concat(classPrefix, "-add ").concat(props.eventIdList[0] === -100 ? 'disabled' : ''),
55
+ onClick: onAdd
56
+ }, /*#__PURE__*/React.createElement(IconFont, {
57
+ className: "".concat(classPrefix, "-add-icon"),
58
+ type: "tianjia1"
59
+ }), "\u6DFB\u52A0\u5C5E\u6027"));
60
+ };
61
+ GlobalAttribute.defaultProps = {
62
+ max: 5
63
+ };
64
+ export default GlobalAttribute;
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { LeftPanelTypes } from '../types';
3
+ declare const SearchPanel: React.FC<LeftPanelTypes.PanelProp>;
4
+ export default SearchPanel;
@@ -0,0 +1,87 @@
1
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
2
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
3
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
4
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
6
+ function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
7
+ import { BizAttributeSelector, BizUserGroup, BizTargetCondition, BizEventSelector } from '@zgfe/business-lib';
8
+ import React, { useMemo } from 'react';
9
+ var SearchPanel = function SearchPanel(props) {
10
+ var type = props.type,
11
+ enableDelete = props.enableDelete,
12
+ showOverview = props.showOverview,
13
+ eventIdList = props.eventIdList,
14
+ onDelete = props.onDelete,
15
+ onChange = props.onChange;
16
+
17
+ // 属性细分中,用户属性和环境属性都含有国家,城市,只能选其中一个的
18
+ var disabledList = useMemo(function () {
19
+ if (!props.allValues.globalDimensions) return;
20
+ var attrs = [];
21
+ props.allValues.globalDimensions.forEach(function (item) {
22
+ attrs.push(item);
23
+ if (item.name) {
24
+ var newItem = _objectSpread({}, item);
25
+ if (['city', 'area', 'country'].includes(item.name)) {
26
+ newItem.propCategory = 'userProp';
27
+ newItem.name = "current_".concat(item.name);
28
+ attrs.push(newItem);
29
+ } else if (['current_city', 'current_area', 'current_country'].includes(item.name)) {
30
+ newItem.propCategory = 'envProp';
31
+ newItem.name = item.name.slice(8);
32
+ attrs.push(newItem);
33
+ }
34
+ }
35
+ });
36
+ return attrs;
37
+ }, [props.allValues.globalDimensions]);
38
+
39
+ // 用户群
40
+ if (type === 'userGroup') {
41
+ var _props$allValues;
42
+ return /*#__PURE__*/React.createElement(BizUserGroup, {
43
+ defaultValue: props.value,
44
+ enableDelete: enableDelete,
45
+ disableItemList: (_props$allValues = props.allValues) === null || _props$allValues === void 0 ? void 0 : _props$allValues.userGroup,
46
+ onChange: onChange,
47
+ onDelete: onDelete
48
+ });
49
+ } else if (type === 'globalDimensions') {
50
+ // 按属性细分
51
+ return /*#__PURE__*/React.createElement(BizAttributeSelector, {
52
+ value: props.value,
53
+ enableEventProp: true,
54
+ enableUserProp: true,
55
+ enableEnvProp: true,
56
+ eventIdList: eventIdList,
57
+ disableItemList: disabledList,
58
+ enableDelete: true,
59
+ onChange: onChange,
60
+ onDelete: onDelete
61
+ });
62
+ } else if (type === 'targets' || type === 'event' || type === 'process') {
63
+ // if (!props.allValues.targets) return null;
64
+ // 指标选择器
65
+ return (
66
+ /*#__PURE__*/
67
+ // <BizEventSelector onChange={onChange} />
68
+ React.createElement(BizTargetCondition, {
69
+ onDelete: onDelete,
70
+ onChange: onChange,
71
+ defaultValue: props.value,
72
+ max: 5,
73
+ onlyAnd: true
74
+ }, /*#__PURE__*/React.createElement(BizEventSelector, {
75
+ showBuiltInTarget: true,
76
+ showAllEvent: showOverview,
77
+ popupContainer: false,
78
+ defaultSelectAble: false
79
+ }))
80
+ );
81
+ }
82
+ return /*#__PURE__*/React.createElement("div", null, "\u6682\u65E0\u76F8\u5173\u7EC4\u4EF6");
83
+ };
84
+ SearchPanel.defaultProps = {
85
+ eventIdList: []
86
+ };
87
+ export default SearchPanel;
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ declare const _default: () => JSX.Element;
3
+ export default _default;
@@ -0,0 +1,28 @@
1
+ import { DemoWrapper } from '@zgfe/business-lib';
2
+ import React from 'react';
3
+ import LeftPanel from '..';
4
+ var defaultValue = {
5
+ targets: [{
6
+ type: 'event',
7
+ alias: '事件概览',
8
+ eventId: -100,
9
+ eventName: '事件概览',
10
+ eventGroupId: 0,
11
+ analysisDimension: {
12
+ analysisIndex: 'number'
13
+ }
14
+ }],
15
+ userGroup: [0]
16
+ };
17
+ export default (function () {
18
+ var onChange = function onChange(data) {
19
+ console.log(data);
20
+ };
21
+ return /*#__PURE__*/React.createElement(DemoWrapper, {
22
+ needMeta: true,
23
+ defaultApp: 177
24
+ }, /*#__PURE__*/React.createElement(LeftPanel, {
25
+ defaultValue: defaultValue,
26
+ onChange: onChange
27
+ }));
28
+ });
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import { LeftPanelTypes } from './types';
3
+ import './styles/index.less';
4
+ export declare const classPrefix = "mi-left-form";
5
+ declare const LeftPanel: React.FC<LeftPanelTypes.Props>;
6
+ export default LeftPanel;