@zgfe/modules-event 0.0.2-event.9 → 0.1.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.
Files changed (45) hide show
  1. package/es/components/eventFilter/index.js +49 -20
  2. package/es/components/eventFilter/styles/index.less +6 -3
  3. package/es/components/eventFilter/types.d.ts +4 -0
  4. package/es/components/index.d.ts +1 -2
  5. package/es/components/index.js +1 -2
  6. package/es/components/renderContent/index.d.ts +1 -1
  7. package/es/components/renderContent/index.js +19 -18
  8. package/es/components/renderContent/styles/index.less +3 -8
  9. package/es/components/renderContent/types.d.ts +0 -1
  10. package/es/components/searchPanel/index.js +24 -6
  11. package/es/components/searchPanel/types.d.ts +2 -0
  12. package/es/components/table/index.js +16 -20
  13. package/es/components/table/styles/index.less +67 -6
  14. package/es/components/table/types.d.ts +1 -0
  15. package/es/components/topBar/index.js +42 -27
  16. package/es/components/topBar/styles/index.less +14 -0
  17. package/es/components/topBar/types.d.ts +4 -1
  18. package/es/constants/fields.js +4 -4
  19. package/es/modules/chart/index.d.ts +1 -1
  20. package/es/modules/chart/index.js +53 -41
  21. package/es/modules/chart/types.d.ts +1 -0
  22. package/es/modules/content/index.js +72 -57
  23. package/es/modules/content/types.d.ts +1 -2
  24. package/es/modules/content/utils.d.ts +6 -1
  25. package/es/modules/content/utils.js +30 -3
  26. package/es/modules/home/demo/create.js +10 -2
  27. package/es/modules/home/demo/edit.js +56 -32
  28. package/es/modules/home/demo/index.js +4 -0
  29. package/es/modules/home/demo/scene.js +4 -0
  30. package/es/modules/home/index.js +67 -34
  31. package/es/modules/home/styles/index.less +7 -2
  32. package/es/modules/home/types.d.ts +5 -0
  33. package/es/modules/topPanel/index.js +39 -31
  34. package/es/modules/topPanel/styles/index.less +11 -1
  35. package/es/modules/topPanel/types.d.ts +7 -4
  36. package/es/style/index.less +6 -3
  37. package/es/types.d.ts +2 -0
  38. package/es/utils/formData.d.ts +8 -1
  39. package/es/utils/formData.js +146 -27
  40. package/package.json +3 -3
  41. package/es/components/common/index.d.ts +0 -6
  42. package/es/components/common/index.js +0 -17
  43. package/es/components/common/styles/index.less +0 -27
  44. package/es/components/table/images/empty.png +0 -0
  45. package/es/style/image/noData.png +0 -0
@@ -8,13 +8,23 @@ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len
8
8
  function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
9
9
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
10
10
  import { Tooltip } from 'antd';
11
- import React, { useEffect, useRef, useState } from 'react';
11
+ import React, { useEffect, useRef, useState, useContext } from 'react';
12
12
  import { BizEventSelector, BizAttributeSelector, IconFont, BizAttrConditionGroup } from '@zgfe/business-lib';
13
+ import { EventContext } from '../../types';
14
+ import { judgeFilterValue } from '../../modules/content/utils';
13
15
  import './styles/index.less';
16
+ import { judgeIsCity, judgeIsArea } from '../../modules/content/utils';
14
17
  import _ from 'lodash';
15
18
  var classPrefix = 'eventfilter-box';
