d2aura 23.0.0

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 (274) hide show
  1. package/api/abstractApi.d.ts +21 -0
  2. package/api/abstractApi.js +56 -0
  3. package/api/abstractApi.js.map +1 -0
  4. package/api/abstractEntityApi.d.ts +37 -0
  5. package/api/abstractEntityApi.js +145 -0
  6. package/api/abstractEntityApi.js.map +1 -0
  7. package/api/advancedFilterApi.d.ts +56 -0
  8. package/api/advancedFilterApi.js +108 -0
  9. package/api/advancedFilterApi.js.map +1 -0
  10. package/api/archiveApi.d.ts +14 -0
  11. package/api/archiveApi.js +25 -0
  12. package/api/archiveApi.js.map +1 -0
  13. package/api/comparison/entityComparisonUtils.d.ts +4 -0
  14. package/api/comparison/entityComparisonUtils.js +15 -0
  15. package/api/comparison/entityComparisonUtils.js.map +1 -0
  16. package/api/constants/constants.d.ts +5 -0
  17. package/api/constants/constants.js +6 -0
  18. package/api/constants/constants.js.map +1 -0
  19. package/api/constants/d2ChartConstants.d.ts +5 -0
  20. package/api/constants/d2ChartConstants.js +6 -0
  21. package/api/constants/d2ChartConstants.js.map +1 -0
  22. package/api/edaApi.d.ts +36 -0
  23. package/api/edaApi.js +109 -0
  24. package/api/edaApi.js.map +1 -0
  25. package/api/impl/errorHandling.d.ts +1 -0
  26. package/api/impl/errorHandling.js +72 -0
  27. package/api/impl/errorHandling.js.map +1 -0
  28. package/api/impl/utils/reportError.d.ts +2 -0
  29. package/api/impl/utils/reportError.js +157 -0
  30. package/api/impl/utils/reportError.js.map +1 -0
  31. package/api/impl/utils/reportServiceMessage.d.ts +1 -0
  32. package/api/impl/utils/reportServiceMessage.js +29 -0
  33. package/api/impl/utils/reportServiceMessage.js.map +1 -0
  34. package/api/types/accessRight.d.ts +5 -0
  35. package/api/types/accessRight.js +7 -0
  36. package/api/types/accessRight.js.map +1 -0
  37. package/api/types/advancedFilter.d.ts +22 -0
  38. package/api/types/advancedFilter.js +16 -0
  39. package/api/types/advancedFilter.js.map +1 -0
  40. package/api/types/apiResult.d.ts +5 -0
  41. package/api/types/apiResult.js +2 -0
  42. package/api/types/apiResult.js.map +1 -0
  43. package/api/types/auditableEntity.d.ts +10 -0
  44. package/api/types/auditableEntity.js +2 -0
  45. package/api/types/auditableEntity.js.map +1 -0
  46. package/api/types/d2ArTypes.d.ts +5 -0
  47. package/api/types/d2ArTypes.js +2 -0
  48. package/api/types/d2ArTypes.js.map +1 -0
  49. package/api/types/d2ChartTypes.d.ts +26 -0
  50. package/api/types/d2ChartTypes.js +7 -0
  51. package/api/types/d2ChartTypes.js.map +1 -0
  52. package/api/types/dbBoolean.d.ts +5 -0
  53. package/api/types/dbBoolean.js +15 -0
  54. package/api/types/dbBoolean.js.map +1 -0
  55. package/api/types/entity.d.ts +7 -0
  56. package/api/types/entity.js +2 -0
  57. package/api/types/entity.js.map +1 -0
  58. package/api/types/entityListResult.d.ts +4 -0
  59. package/api/types/entityListResult.js +2 -0
  60. package/api/types/entityListResult.js.map +1 -0
  61. package/api/types/entityResult.d.ts +4 -0
  62. package/api/types/entityResult.js +2 -0
  63. package/api/types/entityResult.js.map +1 -0
  64. package/api/types/nounGender.d.ts +5 -0
  65. package/api/types/nounGender.js +7 -0
  66. package/api/types/nounGender.js.map +1 -0
  67. package/api/util/d2Boolean.d.ts +8 -0
  68. package/api/util/d2Boolean.js +14 -0
  69. package/api/util/d2Boolean.js.map +1 -0
  70. package/api/util/d2ChartUtils.d.ts +7 -0
  71. package/api/util/d2ChartUtils.js +62 -0
  72. package/api/util/d2ChartUtils.js.map +1 -0
  73. package/api/util/edaUtils.d.ts +5 -0
  74. package/api/util/edaUtils.js +33 -0
  75. package/api/util/edaUtils.js.map +1 -0
  76. package/api/util/fileUtils.d.ts +3 -0
  77. package/api/util/fileUtils.js +22 -0
  78. package/api/util/fileUtils.js.map +1 -0
  79. package/api/validation/abstractEntityValidationUtils.d.ts +8 -0
  80. package/api/validation/abstractEntityValidationUtils.js +24 -0
  81. package/api/validation/abstractEntityValidationUtils.js.map +1 -0
  82. package/core/types/panelConfiguration.d.ts +3 -0
  83. package/core/types/panelConfiguration.js +2 -0
  84. package/core/types/panelConfiguration.js.map +1 -0
  85. package/core/util/humanizeDuration.d.ts +1 -0
  86. package/core/util/humanizeDuration.js +24 -0
  87. package/core/util/humanizeDuration.js.map +1 -0
  88. package/core/util/isStringEmpty.d.ts +1 -0
  89. package/core/util/isStringEmpty.js +4 -0
  90. package/core/util/isStringEmpty.js.map +1 -0
  91. package/core/util/locationUtils.d.ts +10 -0
  92. package/core/util/locationUtils.js +34 -0
  93. package/core/util/locationUtils.js.map +1 -0
  94. package/coreui/abstractApp.d.ts +22 -0
  95. package/coreui/abstractApp.js +49 -0
  96. package/coreui/abstractApp.js.map +1 -0
  97. package/coreui/abstractListPanel.d.ts +88 -0
  98. package/coreui/abstractListPanel.js +426 -0
  99. package/coreui/abstractListPanel.js.map +1 -0
  100. package/coreui/abstractPage.d.ts +18 -0
  101. package/coreui/abstractPage.js +104 -0
  102. package/coreui/abstractPage.js.map +1 -0
  103. package/coreui/auth/loginForm.d.ts +27 -0
  104. package/coreui/auth/loginForm.js +47 -0
  105. package/coreui/auth/loginForm.js.map +1 -0
  106. package/coreui/auth/logoutButton.d.ts +9 -0
  107. package/coreui/auth/logoutButton.js +23 -0
  108. package/coreui/auth/logoutButton.js.map +1 -0
  109. package/coreui/components/about/aboutModalDialog.d.ts +30 -0
  110. package/coreui/components/about/aboutModalDialog.js +96 -0
  111. package/coreui/components/about/aboutModalDialog.js.map +1 -0
  112. package/coreui/components/advancedFilter/advancedFilterButton.d.ts +26 -0
  113. package/coreui/components/advancedFilter/advancedFilterButton.js +115 -0
  114. package/coreui/components/advancedFilter/advancedFilterButton.js.map +1 -0
  115. package/coreui/components/advancedFilter/advancedFilterColumnDefinitions.d.ts +18 -0
  116. package/coreui/components/advancedFilter/advancedFilterColumnDefinitions.js +39 -0
  117. package/coreui/components/advancedFilter/advancedFilterColumnDefinitions.js.map +1 -0
  118. package/coreui/components/advancedFilter/advancedFilterUtils.d.ts +12 -0
  119. package/coreui/components/advancedFilter/advancedFilterUtils.js +101 -0
  120. package/coreui/components/advancedFilter/advancedFilterUtils.js.map +1 -0
  121. package/coreui/components/advancedFilter/advancedFilterValidationUtils.d.ts +11 -0
  122. package/coreui/components/advancedFilter/advancedFilterValidationUtils.js +59 -0
  123. package/coreui/components/advancedFilter/advancedFilterValidationUtils.js.map +1 -0
  124. package/coreui/components/advancedFilter/advancedFilteredGrid.d.ts +55 -0
  125. package/coreui/components/advancedFilter/advancedFilteredGrid.js +165 -0
  126. package/coreui/components/advancedFilter/advancedFilteredGrid.js.map +1 -0
  127. package/coreui/components/advancedFilter/components/advancedFilterOperatorSelect.d.ts +14 -0
  128. package/coreui/components/advancedFilter/components/advancedFilterOperatorSelect.js +35 -0
  129. package/coreui/components/advancedFilter/components/advancedFilterOperatorSelect.js.map +1 -0
  130. package/coreui/components/advancedFilter/components/advancedFilterValueInput.d.ts +23 -0
  131. package/coreui/components/advancedFilter/components/advancedFilterValueInput.js +148 -0
  132. package/coreui/components/advancedFilter/components/advancedFilterValueInput.js.map +1 -0
  133. package/coreui/components/advancedFilter/conditionList/advancedFilterConditionDetailPanel.d.ts +18 -0
  134. package/coreui/components/advancedFilter/conditionList/advancedFilterConditionDetailPanel.js +82 -0
  135. package/coreui/components/advancedFilter/conditionList/advancedFilterConditionDetailPanel.js.map +1 -0
  136. package/coreui/components/advancedFilter/conditionList/advancedFilterConditionListModalDialog.d.ts +23 -0
  137. package/coreui/components/advancedFilter/conditionList/advancedFilterConditionListModalDialog.js +58 -0
  138. package/coreui/components/advancedFilter/conditionList/advancedFilterConditionListModalDialog.js.map +1 -0
  139. package/coreui/components/advancedFilter/conditionList/advancedFilterConditionListPanel.d.ts +31 -0
  140. package/coreui/components/advancedFilter/conditionList/advancedFilterConditionListPanel.js +211 -0
  141. package/coreui/components/advancedFilter/conditionList/advancedFilterConditionListPanel.js.map +1 -0
  142. package/coreui/components/advancedFilter/filterList/advancedFilterListModalDialog.d.ts +15 -0
  143. package/coreui/components/advancedFilter/filterList/advancedFilterListModalDialog.js +48 -0
  144. package/coreui/components/advancedFilter/filterList/advancedFilterListModalDialog.js.map +1 -0
  145. package/coreui/components/advancedFilter/filterSave/filterSaveModalDialog.d.ts +18 -0
  146. package/coreui/components/advancedFilter/filterSave/filterSaveModalDialog.js +37 -0
  147. package/coreui/components/advancedFilter/filterSave/filterSaveModalDialog.js.map +1 -0
  148. package/coreui/components/advancedFilter/floatingColumnFilter/advancedFilterFloatingColumnComponent.d.ts +26 -0
  149. package/coreui/components/advancedFilter/floatingColumnFilter/advancedFilterFloatingColumnComponent.js +81 -0
  150. package/coreui/components/advancedFilter/floatingColumnFilter/advancedFilterFloatingColumnComponent.js.map +1 -0
  151. package/coreui/components/assignEntitiesToEntity/abstractEntitiesOnEntityList.d.ts +32 -0
  152. package/coreui/components/assignEntitiesToEntity/abstractEntitiesOnEntityList.js +102 -0
  153. package/coreui/components/assignEntitiesToEntity/abstractEntitiesOnEntityList.js.map +1 -0
  154. package/coreui/components/changePasswordModalDialog/changePasswordModalDialog.d.ts +23 -0
  155. package/coreui/components/changePasswordModalDialog/changePasswordModalDialog.js +83 -0
  156. package/coreui/components/changePasswordModalDialog/changePasswordModalDialog.js.map +1 -0
  157. package/coreui/components/colorTag/colorTag.d.ts +9 -0
  158. package/coreui/components/colorTag/colorTag.js +17 -0
  159. package/coreui/components/colorTag/colorTag.js.map +1 -0
  160. package/coreui/components/d2Chart/d2ChartOptions.d.ts +3 -0
  161. package/coreui/components/d2Chart/d2ChartOptions.js +73 -0
  162. package/coreui/components/d2Chart/d2ChartOptions.js.map +1 -0
  163. package/coreui/components/d2Chart/d2ChartPanel.d.ts +48 -0
  164. package/coreui/components/d2Chart/d2ChartPanel.js +325 -0
  165. package/coreui/components/d2Chart/d2ChartPanel.js.map +1 -0
  166. package/coreui/components/d2Chart/d2ChartTablePanel.d.ts +31 -0
  167. package/coreui/components/d2Chart/d2ChartTablePanel.js +121 -0
  168. package/coreui/components/d2Chart/d2ChartTablePanel.js.map +1 -0
  169. package/coreui/components/d2Chart/d2ChartToolboxPanel.d.ts +27 -0
  170. package/coreui/components/d2Chart/d2ChartToolboxPanel.js +116 -0
  171. package/coreui/components/d2Chart/d2ChartToolboxPanel.js.map +1 -0
  172. package/coreui/components/edaManager/abstract/edaManagerAbstractPanel.d.ts +51 -0
  173. package/coreui/components/edaManager/abstract/edaManagerAbstractPanel.js +169 -0
  174. package/coreui/components/edaManager/abstract/edaManagerAbstractPanel.js.map +1 -0
  175. package/coreui/components/edaManager/abstract/edaManagerAbstractTablePanel.d.ts +32 -0
  176. package/coreui/components/edaManager/abstract/edaManagerAbstractTablePanel.js +87 -0
  177. package/coreui/components/edaManager/abstract/edaManagerAbstractTablePanel.js.map +1 -0
  178. package/coreui/components/edaManager/abstract/edaManagerAbstractVectorList.d.ts +24 -0
  179. package/coreui/components/edaManager/abstract/edaManagerAbstractVectorList.js +98 -0
  180. package/coreui/components/edaManager/abstract/edaManagerAbstractVectorList.js.map +1 -0
  181. package/coreui/components/edaManager/compactPanel/edaManagerCompactPanel.d.ts +19 -0
  182. package/coreui/components/edaManager/compactPanel/edaManagerCompactPanel.js +52 -0
  183. package/coreui/components/edaManager/compactPanel/edaManagerCompactPanel.js.map +1 -0
  184. package/coreui/components/edaManager/compactPanel/initialLayout.d.ts +2 -0
  185. package/coreui/components/edaManager/compactPanel/initialLayout.js +26 -0
  186. package/coreui/components/edaManager/compactPanel/initialLayout.js.map +1 -0
  187. package/coreui/components/edaManager/components/detail/components/edaVectorMassChangeButton.d.ts +38 -0
  188. package/coreui/components/edaManager/components/detail/components/edaVectorMassChangeButton.js +182 -0
  189. package/coreui/components/edaManager/components/detail/components/edaVectorMassChangeButton.js.map +1 -0
  190. package/coreui/components/edaManager/components/detail/edaVectorDetailModalDialog.d.ts +23 -0
  191. package/coreui/components/edaManager/components/detail/edaVectorDetailModalDialog.js +122 -0
  192. package/coreui/components/edaManager/components/detail/edaVectorDetailModalDialog.js.map +1 -0
  193. package/coreui/components/edaManager/components/detail/edaVectorDetailTablePanel.d.ts +16 -0
  194. package/coreui/components/edaManager/components/detail/edaVectorDetailTablePanel.js +63 -0
  195. package/coreui/components/edaManager/components/detail/edaVectorDetailTablePanel.js.map +1 -0
  196. package/coreui/components/edaManager/components/detail/initialLayout.d.ts +2 -0
  197. package/coreui/components/edaManager/components/detail/initialLayout.js +29 -0
  198. package/coreui/components/edaManager/components/detail/initialLayout.js.map +1 -0
  199. package/coreui/components/edaManager/components/edaManagerTablePanel.d.ts +22 -0
  200. package/coreui/components/edaManager/components/edaManagerTablePanel.js +80 -0
  201. package/coreui/components/edaManager/components/edaManagerTablePanel.js.map +1 -0
  202. package/coreui/components/edaManager/components/edaManagerTimePanel.d.ts +22 -0
  203. package/coreui/components/edaManager/components/edaManagerTimePanel.js +38 -0
  204. package/coreui/components/edaManager/components/edaManagerTimePanel.js.map +1 -0
  205. package/coreui/components/edaManager/components/edaManagerVectorList.d.ts +11 -0
  206. package/coreui/components/edaManager/components/edaManagerVectorList.js +35 -0
  207. package/coreui/components/edaManager/components/edaManagerVectorList.js.map +1 -0
  208. package/coreui/components/edaManager/components/edaStepSelect/edaStepConstants.d.ts +0 -0
  209. package/coreui/components/edaManager/components/edaStepSelect/edaStepConstants.js +2 -0
  210. package/coreui/components/edaManager/components/edaStepSelect/edaStepConstants.js.map +1 -0
  211. package/coreui/components/edaManager/components/edaStepSelect/edaStepSelect.d.ts +13 -0
  212. package/coreui/components/edaManager/components/edaStepSelect/edaStepSelect.js +14 -0
  213. package/coreui/components/edaManager/components/edaStepSelect/edaStepSelect.js.map +1 -0
  214. package/coreui/components/edaManager/components/edaVectorSelect/edaVectorSelect.d.ts +10 -0
  215. package/coreui/components/edaManager/components/edaVectorSelect/edaVectorSelect.js +20 -0
  216. package/coreui/components/edaManager/components/edaVectorSelect/edaVectorSelect.js.map +1 -0
  217. package/coreui/components/edaManager/components/edaVectorSelect/edaVectorSelectModalDialog.d.ts +13 -0
  218. package/coreui/components/edaManager/components/edaVectorSelect/edaVectorSelectModalDialog.js +22 -0
  219. package/coreui/components/edaManager/components/edaVectorSelect/edaVectorSelectModalDialog.js.map +1 -0
  220. package/coreui/components/edaManager/constants.d.ts +2 -0
  221. package/coreui/components/edaManager/constants.js +11 -0
  222. package/coreui/components/edaManager/constants.js.map +1 -0
  223. package/coreui/components/edaManager/panel/edaManagerPanel.d.ts +13 -0
  224. package/coreui/components/edaManager/panel/edaManagerPanel.js +32 -0
  225. package/coreui/components/edaManager/panel/edaManagerPanel.js.map +1 -0
  226. package/coreui/components/edaManager/panel/initialLayout.d.ts +2 -0
  227. package/coreui/components/edaManager/panel/initialLayout.js +39 -0
  228. package/coreui/components/edaManager/panel/initialLayout.js.map +1 -0
  229. package/coreui/components/editor/abstractEntityConfigPanel.d.ts +82 -0
  230. package/coreui/components/editor/abstractEntityConfigPanel.js +307 -0
  231. package/coreui/components/editor/abstractEntityConfigPanel.js.map +1 -0
  232. package/coreui/components/filePicker/filePicker.d.ts +20 -0
  233. package/coreui/components/filePicker/filePicker.js +57 -0
  234. package/coreui/components/filePicker/filePicker.js.map +1 -0
  235. package/coreui/components/grid/auditEntityRowStyleRules.d.ts +3 -0
  236. package/coreui/components/grid/auditEntityRowStyleRules.js +34 -0
  237. package/coreui/components/grid/auditEntityRowStyleRules.js.map +1 -0
  238. package/coreui/components/grid/detailHeaderPanel.d.ts +13 -0
  239. package/coreui/components/grid/detailHeaderPanel.js +29 -0
  240. package/coreui/components/grid/detailHeaderPanel.js.map +1 -0
  241. package/coreui/components/grid/standardColumns.d.ts +14 -0
  242. package/coreui/components/grid/standardColumns.js +150 -0
  243. package/coreui/components/grid/standardColumns.js.map +1 -0
  244. package/coreui/components/history/entityHistoryListPanel.d.ts +38 -0
  245. package/coreui/components/history/entityHistoryListPanel.js +154 -0
  246. package/coreui/components/history/entityHistoryListPanel.js.map +1 -0
  247. package/coreui/components/languageSelect/languageSelect.d.ts +17 -0
  248. package/coreui/components/languageSelect/languageSelect.js +28 -0
  249. package/coreui/components/languageSelect/languageSelect.js.map +1 -0
  250. package/coreui/components/modalWithIcon/openModalWithIcon.d.ts +8 -0
  251. package/coreui/components/modalWithIcon/openModalWithIcon.js +30 -0
  252. package/coreui/components/modalWithIcon/openModalWithIcon.js.map +1 -0
  253. package/coreui/components/select/abstractSelect.d.ts +57 -0
  254. package/coreui/components/select/abstractSelect.js +233 -0
  255. package/coreui/components/select/abstractSelect.js.map +1 -0
  256. package/coreui/components/select/abstractSelectModalDialog.d.ts +33 -0
  257. package/coreui/components/select/abstractSelectModalDialog.js +110 -0
  258. package/coreui/components/select/abstractSelectModalDialog.js.map +1 -0
  259. package/coreui/components/select/selectUtils.d.ts +4 -0
  260. package/coreui/components/select/selectUtils.js +14 -0
  261. package/coreui/components/select/selectUtils.js.map +1 -0
  262. package/coreui/components/titleWithCodePanel/titleWithCodePanel.d.ts +10 -0
  263. package/coreui/components/titleWithCodePanel/titleWithCodePanel.js +20 -0
  264. package/coreui/components/titleWithCodePanel/titleWithCodePanel.js.map +1 -0
  265. package/coreui/icons/icons.d.ts +3 -0
  266. package/coreui/icons/icons.js +18 -0
  267. package/coreui/icons/icons.js.map +1 -0
  268. package/coreui/layout/contextToolbar.d.ts +15 -0
  269. package/coreui/layout/contextToolbar.js +41 -0
  270. package/coreui/layout/contextToolbar.js.map +1 -0
  271. package/coreui/style/index.less +165 -0
  272. package/coreui/style/login.css +214 -0
  273. package/package.json +65 -0
  274. package/tsconfig.json +38 -0
