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