16
19
  var EventFilter = function EventFilter(props) {
17
- var _useState = useState(0),
20
+ var setSearchDisabled = props.setSearchDisabled,
21
+ countChange = props.countChange,
22
+ setIsCity = props.setIsCity,
23
+ setEnableSelectChart = props.setEnableSelectChart;
24
+ var _useContext = useContext(EventContext),
25
+ selectEventData = _useContext.selectEventData,
26
+ searchData = _useContext.searchData;
27
+ var _useState = useState(props.value && props.value.filters && props.value.filters.conditions ? props.value.filters.conditions.length : 0),
18
28
  _useState2 = _slicedToArray(_useState, 2),
19
29
  count = _useState2[0],
20
30
  setCount = _useState2[1];
@@ -23,7 +33,10 @@ var EventFilter = function EventFilter(props) {
23
33
  isAdd = _useState4[0],
24
34
  setIsAdd = _useState4[1];
25
35
  var conditionRef = useRef(null);
26
- var _useState5 = useState({
36
+ var _useState5 = useState(props.value && props.value.id ? {
37
+ id: props.value.id,
38
+ name: props.value.name
39
+ } : {
27
40
  id: -100,
28
41
  name: '事件概览'
29
42
  }),
@@ -43,25 +56,30 @@ var EventFilter = function EventFilter(props) {
43
56
  bizAttributeSelectorValue = _useState12[0],
44
57
  setBizAttributeSelectorValue = _useState12[1];
45
58
  useEffect(function () {
46
- if (props.value) {
47
- var _data = props.value;
59
+ var _data = props.value;
60
+ if (selectEventData) {
61
+ _data = selectEventData;
62
+ setEvent({
63
+ id: selectEventData.id,
64
+ name: selectEventData.name
65
+ });
66
+ }
67
+ if (_data) {
48
68
  if (_data && _data.id) {
49
- setEvent({
50
- id: _data.id,
51
- name: _data.name
52
- });
53
69
  setEventOverview(true);
54
70
  }
55
71
  if (_data.filters) {
56
72
  setFilter(_data.filters);
73
+ setCount(_data.filters.conditions.length);
57
74
  }
58
75
  if (_data.dimension) {
76
+ var _attr = _data.dimension;
59
77
  setBizAttributeSelectorValue(_objectSpread(_objectSpread({}, _data.dimension), {}, {
60
- key: _data.dimension.propCategory === 'eventProp' ? _data.dimension.value : _data.dimension.propCategory + '-' + _data.dimension.value
78
+ key: "".concat(_attr.propCategory, "-").concat(_attr.value)
61
79
  }));
62
80
  }
63
81
  }
64
- }, []);
82
+ }, [selectEventData]);
65
83
  var onAdd = function onAdd() {
66
84
  if (event.id === -1) {
67
85
  return;
@@ -75,15 +93,18 @@ var EventFilter = function EventFilter(props) {
75
93
  }, 0);
76
94
  };
77
95
  var onChangeFilters = function onChangeFilters(data) {
78
- if (data && data.conditions && data.conditions.length > 0) {
79
- setFilter(data);
96
+ setFilter(data);
97
+ };
98
+ useEffect(function () {
99
+ countChange(count);
100
+ if (!judgeFilterValue(filter, count)) {
101
+ setSearchDisabled(true);
80
102
  } else {
81
- setFilter(undefined);
82
- setIsAdd(false);
103
+ setSearchDisabled(false);
83
104
  }
84
- };
105
+ if (count <= 0) setFilter(undefined);
106
+ }, [count, filter]);
85
107
  var onChangeEvent = function onChangeEvent(event) {
86
- console.log('onChangeEvent', event);
87
108
  if (event && event.event && event.event.id === -100) {
88
109
  setEventOverview(false);
89
110
  } else {
@@ -106,7 +127,8 @@ var EventFilter = function EventFilter(props) {
106
127
  propCategory: attr.propCategory,
107
128
  category: attr.category,
108
129
  value: _value,
109
- key: attr.propCategory === 'eventProp' ? attr.id : attr.propCategory + '-' + _value
130
+ id: attr.id,
131
+ key: "".concat(attr.propCategory, "-").concat(_value)
110
132
  });
111
133
  }
112
134
  };
@@ -120,10 +142,16 @@ var EventFilter = function EventFilter(props) {
120
142
  }
121
143
  if (bizAttributeSelectorValue) {
122
144
  var _dimension = _.cloneDeep(bizAttributeSelectorValue);
145
+ setEnableSelectChart && setEnableSelectChart(judgeIsArea(_dimension.value));
146
+ setIsCity && setIsCity(judgeIsCity(_dimension.value));
147
+ if (judgeIsArea(_dimension.value)) {
148
+ _event.chartType = 'map';
149
+ } else {
150
+ if (searchData.chartType === 'map') _event.chartType = 'line';
151
+ }
123
152
  delete _dimension.key;
124
153
  _event.dimension = _dimension;
125
154
  }
126
- console.log('变更searchData', _event);
127
155
  props.onChange && props.onChange(_event);
128
156
  }, [bizAttributeSelectorValue, filter, event]);
129
157
  return /*#__PURE__*/React.createElement("div", {
@@ -148,7 +176,8 @@ var EventFilter = function EventFilter(props) {
148
176
  onChange: onChangeAttr,
149
177
  onDelete: function onDelete() {
150
178
  onChangeAttr(undefined);
151
- }
179
+ },
180
+ placeholder: "\u8BF7\u9009\u62E9\u7EC6\u5206\u5C5E\u6027"
152
181
  }), /*#__PURE__*/React.createElement(Tooltip, {
153
182
  placement: "top",
154
183
  title: '添加属性筛选'
@@ -1,15 +1,15 @@
1
1
  .eventfilter-box {
2
2
  > :nth-child(1) {
3
3
  display: flex;
4
- margin-bottom: 12px;
4
+ margin-bottom: 4px;
5
+ padding: 4px 0 4px 24px;
5
6
  .biz-event-select,
6
7
  .biz-attr-select {
7
- width: 184px;
8
+ width: 208px;
8
9
  margin-right: 16px;
9
10
  }
10
11
  .shaixuan {
11
12
  margin-top: 2px;
12
- margin-left: 20px;
13
13
  color: #9aa1a9;
14
14
  font-size: 20px !important;
15
15
  cursor: pointer;
@@ -22,4 +22,7 @@
22
22
  cursor: not-allowed !important;
23
23
  }
24
24
  }
25
+ > :nth-child(1):hover {
26
+ background: #e8efff;
27
+ }
25
28
  }
@@ -13,4 +13,8 @@ export interface ConditionsnProps {
13
13
  export interface EventFilterProps {
14
14
  value?: eventProps;
15
15
  onChange?: (event: eventProps) => {};
16
+ setSearchDisabled: (disabled: boolean) => void;
17
+ countChange: (count: number) => void;
18
+ setIsCity?: Function;
19
+ setEnableSelectChart?: Function;
16
20
  }
@@ -1,5 +1,4 @@
1
1
  import ContentPanel from './renderContent';
2
2
  import SearchPanel from './searchPanel';
3
3
  import EventTable from './table';
4
- import { MiNone, MiSpin } from './common';
5
- export { ContentPanel, SearchPanel, EventTable, MiNone, MiSpin };
4
+ export { ContentPanel, SearchPanel, EventTable };
@@ -1,5 +1,4 @@
1
1
  import ContentPanel from './renderContent';
2
2
  import SearchPanel from './searchPanel';
3
3
  import EventTable from './table';
4
- import { MiNone, MiSpin } from './common';
5
- export { ContentPanel, SearchPanel, EventTable, MiNone, MiSpin };
4
+ export { ContentPanel, SearchPanel, EventTable };
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
2
  import { RenderContentProps } from './types';
3
3
  import './styles/index.less';
4
- declare const ContentPanel: React.FC<RenderContentProps>;
4
+ declare const ContentPanel: React.ForwardRefExoticComponent<RenderContentProps & React.RefAttributes<any>>;
5
5
  export default ContentPanel;
@@ -4,32 +4,30 @@ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o =
4
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
5
  function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
6
6
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
7
- import { Spin } from 'antd';
8
- import React, { useEffect, useState } from 'react';
9
- import { MiNone, MiSpin } from '..';
7
+ import { Empty } from 'antd';
8
+ import React, { useState, useContext } from 'react';
9
+ import { BizLoading } from '@zgfe/business-lib';
10
+ import { EventContext } from '../../types';
10
11
  import './styles/index.less';
11
12
  import EventChart from '../../modules/chart';
12
13
  var classPrefix = 'render-content';
13
- var ContentPanel = function ContentPanel(props) {
14
- var loading = props.loading,
15
- eventData = props.eventData,
14
+ var ContentPanel = /*#__PURE__*/React.forwardRef(function (props, ref) {
15
+ var eventData = props.eventData,
16
16
  searchData = props.searchData;
17
+ var _useContext = useContext(EventContext),
18
+ loading = _useContext.loading,
19
+ onSelectEvent = _useContext.onSelectEvent;
17
20
  var _useState = useState(props.showList || []),
18
21
  _useState2 = _slicedToArray(_useState, 2),
19
22
  showList = _useState2[0],
20
23
  setShowList = _useState2[1];
21
- useEffect(function () {
22
- setShowList(props.showList);
23
- }, [eventData]);
24
24
  var onChangeShow = function onChangeShow(names) {
25
25
  setShowList(names);
26
26
  if (props.onChangeShow) props.onChangeShow(names);
27
27
  };
28
28
  if (loading) {
29
- return /*#__PURE__*/React.createElement(Spin, {
30
- className: "".concat(classPrefix, "-spin-container"),
31
- tip: "\u67E5\u8BE2\u4E2D...",
32
- indicator: /*#__PURE__*/React.createElement(MiSpin, null)
29
+ return /*#__PURE__*/React.createElement(BizLoading, {
30
+ className: "".concat(classPrefix, "-loading")
33
31
  });
34
32
  }
35
33
  return /*#__PURE__*/React.createElement("div", {
@@ -37,17 +35,20 @@ var ContentPanel = function ContentPanel(props) {
37
35
  }, /*#__PURE__*/React.createElement("div", {
38
36
  className: "".concat(classPrefix, "-chart-container")
39
37
  }, eventData ? /*#__PURE__*/React.createElement(EventChart, {
38
+ ref: ref,
40
39
  dataSource: eventData,
41
40
  params: searchData,
42
41
  showList: showList
43
- }) : /*#__PURE__*/React.createElement(MiNone, {
44
- label: "\u6682\u65E0\u6570\u636E"
45
- })), eventData && eventData.xAxis.length ? /*#__PURE__*/React.createElement(EventChart, {
42
+ }) : /*#__PURE__*/React.createElement(Empty, {
43
+ image: Empty.PRESENTED_IMAGE_SIMPLE,
44
+ description: "\u6682\u65E0\u6570\u636E"
45
+ })), eventData && eventData.series.length > 0 ? /*#__PURE__*/React.createElement(EventChart, {
46
46
  type: "grid",
47
47
  dataSource: eventData,
48
48
  params: searchData,
49
49
  showList: showList,
50
- onChangeShow: onChangeShow
50
+ onChangeShow: onChangeShow,
51
+ onSelectEvent: onSelectEvent
51
52
  }) : null);
52
- };
53
+ });
53
54
  export default ContentPanel;
@@ -5,20 +5,15 @@
5
5
  display: flex;
6
6
  align-items: center;
7
7
  justify-content: center;
8
- height: 368px;
9
- padding: @padding-lg @padding-md;
8
+ height: 392px;
9
+ padding: @padding-lg;
10
10
  border: 1px solid @border-color-base;
11
11
  border-radius: @border-radius-normal;
12
-
13
12
  .echarts-for-react {
14
13
  width: 100%;
15
14
  }
16
15
  }
17
-
18
- &-spin-container {
19
- display: flex;
20
- align-items: center;
21
- justify-content: center;
16
+ &-loading {
22
17
  min-height: 300px;
23
18
  }
24
19
  }
@@ -1,6 +1,5 @@
1
1
  import { SearchValue, ResponseDataProps } from '../../types';
2
2
  export interface RenderContentProps {
3
- loading?: boolean;
4
3
  eventData?: ResponseDataProps;
5
4
  searchData?: SearchValue;
6
5
  showList: string[];
@@ -11,11 +11,13 @@ import { BizDatePicker, BizSelect, BizTargetDimension } from '@zgfe/business-lib
11
11
  import React, { useContext, useEffect, useState } from 'react';
12
12
  import { chartTypeOptions, getInitDate } from '../../constants';
13
13
  import { EventContext } from '../../types';
14
+ import { normalOptions } from '../../modules/content/utils';
14
15
  import './styles/index.less';
15
16
  var classPrefix = 'search-panel';
16
17
  var SearchPanel = function SearchPanel(props) {
17
18
  var _useContext = useContext(EventContext),
18
- includeToday = _useContext.includeToday;
19
+ includeToday = _useContext.includeToday,
20
+ searchData = _useContext.searchData;
19
21
  var _useState = useState(props.time || getInitDate(includeToday)),
20
22
  _useState2 = _slicedToArray(_useState, 2),
21
23
  time = _useState2[0],
@@ -35,10 +37,17 @@ var SearchPanel = function SearchPanel(props) {
35
37
  dimension = _useState8[0],
36
38
  setDimension = _useState8[1];
37
39
  useEffect(function () {
40
+ console.log('123123123', props.chartType, searchData);
38
41
  if (props.chartType && props.chartType !== chart.value) {
39
- setChart({
40
- value: props.chartType
41
- });
42
+ if (props.chartType.indexOf(',') !== -1) {
43
+ setChart({
44
+ value: props.chartType.split(',')[0]
45
+ });
46
+ } else {
47
+ setChart({
48
+ value: props.chartType
49
+ });
50
+ }
42
51
  }
43
52
  var _dimension = {
44
53
  analysisIndex: 'number'
@@ -52,7 +61,14 @@ var SearchPanel = function SearchPanel(props) {
52
61
  _dimension['analysisAttr'] = props.analysisAttr;
53
62
  }
54
63
  setDimension(_objectSpread({}, _dimension));
55
- }, [props.chartType]);
64
+ }, []);
65
+ useEffect(function () {
66
+ if (!props.enableSelectChart && chart.value === 'map') {
67
+ setChart({
68
+ value: 'line'
69
+ });
70
+ }
71
+ }, [props.enableSelectChart]);
56
72
  var onChangeTime = function onChangeTime(val) {
57
73
  if (timer) clearTimeout(timer);
58
74
  setTimer(setTimeout(function () {
@@ -85,8 +101,10 @@ var SearchPanel = function SearchPanel(props) {
85
101
  }
86
102
  }, /*#__PURE__*/React.createElement(BizDatePicker, {
87
103
  defaultValue: time,
88
- onChange: onChangeTime
104
+ onChange: onChangeTime,
105
+ selectRange: 365
89
106
  }), /*#__PURE__*/React.createElement(BizTargetDimension, {
107
+ normalOptions: normalOptions,
90
108
  value: dimension,
91
109
  eventId: props.eventId,
92
110
  onChange: onDimensionChange
@@ -10,4 +10,6 @@ export interface SearchPanelProps {
10
10
  chartType?: EventChartTypes;
11
11
  optionNode?: ReactNode;
12
12
  onChange?: (data: SearchPanelProps) => void;
13
+ setIsCity?: Function;
14
+ setEnableSelectChart?: Function;
13
15
  }
@@ -14,13 +14,13 @@ import { CopyToClipboard } from 'react-copy-to-clipboard';
14
14
  import 'highlight.js/styles/vs.css';
15
15
  import base64 from '../../utils/base64';
16
16
  import { Apis } from '../../constants';
17
- import { Modal, message, Table, ConfigProvider } from 'antd';
17
+ import { Modal, message, Table, ConfigProvider, Empty } from 'antd';
18
18
  import { formTableData, getColumns } from '../../utils/formData';
19
19
  import './styles/index.less';
20
20
  import { getValue } from '../../modules/content/utils';
21
21
  import { EventContext } from '../../types';
22
- import emptyImg from './images/empty.png';
23
- var classPrefix = 'mi-table';
22
+ import { getEventAliasName } from '../../utils/formData';
23
+ var classPrefix = 'event-mi-table';
24
24
  var EventTable = function EventTable(props) {
25
25
  var dataSource = props.dataSource,
26
26
  searchData = props.searchData,
@@ -39,7 +39,8 @@ var EventTable = function EventTable(props) {
39
39
  onUserDrill = _useContext2.onUserDrill,
40
40
  _useContext2$defaultS = _useContext2.defaultSearch,
41
41
  defaultSearch = _useContext2$defaultS === void 0 ? {} : _useContext2$defaultS,
42
- panelName = _useContext2.panelName;
42
+ panelName = _useContext2.panelName,
43
+ setFinalSearchData = _useContext2.setFinalSearchData;
43
44
  var _useState3 = useState(false),
44
45
  _useState4 = _slicedToArray(_useState3, 2),
45
46
  sqlModal = _useState4[0],
@@ -63,7 +64,6 @@ var EventTable = function EventTable(props) {
63
64
  useEffect(function () {
64
65
  var gLen = (searchData === null || searchData === void 0 ? void 0 : searchData.dimension) ? 1 : 0;
65
66
  var _data = formTableData(dataSource, searchData.userGroup || [0], gLen);
66
- console.log(111, _data);
67
67
  setTotal(_data.length);
68
68
  setTableData(_data);
69
69
  }, []);
@@ -82,12 +82,13 @@ var EventTable = function EventTable(props) {
82
82
  } else {
83
83
  eventGroupList === null || eventGroupList === void 0 ? void 0 : eventGroupList.forEach(function (group) {
84
84
  group.eventList.forEach(function (event) {
85
- if (event.name === item.name) {
85
+ if (event.name === item.originalName) {
86
86
  groupValue = event.id.toString();
87
87
  }
88
88
  });
89
89
  });
90
90
  }
91
+ setFinalSearchData({});
91
92
  onUserDrill && onUserDrill({
92
93
  appId: currentApp === null || currentApp === void 0 ? void 0 : currentApp.appId,
93
94
  platform: (currentApp === null || currentApp === void 0 ? void 0 : currentApp.platform) || 0,
@@ -115,7 +116,7 @@ var EventTable = function EventTable(props) {
115
116
  data: searchData
116
117
  }));
117
118
  };
118
- var _getColumns = getColumns(eventGroupList, userPropList, eventEnvList, dataSource.xAxis || [], userGroup, searchData, showList, onShowClick, onClickToDetail);
119
+ var _getColumns = getColumns(eventGroupList, userPropList, eventEnvList, dataSource.xAxis || [], userGroup, searchData, showList, onShowClick, onClickToDetail, props === null || props === void 0 ? void 0 : props.onSelectEvent);
119
120
  return _getColumns;
120
121
  }, [dataSource.xAxis, showList, panelName]);
121
122
  var seeSql = function seeSql() {
@@ -144,12 +145,13 @@ var EventTable = function EventTable(props) {
144
145
  if (searchData.id && !searchData.dimension || !searchData.id) {
145
146
  seriesNames.push(base64.encode('事件'));
146
147
  }
148
+ var fname = "\u4E8B\u4EF6_".concat((searchData === null || searchData === void 0 ? void 0 : searchData.name) ? getEventAliasName(searchData === null || searchData === void 0 ? void 0 : searchData.name, eventGroupList) : '事件概览');
147
149
  var params = _objectSpread(_objectSpread({
148
150
  appId: currentApp === null || currentApp === void 0 ? void 0 : currentApp.appId,
149
151
  platform: (currentApp === null || currentApp === void 0 ? void 0 : currentApp.platform) || 0
150
152
  }, searchData), {}, {
151
153
  down: {
152
- fname: base64.encode('事件分析'),
154
+ fname: base64.encode(fname),
153
155
  titles: seriesNames
154
156
  }
155
157
  });
@@ -157,23 +159,21 @@ var EventTable = function EventTable(props) {
157
159
  method: 'post',
158
160
  data: params,
159
161
  responseType: 'blob',
160
- fileName: '事件分析',
162
+ fileName: fname,
161
163
  getResponse: true
162
164
  }).then(function () {
163
165
  message.success('下载成功!');
164
166
  });
165
167
  };
166
168
  var pageChange = function pageChange(page, pageSize) {
167
- console.log('切页码', page, pageSize);
168
169
  setCurrent(page);
169
170
  setPageSize(pageSize);
170
171
  };
171
172
  var tableEmptyRender = function tableEmptyRender() {
172
- return /*#__PURE__*/React.createElement("div", {
173
- className: "".concat(classPrefix, "-table-empty")
174
- }, /*#__PURE__*/React.createElement("img", {
175
- src: emptyImg
176
- }), /*#__PURE__*/React.createElement("p", null, "\u6682\u65E0\u6570\u636E"));
173
+ return /*#__PURE__*/React.createElement(Empty, {
174
+ image: Empty.PRESENTED_IMAGE_SIMPLE,
175
+ description: "\u6682\u65E0\u6570\u636E"
176
+ });
177
177
  };
178
178
  return /*#__PURE__*/React.createElement("div", {
179
179
  className: classPrefix
@@ -191,9 +191,6 @@ var EventTable = function EventTable(props) {
191
191
  renderEmpty: tableEmptyRender
192
192
  }, /*#__PURE__*/React.createElement(Table, {
193
193
  className: "table",
194
- scroll: {
195
- y: '380px'
196
- },
197
194
  rowKey: 'id',
198
195
  columns: columns,
199
196
  dataSource: tableData,
@@ -218,7 +215,6 @@ var EventTable = function EventTable(props) {
218
215
  type: "qingchu"
219
216
  }),
220
217
  title: "\u67E5\u770BSQL",
221
- className: "".concat(classPrefix, "-share-panel"),
222
218
  onCancel: function onCancel() {
223
219
  return setSqlModal(false);
224
220
  },
@@ -232,7 +228,7 @@ var EventTable = function EventTable(props) {
232
228
  whiteSpace: 'pre-wrap'
233
229
  }
234
230
  }, sqlText), /*#__PURE__*/React.createElement(CopyToClipboard, {
235
- text: JSON.stringify(sqlText, null, 2),
231
+ text: sqlText,
236
232
  onCopy: function onCopy() {
237
233
  return message.success('复制成功!');
238
234
  }
@@ -1,16 +1,21 @@
1
- .mi-table {
1
+ .event-mi-table {
2
2
  margin-top: 16px;
3
+ &-loading {
4
+ min-height: 300px;
5
+ }
3
6
  &-table-header {
4
7
  display: flex;
8
+ align-items: center;
5
9
  justify-content: space-between;
6
10
  height: 50px;
11
+ margin-bottom: -1px;
7
12
  padding: 0 12px;
8
13
  line-height: 50px;
9
14
  background: #fafafb;
15
+ border: 1px solid #e6e7ea;
10
16
  border-radius: 8px 8px 0 0;
11
17
  > :nth-child(2) {
12
18
  display: flex;
13
- margin-top: 9px;
14
19
  > :nth-child(1) {
15
20
  margin-right: 16px;
16
21
  }
@@ -20,6 +25,7 @@
20
25
  line-height: 32px;
21
26
  background: #fff;
22
27
  border: 1px solid #f2f3f4;
28
+ border-radius: 4px;
23
29
  cursor: pointer;
24
30
  .xiazai1 {
25
31
  margin-right: 4px;
@@ -27,11 +33,32 @@
27
33
  vertical-align: -2px;
28
34
  }
29
35
  }
36
+ div:hover {
37
+ color: #165dff;
38
+ background: #e8efff;
39
+ border: 1px solid #165dff;
40
+ }
41
+ div:active {
42
+ color: #1454e5;
43
+ background: #e8efff;
44
+ border: 1px solid #1454e5;
45
+ }
30
46
  }
31
47
  }
32
48
  .ant-table {
49
+ max-height: 550px;
50
+ overflow: auto;
33
51
  border-radius: 0 0 8px 8px;
34
52
  }
53
+ .ant-pagination {
54
+ margin-top: 24px !important;
55
+ }
56
+ .ant-table
57
+ .ant-table-thead
58
+ .ant-table-cell.ant-table-column-has-sorters
59
+ .ant-table-column-sorters {
60
+ justify-content: flex-end !important;
61
+ }
35
62
  .ant-table-cell-with-append {
36
63
  padding-left: 20px;
37
64
  .ant-table-row-expand-icon {
@@ -40,25 +67,30 @@
40
67
  margin-top: 0;
41
68
  }
42
69
  }
43
- .event-name-box {
70
+ .tooltip-name-box {
44
71
  display: flex;
45
- justify-content: space-between;
46
72
  &-market {
47
73
  display: flex;
74
+ margin-right: 8px;
75
+ cursor: pointer;
48
76
  .shoucang {
49
77
  color: #fd9f41;
50
78
  font-size: 16px !important;
51
79
  }
80
+ .notshoucang {
81
+ opacity: 0;
82
+ }
52
83
  }
53
84
 
54
85
  .fuzhi1 {
55
86
  display: none;
87
+ font-size: 16px !important;
56
88
  }
57
89
  .fuzhi1:hover {
58
90
  color: #165dff;
59
91
  }
60
92
  }
61
- .event-name-box:hover {
93
+ .tooltip-name-box:hover {
62
94
  .fuzhi1 {
63
95
  display: block;
64
96
  }
@@ -75,8 +107,23 @@
75
107
  color: rgba(0, 0, 0, 0.25);
76
108
  }
77
109
  }
110
+
111
+ &-chart-box {
112
+ display: flex;
113
+ flex-direction: column;
114
+ width: 100%;
115
+ &-tooltip {
116
+ width: 200px;
117
+ margin-bottom: 24px;
118
+ color: #67727f;
119
+ font-size: 12px;
120
+ }
121
+ }
78
122
  }
79
123
  .event-table-sql-modal {
124
+ .ant-modal {
125
+ width: 720px !important;
126
+ }
80
127
  .ant-modal-header {
81
128
  position: relative;
82
129
  z-index: 1;
@@ -84,7 +131,7 @@
84
131
  background: transparent;
85
132
  }
86
133
  .ant-modal-body {
87
- padding: 0 24px 18px 24px;
134
+ padding: 0 24px 24px 24px;
88
135
  }
89
136
  .ant-modal-close-x {
90
137
  margin-top: 13px;
@@ -104,9 +151,15 @@
104
151
  width: 100%;
105
152
  height: auto;
106
153
  }
154
+ pre {
155
+ margin-bottom: 0;
156
+ }
107
157
  .hljs {
158
+ height: 400px;
108
159
  padding: 16px;
160
+ padding-bottom: 0;
109
161
  background: #fafafb;
162
+ border-radius: 8px;
110
163
  }
111
164
  .copy-box {
112
165
  position: absolute;
@@ -119,4 +172,12 @@
119
172
  margin-right: 8px;
120
173
  }
121
174
  }
175
+ .copy-box:hover {
176
+ color: #165dff;
177
+ background: #e8efff;
178
+ }
179
+ .copy-box:active {
180
+ color: #1454e5;
181
+ background: #e8efff;
182
+ }
122
183
  }
@@ -6,4 +6,5 @@ export interface EventTableProps {
6
6
  isOverview?: boolean;
7
7
  changeShowByName: (name: string) => void;
8
8
  changeShow: (names: string[]) => void;
9
+ onSelectEvent?: (id: number, name: string) => void;
9
10
  }