uplot-plus 0.5.14 → 0.5.24

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 (101) hide show
  1. package/README.md +38 -4
  2. package/dist/axes/layout.d.ts +3 -2
  3. package/dist/axes/layout.d.ts.map +1 -1
  4. package/dist/axes/ticks.d.ts +5 -3
  5. package/dist/axes/ticks.d.ts.map +1 -1
  6. package/dist/components/Band.d.ts.map +1 -1
  7. package/dist/components/BoxWhisker.d.ts +6 -1
  8. package/dist/components/BoxWhisker.d.ts.map +1 -1
  9. package/dist/components/Candlestick.d.ts +4 -1
  10. package/dist/components/Candlestick.d.ts.map +1 -1
  11. package/dist/components/Chart.d.ts +1 -1
  12. package/dist/components/Chart.d.ts.map +1 -1
  13. package/dist/components/FloatingLegend.d.ts +3 -8
  14. package/dist/components/FloatingLegend.d.ts.map +1 -1
  15. package/dist/components/Heatmap.d.ts.map +1 -1
  16. package/dist/components/Legend.d.ts.map +1 -1
  17. package/dist/components/Series.d.ts +1 -0
  18. package/dist/components/Series.d.ts.map +1 -1
  19. package/dist/components/Sparkline.d.ts +2 -1
  20. package/dist/components/Sparkline.d.ts.map +1 -1
  21. package/dist/components/ThemeProvider.d.ts +20 -0
  22. package/dist/components/ThemeProvider.d.ts.map +1 -0
  23. package/dist/components/Tooltip.d.ts.map +1 -1
  24. package/dist/components/Vector.d.ts +1 -1
  25. package/dist/components/Vector.d.ts.map +1 -1
  26. package/dist/components/ZoomRanger.d.ts.map +1 -1
  27. package/dist/components/annotations/AnnotationLabel.d.ts.map +1 -1
  28. package/dist/components/annotations/HLine.d.ts.map +1 -1
  29. package/dist/components/annotations/Region.d.ts.map +1 -1
  30. package/dist/components/annotations/VLine.d.ts.map +1 -1
  31. package/dist/components/overlay/SeriesPanel.d.ts +6 -9
  32. package/dist/components/overlay/SeriesPanel.d.ts.map +1 -1
  33. package/dist/components/overlay/tokens.d.ts +17 -0
  34. package/dist/components/overlay/tokens.d.ts.map +1 -0
  35. package/dist/core/DataStore.d.ts.map +1 -1
  36. package/dist/core/RenderScheduler.d.ts +2 -0
  37. package/dist/core/RenderScheduler.d.ts.map +1 -1
  38. package/dist/core/ScaleManager.d.ts.map +1 -1
  39. package/dist/core/normalizeData.d.ts.map +1 -1
  40. package/dist/formatters.d.ts +3 -0
  41. package/dist/formatters.d.ts.map +1 -1
  42. package/dist/hooks/useChartStore.d.ts +14 -9
  43. package/dist/hooks/useChartStore.d.ts.map +1 -1
  44. package/dist/hooks/useDraggableOverlay.d.ts +4 -9
  45. package/dist/hooks/useDraggableOverlay.d.ts.map +1 -1
  46. package/dist/hooks/useInteraction.d.ts.map +1 -1
  47. package/dist/index.cjs +1 -1
  48. package/dist/index.d.ts +6 -1
  49. package/dist/index.d.ts.map +1 -1
  50. package/dist/index.js +2638 -2120
  51. package/dist/math/lttb.d.ts.map +1 -1
  52. package/dist/math/stack.d.ts +3 -2
  53. package/dist/math/stack.d.ts.map +1 -1
  54. package/dist/math/utils.d.ts +1 -1
  55. package/dist/math/utils.d.ts.map +1 -1
  56. package/dist/paths/bars.d.ts +6 -3
  57. package/dist/paths/bars.d.ts.map +1 -1
  58. package/dist/paths/linear.d.ts.map +1 -1
  59. package/dist/paths/lttbLinear.d.ts.map +1 -1
  60. package/dist/paths/points.d.ts.map +1 -1
  61. package/dist/paths/spline.d.ts.map +1 -1
  62. package/dist/paths/stepped.d.ts.map +1 -1
  63. package/dist/paths/types.d.ts +2 -0
  64. package/dist/paths/types.d.ts.map +1 -1
  65. package/dist/paths/utils.d.ts.map +1 -1
  66. package/dist/rendering/CanvasRenderer.d.ts +3 -3
  67. package/dist/rendering/CanvasRenderer.d.ts.map +1 -1
  68. package/dist/rendering/drawAxes.d.ts +2 -2
  69. package/dist/rendering/drawAxes.d.ts.map +1 -1
  70. package/dist/rendering/drawBands.d.ts +5 -2
  71. package/dist/rendering/drawBands.d.ts.map +1 -1
  72. package/dist/rendering/drawCursor.d.ts +2 -2
  73. package/dist/rendering/drawCursor.d.ts.map +1 -1
  74. package/dist/rendering/drawSelect.d.ts +2 -2
  75. package/dist/rendering/drawSelect.d.ts.map +1 -1
  76. package/dist/rendering/theme.d.ts +45 -4
  77. package/dist/rendering/theme.d.ts.map +1 -1
  78. package/dist/time/fmtDate.d.ts +8 -8
  79. package/dist/time/fmtDate.d.ts.map +1 -1
  80. package/dist/time/timeVals.d.ts +1 -1
  81. package/dist/time/timeVals.d.ts.map +1 -1
  82. package/dist/types/chart.d.ts +7 -0
  83. package/dist/types/chart.d.ts.map +1 -1
  84. package/dist/types/common.d.ts +12 -0
  85. package/dist/types/common.d.ts.map +1 -1
  86. package/dist/types/index.d.ts +4 -3
  87. package/dist/types/index.d.ts.map +1 -1
  88. package/dist/types/interaction.d.ts +6 -2
  89. package/dist/types/interaction.d.ts.map +1 -1
  90. package/dist/types/series.d.ts +10 -5
  91. package/dist/types/series.d.ts.map +1 -1
  92. package/dist/types/theme.d.ts +65 -0
  93. package/dist/types/theme.d.ts.map +1 -0
  94. package/dist/types/tooltip.d.ts +3 -8
  95. package/dist/types/tooltip.d.ts.map +1 -1
  96. package/dist/utils/at.d.ts +9 -0
  97. package/dist/utils/at.d.ts.map +1 -0
  98. package/dist/utils/estimatePanelSize.d.ts +2 -1
  99. package/dist/utils/estimatePanelSize.d.ts.map +1 -1
  100. package/dist/utils/shallowEqual.d.ts.map +1 -1
  101. package/package.json +3 -1