@@ -0,0 +1,325 @@
1
+ import React from "react";
2
+ import ReactEcharts from "echarts-for-react";
3
+ import { compactChartOptions, d2ChartOptions } from "./d2ChartOptions";
4
+ import { at } from "lodash";
5
+ import i18n from "d2core/i18n/i18n";
6
+ import { Empty } from "antd";
7
+ import isEqual from "lodash/isEqual";
8
+ import D2ChartTablePanel from "./d2ChartTablePanel";
9
+ import { ModalDialog } from "d2coreui/components/modal/modalDialog";
10
+ import D2ChartToolboxPanel from "./d2ChartToolboxPanel";
11
+ import { LoadingOutlined } from "@ant-design/icons";
12
+ import { LineStyleEnum } from "../../../api/types/d2ChartTypes";
13
+ import D2ChartUtils from "../../../api/util/d2ChartUtils";
14
+ class D2ChartPanel extends React.Component {
15
+ constructor(props) {
16
+ super(props);
17
+ this.chartInstance = null;
18
+ this.d2ChartPanelInModal = null;
19
+ this.d2ChartTablePanel = null;
20
+ this.state = {
21
+ tableItems: [],
22
+ missingData: [],
23
+ modalVisible: false,
24
+ calendarDataVisible: false,
25
+ missingDataVisible: true,
26
+ };
27
+ this.onSwitchCalendarData = this.onSwitchCalendarData.bind(this);
28
+ this.onSwitchLegend = this.onSwitchLegend.bind(this);
29
+ }
30
+ componentDidUpdate(prevProps) {
31
+ if (!isEqual(this.props.markArea, prevProps.markArea) && this.props.d2ChartRecords.length > 0) {
32
+ this.onReload();
33
+ }
34
+ }
35
+ onSwitchLegend(name) {
36
+ const tableData = this.state.tableItems;
37
+ const d2ChartTableItem = tableData.find(value => value.id === name);
38
+ if (d2ChartTableItem) {
39
+ this.chartInstance.dispatchAction({
40
+ type: d2ChartTableItem.visible ? "legendUnSelect" : "legendSelect",
41
+ name: name,
42
+ });
43
+ d2ChartTableItem.visible = !d2ChartTableItem.visible;
44
+ this.setState({ tableItems: tableData }, () => this.d2ChartTablePanel?.updateGrid());
45
+ }
46
+ }
47
+ onSwitchCalendarData() {
48
+ const calendarDataVisible = this.state.calendarDataVisible;
49
+ const option = this.chartInstance.getOption();
50
+ if (calendarDataVisible) {
51
+ this.prepareCalendarMarkarea(option.series, option.dataset[0]);
52
+ this.chartInstance.setOption(option);
53
+ }
54
+ const calendarSeries = option.series.filter((value) => value.name.startsWith("__markArea-calendar-"));
55
+ calendarSeries.forEach(value => {
56
+ this.chartInstance.dispatchAction({
57
+ type: calendarDataVisible ? "legendSelect" : "legendUnSelect",
58
+ name: value.name,
59
+ });
60
+ });
61
+ }
62
+ prepareCalendarMarkarea(series, dataset) {
63
+ if (this.props.d2ChartCalendarRecords) {
64
+ const markAreas = D2ChartUtils.calendarRecordsToMarkAreas(this.props.d2ChartCalendarRecords);
65
+ Object.keys(markAreas).forEach(key => {
66
+ const markAreaName = `__markArea-calendar-${key}`;
67
+ const markArea = {
68
+ name: markAreaName,
69
+ type: "line",
70
+ sampling: D2ChartPanel.SAMPLING_MODE,
71
+ markArea: markAreas[key],
72
+ encode: {
73
+ x: "timestamp",
74
+ y: markAreaName,
75
+ },
76
+ };
77
+ const seriesIndex = series.findIndex(value => value.name === markAreaName);
78
+ if (seriesIndex >= 0) {
79
+ series[seriesIndex] = markArea;
80
+ }
81
+ else {
82
+ series.push(markArea);
83
+ }
84
+ const dimensionsIndex = dataset.dimensions.findIndex((value) => value === markAreaName);
85
+ if (dimensionsIndex >= 0) {
86
+ dataset.dimensions[dimensionsIndex] = markAreaName;
87
+ }
88
+ else {
89
+ dataset.dimensions.push(markAreaName);
90
+ }
91
+ });
92
+ }
93
+ }
94
+ onSwitchMissingData() {
95
+ this.chartInstance.dispatchAction({
96
+ type: this.state.missingDataVisible ? "legendSelect" : "legendUnSelect",
97
+ name: "__markArea-missing-data",
98
+ });
99
+ }
100
+ setTooltip(option) {
101
+ option.tooltip = {
102
+ trigger: "axis",
103
+ position: (_pos, params) => {
104
+ const param = params[0];
105
+ if (param && param.data) {
106
+ const data = this.state.tableItems;
107
+ data.forEach((value, index) => {
108
+ if (value.visible) {
109
+ value.tooltipValue = param.data[index + 1];
110
+ }
111
+ else {
112
+ value.tooltipValue = undefined;
113
+ }
114
+ });
115
+ this.setState({ tableItems: data, tooltipTime: param.data[0] }, () => {
116
+ this.d2ChartTablePanel?.updateGrid();
117
+ });
118
+ }
119
+ },
120
+ formatter: (params) => {
121
+ if (Array.isArray(params)) {
122
+ const seriesToCompare = params.filter(value => !value.seriesName.startsWith("__"));
123
+ if (seriesToCompare.length === 2) {
124
+ const data = seriesToCompare[0].data;
125
+ const seriesName1 = seriesToCompare[0].seriesName;
126
+ const seriesName2 = seriesToCompare[1].seriesName;
127
+ const dimensions = seriesToCompare[0].dimensionNames;
128
+ const value1 = data[dimensions.findIndex(value => value === seriesName1)];
129
+ const value2 = data[dimensions.findIndex(value => value === seriesName2)];
130
+ if (value1 !== undefined && value2 !== undefined) {
131
+ const gap = value1 - value2;
132
+ return `Gap: ${gap.toFixed(4)}`;
133
+ }
134
+ }
135
+ }
136
+ return "";
137
+ }
138
+ };
139
+ }
140
+ getUniqueId(code, index) {
141
+ return `${code}@${index}`;
142
+ }
143
+ getDiemnsions(currentSeries) {
144
+ return currentSeries.map((value, index) => this.getUniqueId(value.code, index));
145
+ }
146
+ getSeriesFields(currentSeries) {
147
+ return currentSeries.map((_, index) => `col${index}`);
148
+ }
149
+ getSeries(currentSeries, optionColors) {
150
+ return currentSeries.map((value, index) => {
151
+ return {
152
+ name: this.getUniqueId(value.code, index),
153
+ type: "line",
154
+ sampling: D2ChartPanel.SAMPLING_MODE,
155
+ symbol: "none",
156
+ step: "end",
157
+ color: optionColors[value.colorIndex !== undefined ? value.colorIndex : index % optionColors.length],
158
+ encode: {
159
+ x: "timestamp",
160
+ y: this.getUniqueId(value.code, index)
161
+ },
162
+ areaStyle: value.fillColor ? {} : undefined,
163
+ lineStyle: { type: value.lineStyle ?? LineStyleEnum.SOLID }
164
+ };
165
+ });
166
+ }
167
+ getTableItems(currentSeries, seriesFields, optionColors) {
168
+ return currentSeries.map((series, index) => {
169
+ const recordValues = this.props.d2ChartRecords.map(value => at(value, seriesFields[index])[0]).filter(value => value !== undefined);
170
+ const uniqueId = this.getUniqueId(series.code, index);
171
+ const [min, max, sum] = recordValues.reduce(([min, max, sum], val) => [Math.min(min, val), Math.max(max, val), sum + val], [Number.POSITIVE_INFINITY, Number.NEGATIVE_INFINITY, 0]);
172
+ return {
173
+ id: uniqueId,
174
+ displayName: series.name,
175
+ color: optionColors[series.colorIndex !== undefined ? series.colorIndex : index % optionColors.length],
176
+ visible: this.state.tableItems.find(value => value.id === uniqueId)?.visible ?? true,
177
+ min: recordValues.length === 0 ? undefined : min,
178
+ max: recordValues.length === 0 ? undefined : max,
179
+ avg: recordValues.length === 0 ? undefined : sum / recordValues.length,
180
+ sum: sum,
181
+ };
182
+ });
183
+ }
184
+ getDatasetSource(seriesFields) {
185
+ return this.props.d2ChartRecords.map(record => {
186
+ const seriesValuesInTime = at(record, seriesFields);
187
+ const roundedSeriesValues = seriesValuesInTime.map(value => value !== undefined && value !== null ? +value.toFixed(4) : undefined);
188
+ roundedSeriesValues.unshift(record.date.getTime());
189
+ return roundedSeriesValues;
190
+ });
191
+ }
192
+ onReload() {
193
+ const tableItems = [];
194
+ let missingData = [];
195
+ const option = this.chartInstance?.getOption();
196
+ if (option) {
197
+ const currentSeries = this.props.d2ChartSeries;
198
+ const seriesFields = this.getSeriesFields(currentSeries);
199
+ const series = this.getSeries(currentSeries, option.color);
200
+ const dataset = {
201
+ dimensions: ["timestamp", ...this.getDiemnsions(currentSeries)],
202
+ source: this.getDatasetSource(seriesFields),
203
+ };
204
+ tableItems.push(...this.getTableItems(currentSeries, seriesFields, option.color));
205
+ this.setTooltip(option);
206
+ if (this.props.markArea) {
207
+ series.push({
208
+ name: "__markArea",
209
+ type: "line",
210
+ sampling: D2ChartPanel.SAMPLING_MODE,
211
+ markArea: this.props.markArea,
212
+ encode: {
213
+ x: "timestamp",
214
+ y: "__markArea",
215
+ },
216
+ });
217
+ dataset.dimensions.push("__markArea");
218
+ }
219
+ if (this.state.calendarDataVisible) {
220
+ this.prepareCalendarMarkarea(series, dataset);
221
+ }
222
+ const missingDataMarkArea = D2ChartUtils.getMissingDataMarkArea(this.props.d2ChartRecords, seriesFields);
223
+ missingData = missingDataMarkArea.data;
224
+ series.push({
225
+ name: "__markArea-missing-data",
226
+ type: "line",
227
+ sampling: D2ChartPanel.SAMPLING_MODE,
228
+ markArea: missingDataMarkArea,
229
+ encode: {
230
+ x: "timestamp",
231
+ y: "__markArea-missing-data",
232
+ },
233
+ });
234
+ dataset.dimensions.push("__markArea-missing-data");
235
+ option.dataset = dataset;
236
+ option.series = series;
237
+ option.markArea = undefined;
238
+ option.legend[0].selected = Object.fromEntries(tableItems.map(value => [value.id, value.visible]));
239
+ if (this.props.yAxisLabel) {
240
+ option.yAxis[0].name = this.props.yAxisLabel;
241
+ }
242
+ this.chartInstance.setOption(option, true);
243
+ }
244
+ this.setState({
245
+ tableItems: tableItems,
246
+ missingData: missingData,
247
+ });
248
+ }
249
+ resize() {
250
+ this.chartInstance?.resize();
251
+ }
252
+ renderToolbox() {
253
+ return (React.createElement(D2ChartToolboxPanel, { missingData: this.state.missingData, calendarDataVisible: this.state.calendarDataVisible, missingDataVisible: this.state.missingDataVisible, showCalendarIcon: !!this.props.d2ChartCalendarRecords, onSwitchCalendarData: () => {
254
+ this.setState({ calendarDataVisible: !this.state.calendarDataVisible }, () => {
255
+ this.onSwitchCalendarData();
256
+ });
257
+ }, onSwitchMissingData: () => {
258
+ this.setState({ missingDataVisible: !this.state.missingDataVisible }, () => {
259
+ this.onSwitchMissingData();
260
+ });
261
+ }, onZoomControlSwitch: zoomEnabled => {
262
+ this.chartInstance.dispatchAction({
263
+ type: "takeGlobalCursor",
264
+ key: "dataZoomSelect",
265
+ dataZoomSelectActive: zoomEnabled
266
+ });
267
+ }, onZoomReset: () => {
268
+ this.chartInstance.dispatchAction({
269
+ type: "dataZoom",
270
+ start: 0,
271
+ end: 100,
272
+ });
273
+ }, compact: this.props.compact, onFullScreen: () => {
274
+ this.setState({ modalVisible: true }, () => {
275
+ setTimeout(() => this.d2ChartPanelInModal?.onReload());
276
+ setTimeout(() => this.d2ChartPanelInModal?.resize());
277
+ });
278
+ } }));
279
+ }
280
+ renderModalDialog() {
281
+ return (React.createElement(ModalDialog, { mode: "NO_BUTTONS", open: this.state.modalVisible, onCancel: () => this.setState({ modalVisible: false }), title: i18n("Chart"), initialWidth: window.innerWidth * 0.8, initialHeight: window.innerHeight * 0.98 },
282
+ React.createElement(D2ChartPanel, { ref: component => {
283
+ this.d2ChartPanelInModal = component;
284
+ }, d2ChartSeries: this.props.d2ChartSeries, d2ChartRecords: this.props.d2ChartRecords, d2ChartCalendarRecords: this.props.d2ChartCalendarRecords, loading: this.props.loading, tableHeight: 180, tableWrapperStyle: { padding: "0px 12px 8px" }, markArea: this.props.markArea })));
285
+ }
286
+ render() {
287
+ const style = {
288
+ height: "100%",
289
+ display: "flex",
290
+ flexDirection: "column",
291
+ justifyContent: "center",
292
+ };
293
+ if (this.props.loading) {
294
+ return (React.createElement("div", { style: { alignItems: "center", ...style } },
295
+ React.createElement(LoadingOutlined, null)));
296
+ }
297
+ else if (this.props.d2ChartRecords.length === 0) {
298
+ return (React.createElement(Empty, { style: style, description: i18n("No records found."), imageStyle: { height: "8vh" } }));
299
+ }
300
+ else {
301
+ let computedTableHeight = this.props.tableHeight;
302
+ if (computedTableHeight === "auto") {
303
+ computedTableHeight = 62 + this.props.d2ChartSeries.length * 28;
304
+ }
305
+ return (React.createElement("div", { style: { position: "relative", ...style } },
306
+ this.renderModalDialog(),
307
+ this.renderToolbox(),
308
+ React.createElement(ReactEcharts, { style: { height: `calc(100% - ${computedTableHeight}px)` }, onChartReady: instance => {
309
+ this.chartInstance = instance;
310
+ const zr = instance.getZr();
311
+ zr.on("mouseout", () => {
312
+ const tableItems = this.state.tableItems;
313
+ tableItems.forEach(value => value.tooltipValue = undefined);
314
+ this.setState({ tableItems: tableItems, tooltipTime: undefined }, () => {
315
+ this.d2ChartTablePanel?.updateGrid();
316
+ });
317
+ });
318
+ }, option: this.props.compact ? compactChartOptions : d2ChartOptions }),
319
+ React.createElement(D2ChartTablePanel, { style: { height: computedTableHeight, ...this.props.tableWrapperStyle }, ref: component => this.d2ChartTablePanel = component, tableItems: this.state.tableItems, tooltipTime: this.state.tooltipTime, onSwitchLegend: this.onSwitchLegend })));
320
+ }
321
+ }
322
+ }
323
+ D2ChartPanel.SAMPLING_MODE = "minmax";
324
+ export default D2ChartPanel;
325
+ //# sourceMappingURL=d2ChartPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"d2ChartPanel.js","sourceRoot":"","sources":["../../../../../coreui/components/d2Chart/d2ChartPanel.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from \"react\";\r\nimport ReactEcharts, {EChartsInstance, EChartsOption} from \"echarts-for-react\";\r\nimport {compactChartOptions, d2ChartOptions} from \"./d2ChartOptions\";\r\nimport {at} from \"lodash\";\r\nimport i18n from \"d2core/i18n/i18n\";\r\nimport {Empty} from \"antd\";\r\nimport {UnixTime} from \"d2jsapi\";\r\nimport isEqual from \"lodash/isEqual\";\r\nimport D2ChartTablePanel, {D2ChartTableItem} from \"./d2ChartTablePanel\";\r\nimport {ModalDialog, ModalDialogMode} from \"d2coreui/components/modal/modalDialog\";\r\nimport D2ChartToolboxPanel from \"./d2ChartToolboxPanel\";\r\nimport {LoadingOutlined} from \"@ant-design/icons\";\r\nimport {D2ChartRecord, D2ChartSeriesItem, LineStyleEnum, MarkArea, MarkAreaData} from \"../../../api/types/d2ChartTypes\";\r\nimport D2ChartUtils from \"../../../api/util/d2ChartUtils\";\r\n\r\ninterface SeriesItem {\r\n name: string,\r\n type: string,\r\n sampling: string,\r\n symbol?: string,\r\n step?: string,\r\n color?: string,\r\n encode?: { x: string, y: string },\r\n markArea?: MarkArea\r\n}\r\n\r\nexport interface Props {\r\n d2ChartSeries: D2ChartSeriesItem[]\r\n d2ChartRecords: D2ChartRecord[]\r\n d2ChartCalendarRecords?: D2ChartRecord[]\r\n loading?: boolean\r\n\r\n markArea?: MarkArea\r\n compact?: boolean\r\n yAxisLabel?: string\r\n\r\n tableHeight: number | \"auto\"\r\n tableWrapperStyle?: Omit<React.CSSProperties, \"height\">\r\n}\r\n\r\ninterface State {\r\n tableItems: D2ChartTableItem[]\r\n tooltipTime?: UnixTime\r\n missingData: MarkAreaData[][]\r\n\r\n modalVisible: boolean\r\n calendarDataVisible: boolean\r\n missingDataVisible: boolean\r\n}\r\n\r\nexport default class D2ChartPanel extends React.Component<Props, State> {\r\n private static SAMPLING_MODE = \"minmax\";\r\n private chartInstance: EChartsInstance | null = null;\r\n private d2ChartPanelInModal: D2ChartPanel | null = null;\r\n private d2ChartTablePanel: D2ChartTablePanel | null = null;\r\n\r\n constructor(props: Readonly<Props>) {\r\n super(props);\r\n\r\n this.state = {\r\n tableItems: [],\r\n missingData: [],\r\n modalVisible: false,\r\n calendarDataVisible: false,\r\n missingDataVisible: true,\r\n }\r\n\r\n this.onSwitchCalendarData = this.onSwitchCalendarData.bind(this);\r\n this.onSwitchLegend = this.onSwitchLegend.bind(this);\r\n }\r\n\r\n componentDidUpdate(prevProps: Readonly<Props>) {\r\n if (!isEqual(this.props.markArea, prevProps.markArea) && this.props.d2ChartRecords.length > 0) {\r\n this.onReload();\r\n }\r\n }\r\n\r\n private onSwitchLegend(name: string) {\r\n const tableData = this.state.tableItems;\r\n const d2ChartTableItem = tableData.find(value => value.id === name);\r\n\r\n if (d2ChartTableItem) {\r\n this.chartInstance.dispatchAction({\r\n type: d2ChartTableItem.visible ? \"legendUnSelect\" : \"legendSelect\",\r\n name: name,\r\n });\r\n\r\n d2ChartTableItem.visible = !d2ChartTableItem.visible\r\n this.setState({tableItems: tableData}, () => this.d2ChartTablePanel?.updateGrid());\r\n }\r\n }\r\n\r\n private onSwitchCalendarData() {\r\n const calendarDataVisible = this.state.calendarDataVisible;\r\n const option = this.chartInstance.getOption();\r\n\r\n if (calendarDataVisible) {\r\n this.prepareCalendarMarkarea(option.series, option.dataset[0]);\r\n this.chartInstance.setOption(option);\r\n }\r\n const calendarSeries = option.series.filter((value: SeriesItem) => value.name.startsWith(\"__markArea-calendar-\")) as SeriesItem[];\r\n calendarSeries.forEach(value => {\r\n this.chartInstance.dispatchAction({\r\n type: calendarDataVisible ? \"legendSelect\" : \"legendUnSelect\",\r\n name: value.name,\r\n });\r\n });\r\n }\r\n\r\n private prepareCalendarMarkarea(series: SeriesItem[], dataset: any) {\r\n if (this.props.d2ChartCalendarRecords) {\r\n const markAreas = D2ChartUtils.calendarRecordsToMarkAreas(this.props.d2ChartCalendarRecords);\r\n Object.keys(markAreas).forEach(key => {\r\n const markAreaName = `__markArea-calendar-${key}`;\r\n const markArea = {\r\n name: markAreaName,\r\n type: \"line\",\r\n sampling: D2ChartPanel.SAMPLING_MODE,\r\n markArea: markAreas[key],\r\n encode: {\r\n x: \"timestamp\",\r\n y: markAreaName,\r\n },\r\n }\r\n\r\n const seriesIndex = series.findIndex(value => value.name === markAreaName);\r\n if (seriesIndex >= 0) {\r\n series[seriesIndex] = markArea;\r\n } else {\r\n series.push(markArea);\r\n }\r\n\r\n const dimensionsIndex = dataset.dimensions.findIndex((value: string) => value === markAreaName);\r\n if (dimensionsIndex >= 0) {\r\n dataset.dimensions[dimensionsIndex] = markAreaName;\r\n } else {\r\n dataset.dimensions.push(markAreaName);\r\n }\r\n });\r\n }\r\n }\r\n\r\n private onSwitchMissingData() {\r\n this.chartInstance.dispatchAction({\r\n type: this.state.missingDataVisible ? \"legendSelect\" : \"legendUnSelect\",\r\n name: \"__markArea-missing-data\",\r\n });\r\n }\r\n\r\n private setTooltip(option: EChartsOption) {\r\n option.tooltip = {\r\n trigger: \"axis\",\r\n position: (_pos: any, params: any[]) => {\r\n const param = params[0];\r\n if (param && param.data) {\r\n const data = this.state.tableItems;\r\n data.forEach((value, index) => {\r\n if (value.visible) {\r\n value.tooltipValue = param.data[index + 1]; //index 0 is timestamp\r\n } else {\r\n value.tooltipValue = undefined;\r\n }\r\n });\r\n\r\n this.setState({tableItems: data, tooltipTime: param.data[0]}, () => {\r\n this.d2ChartTablePanel?.updateGrid();\r\n });\r\n }\r\n },\r\n formatter: (params: Object | Array<any>) => {\r\n if (Array.isArray(params)) {\r\n const seriesToCompare = params.filter(value => !value.seriesName.startsWith(\"__\"));\r\n if (seriesToCompare.length === 2) {\r\n const data = seriesToCompare[0].data;\r\n const seriesName1 = seriesToCompare[0].seriesName;\r\n const seriesName2 = seriesToCompare[1].seriesName;\r\n const dimensions = seriesToCompare[0].dimensionNames as string[];\r\n\r\n const value1 = data[dimensions.findIndex(value => value === seriesName1)]\r\n const value2 = data[dimensions.findIndex(value => value === seriesName2)]\r\n if (value1 !== undefined && value2 !== undefined) {\r\n const gap = value1 - value2;\r\n return `Gap: ${gap.toFixed(4)}`;\r\n }\r\n }\r\n }\r\n return \"\";\r\n }\r\n }\r\n }\r\n\r\n private getUniqueId(code: string, index: number): string {\r\n return `${code}@${index}`;\r\n }\r\n\r\n private getDiemnsions(currentSeries: D2ChartSeriesItem[]): string[] {\r\n return currentSeries.map((value, index) => this.getUniqueId(value.code!, index));\r\n }\r\n\r\n private getSeriesFields(currentSeries: D2ChartSeriesItem[]): string[] {\r\n return currentSeries.map((_, index) => `col${index}`);\r\n }\r\n\r\n private getSeries(currentSeries: D2ChartSeriesItem[], optionColors: string[]): SeriesItem[] {\r\n return currentSeries.map((value, index) => {\r\n return {\r\n name: this.getUniqueId(value.code!, index),\r\n type: \"line\",\r\n sampling: D2ChartPanel.SAMPLING_MODE,\r\n symbol: \"none\",\r\n step: \"end\",\r\n color: optionColors[value.colorIndex !== undefined ? value.colorIndex : index % optionColors.length],\r\n encode: {\r\n x: \"timestamp\",\r\n y: this.getUniqueId(value.code!, index)\r\n },\r\n areaStyle: value.fillColor ? {} : undefined,\r\n lineStyle: {type: value.lineStyle ?? LineStyleEnum.SOLID}\r\n }\r\n })\r\n }\r\n\r\n private getTableItems(currentSeries: D2ChartSeriesItem[], seriesFields: string[], optionColors: string[]): D2ChartTableItem[] {\r\n return currentSeries.map((series, index) => {\r\n const recordValues = this.props.d2ChartRecords.map(value => at(value, seriesFields[index])[0]).filter(value => value !== undefined) as number[];\r\n const uniqueId = this.getUniqueId(series.code!, index);\r\n const [min, max, sum] = recordValues.reduce(([min, max, sum], val) =>\r\n [Math.min(min, val), Math.max(max, val), sum + val],\r\n [Number.POSITIVE_INFINITY, Number.NEGATIVE_INFINITY, 0]\r\n );\r\n\r\n return {\r\n id: uniqueId,\r\n displayName: series.name!,\r\n color: optionColors[series.colorIndex !== undefined ? series.colorIndex : index % optionColors.length],\r\n visible: this.state.tableItems.find(value => value.id === uniqueId)?.visible ?? true,\r\n min: recordValues.length === 0 ? undefined : min,\r\n max: recordValues.length === 0 ? undefined : max,\r\n avg: recordValues.length === 0 ? undefined : sum / recordValues.length,\r\n sum: sum,\r\n }\r\n });\r\n }\r\n\r\n private getDatasetSource(seriesFields: string[]): (number | undefined)[][] {\r\n return this.props.d2ChartRecords.map(record => {\r\n const seriesValuesInTime: (number | undefined | null)[] = at(record, seriesFields);\r\n const roundedSeriesValues = seriesValuesInTime.map(value => value !== undefined && value !== null ? +value.toFixed(4) : undefined) as (number | undefined)[];\r\n roundedSeriesValues.unshift(record.date.getTime());\r\n\r\n return roundedSeriesValues;\r\n })\r\n }\r\n\r\n onReload() {\r\n const tableItems: D2ChartTableItem[] = [];\r\n let missingData: MarkAreaData[][] = [];\r\n\r\n const option = this.chartInstance?.getOption() as EChartsOption | undefined | null;\r\n if (option) {\r\n const currentSeries = this.props.d2ChartSeries;\r\n const seriesFields = this.getSeriesFields(currentSeries);\r\n const series = this.getSeries(currentSeries, option.color);\r\n const dataset: { dimensions: string[], source: (number | undefined)[][] } = {\r\n dimensions: [\"timestamp\", ...this.getDiemnsions(currentSeries)],\r\n source: this.getDatasetSource(seriesFields),\r\n }\r\n tableItems.push(...this.getTableItems(currentSeries, seriesFields, option.color));\r\n\r\n this.setTooltip(option);\r\n\r\n // chart markArea\r\n if (this.props.markArea) {\r\n series.push({\r\n name: \"__markArea\",\r\n type: \"line\",\r\n sampling: D2ChartPanel.SAMPLING_MODE,\r\n markArea: this.props.markArea,\r\n encode: {\r\n x: \"timestamp\",\r\n y: \"__markArea\",\r\n },\r\n });\r\n\r\n dataset.dimensions.push(\"__markArea\");\r\n }\r\n\r\n //calendar markArea\r\n if (this.state.calendarDataVisible) {\r\n this.prepareCalendarMarkarea(series, dataset);\r\n }\r\n\r\n // missing data markArea\r\n const missingDataMarkArea = D2ChartUtils.getMissingDataMarkArea(this.props.d2ChartRecords, seriesFields);\r\n missingData = missingDataMarkArea.data;\r\n series.push({\r\n name: \"__markArea-missing-data\",\r\n type: \"line\",\r\n sampling: D2ChartPanel.SAMPLING_MODE,\r\n markArea: missingDataMarkArea,\r\n encode: {\r\n x: \"timestamp\",\r\n y: \"__markArea-missing-data\",\r\n },\r\n });\r\n\r\n dataset.dimensions.push(\"__markArea-missing-data\");\r\n\r\n option.dataset = dataset;\r\n option.series = series;\r\n option.markArea = undefined;\r\n option.legend[0].selected = Object.fromEntries(tableItems.map(value => [value.id, value.visible]));\r\n\r\n if (this.props.yAxisLabel) {\r\n option.yAxis[0].name = this.props.yAxisLabel;\r\n }\r\n\r\n this.chartInstance.setOption(option, true);\r\n }\r\n\r\n this.setState({\r\n tableItems: tableItems,\r\n missingData: missingData,\r\n });\r\n }\r\n\r\n resize() {\r\n this.chartInstance?.resize();\r\n }\r\n\r\n private renderToolbox() {\r\n return (\r\n <D2ChartToolboxPanel\r\n missingData={this.state.missingData}\r\n calendarDataVisible={this.state.calendarDataVisible}\r\n missingDataVisible={this.state.missingDataVisible}\r\n showCalendarIcon={!!this.props.d2ChartCalendarRecords}\r\n onSwitchCalendarData={() => {\r\n this.setState({calendarDataVisible: !this.state.calendarDataVisible}, () => {\r\n this.onSwitchCalendarData();\r\n })\r\n }}\r\n onSwitchMissingData={() => {\r\n this.setState({missingDataVisible: !this.state.missingDataVisible}, () => {\r\n this.onSwitchMissingData();\r\n })\r\n }}\r\n onZoomControlSwitch={zoomEnabled => {\r\n this.chartInstance.dispatchAction({\r\n type: \"takeGlobalCursor\",\r\n key: \"dataZoomSelect\",\r\n dataZoomSelectActive: zoomEnabled\r\n });\r\n }}\r\n onZoomReset={() => {\r\n this.chartInstance.dispatchAction({\r\n type: \"dataZoom\",\r\n start: 0,\r\n end: 100,\r\n });\r\n }}\r\n compact={this.props.compact}\r\n onFullScreen={() => {\r\n this.setState({modalVisible: true}, () => {\r\n setTimeout(() => this.d2ChartPanelInModal?.onReload());\r\n setTimeout(() => this.d2ChartPanelInModal?.resize());\r\n })\r\n }}\r\n />\r\n )\r\n }\r\n\r\n private renderModalDialog() {\r\n return (\r\n <ModalDialog\r\n mode={ModalDialogMode.NO_BUTTONS}\r\n open={this.state.modalVisible}\r\n onCancel={() => this.setState({modalVisible: false})}\r\n title={i18n(\"Chart\")}\r\n initialWidth={window.innerWidth * 0.8}\r\n initialHeight={window.innerHeight * 0.98}\r\n >\r\n <D2ChartPanel\r\n ref={component => {\r\n this.d2ChartPanelInModal = component;\r\n }}\r\n d2ChartSeries={this.props.d2ChartSeries}\r\n d2ChartRecords={this.props.d2ChartRecords}\r\n d2ChartCalendarRecords={this.props.d2ChartCalendarRecords}\r\n loading={this.props.loading}\r\n tableHeight={180}\r\n tableWrapperStyle={{padding: \"0px 12px 8px\"}}\r\n markArea={this.props.markArea}\r\n />\r\n </ModalDialog>\r\n )\r\n }\r\n\r\n render() {\r\n const style: React.CSSProperties = {\r\n height: \"100%\",\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n justifyContent: \"center\",\r\n }\r\n\r\n if (this.props.loading) {\r\n return (\r\n <div style={{alignItems: \"center\", ...style}}>\r\n <LoadingOutlined/>\r\n </div>\r\n );\r\n } else if (this.props.d2ChartRecords.length === 0) {\r\n return (\r\n <Empty\r\n style={style}\r\n description={i18n(\"No records found.\")}\r\n imageStyle={{height: \"8vh\"}}\r\n />\r\n );\r\n } else {\r\n let computedTableHeight = this.props.tableHeight;\r\n if (computedTableHeight === \"auto\") {\r\n computedTableHeight = 62 + this.props.d2ChartSeries.length * 28;\r\n }\r\n\r\n return (\r\n <div style={{position: \"relative\", ...style}}>\r\n {this.renderModalDialog()}\r\n {this.renderToolbox()}\r\n <ReactEcharts\r\n style={{height: `calc(100% - ${computedTableHeight}px)`}}\r\n onChartReady={instance => {\r\n this.chartInstance = instance;\r\n const zr = instance.getZr();\r\n zr.on(\"mouseout\", () => {\r\n const tableItems = this.state.tableItems;\r\n tableItems.forEach(value => value.tooltipValue = undefined);\r\n this.setState({tableItems: tableItems, tooltipTime: undefined}, () => {\r\n this.d2ChartTablePanel?.updateGrid();\r\n });\r\n });\r\n }}\r\n option={this.props.compact ? compactChartOptions : d2ChartOptions}\r\n />\r\n <D2ChartTablePanel\r\n style={{height: computedTableHeight, ...this.props.tableWrapperStyle}}\r\n ref={component => this.d2ChartTablePanel = component}\r\n tableItems={this.state.tableItems}\r\n tooltipTime={this.state.tooltipTime}\r\n onSwitchLegend={this.onSwitchLegend}\r\n />\r\n </div>\r\n )\r\n }\r\n }\r\n}"]}
@@ -0,0 +1,31 @@
1
+ import React from "react";
2
+ import { DataGridColDef } from "d2coreui/components/grid/dataGrid";
3
+ import { UnixTime } from "d2jsapi";
4
+ export interface D2ChartTableItem {
5
+ id: string;
6
+ displayName: string;
7
+ color: string;
8
+ visible: boolean;
9
+ min?: number;
10
+ max?: number;
11
+ sum?: number;
12
+ avg?: number;
13
+ tooltipValue?: number;
14
+ }
15
+ interface Props {
16
+ tableItems: D2ChartTableItem[];
17
+ tooltipTime?: UnixTime;
18
+ style?: React.CSSProperties;
19
+ onSwitchLegend(name: string): void;
20
+ }
21
+ interface State {
22
+ }
23
+ export default class D2ChartTablePanel extends React.Component<Props, State> {
24
+ private initialColumnDefs?;
25
+ private gridApi?;
26
+ constructor(props: Readonly<Props>);
27
+ updateGrid(): void;
28
+ getInitialColumnDefs(): DataGridColDef[];
29
+ render(): React.JSX.Element;
30
+ }
31
+ export {};
@@ -0,0 +1,121 @@
1
+ import React from "react";
2
+ import DataGrid from "d2coreui/components/grid/dataGrid";
3
+ import i18n from "d2core/i18n/i18n";
4
+ import { DateTimeUtils } from "d2core/utils/dateTimeUtils";
5
+ import { LocaleHolder } from "d2core/i18n/localeHolder";
6
+ export default class D2ChartTablePanel extends React.Component {
7
+ constructor(props) {
8
+ super(props);
9
+ }
10
+ updateGrid() {
11
+ this.gridApi?.applyTransaction({ update: this.props.tableItems });
12
+ const columnDefs = this.gridApi?.getColumnDefs();
13
+ if (columnDefs) {
14
+ const columnDefinition = columnDefs.find(value => value.colId === "tooltipValue");
15
+ if (columnDefinition) {
16
+ if (this.props.tooltipTime) {
17
+ columnDefinition.headerName = DateTimeUtils.fromUnixTime(this.props.tooltipTime / 1000).format(LocaleHolder.getDateTimeFormat(true, true, false));
18
+ }
19
+ else {
20
+ columnDefinition.headerName = i18n("Value");
21
+ }
22
+ }
23
+ this.gridApi?.updateGridOptions({ columnDefs: columnDefs });
24
+ }
25
+ }
26
+ getInitialColumnDefs() {
27
+ if (!this.initialColumnDefs) {
28
+ this.initialColumnDefs = [
29
+ {
30
+ headerName: "",
31
+ colId: "visible",
32
+ field: "visible",
33
+ minWidth: 48,
34
+ maxWidth: 48,
35
+ initialWidth: 48,
36
+ cellRenderer: (params) => {
37
+ const data = params.data;
38
+ return (React.createElement("div", { style: {
39
+ width: 22,
40
+ height: 22,
41
+ marginTop: 2,
42
+ backgroundColor: data.color,
43
+ flex: "none",
44
+ cursor: "pointer"
45
+ }, onClick: () => this.props.onSwitchLegend(data.id) }, data.visible &&
46
+ React.createElement("svg", { viewBox: "0 0 22 22", style: { width: 20, height: 20, fill: "white" } },
47
+ React.createElement("path", { d: "M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z" }))));
48
+ },
49
+ group: i18n("Basic Columns")
50
+ },
51
+ {
52
+ headerName: i18n("Title"),
53
+ colId: "title",
54
+ field: "displayName",
55
+ initialWidth: 240,
56
+ group: i18n("Basic Columns"),
57
+ },
58
+ {
59
+ headerName: i18n("Value"),
60
+ colId: "tooltipValue",
61
+ field: "tooltipValue",
62
+ initialWidth: 154,
63
+ type: ["numberColumn", "alignRight"],
64
+ enableCellChangeFlash: true,
65
+ group: i18n("Basic Columns"),
66
+ },
67
+ {
68
+ headerName: i18n("Min"),
69
+ colId: "min",
70
+ field: "min",
71
+ initialWidth: 120,
72
+ type: ["numberColumn", "alignRight"],
73
+ group: i18n("Basic Columns"),
74
+ },
75
+ {
76
+ headerName: i18n("Max"),
77
+ colId: "max",
78
+ field: "max",
79
+ initialWidth: 120,
80
+ type: ["numberColumn", "alignRight"],
81
+ group: i18n("Basic Columns"),
82
+ },
83
+ {
84
+ headerName: i18n("Sum"),
85
+ colId: "sum",
86
+ field: "sum",
87
+ initialWidth: 120,
88
+ type: ["numberColumn", "alignRight"],
89
+ group: i18n("Basic Columns"),
90
+ },
91
+ {
92
+ headerName: i18n("Avg"),
93
+ colId: "avg",
94
+ field: "avg",
95
+ initialWidth: 120,
96
+ type: ["numberColumn", "alignRight"],
97
+ group: i18n("Basic Columns"),
98
+ },
99
+ ];
100
+ }
101
+ return this.initialColumnDefs;
102
+ }
103
+ render() {
104
+ return (React.createElement("div", { style: this.props.style },
105
+ React.createElement(DataGrid, { onGridReady: (params) => {
106
+ this.gridApi = params.api;
107
+ }, paging: { pageSize: -1 }, columnDefs: this.getInitialColumnDefs(), onLoadData: callback => {
108
+ callback(this.props.tableItems.length);
109
+ }, toolbar: {
110
+ renderToolbar: () => React.createElement(React.Fragment, null),
111
+ hideRecordCount: true
112
+ }, rowData: this.props.tableItems, panelStyle: { padding: 0 }, tablePanelStyle: { marginTop: 8 }, noRecordsOverlayRenderer: () => React.createElement("div", null), isRowSelectable: () => false, getRowStyle: (params) => {
113
+ const data = params.node.data;
114
+ if (!data.visible) {
115
+ return { background: "#ddd" };
116
+ }
117
+ return;
118
+ } })));
119
+ }
120
+ }
121
+ //# sourceMappingURL=d2ChartTablePanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"d2ChartTablePanel.js","sourceRoot":"","sources":["../../../../../coreui/components/d2Chart/d2ChartTablePanel.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from \"react\";\r\nimport DataGrid, {DataGridColDef} from \"d2coreui/components/grid/dataGrid\";\r\nimport i18n from \"d2core/i18n/i18n\";\r\nimport {ColDef, GridApi, GridReadyEvent} from \"ag-grid-community\";\r\nimport {DateTimeUtils} from \"d2core/utils/dateTimeUtils\";\r\nimport {LocaleHolder} from \"d2core/i18n/localeHolder\";\r\nimport {UnixTime} from \"d2jsapi\";\r\n\r\nexport interface D2ChartTableItem {\r\n id: string\r\n displayName: string\r\n color: string\r\n visible: boolean\r\n\r\n min?: number\r\n max?: number\r\n sum?: number\r\n avg?: number\r\n\r\n tooltipValue?: number\r\n}\r\n\r\ninterface Props {\r\n tableItems: D2ChartTableItem[]\r\n tooltipTime?: UnixTime\r\n\r\n style?: React.CSSProperties\r\n\r\n onSwitchLegend(name: string): void\r\n}\r\n\r\ninterface State {\r\n}\r\n\r\nexport default class D2ChartTablePanel extends React.Component<Props, State> {\r\n private initialColumnDefs?: DataGridColDef[];\r\n private gridApi?: GridApi;\r\n\r\n constructor(props: Readonly<Props>) {\r\n super(props);\r\n }\r\n\r\n updateGrid() {\r\n this.gridApi?.applyTransaction({update: this.props.tableItems});\r\n\r\n const columnDefs = this.gridApi?.getColumnDefs() as ColDef[] | undefined;\r\n if (columnDefs) {\r\n const columnDefinition = columnDefs.find(value => value.colId === \"tooltipValue\");\r\n if (columnDefinition) {\r\n if (this.props.tooltipTime) {\r\n columnDefinition.headerName = DateTimeUtils.fromUnixTime(this.props.tooltipTime / 1000).format(LocaleHolder.getDateTimeFormat(true, true, false));\r\n } else {\r\n columnDefinition.headerName = i18n(\"Value\");\r\n }\r\n }\r\n this.gridApi?.updateGridOptions({columnDefs: columnDefs});\r\n }\r\n }\r\n\r\n getInitialColumnDefs(): DataGridColDef[] {\r\n if (!this.initialColumnDefs) {\r\n this.initialColumnDefs = [\r\n {\r\n headerName: \"\",\r\n colId: \"visible\",\r\n field: \"visible\",\r\n minWidth: 48,\r\n maxWidth: 48,\r\n initialWidth: 48,\r\n cellRenderer: (params: any) => {\r\n const data = params.data as D2ChartTableItem;\r\n\r\n return (\r\n <div\r\n style={{\r\n width: 22,\r\n height: 22,\r\n marginTop: 2,\r\n backgroundColor: data.color,\r\n flex: \"none\",\r\n cursor: \"pointer\"\r\n }}\r\n onClick={() => this.props.onSwitchLegend(data.id)}\r\n >\r\n {data.visible &&\r\n <svg viewBox=\"0 0 22 22\" style={{width: 20, height: 20, fill: \"white\"}}>\r\n <path d=\"M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z\"/>\r\n </svg>\r\n }\r\n </div>\r\n );\r\n },\r\n group: i18n(\"Basic Columns\")\r\n },\r\n {\r\n headerName: i18n(\"Title\"),\r\n colId: \"title\",\r\n field: \"displayName\",\r\n initialWidth: 240,\r\n group: i18n(\"Basic Columns\"),\r\n },\r\n {\r\n headerName: i18n(\"Value\"),\r\n colId: \"tooltipValue\",\r\n field: \"tooltipValue\",\r\n initialWidth: 154,\r\n type: [\"numberColumn\", \"alignRight\"],\r\n enableCellChangeFlash: true,\r\n group: i18n(\"Basic Columns\"),\r\n },\r\n {\r\n headerName: i18n(\"Min\"),\r\n colId: \"min\",\r\n field: \"min\",\r\n initialWidth: 120,\r\n type: [\"numberColumn\", \"alignRight\"],\r\n group: i18n(\"Basic Columns\"),\r\n },\r\n {\r\n headerName: i18n(\"Max\"),\r\n colId: \"max\",\r\n field: \"max\",\r\n initialWidth: 120,\r\n type: [\"numberColumn\", \"alignRight\"],\r\n group: i18n(\"Basic Columns\"),\r\n },\r\n {\r\n headerName: i18n(\"Sum\"),\r\n colId: \"sum\",\r\n field: \"sum\",\r\n initialWidth: 120,\r\n type: [\"numberColumn\", \"alignRight\"],\r\n group: i18n(\"Basic Columns\"),\r\n },\r\n {\r\n headerName: i18n(\"Avg\"),\r\n colId: \"avg\",\r\n field: \"avg\",\r\n initialWidth: 120,\r\n type: [\"numberColumn\", \"alignRight\"],\r\n group: i18n(\"Basic Columns\"),\r\n },\r\n ]\r\n }\r\n\r\n return this.initialColumnDefs;\r\n }\r\n\r\n render() {\r\n return (\r\n <div style={this.props.style}>\r\n <DataGrid\r\n onGridReady={(params: GridReadyEvent) => {\r\n this.gridApi = params.api;\r\n }}\r\n paging={{pageSize: -1}}\r\n columnDefs={this.getInitialColumnDefs()}\r\n onLoadData={callback => {\r\n callback(this.props.tableItems.length);\r\n }}\r\n toolbar={{\r\n renderToolbar: () => <></>,\r\n hideRecordCount: true\r\n }}\r\n rowData={this.props.tableItems}\r\n panelStyle={{padding: 0}}\r\n tablePanelStyle={{marginTop: 8}}\r\n noRecordsOverlayRenderer={() => <div/>}\r\n isRowSelectable={() => false}\r\n getRowStyle={(params: any) => {\r\n const data = params.node.data as D2ChartTableItem;\r\n if (!data.visible) {\r\n return {background: \"#ddd\"}\r\n }\r\n return;\r\n }}\r\n />\r\n </div>\r\n );\r\n }\r\n\r\n}"]}
@@ -0,0 +1,27 @@
1
+ import React from "react";
2
+ import { MarkAreaData } from "../../../api/types/d2ChartTypes";
3
+ interface ChartToolboxPanelProps {
4
+ missingData: MarkAreaData[][];
5
+ calendarDataVisible?: boolean;
6
+ missingDataVisible?: boolean;
7
+ showCalendarIcon?: boolean;
8
+ compact?: boolean;
9
+ onZoomControlSwitch(zoomEnabled: boolean): void;
10
+ onZoomReset(): void;
11
+ onFullScreen?(): void;
12
+ onSwitchCalendarData?(): void;
13
+ onSwitchMissingData?(): void;
14
+ }
15
+ interface ChartToolboxPanelState {
16
+ zoomEnabled: boolean;
17
+ }
18
+ export default class D2ChartToolboxPanel extends React.Component<ChartToolboxPanelProps, ChartToolboxPanelState> {
19
+ constructor(props: Readonly<ChartToolboxPanelProps>);
20
+ private renderZoomInIcon;
21
+ private renderZoomOutIcon;
22
+ private renderMissingDataIcon;
23
+ private renderFullScreenIcon;
24
+ private renderCalendarIcon;
25
+ render(): React.JSX.Element;
26
+ }
27
+ export {};