sea-chart 2.0.1 → 2.0.2

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 (94) hide show
  1. package/dist/components/cell-factory/SimpleCellFormatter.js +1 -1
  2. package/dist/components/cell-factory/link-content.js +4 -4
  3. package/dist/components/color-picker/index.js +1 -1
  4. package/dist/components/color-popover/color-rules/color-rule.js +1 -1
  5. package/dist/components/color-popover/color-rules/index.js +1 -1
  6. package/dist/components/color-popover/color-rules-popover.js +6 -6
  7. package/dist/components/color-popover/color-selector-popover.js +2 -2
  8. package/dist/components/color-setting/color-group-selector.js +1 -1
  9. package/dist/components/common-add-tool/index.js +2 -2
  10. package/dist/components/data-process-setter/hide-column-setter.js +1 -1
  11. package/dist/components/data-process-setter/sort-setter.js +2 -2
  12. package/dist/components/drill-down-settings/drill-down-fields-popover/index.js +4 -4
  13. package/dist/components/icon/index.js +2 -2
  14. package/dist/components/popover/hide-column-popover/hide-column-popover-widgets/hide-column-item.js +1 -1
  15. package/dist/components/popover/hide-column-popover/hide-column-popover.js +1 -1
  16. package/dist/components/popover/sort-popover/sort-popover.js +1 -1
  17. package/dist/components/row-card/row-card-header-cell.js +2 -2
  18. package/dist/components/row-card/row-card-header.js +1 -1
  19. package/dist/components/row-card/row-card-item.js +2 -2
  20. package/dist/components/row-card/row-card.js +2 -2
  21. package/dist/components/statistic-record-dialog/index.js +1 -1
  22. package/dist/components/types-dialog/index.js +7 -7
  23. package/dist/context.js +2 -2
  24. package/dist/services/map-json.js +4 -4
  25. package/dist/settings/basic-number-card/style-settings.js +1 -1
  26. package/dist/settings/index.js +3 -3
  27. package/dist/settings/map-settings/map-style-settings.js +1 -1
  28. package/dist/settings/stacks-settings/index.js +1 -1
  29. package/dist/settings/style-settings.js +1 -1
  30. package/dist/settings/table-settings/data-settings.js +1 -1
  31. package/dist/settings/trend-settings/style-setting.js +2 -2
  32. package/dist/settings/widgets/chart-type/index.js +3 -3
  33. package/dist/settings/widgets/date-summary-item.js +2 -2
  34. package/dist/settings/widgets/numeric-summary-item.js +2 -2
  35. package/dist/settings/widgets/summary-settings.js +2 -2
  36. package/dist/settings/widgets/switch/index.js +1 -1
  37. package/dist/settings/widgets/y-axis-group-settings.js +1 -1
  38. package/dist/utils/chart-utils/base-utils.js +7 -7
  39. package/dist/utils/chart-utils/original-data-utils/basic-chart-calculator.js +1 -1
  40. package/dist/utils/chart-utils/original-data-utils/compare-bar-chart-calculator.js +2 -2
  41. package/dist/utils/chart-utils/original-data-utils/completeness-calculator.js +1 -1
  42. package/dist/utils/chart-utils/sql-statistics-utils.js +9 -9
  43. package/dist/utils/collaborator-utils.js +1 -1
  44. package/dist/utils/collaborator.js +2 -2
  45. package/dist/utils/column-utils.js +12 -12
  46. package/dist/utils/common-utils.js +1 -1
  47. package/dist/utils/date-translate.js +1 -1
  48. package/dist/utils/object-utils.js +1 -1
  49. package/dist/utils/options-utils.js +2 -2
  50. package/dist/utils/row-record-utils.js +2 -2
  51. package/dist/utils/sql/chart-data-sql.js +58 -58
  52. package/dist/utils/sql/column-2-sql-column.js +18 -18
  53. package/dist/view/index.js +2 -5
  54. package/dist/view/title/index.js +2 -2
  55. package/dist/view/wrapper/bar.js +168 -93
  56. package/dist/view/wrapper/basic-number-card.js +8 -8
  57. package/dist/view/wrapper/chart-component.js +16 -52
  58. package/dist/view/wrapper/index.js +1 -237
  59. package/dist/view/wrapper/table/index.js +1 -1
  60. package/dist/view/wrapper/table/one-dimension-table-with-numeric-columns.js +3 -3
  61. package/dist/view/wrapper/table/pivot-table-display-name.js +1 -1
  62. package/dist/view/wrapper/table/two-dimension-table.js +8 -8
  63. package/dist/view/wrapper/table-element/components/formatter.js +2 -2
  64. package/dist/view/wrapper/table-element/components/formatters/FileFormatter/index.js +1 -1
  65. package/dist/view/wrapper/table-element/components/formatters/link-formatter.js +17 -17
  66. package/dist/view/wrapper/table-element/components/link-formatter.js +17 -17
  67. package/dist/view/wrapper/table-element/components/record.js +3 -3
  68. package/dist/view/wrapper/table-element/components/records.js +4 -4
  69. package/dist/view/wrapper/table-element/components/utils.js +1 -1
  70. package/dist/view/wrapper/trend.js +18 -18
  71. package/package.json +5 -11
  72. package/dist/utils/custom-g2.js +0 -684
  73. package/dist/view/wrapper/area.js +0 -282
  74. package/dist/view/wrapper/bar-custom.js +0 -239
  75. package/dist/view/wrapper/bar-group.js +0 -274
  76. package/dist/view/wrapper/combination.js +0 -728
  77. package/dist/view/wrapper/compare.js +0 -383
  78. package/dist/view/wrapper/completeness.js +0 -174
  79. package/dist/view/wrapper/dashboard.js +0 -179
  80. package/dist/view/wrapper/funnel.js +0 -206
  81. package/dist/view/wrapper/heat-map.js +0 -434
  82. package/dist/view/wrapper/horizontal-bar-group.js +0 -226
  83. package/dist/view/wrapper/horizontal-bar.js +0 -175
  84. package/dist/view/wrapper/horizontal-component.js +0 -89
  85. package/dist/view/wrapper/line-group.js +0 -219
  86. package/dist/view/wrapper/line.js +0 -222
  87. package/dist/view/wrapper/map.js +0 -368
  88. package/dist/view/wrapper/mirror.js +0 -218
  89. package/dist/view/wrapper/pie.js +0 -253
  90. package/dist/view/wrapper/ring.js +0 -328
  91. package/dist/view/wrapper/scatter.js +0 -140
  92. package/dist/view/wrapper/treemap.js +0 -206
  93. package/dist/view/wrapper/world-map.js +0 -413
  94. package/dist/view/wrapper/wrappers-d3/bar.js +0 -262
