@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
@@ -1,7 +1,217 @@
1
- import { p } from "../const-BLV7Tvte.js";
2
- import { PieSkeleton as f } from "../skeleton-DsZhv-AH.js";
1
+ import { jsxs as c, jsx as r } from "react/jsx-runtime";
2
+ import { c as x } from "react/compiler-runtime";
3
+ import "react";
4
+ import "echarts";
5
+ import "../widget-store-CB6Trp_0.js";
6
+ import "zustand/shallow";
7
+ import { g as y } from "../options-D9wflre6.js";
8
+ import { m as _ } from "../utils-Dv5Z47UQ.js";
9
+ import { f as S, b as w, a as I, d as v } from "../styles-dOu_pRNb.js";
10
+ import { Box as l, Skeleton as a } from "@mui/material";
11
+ import "@mui/icons-material";
12
+ import "react-markdown";
13
+ import { d as f, a as g } from "../exports-Cr43OCul.js";
14
+ import "../lasso-tool-CYn3ivf-.js";
15
+ import "../cjs-D9ro6BXv.js";
16
+ import "@dnd-kit/core";
17
+ import "@dnd-kit/sortable";
18
+ import "@dnd-kit/utilities";
19
+ function Y({
20
+ refUI: e
21
+ }) {
22
+ return [{
23
+ ...f,
24
+ modifier: () => f.modifier(e)
25
+ }, {
26
+ ...g,
27
+ modifier: async (t) => {
28
+ const o = S(t);
29
+ return g.modifier(o);
30
+ }
31
+ }];
32
+ }
33
+ function ee(e) {
34
+ return {
35
+ type: "pie",
36
+ option: _(y(e), C(e))
37
+ };
38
+ }
39
+ function C({
40
+ data: e = [],
41
+ theme: t
42
+ }) {
43
+ if ((e?.length ?? 0) > 1)
44
+ return {
45
+ xAxis: {
46
+ type: "value",
47
+ show: !0
48
+ },
49
+ yAxis: {
50
+ type: "category",
51
+ show: !0
52
+ },
53
+ legend: {
54
+ show: !0,
55
+ bottom: 0
56
+ },
57
+ grid: {
58
+ bottom: parseInt(t.spacing(4)),
59
+ right: parseInt(t.spacing(4))
60
+ },
61
+ series: e.map((s, i) => ({
62
+ datasetIndex: i,
63
+ type: "bar",
64
+ barMaxWidth: 100,
65
+ emphasis: {
66
+ focus: "series"
67
+ }
68
+ }))
69
+ };
70
+ const n = !0;
71
+ return {
72
+ legend: I(n),
73
+ grid: {
74
+ ...w(n, t),
75
+ left: 0,
76
+ top: 0,
77
+ right: 0
78
+ },
79
+ xAxis: {
80
+ show: !1
81
+ },
82
+ yAxis: {
83
+ show: !1
84
+ },
85
+ tooltip: {
86
+ trigger: "item"
87
+ },
88
+ color: Object.values(t.palette.qualitative.bold),
89
+ series: e.map((s, i) => ({
90
+ datasetIndex: i,
91
+ type: "pie",
92
+ colorBy: "data",
93
+ radius: ["74%", "90%"],
94
+ avoidLabelOverlap: !0,
95
+ selectedOffset: 0,
96
+ bottom: parseInt(t.spacing(4)),
97
+ label: {
98
+ show: !0,
99
+ position: "center",
100
+ formatter: (p) => {
101
+ const {
102
+ name: b
103
+ } = p, d = p.encode?.value?.[0];
104
+ return d === void 0 ? "" : `{c|${Object.values(p.data ?? {}).at(d) ?? ""}}
105
+
106
+ {b|${b}}`;
107
+ },
108
+ rich: {
109
+ b: {
110
+ fontSize: 16,
111
+ fontWeight: "normal",
112
+ lineHeight: 20
113
+ },
114
+ c: {
115
+ fontSize: 28,
116
+ fontWeight: "bold",
117
+ lineHeight: 27
118
+ }
119
+ }
120
+ },
121
+ emphasis: {
122
+ disabled: !0
123
+ },
124
+ itemStyle: {
125
+ borderColor: t.palette.background.paper,
126
+ borderWidth: 1
127
+ }
128
+ }))
129
+ };
130
+ }
131
+ const j = {
132
+ skeleton: {
133
+ graph: v.graph
134
+ }
135
+ }, h = 32, m = 294 - h, u = m - h;
136
+ function te() {
137
+ const e = x(5);
138
+ let t, o;
139
+ e[0] === Symbol.for("react.memo_cache_sentinel") ? (t = {
140
+ display: "flex",
141
+ alignItems: "center",
142
+ justifyContent: "center",
143
+ position: "relative"
144
+ }, o = /* @__PURE__ */ r(a, { variant: "circular", width: m, height: m }), e[0] = t, e[1] = o) : (t = e[0], o = e[1]);
145
+ let n;
146
+ e[2] === Symbol.for("react.memo_cache_sentinel") ? (n = /* @__PURE__ */ r(a, { sx: {
147
+ position: "absolute",
148
+ zIndex: 1
149
+ }, variant: "circular", width: u, height: u }), e[2] = n) : n = e[2];
150
+ let s;
151
+ e[3] === Symbol.for("react.memo_cache_sentinel") ? (s = /* @__PURE__ */ c(l, { sx: t, children: [
152
+ o,
153
+ n,
154
+ /* @__PURE__ */ c(l, { sx: {
155
+ position: "absolute",
156
+ zIndex: 2,
157
+ display: "flex",
158
+ flexDirection: "column",
159
+ alignItems: "center",
160
+ justifyContent: "center",
161
+ gap: T
162
+ }, children: [
163
+ /* @__PURE__ */ r(a, { height: 24, width: 72 }),
164
+ /* @__PURE__ */ r(a, { height: 8, width: 48 })
165
+ ] })
166
+ ] }), e[3] = s) : s = e[3];
167
+ let i;
168
+ return e[4] === Symbol.for("react.memo_cache_sentinel") ? (i = /* @__PURE__ */ c(l, { sx: j.skeleton.graph.container, children: [
169
+ s,
170
+ /* @__PURE__ */ r(l, { sx: {
171
+ display: "flex",
172
+ alignItems: "center",
173
+ gap: E,
174
+ height: A
175
+ }, children: Array(2).fill(0).map(O) })
176
+ ] }), e[4] = i) : i = e[4], i;
177
+ }
178
+ function O(e, t) {
179
+ return /* @__PURE__ */ c(l, { sx: {
180
+ display: "flex",
181
+ alignItems: "center",
182
+ gap: k
183
+ }, children: [
184
+ /* @__PURE__ */ r(a, { variant: "circular", width: 8, height: 8 }),
185
+ /* @__PURE__ */ r(a, { width: 48, height: 8 })
186
+ ] }, t);
187
+ }
188
+ function k(e) {
189
+ const {
190
+ spacing: t
191
+ } = e;
192
+ return t(1.5);
193
+ }
194
+ function A(e) {
195
+ const {
196
+ spacing: t
197
+ } = e;
198
+ return t(5);
199
+ }
200
+ function E(e) {
201
+ const {
202
+ spacing: t
203
+ } = e;
204
+ return t(2);
205
+ }
206
+ function T(e) {
207
+ const {
208
+ spacing: t
209
+ } = e;
210
+ return t(1);
211
+ }
3
212
  export {
4
- f as PieSkeleton,
5
- p as pieConfig
213
+ te as PieSkeleton,
214
+ ee as pieConfig,
215
+ Y as pieDownloadConfig
6
216
  };
