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,299 @@
1
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
2
+ import _asyncToGenerator from "@babel/runtime/helpers/esm/asyncToGenerator";
3
+ import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
4
+ import _createClass from "@babel/runtime/helpers/esm/createClass";
5
+ import _inherits from "@babel/runtime/helpers/esm/inherits";
6
+ import _createSuper from "@babel/runtime/helpers/esm/createSuper";
7
+ import React from 'react';
8
+ import PropTypes from 'prop-types';
9
+ import intl from 'react-intl-universal';
10
+ import { TableUtils, getNumberDisplayString } from 'dtable-store';
11
+ import BaseChart from './base-chart';
12
+ import { Chart } from '../custom-g2';
13
+ import { Loading } from '../components';
14
+ import { DATE_GRANULARITY, EMPTY_NAME, STATISTICS_COUNT_TYPE, STAT_ITEM_THEME_COLORS } from '../constants';
15
+ var propTypes = {
16
+ isPreview: PropTypes.bool,
17
+ isEnlarge: PropTypes.bool,
18
+ theme: PropTypes.string,
19
+ statItem: PropTypes.object,
20
+ chartCalculator: PropTypes.object,
21
+ getTableById: PropTypes.func
22
+ };
23
+ var BasicNumericCard = /*#__PURE__*/function (_BaseChart) {
24
+ _inherits(BasicNumericCard, _BaseChart);
25
+ var _super = _createSuper(BasicNumericCard);
26
+ function BasicNumericCard(props) {
27
+ var _this;
28
+ _classCallCheck(this, BasicNumericCard);
29
+ _this = _super.call(this, props);
30
+ _this.componentDidMount = /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
31
+ var _this$props, statItem, chartCalculator, data;
32
+ return _regeneratorRuntime.wrap(function _callee$(_context) {
33
+ while (1) {
34
+ switch (_context.prev = _context.next) {
35
+ case 0:
36
+ _this$props = _this.props, statItem = _this$props.statItem, chartCalculator = _this$props.chartCalculator;
37
+ if (!_this.container) {
38
+ _context.next = 8;
39
+ break;
40
+ }
41
+ _context.next = 4;
42
+ return chartCalculator.calculate(statItem);
43
+ case 4:
44
+ data = _context.sent;
45
+ _this.setState({
46
+ isCalculatingData: false
47
+ });
48
+ _this.drawChart(data);
49
+ _this.calculateData = data;
50
+ case 8:
51
+ case "end":
52
+ return _context.stop();
53
+ }
54
+ }
55
+ }, _callee);
56
+ }));
57
+ _this.componentDidUpdate = /*#__PURE__*/function () {
58
+ var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(preProps, preState) {
59
+ var _this$props2, statItem, chartCalculator, isCalculatingData, data;
60
+ return _regeneratorRuntime.wrap(function _callee2$(_context2) {
61
+ while (1) {
62
+ switch (_context2.prev = _context2.next) {
63
+ case 0:
64
+ _this$props2 = _this.props, statItem = _this$props2.statItem, chartCalculator = _this$props2.chartCalculator;
65
+ isCalculatingData = _this.state.isCalculatingData;
66
+ if (!(isCalculatingData !== preState.isCalculatingData)) {
67
+ _context2.next = 4;
68
+ break;
69
+ }
70
+ return _context2.abrupt("return");
71
+ case 4:
72
+ if (!_this.shouldCalculateStatItem(preProps, _this.props)) {
73
+ _context2.next = 17;
74
+ break;
75
+ }
76
+ _this.setState({
77
+ isCalculatingData: true
78
+ });
79
+ if (!_this.container) {
80
+ _context2.next = 15;
81
+ break;
82
+ }
83
+ _context2.next = 9;
84
+ return chartCalculator.calculate(statItem);
85
+ case 9:
86
+ data = _context2.sent;
87
+ _this.calculateData = data;
88
+ _this.setState({
89
+ isCalculatingData: false
90
+ });
91
+ _this.chart && _this.chart.destroy();
92
+ _this.drawChart(data);
93
+ if (_this.props.isPreview) {
94
+ _this.chart.forceFit();
95
+ }
96
+ case 15:
97
+ _context2.next = 20;
98
+ break;
99
+ case 17:
100
+ _this.chart && _this.chart.destroy();
101
+ _this.drawChart(_this.calculateData);
102
+ if (_this.props.isPreview) {
103
+ _this.chart.forceFit();
104
+ }
105
+ case 20:
106
+ case "end":
107
+ return _context2.stop();
108
+ }
109
+ }
110
+ }, _callee2);
111
+ }));
112
+ return function (_x, _x2) {
113
+ return _ref2.apply(this, arguments);
114
+ };
115
+ }();
116
+ _this.drawChart = function (data) {
117
+ var _this$props3 = _this.props,
118
+ isPreview = _this$props3.isPreview,
119
+ isEnlarge = _this$props3.isEnlarge,
120
+ theme = _this$props3.theme,
121
+ statItem = _this$props3.statItem;
122
+ if (isPreview) {
123
+ _this.chart = new Chart({
124
+ container: _this.container,
125
+ autoFit: true
126
+ });
127
+ } else {
128
+ _this.chart = new Chart({
129
+ container: _this.container,
130
+ autoFit: true,
131
+ height: 400,
132
+ width: 700
133
+ });
134
+ }
135
+ var summary_method = statItem.summary_method;
136
+ var latest = data && data.latest;
137
+ var content = summary_method === 'Distinct_values' ? latest : _this.formatData(latest);
138
+ var fontSize = _this.getFontSize(content);
139
+ var labelFontSize = fontSize - 32;
140
+ var themeColors = STAT_ITEM_THEME_COLORS.light;
141
+ if (theme === 'dark' && !isEnlarge && isPreview) {
142
+ themeColors = STAT_ITEM_THEME_COLORS.dark;
143
+ }
144
+ var labelContent = _this.createLabelContent(data, labelFontSize);
145
+ _this.chart.annotation().html({
146
+ position: ['50%', '50%'],
147
+ html: "\n <div style=\"color:".concat(themeColors.cardColor, "; text-align: center;\">\n <p class=\"text-content\" style=\"font-size: ").concat(fontSize, "px; margin: -8px 0 2px 0;\">").concat(content, "</p>\n <p style=\"margin: 0;\">").concat(labelContent, "</p>\n </div>\n ")
148
+ });
149
+ _this.chart.render();
150
+ };
151
+ _this.formatData = function (data) {
152
+ var _this$props4 = _this.props,
153
+ getTableById = _this$props4.getTableById,
154
+ statItem = _this$props4.statItem;
155
+ if (typeof data !== 'number') return intl.get(EMPTY_NAME);
156
+ var table_id = statItem.table_id,
157
+ summary_type = statItem.summary_type,
158
+ summary_column = statItem.summary_column;
159
+ if (summary_type !== STATISTICS_COUNT_TYPE.COUNT) {
160
+ var table = getTableById(table_id);
161
+ var selectedColumn = TableUtils.getTableColumnByKey(table, summary_column);
162
+ var formattedContent = getNumberDisplayString(data, selectedColumn.data || {});
163
+ return formattedContent;
164
+ }
165
+ var string = data + '';
166
+ var isFloat = string.indexOf('.') > 0;
167
+ if (isFloat) {
168
+ string = string.slice(0, string.indexOf('.'));
169
+ }
170
+ var content = '';
171
+ var endPoint = -3;
172
+ var startPoint = 0;
173
+ var subString = string.slice(endPoint);
174
+ while (subString.length === 3) {
175
+ content = ',' + subString + content;
176
+ startPoint = endPoint;
177
+ endPoint -= 3;
178
+ subString = string.slice(endPoint, startPoint);
179
+ }
180
+ content = subString + content;
181
+ if (content[0] === ',') {
182
+ content = content.slice(1);
183
+ }
184
+ if (isFloat) {
185
+ var initString = data + '';
186
+ content = content + initString.slice(initString.indexOf('.'));
187
+ }
188
+ return content;
189
+ };
190
+ _this.getFontSize = function (content, maxFontSize) {
191
+ var canvas = document.createElement('canvas');
192
+ var context = canvas.getContext('2d');
193
+ var width = _this.chart.width;
194
+ var font = context.font;
195
+ var initFontSize = maxFontSize || 48;
196
+ var fontStyle = font.slice(font.indexOf('px'));
197
+ font = initFontSize + fontStyle;
198
+ context.font = font;
199
+ context.fontSize = initFontSize;
200
+ while (context.measureText(content).width >= width - 40) {
201
+ initFontSize -= 1;
202
+ context.font = initFontSize + fontStyle;
203
+ context.fontSize = initFontSize;
204
+ }
205
+ canvas = null;
206
+ if (maxFontSize) return initFontSize;
207
+ if (initFontSize < 16) {
208
+ initFontSize = 16;
209
+ }
210
+ return initFontSize;
211
+ };
212
+ _this.createLabelContent = function (data, maxFontSize) {
213
+ var statItem = _this.props.statItem;
214
+ var date_granularity = statItem.date_granularity;
215
+ var conjunctions = '';
216
+ if (date_granularity === DATE_GRANULARITY.YEAR) {
217
+ conjunctions = intl.get('The_year_before_last');
218
+ } else if (date_granularity === DATE_GRANULARITY.QUARTER) {
219
+ conjunctions = intl.get('The_quarter_before_last');
220
+ } else if (date_granularity === DATE_GRANULARITY.MONTH) {
221
+ conjunctions = intl.get('The_month_before_last');
222
+ } else if (date_granularity === DATE_GRANULARITY.WEEK) {
223
+ conjunctions = intl.get('The_week_before_last');
224
+ } else if (date_granularity === 'days_7') {
225
+ conjunctions = intl.get('Previous_7_days');
226
+ } else if (date_granularity === 'days_30') {
227
+ conjunctions = intl.get('Previous_30_days');
228
+ } else {
229
+ conjunctions = intl.get('The_day_before_yesterday');
230
+ }
231
+ var _ref3 = data || {},
232
+ result = _ref3.result,
233
+ type = _ref3.type,
234
+ previous = _ref3.previous;
235
+ var color = '#ff0000',
236
+ icon = 'dtable-icon-down';
237
+ if (type === 'up') {
238
+ color = '#008000';
239
+ icon = 'dtable-icon-up';
240
+ }
241
+ var resultText = "".concat(Number.parseFloat(result * 100).toFixed(2), "%&#8226;").concat(conjunctions).concat(previous);
242
+ if (!previous) {
243
+ resultText = intl.get('Can_not_compare_with_var', {
244
+ var: conjunctions.toLowerCase()
245
+ });
246
+ }
247
+ var labelFontSize = _this.getFontSize(resultText, maxFontSize);
248
+ labelFontSize = labelFontSize > 20 ? 20 : labelFontSize;
249
+ if (!previous) {
250
+ return "<span style='font-size: ".concat(labelFontSize, "px'>").concat(resultText, "</span>");
251
+ }
252
+ if (labelFontSize <= 12) {
253
+ if (!result) return '';
254
+ return "<span style='font-size: ".concat(labelFontSize, "px; width: 100%;'>\n <i style='color: ").concat(color, "' class='dtable-font ").concat(icon, "'></i>\n <span style='color: ").concat(color, "'>").concat(result ? Number.parseFloat(result * 100).toFixed(2) : '', "%</span>\n </span>");
255
+ }
256
+ var resultContent = "\n <span style='display: block; word-break: keep-all; font-size: ".concat(labelFontSize, "px; width: 100%;'>\n ").concat(!result ? '' : "<i style='color: ".concat(color, "' class='dtable-font ").concat(icon, "'></i>"), "\n <span style='color: ").concat(color, "'>").concat(result ? Number.parseFloat(result * 100).toFixed(2) + '%' : '', "</span>\n ").concat(result ? '&#8226;' : '', "\n ").concat(conjunctions, "\n ").concat(_this.formatData(previous), "\n </span>\n ");
257
+ return resultContent;
258
+ };
259
+ _this.state = {
260
+ isCalculatingData: true
261
+ };
262
+ _this.calculateData = null;
263
+ return _this;
264
+ }
265
+ _createClass(BasicNumericCard, [{
266
+ key: "shouldComponentUpdate",
267
+ value: function shouldComponentUpdate(nextProps, nextState) {
268
+ if (this.canUpdate(this.props, nextProps)) {
269
+ return true;
270
+ }
271
+ if (nextState.isCalculatingData !== this.state.isCalculatingData) {
272
+ return true;
273
+ }
274
+ return false;
275
+ }
276
+ }, {
277
+ key: "componentWillUnmount",
278
+ value: function componentWillUnmount() {
279
+ this.container = null;
280
+ }
281
+ }, {
282
+ key: "render",
283
+ value: function render() {
284
+ var _this2 = this;
285
+ var isCalculatingData = this.state.isCalculatingData;
286
+ return /*#__PURE__*/React.createElement(React.Fragment, null, isCalculatingData && /*#__PURE__*/React.createElement("div", {
287
+ className: 'statistic-chart-loading-container'
288
+ }, /*#__PURE__*/React.createElement(Loading, null)), /*#__PURE__*/React.createElement("div", {
289
+ ref: function ref(_ref4) {
290
+ return _this2.container = _ref4;
291
+ },
292
+ className: "statistic-chart-container statistic-number-card"
293
+ }));
294
+ }
295
+ }]);
296
+ return BasicNumericCard;
297
+ }(BaseChart);
298
+ BasicNumericCard.propTypes = propTypes;
299
+ export default BasicNumericCard;