@@ -0,0 +1,65 @@
1
+ /** User-facing theme interface. All fields optional — defaults apply for missing values. */
2
+ export interface ChartTheme {
3
+ axisStroke?: string;
4
+ gridStroke?: string;
5
+ titleFill?: string;
6
+ tickFont?: string;
7
+ labelFont?: string;
8
+ titleFont?: string;
9
+ bandFill?: string;
10
+ cursor?: {
11
+ stroke?: string;
12
+ width?: number;
13
+ dash?: number[];
14
+ pointRadius?: number;
15
+ pointFill?: string;
16
+ };
17
+ select?: {
18
+ fill?: string;
19
+ stroke?: string;
20
+ width?: number;
21
+ };
22
+ seriesColors?: string[];
23
+ candlestick?: {
24
+ upColor?: string;
25
+ downColor?: string;
26
+ };
27
+ boxWhisker?: {
28
+ fill?: string;
29
+ stroke?: string;
30
+ medianColor?: string;
31
+ whiskerColor?: string;
32
+ };
33
+ vector?: {
34
+ color?: string;
35
+ };
36
+ sparkline?: {
37
+ stroke?: string;
38
+ };
39
+ timeline?: {
40
+ labelColor?: string;
41
+ segmentColor?: string;
42
+ segmentTextColor?: string;
43
+ };
44
+ annotation?: {
45
+ stroke?: string;
46
+ fill?: string;
47
+ font?: string;
48
+ labelFill?: string;
49
+ };
50
+ overlay?: {
51
+ fontFamily?: string;
52
+ fontSize?: number;
53
+ panelBg?: string;
54
+ panelBorder?: string;
55
+ panelShadow?: string;
56
+ hiddenOpacity?: number;
57
+ zIndex?: number;
58
+ tooltipZIndex?: number;
59
+ };
60
+ ranger?: {
61
+ accent?: string;
62
+ dim?: string;
63
+ };
64
+ }
65
+ //# sourceMappingURL=theme.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["../../src/types/theme.ts"],"names":[],"mappings":"AAAA,4FAA4F;AAC5F,MAAM,WAAW,UAAU;IAEzB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IAGnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAGlB,MAAM,CAAC,EAAE;QACP,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;QAChB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,SAAS,CAAC,EAAE,MAAM,CAAC;KACpB,CAAC;IAGF,MAAM,CAAC,EAAE;QACP,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,CAAC;IAGF,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IAGxB,WAAW,CAAC,EAAE;QAAE,OAAO,CAAC,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IACvD,UAAU,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,WAAW,CAAC,EAAE,MAAM,CAAC;QAAC,YAAY,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IAC7F,MAAM,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IAC5B,SAAS,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IAChC,QAAQ,CAAC,EAAE;QAAE,UAAU,CAAC,EAAE,MAAM,CAAC;QAAC,YAAY,CAAC,EAAE,MAAM,CAAC;QAAC,gBAAgB,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IACrF,UAAU,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IAGnF,OAAO,CAAC,EAAE;QACR,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,aAAa,CAAC,EAAE,MAAM,CAAC;KACxB,CAAC;IAGF,MAAM,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;CAC5C"}
@@ -1,3 +1,4 @@
1
+ import type { OverlayPosition, OverlayOffset } from './common';
1
2
  /** Data passed to custom tooltip renderers */
