dtable-statistic 4.0.2-test-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 (210) hide show
  1. package/README.md +3 -0
  2. package/es/api/dtable-db-api.js +43 -0
  3. package/es/assets/css/color-picker.css +53 -0
  4. package/es/assets/css/color-rules-popover.css +144 -0
  5. package/es/assets/css/color-theme-dialog.css +40 -0
  6. package/es/assets/css/dashboard.css +562 -0
  7. package/es/assets/css/dialog.css +415 -0
  8. package/es/assets/css/mobile-dashboard.module.css +91 -0
  9. package/es/assets/css/slider.css +77 -0
  10. package/es/assets/css/statistic-chart.module.css +11 -0
  11. package/es/assets/css/statistic-custom-title.module.css +3 -0
  12. package/es/assets/css/statistic-custom.module.css +4 -0
  13. package/es/assets/css/statistic-numeric-column-item.module.css +43 -0
  14. package/es/assets/css/statistic-time-picker.module.css +21 -0
  15. package/es/assets/css/theme.css +61 -0
  16. package/es/assets/images/icon.png +0 -0
  17. package/es/calculator/base-calculator.js +111 -0
  18. package/es/calculator/basic-chart-calculator.js +571 -0
  19. package/es/calculator/combination-calculator.js +296 -0
  20. package/es/calculator/compare-bar-calculator.js +291 -0
  21. package/es/calculator/completeness-calculator.js +307 -0
  22. package/es/calculator/copy-value.js +47 -0
  23. package/es/calculator/dashboard-calculator.js +146 -0
  24. package/es/calculator/heat-map-calculator.js +225 -0
  25. package/es/calculator/horizontal-bar-calculator.js +100 -0
  26. package/es/calculator/index.js +88 -0
  27. package/es/calculator/map-calculator.js +169 -0
  28. package/es/calculator/mirror-calculator.js +217 -0
  29. package/es/calculator/number-card-calculator.js +135 -0
  30. package/es/calculator/pivot-table-calculator.js +810 -0
  31. package/es/calculator/scatter-calculator.js +150 -0
  32. package/es/calculator/thread-manager.js +70 -0
  33. package/es/calculator/trend-calculator.js +204 -0
  34. package/es/calculator/workers/basic-chart-calculator-worker.js +410 -0
  35. package/es/calculator/workers/calculator.worker.js +22 -0
  36. package/es/calculator/workers/card-calculator-worker.js +28 -0
  37. package/es/calculator/workers/combination-calculator-worker.js +257 -0
  38. package/es/calculator/workers/compare-bar-chart-calculator-worker.js +149 -0
  39. package/es/calculator/workers/completeness-calculator-worker.js +153 -0
  40. package/es/calculator/workers/dashboard-calculator-worker.js +56 -0
  41. package/es/calculator/workers/mirror-calculator-worker.js +132 -0
  42. package/es/calculator/workers/pivot-table-calculator-worker.js +615 -0
  43. package/es/calculator/workers/scatter-calculator-worker.js +67 -0
  44. package/es/calculator/workers/trend-calculator-worker.js +93 -0
  45. package/es/calculator/world-map-calculator.js +193 -0
  46. package/es/components/common-add-tool.js +19 -0
  47. package/es/components/dialog/chart-addition-edit-dialog.js +89 -0
  48. package/es/components/dialog/chart-addition-widgets/chart-selector.js +261 -0
  49. package/es/components/dialog/chart-addition-widgets/statistic-chart-selector.module.css +74 -0
  50. package/es/components/dialog/color-theme-dialog.js +71 -0
  51. package/es/components/dialog/enlarged-chart-dialog.js +73 -0
  52. package/es/components/dialog/new-table-dialog.js +113 -0
  53. package/es/components/dialog/new-view-dialog.js +87 -0
  54. package/es/components/dialog/rename-view-dialog.js +87 -0
  55. package/es/components/dialog/statistic-record-dialog/index.css +114 -0
  56. package/es/components/dialog/statistic-record-dialog/index.js +174 -0
  57. package/es/components/dialog/table-select-dialog.js +93 -0
  58. package/es/components/dropdown-menu/statistic-dropdown-menu.js +94 -0
  59. package/es/components/dtable-popover.js +109 -0
  60. package/es/components/dtable-search-input.js +137 -0
  61. package/es/components/dtable-select.js +104 -0
  62. package/es/components/index.js +11 -0
  63. package/es/components/loading.js +8 -0
  64. package/es/components/modal-portal.js +36 -0
  65. package/es/components/popover/color-rules/color-rule.js +179 -0
  66. package/es/components/popover/color-rules/index.js +87 -0
  67. package/es/components/popover/color-rules/rule-filters/filter.js +214 -0
  68. package/es/components/popover/color-rules/rule-filters/index.css +214 -0
  69. package/es/components/popover/color-rules/rule-filters/index.js +97 -0
  70. package/es/components/popover/color-rules/rule-filters/number-input.js +85 -0
  71. package/es/components/popover/color-rules-popover.js +213 -0
  72. package/es/components/popover/color-selector-popover.js +85 -0
  73. package/es/components/seatable-radio/index.css +51 -0
  74. package/es/components/seatable-radio/index.js +28 -0
  75. package/es/components/select/index.js +2 -0
  76. package/es/components/select/option-group.css +104 -0
  77. package/es/components/select/option-group.js +225 -0
  78. package/es/components/select/option.js +51 -0
  79. package/es/components/select/select.css +211 -0
  80. package/es/components/select/select.js +157 -0
  81. package/es/components/toast/alert.js +130 -0
  82. package/es/components/toast/index.js +3 -0
  83. package/es/components/toast/toast.js +164 -0
  84. package/es/components/toast/toastManager.js +150 -0
  85. package/es/components/toast/toaster.js +64 -0
  86. package/es/constants/color-rules.js +8 -0
  87. package/es/constants/dtable-select-style.js +61 -0
  88. package/es/constants/event-types.js +1 -0
  89. package/es/constants/index.js +501 -0
  90. package/es/constants/key-codes.js +102 -0
  91. package/es/constants/zIndexes.js +1 -0
  92. package/es/custom-g2.js +614 -0
  93. package/es/dashboard.js +408 -0
  94. package/es/desktop-dashboard.js +299 -0
  95. package/es/index.js +33 -0
  96. package/es/locale/index.js +17 -0
  97. package/es/locale/lang/de.js +237 -0
  98. package/es/locale/lang/en.js +237 -0
  99. package/es/locale/lang/fr.js +237 -0
  100. package/es/locale/lang/zh_CN.js +237 -0
  101. package/es/mobile-dashboard.js +103 -0
  102. package/es/model/collaborators.js +11 -0
  103. package/es/model/stat-item.js +340 -0
  104. package/es/model/statistic-dashboard.js +8 -0
  105. package/es/service/chart-service.js +192 -0
  106. package/es/service/dashboard-service.js +415 -0
  107. package/es/stat-editor/chart-name-editor.js +75 -0
  108. package/es/stat-editor/index.js +74 -0
  109. package/es/stat-editor/stat-settings/advance-chart-settings/basic-number-card-settings.js +149 -0
  110. package/es/stat-editor/stat-settings/advance-chart-settings/combination-settings.js +415 -0
  111. package/es/stat-editor/stat-settings/advance-chart-settings/dashboard-chart-settings.js +193 -0
  112. package/es/stat-editor/stat-settings/advance-chart-settings/geo-granularity-settings.js +13 -0
  113. package/es/stat-editor/stat-settings/advance-chart-settings/heat-map-settings.js +107 -0
  114. package/es/stat-editor/stat-settings/advance-chart-settings/index.js +332 -0
  115. package/es/stat-editor/stat-settings/advance-chart-settings/map-settings.js +170 -0
  116. package/es/stat-editor/stat-settings/advance-chart-settings/mirror-settings.js +141 -0
  117. package/es/stat-editor/stat-settings/advance-chart-settings/style-setting/combination-style-setting.js +219 -0
  118. package/es/stat-editor/stat-settings/advance-chart-settings/style-setting/heat-map-settings.js +89 -0
  119. package/es/stat-editor/stat-settings/advance-chart-settings/style-setting/map-setting.js +132 -0
  120. package/es/stat-editor/stat-settings/advance-chart-settings/summary-settings.js +319 -0
  121. package/es/stat-editor/stat-settings/advance-chart-settings/trend-chart-settings.js +138 -0
  122. package/es/stat-editor/stat-settings/advance-chart-settings/world-map-settings.js +135 -0
  123. package/es/stat-editor/stat-settings/basic-chart-settings/advance-bar-chart-settings.js +156 -0
  124. package/es/stat-editor/stat-settings/basic-chart-settings/bar-settings.js +147 -0
  125. package/es/stat-editor/stat-settings/basic-chart-settings/completeness-chart-settings.js +195 -0
  126. package/es/stat-editor/stat-settings/basic-chart-settings/custom-bar-settings.js +126 -0
  127. package/es/stat-editor/stat-settings/basic-chart-settings/groupby-settings.js +169 -0
  128. package/es/stat-editor/stat-settings/basic-chart-settings/horizontal-axis-group-settings.js +352 -0
  129. package/es/stat-editor/stat-settings/basic-chart-settings/horizontal-bar-settings.js +145 -0
  130. package/es/stat-editor/stat-settings/basic-chart-settings/horizontal-group-chart-settings.js +153 -0
  131. package/es/stat-editor/stat-settings/basic-chart-settings/index.js +466 -0
  132. package/es/stat-editor/stat-settings/basic-chart-settings/pie-settings.js +183 -0
  133. package/es/stat-editor/stat-settings/basic-chart-settings/pivot-table-settings.js +542 -0
  134. package/es/stat-editor/stat-settings/basic-chart-settings/scatter-settings.js +111 -0
  135. package/es/stat-editor/stat-settings/basic-chart-settings/stack-item-settings.js +86 -0
  136. package/es/stat-editor/stat-settings/basic-chart-settings/stacks-settings.js +169 -0
  137. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/bar-chart-style-setting.js +273 -0
  138. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/completeness-style.js +105 -0
  139. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/horizontal-bar-chart-style.js +243 -0
  140. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/label-font-size-editor.js +65 -0
  141. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/pie-chart-style-settings.js +318 -0
  142. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/time-compare-style.js +49 -0
  143. package/es/stat-editor/stat-settings/basic-chart-settings/summary-method-setting.js +124 -0
  144. package/es/stat-editor/stat-settings/basic-chart-settings/summary-settings.js +150 -0
  145. package/es/stat-editor/stat-settings/basic-chart-settings/time-comparison-settings.js +267 -0
  146. package/es/stat-editor/stat-settings/basic-chart-settings/timer-picker.js +109 -0
  147. package/es/stat-editor/stat-settings/basic-chart-settings/y-axis-group-settings.js +351 -0
  148. package/es/stat-editor/stat-settings/color-setting/color-group-selector.js +60 -0
  149. package/es/stat-editor/stat-settings/color-setting/color-picker.js +129 -0
  150. package/es/stat-editor/stat-settings/color-setting/color-use-type-selector.js +348 -0
  151. package/es/stat-editor/stat-settings/public-setting/axis-label-position-setting.js +102 -0
  152. package/es/stat-editor/stat-settings/public-setting/base-settings.js +124 -0
  153. package/es/stat-editor/stat-settings/public-setting/calender.js +124 -0
  154. package/es/stat-editor/stat-settings/public-setting/column-settings.js +15 -0
  155. package/es/stat-editor/stat-settings/public-setting/custom-title-setting.js +60 -0
  156. package/es/stat-editor/stat-settings/public-setting/data-sort-setting.js +57 -0
  157. package/es/stat-editor/stat-settings/public-setting/ind-toggle-setting.js +41 -0
  158. package/es/stat-editor/stat-settings/public-setting/min-max-setting.js +64 -0
  159. package/es/stat-editor/stat-settings/public-setting/numeric-summary-item.js +118 -0
  160. package/es/stat-editor/stat-settings/public-setting/toggle-setting.js +39 -0
  161. package/es/stat-list/chart-preview.js +139 -0
  162. package/es/stat-list/index.js +275 -0
  163. package/es/stat-view/area-chart.js +521 -0
  164. package/es/stat-view/bar-chart.js +568 -0
  165. package/es/stat-view/base-chart.js +44 -0
  166. package/es/stat-view/basic-number-card.js +255 -0
  167. package/es/stat-view/combination-chart.js +558 -0
  168. package/es/stat-view/compare-chart.js +485 -0
  169. package/es/stat-view/completeness-chart.js +389 -0
  170. package/es/stat-view/custom-bar.js +433 -0
  171. package/es/stat-view/dashboard-chart.js +317 -0
  172. package/es/stat-view/heat-map.js +501 -0
  173. package/es/stat-view/horizontal-bar-chart.js +569 -0
  174. package/es/stat-view/index.js +183 -0
  175. package/es/stat-view/line-chart.js +505 -0
  176. package/es/stat-view/map.js +428 -0
  177. package/es/stat-view/mirror.js +285 -0
  178. package/es/stat-view/pie-chart.js +326 -0
  179. package/es/stat-view/pivot-table/index.js +206 -0
  180. package/es/stat-view/pivot-table/one-dimension-table-no-numeric-columns.js +133 -0
  181. package/es/stat-view/pivot-table/one-dimension-table-with-numeric-columns.js +164 -0
  182. package/es/stat-view/pivot-table/statistic-pivot-table.module.css +132 -0
  183. package/es/stat-view/pivot-table/two-dimension-table.js +344 -0
  184. package/es/stat-view/ring-chart.js +416 -0
  185. package/es/stat-view/scatter-chart.js +367 -0
  186. package/es/stat-view/treemap-chart.js +318 -0
  187. package/es/stat-view/trend-chart.js +299 -0
  188. package/es/stat-view/world-map.js +443 -0
  189. package/es/tabs/index.js +252 -0
  190. package/es/tabs/statistic-tabs.module.css +154 -0
  191. package/es/tabs/tab.js +167 -0
  192. package/es/utils/basic-chart-utils.js +24 -0
  193. package/es/utils/cell-format.js +110 -0
  194. package/es/utils/cell-value.js +27 -0
  195. package/es/utils/collaborator.js +31 -0
  196. package/es/utils/color-utils.js +112 -0
  197. package/es/utils/column-utils.js +18 -0
  198. package/es/utils/column.js +13 -0
  199. package/es/utils/common-utils.js +303 -0
  200. package/es/utils/date-format.js +65 -0
  201. package/es/utils/export-table-utils.js +632 -0
  202. package/es/utils/index.js +26 -0
  203. package/es/utils/object.js +26 -0
  204. package/es/utils/row-utils.js +115 -0
  205. package/es/utils/search.js +67 -0
  206. package/es/utils/sql-utils.js +293 -0
  207. package/es/utils/stat-utils.js +353 -0
  208. package/es/utils/trend-utils.js +136 -0
  209. package/index.js +1 -0
  210. package/package.json +188 -0
