@363045841yyt/klinechart-core 0.8.1-alpha.3 → 0.8.1

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 (130) hide show
  1. package/dist/controllers/createChartController.d.ts.map +1 -1
  2. package/dist/controllers/createChartController.js +30 -4
  3. package/dist/controllers/createChartController.js.map +1 -1
  4. package/dist/controllers/types.d.ts +9 -2
  5. package/dist/controllers/types.d.ts.map +1 -1
  6. package/dist/data-fetchers/baostock.js +3 -3
  7. package/dist/data-fetchers/baostock.js.map +1 -1
  8. package/dist/data-fetchers/dataBuffer.d.ts +6 -1
  9. package/dist/data-fetchers/dataBuffer.d.ts.map +1 -1
  10. package/dist/data-fetchers/dataBuffer.js +88 -47
  11. package/dist/data-fetchers/dataBuffer.js.map +1 -1
  12. package/dist/data-fetchers/index.d.ts +1 -0
  13. package/dist/data-fetchers/index.d.ts.map +1 -1
  14. package/dist/data-fetchers/index.js +1 -0
  15. package/dist/data-fetchers/index.js.map +1 -1
  16. package/dist/data-fetchers/router.d.ts.map +1 -1
  17. package/dist/data-fetchers/router.js +3 -0
  18. package/dist/data-fetchers/router.js.map +1 -1
  19. package/dist/data-fetchers/tradingview.d.ts +3 -0
  20. package/dist/data-fetchers/tradingview.d.ts.map +1 -0
  21. package/dist/data-fetchers/tradingview.js +45 -0
  22. package/dist/data-fetchers/tradingview.js.map +1 -0
  23. package/dist/engine/chart.d.ts +34 -351
  24. package/dist/engine/chart.d.ts.map +1 -1
  25. package/dist/engine/chart.js +246 -1716
  26. package/dist/engine/chart.js.map +1 -1
  27. package/dist/engine/chartContext.d.ts +24 -0
  28. package/dist/engine/chartContext.d.ts.map +1 -0
  29. package/dist/engine/chartContext.js +19 -0
  30. package/dist/engine/chartContext.js.map +1 -0
  31. package/dist/engine/chartTypes.d.ts +77 -0
  32. package/dist/engine/chartTypes.d.ts.map +1 -0
  33. package/dist/engine/chartTypes.js +2 -0
  34. package/dist/engine/chartTypes.js.map +1 -0
  35. package/dist/engine/controller/interaction.d.ts +1 -0
  36. package/dist/engine/controller/interaction.d.ts.map +1 -1
  37. package/dist/engine/controller/interaction.js +9 -2
  38. package/dist/engine/controller/interaction.js.map +1 -1
  39. package/dist/engine/data/chartDataManager.d.ts +102 -0
  40. package/dist/engine/data/chartDataManager.d.ts.map +1 -0
  41. package/dist/engine/data/chartDataManager.js +590 -0
  42. package/dist/engine/data/chartDataManager.js.map +1 -0
  43. package/dist/engine/indicators/chartIndicatorManager.d.ts +102 -0
  44. package/dist/engine/indicators/chartIndicatorManager.d.ts.map +1 -0
  45. package/dist/engine/indicators/chartIndicatorManager.js +437 -0
  46. package/dist/engine/indicators/chartIndicatorManager.js.map +1 -0
  47. package/dist/engine/layout/chartPaneLayout.d.ts +53 -0
  48. package/dist/engine/layout/chartPaneLayout.d.ts.map +1 -0
  49. package/dist/engine/layout/chartPaneLayout.js +388 -0
  50. package/dist/engine/layout/chartPaneLayout.js.map +1 -0
  51. package/dist/engine/render/chartRenderer.d.ts +86 -0
  52. package/dist/engine/render/chartRenderer.d.ts.map +1 -0
  53. package/dist/engine/render/chartRenderer.js +438 -0
  54. package/dist/engine/render/chartRenderer.js.map +1 -0
  55. package/dist/engine/renderers/Indicator/mainIndicatorLegend.d.ts.map +1 -1
  56. package/dist/engine/renderers/Indicator/mainIndicatorLegend.js +73 -7
  57. package/dist/engine/renderers/Indicator/mainIndicatorLegend.js.map +1 -1
  58. package/dist/engine/renderers/comparisonLine.d.ts.map +1 -1
  59. package/dist/engine/renderers/comparisonLine.js +25 -11
  60. package/dist/engine/renderers/comparisonLine.js.map +1 -1
  61. package/dist/engine/subPaneManager.d.ts +27 -6
  62. package/dist/engine/subPaneManager.d.ts.map +1 -1
  63. package/dist/engine/subPaneManager.js +54 -56
  64. package/dist/engine/subPaneManager.js.map +1 -1
  65. package/dist/engine/utils/chartZoomController.d.ts +33 -0
  66. package/dist/engine/utils/chartZoomController.d.ts.map +1 -0
  67. package/dist/engine/utils/chartZoomController.js +66 -0
  68. package/dist/engine/utils/chartZoomController.js.map +1 -0
  69. package/dist/engine/viewport/chartViewportManager.d.ts +72 -0
  70. package/dist/engine/viewport/chartViewportManager.d.ts.map +1 -0
  71. package/dist/engine/viewport/chartViewportManager.js +249 -0
  72. package/dist/engine/viewport/chartViewportManager.js.map +1 -0
  73. package/dist/engine/viewport/viewport.js +1 -1
  74. package/dist/engine/viewport/viewport.js.map +1 -1
  75. package/dist/plugin/types.d.ts +1 -0
  76. package/dist/plugin/types.d.ts.map +1 -1
  77. package/dist/plugin/types.js.map +1 -1
  78. package/dist/tokens/theme-china.d.ts.map +1 -1
  79. package/dist/tokens/theme-china.js +0 -4
  80. package/dist/tokens/theme-china.js.map +1 -1
  81. package/dist/tokens/theme-dark.d.ts.map +1 -1
  82. package/dist/tokens/theme-dark.js +0 -4
  83. package/dist/tokens/theme-dark.js.map +1 -1
  84. package/dist/tokens/theme-light.d.ts.map +1 -1
  85. package/dist/tokens/theme-light.js +1 -5
  86. package/dist/tokens/theme-light.js.map +1 -1
  87. package/dist/tokens/types.d.ts +0 -4
  88. package/dist/tokens/types.d.ts.map +1 -1
  89. package/dist/types/price.d.ts +2 -0
  90. package/dist/types/price.d.ts.map +1 -1
  91. package/dist/types/price.js.map +1 -1
  92. package/dist/version.d.ts +1 -1
  93. package/dist/version.d.ts.map +1 -1
  94. package/dist/version.js +1 -1
  95. package/dist/version.js.map +1 -1
  96. package/package.json +1 -1
  97. package/src/controllers/createChartController.ts +49 -13
  98. package/src/controllers/types.ts +9 -2
  99. package/src/data-fetchers/__tests__/dataBuffer.test.ts +77 -0
  100. package/src/data-fetchers/baostock.ts +3 -3
  101. package/src/data-fetchers/dataBuffer.ts +70 -22
  102. package/src/data-fetchers/index.ts +1 -0
  103. package/src/data-fetchers/router.ts +3 -0
  104. package/src/data-fetchers/tradingview.ts +48 -0
  105. package/src/engine/__tests__/subPaneManager.test.ts +154 -0
  106. package/src/engine/chart.ts +260 -2103
  107. package/src/engine/chartContext.ts +34 -0
  108. package/src/engine/chartTypes.ts +88 -0
  109. package/src/engine/controller/__tests__/interaction.dpr.test.ts +1 -0
  110. package/src/engine/controller/interaction.ts +10 -2
  111. package/src/engine/data/chartDataManager.ts +691 -0
  112. package/src/engine/indicators/__tests__/chartIndicatorManager.test.ts +103 -0
  113. package/src/engine/indicators/chartIndicatorManager.ts +566 -0
  114. package/src/engine/layout/chartPaneLayout.ts +474 -0
  115. package/src/engine/render/chartRenderer.ts +579 -0
  116. package/src/engine/renderers/Indicator/mainIndicatorLegend.ts +99 -13
  117. package/src/engine/renderers/comparisonLine.ts +25 -11
  118. package/src/engine/subPaneManager.ts +75 -59
  119. package/src/engine/utils/chartZoomController.ts +104 -0
  120. package/src/engine/viewport/chartViewportManager.ts +310 -0
  121. package/src/engine/viewport/viewport.ts +1 -1
  122. package/src/plugin/types.ts +1 -0
  123. package/src/tokens/__tests__/__snapshots__/baseline.test.ts.snap +1 -9
  124. package/src/tokens/theme-china.ts +0 -4
  125. package/src/tokens/theme-dark.ts +0 -4
  126. package/src/tokens/theme-light.ts +2 -6
  127. package/src/tokens/types.ts +0 -4
  128. package/src/types/price.ts +2 -0
  129. package/src/version.ts +1 -1
  130. package/src/engine/chart.d.ts +0 -619
