@validationcloud/fractal-ui 1.58.0 → 1.60.0

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 (36) hide show
  1. package/dist/charts.d.ts +4 -2
  2. package/dist/charts.js +22 -21
  3. package/dist/components/echarts-renderer/chart-theme.d.ts +6 -0
  4. package/dist/components/echarts-renderer/chart-theme.js +8 -0
  5. package/dist/components/echarts-renderer/echarts-renderer.d.ts +3 -8
  6. package/dist/components/echarts-renderer/echarts-renderer.js +15 -8
  7. package/dist/components/echarts-renderer/echarts-theme-option.d.ts +4 -4
  8. package/dist/components/echarts-renderer/formatters/formatter-functions.d.ts +22 -0
  9. package/dist/components/echarts-renderer/formatters/formatter-functions.js +41 -0
  10. package/dist/components/echarts-renderer/formatters/formatter-tokens.d.ts +63 -0
  11. package/dist/components/echarts-renderer/formatters/formatter-tokens.js +45 -0
  12. package/dist/components/echarts-renderer/formatters/replace-formatter-tokens.d.ts +26 -0
  13. package/dist/components/echarts-renderer/formatters/replace-formatter-tokens.js +70 -0
  14. package/dist/components/echarts-renderer/formatters/replace-formatter-tokens.test.d.ts +1 -0
  15. package/dist/components/echarts-renderer/mavrik-theme-horizontal.json.d.ts +26 -37
  16. package/dist/components/echarts-renderer/mavrik-theme-horizontal.json.js +34 -32
  17. package/dist/components/echarts-renderer/mavrik-theme.d.ts +4 -493
  18. package/dist/components/echarts-renderer/mavrik-theme.js +12 -19
  19. package/dist/components/echarts-renderer/mavrik-theme.json.d.ts +26 -37
  20. package/dist/components/echarts-renderer/mavrik-theme.json.js +34 -32
  21. package/dist/components/echarts-renderer/merge-theme-graphic-into-options.d.ts +9 -0
  22. package/dist/components/echarts-renderer/merge-theme-graphic-into-options.js +10 -0
  23. package/dist/components/echarts-renderer/use-chart-instance.d.ts +2 -5
  24. package/dist/components/echarts-renderer/use-chart-instance.js +47 -43
  25. package/dist/lib/render-chart-to-image.d.ts +4 -9
  26. package/dist/lib/render-chart-to-image.js +55 -44
  27. package/dist/lib/render-mavrik-chart-to-image.d.ts +1 -2
  28. package/dist/lib/render-mavrik-chart-to-image.js +15 -17
  29. package/dist/lib/render-mavrik-chart-to-image.test.d.ts +1 -0
  30. package/dist/server.d.ts +1 -0
  31. package/dist/server.js +9 -4
  32. package/package.json +1 -1
  33. package/dist/assets/vc-logo.svg.js +0 -4
  34. package/dist/components/echarts-renderer/echarts-theme-option.js +0 -9
  35. package/dist/components/echarts-renderer/watermark-graphic.d.ts +0 -12
  36. package/dist/components/echarts-renderer/watermark-graphic.js +0 -25
package/dist/charts.d.ts CHANGED
@@ -1,9 +1,11 @@
1
1
  export { EChartsRenderer, type EChartsRendererProps, type EChartsRendererRef, type EChartsOption, } from './components/echarts-renderer/echarts-renderer';
2
- export { EChartsThemeOption, isEChartsThemeOption } from './components/echarts-renderer/echarts-theme-option';
2
+ export { type ChartTheme, isChartTheme } from './components/echarts-renderer/chart-theme';
3
+ export type { EChartsThemeOption } from './components/echarts-renderer/echarts-theme-option';
3
4
  export { EChartsChartOption, isEChartsChartOption } from './components/echarts-renderer/echarts-chart-option';
4
5
  export { useChartInstance, type UseChartInstanceProps, type UseChartInstanceReturn, } from './components/echarts-renderer/use-chart-instance';
5
6
  export { MavrikChart, type MavrikChartProps } from './components/echarts-renderer/mavrik-chart';
6
7
  export { MAVRIK_THEME, MAVRIK_THEME_HORIZONTAL, selectMavrikTheme, type MavrikTheme, } from './components/echarts-renderer/mavrik-theme';
7
8
  export { hasHorizontalBars } from './components/echarts-renderer/detect-horizontal-bars';
8
- export { addWatermarkToOptions, WATERMARK_GRAPHIC } from './components/echarts-renderer/watermark-graphic';
9
9
  export { sanitizeChartOptionsForStaticRendering } from './components/echarts-renderer/sanitize-chart-options-for-static-rendering';