7
217
  //# sourceMappingURL=pie.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"pie.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
1
+ {"version":3,"file":"pie.js","sources":["../../src/widgets/pie/config.ts","../../src/widgets/pie/style.ts","../../src/widgets/pie/skeleton.tsx"],"sourcesContent":["import {\n getCommonOptions,\n mergeEchartWidgetConfig,\n type EchartOptionsProps,\n} from '../echart'\nimport type { PieConfig, PieWidgetConfig, PieWidgetData } from './types'\nimport {\n buildGridConfig,\n buildLegendConfig,\n flattenObjectArrayToCSV,\n} from '../_shared/chart-config'\nimport { downloadToCSV, downloadToPNG, type DownloadItem } from '../actions'\nimport type { ConfigProps } from '../loader/types'\n\nexport function pieDownloadConfig({\n refUI,\n}: ConfigProps): DownloadItem<PieWidgetData>[] {\n return [\n {\n ...downloadToPNG,\n modifier: () => downloadToPNG.modifier(refUI),\n },\n {\n ...downloadToCSV,\n modifier: async (data) => {\n const rows = flattenObjectArrayToCSV(data)\n return downloadToCSV.modifier(rows)\n },\n },\n ]\n}\n\nexport function pieConfig(props: PieConfig): PieWidgetConfig {\n return {\n type: 'pie',\n option: mergeEchartWidgetConfig(getCommonOptions(props), getOption(props)),\n }\n}\n\nfunction getOption({ data = [], theme }: PieConfig): EchartOptionsProps {\n const multiSeries = (data?.length ?? 0) > 1\n\n if (multiSeries) {\n return {\n xAxis: {\n type: 'value',\n show: true,\n },\n yAxis: {\n type: 'category',\n show: true,\n },\n legend: {\n show: true,\n bottom: 0,\n },\n grid: {\n bottom: parseInt(theme.spacing(4)),\n right: parseInt(theme.spacing(4)),\n },\n series: data.map((_: unknown, index: number) => ({\n datasetIndex: index,\n type: 'bar',\n barMaxWidth: 100,\n emphasis: {\n focus: 'series',\n },\n })),\n }\n }\n\n const hasLegend = true\n\n return {\n legend: buildLegendConfig(hasLegend),\n grid: {\n ...buildGridConfig(hasLegend, theme),\n left: 0,\n top: 0,\n right: 0,\n },\n xAxis: {\n show: false,\n },\n yAxis: {\n show: false,\n },\n tooltip: {\n trigger: 'item',\n },\n color: Object.values(theme.palette.qualitative.bold),\n series: data.map((_: unknown, index: number) => ({\n datasetIndex: index,\n type: 'pie',\n colorBy: 'data',\n radius: ['74%', '90%'],\n avoidLabelOverlap: true,\n selectedOffset: 0,\n bottom: parseInt(theme.spacing(4)),\n\n label: {\n show: true,\n position: 'center',\n formatter: (params) => {\n const { name } = params\n const encodeIndex = params.encode?.value?.[0]\n if (encodeIndex === undefined) {\n return ''\n }\n\n const value = Object.values(params.data ?? {}).at(encodeIndex) as\n | number\n | string\n\n const formattedValue = value ?? ''\n\n const nameFormatted = name\n\n return `{c|${formattedValue}}\\n\\n{b|${nameFormatted}}`\n },\n rich: {\n b: {\n fontSize: 16,\n fontWeight: 'normal',\n lineHeight: 20,\n },\n c: {\n fontSize: 28,\n fontWeight: 'bold',\n lineHeight: 27,\n },\n },\n },\n emphasis: {\n disabled: true,\n },\n itemStyle: {\n borderColor: theme.palette.background.paper,\n borderWidth: 1,\n },\n })),\n } as EchartOptionsProps\n}\n","import type { SxProps, Theme } from '@mui/material'\nimport { baseSkeletonStyles } from '../_shared/skeleton'\n\nexport const styles = {\n skeleton: {\n graph: baseSkeletonStyles.graph,\n },\n} satisfies Record<string, SxProps<Theme>>\n","import { Box, Skeleton } from '@mui/material'\nimport { styles } from './style'\n\nconst GUTTER = 32\nconst SIZE = 294 - GUTTER\nconst INNER_SIZE = SIZE - GUTTER\n\nexport function PieSkeleton() {\n return (\n <Box sx={styles.skeleton.graph.container}>\n <Box\n sx={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n position: 'relative',\n }}\n >\n <Skeleton variant='circular' width={SIZE} height={SIZE} />\n <Skeleton\n sx={{\n position: 'absolute',\n zIndex: 1,\n }}\n variant='circular'\n width={INNER_SIZE}\n height={INNER_SIZE}\n />\n <Box\n sx={{\n position: 'absolute',\n zIndex: 2,\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n gap: ({ spacing }) => spacing(1),\n }}\n >\n <Skeleton height={24} width={72} />\n <Skeleton height={8} width={48} />\n </Box>\n </Box>\n <Box\n sx={{\n display: 'flex',\n alignItems: 'center',\n gap: ({ spacing }) => spacing(2),\n height: ({ spacing }) => spacing(5),\n }}\n >\n {Array(2)\n .fill(0)\n .map((_, i) => (\n <Box\n key={i}\n sx={{\n display: 'flex',\n alignItems: 'center',\n gap: ({ spacing }) => spacing(1.5),\n }}\n >\n <Skeleton variant='circular' width={8} height={8} />\n <Skeleton width={48} height={8} />\n </Box>\n ))}\n </Box>\n </Box>\n )\n}\n"],"names":["pieDownloadConfig","refUI","downloadToPNG","modifier","downloadToCSV","data","rows","flattenObjectArrayToCSV","pieConfig","props","type","option","mergeEchartWidgetConfig","getCommonOptions","getOption","theme","length","xAxis","show","yAxis","legend","bottom","grid","parseInt","spacing","right","series","map","_","index","datasetIndex","barMaxWidth","emphasis","focus","hasLegend","buildLegendConfig","buildGridConfig","left","top","tooltip","trigger","color","Object","values","palette","qualitative","bold","colorBy","radius","avoidLabelOverlap","selectedOffset","label","position","formatter","params","name","encodeIndex","encode","value","undefined","at","rich","b","fontSize","fontWeight","lineHeight","c","disabled","itemStyle","borderColor","background","paper","borderWidth","styles","skeleton","graph","baseSkeletonStyles","GUTTER","SIZE","INNER_SIZE","PieSkeleton","$","_c","t0","t1","Symbol","for","display","alignItems","justifyContent","Skeleton","t2","jsx","zIndex","t3","Box","jsxs","flexDirection","gap","_temp","t4","container","_temp2","height","_temp3","Array","fill","_temp5","i","_temp4","spacing_2","spacing_1","spacing_0"],"mappings":"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"}
@@ -1,19 +1,217 @@
1
- import { a as r, R as g } from "../range-ui-CtUX11Xm.js";
2
- import { RangeSkeleton as s } from "../skeleton-QVDdb1c2.js";
3
- function n(e) {
1
+ import { jsx as g, jsxs as P } from "react/jsx-runtime";
2
+ import { c as j } from "react/compiler-runtime";
3
+ import { R as Z } from "../row-DrHwXNvF.js";
4
+ import { Box as $, Slider as ee, TextField as te, Skeleton as G } from "@mui/material";
5
+ import { useState as Q } from "react";
6
+ import { u as H } from "../widget-store-CB6Trp_0.js";
7
+ import { useShallow as ne } from "zustand/shallow";
8
+ const _ = {
9
+ rangeItem: {
10
+ display: "flex",
11
+ flexDirection: "column",
12
+ gap: (n) => n.spacing(1.5)
13
+ },
14
+ sliderContainer: {
15
+ display: "flex",
16
+ flexDirection: "column",
17
+ gap: (n) => n.spacing(1),
18
+ px: (n) => n.spacing(1)
19
+ },
20
+ inputsRow: {
21
+ display: "flex",
22
+ gap: (n) => n.spacing(2),
23
+ alignItems: "center"
24
+ },
25
+ input: {
26
+ flex: 1,
27
+ "& .MuiInputBase-input": {
28
+ textAlign: "center"
29
+ }
30
+ },
31
+ slider: {
32
+ width: "100%",
33
+ "&.Mui-disabled": {
34
+ color: (n) => n.palette.text.disabled
35
+ }
36
+ }
37
+ }, ie = (n) => n.toString();
38
+ function ae(n) {
39
+ const e = j(63), {
40
+ id: i,
41
+ index: a
42
+ } = n;
43
+ let r;
44
+ e[0] !== i || e[1] !== a ? (r = (f) => {
45
+ const s = f.getWidget(i);
46
+ return {
47
+ item: s?.data[a],
48
+ onChange: s?.onChange,
49
+ formatter: s?.formatter
50
+ };
51
+ }, e[0] = i, e[1] = a, e[2] = r) : r = e[2];
52
+ const {
53
+ item: t,
54
+ onChange: m,
55
+ formatter: v
56
+ } = H(ne(r)), o = v === void 0 ? ie : v, c = H(oe), d = H(le);
57
+ let b;
58
+ e[3] !== t ? (b = t ? t.value ?? [t.min, t.max] : [0, 0], e[3] = t, e[4] = b) : b = e[4];
59
+ const l = b, [u, y] = Q("");
60
+ if (!t)
61
+ return null;
62
+ let W;
63
+ e[5] !== c || e[6] !== i || e[7] !== a || e[8] !== t || e[9] !== m || e[10] !== d ? (W = (f, s) => {
64
+ if (Array.isArray(s)) {
65
+ const [q, A] = s, x = c(i)?.data ?? [];
66
+ x[a] = {
67
+ ...t,
68
+ value: s
69
+ }, d(i, {
70
+ data: x
71
+ }), m?.([q, A], a);
72
+ }
73
+ }, e[5] = c, e[6] = i, e[7] = a, e[8] = t, e[9] = m, e[10] = d, e[11] = W) : W = e[11];
74
+ const I = W;
75
+ let p;
76
+ e[12] === Symbol.for("react.memo_cache_sentinel") ? (p = (f) => {
77
+ y(f.target.name);
78
+ }, e[12] = p) : p = e[12];
79
+ const S = p;
80
+ let w;
81
+ if (e[13] !== l[0] || e[14] !== l[1] || e[15] !== c || e[16] !== i || e[17] !== a || e[18] !== t.max || e[19] !== t.min || e[20] !== m || e[21] !== d) {
82
+ const f = (s) => {
83
+ const {
84
+ name: q,
85
+ value: A
86
+ } = s.target;
87
+ let x;
88
+ q === "min" ? x = [Math.min(Math.max(t.min, parseFloat(A) || t.min), l[1]), l[1] ?? 0] : x = [l[0] ?? 0, Math.max(Math.min(t.max, parseFloat(A) || t.max), l[0])];
89
+ const X = c(i)?.data ?? [];
90
+ d(i, {
91
+ data: X.map((J, Y) => Y === a ? {
92
+ ...J,
93
+ value: x
94
+ } : J)
95
+ }), m?.([x[0], x[1]], a);
96
+ };
97
+ w = (s) => {
98
+ y(""), f(s);
99
+ }, e[13] = l[0], e[14] = l[1], e[15] = c, e[16] = i, e[17] = a, e[18] = t.max, e[19] = t.min, e[20] = m, e[21] = d, e[22] = w;
100
+ } else
101
+ w = e[22];
102
+ const h = w;
103
+ let E;
104
+ e[23] !== h ? (E = (f) => {
105
+ f.key === "Enter" && (h(f), f.currentTarget.blur());
106
+ }, e[23] = h, e[24] = E) : E = e[24];
107
+ const C = E;
108
+ let R;
109
+ e[25] !== t.color ? (R = t.color && {
110
+ color: t.color
111
+ }, e[25] = t.color, e[26] = R) : R = e[26];
112
+ let M;
113
+ e[27] !== R ? (M = {
114
+ ..._.slider,
115
+ ...R
116
+ }, e[27] = R, e[28] = M) : M = e[28];
117
+ let D;
118
+ e[29] !== l || e[30] !== o || e[31] !== I || e[32] !== t.disabled || e[33] !== t.marks || e[34] !== t.max || e[35] !== t.min || e[36] !== t.step || e[37] !== M ? (D = /* @__PURE__ */ g($, { sx: _.sliderContainer, children: /* @__PURE__ */ g(ee, { value: l, onChange: I, valueLabelDisplay: "auto", valueLabelFormat: o, min: t.min, max: t.max, step: t.step, marks: t.marks, disabled: t.disabled, sx: M }) }), e[29] = l, e[30] = o, e[31] = I, e[32] = t.disabled, e[33] = t.marks, e[34] = t.max, e[35] = t.min, e[36] = t.step, e[37] = M, e[38] = D) : D = e[38];
119
+ const L = `min-${l[0]}`, T = l[0] ?? 0;
120
+ let K;
121
+ e[39] === Symbol.for("react.memo_cache_sentinel") ? (K = {
122
+ "aria-label": "Minimum value"
123
+ }, e[39] = K) : K = e[39];
124
+ let F;
125
+ e[40] !== o || e[41] !== h || e[42] !== C || e[43] !== u || e[44] !== t.disabled || e[45] !== L || e[46] !== T ? (F = /* @__PURE__ */ g(O, { isEditing: u, name: "min", value: T, formatter: o, onFocus: S, onBlur: h, onKeyDown: C, disabled: t.disabled, inputProps: K }, L), e[40] = o, e[41] = h, e[42] = C, e[43] = u, e[44] = t.disabled, e[45] = L, e[46] = T, e[47] = F) : F = e[47];
126
+ const N = `max-${l[1]}`, U = l[1] ?? 0;
127
+ let V;
128
+ e[48] === Symbol.for("react.memo_cache_sentinel") ? (V = {
129
+ "aria-label": "Maximum value"
130
+ }, e[48] = V) : V = e[48];
131
+ let k;
132
+ e[49] !== o || e[50] !== h || e[51] !== C || e[52] !== u || e[53] !== t.disabled || e[54] !== N || e[55] !== U ? (k = /* @__PURE__ */ g(O, { isEditing: u, name: "max", value: U, formatter: o, onFocus: S, onBlur: h, onKeyDown: C, disabled: t.disabled, inputProps: V }, N), e[49] = o, e[50] = h, e[51] = C, e[52] = u, e[53] = t.disabled, e[54] = N, e[55] = U, e[56] = k) : k = e[56];
133
+ let B;
134
+ e[57] !== F || e[58] !== k ? (B = /* @__PURE__ */ P($, { sx: _.inputsRow, children: [
135
+ F,
136
+ k
137
+ ] }), e[57] = F, e[58] = k, e[59] = B) : B = e[59];
138
+ let z;
139
+ return e[60] !== D || e[61] !== B ? (z = /* @__PURE__ */ P($, { sx: _.rangeItem, children: [
140
+ D,
141
+ B
142
+ ] }), e[60] = D, e[61] = B, e[62] = z) : z = e[62], z;
143
+ }
144
+ function le(n) {
145
+ return n.setWidget;
146
+ }
147
+ function oe(n) {
148
+ return n.getWidget;
149
+ }
150
+ function O(n) {
151
+ const e = j(12), {
152
+ isEditing: i,
153
+ name: a,
154
+ disabled: r,
155
+ value: t,
156
+ formatter: m,
157
+ onFocus: v,
158
+ onBlur: o,
159
+ onKeyDown: c,
160
+ inputProps: d
161
+ } = n, [b, l] = Q(String(t)), u = Number(b);
162
+ let y;
163
+ e[0] !== m || e[1] !== u ? (y = m(u), e[0] = m, e[1] = u, e[2] = y) : y = e[2];
164
+ const I = i === a ? b : y;
165
+ let p;
166
+ e[3] === Symbol.for("react.memo_cache_sentinel") ? (p = (w) => {
167
+ l(w.target.value);
168
+ }, e[3] = p) : p = e[3];
169
+ let S;
170
+ return e[4] !== r || e[5] !== d || e[6] !== a || e[7] !== o || e[8] !== v || e[9] !== c || e[10] !== I ? (S = /* @__PURE__ */ g(te, { name: a, value: I, onChange: p, onFocus: v, onBlur: o, onKeyDown: c, disabled: r, size: "small", sx: _.input, inputProps: d }), e[4] = r, e[5] = d, e[6] = a, e[7] = o, e[8] = v, e[9] = c, e[10] = I, e[11] = S) : S = e[11], S;
171
+ }
172
+ function pe(n) {
173
+ const e = j(5);
174
+ let i;
175
+ e[0] !== n.id ? (i = (r) => {
176
+ const {
177
+ index: t
178
+ } = r;
179
+ return /* @__PURE__ */ g(ae, { id: n.id, index: t });
180
+ }, e[0] = n.id, e[1] = i) : i = e[1];
181
+ let a;
182
+ return e[2] !== n.id || e[3] !== i ? (a = /* @__PURE__ */ g(Z, { id: n.id, children: i }), e[2] = n.id, e[3] = i, e[4] = a) : a = e[4], a;
183
+ }
184
+ function he() {
185
+ const n = j(2);
186
+ let e;
187
+ n[0] === Symbol.for("react.memo_cache_sentinel") ? (e = /* @__PURE__ */ g(G, { width: "100%", height: 32 }), n[0] = e) : e = n[0];
188
+ let i;
189
+ return n[1] === Symbol.for("react.memo_cache_sentinel") ? (i = /* @__PURE__ */ P($, { sx: _.rangeItem, "aria-label": "Range skeleton", children: [
190
+ e,
191
+ /* @__PURE__ */ P($, { sx: _.inputsRow, children: [
192
+ /* @__PURE__ */ g(G, { width: "100%", height: 40 }),
193
+ /* @__PURE__ */ g(G, { width: "100%", height: 40 })
194
+ ] })
195
+ ] }), n[1] = i) : i = n[1], i;
196
+ }
197
+ function xe() {
198
+ return {};
199
+ }
200
+ function se(n) {
4
201
  return {
5
- ...e,
6
- note: typeof e.note == "string" ? e.note : void 0
202
+ ...n,
203
+ note: typeof n.note == "string" ? n.note : void 0
7
204
  };
8
205
  }
9
- function t(e) {
10
- return e?.map(n);
206
+ function be(n) {
207
+ return n?.map(se);
11
208
  }
12
209
  export {
13
- r as RangeItem,
14
- s as RangeSkeleton,
15
- g as RangeUI,
16
- n as sanitizeRangeDataItem,
17
- t as sanitizeRangeDataItems
210
+ ae as RangeItem,
211
+ he as RangeSkeleton,
212
+ pe as RangeUI,
213
+ xe as rangeConfig,
214
+ se as sanitizeRangeDataItem,
215
+ be as sanitizeRangeDataItems
18
216
  };
19
217
  //# sourceMappingURL=range.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"range.js","sources":["../../src/widgets/range/serializer.ts"],"sourcesContent":["import type { RangeDataItem } from './types'\n\n/**\n * Sanitizes RangeDataItem by converting ReactNode note values to undefined.\n * This ensures only string values are stored in the widget state.\n *\n * @param item - The RangeDataItem to sanitize\n * @returns A new RangeDataItem with ReactNode note values converted to undefined\n */\nexport function sanitizeRangeDataItem(item: RangeDataItem): RangeDataItem {\n return {\n ...item,\n note: typeof item.note === 'string' ? item.note : undefined,\n }\n}\n\n/**\n * Sanitizes an array of RangeDataItems by converting ReactNode note values to undefined.\n *\n * @param items - Array of RangeDataItems to sanitize\n * @returns A new array with sanitized RangeDataItems\n */\nexport function sanitizeRangeDataItems(\n items: RangeDataItem[] | undefined,\n): RangeDataItem[] | undefined {\n return items?.map(sanitizeRangeDataItem)\n}\n"],"names":["sanitizeRangeDataItem","item","note","undefined","sanitizeRangeDataItems","items","map"],"mappings":";;AASO,SAASA,EAAsBC,GAAoC;AACxE,SAAO;AAAA,IACL,GAAGA;AAAAA,IACHC,MAAM,OAAOD,EAAKC,QAAS,WAAWD,EAAKC,OAAOC;AAAAA,EAAAA;AAEtD;AAQO,SAASC,EACdC,GAC6B;AAC7B,SAAOA,GAAOC,IAAIN,CAAqB;AACzC;"}
1
+ {"version":3,"file":"range.js","sources":["../../src/widgets/range/style.ts","../../src/widgets/range/components/range-item.tsx","../../src/widgets/range/range-ui.tsx","../../src/widgets/range/skeleton.tsx","../../src/widgets/range/config.ts","../../src/widgets/range/serializer.ts"],"sourcesContent":["import type { SxProps, Theme } from '@mui/material'\n\nexport const styles: Record<string, SxProps<Theme>> = {\n root: {\n display: 'flex',\n flexDirection: 'column',\n gap: (theme: Theme) => theme.spacing(2),\n },\n rangeItem: {\n display: 'flex',\n flexDirection: 'column',\n gap: (theme: Theme) => theme.spacing(1.5),\n },\n sliderContainer: {\n display: 'flex',\n flexDirection: 'column',\n gap: (theme: Theme) => theme.spacing(1),\n px: (theme: Theme) => theme.spacing(1),\n },\n inputsRow: {\n display: 'flex',\n gap: (theme: Theme) => theme.spacing(2),\n alignItems: 'center',\n },\n input: {\n flex: 1,\n '& .MuiInputBase-input': {\n textAlign: 'center',\n },\n },\n slider: {\n width: '100%',\n '&.Mui-disabled': {\n color: (theme: Theme) => theme.palette.text.disabled,\n },\n },\n} satisfies Record<string, SxProps<Theme>>\n","import { Box, Slider, TextField } from '@mui/material'\nimport { useState, useMemo, type FocusEvent, type KeyboardEvent } from 'react'\nimport { useWidgetStore } from '../../stores/widget-store'\nimport type { RangeItemProps, RangeWidgetState } from '../types'\nimport { styles } from '../style'\nimport { useShallow } from 'zustand/shallow'\n\ntype EditingState = '' | 'min' | 'max'\n\nconst defaultFormatter = (value: number) => value.toString()\n\nexport function RangeItem({ id, index }: RangeItemProps) {\n const {\n item,\n onChange,\n formatter = defaultFormatter,\n } = useWidgetStore(\n useShallow((state) => {\n const widget = state.getWidget<RangeWidgetState>(id)\n return {\n item: widget?.data[index],\n onChange: widget?.onChange,\n formatter: widget?.formatter,\n }\n }),\n )\n const getWidget = useWidgetStore((store) => store.getWidget)\n const setWidget = useWidgetStore((store) => store.setWidget)\n\n const currentValue = useMemo(\n () => (item ? (item.value ?? [item.min, item.max]) : [0, 0]),\n [item],\n )\n\n // Local state for input values - track if user is editing\n const [isEditing, setIsEditing] = useState<EditingState>('')\n\n if (!item) return null\n\n const handleSliderChange = (_: Event, newValue: number | number[]) => {\n if (Array.isArray(newValue)) {\n const [min, max] = newValue\n const data = getWidget<RangeWidgetState>(id)?.data ?? []\n\n data[index] = {\n ...item,\n value: newValue,\n }\n\n setWidget(id, {\n data,\n })\n\n onChange?.([min!, max!], index)\n }\n }\n\n const handleInputFocus = (e: FocusEvent<HTMLInputElement>) => {\n setIsEditing(e.target.name as EditingState)\n }\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>) => {\n const { name, value } = event.target\n\n let newValue: [number, number]\n if (name === 'min') {\n newValue = [\n Math.min(\n Math.max(item.min, parseFloat(value) || item.min),\n currentValue[1]!,\n ),\n currentValue[1] ?? 0,\n ]\n } else {\n newValue = [\n currentValue[0] ?? 0,\n Math.max(\n Math.min(item.max, parseFloat(value) || item.max),\n currentValue[0]!,\n ),\n ]\n }\n\n const data = getWidget<RangeWidgetState>(id)?.data ?? []\n\n setWidget(id, {\n data: data.map((d: RangeWidgetState['data'][number], i: number) =>\n i === index\n ? {\n ...d,\n value: newValue,\n }\n : d,\n ),\n })\n\n onChange?.([newValue[0], newValue[1]], index)\n }\n\n const handleInputBlur = (e: FocusEvent<HTMLInputElement>) => {\n setIsEditing('')\n handleInputChange(e)\n }\n\n const handleInputKeyDown = (event: KeyboardEvent<HTMLInputElement>) => {\n if (event.key === 'Enter') {\n handleInputBlur(event as unknown as FocusEvent<HTMLInputElement>)\n event.currentTarget.blur()\n }\n }\n\n return (\n <Box sx={styles.rangeItem}>\n <Box sx={styles.sliderContainer}>\n <Slider\n value={currentValue}\n onChange={handleSliderChange}\n valueLabelDisplay='auto'\n valueLabelFormat={formatter}\n min={item.min}\n max={item.max}\n step={item.step}\n marks={item.marks}\n disabled={item.disabled}\n sx={{\n ...styles.slider,\n ...(item.color && {\n color: item.color,\n }),\n }}\n />\n </Box>\n\n <Box sx={styles.inputsRow}>\n <Input\n key={`min-${currentValue[0]}`}\n isEditing={isEditing}\n name='min'\n value={currentValue[0] ?? 0}\n formatter={formatter}\n onFocus={handleInputFocus}\n onBlur={handleInputBlur}\n onKeyDown={handleInputKeyDown}\n disabled={item.disabled}\n inputProps={{\n 'aria-label': 'Minimum value',\n }}\n />\n <Input\n key={`max-${currentValue[1]}`}\n isEditing={isEditing}\n name='max'\n value={currentValue[1] ?? 0}\n formatter={formatter}\n onFocus={handleInputFocus}\n onBlur={handleInputBlur}\n onKeyDown={handleInputKeyDown}\n disabled={item.disabled}\n inputProps={{\n 'aria-label': 'Maximum value',\n }}\n />\n </Box>\n </Box>\n )\n}\n\nfunction Input({\n isEditing,\n name,\n disabled,\n value,\n formatter,\n onFocus: onFocus,\n onBlur: onBlur,\n onKeyDown: onKeyDown,\n inputProps,\n}: {\n isEditing: EditingState\n name: 'min' | 'max'\n disabled?: boolean\n value: number\n formatter: (value: number) => string\n onFocus: (e: FocusEvent<HTMLInputElement>) => void\n onBlur: (e: FocusEvent<HTMLInputElement>) => void\n onKeyDown: (e: KeyboardEvent<HTMLInputElement>) => void\n inputProps?: React.InputHTMLAttributes<HTMLInputElement>\n}) {\n const [currentValue, setCurrentValue] = useState<string>(String(value))\n\n // Compute display values when not editing\n const displayMinValue = useMemo(\n () => formatter(Number(currentValue)),\n [currentValue, formatter],\n )\n\n return (\n <TextField\n name={name}\n value={isEditing === name ? currentValue : displayMinValue}\n onChange={(e) => {\n setCurrentValue(e.target.value)\n }}\n onFocus={onFocus}\n onBlur={onBlur}\n onKeyDown={onKeyDown}\n disabled={disabled}\n size='small'\n sx={styles.input}\n inputProps={inputProps}\n />\n )\n}\n","import type { RangeUIProps } from './types'\nimport { Row } from '../formula/components/row'\nimport { RangeItem } from './components/range-item'\n\nexport function RangeUI(props: RangeUIProps) {\n return (\n <Row id={props.id}>\n {({ index }) => <RangeItem id={props.id} index={index} />}\n </Row>\n )\n}\n","import { Box, Skeleton } from '@mui/material'\nimport { styles } from './style'\n\nexport function RangeSkeleton() {\n return (\n <Box sx={styles.rangeItem} aria-label='Range skeleton'>\n <Skeleton width='100%' height={32} />\n <Box sx={styles.inputsRow}>\n <Skeleton width='100%' height={40} />\n <Skeleton width='100%' height={40} />\n </Box>\n </Box>\n )\n}\n","import type { RangeWidgetConfig } from './types'\n\nexport interface RangeConfigProps {\n formatter?: (value: number) => string\n onChange?: (value: number[], index: number) => void\n}\n\nexport function rangeConfig(): RangeWidgetConfig {\n return {}\n}\n","import type { RangeDataItem } from './types'\n\n/**\n * Sanitizes RangeDataItem by converting ReactNode note values to undefined.\n * This ensures only string values are stored in the widget state.\n *\n * @param item - The RangeDataItem to sanitize\n * @returns A new RangeDataItem with ReactNode note values converted to undefined\n */\nexport function sanitizeRangeDataItem(item: RangeDataItem): RangeDataItem {\n return {\n ...item,\n note: typeof item.note === 'string' ? item.note : undefined,\n }\n}\n\n/**\n * Sanitizes an array of RangeDataItems by converting ReactNode note values to undefined.\n *\n * @param items - Array of RangeDataItems to sanitize\n * @returns A new array with sanitized RangeDataItems\n */\nexport function sanitizeRangeDataItems(\n items: RangeDataItem[] | undefined,\n): RangeDataItem[] | undefined {\n return items?.map(sanitizeRangeDataItem)\n}\n"],"names":["styles","rangeItem","display","flexDirection","gap","theme","spacing","sliderContainer","px","inputsRow","alignItems","input","flex","textAlign","slider","width","color","palette","text","disabled","defaultFormatter","value","toString","RangeItem","t0","$","_c","id","index","t1","state","widget","getWidget","item","data","onChange","formatter","t2","useWidgetStore","useShallow","undefined","_temp","setWidget","_temp2","t3","min","max","currentValue","isEditing","setIsEditing","useState","t4","_","newValue","Array","isArray","handleSliderChange","t5","Symbol","for","e","target","name","handleInputFocus","t6","handleInputChange","event","Math","parseFloat","data_0","map","d","i","e_0","handleInputBlur","t7","event_0","key","currentTarget","blur","handleInputKeyDown","t8","t9","t10","marks","step","Box","jsx","Slider","t11","t12","t13","t14","Input","t15","t16","t17","t18","t19","t20","store_0","store","onFocus","onBlur","onKeyDown","inputProps","setCurrentValue","String","Number","TextField","RangeUI","props","Row","RangeSkeleton","Skeleton","jsxs","rangeConfig","sanitizeRangeDataItem","note","sanitizeRangeDataItems","items"],"mappings":"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"}