@@ -0,0 +1,154 @@
1
+ import { describe, it, expect, vi, beforeEach } from 'vitest'
2
+ import { SubPaneManager, type SubPaneContext } from '../subPaneManager'
3
+ import type { SubIndicatorType } from '../renderers/Indicator'
4
+ import type { IndicatorScheduler } from '../indicators/scheduler'
5
+
6
+ function createMockScheduler(): Partial<IndicatorScheduler> {
7
+ return {
8
+ getIndicatorMetadata: vi.fn((_id: string) => ({
9
+ rendererFactory: vi.fn(() => ({ name: 'custom_rsi_rsi_0' })),
10
+ updateConfig: vi.fn(),
11
+ scale: { indicatorKey: 'test', label: 'Test', decimals: 2 },
12
+ })),
13
+ onSubPaneChanged: vi.fn(),
14
+ }
15
+ }
16
+
17
+ function createMockContext(): SubPaneContext {
18
+ const scheduler = createMockScheduler()
19
+ return {
20
+ getIndicatorScheduler: vi.fn(() => scheduler as unknown as IndicatorScheduler),
21
+ hasPane: vi.fn(() => false),
22
+ upsertPane: vi.fn(),
23
+ getRenderer: vi.fn(),
24
+ useRenderer: vi.fn(),
25
+ removeRenderer: vi.fn(),
26
+ removePaneDefinition: vi.fn(),
27
+ updateRendererConfig: vi.fn(),
28
+ getRightAxisWidth: vi.fn(() => 60),
29
+ getPriceLabelWidth: vi.fn(() => 60),
30
+ getYPaddingPx: vi.fn(() => 4),
31
+ getCrosshairPos: vi.fn(() => null),
32
+ getCrosshairPrice: vi.fn(() => null),
33
+ getActivePaneId: vi.fn(() => null),
34
+ }
35
+ }
36
+
37
+ describe('SubPaneManager', () => {
38
+ let manager: SubPaneManager
39
+ let ctx: SubPaneContext
40
+
41
+ beforeEach(() => {
42
+ manager = new SubPaneManager()
43
+ ctx = createMockContext()
44
+ vi.clearAllMocks()
45
+ })
46
+
47
+ describe('updateParams', () => {
48
+ it('should update paneTitle renderer config with new params and indicatorId', () => {
49
+ manager.create(ctx, 'RSI_0', 'RSI' as SubIndicatorType, {
50
+ period1: 6,
51
+ period2: 12,
52
+ period3: 24,
53
+ })
54
+
55
+ const entry = manager.getByPaneId('RSI_0')
56
+ expect(entry).toBeDefined()
57
+ vi.clearAllMocks()
58
+
59
+ const newParams = { period1: 10, period2: 20, period3: 30 }
60
+ manager.updateParams(ctx, 'RSI_0', newParams)
61
+
62
+ expect(ctx.updateRendererConfig).toHaveBeenCalledWith(
63
+ entry!.paneTitleRendererName,
64
+ { params: newParams, indicatorId: 'RSI' },
65
+ )
66
+ })
67
+
68
+ it('should update main indicator renderer config with new params', () => {
69
+ manager.create(ctx, 'RSI_0', 'RSI' as SubIndicatorType, {
70
+ period1: 6,
71
+ period2: 12,
72
+ period3: 24,
73
+ })
74
+
75
+ const entry = manager.getByPaneId('RSI_0')
76
+ expect(entry).toBeDefined()
77
+ vi.clearAllMocks()
78
+
79
+ const newParams = { period1: 10, period2: 20, period3: 30 }
80
+ manager.updateParams(ctx, 'RSI_0', newParams)
81
+
82
+ expect(ctx.updateRendererConfig).toHaveBeenCalledWith(
83
+ entry!.rendererName,
84
+ newParams,
85
+ )
86
+ })
87
+
88
+ it('should update scheduler config via definition.updateConfig', () => {
89
+ const updateConfigSpy = vi.fn()
90
+ const customScheduler: Partial<IndicatorScheduler> = {
91
+ getIndicatorMetadata: vi.fn(() => ({
92
+ rendererFactory: vi.fn(() => ({ name: 'custom_rsi_rsi_0' })),
93
+ updateConfig: updateConfigSpy,
94
+ scale: { indicatorKey: 'test', label: 'Test', decimals: 2 },
95
+ })),
96
+ onSubPaneChanged: vi.fn(),
97
+ }
98
+ const customCtx: SubPaneContext = {
99
+ ...ctx,
100
+ getIndicatorScheduler: vi.fn(() => customScheduler as unknown as IndicatorScheduler),
101
+ }
102
+
103
+ manager.create(customCtx, 'RSI_0', 'RSI' as SubIndicatorType, {
104
+ period1: 6,
105
+ period2: 12,
106
+ period3: 24,
107
+ })
108
+
109
+ const newParams = { period1: 10, period2: 20, period3: 30 }
110
+ manager.updateParams(customCtx, 'RSI_0', newParams)
111
+
112
+ expect(updateConfigSpy).toHaveBeenCalled()
113
+ })
114
+
115
+ it('should update entry params in the manager', () => {
116
+ manager.create(ctx, 'RSI_0', 'RSI' as SubIndicatorType, {
117
+ period1: 6,
118
+ period2: 12,
119
+ period3: 24,
120
+ })
121
+
122
+ const newParams = { period1: 10, period2: 20, period3: 30 }
123
+ manager.updateParams(ctx, 'RSI_0', newParams)
124
+
125
+ const entry = manager.getByPaneId('RSI_0')
126
+ expect(entry?.params).toEqual(newParams)
127
+ })
128
+
129
+ it('should fire entries signal on update', () => {
130
+ manager.create(ctx, 'RSI_0', 'RSI' as SubIndicatorType, {
131
+ period1: 6,
132
+ period2: 12,
133
+ period3: 24,
134
+ })
135
+
136
+ const listener = vi.fn()
137
+ manager.entriesSignal.subscribe(listener)
138
+ vi.clearAllMocks()
139
+
140
+ const newParams = { period1: 10, period2: 20, period3: 30 }
141
+ manager.updateParams(ctx, 'RSI_0', newParams)
142
+
143
+ expect(listener).toHaveBeenCalledTimes(1)
144
+ })
145
+
146
+ it('should silently skip when paneId does not exist', () => {
147
+ const newParams = { period1: 10, period2: 20, period3: 30 }
148
+ manager.updateParams(ctx, 'NONEXISTENT', newParams)
149
+
150
+ expect(ctx.updateRendererConfig).not.toHaveBeenCalled()
151
+ expect(ctx.getIndicatorScheduler().onSubPaneChanged).not.toHaveBeenCalled()
152
+ })
153
+ })
154
+ })