10
+ export { FormatterToken, isFormatterToken } from './components/echarts-renderer/formatters/formatter-tokens';
11
+ export { replaceFormatterTokens } from './components/echarts-renderer/formatters/replace-formatter-tokens';
package/dist/charts.js CHANGED
@@ -1,25 +1,26 @@
1
- import { EChartsRenderer as o } from "./components/echarts-renderer/echarts-renderer.js";
2
- import { EChartsThemeOption as a, isEChartsThemeOption as i } from "./components/echarts-renderer/echarts-theme-option.js";
3
- import { EChartsChartOption as s, isEChartsChartOption as h } from "./components/echarts-renderer/echarts-chart-option.js";
1
+ import { EChartsRenderer as e } from "./components/echarts-renderer/echarts-renderer.js";
2
+ import { isChartTheme as a } from "./components/echarts-renderer/chart-theme.js";
3
+ import { EChartsChartOption as p, isEChartsChartOption as s } from "./components/echarts-renderer/echarts-chart-option.js";
4
4
  import { useChartInstance as n } from "./components/echarts-renderer/use-chart-instance.js";
5
- import { MavrikChart as E } from "./components/echarts-renderer/mavrik-chart.js";
6
- import { MAVRIK_THEME as x, MAVRIK_THEME_HORIZONTAL as O, selectMavrikTheme as R } from "./components/echarts-renderer/mavrik-theme.js";
7
- import { hasHorizontalBars as M } from "./components/echarts-renderer/detect-horizontal-bars.js";
8
- import { WATERMARK_GRAPHIC as H, addWatermarkToOptions as I } from "./components/echarts-renderer/watermark-graphic.js";
9
- import { sanitizeChartOptionsForStaticRendering as _ } from "./components/echarts-renderer/sanitize-chart-options-for-static-rendering.js";
5
+ import { MavrikChart as f } from "./components/echarts-renderer/mavrik-chart.js";
6
+ import { MAVRIK_THEME as C, MAVRIK_THEME_HORIZONTAL as T, selectMavrikTheme as E } from "./components/echarts-renderer/mavrik-theme.js";
7
+ import { hasHorizontalBars as k } from "./components/echarts-renderer/detect-horizontal-bars.js";
8
+ import { sanitizeChartOptionsForStaticRendering as R } from "./components/echarts-renderer/sanitize-chart-options-for-static-rendering.js";
9
+ import { FormatterToken as F, isFormatterToken as H } from "./components/echarts-renderer/formatters/formatter-tokens.js";
10
+ import { replaceFormatterTokens as l } from "./components/echarts-renderer/formatters/replace-formatter-tokens.js";
10
11
  export {
11
- s as EChartsChartOption,
12
- o as EChartsRenderer,
13
- a as EChartsThemeOption,
14
- x as MAVRIK_THEME,
15
- O as MAVRIK_THEME_HORIZONTAL,
16
- E as MavrikChart,
17
- H as WATERMARK_GRAPHIC,
18
- I as addWatermarkToOptions,
19
- M as hasHorizontalBars,
20
- h as isEChartsChartOption,
21
- i as isEChartsThemeOption,
22
- _ as sanitizeChartOptionsForStaticRendering,
23
- R as selectMavrikTheme,
12
+ p as EChartsChartOption,
13
+ e as EChartsRenderer,
14
+ F as FormatterToken,
15
+ C as MAVRIK_THEME,
16
+ T as MAVRIK_THEME_HORIZONTAL,
17
+ f as MavrikChart,
18
+ k as hasHorizontalBars,
19
+ a as isChartTheme,
20
+ s as isEChartsChartOption,
21
+ H as isFormatterToken,
22
+ l as replaceFormatterTokens,
23
+ R as sanitizeChartOptionsForStaticRendering,
24
+ E as selectMavrikTheme,
24
25
  n as useChartInstance
25
26
  };
@@ -0,0 +1,6 @@
1
+ import { EChartsThemeOption } from './echarts-theme-option';
2
+ export type ChartTheme = {
3
+ name: string;
4
+ config: EChartsThemeOption;
5
+ };
6
+ export declare const isChartTheme: (value: unknown) => value is ChartTheme;
@@ -0,0 +1,8 @@
1
+ const o = (t) => {
2
+ if (!t || typeof t != "object") return !1;
3
+ const e = t;
4
+ return typeof e.name == "string" && typeof e.config == "object";
5
+ };
6
+ export {
7
+ o as isChartTheme
8
+ };
@@ -1,4 +1,5 @@
1
1
  import { EChartsOption } from 'echarts';
2
+ import { ChartTheme } from './chart-theme';
2
3
  import { EChartsThemeOption } from './echarts-theme-option';
3
4
  export type { EChartsOption, EChartsThemeOption };
