@carto/ps-react-ui 4.3.0-widgets.0 → 5.0.0-widgets.10

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 (284) hide show
  1. package/dist/components.js +25 -23
  2. package/dist/components.js.map +1 -1
  3. package/dist/error-B2IJ9d2h.js +38 -0
  4. package/dist/error-B2IJ9d2h.js.map +1 -0
  5. package/dist/exports-Cr43OCul.js +51 -0
  6. package/dist/exports-Cr43OCul.js.map +1 -0
  7. package/dist/{lasso-tool-BC-rsMMW.js → lasso-tool-CYn3ivf-.js} +165 -183
  8. package/dist/lasso-tool-CYn3ivf-.js.map +1 -0
  9. package/dist/no-data-C54XJt13.js +61 -0
  10. package/dist/no-data-C54XJt13.js.map +1 -0
  11. package/dist/note-Clng2ej6.js +124 -0
  12. package/dist/note-Clng2ej6.js.map +1 -0
  13. package/dist/options-D9wflre6.js +49 -0
  14. package/dist/options-D9wflre6.js.map +1 -0
  15. package/dist/row-DrHwXNvF.js +35 -0
  16. package/dist/row-DrHwXNvF.js.map +1 -0
  17. package/dist/series-Do02NQUF.js +91 -0
  18. package/dist/series-Do02NQUF.js.map +1 -0
  19. package/dist/{smart-tooltip-BSlcAkBM.js → smart-tooltip-BEtBaIdz.js} +2 -2
  20. package/dist/{smart-tooltip-BSlcAkBM.js.map → smart-tooltip-BEtBaIdz.js.map} +1 -1
  21. package/dist/styles-dOu_pRNb.js +77 -0
  22. package/dist/styles-dOu_pRNb.js.map +1 -0
  23. package/dist/tooltip-BDnrRKrp.js +25 -0
  24. package/dist/tooltip-BDnrRKrp.js.map +1 -0
  25. package/dist/types/hooks/index.d.ts +2 -0
  26. package/dist/types/hooks/use-debounce.d.ts +19 -0
  27. package/dist/types/hooks/use-widget-ref.d.ts +17 -0
  28. package/dist/types/widgets/_shared/chart-config/config-factory.d.ts +5 -11
  29. package/dist/types/widgets/_shared/chart-config/option-builders.d.ts +3 -8
  30. package/dist/types/widgets/actions/change-column/change-column-icon.d.ts +1 -0
  31. package/dist/types/widgets/actions/change-column/change-column.d.ts +16 -0
  32. package/dist/types/widgets/actions/change-column/sortable-column-item.d.ts +9 -0
  33. package/dist/types/widgets/actions/change-column/types.d.ts +19 -0
  34. package/dist/types/widgets/actions/download/download.d.ts +1 -1
  35. package/dist/types/widgets/actions/download/exports.d.ts +1 -1
  36. package/dist/types/widgets/actions/download/types.d.ts +3 -11
  37. package/dist/types/widgets/actions/fullscreen/fullscreen.d.ts +1 -1
  38. package/dist/types/widgets/actions/fullscreen/styles.d.ts +6 -0
  39. package/dist/types/widgets/actions/fullscreen/types.d.ts +8 -9
  40. package/dist/types/widgets/actions/index.d.ts +14 -1
  41. package/dist/types/widgets/actions/lock-selection/lock-selection.d.ts +19 -0
  42. package/dist/types/widgets/actions/lock-selection/types.d.ts +38 -0
  43. package/dist/types/widgets/actions/relative-data/relative-data.d.ts +18 -0
  44. package/dist/types/widgets/actions/relative-data/style.d.ts +8 -0
  45. package/dist/types/widgets/actions/relative-data/types.d.ts +27 -0
  46. package/dist/types/widgets/actions/relative-data/utils.d.ts +9 -0
  47. package/dist/types/widgets/actions/relative-data/utils.test.d.ts +1 -0
  48. package/dist/types/widgets/actions/searcher/searcher-toggle.d.ts +18 -0
  49. package/dist/types/widgets/actions/searcher/searcher.d.ts +21 -0
  50. package/dist/types/widgets/actions/searcher/types.d.ts +64 -0
  51. package/dist/types/widgets/actions/shared/styles.d.ts +11 -0
  52. package/dist/types/widgets/actions/stack-toggle/grouped-bar-chart-icon.d.ts +1 -0
  53. package/dist/types/widgets/actions/stack-toggle/stack-toggle.d.ts +16 -0
  54. package/dist/types/widgets/actions/stack-toggle/types.d.ts +25 -0
  55. package/dist/types/widgets/actions/zoom-toggle/index.d.ts +2 -0
  56. package/dist/types/widgets/actions/zoom-toggle/style.d.ts +13 -0
  57. package/dist/types/widgets/actions/zoom-toggle/types.d.ts +41 -0
  58. package/dist/types/widgets/actions/zoom-toggle/zoom-toggle.d.ts +18 -0
  59. package/dist/types/widgets/bar/config.d.ts +5 -4
  60. package/dist/types/widgets/bar/index.d.ts +2 -2
  61. package/dist/types/widgets/bar/types.d.ts +6 -12
  62. package/dist/types/widgets/category/category-ui.d.ts +2 -0
  63. package/dist/types/widgets/category/components/category-bar.d.ts +7 -0
  64. package/dist/types/widgets/category/components/category-legend.d.ts +6 -0
  65. package/dist/types/widgets/category/components/category-row-multi.d.ts +11 -0
  66. package/dist/types/widgets/category/components/category-row-other.d.ts +6 -0
  67. package/dist/types/widgets/category/components/category-row-single.d.ts +11 -0
  68. package/dist/types/widgets/category/components/index.d.ts +10 -0
  69. package/dist/types/widgets/category/config.d.ts +16 -0
  70. package/dist/types/widgets/category/index.d.ts +6 -0
  71. package/dist/types/widgets/category/skeleton.d.ts +1 -0
  72. package/dist/types/widgets/category/style.d.ts +121 -0
  73. package/dist/types/widgets/category/types.d.ts +34 -0
  74. package/dist/types/widgets/echart/echart-ui.d.ts +1 -1
  75. package/dist/types/widgets/echart/index.d.ts +2 -2
  76. package/dist/types/widgets/echart/options.d.ts +2 -3
  77. package/dist/types/widgets/echart/types.d.ts +12 -10
  78. package/dist/types/widgets/echart/utils.d.ts +22 -16
  79. package/dist/types/widgets/error/error.d.ts +2 -0
  80. package/dist/types/widgets/error/index.d.ts +2 -0
  81. package/dist/types/widgets/error/types.d.ts +12 -0
  82. package/dist/types/widgets/formula/components/row.d.ts +1 -1
  83. package/dist/types/widgets/formula/config.d.ts +4 -2
  84. package/dist/types/widgets/formula/index.d.ts +2 -1
  85. package/dist/types/widgets/formula/types.d.ts +6 -18
  86. package/dist/types/widgets/histogram/config.d.ts +5 -4
  87. package/dist/types/widgets/histogram/index.d.ts +2 -2
  88. package/dist/types/widgets/histogram/types.d.ts +6 -12
  89. package/dist/types/widgets/index.d.ts +8 -4
  90. package/dist/types/widgets/loader/index.d.ts +3 -0
  91. package/dist/types/widgets/loader/loader.d.ts +2 -0
  92. package/dist/types/widgets/loader/types.d.ts +9 -0
  93. package/dist/types/widgets/loader/utils.d.ts +1 -0
  94. package/dist/types/widgets/markdown/config.d.ts +4 -2
  95. package/dist/types/widgets/markdown/index.d.ts +2 -2
  96. package/dist/types/widgets/markdown/markdown-ui.d.ts +1 -1
  97. package/dist/types/widgets/markdown/types.d.ts +6 -16
  98. package/dist/types/widgets/no-data/index.d.ts +2 -0
  99. package/dist/types/widgets/no-data/no-data.d.ts +35 -0
  100. package/dist/types/widgets/no-data/style.d.ts +6 -0
  101. package/dist/types/widgets/no-data/types.d.ts +67 -0
  102. package/dist/types/widgets/note/index.d.ts +2 -2
  103. package/dist/types/widgets/note/note.d.ts +2 -2
  104. package/dist/types/widgets/note/style.d.ts +12 -1
  105. package/dist/types/widgets/note/types.d.ts +4 -3
  106. package/dist/types/widgets/pie/config.d.ts +5 -4
  107. package/dist/types/widgets/pie/index.d.ts +2 -2
  108. package/dist/types/widgets/pie/types.d.ts +6 -12
  109. package/dist/types/widgets/range/config.d.ts +6 -2
  110. package/dist/types/widgets/range/index.d.ts +2 -1
  111. package/dist/types/widgets/range/types.d.ts +6 -17
  112. package/dist/types/widgets/scatterplot/config.d.ts +5 -4
  113. package/dist/types/widgets/scatterplot/index.d.ts +2 -2
  114. package/dist/types/widgets/scatterplot/types.d.ts +6 -12
  115. package/dist/types/widgets/selection-summary/index.d.ts +2 -0
  116. package/dist/types/widgets/selection-summary/selection-summary.d.ts +2 -0
  117. package/dist/types/widgets/{root → selection-summary}/style.d.ts +3 -2
  118. package/dist/types/widgets/selection-summary/types.d.ts +13 -0
  119. package/dist/types/widgets/spread/config.d.ts +10 -2
  120. package/dist/types/widgets/spread/index.d.ts +2 -1
  121. package/dist/types/widgets/spread/types.d.ts +6 -18
  122. package/dist/types/widgets/stores/index.d.ts +2 -0
  123. package/dist/types/widgets/stores/types.d.ts +104 -12
  124. package/dist/types/widgets/stores/widget-store.d.ts +2 -27
  125. package/dist/types/widgets/subheader/index.d.ts +2 -0
  126. package/dist/types/widgets/subheader/style.d.ts +19 -0
  127. package/dist/types/widgets/subheader/subheader.d.ts +2 -0
  128. package/dist/types/widgets/subheader/types.d.ts +10 -0
  129. package/dist/types/widgets/table/components/cell-header.d.ts +5 -0
  130. package/dist/types/widgets/table/components/cell.d.ts +16 -0
  131. package/dist/types/widgets/table/components/index.d.ts +4 -0
  132. package/dist/types/widgets/table/components/pagination-actions.d.ts +5 -0
  133. package/dist/types/widgets/table/components/pagination.d.ts +5 -0
  134. package/dist/types/widgets/table/components/row.d.ts +5 -0
  135. package/dist/types/widgets/table/config.d.ts +17 -0
  136. package/dist/types/widgets/table/helpers.d.ts +38 -0
  137. package/dist/types/widgets/table/helpers.test.d.ts +1 -0
  138. package/dist/types/widgets/table/hooks/index.d.ts +6 -0
  139. package/dist/types/widgets/table/hooks/use-pagination.d.ts +33 -0
  140. package/dist/types/widgets/table/hooks/use-pagination.test.d.ts +1 -0
  141. package/dist/types/widgets/table/hooks/use-selection.d.ts +30 -0
  142. package/dist/types/widgets/table/hooks/use-selection.test.d.ts +1 -0
  143. package/dist/types/widgets/table/hooks/use-sort.d.ts +22 -0
  144. package/dist/types/widgets/table/hooks/use-sort.test.d.ts +1 -0
  145. package/dist/types/widgets/table/index.d.ts +13 -0
  146. package/dist/types/widgets/table/serializer.d.ts +16 -0
  147. package/dist/types/widgets/table/skeleton.d.ts +10 -0
  148. package/dist/types/widgets/table/style.d.ts +33 -0
  149. package/dist/types/widgets/table/table-ui.d.ts +32 -0
  150. package/dist/types/widgets/table/types.d.ts +196 -0
  151. package/dist/types/widgets/timeseries/config.d.ts +5 -4
  152. package/dist/types/widgets/timeseries/index.d.ts +2 -2
  153. package/dist/types/widgets/timeseries/types.d.ts +6 -12
  154. package/dist/types/widgets/toolbar-actions/index.d.ts +2 -0
  155. package/dist/types/widgets/toolbar-actions/styles.d.ts +37 -0
  156. package/dist/types/widgets/toolbar-actions/toolbar-actions.d.ts +8 -0
  157. package/dist/types/widgets/toolbar-actions/types.d.ts +45 -0
  158. package/dist/types/widgets/wrapper/index.d.ts +2 -2
  159. package/dist/types/widgets/wrapper/styles.d.ts +6 -0
  160. package/dist/types/widgets/wrapper/types.d.ts +7 -5
  161. package/dist/types/widgets/wrapper/wrapper-ui.d.ts +1 -1
  162. package/dist/types/widgets/wrapper/wrapper.d.ts +1 -1
  163. package/dist/utils-Dv5Z47UQ.js +144 -0
  164. package/dist/utils-Dv5Z47UQ.js.map +1 -0
  165. package/dist/widget-store-CB6Trp_0.js +131 -0
  166. package/dist/widget-store-CB6Trp_0.js.map +1 -0
  167. package/dist/widgets/actions.js +834 -6
  168. package/dist/widgets/actions.js.map +1 -1
  169. package/dist/widgets/bar.js +190 -4
  170. package/dist/widgets/bar.js.map +1 -1
  171. package/dist/widgets/category.js +467 -0
  172. package/dist/widgets/category.js.map +1 -0
  173. package/dist/widgets/echart.js +120 -8
  174. package/dist/widgets/echart.js.map +1 -1
  175. package/dist/widgets/error.js +5 -0
  176. package/dist/widgets/error.js.map +1 -0
  177. package/dist/widgets/formula.js +118 -20
  178. package/dist/widgets/formula.js.map +1 -1
  179. package/dist/widgets/histogram.js +173 -4
  180. package/dist/widgets/histogram.js.map +1 -1
  181. package/dist/widgets/loader.js +57 -0
  182. package/dist/widgets/loader.js.map +1 -0
  183. package/dist/widgets/markdown.js +127 -0
  184. package/dist/widgets/markdown.js.map +1 -0
  185. package/dist/widgets/no-data.js +5 -0
  186. package/dist/widgets/no-data.js.map +1 -0
  187. package/dist/widgets/note.js +2 -2
  188. package/dist/widgets/pie.js +214 -4
  189. package/dist/widgets/pie.js.map +1 -1
  190. package/dist/widgets/range.js +210 -12
  191. package/dist/widgets/range.js.map +1 -1
  192. package/dist/widgets/scatterplot.js +220 -4
  193. package/dist/widgets/scatterplot.js.map +1 -1
  194. package/dist/widgets/selection-summary.js +40 -0
  195. package/dist/widgets/selection-summary.js.map +1 -0
  196. package/dist/widgets/skeleton-loader.js +21 -2
  197. package/dist/widgets/skeleton-loader.js.map +1 -1
  198. package/dist/widgets/spread.js +163 -17
  199. package/dist/widgets/spread.js.map +1 -1
  200. package/dist/widgets/stores.js +5 -0
  201. package/dist/widgets/stores.js.map +1 -0
  202. package/dist/widgets/subheader.js +52 -0
  203. package/dist/widgets/subheader.js.map +1 -0
  204. package/dist/widgets/table.js +683 -0
  205. package/dist/widgets/table.js.map +1 -0
  206. package/dist/widgets/timeseries.js +172 -4
  207. package/dist/widgets/timeseries.js.map +1 -1
  208. package/dist/widgets/toolbar-actions.js +6106 -0
  209. package/dist/widgets/toolbar-actions.js.map +1 -0
  210. package/dist/widgets/wrapper.js +292 -6
  211. package/dist/widgets/wrapper.js.map +1 -1
  212. package/dist/widgets.js +8 -83
  213. package/dist/widgets.js.map +1 -1
  214. package/package.json +49 -9
  215. package/dist/const-BLV7Tvte.js +0 -758
  216. package/dist/const-BLV7Tvte.js.map +0 -1
  217. package/dist/download-KroQ0SWg.js +0 -195
  218. package/dist/download-KroQ0SWg.js.map +0 -1
  219. package/dist/echart-CqfROFu3.js +0 -214
  220. package/dist/echart-CqfROFu3.js.map +0 -1
  221. package/dist/formula-ui-ChzvMEOG.js +0 -52
  222. package/dist/formula-ui-ChzvMEOG.js.map +0 -1
  223. package/dist/lasso-tool-BC-rsMMW.js.map +0 -1
  224. package/dist/markdown-n_tOtoiT.js +0 -27
  225. package/dist/markdown-n_tOtoiT.js.map +0 -1
  226. package/dist/markdown-ui-BBrzzd7Y.js +0 -62
  227. package/dist/markdown-ui-BBrzzd7Y.js.map +0 -1
  228. package/dist/note-DF-n70TX.js +0 -101
  229. package/dist/note-DF-n70TX.js.map +0 -1
  230. package/dist/range-ui-CtUX11Xm.js +0 -146
  231. package/dist/range-ui-CtUX11Xm.js.map +0 -1
  232. package/dist/root-L_WZnJY5.js +0 -46
  233. package/dist/root-L_WZnJY5.js.map +0 -1
  234. package/dist/row-DQaSxmDV.js +0 -18
  235. package/dist/row-DQaSxmDV.js.map +0 -1
  236. package/dist/series-CsyEPq-X.js +0 -83
  237. package/dist/series-CsyEPq-X.js.map +0 -1
  238. package/dist/skeleton-BSPcEvfq.js +0 -27
  239. package/dist/skeleton-BSPcEvfq.js.map +0 -1
  240. package/dist/skeleton-C4rOYTy-.js +0 -78
  241. package/dist/skeleton-C4rOYTy-.js.map +0 -1
  242. package/dist/skeleton-C9Jqc241.js +0 -82
  243. package/dist/skeleton-C9Jqc241.js.map +0 -1
  244. package/dist/skeleton-D-zHBBIw.js +0 -64
  245. package/dist/skeleton-D-zHBBIw.js.map +0 -1
  246. package/dist/skeleton-DMP-IwaJ.js +0 -109
  247. package/dist/skeleton-DMP-IwaJ.js.map +0 -1
  248. package/dist/skeleton-DRorqowB.js +0 -22
  249. package/dist/skeleton-DRorqowB.js.map +0 -1
  250. package/dist/skeleton-DsZhv-AH.js +0 -89
  251. package/dist/skeleton-DsZhv-AH.js.map +0 -1
  252. package/dist/skeleton-Dx3FCer0.js +0 -13
  253. package/dist/skeleton-Dx3FCer0.js.map +0 -1
  254. package/dist/skeleton-QVDdb1c2.js +0 -21
  255. package/dist/skeleton-QVDdb1c2.js.map +0 -1
  256. package/dist/skeleton-loader-DWC1-EAx.js +0 -23
  257. package/dist/skeleton-loader-DWC1-EAx.js.map +0 -1
  258. package/dist/spread-ui-BjzH190y.js +0 -82
  259. package/dist/spread-ui-BjzH190y.js.map +0 -1
  260. package/dist/style-BGeCtQkP.js +0 -19
  261. package/dist/style-BGeCtQkP.js.map +0 -1
  262. package/dist/style-C7v1iwqD.js +0 -34
  263. package/dist/style-C7v1iwqD.js.map +0 -1
  264. package/dist/styles-cohnxh9F.js +0 -23
  265. package/dist/styles-cohnxh9F.js.map +0 -1
  266. package/dist/types/widgets/config-loader/index.d.ts +0 -2
  267. package/dist/types/widgets/config-loader/types.d.ts +0 -12
  268. package/dist/types/widgets/config-loader/use-config.d.ts +0 -5
  269. package/dist/types/widgets/root/index.d.ts +0 -2
  270. package/dist/types/widgets/root/root.d.ts +0 -2
  271. package/dist/types/widgets/root/types.d.ts +0 -15
  272. package/dist/types/widgets/widget/const.d.ts +0 -2
  273. package/dist/types/widgets/widget/types.d.ts +0 -47
  274. package/dist/types/widgets/widget/widget.d.ts +0 -2
  275. package/dist/use-config-BYEOiIcu.js +0 -43
  276. package/dist/use-config-BYEOiIcu.js.map +0 -1
  277. package/dist/widget-store-yDO2ul8g.js +0 -44
  278. package/dist/widget-store-yDO2ul8g.js.map +0 -1
  279. package/dist/widgets/config-loader.js +0 -5
  280. package/dist/widgets/config-loader.js.map +0 -1
  281. package/dist/widgets/root.js +0 -5
  282. package/dist/widgets/root.js.map +0 -1
  283. package/dist/wrapper-57csMybC.js +0 -265
  284. package/dist/wrapper-57csMybC.js.map +0 -1
