@perses-dev/components 0.0.0-snapshot-time-range-height-80d08fc

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 (481) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +18 -0
  3. package/dist/DateTimeRangePicker/AbsoluteTimePicker.d.ts +9 -0
  4. package/dist/DateTimeRangePicker/AbsoluteTimePicker.d.ts.map +1 -0
  5. package/dist/DateTimeRangePicker/AbsoluteTimePicker.js +181 -0
  6. package/dist/DateTimeRangePicker/AbsoluteTimePicker.js.map +1 -0
  7. package/dist/DateTimeRangePicker/DateTimeRangePicker.d.ts +12 -0
  8. package/dist/DateTimeRangePicker/DateTimeRangePicker.d.ts.map +1 -0
  9. package/dist/DateTimeRangePicker/DateTimeRangePicker.js +79 -0
  10. package/dist/DateTimeRangePicker/DateTimeRangePicker.js.map +1 -0
  11. package/dist/DateTimeRangePicker/TimeRangeSelector.d.ts +17 -0
  12. package/dist/DateTimeRangePicker/TimeRangeSelector.d.ts.map +1 -0
  13. package/dist/DateTimeRangePicker/TimeRangeSelector.js +58 -0
  14. package/dist/DateTimeRangePicker/TimeRangeSelector.js.map +1 -0
  15. package/dist/DateTimeRangePicker/index.d.ts +4 -0
  16. package/dist/DateTimeRangePicker/index.d.ts.map +1 -0
  17. package/dist/DateTimeRangePicker/index.js +17 -0
  18. package/dist/DateTimeRangePicker/index.js.map +1 -0
  19. package/dist/DateTimeRangePicker/utils.d.ts +7 -0
  20. package/dist/DateTimeRangePicker/utils.d.ts.map +1 -0
  21. package/dist/DateTimeRangePicker/utils.js +37 -0
  22. package/dist/DateTimeRangePicker/utils.js.map +1 -0
  23. package/dist/Drawer/Drawer.d.ts +9 -0
  24. package/dist/Drawer/Drawer.d.ts.map +1 -0
  25. package/dist/Drawer/Drawer.js +34 -0
  26. package/dist/Drawer/Drawer.js.map +1 -0
  27. package/dist/Drawer/index.d.ts +2 -0
  28. package/dist/Drawer/index.d.ts.map +1 -0
  29. package/dist/Drawer/index.js +15 -0
  30. package/dist/Drawer/index.js.map +1 -0
  31. package/dist/EChart.d.ts +61 -0
  32. package/dist/EChart.d.ts.map +1 -0
  33. package/dist/EChart.js +143 -0
  34. package/dist/EChart.js.map +1 -0
  35. package/dist/ErrorAlert.d.ts +9 -0
  36. package/dist/ErrorAlert.d.ts.map +1 -0
  37. package/dist/ErrorAlert.js +25 -0
  38. package/dist/ErrorAlert.js.map +1 -0
  39. package/dist/ErrorBoundary.d.ts +3 -0
  40. package/dist/ErrorBoundary.d.ts.map +1 -0
  41. package/dist/ErrorBoundary.js +16 -0
  42. package/dist/ErrorBoundary.js.map +1 -0
  43. package/dist/GaugeChart/GaugeChart.d.ts +15 -0
  44. package/dist/GaugeChart/GaugeChart.d.ts.map +1 -0
  45. package/dist/GaugeChart/GaugeChart.js +172 -0
  46. package/dist/GaugeChart/GaugeChart.js.map +1 -0
  47. package/dist/GaugeChart/index.d.ts +2 -0
  48. package/dist/GaugeChart/index.d.ts.map +1 -0
  49. package/dist/GaugeChart/index.js +15 -0
  50. package/dist/GaugeChart/index.js.map +1 -0
  51. package/dist/InfoTooltip/InfoTooltip.d.ts +17 -0
  52. package/dist/InfoTooltip/InfoTooltip.d.ts.map +1 -0
  53. package/dist/InfoTooltip/InfoTooltip.js +76 -0
  54. package/dist/InfoTooltip/InfoTooltip.js.map +1 -0
  55. package/dist/InfoTooltip/InfoTooltip.test.d.ts +2 -0
  56. package/dist/InfoTooltip/InfoTooltip.test.d.ts.map +1 -0
  57. package/dist/InfoTooltip/InfoTooltip.test.js +36 -0
  58. package/dist/InfoTooltip/InfoTooltip.test.js.map +1 -0
  59. package/dist/InfoTooltip/index.d.ts +2 -0
  60. package/dist/InfoTooltip/index.d.ts.map +1 -0
  61. package/dist/InfoTooltip/index.js +15 -0
  62. package/dist/InfoTooltip/index.js.map +1 -0
  63. package/dist/JSONEditor.d.ts +8 -0
  64. package/dist/JSONEditor.d.ts.map +1 -0
  65. package/dist/JSONEditor.js +51 -0
  66. package/dist/JSONEditor.js.map +1 -0
  67. package/dist/Legend/CompactLegend.d.ts +13 -0
  68. package/dist/Legend/CompactLegend.d.ts.map +1 -0
  69. package/dist/Legend/CompactLegend.js +45 -0
  70. package/dist/Legend/CompactLegend.js.map +1 -0
  71. package/dist/Legend/Legend.d.ts +11 -0
  72. package/dist/Legend/Legend.d.ts.map +1 -0
  73. package/dist/Legend/Legend.js +39 -0
  74. package/dist/Legend/Legend.js.map +1 -0
  75. package/dist/Legend/LegendColorBadge.d.ts +7 -0
  76. package/dist/Legend/LegendColorBadge.d.ts.map +1 -0
  77. package/dist/Legend/LegendColorBadge.js +31 -0
  78. package/dist/Legend/LegendColorBadge.js.map +1 -0
  79. package/dist/Legend/ListLegend.d.ts +11 -0
  80. package/dist/Legend/ListLegend.d.ts.map +1 -0
  81. package/dist/Legend/ListLegend.js +40 -0
  82. package/dist/Legend/ListLegend.js.map +1 -0
  83. package/dist/Legend/ListLegendItem.d.ts +9 -0
  84. package/dist/Legend/ListLegendItem.d.ts.map +1 -0
  85. package/dist/Legend/ListLegendItem.js +47 -0
  86. package/dist/Legend/ListLegendItem.js.map +1 -0
  87. package/dist/Legend/index.d.ts +2 -0
  88. package/dist/Legend/index.d.ts.map +1 -0
  89. package/dist/Legend/index.js +15 -0
  90. package/dist/Legend/index.js.map +1 -0
  91. package/dist/LineChart/LineChart.d.ts +19 -0
  92. package/dist/LineChart/LineChart.d.ts.map +1 -0
  93. package/dist/LineChart/LineChart.js +189 -0
  94. package/dist/LineChart/LineChart.js.map +1 -0
  95. package/dist/LineChart/index.d.ts +3 -0
  96. package/dist/LineChart/index.d.ts.map +1 -0
  97. package/dist/LineChart/index.js +15 -0
  98. package/dist/LineChart/index.js.map +1 -0
  99. package/dist/LineChart/utils.d.ts +30 -0
  100. package/dist/LineChart/utils.d.ts.map +1 -0
  101. package/dist/LineChart/utils.js +90 -0
  102. package/dist/LineChart/utils.js.map +1 -0
  103. package/dist/OptionsEditorLayout/OptionsEditorColumn.d.ts +13 -0
  104. package/dist/OptionsEditorLayout/OptionsEditorColumn.d.ts.map +1 -0
  105. package/dist/OptionsEditorLayout/OptionsEditorColumn.js +28 -0
  106. package/dist/OptionsEditorLayout/OptionsEditorColumn.js.map +1 -0
  107. package/dist/OptionsEditorLayout/OptionsEditorControl.d.ts +5 -0
  108. package/dist/OptionsEditorLayout/OptionsEditorControl.d.ts.map +1 -0
  109. package/dist/OptionsEditorLayout/OptionsEditorControl.js +50 -0
  110. package/dist/OptionsEditorLayout/OptionsEditorControl.js.map +1 -0
  111. package/dist/OptionsEditorLayout/OptionsEditorGrid.d.ts +13 -0
  112. package/dist/OptionsEditorLayout/OptionsEditorGrid.d.ts.map +1 -0
  113. package/dist/OptionsEditorLayout/OptionsEditorGrid.js +26 -0
  114. package/dist/OptionsEditorLayout/OptionsEditorGrid.js.map +1 -0
  115. package/dist/OptionsEditorLayout/OptionsEditorGroup.d.ts +13 -0
  116. package/dist/OptionsEditorLayout/OptionsEditorGroup.d.ts.map +1 -0
  117. package/dist/OptionsEditorLayout/OptionsEditorGroup.js +36 -0
  118. package/dist/OptionsEditorLayout/OptionsEditorGroup.js.map +1 -0
  119. package/dist/OptionsEditorLayout/index.d.ts +5 -0
  120. package/dist/OptionsEditorLayout/index.d.ts.map +1 -0
  121. package/dist/OptionsEditorLayout/index.js +18 -0
  122. package/dist/OptionsEditorLayout/index.js.map +1 -0
  123. package/dist/StatChart/StatChart.d.ts +19 -0
  124. package/dist/StatChart/StatChart.d.ts.map +1 -0
  125. package/dist/StatChart/StatChart.js +121 -0
  126. package/dist/StatChart/StatChart.js.map +1 -0
  127. package/dist/StatChart/StatChart.test.d.ts +2 -0
  128. package/dist/StatChart/StatChart.test.d.ts.map +1 -0
  129. package/dist/StatChart/StatChart.test.js +87 -0
  130. package/dist/StatChart/StatChart.test.js.map +1 -0
  131. package/dist/StatChart/index.d.ts +2 -0
  132. package/dist/StatChart/index.d.ts.map +1 -0
  133. package/dist/StatChart/index.js +15 -0
  134. package/dist/StatChart/index.js.map +1 -0
  135. package/dist/Tooltip/SeriesInfo.d.ts +12 -0
  136. package/dist/Tooltip/SeriesInfo.d.ts.map +1 -0
  137. package/dist/Tooltip/SeriesInfo.js +143 -0
  138. package/dist/Tooltip/SeriesInfo.js.map +1 -0
  139. package/dist/Tooltip/SeriesMarker.d.ts +7 -0
  140. package/dist/Tooltip/SeriesMarker.d.ts.map +1 -0
  141. package/dist/Tooltip/SeriesMarker.js +33 -0
  142. package/dist/Tooltip/SeriesMarker.js.map +1 -0
  143. package/dist/Tooltip/Tooltip.d.ts +13 -0
  144. package/dist/Tooltip/Tooltip.d.ts.map +1 -0
  145. package/dist/Tooltip/Tooltip.js +72 -0
  146. package/dist/Tooltip/Tooltip.js.map +1 -0
  147. package/dist/Tooltip/TooltipContent.d.ts +9 -0
  148. package/dist/Tooltip/TooltipContent.d.ts.map +1 -0
  149. package/dist/Tooltip/TooltipContent.js +89 -0
  150. package/dist/Tooltip/TooltipContent.js.map +1 -0
  151. package/dist/Tooltip/focused-series.d.ts +25 -0
  152. package/dist/Tooltip/focused-series.d.ts.map +1 -0
  153. package/dist/Tooltip/focused-series.js +111 -0
  154. package/dist/Tooltip/focused-series.js.map +1 -0
  155. package/dist/Tooltip/focused-series.test.d.ts +2 -0
  156. package/dist/Tooltip/focused-series.test.d.ts.map +1 -0
  157. package/dist/Tooltip/focused-series.test.js +93 -0
  158. package/dist/Tooltip/focused-series.test.js.map +1 -0
  159. package/dist/Tooltip/index.d.ts +3 -0
  160. package/dist/Tooltip/index.d.ts.map +1 -0
  161. package/dist/Tooltip/index.js +16 -0
  162. package/dist/Tooltip/index.js.map +1 -0
  163. package/dist/Tooltip/tooltip-model.d.ts +79 -0
  164. package/dist/Tooltip/tooltip-model.d.ts.map +1 -0
  165. package/dist/Tooltip/tooltip-model.js +80 -0
  166. package/dist/Tooltip/tooltip-model.js.map +1 -0
  167. package/dist/Tooltip/utils.d.ts +6 -0
  168. package/dist/Tooltip/utils.d.ts.map +1 -0
  169. package/dist/Tooltip/utils.js +46 -0
  170. package/dist/Tooltip/utils.js.map +1 -0
  171. package/dist/UnitSelector/UnitSelector.d.ts +8 -0
  172. package/dist/UnitSelector/UnitSelector.d.ts.map +1 -0
  173. package/dist/UnitSelector/UnitSelector.js +112 -0
  174. package/dist/UnitSelector/UnitSelector.js.map +1 -0
  175. package/dist/UnitSelector/UnitSelector.test.d.ts +2 -0
  176. package/dist/UnitSelector/UnitSelector.test.d.ts.map +1 -0
  177. package/dist/UnitSelector/UnitSelector.test.js +205 -0
  178. package/dist/UnitSelector/UnitSelector.test.js.map +1 -0
  179. package/dist/UnitSelector/index.d.ts +2 -0
  180. package/dist/UnitSelector/index.d.ts.map +1 -0
  181. package/dist/UnitSelector/index.js +15 -0
  182. package/dist/UnitSelector/index.js.map +1 -0
  183. package/dist/YAxisLabel.d.ts +8 -0
  184. package/dist/YAxisLabel.d.ts.map +1 -0
  185. package/dist/YAxisLabel.js +39 -0
  186. package/dist/YAxisLabel.js.map +1 -0
  187. package/dist/cjs/DateTimeRangePicker/AbsoluteTimePicker.js +187 -0
  188. package/dist/cjs/DateTimeRangePicker/DateTimeRangePicker.js +85 -0
  189. package/dist/cjs/DateTimeRangePicker/TimeRangeSelector.js +69 -0
  190. package/dist/cjs/DateTimeRangePicker/index.js +30 -0
  191. package/dist/cjs/DateTimeRangePicker/utils.js +45 -0
  192. package/dist/cjs/Drawer/Drawer.js +40 -0
  193. package/dist/cjs/Drawer/index.js +28 -0
  194. package/dist/cjs/EChart.js +188 -0
  195. package/dist/cjs/ErrorAlert.js +29 -0
  196. package/dist/cjs/ErrorBoundary.js +22 -0
  197. package/dist/cjs/GaugeChart/GaugeChart.js +178 -0
  198. package/dist/cjs/GaugeChart/index.js +28 -0
  199. package/dist/cjs/InfoTooltip/InfoTooltip.js +93 -0
  200. package/dist/cjs/InfoTooltip/InfoTooltip.test.js +43 -0
  201. package/dist/cjs/InfoTooltip/index.js +28 -0
  202. package/dist/cjs/JSONEditor.js +57 -0
  203. package/dist/cjs/Legend/CompactLegend.js +48 -0
  204. package/dist/cjs/Legend/Legend.js +45 -0
  205. package/dist/cjs/Legend/LegendColorBadge.js +42 -0
  206. package/dist/cjs/Legend/ListLegend.js +44 -0
  207. package/dist/cjs/Legend/ListLegendItem.js +91 -0
  208. package/dist/cjs/Legend/index.js +28 -0
  209. package/dist/cjs/LineChart/LineChart.js +195 -0
  210. package/dist/cjs/LineChart/index.js +28 -0
  211. package/dist/cjs/LineChart/utils.js +95 -0
  212. package/dist/cjs/OptionsEditorLayout/OptionsEditorColumn.js +32 -0
  213. package/dist/cjs/OptionsEditorLayout/OptionsEditorControl.js +61 -0
  214. package/dist/cjs/OptionsEditorLayout/OptionsEditorGrid.js +29 -0
  215. package/dist/cjs/OptionsEditorLayout/OptionsEditorGroup.js +40 -0
  216. package/dist/cjs/OptionsEditorLayout/index.js +31 -0
  217. package/dist/cjs/StatChart/StatChart.js +165 -0
  218. package/dist/cjs/StatChart/StatChart.test.js +89 -0
  219. package/dist/cjs/StatChart/index.js +28 -0
  220. package/dist/cjs/Tooltip/SeriesInfo.js +149 -0
  221. package/dist/cjs/Tooltip/SeriesMarker.js +39 -0
  222. package/dist/cjs/Tooltip/Tooltip.js +116 -0
  223. package/dist/cjs/Tooltip/TooltipContent.js +95 -0
  224. package/dist/cjs/Tooltip/focused-series.js +117 -0
  225. package/dist/cjs/Tooltip/focused-series.test.js +95 -0
  226. package/dist/cjs/Tooltip/index.js +29 -0
  227. package/dist/cjs/Tooltip/tooltip-model.js +98 -0
  228. package/dist/cjs/Tooltip/utils.js +50 -0
  229. package/dist/cjs/UnitSelector/UnitSelector.js +118 -0
  230. package/dist/cjs/UnitSelector/UnitSelector.test.js +212 -0
  231. package/dist/cjs/UnitSelector/index.js +28 -0
  232. package/dist/cjs/YAxisLabel.js +45 -0
  233. package/dist/cjs/context/ChartsThemeProvider.js +83 -0
  234. package/dist/cjs/context/TimeZoneProvider.js +90 -0
  235. package/dist/cjs/index.js +47 -0
  236. package/dist/cjs/model/graph.js +21 -0
  237. package/dist/cjs/model/index.js +30 -0
  238. package/dist/cjs/model/theme.js +16 -0
  239. package/dist/cjs/model/units/bytes.js +60 -0
  240. package/dist/cjs/model/units/constants.js +23 -0
  241. package/dist/cjs/model/units/decimal.js +67 -0
  242. package/dist/cjs/model/units/index.js +30 -0
  243. package/dist/cjs/model/units/percent.js +64 -0
  244. package/dist/cjs/model/units/time.js +102 -0
  245. package/dist/cjs/model/units/types.js +28 -0
  246. package/dist/cjs/model/units/units.js +104 -0
  247. package/dist/cjs/test/index.js +28 -0
  248. package/dist/cjs/test/render.js +36 -0
  249. package/dist/cjs/test/setup-tests.js +20 -0
  250. package/dist/cjs/test-utils/index.js +28 -0
  251. package/dist/cjs/test-utils/theme.js +28 -0
  252. package/dist/cjs/theme/index.js +28 -0
  253. package/dist/cjs/theme/palette/background.js +40 -0
  254. package/dist/cjs/theme/palette/colors/blue.js +35 -0
  255. package/dist/cjs/theme/palette/colors/common.js +28 -0
  256. package/dist/cjs/theme/palette/colors/green.js +35 -0
  257. package/dist/cjs/theme/palette/colors/grey.js +35 -0
  258. package/dist/cjs/theme/palette/colors/index.js +35 -0
  259. package/dist/cjs/theme/palette/colors/orange.js +35 -0
  260. package/dist/cjs/theme/palette/colors/purple.js +35 -0
  261. package/dist/cjs/theme/palette/colors/red.js +35 -0
  262. package/dist/cjs/theme/palette/colors/types.js +16 -0
  263. package/dist/cjs/theme/palette/error.js +32 -0
  264. package/dist/cjs/theme/palette/grey.js +44 -0
  265. package/dist/cjs/theme/palette/index.js +28 -0
  266. package/dist/cjs/theme/palette/palette-options.js +59 -0
  267. package/dist/cjs/theme/palette/primary.js +32 -0
  268. package/dist/cjs/theme/palette/secondary.js +32 -0
  269. package/dist/cjs/theme/palette/success.js +32 -0
  270. package/dist/cjs/theme/palette/text.js +42 -0
  271. package/dist/cjs/theme/palette/warning.js +32 -0
  272. package/dist/cjs/theme/theme.js +64 -0
  273. package/dist/cjs/theme/types/ThemeExtension.d.js +17 -0
  274. package/dist/cjs/theme/typography.js +96 -0
  275. package/dist/cjs/utils/combine-sx.js +29 -0
  276. package/dist/cjs/utils/component-ids.js +31 -0
  277. package/dist/cjs/utils/format.js +56 -0
  278. package/dist/cjs/utils/format.test.js +47 -0
  279. package/dist/cjs/utils/index.js +31 -0
  280. package/dist/cjs/utils/mathjs.js +25 -0
  281. package/dist/cjs/utils/theme-gen.js +188 -0
  282. package/dist/cjs/utils/theme-gen.test.js +197 -0
  283. package/dist/context/ChartsThemeProvider.d.ts +10 -0
  284. package/dist/context/ChartsThemeProvider.d.ts.map +1 -0
  285. package/dist/context/ChartsThemeProvider.js +31 -0
  286. package/dist/context/ChartsThemeProvider.js.map +1 -0
  287. package/dist/context/TimeZoneProvider.d.ts +13 -0
  288. package/dist/context/TimeZoneProvider.d.ts.map +1 -0
  289. package/dist/context/TimeZoneProvider.js +38 -0
  290. package/dist/context/TimeZoneProvider.js.map +1 -0
  291. package/dist/index.d.ts +21 -0
  292. package/dist/index.d.ts.map +1 -0
  293. package/dist/index.js +34 -0
  294. package/dist/index.js.map +1 -0
  295. package/dist/model/graph.d.ts +34 -0
  296. package/dist/model/graph.d.ts.map +1 -0
  297. package/dist/model/graph.js +16 -0
  298. package/dist/model/graph.js.map +1 -0
  299. package/dist/model/index.d.ts +4 -0
  300. package/dist/model/index.d.ts.map +1 -0
  301. package/dist/model/index.js +17 -0
  302. package/dist/model/index.js.map +1 -0
  303. package/dist/model/theme.d.ts +15 -0
  304. package/dist/model/theme.d.ts.map +1 -0
  305. package/dist/model/theme.js +15 -0
  306. package/dist/model/theme.js.map +1 -0
  307. package/dist/model/units/bytes.d.ts +12 -0
  308. package/dist/model/units/bytes.d.ts.map +1 -0
  309. package/dist/model/units/bytes.js +48 -0
  310. package/dist/model/units/bytes.js.map +1 -0
  311. package/dist/model/units/constants.d.ts +2 -0
  312. package/dist/model/units/constants.d.ts.map +1 -0
  313. package/dist/model/units/constants.js +17 -0
  314. package/dist/model/units/constants.js.map +1 -0
  315. package/dist/model/units/decimal.d.ts +24 -0
  316. package/dist/model/units/decimal.d.ts.map +1 -0
  317. package/dist/model/units/decimal.js +59 -0
  318. package/dist/model/units/decimal.js.map +1 -0
  319. package/dist/model/units/index.d.ts +4 -0
  320. package/dist/model/units/index.d.ts.map +1 -0
  321. package/dist/model/units/index.js +17 -0
  322. package/dist/model/units/index.js.map +1 -0
  323. package/dist/model/units/percent.d.ts +12 -0
  324. package/dist/model/units/percent.d.ts.map +1 -0
  325. package/dist/model/units/percent.js +51 -0
  326. package/dist/model/units/percent.js.map +1 -0
  327. package/dist/model/units/time.d.ts +22 -0
  328. package/dist/model/units/time.d.ts.map +1 -0
  329. package/dist/model/units/time.js +88 -0
  330. package/dist/model/units/time.js.map +1 -0
  331. package/dist/model/units/types.d.ts +38 -0
  332. package/dist/model/units/types.d.ts.map +1 -0
  333. package/dist/model/units/types.js +22 -0
  334. package/dist/model/units/types.js.map +1 -0
  335. package/dist/model/units/units.d.ts +40 -0
  336. package/dist/model/units/units.d.ts.map +1 -0
  337. package/dist/model/units/units.js +83 -0
  338. package/dist/model/units/units.js.map +1 -0
  339. package/dist/test/index.d.ts +2 -0
  340. package/dist/test/index.d.ts.map +1 -0
  341. package/dist/test/index.js +15 -0
  342. package/dist/test/index.js.map +1 -0
  343. package/dist/test/render.d.ts +7 -0
  344. package/dist/test/render.d.ts.map +1 -0
  345. package/dist/test/render.js +32 -0
  346. package/dist/test/render.js.map +1 -0
  347. package/dist/test/setup-tests.d.ts +2 -0
  348. package/dist/test/setup-tests.d.ts.map +1 -0
  349. package/dist/test/setup-tests.js +18 -0
  350. package/dist/test/setup-tests.js.map +1 -0
  351. package/dist/test-utils/index.d.ts +2 -0
  352. package/dist/test-utils/index.d.ts.map +1 -0
  353. package/dist/test-utils/index.js +15 -0
  354. package/dist/test-utils/index.js.map +1 -0
  355. package/dist/test-utils/theme.d.ts +3 -0
  356. package/dist/test-utils/theme.d.ts.map +1 -0
  357. package/dist/test-utils/theme.js +22 -0
  358. package/dist/test-utils/theme.js.map +1 -0
  359. package/dist/theme/index.d.ts +37 -0
  360. package/dist/theme/index.d.ts.map +1 -0
  361. package/dist/theme/index.js +15 -0
  362. package/dist/theme/index.js.map +1 -0
  363. package/dist/theme/palette/background.d.ts +3 -0
  364. package/dist/theme/palette/background.d.ts.map +1 -0
  365. package/dist/theme/palette/background.js +34 -0
  366. package/dist/theme/palette/background.js.map +1 -0
  367. package/dist/theme/palette/colors/blue.d.ts +3 -0
  368. package/dist/theme/palette/colors/blue.d.ts.map +1 -0
  369. package/dist/theme/palette/colors/blue.js +29 -0
  370. package/dist/theme/palette/colors/blue.js.map +1 -0
  371. package/dist/theme/palette/colors/common.d.ts +3 -0
  372. package/dist/theme/palette/colors/common.d.ts.map +1 -0
  373. package/dist/theme/palette/colors/common.js +16 -0
  374. package/dist/theme/palette/colors/common.js.map +1 -0
  375. package/dist/theme/palette/colors/green.d.ts +3 -0
  376. package/dist/theme/palette/colors/green.d.ts.map +1 -0
  377. package/dist/theme/palette/colors/green.js +29 -0
  378. package/dist/theme/palette/colors/green.js.map +1 -0
  379. package/dist/theme/palette/colors/grey.d.ts +3 -0
  380. package/dist/theme/palette/colors/grey.d.ts.map +1 -0
  381. package/dist/theme/palette/colors/grey.js +29 -0
  382. package/dist/theme/palette/colors/grey.js.map +1 -0
  383. package/dist/theme/palette/colors/index.d.ts +9 -0
  384. package/dist/theme/palette/colors/index.d.ts.map +1 -0
  385. package/dist/theme/palette/colors/index.js +22 -0
  386. package/dist/theme/palette/colors/index.js.map +1 -0
  387. package/dist/theme/palette/colors/orange.d.ts +3 -0
  388. package/dist/theme/palette/colors/orange.d.ts.map +1 -0
  389. package/dist/theme/palette/colors/orange.js +29 -0
  390. package/dist/theme/palette/colors/orange.js.map +1 -0
  391. package/dist/theme/palette/colors/purple.d.ts +3 -0
  392. package/dist/theme/palette/colors/purple.d.ts.map +1 -0
  393. package/dist/theme/palette/colors/purple.js +29 -0
  394. package/dist/theme/palette/colors/purple.js.map +1 -0
  395. package/dist/theme/palette/colors/red.d.ts +3 -0
  396. package/dist/theme/palette/colors/red.d.ts.map +1 -0
  397. package/dist/theme/palette/colors/red.js +29 -0
  398. package/dist/theme/palette/colors/red.js.map +1 -0
  399. package/dist/theme/palette/colors/types.d.ts +17 -0
  400. package/dist/theme/palette/colors/types.d.ts.map +1 -0
  401. package/dist/theme/palette/colors/types.js +15 -0
  402. package/dist/theme/palette/colors/types.js.map +1 -0
  403. package/dist/theme/palette/error.d.ts +3 -0
  404. package/dist/theme/palette/error.d.ts.map +1 -0
  405. package/dist/theme/palette/error.js +26 -0
  406. package/dist/theme/palette/error.js.map +1 -0
  407. package/dist/theme/palette/grey.d.ts +3 -0
  408. package/dist/theme/palette/grey.d.ts.map +1 -0
  409. package/dist/theme/palette/grey.js +38 -0
  410. package/dist/theme/palette/grey.js.map +1 -0
  411. package/dist/theme/palette/index.d.ts +3 -0
  412. package/dist/theme/palette/index.d.ts.map +1 -0
  413. package/dist/theme/palette/index.js +15 -0
  414. package/dist/theme/palette/index.js.map +1 -0
  415. package/dist/theme/palette/palette-options.d.ts +6 -0
  416. package/dist/theme/palette/palette-options.d.ts.map +1 -0
  417. package/dist/theme/palette/palette-options.js +55 -0
  418. package/dist/theme/palette/palette-options.js.map +1 -0
  419. package/dist/theme/palette/primary.d.ts +3 -0
  420. package/dist/theme/palette/primary.d.ts.map +1 -0
  421. package/dist/theme/palette/primary.js +26 -0
  422. package/dist/theme/palette/primary.js.map +1 -0
  423. package/dist/theme/palette/secondary.d.ts +3 -0
  424. package/dist/theme/palette/secondary.d.ts.map +1 -0
  425. package/dist/theme/palette/secondary.js +26 -0
  426. package/dist/theme/palette/secondary.js.map +1 -0
  427. package/dist/theme/palette/success.d.ts +3 -0
  428. package/dist/theme/palette/success.d.ts.map +1 -0
  429. package/dist/theme/palette/success.js +26 -0
  430. package/dist/theme/palette/success.js.map +1 -0
  431. package/dist/theme/palette/text.d.ts +3 -0
  432. package/dist/theme/palette/text.d.ts.map +1 -0
  433. package/dist/theme/palette/text.js +36 -0
  434. package/dist/theme/palette/text.js.map +1 -0
  435. package/dist/theme/palette/warning.d.ts +3 -0
  436. package/dist/theme/palette/warning.d.ts.map +1 -0
  437. package/dist/theme/palette/warning.js +26 -0
  438. package/dist/theme/palette/warning.js.map +1 -0
  439. package/dist/theme/theme.d.ts +13 -0
  440. package/dist/theme/theme.d.ts.map +1 -0
  441. package/dist/theme/theme.js +67 -0
  442. package/dist/theme/theme.js.map +1 -0
  443. package/dist/theme/types/ThemeExtension.d.js +16 -0
  444. package/dist/theme/types/ThemeExtension.d.js.map +1 -0
  445. package/dist/theme/typography.d.ts +10 -0
  446. package/dist/theme/typography.d.ts.map +1 -0
  447. package/dist/theme/typography.js +92 -0
  448. package/dist/theme/typography.js.map +1 -0
  449. package/dist/utils/combine-sx.d.ts +8 -0
  450. package/dist/utils/combine-sx.d.ts.map +1 -0
  451. package/dist/utils/combine-sx.js +27 -0
  452. package/dist/utils/combine-sx.js.map +1 -0
  453. package/dist/utils/component-ids.d.ts +8 -0
  454. package/dist/utils/component-ids.d.ts.map +1 -0
  455. package/dist/utils/component-ids.js +27 -0
  456. package/dist/utils/component-ids.js.map +1 -0
  457. package/dist/utils/format.d.ts +3 -0
  458. package/dist/utils/format.d.ts.map +1 -0
  459. package/dist/utils/format.js +44 -0
  460. package/dist/utils/format.js.map +1 -0
  461. package/dist/utils/format.test.d.ts +2 -0
  462. package/dist/utils/format.test.d.ts.map +1 -0
  463. package/dist/utils/format.test.js +45 -0
  464. package/dist/utils/format.test.js.map +1 -0
  465. package/dist/utils/index.d.ts +5 -0
  466. package/dist/utils/index.d.ts.map +1 -0
  467. package/dist/utils/index.js +18 -0
  468. package/dist/utils/index.js.map +1 -0
  469. package/dist/utils/mathjs.d.ts +6 -0
  470. package/dist/utils/mathjs.d.ts.map +1 -0
  471. package/dist/utils/mathjs.js +20 -0
  472. package/dist/utils/mathjs.js.map +1 -0
  473. package/dist/utils/theme-gen.d.ts +6 -0
  474. package/dist/utils/theme-gen.d.ts.map +1 -0
  475. package/dist/utils/theme-gen.js +182 -0
  476. package/dist/utils/theme-gen.js.map +1 -0
  477. package/dist/utils/theme-gen.test.d.ts +2 -0
  478. package/dist/utils/theme-gen.test.d.ts.map +1 -0
  479. package/dist/utils/theme-gen.test.js +195 -0
  480. package/dist/utils/theme-gen.test.js.map +1 -0
  481. package/package.json +54 -0
