@carto/ps-react-ui 5.0.0-widgets.13 → 5.0.0-widgets.14

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.
@@ -1,44 +1,45 @@
1
- import { jsxs as c, jsx as r } from "react/jsx-runtime";
2
- import { c as x } from "react/compiler-runtime";
1
+ import { jsxs as f, jsx as i } from "react/jsx-runtime";
2
+ import { c as S } from "react/compiler-runtime";
3
3
  import "react";
4
4
  import "echarts";
5
5
  import "../widget-store-CB6Trp_0.js";
6
6
  import "zustand/shallow";
7
- import { g as y } from "../options-D9wflre6.js";
8
- import { m as _ } from "../utils-D3-eQyDR.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";
7
+ import { g as w } from "../options-D9wflre6.js";
8
+ import { m as I } from "../utils-D3-eQyDR.js";
9
+ import { f as C, c as j, d as k, e as A, g as O } from "../styles-CCZnY17y.js";
10
+ import { Box as d, Skeleton as a } from "@mui/material";
11
11
  import "@mui/icons-material";
12
12
  import "react-markdown";
13
- import { d as f, a as g } from "../exports-Cr43OCul.js";
13
+ import { d as y, a as x } from "../exports-Cr43OCul.js";
14
14
  import "../lasso-tool-BwRzEW7k.js";
15
15
  import "../cjs-D4KH3azB.js";
16
16
  import "@dnd-kit/core";
17
17
  import "@dnd-kit/sortable";
18
18
  import "@dnd-kit/utilities";