4
5
  export type EChartsRendererRef = {
@@ -6,17 +7,11 @@ export type EChartsRendererRef = {
6
7
  };
7
8
  export type EChartsRendererProps = {
8
9
  readonly option: EChartsOption;
9
- readonly theme?: {
10
- name: string;
11
- config: EChartsThemeOption;
12
- };
10
+ readonly theme?: ChartTheme;
13
11
  readonly className?: string;
14
12
  } & Omit<React.ComponentPropsWithoutRef<'div'>, 'children'>;
15
13
  export declare const EChartsRenderer: import('react').ForwardRefExoticComponent<{
16
14
  readonly option: EChartsOption;
17
- readonly theme?: {
18
- name: string;
19
- config: EChartsThemeOption;
20
- };
15
+ readonly theme?: ChartTheme;
21
16
  readonly className?: string;
22
17
  } & Omit<Omit<import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref">, "children"> & import('react').RefAttributes<EChartsRendererRef>>;
@@ -1,20 +1,27 @@
1
1
  "use client";
2
- import { jsx as r } from "react/jsx-runtime";
2
+ import { jsx as e } from "react/jsx-runtime";
3
3
  import { forwardRef as f, useImperativeHandle as i } from "react";
4
- import { twMerge as d } from "../../lib/tailwind-merge.js";
4
+ import { twMerge as s } from "../../lib/tailwind-merge.js";
5
5
  import { useChartInstance as m } from "./use-chart-instance.js";
6
- const v = f(function({ className: o, option: t, theme: n, ...a }, l) {
7
- const { containerRef: s, downloadChart: e } = m({
6
+ const v = f(function({ className: o, option: t, theme: n, ...l }, a) {
7
+ const { containerRef: d, downloadChart: r } = m({
8
8
  options: t,
9
9
  theme: n
10
10
  });
11
11
  return i(
12
- l,
12
+ a,
13
13
  () => ({
14
- download: e
14
+ download: r
15
15
  }),
16
- [e]
17
- ), /* @__PURE__ */ r("div", { className: d("relative h-full w-full", o), ...a, children: /* @__PURE__ */ r("div", { className: "h-full w-full", ref: s }) });
16
+ [r]
17
+ ), /* @__PURE__ */ e(
18
+ "div",
19
+ {
20
+ className: s("border-neutral-70 relative h-full w-full overflow-hidden rounded-lg border", o),
21
+ ...l,
22
+ children: /* @__PURE__ */ e("div", { className: "h-full w-full", ref: d })
23
+ }
24
+ );
18
25
  });
19
26
  export {
20
27
  v as EChartsRenderer
@@ -1,4 +1,4 @@
1
- import { z } from 'zod';
2
- export declare const EChartsThemeOption: z.ZodObject<{}, z.core.$catchall<z.ZodUnknown>>;
3
- export type EChartsThemeOption = z.infer<typeof EChartsThemeOption>;
4
- export declare function isEChartsThemeOption(value: unknown): value is EChartsThemeOption;
1
+ import { GraphicComponentOption } from 'echarts';
2
+ export type EChartsThemeOption = Record<string, unknown> & {
3
+ graphic?: GraphicComponentOption | GraphicComponentOption[];
4
+ };
@@ -0,0 +1,22 @@
1
+ import { FormatterTemplate, FormatterToken } from './formatter-tokens';
2
+ /**
3
+ * ECharts formatter function signature.
4
+ * Accepts a numeric value (or string that can be converted to number) and returns formatted string.
5
+ */
6
+ export type EChartsFormatter = (value: number | string) => string;
7
+ /**
8
+ * Registry mapping formatter tokens to their implementations.
9
+ */
10
+ export declare const formatterRegistry: Record<FormatterToken, EChartsFormatter>;
11
+ /**
12
+ * Retrieves the formatter function for a given token.
13
+ */
14
+ export declare function getFormatter(token: FormatterToken): EChartsFormatter;
15
+ /**
16
+ * Creates a formatter function from a template with prefix/suffix.
17
+ *
18
+ * @example
19
+ * const formatter = createTemplateFormatter({ token: "COMPACT_1", prefix: "$", suffix: " USD" });
20
+ * formatter(1500) // "$1.5k USD"
21
+ */
22
+ export declare function createTemplateFormatter(template: FormatterTemplate): EChartsFormatter;
@@ -0,0 +1,41 @@
1
+ function C(e, t) {
2
+ const r = Math.abs(e), o = e < 0 ? "-" : "";
3
+ return r >= 1e12 ? `${o}${(r / 1e12).toFixed(t)}T` : r >= 1e9 ? `${o}${(r / 1e9).toFixed(t)}B` : r >= 1e6 ? `${o}${(r / 1e6).toFixed(t)}M` : r >= 1e3 ? `${o}${(r / 1e3).toFixed(t)}k` : e.toFixed(t);
4
+ }
5
+ const N = {
6
+ // Fixed decimal places
7
+ VC_PRECISION_0: (e) => Number(e).toFixed(0),
8
+ VC_PRECISION_1: (e) => Number(e).toFixed(1),
9
+ VC_PRECISION_2: (e) => Number(e).toFixed(2),
10
+ VC_PRECISION_3: (e) => Number(e).toFixed(3),
11
+ VC_PRECISION_4: (e) => Number(e).toFixed(4),
12
+ VC_PRECISION_5: (e) => Number(e).toFixed(5),
13
+ VC_PRECISION_6: (e) => Number(e).toFixed(6),
14
+ // Significant digits
15
+ VC_SIGNIFICANT_1: (e) => Number(e).toPrecision(1),
16
+ VC_SIGNIFICANT_2: (e) => Number(e).toPrecision(2),
17
+ VC_SIGNIFICANT_3: (e) => Number(e).toPrecision(3),
18
+ VC_SIGNIFICANT_4: (e) => Number(e).toPrecision(4),
19
+ VC_SIGNIFICANT_5: (e) => Number(e).toPrecision(5),
20
+ VC_SIGNIFICANT_6: (e) => Number(e).toPrecision(6),
21
+ // Compact notation
22
+ VC_COMPACT_0: (e) => C(Number(e), 0),
23
+ VC_COMPACT_1: (e) => C(Number(e), 1),
24
+ VC_COMPACT_2: (e) => C(Number(e), 2),
25
+ // Percentage formatting (multiplies by 100)
26
+ VC_PERCENT_0: (e) => `${(Number(e) * 100).toFixed(0)}%`,
27
+ VC_PERCENT_1: (e) => `${(Number(e) * 100).toFixed(1)}%`,
28
+ VC_PERCENT_2: (e) => `${(Number(e) * 100).toFixed(2)}%`
29
+ };
30
+ function _(e) {
31
+ return N[e];
32
+ }
33
+ function i(e) {
34
+ const t = N[e.token];
35
+ return (r) => `${e.prefix}${t(r)}${e.suffix}`;
36
+ }
37
+ export {
38
+ i as createTemplateFormatter,
39
+ N as formatterRegistry,
40
+ _ as getFormatter
41
+ };
@@ -0,0 +1,63 @@
1
+ /**
2
+ * Formatter token constants for use in static JSON chart options.
3
+ *
4
+ * These tokens are replaced with actual formatter functions at render time,
5
+ * allowing chart options to remain as serializable JSON.
6
+ *
7
+ * Supports two syntaxes:
8
+ * 1. Simple token: `"VC_COMPACT_1"` → "5.2k"
9
+ * 2. Template with prefix/suffix: `"${VC_COMPACT_1} USD"` → "$5.2k USD"
10
+ *
11
+ * @example
12
+ * ```json
13
+ * {
14
+ * "yAxis": { "axisLabel": { "formatter": "{VC_COMPACT_1}" } },
15
+ * "tooltip": { "valueFormatter": "${VC_COMPACT_1} USD" }
16
+ * }
17
+ * ```
18
+ */
19
+ export declare const FormatterToken: {
20
+ readonly VC_PRECISION_0: "VC_PRECISION_0";
21
+ readonly VC_PRECISION_1: "VC_PRECISION_1";
22
+ readonly VC_PRECISION_2: "VC_PRECISION_2";
23
+ readonly VC_PRECISION_3: "VC_PRECISION_3";
24
+ readonly VC_PRECISION_4: "VC_PRECISION_4";
25
+ readonly VC_PRECISION_5: "VC_PRECISION_5";
26
+ readonly VC_PRECISION_6: "VC_PRECISION_6";
27
+ readonly VC_SIGNIFICANT_1: "VC_SIGNIFICANT_1";
28
+ readonly VC_SIGNIFICANT_2: "VC_SIGNIFICANT_2";
29
+ readonly VC_SIGNIFICANT_3: "VC_SIGNIFICANT_3";
30
+ readonly VC_SIGNIFICANT_4: "VC_SIGNIFICANT_4";
31
+ readonly VC_SIGNIFICANT_5: "VC_SIGNIFICANT_5";
32
+ readonly VC_SIGNIFICANT_6: "VC_SIGNIFICANT_6";
33
+ readonly VC_COMPACT_0: "VC_COMPACT_0";
34
+ readonly VC_COMPACT_1: "VC_COMPACT_1";
35
+ readonly VC_COMPACT_2: "VC_COMPACT_2";
36
+ readonly VC_PERCENT_0: "VC_PERCENT_0";
37
+ readonly VC_PERCENT_1: "VC_PERCENT_1";
38
+ readonly VC_PERCENT_2: "VC_PERCENT_2";
39
+ };
40
+ export type FormatterToken = (typeof FormatterToken)[keyof typeof FormatterToken];
41
+ /**
42
+ * Type guard to check if a value is a valid simple formatter token (e.g., "COMPACT_1").
43
+ */
44
+ export declare function isFormatterToken(value: unknown): value is FormatterToken;
45
+ /**
46
+ * Parsed result of a formatter template string.
47
+ */
48
+ export type FormatterTemplate = {
49
+ token: FormatterToken;
50
+ prefix: string;
51
+ suffix: string;
52
+ };
53
+ /**
54
+ * Parses a formatter template string into its components.
55
+ * Returns null if the string is not a valid formatter template.
56
+ *
57
+ * @example
58
+ * parseFormatterTemplate("{VC_COMPACT_1}") // { token: "VC_COMPACT_1", prefix: "", suffix: "" }
59
+ * parseFormatterTemplate("${VC_COMPACT_1}") // { token: "VC_COMPACT_1", prefix: "$", suffix: "" }
60
+ * parseFormatterTemplate("{VC_COMPACT_1} WETH") // { token: "VC_COMPACT_1", prefix: "", suffix: " WETH" }
61
+ * parseFormatterTemplate("${VC_PRECISION_2} USD") // { token: "VC_PRECISION_2", prefix: "$", suffix: " USD" }
62
+ */
63
+ export declare function parseFormatterTemplate(value: unknown): FormatterTemplate | null;
@@ -0,0 +1,45 @@
1
+ const E = {
2
+ // Fixed decimal places (0-6)
3
+ VC_PRECISION_0: "VC_PRECISION_0",
4
+ VC_PRECISION_1: "VC_PRECISION_1",
5
+ VC_PRECISION_2: "VC_PRECISION_2",
6
+ VC_PRECISION_3: "VC_PRECISION_3",
7
+ VC_PRECISION_4: "VC_PRECISION_4",
8
+ VC_PRECISION_5: "VC_PRECISION_5",
9
+ VC_PRECISION_6: "VC_PRECISION_6",
10
+ // Significant digits (1-6)
11
+ VC_SIGNIFICANT_1: "VC_SIGNIFICANT_1",
12
+ VC_SIGNIFICANT_2: "VC_SIGNIFICANT_2",
13
+ VC_SIGNIFICANT_3: "VC_SIGNIFICANT_3",
14
+ VC_SIGNIFICANT_4: "VC_SIGNIFICANT_4",
15
+ VC_SIGNIFICANT_5: "VC_SIGNIFICANT_5",
16
+ VC_SIGNIFICANT_6: "VC_SIGNIFICANT_6",
17
+ // Compact notation (k/M/B/T suffixes)
18
+ VC_COMPACT_0: "VC_COMPACT_0",
19
+ VC_COMPACT_1: "VC_COMPACT_1",
20
+ VC_COMPACT_2: "VC_COMPACT_2",
21
+ // Percentage formatting
22
+ VC_PERCENT_0: "VC_PERCENT_0",
23
+ VC_PERCENT_1: "VC_PERCENT_1",
24
+ VC_PERCENT_2: "VC_PERCENT_2"
25
+ }, N = new Set(Object.values(E));
26
+ function S(C) {
27
+ return typeof C == "string" && N.has(C);
28
+ }
29
+ const T = /^(.*)\{([A-Z0-9_]+)\}(.*)$/;
30
+ function P(C) {
31
+ if (typeof C != "string") return null;
32
+ const _ = T.exec(C);
33
+ if (!_) return null;
34
+ const [, V = "", I = "", t = ""] = _;
35
+ return N.has(I) ? {
36
+ token: I,
37
+ prefix: V,
38
+ suffix: t
39
+ } : null;
40
+ }
41
+ export {
42
+ E as FormatterToken,
43
+ S as isFormatterToken,
44
+ P as parseFormatterTemplate
45
+ };
@@ -0,0 +1,26 @@
1
+ import { EChartsOption } from 'echarts';
2
+ /**
3
+ * Input type that allows formatter tokens (strings) where ECharts expects functions.
4
+ * This is needed because JSON options will have string tokens that get replaced.
5
+ */
6
+ export type EChartsOptionWithTokens = Record<string, unknown>;
7
+ /**
8
+ * Replaces formatter token strings with actual formatter functions.
9
+ *
10
+ * Traverses known ECharts formatter paths and replaces any token strings
11
+ * (e.g., "PRECISION_2") with the corresponding formatter function.
12
+ *
13
+ * @param options - ECharts options that may contain formatter tokens
14
+ * @returns New options object with tokens replaced by functions
15
+ *
16
+ * @example
17
+ * ```ts
18
+ * const options = {
19
+ * xAxis: { axisLabel: { formatter: 'PRECISION_2' } },
20
+ * tooltip: { valueFormatter: 'COMPACT_1' }
21
+ * };
22
+ * const resolved = replaceFormatterTokens(options);
23
+ * // resolved.xAxis.axisLabel.formatter is now a function
24
+ * ```
25
+ */
26
+ export declare function replaceFormatterTokens(options: EChartsOptionWithTokens): EChartsOption;
@@ -0,0 +1,70 @@
1
+ import { getFormatter as p, createTemplateFormatter as u } from "./formatter-functions.js";
2
+ import { isFormatterToken as A, parseFormatterTemplate as b } from "./formatter-tokens.js";
3
+ function l(t) {
4
+ if (t === null || typeof t != "object")
5
+ return t;
6
+ if (Array.isArray(t))
7
+ return t.map((o) => l(o));
8
+ const e = {};
9
+ for (const r of Object.keys(t))
10
+ e[r] = l(t[r]);
11
+ return e;
12
+ }
13
+ const y = [
14
+ // Axis formatters (single object form)
15
+ "xAxis.axisLabel.formatter",
16
+ "yAxis.axisLabel.formatter",
17
+ "radiusAxis.axisLabel.formatter",
18
+ "angleAxis.axisLabel.formatter",
19
+ // Axis formatters (array form)
20
+ "xAxis[].axisLabel.formatter",
21
+ "yAxis[].axisLabel.formatter",
22
+ // Tooltip formatters
23
+ "tooltip.formatter",
24
+ "tooltip.valueFormatter",
25
+ // Series formatters
26
+ "series[].label.formatter",
27
+ "series[].labelLine.formatter",
28
+ "series[].emphasis.label.formatter",
29
+ "series[].tooltip.valueFormatter",
30
+ "series[].tooltip.formatter",
31
+ // Legend formatter
32
+ "legend.formatter",
33
+ // Visual map formatters
34
+ "visualMap.formatter",
35
+ "visualMap[].formatter"
36
+ ];
37
+ function T(t) {
38
+ const e = l(t);
39
+ for (const r of y)
40
+ x(e, r);
41
+ return e;
42
+ }
43
+ function x(t, e) {
44
+ const r = e.split(".");
45
+ n(t, r, 0);
46
+ }
47
+ function n(t, e, r) {
48
+ if (t == null || r >= e.length || typeof t != "object") return;
49
+ const o = e[r];
50
+ if (o === void 0) return;
51
+ const c = r === e.length - 1, m = o.endsWith("[]"), s = m ? o.slice(0, -2) : o, i = t;
52
+ if (m) {
53
+ const a = i[s];
54
+ if (Array.isArray(a))
55
+ for (const f of a)
56
+ n(f, e, r + 1);
57
+ } else if (c) {
58
+ const a = i[s];
59
+ if (A(a))
60
+ i[s] = p(a);
61
+ else {
62
+ const f = b(a);
63
+ f && (i[s] = u(f));
64
+ }
65
+ } else
66
+ n(i[s], e, r + 1);
67
+ }
68
+ export {
69
+ T as replaceFormatterTokens
70
+ };
@@ -13,46 +13,21 @@ declare const _default: {
13
13
  },
14
14
  {
15
15
  "offset": 1,
16
- "color": "#DF687D"
16
+ "color": "#DE7385"
17
17
  }
18
18
  ]
19
19
  },
20
- {
21
- "type": "linear",
22
- "x": 0,
23
- "y": 0,
24
- "x2": 1,
25
- "y2": 0,
26
- "colorStops": [
27
- {
28
- "offset": 0,
29
- "color": "#FFFFFF"
30
- },
31
- {
32
- "offset": 1,
33
- "color": "#FFFFFF"
34
- }
35
- ]
36
- },
37
- {
38
- "type": "linear",
39
- "x": 0,
40
- "y": 0,
41
- "x2": 1,
42
- "y2": 0,
43
- "colorStops": [
44
- {
45
- "offset": 0,
46
- "color": "#1E6FDA"
47
- },
48
- {
49
- "offset": 1,
50
- "color": "#3F8CFF"
51
- }
52
- ]
53
- }
20
+ "#00BBFA",
21
+ "#0072B2",
22
+ "#E69F00",
23
+ "#D66119",
24
+ "#56B4E9",
25
+ "#45B26B",
26
+ "#F0E442",
27
+ "#FF99BF",
28
+ "#8277D8"
54
29
  ],
55
- "backgroundColor": "#242731",
30
+ "backgroundColor": "#1A1D1F",
56
31
  "textStyle": {
57
32
  "fontFamily": "Poppins, sans-serif",
58
33
  "fontWeight": 500
@@ -214,7 +189,7 @@ declare const _default: {
214
189
  "outerBoundsContain": "axisLabel"
215
190
  },
216
191
  "dataZoom": {
217
- "backgroundColor": "rgba(36, 39, 49, 0)",
192
+ "backgroundColor": "rgba(26, 29, 31, 0)",
218
193
  "borderColor": "#3A3D46",
219
194
  "borderRadius": 4,
220
195
  "dataBackground": {
@@ -268,6 +243,7 @@ declare const _default: {
268
243
  }
269
244
  },
270
245
  "tooltip": {
246
+ "confine": true,
271
247
  "backgroundColor": "transparent",
272
248
  "padding": 10,
273
249
  "borderRadius": 8,
@@ -281,6 +257,19 @@ declare const _default: {
281
257
  "fontWeight": 500
282
258
  },
283
259
  "extraCssText": "letter-spacing: 0.22px; box-shadow: 0 14px 11px -4px rgba(0, 0, 0, 0.30), 0 -4px 4px 0 rgba(0, 0, 0, 0.04) inset; background: radial-gradient(ellipse at 25% 0%, rgba(217, 217, 217, 0.12) 0%, transparent 60%), #1A1D1F;"
260
+ },
261
+ "graphic": {
262
+ "type": "image",
263
+ "id": "fractal-watermark",
264
+ "left": "center",
265
+ "top": "middle",
266
+ "style": {
267
+ "image": "",
268
+ "width": 210,
269
+ "height": 24
270
+ },
271
+ "z": 100,
272
+ "silent": true
284
273
  }
285
274
  }
286
275
  ;
@@ -1,35 +1,37 @@
1
- const o = [{ type: "linear", x: 0, y: 0, x2: 1, y2: 0, colorStops: [{ offset: 0, color: "#C14E64" }, { offset: 1, color: "#DF687D" }] }, { type: "linear", x: 0, y: 0, x2: 1, y2: 0, colorStops: [{ offset: 0, color: "#FFFFFF" }, { offset: 1, color: "#FFFFFF" }] }, { type: "linear", x: 0, y: 0, x2: 1, y2: 0, colorStops: [{ offset: 0, color: "#1E6FDA" }, { offset: 1, color: "#3F8CFF" }] }], e = "#242731", t = { fontFamily: "Poppins, sans-serif", fontWeight: 500 }, l = { top: 32, left: 32, textStyle: { color: "#FFFFFF", fontSize: 16, fontWeight: 600 }, subtextStyle: { color: "#A7A9AD" } }, r = { itemStyle: { borderWidth: 1 }, lineStyle: { width: 2 }, areaStyle: { opacity: 0.15 }, showSymbol: !1, symbolSize: 5, symbol: "circle", smooth: !1, sampling: "lttb" }, a = { barGap: "25%", barCategoryGap: "25%" }, i = { axisLine: { show: !0, lineStyle: { color: "#3A3D46", type: "dashed" } }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !1 } }, s = { axisLine: { show: !1 }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !0, lineStyle: { color: ["#3A3D46"], type: "dashed" } } }, n = { axisLine: { show: !1 }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !0, lineStyle: { color: ["#3A3D46"], type: "dashed" } } }, c = { axisLine: { show: !0, lineStyle: { color: "#3A3D46" } }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !1 } }, d = { top: 82, left: "auto", right: 32, icon: "circle", itemGap: 22, itemWidth: 12, itemHeight: 12, textStyle: { color: "#A7A9AD", fontSize: 11 } }, h = { top: 132, left: 32, right: 32, bottom: 32, outerBoundsMode: "same", outerBoundsContain: "axisLabel" }, A = { backgroundColor: "rgba(36, 39, 49, 0)", borderColor: "#3A3D46", borderRadius: 4, dataBackground: { lineStyle: { color: "#606060", width: 1 }, areaStyle: { color: "rgba(96, 96, 96, 0.3)" } }, selectedDataBackground: { lineStyle: { color: "#b36674", width: 1 }, areaStyle: { color: "rgba(164, 91, 105, 0.5)" } }, fillerColor: "rgba(82, 45, 52, 0.35)", handleStyle: { color: "#C14E64", borderColor: "#C14E64" }, moveHandleStyle: { color: "#b36674" }, brushStyle: { color: "rgba(95, 58, 65, 0.2)" }, emphasis: { handleStyle: { color: "rgb(209, 123, 140)", borderColor: "rgb(209, 123, 140)" } }, handleSize: "100%", textStyle: { color: "#A7A9AD" } }, f = { label: { color: "#A7A9AD" }, emphasis: { label: { color: "#FFFFFF" } } }, y = { backgroundColor: "transparent", padding: 10, borderRadius: 8, borderColor: "#50525A", borderWidth: 1, textStyle: { color: "#FCFCFC", fontFamily: "Poppins, sans-serif", fontSize: 11, fontStyle: "normal", fontWeight: 500 }, extraCssText: "letter-spacing: 0.22px; box-shadow: 0 14px 11px -4px rgba(0, 0, 0, 0.30), 0 -4px 4px 0 rgba(0, 0, 0, 0.04) inset; background: radial-gradient(ellipse at 25% 0%, rgba(217, 217, 217, 0.12) 0%, transparent 60%), #1A1D1F;" }, p = {
2
- color: o,
3
- backgroundColor: e,
4
- textStyle: t,
5
- title: l,
6
- line: r,
7
- bar: a,
8
- categoryAxis: i,
9
- valueAxis: s,
10
- logAxis: n,
11
- timeAxis: c,
12
- legend: d,
13
- grid: h,
14
- dataZoom: A,
15
- markPoint: f,
16
- tooltip: y
1
+ const M = [{ type: "linear", x: 0, y: 0, x2: 1, y2: 0, colorStops: [{ offset: 0, color: "#C14E64" }, { offset: 1, color: "#DE7385" }] }, "#00BBFA", "#0072B2", "#E69F00", "#D66119", "#56B4E9", "#45B26B", "#F0E442", "#FF99BF", "#8277D8"], L = "#1A1D1F", N = { fontFamily: "Poppins, sans-serif", fontWeight: 500 }, j = { top: 32, left: 32, textStyle: { color: "#FFFFFF", fontSize: 16, fontWeight: 600 }, subtextStyle: { color: "#A7A9AD" } }, D = { itemStyle: { borderWidth: 1 }, lineStyle: { width: 2 }, areaStyle: { opacity: 0.15 }, showSymbol: !1, symbolSize: 5, symbol: "circle", smooth: !1, sampling: "lttb" }, A = { barGap: "25%", barCategoryGap: "25%" }, g = { axisLine: { show: !0, lineStyle: { color: "#3A3D46", type: "dashed" } }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !1 } }, I = { axisLine: { show: !1 }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !0, lineStyle: { color: ["#3A3D46"], type: "dashed" } } }, u = { axisLine: { show: !1 }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !0, lineStyle: { color: ["#3A3D46"], type: "dashed" } } }, t = { axisLine: { show: !0, lineStyle: { color: "#3A3D46" } }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !1 } }, T = { top: 82, left: "auto", right: 32, icon: "circle", itemGap: 22, itemWidth: 12, itemHeight: 12, textStyle: { color: "#A7A9AD", fontSize: 11 } }, y = { top: 132, left: 32, right: 32, bottom: 32, outerBoundsMode: "same", outerBoundsContain: "axisLabel" }, S = { backgroundColor: "rgba(26, 29, 31, 0)", borderColor: "#3A3D46", borderRadius: 4, dataBackground: { lineStyle: { color: "#606060", width: 1 }, areaStyle: { color: "rgba(96, 96, 96, 0.3)" } }, selectedDataBackground: { lineStyle: { color: "#b36674", width: 1 }, areaStyle: { color: "rgba(164, 91, 105, 0.5)" } }, fillerColor: "rgba(82, 45, 52, 0.35)", handleStyle: { color: "#C14E64", borderColor: "#C14E64" }, moveHandleStyle: { color: "#b36674" }, brushStyle: { color: "rgba(95, 58, 65, 0.2)" }, emphasis: { handleStyle: { color: "rgb(209, 123, 140)", borderColor: "rgb(209, 123, 140)" } }, handleSize: "100%", textStyle: { color: "#A7A9AD" } }, z = { label: { color: "#A7A9AD" }, emphasis: { label: { color: "#FFFFFF" } } }, i = { confine: !0, backgroundColor: "transparent", padding: 10, borderRadius: 8, borderColor: "#50525A", borderWidth: 1, textStyle: { color: "#FCFCFC", fontFamily: "Poppins, sans-serif", fontSize: 11, fontStyle: "normal", fontWeight: 500 }, extraCssText: "letter-spacing: 0.22px; box-shadow: 0 14px 11px -4px rgba(0, 0, 0, 0.30), 0 -4px 4px 0 rgba(0, 0, 0, 0.04) inset; background: radial-gradient(ellipse at 25% 0%, rgba(217, 217, 217, 0.12) 0%, transparent 60%), #1A1D1F;" }, x = { type: "image", id: "fractal-watermark", left: "center", top: "middle", style: { image: "", width: 210, height: 24 }, z: 100, silent: !0 }, C = {
2
+ color: M,
3
+ backgroundColor: L,
4
+ textStyle: N,
5
+ title: j,
6
+ line: D,
7
+ bar: A,
8
+ categoryAxis: g,
9
+ valueAxis: I,
10
+ logAxis: u,
11
+ timeAxis: t,
12
+ legend: T,
13
+ grid: y,
14
+ dataZoom: S,
15
+ markPoint: z,
16
+ tooltip: i,
17
+ graphic: x
17
18
  };
18
19
  export {
19
- e as backgroundColor,
20
- a as bar,
21
- i as categoryAxis,
22
- o as color,
23
- A as dataZoom,
24
- p as default,
25
- h as grid,
26
- d as legend,
27
- r as line,
28
- n as logAxis,
29
- f as markPoint,
30
- t as textStyle,
31
- c as timeAxis,
32
- l as title,
33
- y as tooltip,
34
- s as valueAxis
20
+ L as backgroundColor,
21
+ A as bar,
22
+ g as categoryAxis,
23
+ M as color,
24
+ S as dataZoom,
25
+ C as default,
26
+ x as graphic,
27
+ y as grid,
28
+ T as legend,
29
+ D as line,
30
+ u as logAxis,
31
+ z as markPoint,
32
+ N as textStyle,
33
+ t as timeAxis,
34
+ j as title,
35
+ i as tooltip,
36
+ I as valueAxis
35
37
  };