dtable-statistic 4.4.24 → 5.0.0-alpha.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 (208) hide show
  1. package/es/assets/css/dashboard.css +1 -0
  2. package/es/assets/css/dialog.css +35 -0
  3. package/es/components/dialog/chart-edit-dialog.js +93 -0
  4. package/es/components/dialog/enlarged-chart-dialog.js +8 -13
  5. package/es/components/dialog/statistic-record-dialog/index.js +26 -33
  6. package/es/components/dropdown-menu/statistic-dropdown-menu.js +2 -2
  7. package/es/constants/index.js +3 -499
  8. package/es/dashboard.js +9 -87
  9. package/es/desktop-dashboard.js +51 -32
  10. package/es/index.js +56 -1
  11. package/es/mobile-dashboard.js +8 -16
  12. package/es/model/conver-statItem.js +124 -0
  13. package/es/service/chart-service.js +8 -27
  14. package/es/service/dashboard-service.js +25 -29
  15. package/es/stat-list/chart-preview.js +19 -20
  16. package/es/stat-list/index.js +15 -21
  17. package/es/stat-view/index.js +47 -156
  18. package/es/tabs/tab.js +17 -14
  19. package/es/utils/common-utils.js +2 -352
  20. package/es/utils/export-table-utils.js +0 -69
  21. package/es/utils/index.js +0 -89
  22. package/package.json +6 -8
  23. package/es/assets/css/color-picker.css +0 -53
  24. package/es/assets/css/color-rules-popover.css +0 -144
  25. package/es/assets/css/slider.css +0 -77
  26. package/es/assets/css/statistic-chart.module.css +0 -11
  27. package/es/assets/css/statistic-custom-title.module.css +0 -3
  28. package/es/assets/css/statistic-custom.module.css +0 -4
  29. package/es/assets/css/statistic-numeric-column-item.module.css +0 -43
  30. package/es/assets/css/statistic-time-picker.module.css +0 -21
  31. package/es/calculator/base-calculator.js +0 -80
  32. package/es/calculator/basic-chart-calculator.js +0 -349
  33. package/es/calculator/combination-calculator.js +0 -246
  34. package/es/calculator/compare-bar-calculator.js +0 -197
  35. package/es/calculator/completeness-calculator.js +0 -215
  36. package/es/calculator/copy-value.js +0 -53
  37. package/es/calculator/dashboard-calculator.js +0 -70
  38. package/es/calculator/heat-map-calculator.js +0 -148
  39. package/es/calculator/horizontal-bar-calculator.js +0 -67
  40. package/es/calculator/index.js +0 -81
  41. package/es/calculator/map-calculator.js +0 -103
  42. package/es/calculator/mirror-calculator.js +0 -146
  43. package/es/calculator/number-card-calculator.js +0 -60
  44. package/es/calculator/pivot-table-calculator.js +0 -821
  45. package/es/calculator/scatter-calculator.js +0 -75
  46. package/es/calculator/thread-manager.js +0 -57
  47. package/es/calculator/trend-calculator.js +0 -113
  48. package/es/calculator/workers/basic-chart-calculator-worker.js +0 -495
  49. package/es/calculator/workers/calculator.worker.js +0 -44
  50. package/es/calculator/workers/card-calculator-worker.js +0 -40
  51. package/es/calculator/workers/combination-calculator-worker.js +0 -276
  52. package/es/calculator/workers/compare-bar-chart-calculator-worker.js +0 -150
  53. package/es/calculator/workers/completeness-calculator-worker.js +0 -208
  54. package/es/calculator/workers/dashboard-calculator-worker.js +0 -68
  55. package/es/calculator/workers/mirror-calculator-worker.js +0 -152
  56. package/es/calculator/workers/pivot-table-calculator-worker.js +0 -718
  57. package/es/calculator/workers/scatter-calculator-worker.js +0 -80
  58. package/es/calculator/workers/trend-calculator-worker.js +0 -108
  59. package/es/calculator/world-map-calculator.js +0 -124
  60. package/es/components/common-add-tool.js +0 -28
  61. package/es/components/dialog/chart-addition-edit-dialog.js +0 -90
  62. package/es/components/dialog/chart-addition-widgets/chart-selector.js +0 -259
  63. package/es/components/dialog/chart-addition-widgets/statistic-chart-selector.module.css +0 -83
  64. package/es/components/dialog/statistic-types-dialog/index.css +0 -14
  65. package/es/components/dialog/statistic-types-dialog/index.js +0 -62
  66. package/es/components/dtable-popover.js +0 -97
  67. package/es/components/dtable-search-input.js +0 -135
  68. package/es/components/index.js +0 -55
  69. package/es/components/loading.js +0 -15
  70. package/es/components/modal-portal.js +0 -26
  71. package/es/components/popover/color-rules/color-rule.js +0 -183
  72. package/es/components/popover/color-rules/index.js +0 -87
  73. package/es/components/popover/color-rules/rule-filters/filter.js +0 -221
  74. package/es/components/popover/color-rules/rule-filters/index.css +0 -210
  75. package/es/components/popover/color-rules/rule-filters/index.js +0 -97
  76. package/es/components/popover/color-rules/rule-filters/number-input.js +0 -78
  77. package/es/components/popover/color-rules-popover.js +0 -217
  78. package/es/components/popover/color-selector-popover.js +0 -82
  79. package/es/components/seatable-radio/index.css +0 -51
  80. package/es/components/seatable-radio/index.js +0 -35
  81. package/es/constants/color-rules.js +0 -17
  82. package/es/constants/map.js +0 -13
  83. package/es/constants/model.js +0 -26
  84. package/es/constants/regions.js +0 -2111
  85. package/es/constants/zIndexes.js +0 -7
  86. package/es/custom-g2.js +0 -644
  87. package/es/model/bar-group.js +0 -58
  88. package/es/model/bar.js +0 -47
  89. package/es/model/base-model.js +0 -18
  90. package/es/model/basic-number-card.js +0 -25
  91. package/es/model/combination.js +0 -48
  92. package/es/model/compare-bar.js +0 -56
  93. package/es/model/completeness-group.js +0 -31
  94. package/es/model/completeness.js +0 -25
  95. package/es/model/custom-bar.js +0 -25
  96. package/es/model/dashboard.js +0 -20
  97. package/es/model/generic-model.js +0 -222
  98. package/es/model/heat-map.js +0 -33
  99. package/es/model/horizontal-bar-group.js +0 -55
  100. package/es/model/horizontal-bar.js +0 -47
  101. package/es/model/index.js +0 -187
  102. package/es/model/map.js +0 -38
  103. package/es/model/mirror.js +0 -33
  104. package/es/model/pie.js +0 -38
  105. package/es/model/ring.js +0 -40
  106. package/es/model/scatter.js +0 -22
  107. package/es/model/table.js +0 -32
  108. package/es/model/trend.js +0 -32
  109. package/es/model/world-map.js +0 -34
  110. package/es/service/map-json.js +0 -140
  111. package/es/stat-editor/chart-name-editor.js +0 -68
  112. package/es/stat-editor/index.js +0 -75
  113. package/es/stat-editor/stat-settings/advance-chart-settings/basic-number-card-settings.js +0 -153
  114. package/es/stat-editor/stat-settings/advance-chart-settings/combination-settings.js +0 -422
  115. package/es/stat-editor/stat-settings/advance-chart-settings/dashboard-chart-settings.js +0 -203
  116. package/es/stat-editor/stat-settings/advance-chart-settings/geo-granularity-settings.js +0 -23
  117. package/es/stat-editor/stat-settings/advance-chart-settings/heat-map-settings.js +0 -104
  118. package/es/stat-editor/stat-settings/advance-chart-settings/index.js +0 -334
  119. package/es/stat-editor/stat-settings/advance-chart-settings/map-settings.js +0 -119
  120. package/es/stat-editor/stat-settings/advance-chart-settings/mirror-settings.js +0 -132
  121. package/es/stat-editor/stat-settings/advance-chart-settings/style-setting/combination-style-setting.js +0 -240
  122. package/es/stat-editor/stat-settings/advance-chart-settings/style-setting/heat-map-settings.js +0 -89
  123. package/es/stat-editor/stat-settings/advance-chart-settings/style-setting/map-setting.js +0 -138
  124. package/es/stat-editor/stat-settings/advance-chart-settings/summary-settings.js +0 -331
  125. package/es/stat-editor/stat-settings/advance-chart-settings/trend-chart-settings.js +0 -143
  126. package/es/stat-editor/stat-settings/advance-chart-settings/world-map-settings.js +0 -109
  127. package/es/stat-editor/stat-settings/basic-chart-settings/advance-bar-chart-settings.js +0 -153
  128. package/es/stat-editor/stat-settings/basic-chart-settings/bar-settings.js +0 -144
  129. package/es/stat-editor/stat-settings/basic-chart-settings/completeness-chart-settings.js +0 -214
  130. package/es/stat-editor/stat-settings/basic-chart-settings/custom-bar-settings.js +0 -121
  131. package/es/stat-editor/stat-settings/basic-chart-settings/groupby-settings.js +0 -172
  132. package/es/stat-editor/stat-settings/basic-chart-settings/horizontal-axis-group-settings.js +0 -366
  133. package/es/stat-editor/stat-settings/basic-chart-settings/horizontal-bar-settings.js +0 -142
  134. package/es/stat-editor/stat-settings/basic-chart-settings/horizontal-group-chart-settings.js +0 -150
  135. package/es/stat-editor/stat-settings/basic-chart-settings/index.js +0 -473
  136. package/es/stat-editor/stat-settings/basic-chart-settings/pie-settings.js +0 -182
  137. package/es/stat-editor/stat-settings/basic-chart-settings/pivot-table-settings.js +0 -564
  138. package/es/stat-editor/stat-settings/basic-chart-settings/scatter-settings.js +0 -112
  139. package/es/stat-editor/stat-settings/basic-chart-settings/stack-item-settings.js +0 -87
  140. package/es/stat-editor/stat-settings/basic-chart-settings/stacks-settings.js +0 -187
  141. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/bar-chart-style-setting.js +0 -300
  142. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/completeness-style.js +0 -113
  143. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/horizontal-bar-chart-style.js +0 -289
  144. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/label-font-size-editor.js +0 -58
  145. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/pie-chart-style-settings.js +0 -359
  146. package/es/stat-editor/stat-settings/basic-chart-settings/style-setting/time-compare-style.js +0 -48
  147. package/es/stat-editor/stat-settings/basic-chart-settings/summary-method-setting.js +0 -121
  148. package/es/stat-editor/stat-settings/basic-chart-settings/summary-settings.js +0 -143
  149. package/es/stat-editor/stat-settings/basic-chart-settings/time-comparison-settings.js +0 -269
  150. package/es/stat-editor/stat-settings/basic-chart-settings/timer-picker.js +0 -104
  151. package/es/stat-editor/stat-settings/basic-chart-settings/y-axis-group-settings.js +0 -366
  152. package/es/stat-editor/stat-settings/color-setting/color-group-selector.js +0 -55
  153. package/es/stat-editor/stat-settings/color-setting/color-picker.js +0 -130
  154. package/es/stat-editor/stat-settings/color-setting/color-use-type-selector.js +0 -374
  155. package/es/stat-editor/stat-settings/map/map-level.js +0 -72
  156. package/es/stat-editor/stat-settings/map/map-province-city.js +0 -151
  157. package/es/stat-editor/stat-settings/public-setting/axis-label-position-setting.js +0 -108
  158. package/es/stat-editor/stat-settings/public-setting/base-settings.js +0 -154
  159. package/es/stat-editor/stat-settings/public-setting/calender.js +0 -125
  160. package/es/stat-editor/stat-settings/public-setting/column-settings.js +0 -24
  161. package/es/stat-editor/stat-settings/public-setting/custom-title-setting.js +0 -62
  162. package/es/stat-editor/stat-settings/public-setting/data-sort-setting.js +0 -61
  163. package/es/stat-editor/stat-settings/public-setting/ind-toggle-setting.js +0 -35
  164. package/es/stat-editor/stat-settings/public-setting/min-max-setting.js +0 -60
  165. package/es/stat-editor/stat-settings/public-setting/numeric-summary-item.js +0 -123
  166. package/es/stat-editor/stat-settings/public-setting/toggle-setting.js +0 -33
  167. package/es/stat-editor/stat-settings/public-setting/type-settings/index.css +0 -29
  168. package/es/stat-editor/stat-settings/public-setting/type-settings/index.js +0 -82
  169. package/es/stat-view/area-chart.js +0 -551
  170. package/es/stat-view/bar-chart.js +0 -582
  171. package/es/stat-view/base-chart.js +0 -132
  172. package/es/stat-view/basic-number-card.js +0 -201
  173. package/es/stat-view/combination-chart.js +0 -546
  174. package/es/stat-view/compare-chart.js +0 -483
  175. package/es/stat-view/completeness-chart.js +0 -390
  176. package/es/stat-view/custom-bar.js +0 -418
  177. package/es/stat-view/dashboard-chart.js +0 -266
  178. package/es/stat-view/heat-map.js +0 -463
  179. package/es/stat-view/horizontal-bar-chart.js +0 -562
  180. package/es/stat-view/line-chart.js +0 -518
  181. package/es/stat-view/map.js +0 -448
  182. package/es/stat-view/mirror.js +0 -275
  183. package/es/stat-view/pie-chart.js +0 -290
  184. package/es/stat-view/pivot-table/index.js +0 -196
  185. package/es/stat-view/pivot-table/one-dimension-table-no-numeric-columns.js +0 -156
  186. package/es/stat-view/pivot-table/one-dimension-table-with-numeric-columns.js +0 -176
  187. package/es/stat-view/pivot-table/pivot-table-display-name.js +0 -215
  188. package/es/stat-view/pivot-table/statistic-pivot-table.module.css +0 -132
  189. package/es/stat-view/pivot-table/two-dimension-table.js +0 -384
  190. package/es/stat-view/ring-chart.js +0 -392
  191. package/es/stat-view/scatter-chart.js +0 -306
  192. package/es/stat-view/treemap-chart.js +0 -253
  193. package/es/stat-view/trend-chart.js +0 -249
  194. package/es/stat-view/world-map.js +0 -431
  195. package/es/utils/basic-chart-utils.js +0 -29
  196. package/es/utils/cell-format.js +0 -115
  197. package/es/utils/collaborator.js +0 -50
  198. package/es/utils/color-utils.js +0 -134
  199. package/es/utils/column-utils.js +0 -110
  200. package/es/utils/column.js +0 -20
  201. package/es/utils/date-format.js +0 -71
  202. package/es/utils/map.js +0 -114
  203. package/es/utils/model.js +0 -19
  204. package/es/utils/row-utils.js +0 -134
  205. package/es/utils/search.js +0 -73
  206. package/es/utils/sql-utils.js +0 -359
  207. package/es/utils/stat-utils.js +0 -351
  208. package/es/utils/trend-utils.js +0 -135