@@ -0,0 +1,433 @@
1
+ import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
2
+ import _createClass from "@babel/runtime/helpers/esm/createClass";
3
+ import _inherits from "@babel/runtime/helpers/esm/inherits";
4
+ import _createSuper from "@babel/runtime/helpers/esm/createSuper";
5
+ import React from 'react';
6
+ import PropTypes from 'prop-types';
7
+ import DataSet from '@antv/data-set';
8
+ import intl from 'react-intl-universal';
9
+ import { TableUtils } from 'dtable-store';
10
+ import { Chart } from '../custom-g2';
11
+ import BaseChart from './base-chart';
12
+ import { Loading } from '../components';
13
+ import { getChartDisplayLabels, getChartGroups } from '../utils/basic-chart-utils';
14
+ import { getCurrentTheme, getLabelFontSize } from '../utils/common-utils';
15
+ import { EMPTY_NAME, STAT_ITEM_THEME_COLORS, LABEL_CONFIG_CHANGED, TITLE_AMOUNT, NO_STATISTIC_RESULTS } from '../constants';
16
+ var propTypes = {
17
+ isPreview: PropTypes.bool,
18
+ isEnlarge: PropTypes.bool,
19
+ isEdit: PropTypes.bool,
20
+ statItem: PropTypes.object,
21
+ labelColorConfigs: PropTypes.array,
22
+ chartCalculator: PropTypes.object,
23
+ eventBus: PropTypes.object,
24
+ theme: PropTypes.string,
25
+ colorThemeName: PropTypes.string,
26
+ toggleStatisticRecordsDialog: PropTypes.func
27
+ };
28
+ var CustomBar = /*#__PURE__*/function (_BaseChart) {
29
+ _inherits(CustomBar, _BaseChart);
30
+ var _super = _createSuper(CustomBar);
31
+ function CustomBar(props) {
32
+ var _this;
33
+ _classCallCheck(this, CustomBar);
34
+ _this = _super.call(this, props);
35
+ _this.drawChart = function (originalData) {
36
+ // just support custom stack-bar
37
+ var _this$props = _this.props,
38
+ isPreview = _this$props.isPreview,
39
+ statItem = _this$props.statItem,
40
+ isEnlarge = _this$props.isEnlarge,
41
+ theme = _this$props.theme,
42
+ colorThemeName = _this$props.colorThemeName;
43
+ var display_data = statItem.display_data;
44
+ var currentTheme = getCurrentTheme(colorThemeName);
45
+ var data = originalData;
46
+ var viewConfig = {
47
+ container: _this.container,
48
+ autoFit: true,
49
+ appendPadding: [display_data ? 17 : 0, 0, 0, 0]
50
+ };
51
+ if (!isPreview) {
52
+ viewConfig.height = 400;
53
+ viewConfig.width = 700;
54
+ }
55
+ _this.chart = new Chart(viewConfig);
56
+ _this.chart.on('interval:click', function (e) {
57
+ _this.props.toggleStatisticRecordsDialog(e.data.data, statItem);
58
+ });
59
+ _this.chart.scale('group_name', {
60
+ type: 'cat'
61
+ });
62
+ _this.chart.data(data, {
63
+ 'name': {
64
+ type: 'cat',
65
+ nice: false
66
+ }
67
+ });
68
+ var width = _this.chart.coordinateBBox.width;
69
+ var themeColors = STAT_ITEM_THEME_COLORS.light;
70
+ if (theme === 'dark' && !isEnlarge && isPreview) {
71
+ themeColors = STAT_ITEM_THEME_COLORS.dark;
72
+ }
73
+ var chartData = getChartGroups(data);
74
+ var labelCount = chartData.length;
75
+ if (Math.floor(width / labelCount) <= 20) {
76
+ var displayLabels = getChartDisplayLabels(width, 20, chartData);
77
+ labelCount = displayLabels.length;
78
+ _this.chart.scale('name', {
79
+ ticks: displayLabels
80
+ });
81
+ }
82
+
83
+ // set Coord type
84
+ _this.chart.coordinate('rect');
85
+ _this.chart.scale({
86
+ // Set the type of the name column so that g2 can draw correctly
87
+ name: {
88
+ type: 'cat'
89
+ }
90
+ });
91
+ var labelCfg = {
92
+ style: {
93
+ fontSize: _this.getLabelFontSize(),
94
+ fill: themeColors.textColor
95
+ }
96
+ };
97
+ var display_each_block_data = statItem.display_each_block_data;
98
+ var displayData = display_each_block_data;
99
+ if (displayData) {
100
+ labelCfg.position = 'middle';
101
+ }
102
+
103
+ // get the total value of each stack
104
+ var dv = new DataSet.DataView().source(data);
105
+ dv.transform({
106
+ type: 'aggregate',
107
+ fields: ['value'],
108
+ operations: ['sum'],
109
+ as: ['value_sum'],
110
+ groupBy: ['name', 'y_axis_type']
111
+ });
112
+ var groupColorCallback = currentTheme && currentTheme.colors;
113
+ _this.chart.scale({
114
+ group_name: {
115
+ type: 'cat'
116
+ }
117
+ });
118
+ _this.chart.interval().label(displayData ? 'formatted_value' : false, labelCfg).position('name*value').color('group_name', groupColorCallback).tooltip('name*formatted_value*group_name*raw_name', function (name, formatted_value, group_name, raw_name) {
119
+ var nameContent = group_name;
120
+ if (!group_name && typeof group_name !== 'number') {
121
+ nameContent = intl.get(EMPTY_NAME);
122
+ }
123
+ var title = !name && typeof name !== 'number' ? intl.get(EMPTY_NAME) : name;
124
+ return {
125
+ title: title,
126
+ value: formatted_value,
127
+ name: nameContent
128
+ };
129
+ }).adjust([{
130
+ type: 'dodge',
131
+ dodgeBy: 'y_axis_type',
132
+ marginRatio: 0.1
133
+ }, {
134
+ type: 'stack'
135
+ }]).state({
136
+ active: {
137
+ style: {
138
+ stroke: null
139
+ }
140
+ }
141
+ });
142
+ _this.chart.tooltip({
143
+ showTitle: true,
144
+ showMarkers: false,
145
+ containerTpl: '<div class="g2-tooltip"><div class="g2-tooltip-list"></div></div>',
146
+ itemTpl: '<div class="g2-tooltip-content"><div class="tooltip-name">{title}<div><div class="tooltip-item">{name}: {value}<div></div>',
147
+ domStyles: {
148
+ 'g2-tooltip': {
149
+ borderRadius: '2px',
150
+ backgroundColor: '#fff',
151
+ padding: '10px'
152
+ },
153
+ 'tooltip-item': {
154
+ marginTop: '5px'
155
+ }
156
+ }
157
+ });
158
+
159
+ // set axis label and tooltip
160
+ _this.chart.axis('name', {
161
+ line: {
162
+ style: themeColors.gridColor
163
+ },
164
+ label: {
165
+ autoRotate: true,
166
+ style: {
167
+ fill: themeColors.textColor
168
+ },
169
+ formatter: function formatter(name) {
170
+ var label = name;
171
+ if (name.length > 10) {
172
+ label = "".concat(name.slice(0, 10), "...");
173
+ }
174
+ if (name === '' || name === 'undefined') {
175
+ label = intl.get(EMPTY_NAME);
176
+ }
177
+ return label;
178
+ }
179
+ }
180
+ });
181
+ _this.chart.axis('value', {
182
+ label: {
183
+ style: {
184
+ fill: themeColors.textColor
185
+ }
186
+ },
187
+ grid: {
188
+ line: {
189
+ style: {
190
+ stroke: themeColors.gridColor
191
+ }
192
+ }
193
+ }
194
+ });
195
+ var legendPosition = 'bottom';
196
+ _this.chart.legend('group_name', {
197
+ position: legendPosition,
198
+ itemName: {
199
+ style: {
200
+ fill: themeColors.textColor
201
+ },
202
+ formatter: function formatter(name) {
203
+ if (!name && typeof name !== 'number') {
204
+ return intl.get(EMPTY_NAME);
205
+ }
206
+ return name;
207
+ }
208
+ },
209
+ pageNavigator: {
210
+ text: {
211
+ style: {
212
+ fill: themeColors.textColor
213
+ }
214
+ },
215
+ marker: {
216
+ style: {
217
+ fill: themeColors.legendPageNavigatorMarkerColor,
218
+ inactiveFill: themeColors.legendPageNavigatorMarkerColor,
219
+ inactiveOpacity: 0.45
220
+ }
221
+ }
222
+ }
223
+ });
224
+ _this.chart.interaction('active-region');
225
+ _this.chart.render();
226
+ _this.renderAxisLabel();
227
+ };
228
+ _this.renderAxisLabel = function (newStatItem) {
229
+ var _this$props2 = _this.props,
230
+ getTableById = _this$props2.getTableById,
231
+ statItem = _this$props2.statItem,
232
+ isEnlarge = _this$props2.isEnlarge,
233
+ isPreview = _this$props2.isPreview,
234
+ theme = _this$props2.theme;
235
+ if (newStatItem && newStatItem._id !== statItem._id) {
236
+ return;
237
+ }
238
+ if (!_this.chart) return;
239
+ statItem = newStatItem || statItem;
240
+ var _statItem = statItem,
241
+ table_id = _statItem.table_id,
242
+ x_axis_column_key = _statItem.x_axis_column_key,
243
+ show_y_axis_label = _statItem.show_y_axis_label,
244
+ show_x_axis_label = _statItem.show_x_axis_label,
245
+ y_axis_label_position = _statItem.y_axis_label_position,
246
+ x_axis_label_position = _statItem.x_axis_label_position,
247
+ title_name = _statItem.title_name;
248
+ var table = getTableById(table_id);
249
+ var autoPadding = _this.chart.autoPadding;
250
+ var textColor = '#999999';
251
+ if (theme === 'dark' && !isEnlarge && isPreview) {
252
+ textColor = '#ffffff';
253
+ }
254
+ var xAxisID = "chart-x-axis-label_".concat(statItem._id);
255
+ var chartContainer = _this.chart.getCanvas().get('container');
256
+ var xLabel = chartContainer.querySelector("#".concat(xAxisID));
257
+ if (!xLabel && show_x_axis_label) {
258
+ var div = document.createElement('div');
259
+ div.id = xAxisID;
260
+ div.className = 'statistic-chart-axis-label';
261
+ var column = TableUtils.getTableColumnByKey(table, x_axis_column_key);
262
+ div.innerHTML = "".concat(column ? column.name : '');
263
+ div.setAttribute('style', "color:".concat(textColor, "; width: 100%; padding-left: ").concat(autoPadding.left, "px; text-align: ").concat(x_axis_label_position, "; bottom: -20px"));
264
+ chartContainer.appendChild(div);
265
+ }
266
+ if (xLabel && show_x_axis_label) {
267
+ xLabel.setAttribute('style', "color:".concat(textColor, "; width: 100%; padding-left: ").concat(autoPadding.left, "px; text-align: ").concat(x_axis_label_position, "; bottom: -20px"));
268
+ }
269
+ if (xLabel && !show_x_axis_label) {
270
+ xLabel.parentNode.removeChild(xLabel);
271
+ }
272
+ var yAxisID = "chart-y-axis-label_".concat(statItem._id);
273
+ var yLabel = chartContainer.querySelector("#".concat(yAxisID));
274
+ var paddingLeft = autoPadding.bottom + (show_x_axis_label ? 10 : 0);
275
+ if (!yLabel && show_y_axis_label) {
276
+ var _div = document.createElement('div');
277
+ _div.id = yAxisID;
278
+ _div.className = 'statistic-chart-axis-label';
279
+ _div.innerHTML = title_name || intl.get(TITLE_AMOUNT);
280
+ var containerHeight = chartContainer.offsetHeight;
281
+ var textAlign = 'center';
282
+ if (y_axis_label_position === 'bottom') textAlign = 'left';
283
+ if (y_axis_label_position === 'top') textAlign = 'right';
284
+ _div.setAttribute('style', "color:".concat(textColor, "; padding-right: ").concat(autoPadding.top, "px; padding-left: ").concat(paddingLeft, "px; position: absolute; width: ").concat(containerHeight, "px; text-align: ").concat(textAlign, "; top: 0; left: 0px; transform: translate(-").concat(containerHeight / 2 + 12, "px, ").concat((containerHeight - autoPadding.bottom) / 2 + autoPadding.bottom / 4, "px) rotate(-90deg)"));
285
+ chartContainer.appendChild(_div);
286
+ }
287
+ if (yLabel && show_y_axis_label) {
288
+ var _containerHeight = chartContainer.offsetHeight;
289
+ var _textAlign = 'center';
290
+ if (y_axis_label_position === 'bottom') _textAlign = 'left';
291
+ if (y_axis_label_position === 'top') _textAlign = 'right';
292
+ yLabel.setAttribute('style', "color:".concat(textColor, "; padding-right: ").concat(autoPadding.top, "px; padding-left: ").concat(paddingLeft, "px; position: absolute; width: ").concat(_containerHeight, "px; text-align: ").concat(_textAlign, "; top: 0; left: 0px; transform: translate(-").concat(_containerHeight / 2 + 12, "px, ").concat((_containerHeight - autoPadding.bottom) / 2 + autoPadding.bottom / 4, "px) rotate(-90deg)"));
293
+ }
294
+ if (yLabel && !show_y_axis_label) {
295
+ yLabel.parentNode.removeChild(yLabel);
296
+ }
297
+ };
298
+ _this.destroyChart = function () {
299
+ _this.chart.destroy();
300
+ _this.chart = null;
301
+ };
302
+ _this.getLabelFontSize = function () {
303
+ var statItem = _this.props.statItem;
304
+ var label_font_size = statItem.label_font_size;
305
+ return getLabelFontSize(label_font_size);
306
+ };
307
+ _this.state = {
308
+ isCalculatingData: true,
309
+ showResultDescription: true
310
+ };
311
+ _this.calculateData = null;
312
+ return _this;
313
+ }
314
+ _createClass(CustomBar, [{
315
+ key: "componentDidMount",
316
+ value: function componentDidMount() {
317
+ var _this2 = this;
318
+ var _this$props3 = this.props,
319
+ statItem = _this$props3.statItem,
320
+ chartCalculator = _this$props3.chartCalculator,
321
+ eventBus = _this$props3.eventBus;
322
+ this.unsubscribeStyleChange = eventBus.subscribe(LABEL_CONFIG_CHANGED, function (newStatItem) {
323
+ _this2.renderAxisLabel(newStatItem);
324
+ });
325
+ chartCalculator.calculate(statItem).then(function (data) {
326
+ if (!_this2.container) return;
327
+ var showResultDescription = data.length > 0 ? false : true;
328
+ _this2.setState({
329
+ isCalculatingData: false,
330
+ showResultDescription: showResultDescription
331
+ }, function () {
332
+ if (!showResultDescription) {
333
+ _this2.drawChart(data);
334
+ _this2.calculateData = data;
335
+ }
336
+ });
337
+ });
338
+ }
339
+ }, {
340
+ key: "shouldComponentUpdate",
341
+ value: function shouldComponentUpdate(nextProps, nextState) {
342
+ var _this$props4 = this.props,
343
+ statItem = _this$props4.statItem,
344
+ colorThemeName = _this$props4.colorThemeName;
345
+ var nextStatItem = nextProps.statItem;
346
+ if (this.canUpdate(this.props, nextProps) || statItem.y_axises !== nextStatItem.y_axises) {
347
+ return true;
348
+ }
349
+ if (nextState.isCalculatingData !== this.state.isCalculatingData) {
350
+ return true;
351
+ }
352
+ if (nextProps.colorThemeName !== colorThemeName) {
353
+ return true;
354
+ }
355
+ return false;
356
+ }
357
+ }, {
358
+ key: "componentDidUpdate",
359
+ value: function componentDidUpdate(preProps, preState) {
360
+ var _this3 = this;
361
+ var _this$props5 = this.props,
362
+ statItem = _this$props5.statItem,
363
+ chartCalculator = _this$props5.chartCalculator;
364
+ var isCalculatingData = this.state.isCalculatingData;
365
+ if (isCalculatingData !== preState.isCalculatingData) return;
366
+ if (this.shouldCalculateStatItem(preProps, this.props) || preProps.statItem.y_axises !== statItem.y_axises) {
367
+ this.setState({
368
+ isCalculatingData: true
369
+ });
370
+ chartCalculator.calculate(statItem).then(function (data) {
371
+ var showResultDescription = data.length > 0 ? false : true;
372
+ if (_this3.chart) {
373
+ _this3.destroyChart();
374
+ }
375
+ if (!_this3.container) return;
376
+ _this3.calculateData = data;
377
+ _this3.setState({
378
+ isCalculatingData: false,
379
+ showResultDescription: showResultDescription
380
+ }, function () {
381
+ if (!showResultDescription) {
382
+ _this3.drawChart(data);
383
+ if (_this3.props.isPreview) _this3.chart.forceFit();
384
+ }
385
+ });
386
+ });
387
+ } else {
388
+ if (!this.state.showResultDescription) {
389
+ if (this.chart) {
390
+ this.destroyChart();
391
+ }
392
+ this.drawChart(this.calculateData);
393
+ if (this.props.isPreview) {
394
+ this.chart.forceFit();
395
+ }
396
+ }
397
+ }
398
+ }
399
+ }, {
400
+ key: "componentWillUnmount",
401
+ value: function componentWillUnmount() {
402
+ this.container = null;
403
+ this.unsubscribeStyleChange();
404
+ }
405
+ }, {
406
+ key: "render",
407
+ value: function render() {
408
+ var _this4 = this;
409
+ var statItem = this.props.statItem;
410
+ var _this$state = this.state,
411
+ isCalculatingData = _this$state.isCalculatingData,
412
+ showResultDescription = _this$state.showResultDescription;
413
+ var show_y_axis_label = statItem.show_y_axis_label,
414
+ show_x_axis_label = statItem.show_x_axis_label;
415
+ return /*#__PURE__*/React.createElement(React.Fragment, null, isCalculatingData && /*#__PURE__*/React.createElement("div", {
416
+ className: 'statistic-chart-loading-container'
417
+ }, /*#__PURE__*/React.createElement(Loading, null)), showResultDescription && /*#__PURE__*/React.createElement("div", {
418
+ className: 'statistic-chart-text'
419
+ }, intl.get(NO_STATISTIC_RESULTS)), /*#__PURE__*/React.createElement("div", {
420
+ ref: function ref(_ref) {
421
+ return _this4.container = _ref;
422
+ },
423
+ style: {
424
+ padding: show_y_axis_label || show_x_axis_label ? 30 : 20
425
+ },
426
+ className: "statistic-chart-container"
427
+ }));
428
+ }
429
+ }]);
430
+ return CustomBar;
431
+ }(BaseChart);
432
+ CustomBar.propTypes = propTypes;
433
+ export default CustomBar;