@@ -0,0 +1,95 @@
1
+ // Copyright 2022 The Perses Authors
2
+ // Licensed under the Apache License, Version 2.0 (the "License");
3
+ // you may not use this file except in compliance with the License.
4
+ // You may obtain a copy of the License at
5
+ //
6
+ // http://www.apache.org/licenses/LICENSE-2.0
7
+ //
8
+ // Unless required by applicable law or agreed to in writing, software
9
+ // distributed under the License is distributed on an "AS IS" BASIS,
10
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
+ // See the License for the specific language governing permissions and
12
+ // limitations under the License.
13
+ "use strict";
14
+ Object.defineProperty(exports, "__esModule", {
15
+ value: true
16
+ });
17
+ function _export(target, all) {
18
+ for(var name in all)Object.defineProperty(target, name, {
19
+ enumerable: true,
20
+ get: all[name]
21
+ });
22
+ }
23
+ _export(exports, {
24
+ enableDataZoom: ()=>enableDataZoom,
25
+ restoreChart: ()=>restoreChart,
26
+ getDateRange: ()=>getDateRange,
27
+ getFormattedDate: ()=>getFormattedDate,
28
+ getYAxes: ()=>getYAxes
29
+ });
30
+ const _lodashEs = require("lodash-es");
31
+ const _model = require("../model");
32
+ const _utils = require("../utils");
33
+ function enableDataZoom(chart) {
34
+ const chartModel = chart['_model'];
35
+ if (chartModel === undefined) return;
36
+ if (chartModel.option.toolbox !== undefined && chartModel.option.toolbox.length > 0) {
37
+ // check if hidden data zoom icon is unselected (if selected it would be 'emphasis' instead of 'normal')
38
+ if (chartModel.option.toolbox[0].feature.dataZoom.iconStatus.zoom === 'normal') {
39
+ chart.dispatchAction({
40
+ type: 'takeGlobalCursor',
41
+ key: 'dataZoomSelect',
42
+ dataZoomSelectActive: true
43
+ });
44
+ }
45
+ }
46
+ }
47
+ function restoreChart(chart) {
48
+ // TODO: support incremental unzoom instead of restore to original state
49
+ chart.dispatchAction({
50
+ type: 'restore'
51
+ });
52
+ }
53
+ function getDateRange(data) {
54
+ const defaultRange = 3600000; // hour in ms
55
+ if (data.length === 0) return defaultRange;
56
+ const lastDatum = data[data.length - 1];
57
+ if (data[0] === undefined || lastDatum === undefined) return defaultRange;
58
+ return lastDatum - data[0];
59
+ }
60
+ function getFormattedDate(value, rangeMs, timeZone) {
61
+ const dateFormatOptions = (0, _utils.dateFormatOptionsWithTimeZone)({
62
+ hour: 'numeric',
63
+ minute: 'numeric',
64
+ hourCycle: 'h23'
65
+ }, timeZone);
66
+ const thirtyMinMs = 1800000;
67
+ const dayMs = 86400000;
68
+ if (rangeMs <= thirtyMinMs) {
69
+ dateFormatOptions.second = 'numeric';
70
+ } else if (rangeMs >= dayMs) {
71
+ dateFormatOptions.month = 'numeric';
72
+ dateFormatOptions.day = 'numeric';
73
+ }
74
+ const DATE_FORMAT = new Intl.DateTimeFormat(undefined, dateFormatOptions);
75
+ // remove comma when month / day present
76
+ return DATE_FORMAT.format(value).replace(/, /g, ' ');
77
+ }
78
+ function getYAxes(yAxis, unit) {
79
+ // TODO: support alternate yAxis that shows on right side
80
+ const Y_AXIS_DEFAULT = {
81
+ type: 'value',
82
+ boundaryGap: [
83
+ 0,
84
+ '10%'
85
+ ],
86
+ axisLabel: {
87
+ formatter: (value)=>{
88
+ return (0, _model.formatValue)(value, unit);
89
+ }
90
+ }
91
+ };
92
+ return [
93
+ (0, _lodashEs.merge)(Y_AXIS_DEFAULT, yAxis)
94
+ ];
95
+ }
@@ -0,0 +1,32 @@
1
+ // Copyright 2022 The Perses Authors
2
+ // Licensed under the Apache License, Version 2.0 (the "License");
3
+ // you may not use this file except in compliance with the License.
4
+ // You may obtain a copy of the License at
5
+ //
6
+ // http://www.apache.org/licenses/LICENSE-2.0
7
+ //
8
+ // Unless required by applicable law or agreed to in writing, software
9
+ // distributed under the License is distributed on an "AS IS" BASIS,
10
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
+ // See the License for the specific language governing permissions and
12
+ // limitations under the License.
13
+ "use strict";
14
+ Object.defineProperty(exports, "__esModule", {
15
+ value: true
16
+ });
17
+ Object.defineProperty(exports, "OptionsEditorColumn", {
18
+ enumerable: true,
19
+ get: ()=>OptionsEditorColumn
20
+ });
21
+ const _jsxRuntime = require("react/jsx-runtime");
22
+ const _material = require("@mui/material");
23
+ const OptionsEditorColumn = ({ children })=>{
24
+ return /*#__PURE__*/ (0, _jsxRuntime.jsx)(_material.Grid, {
25
+ item: true,
26
+ xs: 4,
27
+ children: /*#__PURE__*/ (0, _jsxRuntime.jsx)(_material.Stack, {
28
+ spacing: 3,
29
+ children: children
30
+ })
31
+ });
32
+ };
@@ -0,0 +1,61 @@
1
+ // Copyright 2022 The Perses Authors
2
+ // Licensed under the Apache License, Version 2.0 (the "License");
3
+ // you may not use this file except in compliance with the License.
4
+ // You may obtain a copy of the License at
5
+ //
6
+ // http://www.apache.org/licenses/LICENSE-2.0
7
+ //
8
+ // Unless required by applicable law or agreed to in writing, software
9
+ // distributed under the License is distributed on an "AS IS" BASIS,
10
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
+ // See the License for the specific language governing permissions and
12
+ // limitations under the License.
13
+ "use strict";
14
+ Object.defineProperty(exports, "__esModule", {
15
+ value: true
16
+ });
17
+ Object.defineProperty(exports, "OptionsEditorControl", {
18
+ enumerable: true,
19
+ get: ()=>OptionsEditorControl
20
+ });
21
+ const _jsxRuntime = require("react/jsx-runtime");
22
+ const _material = require("@mui/material");
23
+ const _react = /*#__PURE__*/ _interopRequireDefault(require("react"));
24
+ const _utils = require("../utils");
25
+ function _interopRequireDefault(obj) {
26
+ return obj && obj.__esModule ? obj : {
27
+ default: obj
28
+ };
29
+ }
30
+ const OptionsEditorControl = ({ label , control })=>{
31
+ // Make sure we have a unique ID we can use for associating labels and
32
+ // controls for a11y.
33
+ const generatedControlId = (0, _utils.useId)('EditorSectionControl');
34
+ const controlId = `${generatedControlId}-control`;
35
+ const controlProps = {
36
+ id: controlId
37
+ };
38
+ return /*#__PURE__*/ (0, _jsxRuntime.jsx)(_material.FormControl, {
39
+ children: /*#__PURE__*/ (0, _jsxRuntime.jsxs)(_material.Stack, {
40
+ direction: "row",
41
+ alignItems: "center",
42
+ justifyContent: "space-between",
43
+ children: [
44
+ /*#__PURE__*/ (0, _jsxRuntime.jsx)(_material.FormLabel, {
45
+ htmlFor: controlId,
46
+ children: label
47
+ }),
48
+ /*#__PURE__*/ (0, _jsxRuntime.jsxs)(_material.Box, {
49
+ sx: {
50
+ width: '160px',
51
+ textAlign: 'right'
52
+ },
53
+ children: [
54
+ " ",
55
+ /*#__PURE__*/ _react.default.cloneElement(control, controlProps)
56
+ ]
57
+ })
58
+ ]
59
+ })
60
+ });
61
+ };
@@ -0,0 +1,29 @@
1
+ // Copyright 2022 The Perses Authors
2
+ // Licensed under the Apache License, Version 2.0 (the "License");
3
+ // you may not use this file except in compliance with the License.
4
+ // You may obtain a copy of the License at
5
+ //
6
+ // http://www.apache.org/licenses/LICENSE-2.0
7
+ //
8
+ // Unless required by applicable law or agreed to in writing, software
9
+ // distributed under the License is distributed on an "AS IS" BASIS,
10
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
+ // See the License for the specific language governing permissions and
12
+ // limitations under the License.
13
+ "use strict";
14
+ Object.defineProperty(exports, "__esModule", {
15
+ value: true
16
+ });
17
+ Object.defineProperty(exports, "OptionsEditorGrid", {
18
+ enumerable: true,
19
+ get: ()=>OptionsEditorGrid
20
+ });
21
+ const _jsxRuntime = require("react/jsx-runtime");
22
+ const _material = require("@mui/material");
23
+ const OptionsEditorGrid = ({ children })=>{
24
+ return /*#__PURE__*/ (0, _jsxRuntime.jsx)(_material.Grid, {
25
+ container: true,
26
+ spacing: 8,
27
+ children: children
28
+ });
29
+ };
@@ -0,0 +1,40 @@
1
+ // Copyright 2022 The Perses Authors
2
+ // Licensed under the Apache License, Version 2.0 (the "License");
3
+ // you may not use this file except in compliance with the License.
4
+ // You may obtain a copy of the License at
5
+ //
6
+ // http://www.apache.org/licenses/LICENSE-2.0
7
+ //
8
+ // Unless required by applicable law or agreed to in writing, software
9
+ // distributed under the License is distributed on an "AS IS" BASIS,
10
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
+ // See the License for the specific language governing permissions and
12
+ // limitations under the License.
13
+ "use strict";
14
+ Object.defineProperty(exports, "__esModule", {
15
+ value: true
16
+ });
17
+ Object.defineProperty(exports, "OptionsEditorGroup", {
18
+ enumerable: true,
19
+ get: ()=>OptionsEditorGroup
20
+ });
21
+ const _jsxRuntime = require("react/jsx-runtime");
22
+ const _material = require("@mui/material");
23
+ const OptionsEditorGroup = ({ title , children })=>{
24
+ return /*#__PURE__*/ (0, _jsxRuntime.jsxs)(_material.Box, {
25
+ children: [
26
+ /*#__PURE__*/ (0, _jsxRuntime.jsx)(_material.Typography, {
27
+ variant: "overline",
28
+ component: "h4",
29
+ borderBottom: 1,
30
+ borderColor: "grey.300",
31
+ marginBottom: (theme)=>theme.spacing(1),
32
+ children: title
33
+ }),
34
+ /*#__PURE__*/ (0, _jsxRuntime.jsx)(_material.Stack, {
35
+ spacing: 1,
36
+ children: children
37
+ })
38
+ ]
39
+ });
40
+ };
@@ -0,0 +1,31 @@
1
+ // Copyright 2022 The Perses Authors
2
+ // Licensed under the Apache License, Version 2.0 (the "License");
3
+ // you may not use this file except in compliance with the License.
4
+ // You may obtain a copy of the License at
5
+ //
6
+ // http://www.apache.org/licenses/LICENSE-2.0
7
+ //
8
+ // Unless required by applicable law or agreed to in writing, software
9
+ // distributed under the License is distributed on an "AS IS" BASIS,
10
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
+ // See the License for the specific language governing permissions and
12
+ // limitations under the License.
13
+ "use strict";
14
+ Object.defineProperty(exports, "__esModule", {
15
+ value: true
16
+ });
17
+ _exportStar(require("./OptionsEditorColumn"), exports);
18
+ _exportStar(require("./OptionsEditorControl"), exports);
19
+ _exportStar(require("./OptionsEditorGrid"), exports);
20
+ _exportStar(require("./OptionsEditorGroup"), exports);
21
+ function _exportStar(from, to) {
22
+ Object.keys(from).forEach(function(k) {
23
+ if (k !== "default" && !Object.prototype.hasOwnProperty.call(to, k)) Object.defineProperty(to, k, {
24
+ enumerable: true,
25
+ get: function() {
26
+ return from[k];
27
+ }
28
+ });
29
+ });
30
+ return from;
31
+ }
@@ -0,0 +1,165 @@
1
+ // Copyright 2022 The Perses Authors
2
+ // Licensed under the Apache License, Version 2.0 (the "License");
3
+ // you may not use this file except in compliance with the License.
4
+ // You may obtain a copy of the License at
5
+ //
6
+ // http://www.apache.org/licenses/LICENSE-2.0
7
+ //
8
+ // Unless required by applicable law or agreed to in writing, software
9
+ // distributed under the License is distributed on an "AS IS" BASIS,
10
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
+ // See the License for the specific language governing permissions and
12
+ // limitations under the License.
13
+ "use strict";
14
+ Object.defineProperty(exports, "__esModule", {
15
+ value: true
16
+ });
17
+ Object.defineProperty(exports, "StatChart", {
18
+ enumerable: true,
19
+ get: ()=>StatChart
20
+ });
21
+ const _jsxRuntime = require("react/jsx-runtime");
22
+ const _react = /*#__PURE__*/ _interopRequireWildcard(require("react"));
23
+ const _material = require("@mui/material");
24
+ const _lodashEs = require("lodash-es");
25
+ const _core = require("echarts/core");
26
+ const _charts = require("echarts/charts");
27
+ const _components = require("echarts/components");
28
+ const _renderers = require("echarts/renderers");
29
+ const _chartsThemeProvider = require("../context/ChartsThemeProvider");
30
+ const _units = require("../model/units");
31
+ const _echart = require("../EChart");
32
+ function _getRequireWildcardCache(nodeInterop) {
33
+ if (typeof WeakMap !== "function") return null;
34
+ var cacheBabelInterop = new WeakMap();
35
+ var cacheNodeInterop = new WeakMap();
36
+ return (_getRequireWildcardCache = function(nodeInterop) {
37
+ return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
38
+ })(nodeInterop);
39
+ }
40
+ function _interopRequireWildcard(obj, nodeInterop) {
41
+ if (!nodeInterop && obj && obj.__esModule) {
42
+ return obj;
43
+ }
44
+ if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
45
+ return {
46
+ default: obj
47
+ };
48
+ }
49
+ var cache = _getRequireWildcardCache(nodeInterop);
50
+ if (cache && cache.has(obj)) {
51
+ return cache.get(obj);
52
+ }
53
+ var newObj = {};
54
+ var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
55
+ for(var key in obj){
56
+ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
57
+ var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
58
+ if (desc && (desc.get || desc.set)) {
59
+ Object.defineProperty(newObj, key, desc);
60
+ } else {
61
+ newObj[key] = obj[key];
62
+ }
63
+ }
64
+ }
65
+ newObj.default = obj;
66
+ if (cache) {
67
+ cache.set(obj, newObj);
68
+ }
69
+ return newObj;
70
+ }
71
+ (0, _core.use)([
72
+ _charts.GaugeChart,
73
+ _charts.LineChart,
74
+ _components.GridComponent,
75
+ _components.DatasetComponent,
76
+ _components.TitleComponent,
77
+ _components.TooltipComponent,
78
+ _renderers.CanvasRenderer
79
+ ]);
80
+ const PANEL_PADDING = 32;
81
+ const MIN_VALUE_SIZE = 12;
82
+ const MAX_VALUE_SIZE = 36;
83
+ function StatChart(props) {
84
+ const { width , height , data , unit , sparkline } = props;
85
+ const chartsTheme = (0, _chartsThemeProvider.useChartsTheme)();
86
+ const formattedValue = data.calculatedValue === undefined ? '' : (0, _units.formatValue)(data.calculatedValue, unit);
87
+ const option = (0, _react.useMemo)(()=>{
88
+ if (data.seriesData === undefined) return chartsTheme.noDataOption;
89
+ const series = data.seriesData;
90
+ const statSeries = [];
91
+ if (sparkline !== undefined) {
92
+ const lineSeries = {
93
+ type: 'line',
94
+ data: [
95
+ ...series.values
96
+ ],
97
+ zlevel: 1,
98
+ symbol: 'none',
99
+ animation: false,
100
+ silent: true
101
+ };
102
+ const mergedSeries = (0, _lodashEs.merge)(lineSeries, sparkline);
103
+ statSeries.push(mergedSeries);
104
+ }
105
+ const option = {
106
+ title: {
107
+ show: false
108
+ },
109
+ grid: {
110
+ show: false,
111
+ top: '35%',
112
+ right: 0,
113
+ bottom: 0,
114
+ left: 0,
115
+ containLabel: false
116
+ },
117
+ xAxis: {
118
+ type: 'time',
119
+ show: false,
120
+ boundaryGap: false
121
+ },
122
+ yAxis: {
123
+ type: 'value',
124
+ show: false
125
+ },
126
+ tooltip: {
127
+ show: false
128
+ },
129
+ series: statSeries
130
+ };
131
+ return option;
132
+ }, [
133
+ data,
134
+ chartsTheme,
135
+ sparkline
136
+ ]);
137
+ const isLargePanel = width > 250 && height > 180;
138
+ // adjusts fontSize depending on number of characters, clamp also used in fontSize attribute
139
+ const charactersAdjust = formattedValue.length;
140
+ const valueSize = isLargePanel === true ? MAX_VALUE_SIZE : Math.min(width, height) / charactersAdjust;
141
+ return /*#__PURE__*/ (0, _jsxRuntime.jsxs)(_material.Box, {
142
+ children: [
143
+ /*#__PURE__*/ (0, _jsxRuntime.jsx)(_material.Typography, {
144
+ variant: "h3",
145
+ sx: (theme)=>({
146
+ color: theme.palette.text.primary,
147
+ fontSize: `clamp(${MIN_VALUE_SIZE}px, ${valueSize}px, ${MAX_VALUE_SIZE}px)`
148
+ }),
149
+ children: formattedValue
150
+ }),
151
+ sparkline !== undefined && /*#__PURE__*/ (0, _jsxRuntime.jsx)(_echart.EChart, {
152
+ sx: {
153
+ width: width + PANEL_PADDING,
154
+ height: height,
155
+ position: 'absolute',
156
+ bottom: 0,
157
+ left: 0
158
+ },
159
+ option: option,
160
+ theme: chartsTheme.echartsTheme,
161
+ renderer: "svg"
162
+ })
163
+ ]
164
+ });
165
+ }
@@ -0,0 +1,89 @@
1
+ // Copyright 2022 The Perses Authors
2
+ // Licensed under the Apache License, Version 2.0 (the "License");
3
+ // you may not use this file except in compliance with the License.
4
+ // You may obtain a copy of the License at
5
+ //
6
+ // http://www.apache.org/licenses/LICENSE-2.0
7
+ //
8
+ // Unless required by applicable law or agreed to in writing, software
9
+ // distributed under the License is distributed on an "AS IS" BASIS,
10
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
+ // See the License for the specific language governing permissions and
12
+ // limitations under the License.
13
+ "use strict";
14
+ Object.defineProperty(exports, "__esModule", {
15
+ value: true
16
+ });
17
+ const _jsxRuntime = require("react/jsx-runtime");
18
+ const _react = require("@testing-library/react");
19
+ const _chartsThemeProvider = require("../context/ChartsThemeProvider");
20
+ const _testUtils = require("../test-utils");
21
+ const _statChart = require("./StatChart");
22
+ describe('StatChart', ()=>{
23
+ const renderChart = (unit)=>{
24
+ const contentDimensions = {
25
+ width: 200,
26
+ height: 200
27
+ };
28
+ (0, _react.render)(/*#__PURE__*/ (0, _jsxRuntime.jsx)(_chartsThemeProvider.ChartsThemeProvider, {
29
+ chartsTheme: _testUtils.testChartsTheme,
30
+ children: /*#__PURE__*/ (0, _jsxRuntime.jsx)(_statChart.StatChart, {
31
+ width: contentDimensions.width,
32
+ height: contentDimensions.height,
33
+ data: mockStatData,
34
+ unit: unit
35
+ })
36
+ }));
37
+ };
38
+ const mockStatData = {
39
+ calculatedValue: 7.72931659687181,
40
+ name: 'Example Stat Chart',
41
+ seriesData: {
42
+ name: '(((count(count(node_cpu_seconds_total{job="example"}) by (cpu))',
43
+ values: [
44
+ [
45
+ 1654006170000,
46
+ 7.736401673473903
47
+ ],
48
+ [
49
+ 1654006185000,
50
+ 7.733891213538757
51
+ ],
52
+ [
53
+ 1654006200000,
54
+ 7.731101813010433
55
+ ],
56
+ [
57
+ 1654006215000,
58
+ 7.722454672079215
59
+ ],
60
+ [
61
+ 1654006230000,
62
+ 7.722733612256738
63
+ ]
64
+ ]
65
+ }
66
+ };
67
+ it('render default options (no sparkline)', ()=>{
68
+ const unit = {
69
+ kind: 'Decimal',
70
+ decimal_places: 2
71
+ };
72
+ renderChart(unit);
73
+ expect(_react.screen.getByText('7.73')).toBeInTheDocument();
74
+ });
75
+ it('show value with time unit formatting', ()=>{
76
+ const unit = {
77
+ kind: 'Seconds'
78
+ };
79
+ renderChart(unit);
80
+ expect(_react.screen.getByText('7.73 seconds')).toBeInTheDocument();
81
+ });
82
+ it('show value with time unit formatting', ()=>{
83
+ const unit = {
84
+ kind: 'Months'
85
+ };
86
+ renderChart(unit);
87
+ expect(_react.screen.getByText('7.73 months')).toBeInTheDocument();
88
+ });
89
+ });
@@ -0,0 +1,28 @@
1
+ // Copyright 2022 The Perses Authors
2
+ // Licensed under the Apache License, Version 2.0 (the "License");
3
+ // you may not use this file except in compliance with the License.
4
+ // You may obtain a copy of the License at
5
+ //
6
+ // http://www.apache.org/licenses/LICENSE-2.0
7
+ //
8
+ // Unless required by applicable law or agreed to in writing, software
9
+ // distributed under the License is distributed on an "AS IS" BASIS,
10
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
+ // See the License for the specific language governing permissions and
12
+ // limitations under the License.
13
+ "use strict";
14
+ Object.defineProperty(exports, "__esModule", {
15
+ value: true
16
+ });
17
+ _exportStar(require("./StatChart"), exports);
18
+ function _exportStar(from, to) {
19
+ Object.keys(from).forEach(function(k) {
20
+ if (k !== "default" && !Object.prototype.hasOwnProperty.call(to, k)) Object.defineProperty(to, k, {
21
+ enumerable: true,
22
+ get: function() {
23
+ return from[k];
24
+ }
25
+ });
26
+ });
27
+ return from;
28
+ }