19
- function Y({
19
+ function te({
20
20
  refUI: e
21
21
  }) {
22
22
  return [{
23
- ...f,
24
- modifier: () => f.modifier(e)
23
+ ...y,
24
+ modifier: () => y.modifier(e)
25
25
  }, {
26
- ...g,
26
+ ...x,
27
27
  modifier: async (t) => {
28
- const o = S(t);
29
- return g.modifier(o);
28
+ const n = C(t);
29
+ return x.modifier(n);
30
30
  }
31
31
  }];
32
32
  }
33
- function ee(e) {
33
+ function oe(e) {
34
34
  return {
35
35
  type: "pie",
36
- option: _(y(e), C(e))
36
+ option: I(w(e), N(e))
37
37
  };
38
38
  }
39
- function C({
39
+ function N({
40
40
  data: e = [],
41
- theme: t
41
+ theme: t,
42
+ formatter: n
42
43
  }) {
43
44
  if ((e?.length ?? 0) > 1)
44
45
  return {
@@ -58,8 +59,8 @@ function C({
58
59
  bottom: parseInt(t.spacing(4)),
59
60
  right: parseInt(t.spacing(4))
60
61
  },
61
- series: e.map((s, i) => ({
62
- datasetIndex: i,
62
+ series: e.map((o, l) => ({
63
+ datasetIndex: l,
63
64
  type: "bar",
64
65
  barMaxWidth: 100,
65
66
  emphasis: {
@@ -67,11 +68,11 @@ function C({
67
68
  }
68
69
  }))
69
70
  };
70
- const n = !0;
71
+ const r = !0;
71
72
  return {
72
- legend: I(n),
73
+ legend: A(r),
73
74
  grid: {
74
- ...w(n, t),
75
+ ...k(r, t),
75
76
  left: 0,
76
77
  top: 0,
77
78
  right: 0
@@ -83,11 +84,20 @@ function C({
83
84
  show: !1
84
85
  },
85
86
  tooltip: {
86
- trigger: "item"
87
+ trigger: "item",
88
+ formatter: j((o) => {
89
+ const l = o.value && typeof o.value == "object" && !Array.isArray(o.value) ? Object.values(o.value) : [], c = o.encode?.value?.at(0), p = l[c ?? 0], u = typeof p == "number" && n ? n(p) : p ?? "", m = typeof o.marker == "string" ? o.marker : "", h = o.seriesName ? `${o.seriesName}: ` : "", b = o.name ?? "";
90
+ return {
91
+ name: h,
92
+ seriesName: b,
93
+ marker: m,
94
+ value: u
95
+ };
96
+ })
87
97
  },
88
98
  color: Object.values(t.palette.qualitative.bold),
89
- series: e.map((s, i) => ({
90
- datasetIndex: i,
99
+ series: e.map((o, l) => ({
100
+ datasetIndex: l,
91
101
  type: "pie",
92
102
  colorBy: "data",
93
103
  radius: ["74%", "90%"],
@@ -97,13 +107,16 @@ function C({
97
107
  label: {
98
108
  show: !0,
99
109
  position: "center",
100
- formatter: (p) => {
110
+ formatter: (c) => {
101
111
  const {
102
- name: b
103
- } = p, d = p.encode?.value?.[0];
104
- return d === void 0 ? "" : `{c|${Object.values(p.data ?? {}).at(d) ?? ""}}
112
+ name: p
113
+ } = c, u = c.encode?.value?.[0];
114
+ if (u === void 0)
115
+ return "";
116
+ const m = Object.values(c.data ?? {}).at(u);
117
+ return `{c|${typeof m == "number" && n ? n(m) : m ?? ""}}
105
118
 
106
- {b|${b}}`;
119
+ {b|${p}}`;
107
120
  },
108
121
  rich: {
109
122
  b: {
@@ -128,90 +141,90 @@ function C({
128
141
  }))
129
142
  };
130
143
  }
131
- const j = {
144
+ const T = {
132
145
  skeleton: {
133
- graph: v.graph
146
+ graph: O.graph
134
147
  }
135
- }, h = 32, m = 294 - h, u = m - h;
136
- function te() {
137
- const e = x(5);
138
- let t, o;
148
+ }, _ = 32, g = 294 - _, v = g - _;
149
+ function ne() {
150
+ const e = S(5);
151
+ let t, n;
139
152
  e[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t = {
140
153
  display: "flex",
141
154
  alignItems: "center",
142
155
  justifyContent: "center",
143
156
  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] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (n = /* @__PURE__ */ r(a, { sx: {
157
+ }, n = /* @__PURE__ */ i(a, { variant: "circular", width: g, height: g }), e[0] = t, e[1] = n) : (t = e[0], n = e[1]);
158
+ let s;
159
+ e[2] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (s = /* @__PURE__ */ i(a, { sx: {
147
160
  position: "absolute",
148
161
  zIndex: 1
149
- }, variant: "circular", width: u, height: u }), e[2] = n) : n = e[2];
150
- let s;
151
- e[3] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (s = /* @__PURE__ */ c(l, { sx: t, children: [
152
- o,
162
+ }, variant: "circular", width: v, height: v }), e[2] = s) : s = e[2];
163
+ let r;
164
+ e[3] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (r = /* @__PURE__ */ f(d, { sx: t, children: [
153
165
  n,
154
- /* @__PURE__ */ c(l, { sx: {
166
+ s,
167
+ /* @__PURE__ */ f(d, { sx: {
155
168
  position: "absolute",
156
169
  zIndex: 2,
157
170
  display: "flex",
158
171
  flexDirection: "column",
159
172
  alignItems: "center",
160
173
  justifyContent: "center",
161
- gap: T
174
+ gap: $
162
175
  }, children: [
163
- /* @__PURE__ */ r(a, { height: 24, width: 72 }),
164
- /* @__PURE__ */ r(a, { height: 8, width: 48 })
176
+ /* @__PURE__ */ i(a, { height: 24, width: 72 }),
177
+ /* @__PURE__ */ i(a, { height: 8, width: 48 })
165
178
  ] })
166
- ] }), e[3] = s) : s = e[3];
167
- let i;
168
- return e[4] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (i = /* @__PURE__ */ c(l, { sx: j.skeleton.graph.container, children: [
169
- s,
170
- /* @__PURE__ */ r(l, { sx: {
179
+ ] }), e[3] = r) : r = e[3];
180
+ let o;
181
+ return e[4] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (o = /* @__PURE__ */ f(d, { sx: T.skeleton.graph.container, children: [
182
+ r,
183
+ /* @__PURE__ */ i(d, { sx: {
171
184
  display: "flex",
172
185
  alignItems: "center",
173
- gap: E,
174
- height: A
175
- }, children: Array(2).fill(0).map(O) })
176
- ] }), e[4] = i) : i = e[4], i;
186
+ gap: z,
187
+ height: W
188
+ }, children: Array(2).fill(0).map(E) })
189
+ ] }), e[4] = o) : o = e[4], o;
177
190
  }
178
- function O(e, t) {
179
- return /* @__PURE__ */ c(l, { sx: {
191
+ function E(e, t) {
192
+ return /* @__PURE__ */ f(d, { sx: {
180
193
  display: "flex",
181
194
  alignItems: "center",
182
- gap: k
195
+ gap: V
183
196
  }, children: [
184
- /* @__PURE__ */ r(a, { variant: "circular", width: 8, height: 8 }),
185
- /* @__PURE__ */ r(a, { width: 48, height: 8 })
197
+ /* @__PURE__ */ i(a, { variant: "circular", width: 8, height: 8 }),
198
+ /* @__PURE__ */ i(a, { width: 48, height: 8 })
186
199
  ] }, t);
187
200
  }
188
- function k(e) {
201
+ function V(e) {
189
202
  const {
190
203
  spacing: t
191
204
  } = e;
192
205
  return t(1.5);
193
206
  }
194
- function A(e) {
207
+ function W(e) {
195
208
  const {
196
209
  spacing: t
197
210
  } = e;
198
211
  return t(5);
199
212
  }
200
- function E(e) {
213
+ function z(e) {
201
214
  const {
202
215
  spacing: t
203
216
  } = e;
204
217
  return t(2);
205
218
  }
206
- function T(e) {
219
+ function $(e) {
207
220
  const {
208
221
  spacing: t
209
222
  } = e;
210
223
  return t(1);
211
224
  }
212
225
  export {
213
- te as PieSkeleton,
214
- ee as pieConfig,
215
- Y as pieDownloadConfig
226
+ ne as PieSkeleton,
227
+ oe as pieConfig,
228
+ te as pieDownloadConfig
216
229
  };
217
230
  //# sourceMappingURL=pie.js.map
@@ -1 +1 @@
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
+ {"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 createTooltipFormatter,\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({\n data = [],\n theme,\n formatter,\n}: 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 formatter: createTooltipFormatter((item) => {\n const value =\n item.value &&\n typeof item.value === 'object' &&\n !Array.isArray(item.value)\n ? (Object.values(item.value) as (string | number)[])\n : []\n const index = item.encode?.value?.at(0)\n const _value = value[index ?? 0]\n\n const formattedValue =\n typeof _value === 'number' && formatter\n ? formatter(_value)\n : (_value ?? '')\n\n const marker = typeof item.marker === 'string' ? item.marker : ''\n const seriesName = item.seriesName ? `${item.seriesName}: ` : ''\n const name = item.name ?? ''\n\n return {\n name: seriesName,\n seriesName: name,\n marker,\n value: formattedValue,\n }\n }),\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 =\n typeof value === 'number' && formatter\n ? formatter(value)\n : (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","formatter","length","xAxis","show","yAxis","legend","bottom","grid","parseInt","spacing","right","series","map","_","index","datasetIndex","barMaxWidth","emphasis","focus","hasLegend","buildLegendConfig","buildGridConfig","left","top","tooltip","trigger","createTooltipFormatter","item","value","Array","isArray","Object","values","encode","at","_value","formattedValue","marker","seriesName","name","color","palette","qualitative","bold","colorBy","radius","avoidLabelOverlap","selectedOffset","label","position","params","encodeIndex","undefined","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","fill","_temp5","i","_temp4","spacing_2","spacing_1","spacing_0"],"mappings":";;;;;;;;;;;;;;;;;;AAeO,SAASA,GAAkB;AAAA,EAChCC,OAAAA;AACW,GAAkC;AAC7C,SAAO,CACL;AAAA,IACE,GAAGC;AAAAA,IACHC,UAAUA,MAAMD,EAAcC,SAASF,CAAK;AAAA,EAAA,GAE9C;AAAA,IACE,GAAGG;AAAAA,IACHD,UAAU,OAAOE,MAAS;AACxB,YAAMC,IAAOC,EAAwBF,CAAI;AACzC,aAAOD,EAAcD,SAASG,CAAI;AAAA,IACpC;AAAA,EAAA,CACD;AAEL;AAEO,SAASE,GAAUC,GAAmC;AAC3D,SAAO;AAAA,IACLC,MAAM;AAAA,IACNC,QAAQC,EAAwBC,EAAiBJ,CAAK,GAAGK,EAAUL,CAAK,CAAC;AAAA,EAAA;AAE7E;AAEA,SAASK,EAAU;AAAA,EACjBT,MAAAA,IAAO,CAAA;AAAA,EACPU,OAAAA;AAAAA,EACAC,WAAAA;AACS,GAAuB;AAGhC,OAFqBX,GAAMY,UAAU,KAAK;AAGxC,WAAO;AAAA,MACLC,OAAO;AAAA,QACLR,MAAM;AAAA,QACNS,MAAM;AAAA,MAAA;AAAA,MAERC,OAAO;AAAA,QACLV,MAAM;AAAA,QACNS,MAAM;AAAA,MAAA;AAAA,MAERE,QAAQ;AAAA,QACNF,MAAM;AAAA,QACNG,QAAQ;AAAA,MAAA;AAAA,MAEVC,MAAM;AAAA,QACJD,QAAQE,SAAST,EAAMU,QAAQ,CAAC,CAAC;AAAA,QACjCC,OAAOF,SAAST,EAAMU,QAAQ,CAAC,CAAC;AAAA,MAAA;AAAA,MAElCE,QAAQtB,EAAKuB,IAAI,CAACC,GAAYC,OAAmB;AAAA,QAC/CC,cAAcD;AAAAA,QACdpB,MAAM;AAAA,QACNsB,aAAa;AAAA,QACbC,UAAU;AAAA,UACRC,OAAO;AAAA,QAAA;AAAA,MACT,EACA;AAAA,IAAA;AAIN,QAAMC,IAAY;AAElB,SAAO;AAAA,IACLd,QAAQe,EAAkBD,CAAS;AAAA,IACnCZ,MAAM;AAAA,MACJ,GAAGc,EAAgBF,GAAWpB,CAAK;AAAA,MACnCuB,MAAM;AAAA,MACNC,KAAK;AAAA,MACLb,OAAO;AAAA,IAAA;AAAA,IAETR,OAAO;AAAA,MACLC,MAAM;AAAA,IAAA;AAAA,IAERC,OAAO;AAAA,MACLD,MAAM;AAAA,IAAA;AAAA,IAERqB,SAAS;AAAA,MACPC,SAAS;AAAA,MACTzB,WAAW0B,EAAwBC,CAAAA,MAAS;AAC1C,cAAMC,IACJD,EAAKC,SACL,OAAOD,EAAKC,SAAU,YACtB,CAACC,MAAMC,QAAQH,EAAKC,KAAK,IACpBG,OAAOC,OAAOL,EAAKC,KAAK,IACzB,CAAA,GACAd,IAAQa,EAAKM,QAAQL,OAAOM,GAAG,CAAC,GAChCC,IAASP,EAAMd,KAAS,CAAC,GAEzBsB,IACJ,OAAOD,KAAW,YAAYnC,IAC1BA,EAAUmC,CAAM,IACfA,KAAU,IAEXE,IAAS,OAAOV,EAAKU,UAAW,WAAWV,EAAKU,SAAS,IACzDC,IAAaX,EAAKW,aAAa,GAAGX,EAAKW,UAAU,OAAO,IACxDC,IAAOZ,EAAKY,QAAQ;AAE1B,eAAO;AAAA,UACLA,MAAMD;AAAAA,UACNA,YAAYC;AAAAA,UACZF,QAAAA;AAAAA,UACAT,OAAOQ;AAAAA,QAAAA;AAAAA,MAEX,CAAC;AAAA,IAAA;AAAA,IAEHI,OAAOT,OAAOC,OAAOjC,EAAM0C,QAAQC,YAAYC,IAAI;AAAA,IACnDhC,QAAQtB,EAAKuB,IAAI,CAACC,GAAYC,OAAmB;AAAA,MAC/CC,cAAcD;AAAAA,MACdpB,MAAM;AAAA,MACNkD,SAAS;AAAA,MACTC,QAAQ,CAAC,OAAO,KAAK;AAAA,MACrBC,mBAAmB;AAAA,MACnBC,gBAAgB;AAAA,MAChBzC,QAAQE,SAAST,EAAMU,QAAQ,CAAC,CAAC;AAAA,MAEjCuC,OAAO;AAAA,QACL7C,MAAM;AAAA,QACN8C,UAAU;AAAA,QACVjD,WAAYkD,CAAAA,MAAW;AACrB,gBAAM;AAAA,YAAEX,MAAAA;AAAAA,UAAAA,IAASW,GACXC,IAAcD,EAAOjB,QAAQL,QAAQ,CAAC;AAC5C,cAAIuB,MAAgBC;AAClB,mBAAO;AAGT,gBAAMxB,IAAQG,OAAOC,OAAOkB,EAAO7D,QAAQ,CAAA,CAAE,EAAE6C,GAAGiB,CAAW;AAW7D,iBAAO,MANL,OAAOvB,KAAU,YAAY5B,IACzBA,EAAU4B,CAAK,IACdA,KAAS,EAIW;AAAA;AAAA,KAFLW,CAE6B;AAAA,QACrD;AAAA,QACAc,MAAM;AAAA,UACJC,GAAG;AAAA,YACDC,UAAU;AAAA,YACVC,YAAY;AAAA,YACZC,YAAY;AAAA,UAAA;AAAA,UAEdC,GAAG;AAAA,YACDH,UAAU;AAAA,YACVC,YAAY;AAAA,YACZC,YAAY;AAAA,UAAA;AAAA,QACd;AAAA,MACF;AAAA,MAEFxC,UAAU;AAAA,QACR0C,UAAU;AAAA,MAAA;AAAA,MAEZC,WAAW;AAAA,QACTC,aAAa9D,EAAM0C,QAAQqB,WAAWC;AAAAA,QACtCC,aAAa;AAAA,MAAA;AAAA,IACf,EACA;AAAA,EAAA;AAEN;AC7KO,MAAMC,IAAS;AAAA,EACpBC,UAAU;AAAA,IACRC,OAAOC,EAAmBD;AAAAA,EAAAA;AAE9B,GCJME,IAAS,IACTC,IAAO,MAAMD,GACbE,IAAaD,IAAOD;AAEnB,SAAAG,KAAA;AAAA,QAAAC,IAAAC,EAAA,CAAA;AAAA,MAAAC,GAAAC;AAAA,EAAAH,EAAA,CAAA,MAAAI,uBAAAC,IAAA,2BAAA,KAIKH,IAAA;AAAA,IAAAI,SACO;AAAA,IAAMC,YACH;AAAA,IAAQC,gBACJ;AAAA,IAAQhC,UACd;AAAA,EAAA,GAGZ2B,sBAACM,GAAA,EAAiB,SAAA,YAAkBZ,OAAAA,GAAcA,QAAAA,GAAI,GAAIG,OAAAE,GAAAF,OAAAG,MAAAD,IAAAF,EAAA,CAAA,GAAAG,IAAAH,EAAA,CAAA;AAAA,MAAAU;AAAA,EAAAV,EAAA,CAAA,MAAAI,uBAAAC,IAAA,2BAAA,KAC1DK,IAAA,gBAAAC,EAACF,KACK,IAAA;AAAA,IAAAjC,UACQ;AAAA,IAAUoC,QACZ;AAAA,EAAA,GAEF,SAAA,YACDd,OAAAA,GACCA,QAAAA,GAAU,GAClBE,OAAAU,KAAAA,IAAAV,EAAA,CAAA;AAAA,MAAAa;AAAA,EAAAb,EAAA,CAAA,MAAAI,uBAAAC,IAAA,2BAAA,KAjBJQ,sBAACC,GAAA,EACK,IAAAZ,GAOJC,UAAAA;AAAAA,IAAAA;AAAAA,IACAO;AAAAA,IASA,gBAAAK,EAACD,KACK,IAAA;AAAA,MAAAtC,UACQ;AAAA,MAAUoC,QACZ;AAAA,MAACN,SACA;AAAA,MAAMU,eACA;AAAA,MAAQT,YACX;AAAA,MAAQC,gBACJ;AAAA,MAAQS,KACnBC;AAAAA,IAAAA,GAGP,UAAA;AAAA,MAAA,gBAAAP,EAACF,GAAA,EAAiB,QAAA,IAAW,OAAA,IAAE;AAAA,MAC/B,gBAAAE,EAACF,GAAA,EAAiB,QAAA,GAAU,OAAA,GAAA,CAAE;AAAA,IAAA,EAAA,CAChC;AAAA,EAAA,GACF,GAAMT,OAAAa,KAAAA,IAAAb,EAAA,CAAA;AAAA,MAAAmB;AAAA,SAAAnB,EAAA,CAAA,MAAAI,uBAAAC,IAAA,2BAAA,KAjCRc,sBAACL,GAAA,EAAQ,IAAAtB,EAAMC,SAASC,MAAM0B,WAC5BP,UAAAA;AAAAA,IAAAA;AAAAA,IAiCA,gBAAAF,EAACG,KACK,IAAA;AAAA,MAAAR,SACO;AAAA,MAAMC,YACH;AAAA,MAAQU,KACfI;AAAAA,MAA2BC,QACxBC;AAAAA,IAAAA,GAGTnE,gBAAM,CAAC,EAACoE,KACD,CAAC,EAACrF,IACHsF,CAYJ,EAAA,CACL;AAAA,EAAA,GACF,GAAMzB,OAAAmB,KAAAA,IAAAnB,EAAA,CAAA,GA1DNmB;AA0DM;AA5DH,SAAAM,EAAArF,GAAAsF,GAAA;AAAA,SA+CK,gBAAAX,EAACD,KAEK,IAAA;AAAA,IAAAR,SACO;AAAA,IAAMC,YACH;AAAA,IAAQU,KACfU;AAAAA,EAAAA,GAGP,UAAA;AAAA,IAAA,gBAAAhB,EAACF,KAAiB,SAAA,YAAkB,OAAA,GAAW,QAAA,GAAC;AAAA,IAChD,gBAAAE,EAACF,GAAA,EAAgB,OAAA,IAAY,QAAA,EAAA,CAAC;AAAA,EAAA,EAAA,GARzBiB,CASP;AAAM;AAzDX,SAAAC,EAAAzB,GAAA;AAoDe,QAAA;AAAA,IAAAlE,SAAA4F;AAAAA,EAAAA,IAAA1B;AAAW,SAAKlE,EAAQ,GAAG;AAAC;AApD3C,SAAAuF,EAAArB,GAAA;AAyCY,QAAA;AAAA,IAAAlE,SAAA6F;AAAAA,EAAAA,IAAA3B;AAAW,SAAKlE,EAAQ,CAAC;AAAC;AAzCtC,SAAAqF,EAAAnB,GAAA;AAwCS,QAAA;AAAA,IAAAlE,SAAA8F;AAAAA,EAAAA,IAAA5B;AAAW,SAAKlE,EAAQ,CAAC;AAAC;AAxCnC,SAAAkF,EAAAhB,GAAA;AA6BW,QAAA;AAAA,IAAAlE,SAAAA;AAAAA,EAAAA,IAAAkE;AAAW,SAAKlE,EAAQ,CAAC;AAAC;"}
@@ -1,124 +1,134 @@
1
- import { jsxs as p, jsx as i } from "react/jsx-runtime";
2
- import { c as f } from "react/compiler-runtime";
1
+ import { jsxs as g, jsx as i } from "react/jsx-runtime";
2
+ import { c as b } from "react/compiler-runtime";
3
3
  import "react";
4
4
  import "echarts";
5
5
  import "../widget-store-CB6Trp_0.js";
6
6
  import "zustand/shallow";
7
- import { g } from "../options-D9wflre6.js";
8
- import { m } from "../utils-D3-eQyDR.js";
9
- import { s as d, a as u, d as y } from "../styles-dOu_pRNb.js";
10
- import { Box as a, Skeleton as n } from "@mui/material";
7
+ import { g as w } from "../options-D9wflre6.js";
8
+ import { m as S } from "../utils-D3-eQyDR.js";
9
+ import { s as v, c as k, b as L, e as I, g as _ } from "../styles-CCZnY17y.js";
10
+ import { Box as s, Skeleton as p } from "@mui/material";
11
11
  import "@mui/icons-material";
12
12
  import "react-markdown";
13
- import { d as l, a as r } from "../exports-Cr43OCul.js";
13
+ import { d as c, a as f } from "../exports-Cr43OCul.js";
14
14
  import "../lasso-tool-BwRzEW7k.js";
15
15
  import "../cjs-D4KH3azB.js";
16
16
  import "@dnd-kit/core";
17
17
  import "@dnd-kit/sortable";
18
18
  import "@dnd-kit/utilities";
19
- function B({
19
+ function U({
20
20
  refUI: e
21
21
  }) {
22
22
  return [{
23
- ...l,
24
- modifier: () => l.modifier(e)
23
+ ...c,
24
+ modifier: () => c.modifier(e)
25
25
  }, {
26
- ...r,
26
+ ...f,
27
27
  modifier: async (t) => {
28
- const o = d(t);
29
- return r.modifier(o);
28
+ const o = v(t);
29
+ return f.modifier(o);
30
30
  }
31
31
  }];
32
32
  }
33
- function G(e) {
33
+ function X(e) {
34
34
  return {
35
35
  type: "scatterplot",
36
- option: m(g(e), h(e))
36
+ option: S(w(e), T(e))
37
37
  };
38
38
  }
39
- function h({
39
+ function T({
40
40
  data: e = [],
41
- theme: t
41
+ theme: t,
42
+ formatter: o
42
43
  }) {
43
- const o = e.length > 1;
44
+ const n = e.length > 1, u = {
45
+ type: "value",
46
+ axisLine: {
47
+ show: !1
48
+ },
49
+ axisTick: {
50
+ show: !1
51
+ },
52
+ axisLabel: {
53
+ fontSize: t.typography.overlineDelicate.fontSize,
54
+ fontFamily: t.typography.overlineDelicate.fontFamily,
55
+ showMinLabel: !0,
56
+ showMaxLabel: !0,
57
+ hideOverlap: !0,
58
+ padding: [parseInt(t.spacing(0.5)), parseInt(t.spacing(0.5)), 0, parseInt(t.spacing(0.5))],
59
+ color: t.palette.black[60]
60
+ },
61
+ splitLine: {
62
+ show: !0,
63
+ lineStyle: {
64
+ color: t.palette.black[4]
65
+ }
66
+ }
67
+ }, d = {
68
+ type: "value",
69
+ axisLabel: {
70
+ fontSize: t.typography.overlineDelicate.fontSize,
71
+ fontFamily: t.typography.overlineDelicate.fontFamily,
72
+ inside: !1,
73
+ padding: [0, 0, parseInt(t.spacing(1.25)), parseInt(t.spacing(3.25))],
74
+ margin: 0,
75
+ show: !0,
76
+ showMaxLabel: !0,
77
+ showMinLabel: !1,
78
+ align: "right",
79
+ verticalAlign: "bottom"
80
+ },
81
+ axisLine: {
82
+ show: !1
83
+ },
84
+ axisTick: {
85
+ show: !1
86
+ },
87
+ splitLine: {
88
+ show: !0,
89
+ lineStyle: {
90
+ color: t.palette.black[4]
91
+ }
92
+ }
93
+ };
44
94
  return {
45
- legend: u(o),
95
+ legend: I(n),
46
96
  grid: {
47
- ...!o && {
97
+ ...!n && {
48
98
  bottom: parseInt(t.spacing(1))
49
99
  },
50
- ...o && {
100
+ ...n && {
51
101
  bottom: parseInt(t.spacing(10))
52
102
  }
53
103
  },
54
- xAxis: {
55
- type: "value",
56
- axisLine: {
57
- show: !1
58
- },
59
- axisTick: {
60
- show: !1
61
- },
62
- axisLabel: {
63
- fontSize: t.typography.overlineDelicate.fontSize,
64
- fontFamily: t.typography.overlineDelicate.fontFamily,
65
- showMinLabel: !0,
66
- showMaxLabel: !0,
67
- hideOverlap: !0,
68
- padding: [parseInt(t.spacing(0.5)), parseInt(t.spacing(0.5)), 0, parseInt(t.spacing(0.5))],
69
- color: t.palette.black[60]
70
- },
71
- splitLine: {
72
- show: !0,
73
- lineStyle: {
74
- color: t.palette.black[4]
75
- }
76
- }
77
- },
78
- yAxis: {
79
- type: "value",
80
- axisLabel: {
81
- fontSize: t.typography.overlineDelicate.fontSize,
82
- fontFamily: t.typography.overlineDelicate.fontFamily,
83
- inside: !1,
84
- padding: [0, 0, parseInt(t.spacing(1.25)), parseInt(t.spacing(3.25))],
85
- margin: 0,
86
- show: !0,
87
- showMaxLabel: !0,
88
- showMinLabel: !1,
89
- align: "right",
90
- verticalAlign: "bottom"
91
- },
92
- axisLine: {
93
- show: !1
94
- },
95
- axisTick: {
96
- show: !1
97
- },
98
- splitLine: {
99
- show: !0,
100
- lineStyle: {
101
- color: t.palette.black[4]
102
- }
103
- }
104
- },
104
+ xAxis: u,
105
+ yAxis: L(d, o),
105
106
  tooltip: {
106
- trigger: "item"
107
+ trigger: "item",
107
108
  // position: createTooltipPositioner(theme),
109
+ formatter: k((a) => {
110
+ const r = a.value, y = a.encode?.y?.at(0), l = r[y ?? ""], h = typeof l == "number" && o ? o(l) : l ?? "", x = typeof a.marker == "string" ? a.marker : "";
111
+ return {
112
+ name: a.seriesName ?? "",
113
+ seriesName: "",
114
+ marker: x,
115
+ value: h
116
+ };
117
+ })
108
118
  },
109
119
  color: Object.values(t.palette.qualitative.bold),
110
- series: e.map((v, c) => ({
111
- datasetIndex: c,
120
+ series: e.map((a, r) => ({
121
+ datasetIndex: r,
112
122
  type: "scatter",
113
123
  symbolSize: 8
114
124
  }))
115
125
  };
116
126
  }
117
- const s = {
127
+ const m = {
118
128
  skeleton: {
119
129
  graph: {
120
130
  container: {
121
- ...y.graph.container,
131
+ ..._.graph.container,
122
132
  position: "relative"
123
133
  }
124
134
  },
@@ -135,7 +145,7 @@ const s = {
135
145
  bottom: 0
136
146
  }
137
147
  }
138
- }, b = [{
148
+ }, C = [{
139
149
  left: "20%",
140
150
  top: "62%"
141
151
  }, {
@@ -181,34 +191,34 @@ const s = {
181
191
  left: "40%",
182
192
  top: "40%"
183
193
  }];
184
- function R() {
185
- const e = f(2);
194
+ function Z() {
195
+ const e = b(2);
186
196
  let t;
187
- e[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t = b.map(S), e[0] = t) : t = e[0];
197
+ e[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t = C.map(F), e[0] = t) : t = e[0];
188
198
  let o;
189
- return e[1] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (o = /* @__PURE__ */ p(a, { sx: s.skeleton.graph.container, children: [
199
+ return e[1] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (o = /* @__PURE__ */ g(s, { sx: m.skeleton.graph.container, children: [
190
200
  t,
191
- /* @__PURE__ */ i(a, { sx: s.skeleton.legend, children: Array(2).fill(0).map(x) })
201
+ /* @__PURE__ */ i(s, { sx: m.skeleton.legend, children: Array(2).fill(0).map(A) })
192
202
  ] }), e[1] = o) : o = e[1], o;
193
203
  }
194
- function x(e, t) {
195
- return /* @__PURE__ */ p(a, { sx: {
204
+ function A(e, t) {
205
+ return /* @__PURE__ */ g(s, { sx: {
196
206
  display: "flex",
197
207
  alignItems: "center",
198
- gap: w
208
+ gap: D
199
209
  }, children: [
200
- /* @__PURE__ */ i(n, { variant: "circular", width: 8, height: 8 }),
201
- /* @__PURE__ */ i(n, { width: 48, height: 8 })
210
+ /* @__PURE__ */ i(p, { variant: "circular", width: 8, height: 8 }),
211
+ /* @__PURE__ */ i(p, { width: 48, height: 8 })
202
212
  ] }, t);
203
213
  }
204
- function w(e) {
214
+ function D(e) {
205
215
  const {
206
216
  spacing: t
207
217
  } = e;
208
218
  return t(1.5);
209
219
  }
210
- function S(e, t) {
211
- return /* @__PURE__ */ i(n, { variant: "circular", width: 12, height: 12, sx: {
220
+ function F(e, t) {
221
+ return /* @__PURE__ */ i(p, { variant: "circular", width: 12, height: 12, sx: {
212
222
  position: "absolute",
213
223
  top: e.top,
214
224
  left: e.left,
@@ -216,8 +226,8 @@ function S(e, t) {
216
226
  } }, t);
217
227
  }
218
228
  export {
219
- R as ScatterplotSkeleton,
220
- G as scatterplotConfig,
221
- B as scatterplotDownloadConfig
229
+ Z as ScatterplotSkeleton,
230
+ X as scatterplotConfig,
231
+ U as scatterplotDownloadConfig
222
232
  };
223
233
  //# sourceMappingURL=scatterplot.js.map