2
3
  export interface TooltipData {
3
4
  /** X value at cursor */
@@ -25,19 +26,13 @@ export interface TooltipProps {
25
26
  /** Custom render function */
26
27
  children?: (data: TooltipData) => React.ReactNode;
27
28
  /** Offset from cursor in CSS pixels */
28
- offset?: {
29
- x?: number;
30
- y?: number;
31
- };
29
+ offset?: OverlayOffset;
32
30
  /** Max decimal places for the default x label (default: 2). Has no effect when using a custom render function. */
33
31
  precision?: number;
34
32
  /** Behavior mode: 'cursor' (default, follows cursor) or 'draggable' (fixed position, drag to move). */
35
33
  mode?: 'cursor' | 'draggable';
36
34
  /** Initial position for draggable mode (default: 'top-right') */
37
- position?: {
38
- x: number;
39
- y: number;
40
- } | 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';
35
+ position?: OverlayPosition;
41
36
  /** Opacity when not hovered in draggable mode (default: 0.8) */
42
37
  idleOpacity?: number;
43
38
  }
@@ -1 +1 @@
1
- {"version":3,"file":"tooltip.d.ts","sourceRoot":"","sources":["../../src/types/tooltip.ts"],"names":[],"mappings":"AAAA,8CAA8C;AAC9C,MAAM,WAAW,WAAW;IAC1B,wBAAwB;IACxB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACjB,wBAAwB;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,8BAA8B;IAC9B,KAAK,EAAE,WAAW,EAAE,CAAC;IACrB,sDAAsD;IACtD,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;CACb;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,YAAY;IAC3B,kDAAkD;IAClD,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,qBAAqB;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,6BAA6B;IAC7B,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,WAAW,KAAK,KAAK,CAAC,SAAS,CAAC;IAClD,uCAAuC;IACvC,MAAM,CAAC,EAAE;QAAE,CAAC,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IACpC,kHAAkH;IAClH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,uGAAuG;IACvG,IAAI,CAAC,EAAE,QAAQ,GAAG,WAAW,CAAC;IAC9B,iEAAiE;IACjE,QAAQ,CAAC,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,UAAU,GAAG,WAAW,GAAG,aAAa,GAAG,cAAc,CAAC;IAChG,gEAAgE;IAChE,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB"}
1
+ {"version":3,"file":"tooltip.d.ts","sourceRoot":"","sources":["../../src/types/tooltip.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAE/D,8CAA8C;AAC9C,MAAM,WAAW,WAAW;IAC1B,wBAAwB;IACxB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACjB,wBAAwB;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,8BAA8B;IAC9B,KAAK,EAAE,WAAW,EAAE,CAAC;IACrB,sDAAsD;IACtD,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;CACb;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,YAAY;IAC3B,kDAAkD;IAClD,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,qBAAqB;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,6BAA6B;IAC7B,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,WAAW,KAAK,KAAK,CAAC,SAAS,CAAC;IAClD,uCAAuC;IACvC,MAAM,CAAC,EAAE,aAAa,CAAC;IACvB,kHAAkH;IAClH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,uGAAuG;IACvG,IAAI,CAAC,EAAE,QAAQ,GAAG,WAAW,CAAC;IAC9B,iEAAiE;IACjE,QAAQ,CAAC,EAAE,eAAe,CAAC;IAC3B,gEAAgE;IAChE,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Type-safe array access helper.
3
+ *
4
+ * With `noUncheckedIndexedAccess` enabled, `arr[i]` returns `T | undefined`.
5
+ * This helper centralises the single unavoidable assertion so call-sites
6
+ * stay clean. Use only when the index is known to be valid.
7
+ */
8
+ export declare function at<T>(arr: ArrayLike<T>, i: number): T;
9
+ //# sourceMappingURL=at.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"at.d.ts","sourceRoot":"","sources":["../../src/utils/at.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,wBAAgB,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,GAAG,CAAC,CAAwB"}
@@ -1,3 +1,4 @@
1
+ import type { ResolvedTheme } from '../rendering/theme';
1
2
  export interface PanelContent {
2
3
  header?: string;
3
4
  rows: Array<{
@@ -5,7 +6,7 @@ export interface PanelContent {
5
6
  value?: string;
6
7
  }>;
7
8
  }
8
- export declare function estimatePanelSize(content: PanelContent): {
9
+ export declare function estimatePanelSize(content: PanelContent, theme?: ResolvedTheme): {
9
10
  w: number;
10
11
  h: number;
11
12
  };
@@ -1 +1 @@
1
- {"version":3,"file":"estimatePanelSize.d.ts","sourceRoot":"","sources":["../../src/utils/estimatePanelSize.ts"],"names":[],"mappings":"AAaA,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,KAAK,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAChD;AAED,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,YAAY,GAAG;IAAE,CAAC,EAAE,MAAM,CAAC;IAAC,CAAC,EAAE,MAAM,CAAA;CAAE,CAoBjF"}
1
+ {"version":3,"file":"estimatePanelSize.d.ts","sourceRoot":"","sources":["../../src/utils/estimatePanelSize.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAexD,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,KAAK,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAChD;AAED,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,YAAY,EAAE,KAAK,CAAC,EAAE,aAAa,GAAG;IAAE,CAAC,EAAE,MAAM,CAAC;IAAC,CAAC,EAAE,MAAM,CAAA;CAAE,CAsBxG"}
@@ -1 +1 @@
1
- {"version":3,"file":"shallowEqual.d.ts","sourceRoot":"","sources":["../../src/utils/shallowEqual.ts"],"names":[],"mappings":"AAeA;;;;;;;GAOG;AACH,wBAAgB,YAAY,CAAC,CAAC,EAAE,MAAM,GAAG,IAAI,EAAE,CAAC,EAAE,MAAM,GAAG,OAAO,CAmBjE"}
1
+ {"version":3,"file":"shallowEqual.d.ts","sourceRoot":"","sources":["../../src/utils/shallowEqual.ts"],"names":[],"mappings":"AAeA;;;;;;;GAOG;AACH,wBAAgB,YAAY,CAAC,CAAC,EAAE,MAAM,GAAG,IAAI,EAAE,CAAC,EAAE,MAAM,GAAG,OAAO,CAoBjE"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "uplot-plus",
3
- "version": "0.5.14",
3
+ "version": "0.5.24",
4
4
  "description": "High-performance React charting library with multi-x-axis support",
5
5
  "type": "module",
6
6
  "main": "dist/index.cjs",
@@ -32,6 +32,7 @@
32
32
  "lint": "eslint src/ demo/ test/ e2e/",
33
33
  "typecheck": "tsc --noEmit --noUnusedLocals --noUnusedParameters",
34
34
  "test": "vitest run",
35
+ "test:coverage": "vitest run --coverage",
35
36
  "test:e2e": "playwright test --config e2e/playwright.config.ts",
36
37
  "test:e2e:ui": "playwright test --config e2e/playwright.config.ts --ui",
37
38
  "build:demo": "vite build demo"
@@ -51,6 +52,7 @@
51
52
  "@types/react": "^18.2.0",
52
53
  "@types/react-dom": "^18.2.0",
53
54
  "@vitejs/plugin-react": "^4.2.0",
55
+ "@vitest/coverage-v8": "^2.1.9",
54
56
  "eslint": "^9.0.0",
55
57
  "eslint-plugin-react-hooks": "^7.0.1",
56
58
  "jsdom": "^28.1.0",