@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.
- package/dist/charts.d.ts +4 -2
- package/dist/charts.js +22 -21
- package/dist/components/echarts-renderer/chart-theme.d.ts +6 -0
- package/dist/components/echarts-renderer/chart-theme.js +8 -0
- package/dist/components/echarts-renderer/echarts-renderer.d.ts +3 -8
- package/dist/components/echarts-renderer/echarts-renderer.js +15 -8
- package/dist/components/echarts-renderer/echarts-theme-option.d.ts +4 -4
- package/dist/components/echarts-renderer/formatters/formatter-functions.d.ts +22 -0
- package/dist/components/echarts-renderer/formatters/formatter-functions.js +41 -0
- package/dist/components/echarts-renderer/formatters/formatter-tokens.d.ts +63 -0
- package/dist/components/echarts-renderer/formatters/formatter-tokens.js +45 -0
- package/dist/components/echarts-renderer/formatters/replace-formatter-tokens.d.ts +26 -0
- package/dist/components/echarts-renderer/formatters/replace-formatter-tokens.js +70 -0
- package/dist/components/echarts-renderer/formatters/replace-formatter-tokens.test.d.ts +1 -0
- package/dist/components/echarts-renderer/mavrik-theme-horizontal.json.d.ts +26 -37
- package/dist/components/echarts-renderer/mavrik-theme-horizontal.json.js +34 -32
- package/dist/components/echarts-renderer/mavrik-theme.d.ts +4 -493
- package/dist/components/echarts-renderer/mavrik-theme.js +12 -19
- package/dist/components/echarts-renderer/mavrik-theme.json.d.ts +26 -37
- package/dist/components/echarts-renderer/mavrik-theme.json.js +34 -32
- package/dist/components/echarts-renderer/merge-theme-graphic-into-options.d.ts +9 -0
- package/dist/components/echarts-renderer/merge-theme-graphic-into-options.js +10 -0
- package/dist/components/echarts-renderer/use-chart-instance.d.ts +2 -5
- package/dist/components/echarts-renderer/use-chart-instance.js +47 -43
- package/dist/lib/render-chart-to-image.d.ts +4 -9
- package/dist/lib/render-chart-to-image.js +55 -44
- package/dist/lib/render-mavrik-chart-to-image.d.ts +1 -2
- package/dist/lib/render-mavrik-chart-to-image.js +15 -17
- package/dist/lib/render-mavrik-chart-to-image.test.d.ts +1 -0
- package/dist/server.d.ts +1 -0
- package/dist/server.js +9 -4
- package/package.json +1 -1
- package/dist/assets/vc-logo.svg.js +0 -4
- package/dist/components/echarts-renderer/echarts-theme-option.js +0 -9
- package/dist/components/echarts-renderer/watermark-graphic.d.ts +0 -12
- 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 {
|
|
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
|
|
2
|
-
import {
|
|
3
|
-
import { EChartsChartOption as
|
|
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
|
|
6
|
-
import { MAVRIK_THEME as
|
|
7
|
-
import { hasHorizontalBars as
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
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
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
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
|
};
|
|
@@ -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
|
|
2
|
+
import { jsx as e } from "react/jsx-runtime";
|
|
3
3
|
import { forwardRef as f, useImperativeHandle as i } from "react";
|
|
4
|
-
import { twMerge as
|
|
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, ...
|
|
7
|
-
const { containerRef:
|
|
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
|
-
|
|
12
|
+
a,
|
|
13
13
|
() => ({
|
|
14
|
-
download:
|
|
14
|
+
download: r
|
|
15
15
|
}),
|
|
16
|
-
[
|
|
17
|
-
), /* @__PURE__ */
|
|
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 {
|
|
2
|
-
export
|
|
3
|
-
|
|
4
|
-
|
|
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
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -13,46 +13,21 @@ declare const _default: {
|
|
|
13
13
|
},
|
|
14
14
|
{
|
|
15
15
|
"offset": 1,
|
|
16
|
-
"color": "#
|
|
16
|
+
"color": "#DE7385"
|
|
17
17
|
}
|
|
18
18
|
]
|
|
19
19
|
},
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
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": "#
|
|
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(
|
|
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:
|
|
3
|
-
backgroundColor:
|
|
4
|
-
textStyle:
|
|
5
|
-
title:
|
|
6
|
-
line:
|
|
7
|
-
bar:
|
|
8
|
-
categoryAxis:
|
|
9
|
-
valueAxis:
|
|
10
|
-
logAxis:
|
|
11
|
-
timeAxis:
|
|
12
|
-
legend:
|
|
13
|
-
grid:
|
|
14
|
-
dataZoom:
|
|
15
|
-
markPoint:
|
|
16
|
-
tooltip:
|
|
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
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
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
|
};
|