@@ -0,0 +1,467 @@
1
+ import { jsx as h, jsxs as R } from "react/jsx-runtime";
2
+ import { c as M } from "react/compiler-runtime";
3
+ import { Box as C, Typography as L, useTheme as Q, Skeleton as N } from "@mui/material";
4
+ import "react";
5
+ import { u as X } from "../widget-store-CB6Trp_0.js";
6
+ import { useShallow as Y } from "zustand/shallow";
7
+ import "@mui/icons-material";
8
+ import "react-markdown";
9
+ import { d as z, a as U } from "../exports-Cr43OCul.js";
10
+ import "../lasso-tool-CYn3ivf-.js";
11
+ import "../cjs-D9ro6BXv.js";
12
+ import "@dnd-kit/core";
13
+ import "@dnd-kit/sortable";
14
+ import "@dnd-kit/utilities";
15
+ const u = {
16
+ root: {
17
+ display: "flex",
18
+ flexDirection: "column",
19
+ position: "relative",
20
+ overflow: "auto"
21
+ },
22
+ list: {
23
+ display: "flex",
24
+ flexDirection: "column",
25
+ gap: (t) => t.spacing(1)
26
+ },
27
+ row: {
28
+ display: "flex",
29
+ flexDirection: "column",
30
+ gap: (t) => t.spacing(0.5),
31
+ pointerEvents: "none"
32
+ },
33
+ rowClickable: {
34
+ pointerEvents: "auto"
35
+ // display: 'flex',
36
+ // flexDirection: 'column',
37
+ // gap: (theme: Theme) => theme.spacing(0.5),
38
+ // cursor: 'pointer',
39
+ // borderRadius: 1,
40
+ // padding: (theme: Theme) => theme.spacing(0.5),
41
+ // margin: (theme: Theme) => theme.spacing(-0.5),
42
+ // transition: 'background-color 0.15s ease-in-out',
43
+ // '&:hover': {
44
+ // backgroundColor: (theme: Theme) => theme.palette.action.hover,
45
+ // },
46
+ },
47
+ rowHeader: {
48
+ display: "flex",
49
+ justifyContent: "space-between",
50
+ alignItems: "center"
51
+ },
52
+ rowLabel: {
53
+ typography: "body2",
54
+ fontWeight: "medium",
55
+ color: "text.primary"
56
+ },
57
+ rowValue: {
58
+ typography: "body2",
59
+ color: "text.secondary"
60
+ },
61
+ barContainer: {
62
+ display: "flex",
63
+ flexDirection: "column"
64
+ },
65
+ bar: {
66
+ height: 4,
67
+ borderRadius: 2,
68
+ backgroundColor: (t) => t.palette.action.disabledBackground,
69
+ overflow: "hidden",
70
+ position: "relative",
71
+ transition: "background-color 0.15s ease-in-out",
72
+ cursor: "pointer",
73
+ "&:hover": {
74
+ backgroundColor: (t) => t.palette.action.hover,
75
+ "& > div": {
76
+ filter: "brightness(1.2)"
77
+ }
78
+ }
79
+ },
80
+ barFill: {
81
+ height: "100%",
82
+ borderRadius: 2,
83
+ transition: "width 0.3s ease-in-out, background-color 0.15s ease-in-out"
84
+ },
85
+ barFillMuted: {
86
+ backgroundColor: (t) => t.palette.action.disabled
87
+ },
88
+ legend: {
89
+ display: "flex",
90
+ alignItems: "center",
91
+ gap: (t) => t.spacing(2),
92
+ flexWrap: "wrap",
93
+ paddingTop: (t) => t.spacing(2),
94
+ position: "sticky",
95
+ bottom: 0,
96
+ backgroundColor: "background.paper",
97
+ borderTop: (t) => `1px solid ${t.palette.divider}`,
98
+ marginTop: (t) => t.spacing(2)
99
+ },
100
+ legendItem: {
101
+ display: "flex",
102
+ alignItems: "center",
103
+ gap: (t) => t.spacing(1)
104
+ },
105
+ legendDot: {
106
+ width: 8,
107
+ height: 8,
108
+ borderRadius: "50%"
109
+ },
110
+ legendLabel: {
111
+ typography: "caption",
112
+ color: "text.secondary",
113
+ textTransform: "uppercase",
114
+ fontWeight: "medium"
115
+ },
116
+ multiBarRow: {
117
+ display: "flex",
118
+ alignItems: "center",
119
+ gap: (t) => t.spacing(1)
120
+ },
121
+ multiBarValue: {
122
+ typography: "body2",
123
+ color: "text.secondary",
124
+ minWidth: 48,
125
+ textAlign: "right"
126
+ },
127
+ multiBarContainer: {
128
+ flex: 1
129
+ },
130
+ otherRow: {
131
+ display: "flex",
132
+ justifyContent: "space-between",
133
+ alignItems: "center"
134
+ },
135
+ otherLabel: {
136
+ typography: "body2",
137
+ fontWeight: "medium",
138
+ color: "text.secondary",
139
+ fontStyle: "italic"
140
+ },
141
+ otherCount: {
142
+ typography: "body2",
143
+ color: "text.disabled"
144
+ }
145
+ };
146
+ function J(t) {
147
+ const e = M(6), {
148
+ value: r,
149
+ maxValue: o,
150
+ color: i,
151
+ selected: n
152
+ } = t, c = n === void 0 ? !0 : n, a = o > 0 ? r / o * 100 : 0;
153
+ let d;
154
+ e[0] !== i || e[1] !== a || e[2] !== c ? (d = c ? {
155
+ ...u.barFill,
156
+ width: `${a}%`,
157
+ backgroundColor: i
158
+ } : {
159
+ ...u.barFill,
160
+ ...u.barFillMuted,
161
+ width: `${a}%`
162
+ }, e[0] = i, e[1] = a, e[2] = c, e[3] = d) : d = e[3];
163
+ const l = d;
164
+ let m;
165
+ return e[4] !== l ? (m = /* @__PURE__ */ h(C, { sx: u.bar, children: /* @__PURE__ */ h(C, { sx: l }) }), e[4] = l, e[5] = m) : m = e[5], m;
166
+ }
167
+ function Z(t) {
168
+ const e = M(23), {
169
+ name: r,
170
+ value: o,
171
+ maxValue: i,
172
+ color: n,
173
+ formatter: c,
174
+ onClick: a,
175
+ selected: d
176
+ } = t, l = d === void 0 ? !0 : d;
177
+ let m;
178
+ e[0] !== r || e[1] !== a ? (m = a ? () => a({
179
+ name: r
180
+ }) : void 0, e[0] = r, e[1] = a, e[2] = m) : m = e[2];
181
+ const f = m, y = a ? u.rowClickable : u.row;
182
+ let g;
183
+ e[3] !== r ? (g = /* @__PURE__ */ h(L, { sx: u.rowLabel, children: r }), e[3] = r, e[4] = g) : g = e[4];
184
+ let w;
185
+ e[5] !== c || e[6] !== o ? (w = c(o), e[5] = c, e[6] = o, e[7] = w) : w = e[7];
186
+ let x;
187
+ e[8] !== w ? (x = /* @__PURE__ */ h(L, { sx: u.rowValue, children: w }), e[8] = w, e[9] = x) : x = e[9];
188
+ let b;
189
+ e[10] !== g || e[11] !== x ? (b = /* @__PURE__ */ R(C, { sx: u.rowHeader, children: [
190
+ g,
191
+ x
192
+ ] }), e[10] = g, e[11] = x, e[12] = b) : b = e[12];
193
+ let k;
194
+ e[13] !== n || e[14] !== i || e[15] !== l || e[16] !== o ? (k = /* @__PURE__ */ h(J, { value: o, maxValue: i, color: n, selected: l }), e[13] = n, e[14] = i, e[15] = l, e[16] = o, e[17] = k) : k = e[17];
195
+ let v;
196
+ return e[18] !== f || e[19] !== y || e[20] !== b || e[21] !== k ? (v = /* @__PURE__ */ R(C, { sx: y, onClick: f, children: [
197
+ b,
198
+ k
199
+ ] }), e[18] = f, e[19] = y, e[20] = b, e[21] = k, e[22] = v) : v = e[22], v;
200
+ }
201
+ function ee(t) {
202
+ const e = M(25), {
203
+ name: r,
204
+ values: o,
205
+ maxValue: i,
206
+ colors: n,
207
+ formatter: c,
208
+ onClick: a,
209
+ selected: d
210
+ } = t, l = d === void 0 ? !0 : d;
211
+ let m;
212
+ e[0] !== r || e[1] !== a ? (m = a ? () => a({
213
+ name: r
214
+ }) : void 0, e[0] = r, e[1] = a, e[2] = m) : m = e[2];
215
+ const f = m, y = a ? u.rowClickable : u.row;
216
+ let g;
217
+ e[3] !== r ? (g = /* @__PURE__ */ h(L, { sx: u.rowLabel, children: r }), e[3] = r, e[4] = g) : g = e[4];
218
+ let w;
219
+ if (e[5] !== n || e[6] !== c || e[7] !== i || e[8] !== r || e[9] !== l || e[10] !== o) {
220
+ let k;
221
+ e[12] !== n || e[13] !== c || e[14] !== i || e[15] !== r || e[16] !== l ? (k = (v, D) => /* @__PURE__ */ R(C, { sx: u.multiBarRow, children: [
222
+ /* @__PURE__ */ h(C, { sx: u.multiBarContainer, children: /* @__PURE__ */ h(J, { value: v, maxValue: i, color: n[D % n.length] ?? "", selected: l }) }),
223
+ /* @__PURE__ */ h(L, { sx: u.multiBarValue, children: c(v) })
224
+ ] }, `${r}-${v}-${D}`), e[12] = n, e[13] = c, e[14] = i, e[15] = r, e[16] = l, e[17] = k) : k = e[17], w = o.map(k), e[5] = n, e[6] = c, e[7] = i, e[8] = r, e[9] = l, e[10] = o, e[11] = w;
225
+ } else
226
+ w = e[11];
227
+ let x;
228
+ e[18] !== w ? (x = /* @__PURE__ */ h(C, { sx: u.barContainer, children: w }), e[18] = w, e[19] = x) : x = e[19];
229
+ let b;
230
+ return e[20] !== f || e[21] !== y || e[22] !== g || e[23] !== x ? (b = /* @__PURE__ */ R(C, { sx: y, onClick: f, children: [
231
+ g,
232
+ x
233
+ ] }), e[20] = f, e[21] = y, e[22] = g, e[23] = x, e[24] = b) : b = e[24], b;
234
+ }
235
+ function te(t) {
236
+ const e = M(10), {
237
+ hiddenCount: r,
238
+ otherLabel: o,
239
+ otherCountLabel: i
240
+ } = t, n = o === void 0 ? "Other" : o, c = i === void 0 ? "{count} more" : i;
241
+ let a;
242
+ e[0] !== r || e[1] !== c ? (a = c.replace("{count}", String(r)), e[0] = r, e[1] = c, e[2] = a) : a = e[2];
243
+ const d = a;
244
+ let l;
245
+ e[3] !== n ? (l = /* @__PURE__ */ h(L, { sx: u.otherLabel, children: n }), e[3] = n, e[4] = l) : l = e[4];
246
+ let m;
247
+ e[5] !== d ? (m = /* @__PURE__ */ R(L, { sx: u.otherCount, children: [
248
+ "(",
249
+ d,
250
+ ")"
251
+ ] }), e[5] = d, e[6] = m) : m = e[6];
252
+ let f;
253
+ return e[7] !== l || e[8] !== m ? (f = /* @__PURE__ */ R(C, { sx: u.otherRow, children: [
254
+ l,
255
+ m
256
+ ] }), e[7] = l, e[8] = m, e[9] = f) : f = e[9], f;
257
+ }
258
+ function oe(t) {
259
+ const e = M(7), {
260
+ series: r,
261
+ colors: o
262
+ } = t;
263
+ if (r.length === 0)
264
+ return null;
265
+ let i;
266
+ if (e[0] !== o || e[1] !== r) {
267
+ let c;
268
+ e[3] !== o ? (c = (a, d) => /* @__PURE__ */ R(C, { sx: u.legendItem, children: [
269
+ /* @__PURE__ */ h(C, { sx: {
270
+ ...u.legendDot,
271
+ backgroundColor: a.color ?? o[d % o.length]
272
+ } }),
273
+ /* @__PURE__ */ h(L, { sx: u.legendLabel, children: a.name })
274
+ ] }, a.name), e[3] = o, e[4] = c) : c = e[4], i = r.map(c), e[0] = o, e[1] = r, e[2] = i;
275
+ } else
276
+ i = e[2];
277
+ let n;
278
+ return e[5] !== i ? (n = /* @__PURE__ */ h(C, { sx: u.legend, children: i }), e[5] = i, e[6] = n) : n = e[6], n;
279
+ }
280
+ const le = (t) => t.toString();
281
+ function we(t) {
282
+ const e = M(46), {
283
+ id: r
284
+ } = t, o = Q();
285
+ let i;
286
+ e[0] !== r ? (i = (s) => {
287
+ const p = s.getWidget(r);
288
+ return {
289
+ formatter: p?.formatter,
290
+ series: p?.series,
291
+ data: p?.data,
292
+ maxItems: p?.maxItems,
293
+ labels: p?.labels,
294
+ onRowClick: p?.onRowClick,
295
+ selected: p?.selected,
296
+ max: p?.max
297
+ };
298
+ }, e[0] = r, e[1] = i) : i = e[1];
299
+ const n = X(Y(i)), c = n?.formatter ?? le;
300
+ n?.series;
301
+ let a;
302
+ e[2] !== n?.series ? (a = n?.series ?? [], e[2] = n?.series, e[3] = a) : a = e[3];
303
+ const d = a, l = n?.data, m = n?.maxItems, f = n?.labels, y = n?.onRowClick, g = n?.selected, w = n?.max;
304
+ let x;
305
+ e[4] !== o.palette.qualitative.bold ? (x = Object.values(o.palette.qualitative.bold), e[4] = o.palette.qualitative.bold, e[5] = x) : x = e[5];
306
+ const b = x;
307
+ let k;
308
+ e: {
309
+ if (d.length > 0) {
310
+ let p;
311
+ if (e[6] !== b || e[7] !== d || e[8] !== o.palette.primary.main) {
312
+ let $;
313
+ e[10] !== b || e[11] !== o.palette.primary.main ? ($ = (_, S) => _.color ?? b[S % b.length] ?? o.palette.primary.main, e[10] = b, e[11] = o.palette.primary.main, e[12] = $) : $ = e[12], p = d.map($), e[6] = b, e[7] = d, e[8] = o.palette.primary.main, e[9] = p;
314
+ } else
315
+ p = e[9];
316
+ k = p;
317
+ break e;
318
+ }
319
+ let s;
320
+ e[13] !== o.palette.primary.main ? (s = [o.palette.primary.main], e[13] = o.palette.primary.main, e[14] = s) : s = e[14], k = s;
321
+ }
322
+ const v = k;
323
+ let D;
324
+ e: {
325
+ if (!l || l.length === 0) {
326
+ let $;
327
+ e[15] === Symbol.for("react.memo_cache_sentinel") ? ($ = [], e[15] = $) : $ = e[15], D = $;
328
+ break e;
329
+ }
330
+ const s = Math.max(l.length, 1);
331
+ let p;
332
+ if (e[16] !== l || e[17] !== s) {
333
+ const $ = /* @__PURE__ */ new Map(), _ = [];
334
+ for (let S = 0; S < l.length; S++) {
335
+ const K = l[S];
336
+ for (const E of K) {
337
+ let P = $.get(E.name);
338
+ P || (P = new Array(s).fill(0), $.set(E.name, P), _.push(E.name)), P[S] = E.value;
339
+ }
340
+ }
341
+ p = _.map((S) => ({
342
+ name: S,
343
+ values: $.get(S)
344
+ })), e[16] = l, e[17] = s, e[18] = p;
345
+ } else
346
+ p = e[18];
347
+ D = p;
348
+ }
349
+ const I = D;
350
+ let j;
351
+ e: {
352
+ if (w !== void 0) {
353
+ j = w;
354
+ break e;
355
+ }
356
+ if (I.length === 0) {
357
+ j = 0;
358
+ break e;
359
+ }
360
+ let s;
361
+ e[19] !== I ? (s = I.flatMap(re), e[19] = I, e[20] = s) : s = e[20], j = Math.max(...s);
362
+ }
363
+ const A = j;
364
+ let O;
365
+ e: {
366
+ if (m === void 0) {
367
+ O = I;
368
+ break e;
369
+ }
370
+ const s = Math.max(0, m);
371
+ if (s >= I.length) {
372
+ O = I;
373
+ break e;
374
+ }
375
+ let p;
376
+ e[21] !== I || e[22] !== s ? (p = I.slice(0, s), e[21] = I, e[22] = s, e[23] = p) : p = e[23], O = p;
377
+ }
378
+ const W = O, q = I.length - W.length;
379
+ if (I.length === 0)
380
+ return null;
381
+ const G = d.length > 1;
382
+ let V;
383
+ e[24] !== v || e[25] !== c || e[26] !== G || e[27] !== A || e[28] !== y || e[29] !== g || e[30] !== o || e[31] !== W ? (V = G ? W.map((s) => /* @__PURE__ */ h(ee, { name: s.name, values: s.values, maxValue: A, colors: v, formatter: c, onClick: y, selected: g?.(s.name) ?? !0 }, s.name)) : W.map((s) => /* @__PURE__ */ h(Z, { name: s.name, value: s.values[0] ?? 0, selected: g?.(s.name) ?? !0, maxValue: A, color: v[0] ?? o.palette.primary.main, formatter: c, onClick: y }, s.name)), e[24] = v, e[25] = c, e[26] = G, e[27] = A, e[28] = y, e[29] = g, e[30] = o, e[31] = W, e[32] = V) : V = e[32];
384
+ let B;
385
+ e[33] !== q || e[34] !== f?.other || e[35] !== f?.otherCount ? (B = q > 0 && /* @__PURE__ */ h(te, { hiddenCount: q, otherLabel: f?.other, otherCountLabel: f?.otherCount }), e[33] = q, e[34] = f?.other, e[35] = f?.otherCount, e[36] = B) : B = e[36];
386
+ let T;
387
+ e[37] !== V || e[38] !== B ? (T = /* @__PURE__ */ R(C, { sx: u.list, children: [
388
+ V,
389
+ B
390
+ ] }), e[37] = V, e[38] = B, e[39] = T) : T = e[39];
391
+ let F;
392
+ e[40] !== v || e[41] !== d ? (F = d.length > 0 && /* @__PURE__ */ h(oe, { series: d, colors: v }), e[40] = v, e[41] = d, e[42] = F) : F = e[42];
393
+ let H;
394
+ return e[43] !== T || e[44] !== F ? (H = /* @__PURE__ */ R(C, { sx: u.root, children: [
395
+ T,
396
+ F
397
+ ] }), e[43] = T, e[44] = F, e[45] = H) : H = e[45], H;
398
+ }
399
+ function re(t) {
400
+ return t.values;
401
+ }
402
+ const ne = [85, 70, 55, 75, 60];
403
+ function ve() {
404
+ const t = M(1);
405
+ let e;
406
+ return t[0] === Symbol.for("react.memo_cache_sentinel") ? (e = /* @__PURE__ */ h(C, { sx: u.list, "aria-label": "Category skeleton", children: Array.from({
407
+ length: 5
408
+ }).map(ie) }), t[0] = e) : e = t[0], e;
409
+ }
410
+ function ie(t, e) {
411
+ return /* @__PURE__ */ R(C, { sx: u.row, children: [
412
+ /* @__PURE__ */ R(C, { sx: u.rowHeader, children: [
413
+ /* @__PURE__ */ h(N, { width: 80, height: 16 }),
414
+ /* @__PURE__ */ h(N, { width: 40, height: 16 })
415
+ ] }),
416
+ /* @__PURE__ */ h(N, { variant: "rectangular", height: 4, sx: {
417
+ borderRadius: 2,
418
+ width: `${ne[e]}%`
419
+ } })
420
+ ] }, e);
421
+ }
422
+ function ke({
423
+ refUI: t,
424
+ series: e
425
+ }) {
426
+ return [{
427
+ ...z,
428
+ modifier: () => z.modifier(t)
429
+ }, {
430
+ ...U,
431
+ modifier: async (r) => {
432
+ if (!r?.length || r[0]?.length === 0)
433
+ return U.modifier([]);
434
+ const o = r.length, i = /* @__PURE__ */ new Map(), n = [];
435
+ for (let l = 0; l < o; l++) {
436
+ const m = r[l];
437
+ for (const f of m) {
438
+ let y = i.get(f.name);
439
+ y || (y = new Array(o).fill(0), i.set(f.name, y), n.push(f.name)), y[l] = f.value;
440
+ }
441
+ }
442
+ const c = n.map((l) => [l, ...i.get(l)]), d = o > 1 ? ["Category", ...e?.map((l) => l.name) ?? Array.from({
443
+ length: o
444
+ }, (l, m) => `Series ${m + 1}`)] : ["Category", "Value"];
445
+ return U.modifier([d, ...c]);
446
+ }
447
+ }];
448
+ }
449
+ function $e() {
450
+ return {
451
+ series: [],
452
+ maxItems: void 0,
453
+ max: void 0
454
+ };
455
+ }
456
+ export {
457
+ J as CategoryBar,
458
+ oe as CategoryLegend,
459
+ ee as CategoryRowMulti,
460
+ te as CategoryRowOther,
461
+ Z as CategoryRowSingle,
462
+ ve as CategorySkeleton,
463
+ we as CategoryUI,
464
+ $e as categoryConfig,
465
+ ke as categoryDownloadConfig
466
+ };
467
+ //# sourceMappingURL=category.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"category.js","sources":["../../src/widgets/category/style.ts","../../src/widgets/category/components/category-bar.tsx","../../src/widgets/category/components/category-row-single.tsx","../../src/widgets/category/components/category-row-multi.tsx","../../src/widgets/category/components/category-row-other.tsx","../../src/widgets/category/components/category-legend.tsx","../../src/widgets/category/category-ui.tsx","../../src/widgets/category/skeleton.tsx","../../src/widgets/category/config.ts"],"sourcesContent":["import type { SxProps, Theme } from '@mui/material'\n\nexport const styles = {\n root: {\n display: 'flex',\n flexDirection: 'column',\n position: 'relative',\n overflow: 'auto',\n },\n list: {\n display: 'flex',\n flexDirection: 'column',\n gap: (theme: Theme) => theme.spacing(1),\n },\n row: {\n display: 'flex',\n flexDirection: 'column',\n gap: (theme: Theme) => theme.spacing(0.5),\n pointerEvents: 'none',\n },\n rowClickable: {\n pointerEvents: 'auto',\n // display: 'flex',\n // flexDirection: 'column',\n // gap: (theme: Theme) => theme.spacing(0.5),\n // cursor: 'pointer',\n // borderRadius: 1,\n // padding: (theme: Theme) => theme.spacing(0.5),\n // margin: (theme: Theme) => theme.spacing(-0.5),\n // transition: 'background-color 0.15s ease-in-out',\n // '&:hover': {\n // backgroundColor: (theme: Theme) => theme.palette.action.hover,\n // },\n },\n rowHeader: {\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n },\n rowLabel: {\n typography: 'body2',\n fontWeight: 'medium',\n color: 'text.primary',\n },\n rowValue: {\n typography: 'body2',\n color: 'text.secondary',\n },\n barContainer: {\n display: 'flex',\n flexDirection: 'column',\n },\n bar: {\n height: 4,\n borderRadius: 2,\n backgroundColor: (theme: Theme) => theme.palette.action.disabledBackground,\n overflow: 'hidden',\n position: 'relative',\n transition: 'background-color 0.15s ease-in-out',\n cursor: 'pointer',\n '&:hover': {\n backgroundColor: (theme: Theme) => theme.palette.action.hover,\n\n '& > div': {\n filter: 'brightness(1.2)',\n },\n },\n },\n barFill: {\n height: '100%',\n borderRadius: 2,\n transition: 'width 0.3s ease-in-out, background-color 0.15s ease-in-out',\n },\n barFillMuted: {\n backgroundColor: (theme: Theme) => theme.palette.action.disabled,\n },\n legend: {\n display: 'flex',\n alignItems: 'center',\n gap: (theme: Theme) => theme.spacing(2),\n flexWrap: 'wrap',\n paddingTop: (theme: Theme) => theme.spacing(2),\n position: 'sticky',\n bottom: 0,\n backgroundColor: 'background.paper',\n borderTop: (theme: Theme) => `1px solid ${theme.palette.divider}`,\n marginTop: (theme: Theme) => theme.spacing(2),\n },\n legendItem: {\n display: 'flex',\n alignItems: 'center',\n gap: (theme: Theme) => theme.spacing(1),\n },\n legendDot: {\n width: 8,\n height: 8,\n borderRadius: '50%',\n },\n legendLabel: {\n typography: 'caption',\n color: 'text.secondary',\n textTransform: 'uppercase',\n fontWeight: 'medium',\n },\n multiBarRow: {\n display: 'flex',\n alignItems: 'center',\n gap: (theme: Theme) => theme.spacing(1),\n },\n multiBarValue: {\n typography: 'body2',\n color: 'text.secondary',\n minWidth: 48,\n textAlign: 'right',\n },\n multiBarContainer: {\n flex: 1,\n },\n otherRow: {\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n },\n otherLabel: {\n typography: 'body2',\n fontWeight: 'medium',\n color: 'text.secondary',\n fontStyle: 'italic',\n },\n otherCount: {\n typography: 'body2',\n color: 'text.disabled',\n },\n} satisfies Record<string, SxProps<Theme>>\n","import { Box } from '@mui/material'\nimport { styles } from '../style'\n\nexport interface CategoryBarProps {\n value: number\n maxValue: number\n color: string\n selected?: boolean\n}\n\nexport function CategoryBar({\n value,\n maxValue,\n color,\n selected = true,\n}: CategoryBarProps) {\n const percentage = maxValue > 0 ? (value / maxValue) * 100 : 0\n\n const barFillSx = selected\n ? { ...styles.barFill, width: `${percentage}%`, backgroundColor: color }\n : { ...styles.barFill, ...styles.barFillMuted, width: `${percentage}%` }\n\n return (\n <Box sx={styles.bar}>\n <Box sx={barFillSx} />\n </Box>\n )\n}\n","import { Box, Typography } from '@mui/material'\nimport { styles } from '../style'\nimport { CategoryBar } from './category-bar'\nimport type { CategoryWidgetConfig } from '../types'\n\nexport interface CategoryRowSingleProps {\n name: string\n value: number\n maxValue: number\n color: string\n formatter: NonNullable<CategoryWidgetConfig['formatter']>\n onClick?: CategoryWidgetConfig['onRowClick']\n selected?: boolean\n}\n\nexport function CategoryRowSingle({\n name,\n value,\n maxValue,\n color,\n formatter,\n onClick,\n selected = true,\n}: CategoryRowSingleProps) {\n const handleClick = onClick\n ? () =>\n onClick({\n name,\n })\n : undefined\n const rowStyle = onClick ? styles.rowClickable : styles.row\n\n return (\n <Box sx={rowStyle} onClick={handleClick}>\n <Box sx={styles.rowHeader}>\n <Typography sx={styles.rowLabel}>{name}</Typography>\n <Typography sx={styles.rowValue}>{formatter(value)}</Typography>\n </Box>\n <CategoryBar\n value={value}\n maxValue={maxValue}\n color={color}\n selected={selected}\n />\n </Box>\n )\n}\n","import { Box, Typography } from '@mui/material'\nimport { styles } from '../style'\nimport { CategoryBar } from './category-bar'\nimport type { CategoryWidgetConfig } from '../types'\n\nexport interface CategoryRowMultiProps {\n name: string\n values: number[]\n maxValue: number\n colors: string[]\n formatter: NonNullable<CategoryWidgetConfig['formatter']>\n onClick?: CategoryWidgetConfig['onRowClick']\n selected?: boolean\n}\n\nexport function CategoryRowMulti({\n name,\n values,\n maxValue,\n colors,\n formatter,\n onClick,\n selected = true,\n}: CategoryRowMultiProps) {\n const handleClick = onClick ? () => onClick({ name }) : undefined\n const rowStyle = onClick ? styles.rowClickable : styles.row\n\n return (\n <Box sx={rowStyle} onClick={handleClick}>\n <Typography sx={styles.rowLabel}>{name}</Typography>\n <Box sx={styles.barContainer}>\n {values.map((value, index) => (\n <Box key={`${name}-${value}-${index}`} sx={styles.multiBarRow}>\n <Box sx={styles.multiBarContainer}>\n <CategoryBar\n value={value}\n maxValue={maxValue}\n color={colors[index % colors.length] ?? ''}\n selected={selected}\n />\n </Box>\n <Typography sx={styles.multiBarValue}>\n {formatter(value)}\n </Typography>\n </Box>\n ))}\n </Box>\n </Box>\n )\n}\n","import { Box, Typography } from '@mui/material'\nimport { styles } from '../style'\n\nexport interface CategoryRowOtherProps {\n hiddenCount: number\n otherLabel?: string\n otherCountLabel?: string\n}\n\nexport function CategoryRowOther({\n hiddenCount,\n otherLabel = 'Other',\n otherCountLabel = '{count} more',\n}: CategoryRowOtherProps) {\n const countText = otherCountLabel.replace('{count}', String(hiddenCount))\n\n return (\n <Box sx={styles.otherRow}>\n <Typography sx={styles.otherLabel}>{otherLabel}</Typography>\n <Typography sx={styles.otherCount}>({countText})</Typography>\n </Box>\n )\n}\n","import { Box, Typography } from '@mui/material'\nimport { styles } from '../style'\nimport type { CategorySeriesConfig } from '../types'\n\nexport interface CategoryLegendProps {\n series: CategorySeriesConfig[]\n colors: string[]\n}\n\nexport function CategoryLegend({ series, colors }: CategoryLegendProps) {\n if (series.length === 0) {\n return null\n }\n\n return (\n <Box sx={styles.legend}>\n {series.map((item, index) => (\n <Box key={item.name} sx={styles.legendItem}>\n <Box\n sx={{\n ...styles.legendDot,\n backgroundColor: item.color ?? colors[index % colors.length],\n }}\n />\n <Typography sx={styles.legendLabel}>{item.name}</Typography>\n </Box>\n ))}\n </Box>\n )\n}\n","import { Box, useTheme } from '@mui/material'\nimport { useMemo } from 'react'\nimport { useWidgetStore } from '../stores/widget-store'\nimport { styles } from './style'\nimport type { CategoryUIProps, CategoryWidgetState } from './types'\nimport {\n CategoryRowSingle,\n CategoryRowMulti,\n CategoryRowOther,\n CategoryLegend,\n} from './components'\nimport { useShallow } from 'zustand/shallow'\n\nconst defaultFormatter = (value: number) => value.toString()\n\ninterface GroupedCategoryItem {\n name: string\n values: number[]\n}\n\nexport function CategoryUI({ id }: CategoryUIProps) {\n const theme = useTheme()\n const widget = useWidgetStore(\n useShallow((state) => {\n const widget = state.getWidget<CategoryWidgetState>(id)\n return {\n formatter: widget?.formatter,\n series: widget?.series,\n data: widget?.data,\n maxItems: widget?.maxItems,\n labels: widget?.labels,\n onRowClick: widget?.onRowClick,\n selected: widget?.selected,\n max: widget?.max,\n }\n }),\n )\n\n const formatter = widget?.formatter ?? defaultFormatter\n const series = useMemo(() => widget?.series ?? [], [widget?.series])\n const data = widget?.data\n const maxItems = widget?.maxItems\n const labels = widget?.labels\n const onRowClick = widget?.onRowClick\n const selected = widget?.selected\n const max = widget?.max\n\n const qualitativeColors = useMemo(\n () => Object.values(theme.palette.qualitative.bold),\n [theme.palette.qualitative.bold],\n )\n\n const colors = useMemo((): string[] => {\n if (series.length > 0) {\n return series.map(\n (s, index: number) =>\n s.color ??\n qualitativeColors[index % qualitativeColors.length] ??\n theme.palette.primary.main,\n )\n }\n return [theme.palette.primary.main]\n }, [series, theme.palette.primary.main, qualitativeColors])\n\n // Group data items by name to support multi-series display\n // data is CategoryDataItem[][] where data[seriesIndex] contains items for that series\n const groupedData = useMemo((): GroupedCategoryItem[] => {\n if (!data || data.length === 0) return []\n\n const seriesCount = Math.max(data.length, 1)\n const grouped = new Map<string, number[]>()\n const nameOrder: string[] = []\n\n // Iterate over each series (outer array)\n for (let seriesIndex = 0; seriesIndex < data.length; seriesIndex++) {\n const seriesData = data[seriesIndex]!\n for (const item of seriesData) {\n let values = grouped.get(item.name)\n if (!values) {\n values = new Array<number>(seriesCount).fill(0)\n grouped.set(item.name, values)\n nameOrder.push(item.name)\n }\n values[seriesIndex] = item.value\n }\n }\n\n return nameOrder.map((name) => ({\n name,\n values: grouped.get(name)!,\n }))\n }, [data])\n\n const maxValue = useMemo(() => {\n // If max is explicitly configured, use it\n if (max !== undefined) {\n return max\n }\n\n // Otherwise, calculate from data (existing behavior)\n if (groupedData.length === 0) return 0\n return Math.max(...groupedData.flatMap((item) => item.values))\n }, [max, groupedData])\n\n // Slice data to maxItems and compute hidden count\n const visibleData = useMemo(() => {\n if (maxItems === undefined) {\n return groupedData\n }\n const limit = Math.max(0, maxItems)\n if (limit >= groupedData.length) {\n return groupedData\n }\n return groupedData.slice(0, limit)\n }, [groupedData, maxItems])\n\n const hiddenCount = groupedData.length - visibleData.length\n\n if (groupedData.length === 0) {\n return null\n }\n\n const isMulti = series.length > 1\n\n return (\n <Box sx={styles.root}>\n <Box sx={styles.list}>\n {isMulti\n ? visibleData.map((item) => (\n <CategoryRowMulti\n key={item.name}\n name={item.name}\n values={item.values}\n maxValue={maxValue}\n colors={colors}\n formatter={formatter}\n onClick={onRowClick}\n selected={selected?.(item.name) ?? true}\n />\n ))\n : visibleData.map((item) => (\n <CategoryRowSingle\n key={item.name}\n name={item.name}\n value={item.values[0] ?? 0}\n selected={selected?.(item.name) ?? true}\n maxValue={maxValue}\n color={colors[0] ?? theme.palette.primary.main}\n formatter={formatter}\n onClick={onRowClick}\n />\n ))}\n {hiddenCount > 0 && (\n <CategoryRowOther\n hiddenCount={hiddenCount}\n otherLabel={labels?.other}\n otherCountLabel={labels?.otherCount}\n />\n )}\n </Box>\n {series.length > 0 && <CategoryLegend series={series} colors={colors} />}\n </Box>\n )\n}\n","import { Box, Skeleton } from '@mui/material'\nimport { styles } from './style'\n\nconst widthPatterns = [85, 70, 55, 75, 60]\n\nexport function CategorySkeleton() {\n return (\n <Box sx={styles.list} aria-label='Category skeleton'>\n {Array.from({ length: 5 }).map((_, index) => (\n <Box key={index} sx={styles.row}>\n <Box sx={styles.rowHeader}>\n <Skeleton width={80} height={16} />\n <Skeleton width={40} height={16} />\n </Box>\n <Skeleton\n variant='rectangular'\n height={4}\n sx={{ borderRadius: 2, width: `${widthPatterns[index]}%` }}\n />\n </Box>\n ))}\n </Box>\n )\n}\n","import { downloadToCSV, downloadToPNG, type DownloadItem } from '../actions'\nimport type { ConfigProps } from '../loader/types'\nimport type {\n CategoryWidgetConfig,\n CategoryWidgetData,\n CategorySeriesConfig,\n CategoryLabels,\n} from './types'\n\nexport interface CategoryDownloadConfigProps extends ConfigProps {\n series?: CategorySeriesConfig[]\n}\n\nexport interface CategoryConfigProps {\n data?: CategoryWidgetData\n series?: CategorySeriesConfig[]\n formatter?: (value: number) => string\n maxItems?: number\n labels?: CategoryLabels\n max?: number\n}\n\nexport function categoryDownloadConfig({\n refUI,\n series,\n}: CategoryDownloadConfigProps): DownloadItem<CategoryWidgetData>[] {\n return [\n {\n ...downloadToPNG,\n modifier: () => downloadToPNG.modifier(refUI),\n },\n {\n ...downloadToCSV,\n modifier: async (data) => {\n if (!data?.length || data[0]?.length === 0) {\n return downloadToCSV.modifier([])\n }\n\n // data is CategoryDataItem[][] where data[seriesIndex] contains items for that series\n const seriesCount = data.length\n const grouped = new Map<string, number[]>()\n const nameOrder: string[] = []\n\n // Iterate over each series (outer array)\n for (let seriesIndex = 0; seriesIndex < seriesCount; seriesIndex++) {\n const seriesData = data[seriesIndex]!\n for (const item of seriesData) {\n let values = grouped.get(item.name)\n if (!values) {\n values = new Array<number>(seriesCount).fill(0)\n grouped.set(item.name, values)\n nameOrder.push(item.name)\n }\n values[seriesIndex] = item.value\n }\n }\n\n // Build rows\n const rows = nameOrder.map((name) => [name, ...grouped.get(name)!])\n\n const isMulti = seriesCount > 1\n const headers = isMulti\n ? [\n 'Category',\n ...(series?.map((s: CategorySeriesConfig) => s.name) ??\n Array.from(\n { length: seriesCount },\n (_, i) => `Series ${i + 1}`,\n )),\n ]\n : ['Category', 'Value']\n\n return downloadToCSV.modifier([headers, ...rows])\n },\n },\n ]\n}\n\nexport function categoryConfig(): CategoryWidgetConfig {\n return {\n series: [],\n maxItems: undefined,\n max: undefined,\n }\n}\n"],"names":["styles","root","display","flexDirection","position","overflow","list","gap","theme","spacing","row","pointerEvents","rowClickable","rowHeader","justifyContent","alignItems","rowLabel","typography","fontWeight","color","rowValue","barContainer","bar","height","borderRadius","backgroundColor","palette","action","disabledBackground","transition","cursor","hover","filter","barFill","barFillMuted","disabled","legend","flexWrap","paddingTop","bottom","borderTop","divider","marginTop","legendItem","legendDot","width","legendLabel","textTransform","multiBarRow","multiBarValue","minWidth","textAlign","multiBarContainer","flex","otherRow","otherLabel","fontStyle","otherCount","CategoryBar","t0","$","_c","value","maxValue","selected","t1","undefined","percentage","t2","barFillSx","t3","jsx","Box","CategoryRowSingle","name","formatter","onClick","handleClick","rowStyle","Typography","t4","t5","t6","t7","t8","jsxs","CategoryRowMulti","values","colors","index","length","map","CategoryRowOther","hiddenCount","otherCountLabel","replace","String","countText","CategoryLegend","series","item","defaultFormatter","toString","CategoryUI","id","useTheme","state","widget","getWidget","data","maxItems","labels","onRowClick","max","widget_0","useWidgetStore","useShallow","qualitative","bold","Object","qualitativeColors","bb0","primary","main","s","bb1","Symbol","for","seriesCount","Math","grouped","Map","nameOrder","seriesIndex","seriesData","get","Array","fill","set","push","groupedData","bb2","flatMap","_temp","bb3","limit","slice","visibleData","isMulti","item_1","item_2","t9","other","t10","t11","t12","item_0","widthPatterns","CategorySkeleton","from","_","Skeleton","categoryDownloadConfig","refUI","downloadToPNG","modifier","downloadToCSV","rows","headers","i","categoryConfig"],"mappings":"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"}
@@ -1,11 +1,123 @@
1
- import { E as g, a as o, g as r, b as s, c as e, d as C, m as h } from "../echart-CqfROFu3.js";
1
+ import { jsx as j } from "react/jsx-runtime";
2
+ import { c as U } from "react/compiler-runtime";
3
+ import { useRef as I, useEffect as h, useImperativeHandle as $ } from "react";
4
+ import * as B from "echarts";
5
+ import { u as k } from "../widget-store-CB6Trp_0.js";
6
+ import { useShallow as D } from "zustand/shallow";
7
+ import { g as Q } from "../options-D9wflre6.js";
8
+ import { g as V, a as X, b as Y, m as ee } from "../utils-Dv5Z47UQ.js";
9
+ function H(t) {
10
+ const e = U(21), {
11
+ id: r,
12
+ ref: i,
13
+ init: c,
14
+ option: l,
15
+ className: o,
16
+ style: a,
17
+ onEvents: d
18
+ } = t, u = I(null), n = I(null), f = I(null), m = k(N);
19
+ let s, v;
20
+ e[0] !== r || e[1] !== m ? (s = () => {
21
+ m(r, {
22
+ refUI: u
23
+ });
24
+ }, v = [r, m], e[0] = r, e[1] = m, e[2] = s, e[3] = v) : (s = e[2], v = e[3]), h(s, v);
25
+ let E, p;
26
+ e[4] === Symbol.for("react.memo_cache_sentinel") ? (E = () => n.current, p = [], e[4] = E, e[5] = p) : (E = e[4], p = e[5]), $(i, E, p);
27
+ let b, C;
28
+ e[6] !== c ? (b = () => {
29
+ if (u.current)
30
+ return n.current = B.init(u.current, null, {
31
+ renderer: "svg",
32
+ height: 304,
33
+ ...c
34
+ }), () => {
35
+ n.current?.dispose(), n.current = null;
36
+ };
37
+ }, C = [c], e[6] = c, e[7] = b, e[8] = C) : (b = e[7], C = e[8]), h(b, C);
38
+ let _, O;
39
+ e[9] !== l ? (_ = () => {
40
+ n.current?.setOption(l, {
41
+ lazyUpdate: !0
42
+ });
43
+ }, O = [l], e[9] = l, e[10] = _, e[11] = O) : (_ = e[10], O = e[11]), h(_, O);
44
+ let S, y;
45
+ e[12] === Symbol.for("react.memo_cache_sentinel") ? (y = () => {
46
+ const g = () => {
47
+ n.current?.resize();
48
+ };
49
+ return f.current = new ResizeObserver(g), f.current.observe(u.current), () => {
50
+ f.current?.disconnect(), f.current = null;
51
+ };
52
+ }, S = [], e[12] = S, e[13] = y) : (S = e[12], y = e[13]), h(y, S);
53
+ let z, R;
54
+ e[14] !== d ? (z = () => {
55
+ const g = {
56
+ ...d ?? {}
57
+ };
58
+ return g.click || (g.mousemove = () => {
59
+ n.current?.getZr().setCursorStyle("default");
60
+ }), Object.entries(g).forEach((w) => {
61
+ const [x, Z] = w;
62
+ n.current?.on(x, Z);
63
+ }), () => {
64
+ Object.entries(g).forEach((w) => {
65
+ const [x] = w;
66
+ n.current?.off(x);
67
+ });
68
+ };
69
+ }, R = [d], e[14] = d, e[15] = z, e[16] = R) : (z = e[15], R = e[16]), h(z, R);
70
+ let W;
71
+ return e[17] !== o || e[18] !== r || e[19] !== a ? (W = /* @__PURE__ */ j("div", { id: r, ref: u, style: a, className: o }), e[17] = o, e[18] = r, e[19] = a, e[20] = W) : W = e[20], W;
72
+ }
73
+ function N(t) {
74
+ return t.setWidget;
75
+ }
76
+ function L(t) {
77
+ const e = U(14);
78
+ let r;
79
+ e[0] !== t.id ? (r = (m) => {
80
+ const s = m.getWidget(t.id);
81
+ return {
82
+ id: s?.id,
83
+ data: s?.data,
84
+ option: s?.option,
85
+ onEvents: s?.onEvents,
86
+ init: s?.init
87
+ };
88
+ }, e[0] = t.id, e[1] = r) : r = e[1];
89
+ const i = k(D(r));
90
+ let c;
91
+ e[2] !== i.data ? (c = q(i.data), e[2] = i.data, e[3] = c) : c = e[3];
92
+ const l = c;
93
+ if (!i.id)
94
+ return null;
95
+ let o;
96
+ e[4] !== l ? (o = l && {
97
+ dataset: l
98
+ }, e[4] = l, e[5] = o) : o = e[5];
99
+ let a;
100
+ e[6] !== o || e[7] !== i.option ? (a = {
101
+ ...i.option,
102
+ ...o
103
+ }, e[6] = o, e[7] = i.option, e[8] = a) : a = e[8];
104
+ const d = a, u = i.onEvents, n = i.init;
105
+ let f;
106
+ return e[9] !== n || e[10] !== u || e[11] !== d || e[12] !== t.id ? (f = /* @__PURE__ */ j(H, { id: t.id, option: d, onEvents: u, init: n }), e[9] = n, e[10] = u, e[11] = d, e[12] = t.id, e[13] = f) : f = e[13], f;
107
+ }
108
+ function q(t) {
109
+ if (!(!t || t.length === 0))
110
+ return t.map((e) => ({
111
+ source: e
112
+ }));
113
+ }
2
114
  export {
3
- g as Echart,
4
- o as EchartUI,
5
- r as getCommonOptions,
6
- s as getEChartBrushConfig,
7
- e as getEChartStackConfig,
8
- C as getEChartZoomConfig,
9
- h as mergeWidgetConfig
115
+ L as Echart,
116
+ H as EchartUI,
117
+ Q as getCommonOptions,
118
+ V as getEChartBrushConfig,
119
+ X as getEChartStackConfig,
120
+ Y as getEChartZoomConfig,
121
+ ee as mergeEchartWidgetConfig
10
122
  };
11
123
  //# sourceMappingURL=echart.js.map