@@ -1,12 +1,11 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
4
3
  Object.defineProperty(exports, "__esModule", {
5
4
  value: true
6
5
  });
7
6
  exports.default = void 0;
7
+ var _seaChart = require("sea-chart");
8
8
  var _commonUtils = require("../utils/common-utils");
9
- var _model = _interopRequireWildcard(require("../model"));
10
9
  class ChartService {
11
10
  constructor(_ref) {
12
11
  let {
@@ -17,10 +16,8 @@ class ChartService {
17
16
  generatorChart() {
18
17
  let statistic = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
19
18
  let table = arguments.length > 1 ? arguments[1] : undefined;
20
- const object = new _model.GenericModel(statistic);
21
- const ChartModel = _model.default[object.type];
22
- if (!ChartModel) return null;
23
- return new ChartModel(object, table);
19
+ const chartModel = new _seaChart.ChartModel(statistic, table);
20
+ return chartModel;
24
21
  }
25
22
  getInitChart(_ref2) {
26
23
  let {
@@ -55,27 +52,11 @@ class ChartService {
55
52
  stat_items
56
53
  } = dashboard;
57
54
  const statId = (0, _commonUtils.generatorUniqueId)(stat_items);
58
- const {
59
- name
60
- } = originalStatItem;
61
- return {
62
- ...originalStatItem,
63
- _id: statId,
64
- name: name + '(copy)',
65
- layout: null
66
- };
67
- }
68
- getConvertedChart(_ref4) {
69
- let {
70
- originalStatistic,
71
- targetStatisticType,
72
- activeTable
73
- } = _ref4;
74
- if (targetStatisticType === originalStatistic.type) return originalStatistic;
75
- return this.generatorChart({
76
- ...originalStatistic,
77
- type: targetStatisticType
78
- }, activeTable);
55
+ const newStatItem = JSON.parse(JSON.stringify(originalStatItem));
56
+ newStatItem.config._id = statId;
57
+ newStatItem.style_config.title.text = originalStatItem.style_config.title.text + '(copy)';
58
+ newStatItem.layout = null;
59
+ return newStatItem;
79
60
  }
80
61
  }
81
62
  var _default = exports.default = ChartService;
@@ -5,6 +5,7 @@ Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
7
  exports.default = void 0;
8
+ var _seaChart = require("sea-chart");
8
9
  var _statisticDashboard = _interopRequireDefault(require("../model/statistic-dashboard"));
9
10
  var _utils = require("../utils");
10
11
  var _commonUtils = require("../utils/common-utils");
@@ -15,13 +16,11 @@ class DashBoardService {
15
16
  let {
16
17
  value,
17
18
  defaultDashboardName,
18
- chartCalculator,
19
19
  chartService,
20
20
  updateStatistics,
21
21
  deletePluginSettings
22
22
  } = _ref;
23
23
  this.defaultDashboardName = defaultDashboardName;
24
- this.chartCalculator = chartCalculator;
25
24
  this.chartService = chartService;
26
25
  this.initStatistics(value, updateStatistics, deletePluginSettings);
27
26
  }
@@ -64,23 +63,23 @@ class DashBoardService {
64
63
  type
65
64
  } = chart;
66
65
  switch (type) {
67
- case _constants.STAT_TYPE.PIVOT_TABLE:
66
+ case _seaChart.CHART_TYPE.TABLE:
68
67
  {
69
68
  return this.convertPivotTable(chart);
70
69
  }
71
- case _constants.STAT_TYPE.BAR:
70
+ case _seaChart.CHART_TYPE.BAR:
72
71
  {
73
72
  return this.convertChartBar(chart);
74
73
  }
75
- case _constants.STAT_TYPE.LINE:
74
+ case _seaChart.CHART_TYPE.LINE:
76
75
  {
77
76
  return this.convertChartLine(chart);
78
77
  }
79
- case _constants.STAT_TYPE.PIE:
78
+ case _seaChart.CHART_TYPE.PIE:
80
79
  {
81
80
  return this.chartService.generatorChart({
82
81
  ...chart,
83
- type: _constants.STAT_TYPE.RING
82
+ type: _seaChart.CHART_TYPE.RING
84
83
  });
85
84
  }
86
85
  default:
@@ -121,9 +120,9 @@ class DashBoardService {
121
120
  };
122
121
  const isGroupbyMultipleNumericColumns = column_groupby_multiple_numeric_column && column_groupby_numeric_column_keys && column_groupby_numeric_column_keys.length > 0;
123
122
  if (column_groupby_column_key || isGroupbyMultipleNumericColumns) {
124
- convertedChart.type = _constants.STAT_TYPE.BAR_GROUP;
123
+ convertedChart.type = _seaChart.CHART_TYPE.BAR_GROUP;
125
124
  if (y_axis_use_stack) {
126
- convertedChart.type = _constants.STAT_TYPE.BAR_STACK;
125
+ convertedChart.type = _seaChart.CHART_TYPE.BAR_STACK;
127
126
  }
128
127
  if (isGroupbyMultipleNumericColumns) {
129
128
  convertedChart.column_groupby_multiple_numeric_column = column_groupby_multiple_numeric_column;
@@ -150,7 +149,7 @@ class DashBoardService {
150
149
  ...chart
151
150
  };
152
151
  if (column_groupby_column_key) {
153
- convertedChart.type = _constants.STAT_TYPE.GROUP_LINE;
152
+ convertedChart.type = _seaChart.CHART_TYPE.LINE_GROUP;
154
153
  if (isGroupbyMultipleNumericColumns) {
155
154
  convertedChart.column_groupby_multiple_numeric_column = column_groupby_multiple_numeric_column;
156
155
  convertedChart.column_groupby_numeric_columns = column_groupby_numeric_column_keys.map(key => {
@@ -210,13 +209,12 @@ class DashBoardService {
210
209
  if (!Array.isArray(charts) || charts.length === 0) {
211
210
  return dashboard;
212
211
  }
213
- charts = charts.filter(chart => this.chartCalculator.isValidChart(chart));
214
212
  charts = charts.map((chart, index) => {
215
213
  if (!chart.layout) {
216
214
  return {
217
215
  ...chart,
218
216
  layout: {
219
- i: chart._id,
217
+ i: chart.config._id,
220
218
  x: index % 2 * 2,
221
219
  y: Infinity,
222
220
  w: 2,
@@ -342,7 +340,7 @@ class DashBoardService {
342
340
  stat_items
343
341
  } = updatedDashboard;
344
342
  updatedDashboard.stat_items = stat_items.map(chart => {
345
- const chartLayout = idChartLayoutMap[chart._id];
343
+ const chartLayout = idChartLayoutMap[chart.config._id];
346
344
  if (!chartLayout) return chart;
347
345
  const {
348
346
  x,
@@ -379,7 +377,7 @@ class DashBoardService {
379
377
  const statItemsLen = updatedDashboard.stat_items.length;
380
378
  if (!chart.layout) {
381
379
  chart.layout = {
382
- i: chart._id,
380
+ i: chart.config._id,
383
381
  x: statItemsLen % 2 * 2,
384
382
  y: Infinity,
385
383
  w: 2,
@@ -401,7 +399,7 @@ class DashBoardService {
401
399
  if (!updatedDashboard) {
402
400
  break;
403
401
  }
404
- let deleteIndex = updatedDashboard.stat_items.findIndex(chart => chart._id === chart_id);
402
+ let deleteIndex = updatedDashboard.stat_items.findIndex(chart => chart.config._id === chart_id);
405
403
  if (deleteIndex < 0) {
406
404
  break;
407
405
  }
@@ -415,13 +413,13 @@ class DashBoardService {
415
413
  index,
416
414
  chart
417
415
  } = payload;
418
- const charId = chart._id;
416
+ const charId = chart.config._id;
419
417
  const updatedStatistics = [...this.statistics];
420
418
  let updatedDashboard = updatedStatistics[index];
421
419
  if (!updatedDashboard) {
422
420
  break;
423
421
  }
424
- let updateIndex = updatedDashboard.stat_items.findIndex(chart => chart._id === charId);
422
+ let updateIndex = updatedDashboard.stat_items.findIndex(chart => chart.config._id === charId);
425
423
  if (updateIndex < 0) {
426
424
  break;
427
425
  }
@@ -439,29 +437,27 @@ class DashBoardService {
439
437
  const updatedStatistics = [...this.statistics];
440
438
  let currentDashboard = updatedStatistics[index];
441
439
  if (!currentDashboard || !Array.isArray(currentDashboard.stat_items)) break;
442
- let movedChartIndex = currentDashboard.stat_items.findIndex(chart => chart._id === chart_id);
440
+ let movedChartIndex = currentDashboard.stat_items.findIndex(chart => chart.config._id === chart_id);
443
441
  if (movedChartIndex < 0) break;
444
442
  let targetDashboard = target_view_id && updatedStatistics.find(view => view._id === target_view_id);
445
443
  if (!targetDashboard) break;
446
444
  const movedCharts = currentDashboard.stat_items.splice(movedChartIndex, 1);
447
445
  let movedChart = movedCharts && movedCharts[0];
448
446
  if (!movedChart) break;
449
- let newChartId = movedChart._id;
447
+ let newChartId = movedChart.config._id;
450
448
  if (!Array.isArray(targetDashboard.stat_items)) {
451
449
  targetDashboard.stat_items = [];
452
450
  } else {
453
451
  newChartId = (0, _commonUtils.generatorUniqueId)(targetDashboard.statItems);
454
452
  }
455
- movedChart = Object.assign(movedChart, {
456
- _id: newChartId,
457
- layout: {
458
- i: newChartId,
459
- x: targetDashboard.stat_items.length % 2 * 2,
460
- y: Infinity,
461
- w: 2,
462
- h: 7
463
- }
464
- });
453
+ movedChart.config._id = newChartId;
454
+ movedChart.layout = {
455
+ i: newChartId,
456
+ x: targetDashboard.stat_items.length % 2 * 2,
457
+ y: Infinity,
458
+ w: 2,
459
+ h: 7
460
+ };
465
461
  targetDashboard.stat_items.push(movedChart);
466
462
  this.statistics = updatedStatistics;
467
463
  break;
@@ -11,7 +11,6 @@ var _reactDom = _interopRequireDefault(require("react-dom"));
11
11
  var _html2canvas = _interopRequireDefault(require("html2canvas"));
12
12
  var _statView = _interopRequireDefault(require("../stat-view"));
13
13
  var _statisticDropdownMenu = _interopRequireDefault(require("../components/dropdown-menu/statistic-dropdown-menu"));
14
- var _constants = require("../constants");
15
14
  class ChartPreview extends _react.Component {
16
15
  constructor() {
17
16
  super(...arguments);
@@ -34,7 +33,7 @@ class ChartPreview extends _react.Component {
34
33
  // for charts rendered with `<canvas>`
35
34
  const {
36
35
  _id: id
37
- } = statItem;
36
+ } = statItem.config;
38
37
  const originalElement = document.querySelector("#stat-item-".concat(id, " .statistic-chart-container > div"));
39
38
  if (originalElement) {
40
39
  const containerWidth = originalElement.scrollWidth + 15 * 2;
@@ -52,7 +51,7 @@ class ChartPreview extends _react.Component {
52
51
  }).then(canvas => {
53
52
  let eleA = document.createElement('a');
54
53
  eleA.href = canvas.toDataURL('image/png');
55
- eleA.download = "".concat(statItem.name || 'image', ".png");
54
+ eleA.download = "".concat(statItem.style_config.title.text || 'image', ".png");
56
55
  eleA.click();
57
56
  document.body.removeChild(exportContainer);
58
57
  });
@@ -72,50 +71,50 @@ class ChartPreview extends _react.Component {
72
71
  };
73
72
  this.renderChart = statItem => {
74
73
  const {
75
- dtableChangedTime,
76
- chartCalculator,
77
74
  theme,
78
75
  colorThemeName,
79
- eventBus
76
+ api,
77
+ value,
78
+ getTableById,
79
+ toggleStatisticRecordsDialog
80
80
  } = this.props;
81
81
  return /*#__PURE__*/_react.default.createElement(_statView.default, {
82
82
  ref: ref => this.chartView = ref,
83
- isPreview: true,
84
- isEnlarge: false,
85
- dtableChangedTime: dtableChangedTime,
86
83
  theme: theme,
87
84
  colorThemeName: colorThemeName,
88
85
  statItem: statItem,
89
- chartCalculator: chartCalculator,
90
- eventBus: eventBus,
91
- getTableById: this.props.getTableById,
92
- queryMapJson: this.props.queryMapJson,
93
- toggleStatisticRecordsDialog: this.props.toggleStatisticRecordsDialog
86
+ api: api,
87
+ value: value,
88
+ getTableById: getTableById,
89
+ toggleStatisticRecordsDialog: toggleStatisticRecordsDialog
94
90
  });
95
91
  };
96
92
  this.moveChartToView = viewId => {
97
93
  const {
98
94
  statItem
99
95
  } = this.props;
100
- this.props.moveChartToView(statItem._id, viewId);
96
+ this.props.moveChartToView(statItem.config._id, viewId);
101
97
  };
102
98
  }
103
99
  render() {
100
+ var _statItem$config;
104
101
  const {
105
102
  isTableReadOnly,
106
103
  statItem
107
104
  } = this.props;
108
105
  const {
109
106
  _id: statId,
110
- name: statName,
111
107
  type
112
- } = statItem;
113
- const showStatName = !(type === _constants.STAT_TYPE.BASIC_NUMBER_CARD || type === _constants.STAT_TYPE.DASHBOARD);
108
+ } = statItem.config;
109
+ const {
110
+ text: statName
111
+ } = statItem.style_config.title;
112
+ const statItemId = statItem === null || statItem === void 0 ? void 0 : (_statItem$config = statItem.config) === null || _statItem$config === void 0 ? void 0 : _statItem$config._id;
114
113
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
115
114
  className: "statistic-chart-preview-header"
116
115
  }, /*#__PURE__*/_react.default.createElement("span", {
117
116
  className: "statistic-chart-preview-name"
118
- }, showStatName ? statName : ''), /*#__PURE__*/_react.default.createElement("span", {
117
+ }, statName), /*#__PURE__*/_react.default.createElement("span", {
119
118
  className: "statistic-chart-preview-operations"
120
119
  }, /*#__PURE__*/_react.default.createElement("span", {
121
120
  className: "statistic-chart-preview-microscope",
@@ -135,7 +134,7 @@ class ChartPreview extends _react.Component {
135
134
  onNewTableDialogToggle: this.onNewTableDialogToggle,
136
135
  onUpdateTableDialogToggle: this.onUpdateTableDialogToggle
137
136
  }))), /*#__PURE__*/_react.default.createElement("div", {
138
- id: "stat-item-".concat(statItem._id),
137
+ id: "stat-item-".concat(statItemId),
139
138
  className: "statistic-chart-preview-container"
140
139
  }, this.renderChart(statItem)), /*#__PURE__*/_react.default.createElement("div", {
141
140
  className: "statistic-chart-preview-container-resize"
@@ -10,8 +10,9 @@ var _react = _interopRequireWildcard(require("react"));
10
10
  var _reactGridLayout = _interopRequireWildcard(require("react-grid-layout"));
11
11
  var _reactIntlUniversal = _interopRequireDefault(require("react-intl-universal"));
12
12
  var _toaster = _interopRequireDefault(require("dtable-ui-component/lib/toaster"));
13
+ var _seaChart = require("sea-chart");
13
14
  var _chartPreview = _interopRequireDefault(require("./chart-preview"));
14
- var _components = require("../components");
15
+ var _newTableDialog = _interopRequireDefault(require("../components/dialog/new-table-dialog"));
15
16
  var _enlargedChartDialog = _interopRequireDefault(require("../components/dialog/enlarged-chart-dialog"));
16
17
  var _tableSelectDialog = _interopRequireDefault(require("../components/dialog/table-select-dialog"));
17
18
  var _exportTableUtils = require("../utils/export-table-utils");
@@ -59,7 +60,7 @@ class StatList extends _react.Component {
59
60
  });
60
61
  };
61
62
  this.exportChart2Table = (tableName, chart) => {
62
- if (chart.type !== _constants.STAT_TYPE.PIVOT_TABLE) {
63
+ if (chart.type !== _seaChart.CHART_TYPE.TABLE) {
63
64
  this.statisticalResult4Export = null;
64
65
  _toaster.default.danger(_reactIntlUniversal.default.get('Failed_export_statistic_to_Table'));
65
66
  this.closeNewTableDialog();
@@ -100,7 +101,7 @@ class StatList extends _react.Component {
100
101
  const {
101
102
  getTableById
102
103
  } = this.props;
103
- if (chartUpdate2Table.type !== _constants.STAT_TYPE.PIVOT_TABLE) {
104
+ if (chartUpdate2Table.type !== _seaChart.CHART_TYPE.TABLE) {
104
105
  this.statisticalResult4Update = null;
105
106
  _toaster.default.danger(_reactIntlUniversal.default.get('Failed_export_statistic_to_Table'));
106
107
  this.closeSelectTableDialog();
@@ -151,6 +152,7 @@ class StatList extends _react.Component {
151
152
  chartIndexExport2Table: -1,
152
153
  chartIndexUpdate2Table: -1
153
154
  };
155
+ this.value = props.getValue();
154
156
  }
155
157
  UNSAFE_componentWillReceiveProps(nextProps) {
156
158
  const {
@@ -163,12 +165,10 @@ class StatList extends _react.Component {
163
165
  render() {
164
166
  const {
165
167
  isTableReadOnly,
166
- dtableChangedTime,
167
168
  theme,
168
169
  colorThemeName,
169
170
  statItems,
170
- chartCalculator,
171
- eventBus
171
+ api
172
172
  } = this.props;
173
173
  const {
174
174
  layout,
@@ -192,8 +192,9 @@ class StatList extends _react.Component {
192
192
  onLayoutChange: this.onLayoutChange,
193
193
  cols: 4,
194
194
  useCSSTransforms: false
195
- }, statItems.map((statItem, index) => {
196
- const statId = statItem._id;
195
+ }, statItems.map((item, index) => {
196
+ var _item$config;
197
+ const statId = item === null || item === void 0 ? void 0 : (_item$config = item.config) === null || _item$config === void 0 ? void 0 : _item$config._id;
197
198
  if (!statId) return null;
198
199
  return /*#__PURE__*/_react.default.createElement("div", {
199
200
  id: statId,
@@ -201,16 +202,13 @@ class StatList extends _react.Component {
201
202
  className: "statistic-chart-preview"
202
203
  }, /*#__PURE__*/_react.default.createElement(_chartPreview.default, {
203
204
  isTableReadOnly: isTableReadOnly,
204
- dtableChangedTime: dtableChangedTime,
205
205
  theme: theme,
206
206
  colorThemeName: colorThemeName,
207
- statItem: statItem,
208
- chartCalculator: chartCalculator,
209
- eventBus: eventBus,
207
+ statItem: item,
208
+ api: api,
209
+ value: this.value,
210
210
  getOtherStatistics: this.props.getOtherStatistics,
211
211
  getTableById: this.props.getTableById,
212
- getTables: this.props.getTables,
213
- queryMapJson: this.props.queryMapJson,
214
212
  copyChart: this.props.copyChart,
215
213
  moveChartToView: this.props.moveChartToView,
216
214
  deleteChart: this.props.deleteChart,
@@ -228,21 +226,17 @@ class StatList extends _react.Component {
228
226
  return this.showSelectTableDialog(index, statisticalResult);
229
227
  },
230
228
  onToggleEditChart: this.props.onToggleEditChart,
231
- onCloseDashboard: this.props.onCloseDashboard,
232
229
  toggleStatisticRecordsDialog: this.props.toggleStatisticRecordsDialog
233
230
  }));
234
231
  })), enlargedChart && /*#__PURE__*/_react.default.createElement(_enlargedChartDialog.default, {
235
- dtableChangedTime: dtableChangedTime,
236
232
  colorThemeName: colorThemeName,
237
233
  statItem: enlargedChart,
238
- eventBus: eventBus,
239
- chartCalculator: chartCalculator,
234
+ api: api,
235
+ value: this.value,
240
236
  getTableById: this.props.getTableById,
241
- queryMapJson: this.props.queryMapJson,
242
237
  onEnlargeToggle: this.closeEnlargedChart,
243
- onToggleShowEnlarged: this.closeEnlargedChart,
244
238
  toggleStatisticRecordsDialog: this.props.toggleStatisticRecordsDialog
245
- }), chartExport2Table && /*#__PURE__*/_react.default.createElement(_components.NewTableDialog, {
239
+ }), chartExport2Table && /*#__PURE__*/_react.default.createElement(_newTableDialog.default, {
246
240
  getTables: this.props.getTables,
247
241
  tableName: chartExport2Table.name,
248
242
  onNewTableConfirm: tableName => this.exportChart2Table(tableName, chartExport2Table),
@@ -6,170 +6,61 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.default = void 0;
8
8
  var _react = _interopRequireDefault(require("react"));
9
- var _pivotTable = _interopRequireDefault(require("./pivot-table"));
10
- var _barChart = _interopRequireDefault(require("./bar-chart"));
11
- var _compareChart = _interopRequireDefault(require("./compare-chart"));
12
- var _horizontalBarChart = _interopRequireDefault(require("./horizontal-bar-chart"));
13
- var _completenessChart = _interopRequireDefault(require("./completeness-chart"));
14
- var _lineChart = _interopRequireDefault(require("./line-chart"));
15
- var _areaChart = _interopRequireDefault(require("./area-chart"));
16
- var _pieChart = _interopRequireDefault(require("./pie-chart"));
17
- var _ringChart = _interopRequireDefault(require("./ring-chart"));
18
- var _scatterChart = _interopRequireDefault(require("./scatter-chart"));
19
- var _combinationChart = _interopRequireDefault(require("./combination-chart"));
20
- var _map = _interopRequireDefault(require("./map"));
21
- var _worldMap = _interopRequireDefault(require("./world-map"));
22
- var _heatMap = _interopRequireDefault(require("./heat-map"));
23
- var _mirror = _interopRequireDefault(require("./mirror"));
24
- var _basicNumberCard = _interopRequireDefault(require("./basic-number-card"));
25
- var _trendChart = _interopRequireDefault(require("./trend-chart"));
26
- var _dashboardChart = _interopRequireDefault(require("./dashboard-chart"));
27
- var _treemapChart = _interopRequireDefault(require("./treemap-chart"));
28
- var _customBar = _interopRequireDefault(require("./custom-bar"));
29
- var _constants = require("../constants");
9
+ var _seaChart = require("sea-chart");
10
+ var _dtableUtils = require("dtable-utils");
30
11
  class StatView extends _react.default.Component {
31
- constructor() {
32
- super(...arguments);
12
+ constructor(props) {
13
+ super(props);
14
+ this.getViewRef = ref => {
15
+ this.viewRef = ref;
16
+ };
33
17
  this.getStatData = () => {
34
- if (!this.chartView || !this.chartView.getStatData) return null;
35
- return this.chartView.getStatData();
18
+ const {
19
+ getTableById,
20
+ statItem
21
+ } = this.props;
22
+ const {
23
+ table_id,
24
+ groupby_column_key,
25
+ column_groupby_column_key,
26
+ summary_column_key
27
+ } = statItem.config;
28
+ const table = getTableById(table_id);
29
+ const groupbyColumn = groupby_column_key && (0, _dtableUtils.getTableColumnByKey)(table, groupby_column_key);
30
+ const columnGroupbyColumn = column_groupby_column_key && (0, _dtableUtils.getTableColumnByKey)(table, column_groupby_column_key);
31
+ const summaryColumn = (0, _dtableUtils.getTableColumnByKey)(table, summary_column_key) || {};
32
+ return {
33
+ pivotResult: this.viewRef.state.data.result,
34
+ statisticTableColumns: table.columns,
35
+ groupbyColumn,
36
+ columnGroupbyColumn,
37
+ summaryColumn
38
+ };
36
39
  };
40
+ this.viewRef = null;
37
41
  }
38
42
  render() {
39
43
  const {
40
- isPreview,
41
- isEnlarge,
42
- isEdit,
43
- dtableChangedTime,
44
- theme,
45
- colorThemeName,
46
44
  statItem,
47
- chartCalculator,
48
- eventBus,
49
- getTableById,
50
- toggleStatisticRecordsDialog
51
- } = this.props;
52
- let viewProps = {
53
- isPreview,
54
- isEnlarge,
55
- isEdit,
56
- dtableChangedTime,
45
+ api,
46
+ value,
57
47
  theme,
58
- colorThemeName,
59
- statItem,
60
- chartCalculator,
61
- eventBus,
62
- getTableById,
63
- queryMapJson: this.props.queryMapJson,
64
- toggleStatisticRecordsDialog,
65
- ref: ref => {
66
- this.chartView = ref;
67
- }
68
- };
69
- switch (statItem.type) {
70
- case _constants.STAT_TYPE.BAR:
71
- case _constants.STAT_TYPE.BAR_GROUP:
72
- case _constants.STAT_TYPE.BAR_STACK:
73
- {
74
- return /*#__PURE__*/_react.default.createElement(_barChart.default, viewProps);
75
- }
76
- case _constants.STAT_TYPE.COMPARE_BAR:
77
- {
78
- return /*#__PURE__*/_react.default.createElement(_compareChart.default, viewProps);
79
- }
80
- case _constants.STAT_TYPE.HORIZONTAL_BAR:
81
- case _constants.STAT_TYPE.HORIZONTAL_GROUP_BAR:
82
- case _constants.STAT_TYPE.STACKED_HORIZONTAL_BAR:
83
- {
84
- return /*#__PURE__*/_react.default.createElement(_horizontalBarChart.default, viewProps);
85
- }
86
- case _constants.STAT_TYPE.COMPLETENESS_CHART:
87
- case _constants.STAT_TYPE.GROUP_COMPLETENESS_CHART:
88
- {
89
- return /*#__PURE__*/_react.default.createElement(_completenessChart.default, viewProps);
90
- }
91
- case _constants.STAT_TYPE.LINE:
92
- case _constants.STAT_TYPE.GROUP_LINE:
93
- {
94
- return /*#__PURE__*/_react.default.createElement(_lineChart.default, viewProps);
95
- }
96
- case _constants.STAT_TYPE.AREA_CHART:
97
- case _constants.STAT_TYPE.AREA_GROUP_CHART:
98
- {
99
- return /*#__PURE__*/_react.default.createElement(_areaChart.default, viewProps);
100
- }
101
- case _constants.STAT_TYPE.PIE:
102
- {
103
- return /*#__PURE__*/_react.default.createElement(_pieChart.default, viewProps);
104
- }
105
- case _constants.STAT_TYPE.RING:
106
- {
107
- return /*#__PURE__*/_react.default.createElement(_ringChart.default, viewProps);
108
- }
109
- case _constants.STAT_TYPE.SCATTER:
110
- {
111
- return /*#__PURE__*/_react.default.createElement(_scatterChart.default, viewProps);
112
- }
113
- case _constants.STAT_TYPE.COMBINATION_CHART:
114
- {
115
- return /*#__PURE__*/_react.default.createElement(_combinationChart.default, viewProps);
116
- }
117
- case _constants.STAT_TYPE.MAP:
118
- case _constants.STAT_TYPE.MAP_BUBBLE:
119
- {
120
- viewProps.isPreview = viewProps.isEnlarge ? false : viewProps.isPreview;
121
- return /*#__PURE__*/_react.default.createElement(_map.default, viewProps);
122
- }
123
- case _constants.STAT_TYPE.WORLD_MAP:
124
- case _constants.STAT_TYPE.WORLD_MAP_BUBBLE:
125
- {
126
- viewProps.isPreview = viewProps.isEnlarge ? false : viewProps.isPreview;
127
- return /*#__PURE__*/_react.default.createElement(_worldMap.default, viewProps);
128
- }
129
- case _constants.STAT_TYPE.HEAT_MAP:
130
- {
131
- viewProps.isPreview = viewProps.isEnlarge ? false : viewProps.isPreview;
132
- return /*#__PURE__*/_react.default.createElement(_heatMap.default, viewProps);
133
- }
134
- case _constants.STAT_TYPE.MIRROR:
135
- {
136
- viewProps.isPreview = viewProps.isEnlarge ? false : viewProps.isPreview;
137
- return /*#__PURE__*/_react.default.createElement(_mirror.default, viewProps);
138
- }
139
- case _constants.STAT_TYPE.BASIC_NUMBER_CARD:
140
- {
141
- return /*#__PURE__*/_react.default.createElement(_basicNumberCard.default, viewProps);
142
- }
143
- case _constants.STAT_TYPE.TREND_CHART:
144
- {
145
- return /*#__PURE__*/_react.default.createElement(_trendChart.default, viewProps);
146
- }
147
- case _constants.STAT_TYPE.DASHBOARD:
148
- {
149
- return /*#__PURE__*/_react.default.createElement(_dashboardChart.default, viewProps);
150
- }
151
- case _constants.STAT_TYPE.TREEMAP:
152
- {
153
- return /*#__PURE__*/_react.default.createElement(_treemapChart.default, viewProps);
154
- }
155
- case _constants.STAT_TYPE.PIVOT_TABLE:
156
- {
157
- return /*#__PURE__*/_react.default.createElement(_pivotTable.default, viewProps);
158
- }
159
- case _constants.STAT_TYPE.CUSTOM_BAR:
160
- {
161
- return /*#__PURE__*/_react.default.createElement(_customBar.default, viewProps);
162
- }
163
- default:
164
- {
165
- return null;
166
- }
167
- }
48
+ colorThemeName
49
+ } = this.props;
50
+ return /*#__PURE__*/_react.default.createElement("div", {
51
+ className: "statistic-chart-container"
52
+ }, /*#__PURE__*/_react.default.createElement(_seaChart.View, {
53
+ chart: statItem,
54
+ api: api,
55
+ config: window.dtable,
56
+ tables: value.tables,
57
+ collaborators: value.collaborators,
58
+ hideTitle: true,
59
+ globalTheme: theme,
60
+ chartColorTheme: colorThemeName,
61
+ isCalculateByView: true,
62
+ onViewRef: this.getViewRef
63
+ }));
168
64
  }
169
65
  }
170
- StatView.defaultProps = {
171
- isPreview: false,
172
- isEnlarge: false,
173
- isEdit: false
174
- };
175
66
  var _default = exports.default = StatView;