@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.
- package/dist/controllers/createChartController.d.ts.map +1 -1
- package/dist/controllers/createChartController.js +30 -4
- package/dist/controllers/createChartController.js.map +1 -1
- package/dist/controllers/types.d.ts +9 -2
- package/dist/controllers/types.d.ts.map +1 -1
- package/dist/data-fetchers/baostock.js +3 -3
- package/dist/data-fetchers/baostock.js.map +1 -1
- package/dist/data-fetchers/dataBuffer.d.ts +6 -1
- package/dist/data-fetchers/dataBuffer.d.ts.map +1 -1
- package/dist/data-fetchers/dataBuffer.js +88 -47
- package/dist/data-fetchers/dataBuffer.js.map +1 -1
- package/dist/data-fetchers/index.d.ts +1 -0
- package/dist/data-fetchers/index.d.ts.map +1 -1
- package/dist/data-fetchers/index.js +1 -0
- package/dist/data-fetchers/index.js.map +1 -1
- package/dist/data-fetchers/router.d.ts.map +1 -1
- package/dist/data-fetchers/router.js +3 -0
- package/dist/data-fetchers/router.js.map +1 -1
- package/dist/data-fetchers/tradingview.d.ts +3 -0
- package/dist/data-fetchers/tradingview.d.ts.map +1 -0
- package/dist/data-fetchers/tradingview.js +45 -0
- package/dist/data-fetchers/tradingview.js.map +1 -0
- package/dist/engine/chart.d.ts +34 -351
- package/dist/engine/chart.d.ts.map +1 -1
- package/dist/engine/chart.js +246 -1716
- package/dist/engine/chart.js.map +1 -1
- package/dist/engine/chartContext.d.ts +24 -0
- package/dist/engine/chartContext.d.ts.map +1 -0
- package/dist/engine/chartContext.js +19 -0
- package/dist/engine/chartContext.js.map +1 -0
- package/dist/engine/chartTypes.d.ts +77 -0
- package/dist/engine/chartTypes.d.ts.map +1 -0
- package/dist/engine/chartTypes.js +2 -0
- package/dist/engine/chartTypes.js.map +1 -0
- package/dist/engine/controller/interaction.d.ts +1 -0
- package/dist/engine/controller/interaction.d.ts.map +1 -1
- package/dist/engine/controller/interaction.js +9 -2
- package/dist/engine/controller/interaction.js.map +1 -1
- package/dist/engine/data/chartDataManager.d.ts +102 -0
- package/dist/engine/data/chartDataManager.d.ts.map +1 -0
- package/dist/engine/data/chartDataManager.js +590 -0
- package/dist/engine/data/chartDataManager.js.map +1 -0
- package/dist/engine/indicators/chartIndicatorManager.d.ts +102 -0
- package/dist/engine/indicators/chartIndicatorManager.d.ts.map +1 -0
- package/dist/engine/indicators/chartIndicatorManager.js +437 -0
- package/dist/engine/indicators/chartIndicatorManager.js.map +1 -0
- package/dist/engine/layout/chartPaneLayout.d.ts +53 -0
- package/dist/engine/layout/chartPaneLayout.d.ts.map +1 -0
- package/dist/engine/layout/chartPaneLayout.js +388 -0
- package/dist/engine/layout/chartPaneLayout.js.map +1 -0
- package/dist/engine/render/chartRenderer.d.ts +86 -0
- package/dist/engine/render/chartRenderer.d.ts.map +1 -0
- package/dist/engine/render/chartRenderer.js +438 -0
- package/dist/engine/render/chartRenderer.js.map +1 -0
- package/dist/engine/renderers/Indicator/mainIndicatorLegend.d.ts.map +1 -1
- package/dist/engine/renderers/Indicator/mainIndicatorLegend.js +73 -7
- package/dist/engine/renderers/Indicator/mainIndicatorLegend.js.map +1 -1
- package/dist/engine/renderers/comparisonLine.d.ts.map +1 -1
- package/dist/engine/renderers/comparisonLine.js +25 -11
- package/dist/engine/renderers/comparisonLine.js.map +1 -1
- package/dist/engine/subPaneManager.d.ts +27 -6
- package/dist/engine/subPaneManager.d.ts.map +1 -1
- package/dist/engine/subPaneManager.js +54 -56
- package/dist/engine/subPaneManager.js.map +1 -1
- package/dist/engine/utils/chartZoomController.d.ts +33 -0
- package/dist/engine/utils/chartZoomController.d.ts.map +1 -0
- package/dist/engine/utils/chartZoomController.js +66 -0
- package/dist/engine/utils/chartZoomController.js.map +1 -0
- package/dist/engine/viewport/chartViewportManager.d.ts +72 -0
- package/dist/engine/viewport/chartViewportManager.d.ts.map +1 -0
- package/dist/engine/viewport/chartViewportManager.js +249 -0
- package/dist/engine/viewport/chartViewportManager.js.map +1 -0
- package/dist/engine/viewport/viewport.js +1 -1
- package/dist/engine/viewport/viewport.js.map +1 -1
- package/dist/plugin/types.d.ts +1 -0
- package/dist/plugin/types.d.ts.map +1 -1
- package/dist/plugin/types.js.map +1 -1
- package/dist/tokens/theme-china.d.ts.map +1 -1
- package/dist/tokens/theme-china.js +0 -4
- package/dist/tokens/theme-china.js.map +1 -1
- package/dist/tokens/theme-dark.d.ts.map +1 -1
- package/dist/tokens/theme-dark.js +0 -4
- package/dist/tokens/theme-dark.js.map +1 -1
- package/dist/tokens/theme-light.d.ts.map +1 -1
- package/dist/tokens/theme-light.js +1 -5
- package/dist/tokens/theme-light.js.map +1 -1
- package/dist/tokens/types.d.ts +0 -4
- package/dist/tokens/types.d.ts.map +1 -1
- package/dist/types/price.d.ts +2 -0
- package/dist/types/price.d.ts.map +1 -1
- package/dist/types/price.js.map +1 -1
- package/dist/version.d.ts +1 -1
- package/dist/version.d.ts.map +1 -1
- package/dist/version.js +1 -1
- package/dist/version.js.map +1 -1
- package/package.json +1 -1
- package/src/controllers/createChartController.ts +49 -13
- package/src/controllers/types.ts +9 -2
- package/src/data-fetchers/__tests__/dataBuffer.test.ts +77 -0
- package/src/data-fetchers/baostock.ts +3 -3
- package/src/data-fetchers/dataBuffer.ts +70 -22
- package/src/data-fetchers/index.ts +1 -0
- package/src/data-fetchers/router.ts +3 -0
- package/src/data-fetchers/tradingview.ts +48 -0
- package/src/engine/__tests__/subPaneManager.test.ts +154 -0
- package/src/engine/chart.ts +260 -2103
- package/src/engine/chartContext.ts +34 -0
- package/src/engine/chartTypes.ts +88 -0
- package/src/engine/controller/__tests__/interaction.dpr.test.ts +1 -0
- package/src/engine/controller/interaction.ts +10 -2
- package/src/engine/data/chartDataManager.ts +691 -0
- package/src/engine/indicators/__tests__/chartIndicatorManager.test.ts +103 -0
- package/src/engine/indicators/chartIndicatorManager.ts +566 -0
- package/src/engine/layout/chartPaneLayout.ts +474 -0
- package/src/engine/render/chartRenderer.ts +579 -0
- package/src/engine/renderers/Indicator/mainIndicatorLegend.ts +99 -13
- package/src/engine/renderers/comparisonLine.ts +25 -11
- package/src/engine/subPaneManager.ts +75 -59
- package/src/engine/utils/chartZoomController.ts +104 -0
- package/src/engine/viewport/chartViewportManager.ts +310 -0
- package/src/engine/viewport/viewport.ts +1 -1
- package/src/plugin/types.ts +1 -0
- package/src/tokens/__tests__/__snapshots__/baseline.test.ts.snap +1 -9
- package/src/tokens/theme-china.ts +0 -4
- package/src/tokens/theme-dark.ts +0 -4
- package/src/tokens/theme-light.ts +2 -6
- package/src/tokens/types.ts +0 -4
- package/src/types/price.ts +2 -0
- package/src/version.ts +1 -1
- 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
|
+
})
|