sea-chart 2.0.36 → 2.0.38
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/api/index.js +8 -15
- package/dist/components/cell-factory/FormatterConfig.js +55 -62
- package/dist/components/cell-factory/SimpleCellFormatter.js +5 -12
- package/dist/components/cell-factory/SingleSelectOption.js +11 -18
- package/dist/components/cell-factory/cell-editor-factory.js +5 -12
- package/dist/components/cell-factory/cell-formatter-factory.js +4 -11
- package/dist/components/cell-factory/link-content.js +30 -38
- package/dist/components/chart-color-selector/color-selector.js +11 -18
- package/dist/components/collaborator/index.js +7 -14
- package/dist/components/color-picker/index.js +12 -19
- package/dist/components/color-popover/color-rules/color-rule.js +26 -34
- package/dist/components/color-popover/color-rules/index.js +7 -15
- package/dist/components/color-popover/color-rules/rule-filters/filter.js +27 -34
- package/dist/components/color-popover/color-rules/rule-filters/index.js +17 -25
- package/dist/components/color-popover/color-rules/rule-filters/number-input.js +9 -17
- package/dist/components/color-popover/color-rules-popover.js +30 -38
- package/dist/components/color-popover/color-selector-popover.js +12 -20
- package/dist/components/color-setting/color-group-selector.js +13 -21
- package/dist/components/common-add-tool/index.js +8 -15
- package/dist/components/data-process-setter/data-setting-header.js +7 -14
- package/dist/components/data-process-setter/hide-column-setter.js +13 -20
- package/dist/components/data-process-setter/index.js +4 -27
- package/dist/components/data-process-setter/sort-setter.js +18 -26
- package/dist/components/draggable/Draggable.js +7 -13
- package/dist/components/drill-down-settings/drill-down-fields-popover/index.js +40 -48
- package/dist/components/drill-down-settings/drill-down-fields-settings/index.js +10 -18
- package/dist/components/drill-down-settings/index.js +11 -18
- package/dist/components/dtable-popover/index.js +13 -20
- package/dist/components/dtable-search-input/index.js +13 -21
- package/dist/components/font-settings/index.js +14 -22
- package/dist/components/goal-line-setting/goal-setting-item.js +6 -14
- package/dist/components/goal-line-setting/index.js +12 -19
- package/dist/components/highlighter/highlighter.js +7 -14
- package/dist/components/icon/index.js +5 -12
- package/dist/components/index.js +7 -48
- package/dist/components/loading/index.js +6 -13
- package/dist/components/number-input/index.js +4 -11
- package/dist/components/pixel-editor/index.js +15 -23
- package/dist/components/popover/hide-column-popover/hide-column-popover-widgets/hide-column-item.js +8 -15
- package/dist/components/popover/hide-column-popover/hide-column-popover.js +26 -34
- package/dist/components/popover/sort-popover/sort-popover-widgets/sort-utils.js +9 -18
- package/dist/components/popover/sort-popover/sort-popover.js +55 -65
- package/dist/components/resize-handle/ResizeHandle.js +6 -13
- package/dist/components/row-card/row-card-header-cell.js +17 -24
- package/dist/components/row-card/row-card-header.js +15 -22
- package/dist/components/row-card/row-card-item.js +35 -43
- package/dist/components/row-card/row-card.js +17 -25
- package/dist/components/statistic-record-dialog/index.js +56 -64
- package/dist/components/tooltip/index.js +14 -21
- package/dist/components/types-dialog/index.js +62 -70
- package/dist/components/types-dialog/use-force-update.js +4 -10
- package/dist/constants/color-rules.js +8 -14
- package/dist/constants/common-constants.js +8 -14
- package/dist/constants/error.js +2 -8
- package/dist/constants/geolocation.js +9 -15
- package/dist/constants/index.js +142 -271
- package/dist/constants/key-codes.js +0 -2
- package/dist/constants/model.js +3 -9
- package/dist/constants/regions.js +3 -8
- package/dist/constants/style.js +6 -12
- package/dist/constants/table.js +1 -7
- package/dist/constants/type-image.js +33 -39
- package/dist/constants/type.js +3 -9
- package/dist/context.js +13 -20
- package/dist/editor/index.js +8 -15
- package/dist/index.js +13 -104
- package/dist/intl.js +10 -17
- package/dist/locale/index.js +16 -23
- package/dist/locale/lang/de.js +1 -7
- package/dist/locale/lang/en.js +1 -7
- package/dist/locale/lang/es.js +1 -7
- package/dist/locale/lang/fr.js +1 -7
- package/dist/locale/lang/pt.js +1 -7
- package/dist/locale/lang/ru.js +1 -7
- package/dist/locale/lang/zh_CN.js +1 -7
- package/dist/model/area-group.js +12 -19
- package/dist/model/area.js +12 -19
- package/dist/model/bar-custom.js +11 -18
- package/dist/model/bar-group.js +12 -19
- package/dist/model/bar-stack.js +10 -17
- package/dist/model/bar.js +11 -18
- package/dist/model/base-model.js +4 -11
- package/dist/model/basic-number-card.js +13 -20
- package/dist/model/chart.js +7 -13
- package/dist/model/combination.js +15 -22
- package/dist/model/compare-bar.js +14 -21
- package/dist/model/completeness-group.js +11 -18
- package/dist/model/completeness.js +10 -17
- package/dist/model/dashboard.js +7 -14
- package/dist/model/funnel.js +14 -21
- package/dist/model/generic-model.js +135 -143
- package/dist/model/heat-map.js +9 -16
- package/dist/model/horizontal-bar.js +11 -18
- package/dist/model/horizontal-group-bar.js +10 -17
- package/dist/model/index.js +69 -93
- package/dist/model/line-group.js +13 -20
- package/dist/model/line.js +12 -19
- package/dist/model/map-bubble.js +12 -19
- package/dist/model/map.js +12 -19
- package/dist/model/mirror.js +13 -20
- package/dist/model/pie.js +12 -19
- package/dist/model/ring.js +12 -19
- package/dist/model/scatter.js +10 -17
- package/dist/model/stacked-horizontal-bar.js +11 -18
- package/dist/model/table-element.js +5 -12
- package/dist/model/table.js +7 -14
- package/dist/model/tree-map.js +7 -14
- package/dist/model/trend.js +11 -18
- package/dist/model/user.js +1 -7
- package/dist/model/world-map-bubble.js +12 -19
- package/dist/model/world-map.js +12 -19
- package/dist/services/map-json.js +11 -17
- package/dist/settings/advance-bar-settings/data-settings.js +36 -44
- package/dist/settings/advance-bar-settings/index.js +3 -20
- package/dist/settings/advance-bar-settings/style-settings.js +63 -71
- package/dist/settings/bar-settings/data-settings.js +39 -47
- package/dist/settings/bar-settings/index.js +3 -20
- package/dist/settings/bar-settings/style-settings.js +49 -57
- package/dist/settings/basic-number-card/data-settings.js +49 -57
- package/dist/settings/basic-number-card/index.js +3 -20
- package/dist/settings/basic-number-card/style-settings.js +19 -27
- package/dist/settings/combination-settings/data-settings.js +55 -63
- package/dist/settings/combination-settings/index.js +3 -20
- package/dist/settings/combination-settings/style-settings.js +65 -73
- package/dist/settings/completeness-settings/callbacks/callbacks.js +16 -27
- package/dist/settings/completeness-settings/data-settings/completion-settings.js +21 -28
- package/dist/settings/completeness-settings/data-settings/data-settings.js +25 -32
- package/dist/settings/completeness-settings/index.js +3 -20
- package/dist/settings/completeness-settings/style-settings.js +19 -26
- package/dist/settings/dashboard-settings/data-settings.js +43 -51
- package/dist/settings/dashboard-settings/index.js +2 -13
- package/dist/settings/data-settings.js +72 -79
- package/dist/settings/funnel-settings/components/dnd-item/dnd-item.js +12 -19
- package/dist/settings/funnel-settings/components/dnd-list.js +15 -23
- package/dist/settings/funnel-settings/components/funnel-label-setting.js +32 -40
- package/dist/settings/funnel-settings/components/funnel-layer-setting.js +20 -28
- package/dist/settings/funnel-settings/data-settings.js +23 -31
- package/dist/settings/funnel-settings/index.js +3 -20
- package/dist/settings/funnel-settings/style-settings.js +11 -19
- package/dist/settings/heat-map-settings/data-settings.js +18 -26
- package/dist/settings/heat-map-settings/index.js +3 -20
- package/dist/settings/heat-map-settings/style-settings.js +18 -26
- package/dist/settings/horizontal-bar-settings/data-settings.js +12 -19
- package/dist/settings/horizontal-bar-settings/index.js +3 -20
- package/dist/settings/horizontal-bar-settings/style-settings.js +12 -19
- package/dist/settings/index.js +52 -70
- package/dist/settings/map-settings/components/location-field-selector.js +10 -17
- package/dist/settings/map-settings/components/map-level-selector.js +11 -18
- package/dist/settings/map-settings/components/map-province-city-selector.js +19 -26
- package/dist/settings/map-settings/index.js +3 -20
- package/dist/settings/map-settings/map-data-settings.js +23 -30
- package/dist/settings/map-settings/map-style-settings.js +27 -35
- package/dist/settings/mirror-settings/data-settings.js +26 -34
- package/dist/settings/mirror-settings/index.js +2 -13
- package/dist/settings/pie-settings/data-settings.js +33 -41
- package/dist/settings/pie-settings/index.js +3 -20
- package/dist/settings/pie-settings/style-settings.js +47 -55
- package/dist/settings/scatter/data-settings.js +27 -34
- package/dist/settings/scatter/index.js +3 -12
- package/dist/settings/stacks-settings/index.js +19 -27
- package/dist/settings/stacks-settings/stack-item-settings.js +19 -27
- package/dist/settings/style-settings.js +65 -73
- package/dist/settings/table-element-settings/components/data-filter.js +30 -38
- package/dist/settings/table-element-settings/data-settings.js +21 -29
- package/dist/settings/table-element-settings/index.js +2 -13
- package/dist/settings/table-settings/data-settings.js +112 -120
- package/dist/settings/table-settings/index.js +2 -13
- package/dist/settings/time-comparison-settings/data-settings.js +43 -51
- package/dist/settings/time-comparison-settings/index.js +3 -20
- package/dist/settings/time-comparison-settings/style-settings.js +42 -50
- package/dist/settings/trend-settings/data-settings.js +24 -32
- package/dist/settings/trend-settings/index.js +3 -20
- package/dist/settings/trend-settings/style-setting.js +19 -27
- package/dist/settings/widgets/basic-summary/index.js +55 -63
- package/dist/settings/widgets/chart-type/index.js +18 -26
- package/dist/settings/widgets/color-settings/index.js +72 -80
- package/dist/settings/widgets/common-data-settings.js +21 -29
- package/dist/settings/widgets/data-filter/index.js +35 -43
- package/dist/settings/widgets/data-sort.js +16 -24
- package/dist/settings/widgets/date-summary-item.js +26 -34
- package/dist/settings/widgets/display-values-settings/index.js +14 -22
- package/dist/settings/widgets/divider/index.js +8 -16
- package/dist/settings/widgets/font-settings/font-color-settings.js +11 -19
- package/dist/settings/widgets/font-settings/font-size-settings.js +14 -22
- package/dist/settings/widgets/font-settings/font-weight-settings.js +17 -25
- package/dist/settings/widgets/font-settings/index.js +4 -27
- package/dist/settings/widgets/group-by.js +51 -59
- package/dist/settings/widgets/min-max-setting.js +10 -18
- package/dist/settings/widgets/mininum-slice-percent.js +10 -18
- package/dist/settings/widgets/numeric-summary-item.js +25 -33
- package/dist/settings/widgets/select-line-type/index.js +10 -17
- package/dist/settings/widgets/select-table/index.js +9 -16
- package/dist/settings/widgets/select-view/index.js +20 -28
- package/dist/settings/widgets/stack.js +14 -22
- package/dist/settings/widgets/summary-method-setting.js +17 -25
- package/dist/settings/widgets/summary-settings.js +74 -82
- package/dist/settings/widgets/switch/index.js +9 -16
- package/dist/settings/widgets/text-horizontal-settings.js +15 -23
- package/dist/settings/widgets/time-picker.js +29 -37
- package/dist/settings/widgets/title-settings/index.js +29 -37
- package/dist/settings/widgets/title-settings/title-text.js +5 -12
- package/dist/settings/widgets/x-axios.js +0 -1
- package/dist/settings/widgets/y-axis-group-settings.js +64 -72
- package/dist/utils/cell-format-utils.js +17 -27
- package/dist/utils/cell-value-utils.js +4 -11
- package/dist/utils/chart-utils/base-utils.js +324 -332
- package/dist/utils/chart-utils/index.js +28 -41
- package/dist/utils/chart-utils/original-data-utils/basic-chart-calculator.js +77 -84
- package/dist/utils/chart-utils/original-data-utils/card-calculator.js +13 -20
- package/dist/utils/chart-utils/original-data-utils/combination-calculator.js +45 -52
- package/dist/utils/chart-utils/original-data-utils/compare-bar-chart-calculator.js +21 -28
- package/dist/utils/chart-utils/original-data-utils/completeness-calculator.js +33 -40
- package/dist/utils/chart-utils/original-data-utils/dashboard-calculator.js +16 -23
- package/dist/utils/chart-utils/original-data-utils/index.js +50 -57
- package/dist/utils/chart-utils/original-data-utils/mirror-calculator.js +19 -26
- package/dist/utils/chart-utils/original-data-utils/pivot-table-calculator.js +90 -96
- package/dist/utils/chart-utils/original-data-utils/scatter-calculator.js +19 -26
- package/dist/utils/chart-utils/original-data-utils/trend-calculator.js +31 -38
- package/dist/utils/chart-utils/sql-statistics-utils.js +229 -237
- package/dist/utils/chart.js +9 -17
- package/dist/utils/collaborator-manager.js +3 -9
- package/dist/utils/collaborator-utils.js +19 -31
- package/dist/utils/collaborator.js +6 -15
- package/dist/utils/color-utils.js +18 -29
- package/dist/utils/column-utils.js +77 -104
- package/dist/utils/common-utils.js +28 -53
- package/dist/utils/concurrency-manager.js +1 -7
- package/dist/utils/contexts.js +5 -12
- package/dist/utils/date-translate.js +12 -20
- package/dist/utils/digital-sign-utils.js +7 -14
- package/dist/utils/event-bus.js +1 -7
- package/dist/utils/hotkey.js +5 -11
- package/dist/utils/index.js +54 -221
- package/dist/utils/key-generator.js +2 -9
- package/dist/utils/map.js +22 -31
- package/dist/utils/object-utils.js +2 -8
- package/dist/utils/options-utils.js +10 -18
- package/dist/utils/row-record-utils.js +166 -178
- package/dist/utils/row-utils.js +27 -38
- package/dist/utils/search.js +24 -32
- package/dist/utils/sql/chart-data-sql.js +106 -112
- package/dist/utils/sql/column-2-sql-column.js +158 -168
- package/dist/utils/sql/index.js +3 -27
- package/dist/utils/trend-utils.js +39 -47
- package/dist/view/index.js +90 -96
- package/dist/view/title/index.js +16 -24
- package/dist/view/wrapper/area-group.js +45 -53
- package/dist/view/wrapper/area.js +43 -51
- package/dist/view/wrapper/bar-compare.js +38 -46
- package/dist/view/wrapper/bar-custom-stack.js +39 -47
- package/dist/view/wrapper/bar-group.js +45 -53
- package/dist/view/wrapper/bar-stack.js +48 -56
- package/dist/view/wrapper/bar.js +40 -48
- package/dist/view/wrapper/basic-number-card.js +26 -34
- package/dist/view/wrapper/chart-component.js +123 -131
- package/dist/view/wrapper/combination.js +55 -63
- package/dist/view/wrapper/completeness-group.js +40 -48
- package/dist/view/wrapper/completeness.js +36 -44
- package/dist/view/wrapper/dashboard.js +39 -44
- package/dist/view/wrapper/funnel.js +40 -43
- package/dist/view/wrapper/heat-map.js +62 -70
- package/dist/view/wrapper/horizontal-bar-group.js +52 -60
- package/dist/view/wrapper/horizontal-bar-stack.js +47 -55
- package/dist/view/wrapper/horizontal-bar.js +41 -49
- package/dist/view/wrapper/index.js +107 -115
- package/dist/view/wrapper/line-group.js +43 -51
- package/dist/view/wrapper/line.js +42 -50
- package/dist/view/wrapper/map-bubble.js +40 -48
- package/dist/view/wrapper/map-world-bubble.js +39 -47
- package/dist/view/wrapper/map-world.js +41 -49
- package/dist/view/wrapper/map.js +42 -50
- package/dist/view/wrapper/mirror.js +41 -49
- package/dist/view/wrapper/pie.js +44 -52
- package/dist/view/wrapper/ring.js +49 -57
- package/dist/view/wrapper/scatter.js +42 -50
- package/dist/view/wrapper/table/index.js +14 -22
- package/dist/view/wrapper/table/one-dimension-table-no-numeric-columns.js +49 -57
- package/dist/view/wrapper/table/one-dimension-table-with-numeric-columns.js +53 -61
- package/dist/view/wrapper/table/pivot-table-display-name.js +82 -90
- package/dist/view/wrapper/table/two-dimension-table.js +85 -93
- package/dist/view/wrapper/table-element/components/dataset-utils.js +23 -36
- package/dist/view/wrapper/table-element/components/formatter.js +90 -99
- package/dist/view/wrapper/table-element/components/formatters/FileFormatter/index.js +23 -32
- package/dist/view/wrapper/table-element/components/formatters/formula-formatter.js +9 -16
- package/dist/view/wrapper/table-element/components/formatters/link-formatter.js +90 -97
- package/dist/view/wrapper/table-element/components/formula-formatter.js +9 -16
- package/dist/view/wrapper/table-element/components/link-formatter.js +90 -97
- package/dist/view/wrapper/table-element/components/record.js +13 -20
- package/dist/view/wrapper/table-element/components/records-body.js +9 -17
- package/dist/view/wrapper/table-element/components/records-header/index.js +7 -15
- package/dist/view/wrapper/table-element/components/records-header/records-header-cell.js +8 -16
- package/dist/view/wrapper/table-element/components/records.js +25 -33
- package/dist/view/wrapper/table-element/components/resize-column-handle/resize-column-handle.js +5 -12
- package/dist/view/wrapper/table-element/components/utils.js +6 -16
- package/dist/view/wrapper/table-element/components/value-display-utils.js +4 -11
- package/dist/view/wrapper/table-element/components/vertical-scrollbar/index.js +6 -13
- package/dist/view/wrapper/table-element/index.js +18 -26
- package/dist/view/wrapper/treemap.js +38 -46
- package/dist/view/wrapper/trend.js +58 -66
- package/package.json +5 -5
package/dist/view/wrapper/bar.js
CHANGED
|
@@ -1,23 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
var _classnames = _interopRequireDefault(require("classnames"));
|
|
14
|
-
var _constants = require("../../constants");
|
|
15
|
-
var _utils = require("../../utils");
|
|
16
|
-
var _colorUtils = require("../../utils/color-utils");
|
|
17
|
-
var _intl = _interopRequireDefault(require("../../intl"));
|
|
18
|
-
var _tooltip = _interopRequireDefault(require("../../components/tooltip"));
|
|
19
|
-
var _chartComponent = _interopRequireDefault(require("./chart-component"));
|
|
20
|
-
class Bar extends _chartComponent.default {
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import PropTypes from 'prop-types';
|
|
3
|
+
import { debounce } from 'lodash-es';
|
|
4
|
+
import * as d3 from 'd3';
|
|
5
|
+
import classNames from 'classnames';
|
|
6
|
+
import { TYPE_COLOR_USING, CHART_STYLE_COLORS, CHART_THEME_COLOR } from '../../constants';
|
|
7
|
+
import { BaseUtils, isFunction } from '../../utils';
|
|
8
|
+
import { getLabelColor, getConvertedColorRules } from '../../utils/color-utils';
|
|
9
|
+
import intl from '../../intl';
|
|
10
|
+
import ToolTip from '../../components/tooltip';
|
|
11
|
+
import ChartComponent from './chart-component';
|
|
12
|
+
class Bar extends ChartComponent {
|
|
21
13
|
constructor(props) {
|
|
22
14
|
super(props);
|
|
23
15
|
this.handleResize = () => {
|
|
@@ -50,11 +42,11 @@ class Bar extends _chartComponent.default {
|
|
|
50
42
|
let {
|
|
51
43
|
result: data
|
|
52
44
|
} = this.props;
|
|
53
|
-
data =
|
|
45
|
+
data = BaseUtils.formatEmptyName(data, '', intl.get('Empty'));
|
|
54
46
|
if (!Array.isArray(data)) return;
|
|
55
47
|
this.draw(data);
|
|
56
48
|
this.renderAxisLabel(this.props.chart, this.props.tables, this.container);
|
|
57
|
-
|
|
49
|
+
isFunction(customRender) && customRender(this.chart);
|
|
58
50
|
};
|
|
59
51
|
this.getFillColor = data => {
|
|
60
52
|
const {
|
|
@@ -66,12 +58,12 @@ class Bar extends _chartComponent.default {
|
|
|
66
58
|
color_option,
|
|
67
59
|
y_axis_label_color_rules
|
|
68
60
|
} = chart.config;
|
|
69
|
-
let chartBarColor = y_axis_label_color ||
|
|
61
|
+
let chartBarColor = y_axis_label_color || CHART_STYLE_COLORS[0];
|
|
70
62
|
if (chartColorTheme) {
|
|
71
|
-
chartBarColor =
|
|
63
|
+
chartBarColor = BaseUtils.getCurrentTheme(chartColorTheme).colors[0];
|
|
72
64
|
}
|
|
73
|
-
const colorRules = color_option ===
|
|
74
|
-
const color =
|
|
65
|
+
const colorRules = color_option === TYPE_COLOR_USING.USE_RULES && y_axis_label_color_rules && getConvertedColorRules(y_axis_label_color_rules);
|
|
66
|
+
const color = getLabelColor({
|
|
75
67
|
chart: chart.config,
|
|
76
68
|
colorRules,
|
|
77
69
|
value: data.value
|
|
@@ -95,7 +87,7 @@ class Bar extends _chartComponent.default {
|
|
|
95
87
|
items: [{
|
|
96
88
|
color: this.getFillColor(data),
|
|
97
89
|
name: data.name,
|
|
98
|
-
value:
|
|
90
|
+
value: BaseUtils.getSummaryValueDisplayString(summaryColumn, Number(data.value), y_axis_summary_method)
|
|
99
91
|
}]
|
|
100
92
|
};
|
|
101
93
|
this.setState({
|
|
@@ -137,7 +129,7 @@ class Bar extends _chartComponent.default {
|
|
|
137
129
|
tables,
|
|
138
130
|
summaryColumn
|
|
139
131
|
} = this.props;
|
|
140
|
-
const theme =
|
|
132
|
+
const theme = CHART_THEME_COLOR[globalTheme];
|
|
141
133
|
const {
|
|
142
134
|
display_goal_line,
|
|
143
135
|
goal_value,
|
|
@@ -165,11 +157,11 @@ class Bar extends _chartComponent.default {
|
|
|
165
157
|
const y = d3.scaleLinear().domain(y_axis_auto_range ? [0, d3.max(data, d => d.value)] : [y_axis_min, y_axis_max]).range([chartHeight - insertPadding, insertPadding + marginTop]);
|
|
166
158
|
|
|
167
159
|
// Y axis
|
|
168
|
-
this.chart.append('g').attr('class', 'y-axis-wrapper').attr('transform',
|
|
160
|
+
this.chart.append('g').attr('class', 'y-axis-wrapper').attr('transform', `translate(${insertPadding}, 0)`).call(d3.axisLeft(y).tickSizeInner(0).ticks(5).tickFormat(d => BaseUtils.getSummaryValueDisplayString(summaryColumn, d, y_axis_summary_method))).call(g => this.drawYaxis(g, theme));
|
|
169
161
|
const x = d3.scaleBand().domain(data.map(item => item.name)).range([insertPadding + this.horizontalOverflowOffset, chartWidth - insertPadding]).paddingInner(0.5).paddingOuter(0.1);
|
|
170
162
|
|
|
171
163
|
// X axis
|
|
172
|
-
this.chart.append('g').attr('class', 'x-axis-wrapper').attr('transform',
|
|
164
|
+
this.chart.append('g').attr('class', 'x-axis-wrapper').attr('transform', `translate(0, ${chartHeight - insertPadding})`).call(d3.axisBottom(x).tickSizeOuter(0).tickSizeInner(5)).call(g => {
|
|
173
165
|
g.selectAll('.domain').attr('stroke', theme.XAxisColor);
|
|
174
166
|
g.selectAll('.tick line').attr('stroke', theme.XAxisColor);
|
|
175
167
|
g.selectAll('text').attr('font-size', theme.fontSize);
|
|
@@ -188,7 +180,7 @@ class Bar extends _chartComponent.default {
|
|
|
188
180
|
y: Number(path.dataset.y),
|
|
189
181
|
theme,
|
|
190
182
|
label_font_size,
|
|
191
|
-
text:
|
|
183
|
+
text: BaseUtils.getSummaryValueDisplayString(summaryColumn, Number(path.dataset.value), y_axis_summary_method)
|
|
192
184
|
});
|
|
193
185
|
}
|
|
194
186
|
// add rect borderRadius
|
|
@@ -222,12 +214,12 @@ class Bar extends _chartComponent.default {
|
|
|
222
214
|
componentDidMount() {
|
|
223
215
|
this.createChart();
|
|
224
216
|
this.drawChart();
|
|
225
|
-
this.debouncedHandleResize =
|
|
217
|
+
this.debouncedHandleResize = debounce(this.handleResize, 300);
|
|
226
218
|
window.addEventListener('resize', this.debouncedHandleResize);
|
|
227
219
|
}
|
|
228
220
|
componentDidUpdate(prevProps) {
|
|
229
221
|
super.componentDidUpdate(prevProps);
|
|
230
|
-
if (
|
|
222
|
+
if (BaseUtils.shouldChartComponentUpdate(prevProps, this.props)) {
|
|
231
223
|
this.destroyChart();
|
|
232
224
|
this.createChart();
|
|
233
225
|
this.drawChart();
|
|
@@ -245,13 +237,13 @@ class Bar extends _chartComponent.default {
|
|
|
245
237
|
tooltipData,
|
|
246
238
|
toolTipPosition
|
|
247
239
|
} = this.state;
|
|
248
|
-
return /*#__PURE__*/
|
|
240
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
249
241
|
ref: ref => this.container = ref,
|
|
250
|
-
className: (
|
|
242
|
+
className: classNames('sea-chart-container', {
|
|
251
243
|
'show-x-axis-label': this.isShowXAxisLabel(chart),
|
|
252
244
|
'show-y-axis-label': this.isShowYAxisLabel(chart)
|
|
253
245
|
})
|
|
254
|
-
}, /*#__PURE__*/
|
|
246
|
+
}, /*#__PURE__*/React.createElement(ToolTip, {
|
|
255
247
|
tooltipData: tooltipData,
|
|
256
248
|
toolTipPosition: toolTipPosition,
|
|
257
249
|
chart: this.chart
|
|
@@ -259,16 +251,16 @@ class Bar extends _chartComponent.default {
|
|
|
259
251
|
}
|
|
260
252
|
}
|
|
261
253
|
Bar.propTypes = {
|
|
262
|
-
canvasStyle:
|
|
263
|
-
chart:
|
|
264
|
-
groupbyColumn:
|
|
265
|
-
columnGroupbyColumn:
|
|
266
|
-
summaryColumn:
|
|
267
|
-
result:
|
|
268
|
-
tables:
|
|
269
|
-
globalTheme:
|
|
270
|
-
chartColorTheme:
|
|
271
|
-
toggleRecords:
|
|
272
|
-
customRender:
|
|
254
|
+
canvasStyle: PropTypes.object,
|
|
255
|
+
chart: PropTypes.object,
|
|
256
|
+
groupbyColumn: PropTypes.object,
|
|
257
|
+
columnGroupbyColumn: PropTypes.object,
|
|
258
|
+
summaryColumn: PropTypes.object,
|
|
259
|
+
result: PropTypes.array,
|
|
260
|
+
tables: PropTypes.array,
|
|
261
|
+
globalTheme: PropTypes.string,
|
|
262
|
+
chartColorTheme: PropTypes.string,
|
|
263
|
+
toggleRecords: PropTypes.func,
|
|
264
|
+
customRender: PropTypes.func
|
|
273
265
|
};
|
|
274
|
-
|
|
266
|
+
export default Bar;
|
|
@@ -1,17 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
});
|
|
8
|
-
exports.default = void 0;
|
|
9
|
-
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
-
var _dtableUtils = require("dtable-utils");
|
|
11
|
-
var _utils = require("../../utils");
|
|
12
|
-
var _intl = _interopRequireDefault(require("../../intl"));
|
|
13
|
-
var _constants = require("../../constants");
|
|
14
|
-
class BasicNumericCard extends _react.Component {
|
|
1
|
+
import React, { Component } from 'react';
|
|
2
|
+
import { isNumber } from 'dtable-utils';
|
|
3
|
+
import { BaseUtils } from '../../utils';
|
|
4
|
+
import intl from '../../intl';
|
|
5
|
+
import { BASIC_NUMBER_CARD_CALCULATION_METHOD, EMPTY_NAME, CHART_THEME_COLOR } from '../../constants';
|
|
6
|
+
class BasicNumericCard extends Component {
|
|
15
7
|
constructor(props) {
|
|
16
8
|
super(props);
|
|
17
9
|
this.setCurrentLineHeight = () => {
|
|
@@ -25,7 +17,7 @@ class BasicNumericCard extends _react.Component {
|
|
|
25
17
|
const currentLineHeight = parseFloat(computedStyle.lineHeight);
|
|
26
18
|
const currentLabelHeight = parseFloat(computedStyle.height);
|
|
27
19
|
if (prevLineHeight === currentLineHeight && prevLabelHeight === currentLabelHeight) return;
|
|
28
|
-
if (
|
|
20
|
+
if (isNumber(currentLineHeight) && isNumber(currentLabelHeight)) {
|
|
29
21
|
this.setState({
|
|
30
22
|
currentLineHeight,
|
|
31
23
|
currentLabelHeight
|
|
@@ -51,7 +43,7 @@ class BasicNumericCard extends _react.Component {
|
|
|
51
43
|
}
|
|
52
44
|
};
|
|
53
45
|
this.formatData = data => {
|
|
54
|
-
if (!data && data !== 0) return
|
|
46
|
+
if (!data && data !== 0) return intl.get(EMPTY_NAME);
|
|
55
47
|
const {
|
|
56
48
|
chart,
|
|
57
49
|
summaryColumn
|
|
@@ -61,8 +53,8 @@ class BasicNumericCard extends _react.Component {
|
|
|
61
53
|
summary_method
|
|
62
54
|
} = chart.config;
|
|
63
55
|
// COUNT / SUMMARIZE_A_FIELD
|
|
64
|
-
if (summary_type !==
|
|
65
|
-
const formattedContent =
|
|
56
|
+
if (summary_type !== BASIC_NUMBER_CARD_CALCULATION_METHOD) {
|
|
57
|
+
const formattedContent = BaseUtils.getSummaryValueDisplayString(summaryColumn, data, summary_method);
|
|
66
58
|
return formattedContent;
|
|
67
59
|
}
|
|
68
60
|
let string = data + '';
|
|
@@ -108,7 +100,7 @@ class BasicNumericCard extends _react.Component {
|
|
|
108
100
|
chart,
|
|
109
101
|
result
|
|
110
102
|
} = this.props;
|
|
111
|
-
const theme =
|
|
103
|
+
const theme = CHART_THEME_COLOR[globalTheme];
|
|
112
104
|
const {
|
|
113
105
|
config
|
|
114
106
|
} = chart;
|
|
@@ -127,47 +119,47 @@ class BasicNumericCard extends _react.Component {
|
|
|
127
119
|
const numericValue = typeof result === 'object' && result !== null ? result.value : result;
|
|
128
120
|
let content = null;
|
|
129
121
|
if (summary_method === 'Distinct_values') {
|
|
130
|
-
content =
|
|
122
|
+
content = isNumber(numericValue) ? numericValue : 0;
|
|
131
123
|
} else {
|
|
132
124
|
content = this.formatData(numericValue);
|
|
133
125
|
}
|
|
134
|
-
return /*#__PURE__*/
|
|
126
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
135
127
|
className: "sea-chart-container plugin-number-card"
|
|
136
|
-
}, /*#__PURE__*/
|
|
128
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
137
129
|
style: {
|
|
138
130
|
color: theme.cardColor,
|
|
139
131
|
width: '100%',
|
|
140
132
|
height: '100%',
|
|
141
133
|
position: 'relative'
|
|
142
134
|
}
|
|
143
|
-
}, /*#__PURE__*/
|
|
135
|
+
}, /*#__PURE__*/React.createElement("p", {
|
|
144
136
|
style: {
|
|
145
137
|
position: 'absolute',
|
|
146
138
|
width: '100%',
|
|
147
139
|
top: 'calc((100% - 25px)/2)',
|
|
148
140
|
transform: 'translateY(-50%)',
|
|
149
|
-
fontSize:
|
|
141
|
+
fontSize: `${font_size}px`,
|
|
150
142
|
margin: '-8px 0 2px 0',
|
|
151
|
-
textAlign:
|
|
152
|
-
fontWeight:
|
|
153
|
-
color:
|
|
143
|
+
textAlign: `${text_align}`,
|
|
144
|
+
fontWeight: `${font_weight}`,
|
|
145
|
+
color: `${font_color}`
|
|
154
146
|
}
|
|
155
|
-
}, /*#__PURE__*/
|
|
147
|
+
}, /*#__PURE__*/React.createElement("span", {
|
|
156
148
|
onClick: this.handleClickNumber,
|
|
157
149
|
style: {
|
|
158
150
|
cursor: 'pointer'
|
|
159
151
|
}
|
|
160
|
-
}, content)), /*#__PURE__*/
|
|
152
|
+
}, content)), /*#__PURE__*/React.createElement("p", {
|
|
161
153
|
ref: ref => this.labelRef = ref,
|
|
162
154
|
style: {
|
|
163
155
|
position: 'absolute',
|
|
164
156
|
width: '100%',
|
|
165
157
|
bottom: '0px',
|
|
166
158
|
margin: '0',
|
|
167
|
-
transform: currentLineHeight ?
|
|
168
|
-
fontSize:
|
|
169
|
-
fontWeight:
|
|
170
|
-
textAlign:
|
|
159
|
+
transform: currentLineHeight ? `translateY(${currentLabelHeight - currentLineHeight}px)` : '',
|
|
160
|
+
fontSize: `${card_label_font_size}px`,
|
|
161
|
+
fontWeight: `${label_font_weight}`,
|
|
162
|
+
textAlign: `${label_text_align}`,
|
|
171
163
|
color: label_font_color,
|
|
172
164
|
overflow: 'hidden',
|
|
173
165
|
textOverflow: 'ellipsis',
|
|
@@ -178,4 +170,4 @@ class BasicNumericCard extends _react.Component {
|
|
|
178
170
|
}, name)));
|
|
179
171
|
}
|
|
180
172
|
}
|
|
181
|
-
|
|
173
|
+
export default BasicNumericCard;
|