@@ -1,274 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.default = void 0;
8
- var _react = _interopRequireDefault(require("react"));
9
- var _propTypes = _interopRequireDefault(require("prop-types"));
10
- var _dataSet = _interopRequireDefault(require("@antv/data-set"));
11
- var _dtableUtils = require("dtable-utils");
12
- var _lodashEs = require("lodash-es");
13
- var _classnames = _interopRequireDefault(require("classnames"));
14
- var _constants = require("dtable-ui-component/lib/constants");
15
- var _intl = _interopRequireDefault(require("../../intl"));
16
- var _columnUtils = require("../../utils/column-utils");
17
- var _constants2 = require("../../constants");
18
- var _utils = require("../../utils");
19
- var _colorRules = require("../../constants/color-rules");
20
- var _chartComponent = _interopRequireDefault(require("./chart-component"));
21
- class BarGroup extends _chartComponent.default {
22
- constructor(props) {
23
- super(props);
24
- this.handleResize = () => {
25
- this.chart && this.chart.destroy();
26
- this.createChart();
27
- this.drawChart();
28
- this.renderAxisLabel(this.props.chart, this.props.tables);
29
- };
30
- this.createChart = () => {
31
- const {
32
- chart
33
- } = this.props;
34
- const {
35
- y_axis_show_value
36
- } = chart.config;
37
- const appendPadding = [y_axis_show_value ? 17 : 0, 0, 0, 0];
38
- this.initChart(this.container, {
39
- appendPadding
40
- });
41
- this.chart.on('interval:click', e => {
42
- this.props.toggleRecords(e.data.data);
43
- });
44
- };
45
- this.clearChart = () => {
46
- this.chart.annotation().clear(true);
47
- this.chart.clear(true);
48
- };
49
- this.drawChart = () => {
50
- let {
51
- result: data
52
- } = this.props;
53
- data = _utils.BaseUtils.formatEmptyName(data, '', _intl.default.get('Empty'));
54
- if (!Array.isArray(data)) return;
55
- this.chart.scale(this.groupName, {
56
- type: 'cat'
57
- });
58
- const {
59
- chart
60
- } = this.props;
61
- const {
62
- sort_type,
63
- type
64
- } = chart.config;
65
- if (type === _constants2.CHART_TYPE.BAR_STACK && sort_type) {
66
- data = (0, _columnUtils.sortDataByGroupSum)(data, sort_type);
67
- }
68
- this.loadData(data);
69
- this.draw(data);
70
- requestAnimationFrame(() => {
71
- this.chart.render();
72
- });
73
- };
74
- this.draw = data => {
75
- const {
76
- chart,
77
- summaryColumn,
78
- globalTheme,
79
- chartColorTheme,
80
- customRender,
81
- tables
82
- } = this.props;
83
- const {
84
- type,
85
- y_axis_summary_method,
86
- y_axis_show_value,
87
- label_font_size,
88
- display_each_block_data,
89
- y_axis_summary_type,
90
- table_id,
91
- column_groupby_column_key,
92
- color_theme
93
- } = chart.config;
94
- const {
95
- display_goal_line,
96
- goal_value,
97
- goal_label
98
- } = chart.style_config || {};
99
- const theme = _constants2.CHART_THEME_COLOR[globalTheme];
100
- const isGroup = type === _constants2.CHART_TYPE.BAR_GROUP;
101
- const newData = this.getChartGroupData(data);
102
- const column_groupby_column = this.getColumn(tables, table_id, column_groupby_column_key);
103
- const useSingleSelectColumnColor = (column_groupby_column === null || column_groupby_column === void 0 ? void 0 : column_groupby_column.type) === _constants.CellType.SINGLE_SELECT && color_theme === _colorRules.SUPPORT_SINGLE_SELECT_THEMES_OPTIONS.SINGLE_SELECT_COLUMN_COLORS;
104
- let singleBarWidth, singleBarRadius;
105
- // y-axis label width:6 + 10
106
- const chartWidth = this.chart.width - 6 - 10; // 10 is y-axis number width and 6 is gap between number and y axis line
107
- if (!isGroup) {
108
- singleBarWidth = Math.round(chartWidth / (2 * newData.length));
109
- this.markFirstOrLast(data, 'first');
110
- } else {
111
- const maxCountGroup = (0, _lodashEs.maxBy)(newData, 'currentGroupCount');
112
- // y-axis label width:6 + 10
113
- singleBarWidth = maxCountGroup && Math.round(chartWidth / (2 * newData.length * maxCountGroup.currentGroupCount));
114
- }
115
- singleBarRadius = Math.min(singleBarWidth / 5, 10);
116
- this.drawLabels(newData);
117
- // set Coord type
118
- this.chart.coordinate('rect');
119
- this.autoAdjustDataOptions(chart, data, summaryColumn);
120
- let yAxisShowValue = y_axis_show_value;
121
- if (type === _constants2.CHART_TYPE.BAR_STACK) {
122
- yAxisShowValue = display_each_block_data;
123
- let summaryColumnData = _constants2.DEFAULT_NUMBER_FORMAT_OBJECT;
124
- if (y_axis_summary_type === _constants2.CHART_SUMMARY_TYPE.ADVANCED) {
125
- summaryColumnData = (summaryColumn === null || summaryColumn === void 0 ? void 0 : summaryColumn.data) || _constants2.DEFAULT_NUMBER_FORMAT_OBJECT;
126
- }
127
- // get the total value of each stack
128
- const dv = new _dataSet.default.DataView().source(data);
129
- dv.transform({
130
- type: 'aggregate',
131
- fields: ['value'],
132
- operations: ['sum'],
133
- as: ['value_sum'],
134
- groupBy: ['name']
135
- });
136
- if (yAxisShowValue) {
137
- dv.rows.forEach(item => {
138
- this.chart.annotation().text({
139
- content: () => {
140
- if (y_axis_summary_method === _constants2.CHART_SUMMARY_TYPE.DISTINCT_VALUES) {
141
- return item.value_sum;
142
- }
143
- return (0, _dtableUtils.getNumberDisplayString)(item.value_sum, summaryColumnData);
144
- },
145
- position: {
146
- name: item.name,
147
- value: item.value_sum
148
- },
149
- offsetY: -10,
150
- offsetX: -5
151
- });
152
- });
153
- }
154
- }
155
-
156
- // dodgePadding set to 0, cause width bewteen bars is designed to 0
157
- const adjust = !isGroup ? {
158
- type: 'stack'
159
- } : {
160
- type: 'dodge',
161
- marginRatio: 0
162
- };
163
-
164
- // use single select column color
165
- useSingleSelectColumnColor ? this.setSingleSelectColorMap(data) : this.setColorMap(data, chartColorTheme);
166
- this.chart.interval().animate({
167
- // custom update animation
168
- update: {
169
- animation: 'fadeIn',
170
- duration: 1000,
171
- easing: 'easeLinear'
172
- }
173
- }).label(y_axis_show_value ? 'value' : false, {
174
- style: {
175
- fontSize: _utils.BaseUtils.getLabelFontSize(label_font_size),
176
- fill: theme.labelColor,
177
- ...this.labelStroke
178
- },
179
- position: type === _constants2.CHART_TYPE.BAR_STACK ? 'middle' : ''
180
- }).position('name*value').size(singleBarWidth).color('group_name', group_name => {
181
- return this.colorMap[group_name] || _constants2.CHART_STYLE_COLORS[0];
182
- }).tooltip('name*value*group_name*raw_name', (name, value, group_name, raw_name) => {
183
- return {
184
- title: !name && typeof name !== 'number' ? _intl.default.get(_constants2.EMPTY_NAME) : name,
185
- value: _utils.BaseUtils.getSummaryValueDisplayString(summaryColumn, value, y_axis_summary_method),
186
- name: !group_name && typeof group_name !== 'number' ? _intl.default.get(_constants2.EMPTY_NAME) : group_name
187
- };
188
- }).adjust([adjust]).state({
189
- active: {
190
- style: {
191
- stroke: null
192
- }
193
- }
194
- }).style('isFirst', isFirst => {
195
- if (adjust.type === 'stack') {
196
- if (isFirst) {
197
- return {
198
- radius: [singleBarRadius, singleBarRadius, 0, 0]
199
- };
200
- } else {
201
- return {
202
- radius: [0, 0, 0, 0]
203
- };
204
- }
205
- } else {
206
- return {
207
- radius: [singleBarRadius, singleBarRadius, 0, 0]
208
- };
209
- }
210
- });
211
- if (isGroup) {
212
- this.formatDataByName(data);
213
- }
214
- if (display_goal_line && goal_label && goal_value) {
215
- this.setDispalyGoalLine(goal_label, goal_value, chartWidth);
216
- }
217
- this.setToolTip(isGroup, summaryColumn, y_axis_summary_method, useSingleSelectColumnColor);
218
- (0, _utils.isFunction)(customRender) && customRender(this.chart);
219
- this.setNameLabelAndTooltip(theme, this.labelCount);
220
- this.setValueLabel(theme);
221
- this.setLegend('group_name', theme, 'top-right');
222
- this.chart.interaction('element-highlight-by-x');
223
- };
224
- this.chart = null;
225
- }
226
- componentDidMount() {
227
- this.createChart();
228
- this.drawChart();
229
- this.renderAxisLabel(this.props.chart, this.props.tables);
230
- this.debouncedHandleResize = (0, _lodashEs.debounce)(this.handleResize, 300);
231
- window.addEventListener('resize', this.debouncedHandleResize);
232
- }
233
- componentDidUpdate(prevProps) {
234
- super.componentDidUpdate(prevProps);
235
- if (_utils.BaseUtils.shouldChartComponentUpdate(prevProps, this.props)) {
236
- var _this$chart;
237
- ((_this$chart = this.chart) === null || _this$chart === void 0 ? void 0 : _this$chart.autoPadding) && this.chart.destroy();
238
- this.createChart();
239
- this.drawChart();
240
- this.renderAxisLabel(prevProps.chart, prevProps.tables);
241
- }
242
- }
243
- componentWillUnmount() {
244
- var _this$chart2;
245
- ((_this$chart2 = this.chart) === null || _this$chart2 === void 0 ? void 0 : _this$chart2.autoPadding) && this.chart.destroy();
246
- window.removeEventListener('resize', this.debouncedHandleResize);
247
- }
248
- render() {
249
- const {
250
- chart
251
- } = this.props;
252
- return /*#__PURE__*/_react.default.createElement("div", {
253
- className: (0, _classnames.default)('sea-chart-container', {
254
- 'show-x-axis-label': this.isShowXAxisLabel(chart),
255
- 'show-y-axis-label': this.isShowYAxisLabel(chart)
256
- }),
257
- ref: ref => this.container = ref
258
- });
259
- }
260
- }
261
- BarGroup.propTypes = {
262
- canvasStyle: _propTypes.default.object,
263
- chart: _propTypes.default.object,
264
- groupbyColumn: _propTypes.default.object,
265
- columnGroupbyColumn: _propTypes.default.object,
266
- summaryColumn: _propTypes.default.object,
267
- result: _propTypes.default.array,
268
- tables: _propTypes.default.array,
269
- globalTheme: _propTypes.default.string,
270
- chartColorTheme: _propTypes.default.string,
271
- toggleRecords: _propTypes.default.func,
272
- customRender: _propTypes.default.func
273
- };
274
- var _default = exports.default = BarGroup;