@363045841yyt/klinechart-core 0.7.3
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/README.md +201 -0
- package/README.zh-CN.md +201 -0
- package/dist/config/chartSettings.d.ts +70 -0
- package/dist/config/chartSettings.d.ts.map +1 -0
- package/dist/config/chartSettings.js +50 -0
- package/dist/config/chartSettings.js.map +1 -0
- package/dist/controllers/createChartController.d.ts +16 -0
- package/dist/controllers/createChartController.d.ts.map +1 -0
- package/dist/controllers/createChartController.js +525 -0
- package/dist/controllers/createChartController.js.map +1 -0
- package/dist/controllers/createDrawingController.d.ts +25 -0
- package/dist/controllers/createDrawingController.d.ts.map +1 -0
- package/dist/controllers/createDrawingController.js +77 -0
- package/dist/controllers/createDrawingController.js.map +1 -0
- package/dist/controllers/createIndicatorSelectorController.d.ts +19 -0
- package/dist/controllers/createIndicatorSelectorController.d.ts.map +1 -0
- package/dist/controllers/createIndicatorSelectorController.js +256 -0
- package/dist/controllers/createIndicatorSelectorController.js.map +1 -0
- package/dist/controllers/createToolbarController.d.ts +28 -0
- package/dist/controllers/createToolbarController.d.ts.map +1 -0
- package/dist/controllers/createToolbarController.js +121 -0
- package/dist/controllers/createToolbarController.js.map +1 -0
- package/dist/controllers/index.d.ts +3 -0
- package/dist/controllers/index.d.ts.map +1 -0
- package/dist/controllers/index.js +2 -0
- package/dist/controllers/index.js.map +1 -0
- package/dist/controllers/types.d.ts +218 -0
- package/dist/controllers/types.d.ts.map +1 -0
- package/dist/controllers/types.js +11 -0
- package/dist/controllers/types.js.map +1 -0
- package/dist/engine/chart-store.d.ts +75 -0
- package/dist/engine/chart-store.d.ts.map +1 -0
- package/dist/engine/chart-store.js +88 -0
- package/dist/engine/chart-store.js.map +1 -0
- package/dist/engine/chart.d.ts +618 -0
- package/dist/engine/chart.d.ts.map +1 -0
- package/dist/engine/chart.js +2285 -0
- package/dist/engine/chart.js.map +1 -0
- package/dist/engine/controller/interaction.d.ts +168 -0
- package/dist/engine/controller/interaction.d.ts.map +1 -0
- package/dist/engine/controller/interaction.js +612 -0
- package/dist/engine/controller/interaction.js.map +1 -0
- package/dist/engine/controller/markerInteraction.d.ts +29 -0
- package/dist/engine/controller/markerInteraction.d.ts.map +1 -0
- package/dist/engine/controller/markerInteraction.js +111 -0
- package/dist/engine/controller/markerInteraction.js.map +1 -0
- package/dist/engine/controller/pinchTracker.d.ts +19 -0
- package/dist/engine/controller/pinchTracker.d.ts.map +1 -0
- package/dist/engine/controller/pinchTracker.js +72 -0
- package/dist/engine/controller/pinchTracker.js.map +1 -0
- package/dist/engine/controller/tooltipPosition.d.ts +22 -0
- package/dist/engine/controller/tooltipPosition.d.ts.map +1 -0
- package/dist/engine/controller/tooltipPosition.js +31 -0
- package/dist/engine/controller/tooltipPosition.js.map +1 -0
- package/dist/engine/draw/pixelAlign.d.ts +115 -0
- package/dist/engine/draw/pixelAlign.d.ts.map +1 -0
- package/dist/engine/draw/pixelAlign.js +185 -0
- package/dist/engine/draw/pixelAlign.js.map +1 -0
- package/dist/engine/drawing/index.d.ts +48 -0
- package/dist/engine/drawing/index.d.ts.map +1 -0
- package/dist/engine/drawing/index.js +561 -0
- package/dist/engine/drawing/index.js.map +1 -0
- package/dist/engine/drawing/interaction.d.ts +76 -0
- package/dist/engine/drawing/interaction.d.ts.map +1 -0
- package/dist/engine/drawing/interaction.js +702 -0
- package/dist/engine/drawing/interaction.js.map +1 -0
- package/dist/engine/drawing/plugin.d.ts +29 -0
- package/dist/engine/drawing/plugin.d.ts.map +1 -0
- package/dist/engine/drawing/plugin.js +292 -0
- package/dist/engine/drawing/plugin.js.map +1 -0
- package/dist/engine/indicators/atrState.d.ts +17 -0
- package/dist/engine/indicators/atrState.d.ts.map +1 -0
- package/dist/engine/indicators/atrState.js +13 -0
- package/dist/engine/indicators/atrState.js.map +1 -0
- package/dist/engine/indicators/bollState.d.ts +35 -0
- package/dist/engine/indicators/bollState.d.ts.map +1 -0
- package/dist/engine/indicators/bollState.js +25 -0
- package/dist/engine/indicators/bollState.js.map +1 -0
- package/dist/engine/indicators/calculators.d.ts +466 -0
- package/dist/engine/indicators/calculators.d.ts.map +1 -0
- package/dist/engine/indicators/calculators.js +1882 -0
- package/dist/engine/indicators/calculators.js.map +1 -0
- package/dist/engine/indicators/cciState.d.ts +16 -0
- package/dist/engine/indicators/cciState.d.ts.map +1 -0
- package/dist/engine/indicators/cciState.js +12 -0
- package/dist/engine/indicators/cciState.js.map +1 -0
- package/dist/engine/indicators/chaikinVolState.d.ts +19 -0
- package/dist/engine/indicators/chaikinVolState.d.ts.map +1 -0
- package/dist/engine/indicators/chaikinVolState.js +18 -0
- package/dist/engine/indicators/chaikinVolState.js.map +1 -0
- package/dist/engine/indicators/cmfState.d.ts +17 -0
- package/dist/engine/indicators/cmfState.d.ts.map +1 -0
- package/dist/engine/indicators/cmfState.js +13 -0
- package/dist/engine/indicators/cmfState.js.map +1 -0
- package/dist/engine/indicators/demaState.d.ts +17 -0
- package/dist/engine/indicators/demaState.d.ts.map +1 -0
- package/dist/engine/indicators/demaState.js +13 -0
- package/dist/engine/indicators/demaState.js.map +1 -0
- package/dist/engine/indicators/donchianState.d.ts +24 -0
- package/dist/engine/indicators/donchianState.d.ts.map +1 -0
- package/dist/engine/indicators/donchianState.js +18 -0
- package/dist/engine/indicators/donchianState.js.map +1 -0
- package/dist/engine/indicators/eneState.d.ts +31 -0
- package/dist/engine/indicators/eneState.d.ts.map +1 -0
- package/dist/engine/indicators/eneState.js +21 -0
- package/dist/engine/indicators/eneState.js.map +1 -0
- package/dist/engine/indicators/expmaState.d.ts +31 -0
- package/dist/engine/indicators/expmaState.d.ts.map +1 -0
- package/dist/engine/indicators/expmaState.js +21 -0
- package/dist/engine/indicators/expmaState.js.map +1 -0
- package/dist/engine/indicators/fastkState.d.ts +16 -0
- package/dist/engine/indicators/fastkState.d.ts.map +1 -0
- package/dist/engine/indicators/fastkState.js +12 -0
- package/dist/engine/indicators/fastkState.js.map +1 -0
- package/dist/engine/indicators/fibState.d.ts +27 -0
- package/dist/engine/indicators/fibState.d.ts.map +1 -0
- package/dist/engine/indicators/fibState.js +13 -0
- package/dist/engine/indicators/fibState.js.map +1 -0
- package/dist/engine/indicators/hmaState.d.ts +17 -0
- package/dist/engine/indicators/hmaState.d.ts.map +1 -0
- package/dist/engine/indicators/hmaState.js +13 -0
- package/dist/engine/indicators/hmaState.js.map +1 -0
- package/dist/engine/indicators/hvState.d.ts +19 -0
- package/dist/engine/indicators/hvState.d.ts.map +1 -0
- package/dist/engine/indicators/hvState.js +14 -0
- package/dist/engine/indicators/hvState.js.map +1 -0
- package/dist/engine/indicators/ichimokuState.d.ts +45 -0
- package/dist/engine/indicators/ichimokuState.d.ts.map +1 -0
- package/dist/engine/indicators/ichimokuState.js +27 -0
- package/dist/engine/indicators/ichimokuState.js.map +1 -0
- package/dist/engine/indicators/indicator.worker.d.ts +6 -0
- package/dist/engine/indicators/indicator.worker.d.ts.map +1 -0
- package/dist/engine/indicators/indicator.worker.js +144 -0
- package/dist/engine/indicators/indicator.worker.js.map +1 -0
- package/dist/engine/indicators/indicatorDefinitionRegistry.d.ts +31 -0
- package/dist/engine/indicators/indicatorDefinitionRegistry.d.ts.map +1 -0
- package/dist/engine/indicators/indicatorDefinitionRegistry.js +38 -0
- package/dist/engine/indicators/indicatorDefinitionRegistry.js.map +1 -0
- package/dist/engine/indicators/indicatorMetadata.d.ts +88 -0
- package/dist/engine/indicators/indicatorMetadata.d.ts.map +1 -0
- package/dist/engine/indicators/indicatorMetadata.js +22 -0
- package/dist/engine/indicators/indicatorMetadata.js.map +1 -0
- package/dist/engine/indicators/indicatorRegistry.d.ts +58 -0
- package/dist/engine/indicators/indicatorRegistry.d.ts.map +1 -0
- package/dist/engine/indicators/indicatorRegistry.js +91 -0
- package/dist/engine/indicators/indicatorRegistry.js.map +1 -0
- package/dist/engine/indicators/indicatorRuntime.d.ts +132 -0
- package/dist/engine/indicators/indicatorRuntime.d.ts.map +1 -0
- package/dist/engine/indicators/indicatorRuntime.js +1354 -0
- package/dist/engine/indicators/indicatorRuntime.js.map +1 -0
- package/dist/engine/indicators/kamaState.d.ts +21 -0
- package/dist/engine/indicators/kamaState.d.ts.map +1 -0
- package/dist/engine/indicators/kamaState.js +20 -0
- package/dist/engine/indicators/kamaState.js.map +1 -0
- package/dist/engine/indicators/keltnerState.d.ts +28 -0
- package/dist/engine/indicators/keltnerState.d.ts.map +1 -0
- package/dist/engine/indicators/keltnerState.js +22 -0
- package/dist/engine/indicators/keltnerState.js.map +1 -0
- package/dist/engine/indicators/kstState.d.ts +22 -0
- package/dist/engine/indicators/kstState.d.ts.map +1 -0
- package/dist/engine/indicators/kstState.js +20 -0
- package/dist/engine/indicators/kstState.js.map +1 -0
- package/dist/engine/indicators/maState.d.ts +27 -0
- package/dist/engine/indicators/maState.d.ts.map +1 -0
- package/dist/engine/indicators/maState.js +18 -0
- package/dist/engine/indicators/maState.js.map +1 -0
- package/dist/engine/indicators/macdState.d.ts +59 -0
- package/dist/engine/indicators/macdState.d.ts.map +1 -0
- package/dist/engine/indicators/macdState.js +33 -0
- package/dist/engine/indicators/macdState.js.map +1 -0
- package/dist/engine/indicators/mfiState.d.ts +17 -0
- package/dist/engine/indicators/mfiState.d.ts.map +1 -0
- package/dist/engine/indicators/mfiState.js +13 -0
- package/dist/engine/indicators/mfiState.js.map +1 -0
- package/dist/engine/indicators/momState.d.ts +16 -0
- package/dist/engine/indicators/momState.d.ts.map +1 -0
- package/dist/engine/indicators/momState.js +12 -0
- package/dist/engine/indicators/momState.js.map +1 -0
- package/dist/engine/indicators/obvState.d.ts +15 -0
- package/dist/engine/indicators/obvState.d.ts.map +1 -0
- package/dist/engine/indicators/obvState.js +12 -0
- package/dist/engine/indicators/obvState.js.map +1 -0
- package/dist/engine/indicators/parkinsonState.d.ts +19 -0
- package/dist/engine/indicators/parkinsonState.d.ts.map +1 -0
- package/dist/engine/indicators/parkinsonState.js +14 -0
- package/dist/engine/indicators/parkinsonState.js.map +1 -0
- package/dist/engine/indicators/pivotState.d.ts +30 -0
- package/dist/engine/indicators/pivotState.d.ts.map +1 -0
- package/dist/engine/indicators/pivotState.js +20 -0
- package/dist/engine/indicators/pivotState.js.map +1 -0
- package/dist/engine/indicators/pvtState.d.ts +15 -0
- package/dist/engine/indicators/pvtState.d.ts.map +1 -0
- package/dist/engine/indicators/pvtState.js +12 -0
- package/dist/engine/indicators/pvtState.js.map +1 -0
- package/dist/engine/indicators/rocState.d.ts +17 -0
- package/dist/engine/indicators/rocState.d.ts.map +1 -0
- package/dist/engine/indicators/rocState.js +13 -0
- package/dist/engine/indicators/rocState.js.map +1 -0
- package/dist/engine/indicators/rsiState.d.ts +44 -0
- package/dist/engine/indicators/rsiState.d.ts.map +1 -0
- package/dist/engine/indicators/rsiState.js +32 -0
- package/dist/engine/indicators/rsiState.js.map +1 -0
- package/dist/engine/indicators/sarState.d.ts +27 -0
- package/dist/engine/indicators/sarState.d.ts.map +1 -0
- package/dist/engine/indicators/sarState.js +18 -0
- package/dist/engine/indicators/sarState.js.map +1 -0
- package/dist/engine/indicators/scheduler.d.ts +277 -0
- package/dist/engine/indicators/scheduler.d.ts.map +1 -0
- package/dist/engine/indicators/scheduler.js +1012 -0
- package/dist/engine/indicators/scheduler.js.map +1 -0
- package/dist/engine/indicators/soa.d.ts +116 -0
- package/dist/engine/indicators/soa.d.ts.map +1 -0
- package/dist/engine/indicators/soa.js +242 -0
- package/dist/engine/indicators/soa.js.map +1 -0
- package/dist/engine/indicators/stateComposer.d.ts +151 -0
- package/dist/engine/indicators/stateComposer.d.ts.map +1 -0
- package/dist/engine/indicators/stateComposer.js +1018 -0
- package/dist/engine/indicators/stateComposer.js.map +1 -0
- package/dist/engine/indicators/stochState.d.ts +19 -0
- package/dist/engine/indicators/stochState.d.ts.map +1 -0
- package/dist/engine/indicators/stochState.js +12 -0
- package/dist/engine/indicators/stochState.js.map +1 -0
- package/dist/engine/indicators/structureState.d.ts +44 -0
- package/dist/engine/indicators/structureState.d.ts.map +1 -0
- package/dist/engine/indicators/structureState.js +22 -0
- package/dist/engine/indicators/structureState.js.map +1 -0
- package/dist/engine/indicators/supertrendState.d.ts +23 -0
- package/dist/engine/indicators/supertrendState.d.ts.map +1 -0
- package/dist/engine/indicators/supertrendState.js +18 -0
- package/dist/engine/indicators/supertrendState.js.map +1 -0
- package/dist/engine/indicators/temaState.d.ts +17 -0
- package/dist/engine/indicators/temaState.d.ts.map +1 -0
- package/dist/engine/indicators/temaState.js +13 -0
- package/dist/engine/indicators/temaState.js.map +1 -0
- package/dist/engine/indicators/trixState.d.ts +21 -0
- package/dist/engine/indicators/trixState.d.ts.map +1 -0
- package/dist/engine/indicators/trixState.js +20 -0
- package/dist/engine/indicators/trixState.js.map +1 -0
- package/dist/engine/indicators/vmaState.d.ts +17 -0
- package/dist/engine/indicators/vmaState.d.ts.map +1 -0
- package/dist/engine/indicators/vmaState.js +13 -0
- package/dist/engine/indicators/vmaState.js.map +1 -0
- package/dist/engine/indicators/volumeProfileState.d.ts +35 -0
- package/dist/engine/indicators/volumeProfileState.d.ts.map +1 -0
- package/dist/engine/indicators/volumeProfileState.js +28 -0
- package/dist/engine/indicators/volumeProfileState.js.map +1 -0
- package/dist/engine/indicators/vwapState.d.ts +17 -0
- package/dist/engine/indicators/vwapState.d.ts.map +1 -0
- package/dist/engine/indicators/vwapState.js +15 -0
- package/dist/engine/indicators/vwapState.js.map +1 -0
- package/dist/engine/indicators/wmaState.d.ts +17 -0
- package/dist/engine/indicators/wmaState.d.ts.map +1 -0
- package/dist/engine/indicators/wmaState.js +13 -0
- package/dist/engine/indicators/wmaState.js.map +1 -0
- package/dist/engine/indicators/wmsrState.d.ts +16 -0
- package/dist/engine/indicators/wmsrState.d.ts.map +1 -0
- package/dist/engine/indicators/wmsrState.js +12 -0
- package/dist/engine/indicators/wmsrState.js.map +1 -0
- package/dist/engine/indicators/workerProtocol.d.ts +501 -0
- package/dist/engine/indicators/workerProtocol.d.ts.map +1 -0
- package/dist/engine/indicators/workerProtocol.js +20 -0
- package/dist/engine/indicators/workerProtocol.js.map +1 -0
- package/dist/engine/indicators/zonesState.d.ts +27 -0
- package/dist/engine/indicators/zonesState.d.ts.map +1 -0
- package/dist/engine/indicators/zonesState.js +18 -0
- package/dist/engine/indicators/zonesState.js.map +1 -0
- package/dist/engine/layout/pane.d.ts +104 -0
- package/dist/engine/layout/pane.d.ts.map +1 -0
- package/dist/engine/layout/pane.js +107 -0
- package/dist/engine/layout/pane.js.map +1 -0
- package/dist/engine/marker/registry.d.ts +175 -0
- package/dist/engine/marker/registry.d.ts.map +1 -0
- package/dist/engine/marker/registry.js +171 -0
- package/dist/engine/marker/registry.js.map +1 -0
- package/dist/engine/paneRenderer.d.ts +46 -0
- package/dist/engine/paneRenderer.d.ts.map +1 -0
- package/dist/engine/paneRenderer.js +121 -0
- package/dist/engine/paneRenderer.js.map +1 -0
- package/dist/engine/renderers/Indicator/atr.d.ts +18 -0
- package/dist/engine/renderers/Indicator/atr.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/atr.js +237 -0
- package/dist/engine/renderers/Indicator/atr.js.map +1 -0
- package/dist/engine/renderers/Indicator/boll.d.ts +3 -0
- package/dist/engine/renderers/Indicator/boll.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/boll.js +312 -0
- package/dist/engine/renderers/Indicator/boll.js.map +1 -0
- package/dist/engine/renderers/Indicator/cci.d.ts +23 -0
- package/dist/engine/renderers/Indicator/cci.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/cci.js +266 -0
- package/dist/engine/renderers/Indicator/cci.js.map +1 -0
- package/dist/engine/renderers/Indicator/chaikinVol.d.ts +5 -0
- package/dist/engine/renderers/Indicator/chaikinVol.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/chaikinVol.js +175 -0
- package/dist/engine/renderers/Indicator/chaikinVol.js.map +1 -0
- package/dist/engine/renderers/Indicator/cmf.d.ts +5 -0
- package/dist/engine/renderers/Indicator/cmf.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/cmf.js +175 -0
- package/dist/engine/renderers/Indicator/cmf.js.map +1 -0
- package/dist/engine/renderers/Indicator/dema.d.ts +6 -0
- package/dist/engine/renderers/Indicator/dema.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/dema.js +164 -0
- package/dist/engine/renderers/Indicator/dema.js.map +1 -0
- package/dist/engine/renderers/Indicator/donchian.d.ts +6 -0
- package/dist/engine/renderers/Indicator/donchian.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/donchian.js +181 -0
- package/dist/engine/renderers/Indicator/donchian.js.map +1 -0
- package/dist/engine/renderers/Indicator/ene.d.ts +3 -0
- package/dist/engine/renderers/Indicator/ene.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/ene.js +280 -0
- package/dist/engine/renderers/Indicator/ene.js.map +1 -0
- package/dist/engine/renderers/Indicator/expma.d.ts +3 -0
- package/dist/engine/renderers/Indicator/expma.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/expma.js +216 -0
- package/dist/engine/renderers/Indicator/expma.js.map +1 -0
- package/dist/engine/renderers/Indicator/fastk.d.ts +23 -0
- package/dist/engine/renderers/Indicator/fastk.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/fastk.js +289 -0
- package/dist/engine/renderers/Indicator/fastk.js.map +1 -0
- package/dist/engine/renderers/Indicator/fib.d.ts +5 -0
- package/dist/engine/renderers/Indicator/fib.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/fib.js +182 -0
- package/dist/engine/renderers/Indicator/fib.js.map +1 -0
- package/dist/engine/renderers/Indicator/hma.d.ts +6 -0
- package/dist/engine/renderers/Indicator/hma.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/hma.js +164 -0
- package/dist/engine/renderers/Indicator/hma.js.map +1 -0
- package/dist/engine/renderers/Indicator/hv.d.ts +5 -0
- package/dist/engine/renderers/Indicator/hv.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/hv.js +162 -0
- package/dist/engine/renderers/Indicator/hv.js.map +1 -0
- package/dist/engine/renderers/Indicator/ichimoku.d.ts +6 -0
- package/dist/engine/renderers/Indicator/ichimoku.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/ichimoku.js +220 -0
- package/dist/engine/renderers/Indicator/ichimoku.js.map +1 -0
- package/dist/engine/renderers/Indicator/index.d.ts +63 -0
- package/dist/engine/renderers/Indicator/index.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/index.js +204 -0
- package/dist/engine/renderers/Indicator/index.js.map +1 -0
- package/dist/engine/renderers/Indicator/indicatorData.d.ts +23 -0
- package/dist/engine/renderers/Indicator/indicatorData.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/indicatorData.js +617 -0
- package/dist/engine/renderers/Indicator/indicatorData.js.map +1 -0
- package/dist/engine/renderers/Indicator/kama.d.ts +6 -0
- package/dist/engine/renderers/Indicator/kama.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/kama.js +164 -0
- package/dist/engine/renderers/Indicator/kama.js.map +1 -0
- package/dist/engine/renderers/Indicator/keltner.d.ts +6 -0
- package/dist/engine/renderers/Indicator/keltner.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/keltner.js +181 -0
- package/dist/engine/renderers/Indicator/keltner.js.map +1 -0
- package/dist/engine/renderers/Indicator/kst.d.ts +23 -0
- package/dist/engine/renderers/Indicator/kst.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/kst.js +290 -0
- package/dist/engine/renderers/Indicator/kst.js.map +1 -0
- package/dist/engine/renderers/Indicator/ma.d.ts +4 -0
- package/dist/engine/renderers/Indicator/ma.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/ma.js +218 -0
- package/dist/engine/renderers/Indicator/ma.js.map +1 -0
- package/dist/engine/renderers/Indicator/macd.d.ts +51 -0
- package/dist/engine/renderers/Indicator/macd.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/macd.js +432 -0
- package/dist/engine/renderers/Indicator/macd.js.map +1 -0
- package/dist/engine/renderers/Indicator/macdLegend.d.ts +13 -0
- package/dist/engine/renderers/Indicator/macdLegend.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/macdLegend.js +116 -0
- package/dist/engine/renderers/Indicator/macdLegend.js.map +1 -0
- package/dist/engine/renderers/Indicator/mainIndicatorLegend.d.ts +11 -0
- package/dist/engine/renderers/Indicator/mainIndicatorLegend.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/mainIndicatorLegend.js +220 -0
- package/dist/engine/renderers/Indicator/mainIndicatorLegend.js.map +1 -0
- package/dist/engine/renderers/Indicator/mfi.d.ts +5 -0
- package/dist/engine/renderers/Indicator/mfi.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/mfi.js +180 -0
- package/dist/engine/renderers/Indicator/mfi.js.map +1 -0
- package/dist/engine/renderers/Indicator/mom.d.ts +23 -0
- package/dist/engine/renderers/Indicator/mom.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/mom.js +285 -0
- package/dist/engine/renderers/Indicator/mom.js.map +1 -0
- package/dist/engine/renderers/Indicator/obv.d.ts +5 -0
- package/dist/engine/renderers/Indicator/obv.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/obv.js +162 -0
- package/dist/engine/renderers/Indicator/obv.js.map +1 -0
- package/dist/engine/renderers/Indicator/parkinson.d.ts +5 -0
- package/dist/engine/renderers/Indicator/parkinson.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/parkinson.js +162 -0
- package/dist/engine/renderers/Indicator/parkinson.js.map +1 -0
- package/dist/engine/renderers/Indicator/pivot.d.ts +5 -0
- package/dist/engine/renderers/Indicator/pivot.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/pivot.js +181 -0
- package/dist/engine/renderers/Indicator/pivot.js.map +1 -0
- package/dist/engine/renderers/Indicator/pvt.d.ts +5 -0
- package/dist/engine/renderers/Indicator/pvt.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/pvt.js +162 -0
- package/dist/engine/renderers/Indicator/pvt.js.map +1 -0
- package/dist/engine/renderers/Indicator/roc.d.ts +6 -0
- package/dist/engine/renderers/Indicator/roc.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/roc.js +175 -0
- package/dist/engine/renderers/Indicator/roc.js.map +1 -0
- package/dist/engine/renderers/Indicator/rsi.d.ts +34 -0
- package/dist/engine/renderers/Indicator/rsi.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/rsi.js +351 -0
- package/dist/engine/renderers/Indicator/rsi.js.map +1 -0
- package/dist/engine/renderers/Indicator/sar.d.ts +6 -0
- package/dist/engine/renderers/Indicator/sar.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/sar.js +146 -0
- package/dist/engine/renderers/Indicator/sar.js.map +1 -0
- package/dist/engine/renderers/Indicator/scale/atr_scale.d.ts +12 -0
- package/dist/engine/renderers/Indicator/scale/atr_scale.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/scale/atr_scale.js +13 -0
- package/dist/engine/renderers/Indicator/scale/atr_scale.js.map +1 -0
- package/dist/engine/renderers/Indicator/scale/cci_scale.d.ts +12 -0
- package/dist/engine/renderers/Indicator/scale/cci_scale.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/scale/cci_scale.js +13 -0
- package/dist/engine/renderers/Indicator/scale/cci_scale.js.map +1 -0
- package/dist/engine/renderers/Indicator/scale/fastk_scale.d.ts +12 -0
- package/dist/engine/renderers/Indicator/scale/fastk_scale.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/scale/fastk_scale.js +13 -0
- package/dist/engine/renderers/Indicator/scale/fastk_scale.js.map +1 -0
- package/dist/engine/renderers/Indicator/scale/indicator_scale.d.ts +39 -0
- package/dist/engine/renderers/Indicator/scale/indicator_scale.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/scale/indicator_scale.js +120 -0
- package/dist/engine/renderers/Indicator/scale/indicator_scale.js.map +1 -0
- package/dist/engine/renderers/Indicator/scale/kst_scale.d.ts +12 -0
- package/dist/engine/renderers/Indicator/scale/kst_scale.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/scale/kst_scale.js +13 -0
- package/dist/engine/renderers/Indicator/scale/kst_scale.js.map +1 -0
- package/dist/engine/renderers/Indicator/scale/macd_scale.d.ts +15 -0
- package/dist/engine/renderers/Indicator/scale/macd_scale.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/scale/macd_scale.js +16 -0
- package/dist/engine/renderers/Indicator/scale/macd_scale.js.map +1 -0
- package/dist/engine/renderers/Indicator/scale/mom_scale.d.ts +12 -0
- package/dist/engine/renderers/Indicator/scale/mom_scale.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/scale/mom_scale.js +13 -0
- package/dist/engine/renderers/Indicator/scale/mom_scale.js.map +1 -0
- package/dist/engine/renderers/Indicator/scale/rsi_scale.d.ts +12 -0
- package/dist/engine/renderers/Indicator/scale/rsi_scale.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/scale/rsi_scale.js +13 -0
- package/dist/engine/renderers/Indicator/scale/rsi_scale.js.map +1 -0
- package/dist/engine/renderers/Indicator/scale/stoch_scale.d.ts +12 -0
- package/dist/engine/renderers/Indicator/scale/stoch_scale.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/scale/stoch_scale.js +13 -0
- package/dist/engine/renderers/Indicator/scale/stoch_scale.js.map +1 -0
- package/dist/engine/renderers/Indicator/scale/volume_scale.d.ts +15 -0
- package/dist/engine/renderers/Indicator/scale/volume_scale.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/scale/volume_scale.js +19 -0
- package/dist/engine/renderers/Indicator/scale/volume_scale.js.map +1 -0
- package/dist/engine/renderers/Indicator/scale/wmsr_scale.d.ts +12 -0
- package/dist/engine/renderers/Indicator/scale/wmsr_scale.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/scale/wmsr_scale.js +13 -0
- package/dist/engine/renderers/Indicator/scale/wmsr_scale.js.map +1 -0
- package/dist/engine/renderers/Indicator/stoch.d.ts +23 -0
- package/dist/engine/renderers/Indicator/stoch.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/stoch.js +329 -0
- package/dist/engine/renderers/Indicator/stoch.js.map +1 -0
- package/dist/engine/renderers/Indicator/structure.d.ts +5 -0
- package/dist/engine/renderers/Indicator/structure.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/structure.js +176 -0
- package/dist/engine/renderers/Indicator/structure.js.map +1 -0
- package/dist/engine/renderers/Indicator/subPaneConfig.d.ts +16 -0
- package/dist/engine/renderers/Indicator/subPaneConfig.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/subPaneConfig.js +194 -0
- package/dist/engine/renderers/Indicator/subPaneConfig.js.map +1 -0
- package/dist/engine/renderers/Indicator/supertrend.d.ts +6 -0
- package/dist/engine/renderers/Indicator/supertrend.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/supertrend.js +149 -0
- package/dist/engine/renderers/Indicator/supertrend.js.map +1 -0
- package/dist/engine/renderers/Indicator/tema.d.ts +6 -0
- package/dist/engine/renderers/Indicator/tema.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/tema.js +164 -0
- package/dist/engine/renderers/Indicator/tema.js.map +1 -0
- package/dist/engine/renderers/Indicator/trix.d.ts +6 -0
- package/dist/engine/renderers/Indicator/trix.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/trix.js +197 -0
- package/dist/engine/renderers/Indicator/trix.js.map +1 -0
- package/dist/engine/renderers/Indicator/vma.d.ts +5 -0
- package/dist/engine/renderers/Indicator/vma.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/vma.js +162 -0
- package/dist/engine/renderers/Indicator/vma.js.map +1 -0
- package/dist/engine/renderers/Indicator/volumeProfile.d.ts +5 -0
- package/dist/engine/renderers/Indicator/volumeProfile.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/volumeProfile.js +165 -0
- package/dist/engine/renderers/Indicator/volumeProfile.js.map +1 -0
- package/dist/engine/renderers/Indicator/vwap.d.ts +5 -0
- package/dist/engine/renderers/Indicator/vwap.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/vwap.js +162 -0
- package/dist/engine/renderers/Indicator/vwap.js.map +1 -0
- package/dist/engine/renderers/Indicator/wma.d.ts +6 -0
- package/dist/engine/renderers/Indicator/wma.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/wma.js +164 -0
- package/dist/engine/renderers/Indicator/wma.js.map +1 -0
- package/dist/engine/renderers/Indicator/wmsr.d.ts +23 -0
- package/dist/engine/renderers/Indicator/wmsr.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/wmsr.js +298 -0
- package/dist/engine/renderers/Indicator/wmsr.js.map +1 -0
- package/dist/engine/renderers/Indicator/zones.d.ts +5 -0
- package/dist/engine/renderers/Indicator/zones.d.ts.map +1 -0
- package/dist/engine/renderers/Indicator/zones.js +151 -0
- package/dist/engine/renderers/Indicator/zones.js.map +1 -0
- package/dist/engine/renderers/candle.d.ts +22 -0
- package/dist/engine/renderers/candle.d.ts.map +1 -0
- package/dist/engine/renderers/candle.js +356 -0
- package/dist/engine/renderers/candle.js.map +1 -0
- package/dist/engine/renderers/crosshair.d.ts +18 -0
- package/dist/engine/renderers/crosshair.d.ts.map +1 -0
- package/dist/engine/renderers/crosshair.js +54 -0
- package/dist/engine/renderers/crosshair.js.map +1 -0
- package/dist/engine/renderers/customMarkers.d.ts +7 -0
- package/dist/engine/renderers/customMarkers.d.ts.map +1 -0
- package/dist/engine/renderers/customMarkers.js +145 -0
- package/dist/engine/renderers/customMarkers.js.map +1 -0
- package/dist/engine/renderers/extremaMarkers.d.ts +6 -0
- package/dist/engine/renderers/extremaMarkers.d.ts.map +1 -0
- package/dist/engine/renderers/extremaMarkers.js +181 -0
- package/dist/engine/renderers/extremaMarkers.js.map +1 -0
- package/dist/engine/renderers/gridLines.d.ts +8 -0
- package/dist/engine/renderers/gridLines.d.ts.map +1 -0
- package/dist/engine/renderers/gridLines.js +84 -0
- package/dist/engine/renderers/gridLines.js.map +1 -0
- package/dist/engine/renderers/lastPrice.d.ts +10 -0
- package/dist/engine/renderers/lastPrice.d.ts.map +1 -0
- package/dist/engine/renderers/lastPrice.js +87 -0
- package/dist/engine/renderers/lastPrice.js.map +1 -0
- package/dist/engine/renderers/paneTitle.d.ts +41 -0
- package/dist/engine/renderers/paneTitle.d.ts.map +1 -0
- package/dist/engine/renderers/paneTitle.js +86 -0
- package/dist/engine/renderers/paneTitle.js.map +1 -0
- package/dist/engine/renderers/subVolume.d.ts +14 -0
- package/dist/engine/renderers/subVolume.d.ts.map +1 -0
- package/dist/engine/renderers/subVolume.js +247 -0
- package/dist/engine/renderers/subVolume.js.map +1 -0
- package/dist/engine/renderers/timeAxis.d.ts +15 -0
- package/dist/engine/renderers/timeAxis.d.ts.map +1 -0
- package/dist/engine/renderers/timeAxis.js +107 -0
- package/dist/engine/renderers/timeAxis.js.map +1 -0
- package/dist/engine/renderers/webgl/candleSurface.d.ts +81 -0
- package/dist/engine/renderers/webgl/candleSurface.d.ts.map +1 -0
- package/dist/engine/renderers/webgl/candleSurface.js +811 -0
- package/dist/engine/renderers/webgl/candleSurface.js.map +1 -0
- package/dist/engine/renderers/webgl/sharedWebGLSurface.d.ts +34 -0
- package/dist/engine/renderers/webgl/sharedWebGLSurface.d.ts.map +1 -0
- package/dist/engine/renderers/webgl/sharedWebGLSurface.js +102 -0
- package/dist/engine/renderers/webgl/sharedWebGLSurface.js.map +1 -0
- package/dist/engine/renderers/yAxis.d.ts +15 -0
- package/dist/engine/renderers/yAxis.d.ts.map +1 -0
- package/dist/engine/renderers/yAxis.js +93 -0
- package/dist/engine/renderers/yAxis.js.map +1 -0
- package/dist/engine/scale/logFormula.d.ts +67 -0
- package/dist/engine/scale/logFormula.d.ts.map +1 -0
- package/dist/engine/scale/logFormula.js +107 -0
- package/dist/engine/scale/logFormula.js.map +1 -0
- package/dist/engine/scale/price.d.ts +12 -0
- package/dist/engine/scale/price.d.ts.map +1 -0
- package/dist/engine/scale/price.js +20 -0
- package/dist/engine/scale/price.js.map +1 -0
- package/dist/engine/scale/priceScale.d.ts +88 -0
- package/dist/engine/scale/priceScale.d.ts.map +1 -0
- package/dist/engine/scale/priceScale.js +227 -0
- package/dist/engine/scale/priceScale.js.map +1 -0
- package/dist/engine/subPaneManager.d.ts +23 -0
- package/dist/engine/subPaneManager.d.ts.map +1 -0
- package/dist/engine/subPaneManager.js +342 -0
- package/dist/engine/subPaneManager.js.map +1 -0
- package/dist/engine/theme/colors.d.ts +223 -0
- package/dist/engine/theme/colors.d.ts.map +1 -0
- package/dist/engine/theme/colors.js +375 -0
- package/dist/engine/theme/colors.js.map +1 -0
- package/dist/engine/theme/fonts.d.ts +13 -0
- package/dist/engine/theme/fonts.d.ts.map +1 -0
- package/dist/engine/theme/fonts.js +18 -0
- package/dist/engine/theme/fonts.js.map +1 -0
- package/dist/engine/utils/klineConfig.d.ts +29 -0
- package/dist/engine/utils/klineConfig.d.ts.map +1 -0
- package/dist/engine/utils/klineConfig.js +46 -0
- package/dist/engine/utils/klineConfig.js.map +1 -0
- package/dist/engine/utils/tickCount.d.ts +9 -0
- package/dist/engine/utils/tickCount.d.ts.map +1 -0
- package/dist/engine/utils/tickCount.js +12 -0
- package/dist/engine/utils/tickCount.js.map +1 -0
- package/dist/engine/utils/tickPosition.d.ts +25 -0
- package/dist/engine/utils/tickPosition.d.ts.map +1 -0
- package/dist/engine/utils/tickPosition.js +141 -0
- package/dist/engine/utils/tickPosition.js.map +1 -0
- package/dist/engine/utils/zoom.d.ts +31 -0
- package/dist/engine/utils/zoom.d.ts.map +1 -0
- package/dist/engine/utils/zoom.js +43 -0
- package/dist/engine/utils/zoom.js.map +1 -0
- package/dist/engine/viewport/viewport.d.ts +32 -0
- package/dist/engine/viewport/viewport.d.ts.map +1 -0
- package/dist/engine/viewport/viewport.js +54 -0
- package/dist/engine/viewport/viewport.js.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/plugin/ConfigManager.d.ts +32 -0
- package/dist/plugin/ConfigManager.d.ts.map +1 -0
- package/dist/plugin/ConfigManager.js +81 -0
- package/dist/plugin/ConfigManager.js.map +1 -0
- package/dist/plugin/EventBus.d.ts +38 -0
- package/dist/plugin/EventBus.d.ts.map +1 -0
- package/dist/plugin/EventBus.js +66 -0
- package/dist/plugin/EventBus.js.map +1 -0
- package/dist/plugin/HookSystem.d.ts +32 -0
- package/dist/plugin/HookSystem.d.ts.map +1 -0
- package/dist/plugin/HookSystem.js +86 -0
- package/dist/plugin/HookSystem.js.map +1 -0
- package/dist/plugin/PluginHost.d.ts +61 -0
- package/dist/plugin/PluginHost.d.ts.map +1 -0
- package/dist/plugin/PluginHost.js +196 -0
- package/dist/plugin/PluginHost.js.map +1 -0
- package/dist/plugin/PluginRegistry.d.ts +44 -0
- package/dist/plugin/PluginRegistry.d.ts.map +1 -0
- package/dist/plugin/PluginRegistry.js +77 -0
- package/dist/plugin/PluginRegistry.js.map +1 -0
- package/dist/plugin/StateStore.d.ts +42 -0
- package/dist/plugin/StateStore.d.ts.map +1 -0
- package/dist/plugin/StateStore.js +63 -0
- package/dist/plugin/StateStore.js.map +1 -0
- package/dist/plugin/index.d.ts +12 -0
- package/dist/plugin/index.d.ts.map +1 -0
- package/dist/plugin/index.js +15 -0
- package/dist/plugin/index.js.map +1 -0
- package/dist/plugin/rendererPluginManager.d.ts +81 -0
- package/dist/plugin/rendererPluginManager.d.ts.map +1 -0
- package/dist/plugin/rendererPluginManager.js +309 -0
- package/dist/plugin/rendererPluginManager.js.map +1 -0
- package/dist/plugin/stateKeys.d.ts +7 -0
- package/dist/plugin/stateKeys.d.ts.map +1 -0
- package/dist/plugin/stateKeys.js +7 -0
- package/dist/plugin/stateKeys.js.map +1 -0
- package/dist/plugin/types.d.ts +449 -0
- package/dist/plugin/types.d.ts.map +1 -0
- package/dist/plugin/types.js +63 -0
- package/dist/plugin/types.js.map +1 -0
- package/dist/reactivity/index.d.ts +3 -0
- package/dist/reactivity/index.d.ts.map +1 -0
- package/dist/reactivity/index.js +2 -0
- package/dist/reactivity/index.js.map +1 -0
- package/dist/reactivity/signal.d.ts +40 -0
- package/dist/reactivity/signal.d.ts.map +1 -0
- package/dist/reactivity/signal.js +92 -0
- package/dist/reactivity/signal.js.map +1 -0
- package/dist/semantic/controller.d.ts +41 -0
- package/dist/semantic/controller.d.ts.map +1 -0
- package/dist/semantic/controller.js +189 -0
- package/dist/semantic/controller.js.map +1 -0
- package/dist/semantic/drawShape.d.ts +19 -0
- package/dist/semantic/drawShape.d.ts.map +1 -0
- package/dist/semantic/drawShape.js +209 -0
- package/dist/semantic/drawShape.js.map +1 -0
- package/dist/semantic/index.d.ts +6 -0
- package/dist/semantic/index.d.ts.map +1 -0
- package/dist/semantic/index.js +4 -0
- package/dist/semantic/index.js.map +1 -0
- package/dist/semantic/schema.json +256 -0
- package/dist/semantic/types.d.ts +299 -0
- package/dist/semantic/types.d.ts.map +1 -0
- package/dist/semantic/types.js +6 -0
- package/dist/semantic/types.js.map +1 -0
- package/dist/semantic/validator.d.ts +48 -0
- package/dist/semantic/validator.d.ts.map +1 -0
- package/dist/semantic/validator.js +288 -0
- package/dist/semantic/validator.js.map +1 -0
- package/dist/types/kLine.d.ts +4 -0
- package/dist/types/kLine.d.ts.map +1 -0
- package/dist/types/kLine.js +12 -0
- package/dist/types/kLine.js.map +1 -0
- package/dist/types/price.d.ts +32 -0
- package/dist/types/price.d.ts.map +1 -0
- package/dist/types/price.js +19 -0
- package/dist/types/price.js.map +1 -0
- package/dist/types/volumePrice.d.ts +27 -0
- package/dist/types/volumePrice.d.ts.map +1 -0
- package/dist/types/volumePrice.js +23 -0
- package/dist/types/volumePrice.js.map +1 -0
- package/dist/utils/dateFormat.d.ts +84 -0
- package/dist/utils/dateFormat.d.ts.map +1 -0
- package/dist/utils/dateFormat.js +193 -0
- package/dist/utils/dateFormat.js.map +1 -0
- package/dist/utils/kLineDraw/axis.d.ts +151 -0
- package/dist/utils/kLineDraw/axis.d.ts.map +1 -0
- package/dist/utils/kLineDraw/axis.js +243 -0
- package/dist/utils/kLineDraw/axis.js.map +1 -0
- package/dist/utils/priceToY.d.ts +8 -0
- package/dist/utils/priceToY.d.ts.map +1 -0
- package/dist/utils/priceToY.js +19 -0
- package/dist/utils/priceToY.js.map +1 -0
- package/dist/utils/volumePrice.d.ts +55 -0
- package/dist/utils/volumePrice.d.ts.map +1 -0
- package/dist/utils/volumePrice.js +170 -0
- package/dist/utils/volumePrice.js.map +1 -0
- package/dist/version.d.ts +2 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +3 -0
- package/dist/version.js.map +1 -0
- package/package.json +122 -0
- package/src/__tests__/signal.test.ts +124 -0
- package/src/config/chartSettings.ts +66 -0
- package/src/controllers/__tests__/drawing.test.ts +214 -0
- package/src/controllers/__tests__/indicatorSelector.test.ts +481 -0
- package/src/controllers/__tests__/toolbar.test.ts +225 -0
- package/src/controllers/createChartController.ts +665 -0
- package/src/controllers/createDrawingController.ts +96 -0
- package/src/controllers/createIndicatorSelectorController.ts +307 -0
- package/src/controllers/createToolbarController.ts +146 -0
- package/src/controllers/index.ts +19 -0
- package/src/controllers/types.ts +284 -0
- package/src/engine/__tests__/chart.dpr.test.ts +401 -0
- package/src/engine/__tests__/paneRenderer.resize.test.ts +92 -0
- package/src/engine/chart-store.ts +121 -0
- package/src/engine/chart.d.ts +618 -0
- package/src/engine/chart.ts +2815 -0
- package/src/engine/controller/__tests__/interaction.dpr.test.ts +259 -0
- package/src/engine/controller/interaction.ts +722 -0
- package/src/engine/controller/markerInteraction.ts +130 -0
- package/src/engine/controller/pinchTracker.ts +82 -0
- package/src/engine/controller/tooltipPosition.ts +48 -0
- package/src/engine/draw/__tests__/pixelAlign.spec.ts +177 -0
- package/src/engine/draw/pixelAlign.ts +260 -0
- package/src/engine/drawing/index.ts +655 -0
- package/src/engine/drawing/interaction.ts +842 -0
- package/src/engine/drawing/plugin.ts +343 -0
- package/src/engine/indicators/__tests__/__fixtures__/golden/atr.json +38 -0
- package/src/engine/indicators/__tests__/__fixtures__/golden/dema.json +14 -0
- package/src/engine/indicators/__tests__/__fixtures__/golden/hma.json +14 -0
- package/src/engine/indicators/__tests__/__fixtures__/golden/index.ts +55 -0
- package/src/engine/indicators/__tests__/__fixtures__/golden/kama.json +14 -0
- package/src/engine/indicators/__tests__/__fixtures__/golden/tema.json +14 -0
- package/src/engine/indicators/__tests__/__fixtures__/golden/wma.json +40 -0
- package/src/engine/indicators/__tests__/__fixtures__/synthetic.ts +65 -0
- package/src/engine/indicators/__tests__/_propertyAssertions.ts +76 -0
- package/src/engine/indicators/__tests__/atr.test.ts +153 -0
- package/src/engine/indicators/__tests__/calculators.test.ts +614 -0
- package/src/engine/indicators/__tests__/cmf-mfi.test.ts +100 -0
- package/src/engine/indicators/__tests__/dema.test.ts +73 -0
- package/src/engine/indicators/__tests__/donchian.test.ts +70 -0
- package/src/engine/indicators/__tests__/hma.test.ts +73 -0
- package/src/engine/indicators/__tests__/ichimoku.test.ts +105 -0
- package/src/engine/indicators/__tests__/kama.test.ts +80 -0
- package/src/engine/indicators/__tests__/keltner.test.ts +65 -0
- package/src/engine/indicators/__tests__/pivot-fib.test.ts +110 -0
- package/src/engine/indicators/__tests__/roc.test.ts +68 -0
- package/src/engine/indicators/__tests__/sar.test.ts +86 -0
- package/src/engine/indicators/__tests__/scheduler.test.ts +831 -0
- package/src/engine/indicators/__tests__/soa.test.ts +533 -0
- package/src/engine/indicators/__tests__/structure.test.ts +110 -0
- package/src/engine/indicators/__tests__/supertrend.test.ts +65 -0
- package/src/engine/indicators/__tests__/tema.test.ts +68 -0
- package/src/engine/indicators/__tests__/trix.test.ts +70 -0
- package/src/engine/indicators/__tests__/volatility.test.ts +117 -0
- package/src/engine/indicators/__tests__/volume.test.ts +115 -0
- package/src/engine/indicators/__tests__/volumeProfile.test.ts +74 -0
- package/src/engine/indicators/__tests__/vwap.test.ts +69 -0
- package/src/engine/indicators/__tests__/wma.test.ts +112 -0
- package/src/engine/indicators/__tests__/zones.test.ts +95 -0
- package/src/engine/indicators/atrState.ts +27 -0
- package/src/engine/indicators/bollState.ts +51 -0
- package/src/engine/indicators/calculators.ts +2593 -0
- package/src/engine/indicators/cciState.ts +25 -0
- package/src/engine/indicators/chaikinVolState.ts +32 -0
- package/src/engine/indicators/cmfState.ts +27 -0
- package/src/engine/indicators/demaState.ts +27 -0
- package/src/engine/indicators/donchianState.ts +43 -0
- package/src/engine/indicators/eneState.ts +43 -0
- package/src/engine/indicators/expmaState.ts +43 -0
- package/src/engine/indicators/fastkState.ts +25 -0
- package/src/engine/indicators/fibState.ts +41 -0
- package/src/engine/indicators/hmaState.ts +27 -0
- package/src/engine/indicators/hvState.ts +28 -0
- package/src/engine/indicators/ichimokuState.ts +70 -0
- package/src/engine/indicators/indicator.worker.ts +169 -0
- package/src/engine/indicators/indicatorDefinitionRegistry.ts +62 -0
- package/src/engine/indicators/indicatorMetadata.ts +110 -0
- package/src/engine/indicators/indicatorRegistry.ts +106 -0
- package/src/engine/indicators/indicatorRuntime.ts +1548 -0
- package/src/engine/indicators/kamaState.ts +34 -0
- package/src/engine/indicators/keltnerState.ts +49 -0
- package/src/engine/indicators/kstState.ts +42 -0
- package/src/engine/indicators/maState.ts +36 -0
- package/src/engine/indicators/macdState.ts +76 -0
- package/src/engine/indicators/mfiState.ts +27 -0
- package/src/engine/indicators/momState.ts +25 -0
- package/src/engine/indicators/obvState.ts +25 -0
- package/src/engine/indicators/parkinsonState.ts +28 -0
- package/src/engine/indicators/pivotState.ts +51 -0
- package/src/engine/indicators/pvtState.ts +25 -0
- package/src/engine/indicators/rocState.ts +27 -0
- package/src/engine/indicators/rsiState.ts +65 -0
- package/src/engine/indicators/sarState.ts +41 -0
- package/src/engine/indicators/scheduler.ts +1205 -0
- package/src/engine/indicators/soa.ts +352 -0
- package/src/engine/indicators/stateComposer.ts +1262 -0
- package/src/engine/indicators/stochState.ts +26 -0
- package/src/engine/indicators/structureState.ts +69 -0
- package/src/engine/indicators/supertrendState.ts +37 -0
- package/src/engine/indicators/temaState.ts +27 -0
- package/src/engine/indicators/trixState.ts +35 -0
- package/src/engine/indicators/vmaState.ts +27 -0
- package/src/engine/indicators/volumeProfileState.ts +63 -0
- package/src/engine/indicators/vwapState.ts +29 -0
- package/src/engine/indicators/wmaState.ts +27 -0
- package/src/engine/indicators/wmsrState.ts +25 -0
- package/src/engine/indicators/workerProtocol.ts +613 -0
- package/src/engine/indicators/zonesState.ts +47 -0
- package/src/engine/layout/pane.ts +161 -0
- package/src/engine/marker/registry.ts +266 -0
- package/src/engine/paneRenderer.ts +169 -0
- package/src/engine/renderers/Indicator/atr.ts +237 -0
- package/src/engine/renderers/Indicator/boll.ts +317 -0
- package/src/engine/renderers/Indicator/cci.ts +275 -0
- package/src/engine/renderers/Indicator/chaikinVol.ts +138 -0
- package/src/engine/renderers/Indicator/cmf.ts +137 -0
- package/src/engine/renderers/Indicator/dema.ts +136 -0
- package/src/engine/renderers/Indicator/donchian.ts +138 -0
- package/src/engine/renderers/Indicator/ene.ts +271 -0
- package/src/engine/renderers/Indicator/expma.ts +197 -0
- package/src/engine/renderers/Indicator/fastk.ts +316 -0
- package/src/engine/renderers/Indicator/fib.ts +141 -0
- package/src/engine/renderers/Indicator/hma.ts +136 -0
- package/src/engine/renderers/Indicator/hv.ts +124 -0
- package/src/engine/renderers/Indicator/ichimoku.ts +182 -0
- package/src/engine/renderers/Indicator/index.ts +241 -0
- package/src/engine/renderers/Indicator/indicatorData.ts +650 -0
- package/src/engine/renderers/Indicator/kama.ts +136 -0
- package/src/engine/renderers/Indicator/keltner.ts +138 -0
- package/src/engine/renderers/Indicator/kst.ts +302 -0
- package/src/engine/renderers/Indicator/ma.ts +200 -0
- package/src/engine/renderers/Indicator/macd.ts +477 -0
- package/src/engine/renderers/Indicator/macdLegend.ts +141 -0
- package/src/engine/renderers/Indicator/mainIndicatorLegend.ts +272 -0
- package/src/engine/renderers/Indicator/mfi.ts +142 -0
- package/src/engine/renderers/Indicator/mom.ts +311 -0
- package/src/engine/renderers/Indicator/obv.ts +123 -0
- package/src/engine/renderers/Indicator/parkinson.ts +124 -0
- package/src/engine/renderers/Indicator/pivot.ts +131 -0
- package/src/engine/renderers/Indicator/pvt.ts +123 -0
- package/src/engine/renderers/Indicator/roc.ts +143 -0
- package/src/engine/renderers/Indicator/rsi.ts +390 -0
- package/src/engine/renderers/Indicator/sar.ts +113 -0
- package/src/engine/renderers/Indicator/scale/atr_scale.ts +19 -0
- package/src/engine/renderers/Indicator/scale/cci_scale.ts +19 -0
- package/src/engine/renderers/Indicator/scale/fastk_scale.ts +19 -0
- package/src/engine/renderers/Indicator/scale/indicator_scale.ts +204 -0
- package/src/engine/renderers/Indicator/scale/kst_scale.ts +19 -0
- package/src/engine/renderers/Indicator/scale/macd_scale.ts +22 -0
- package/src/engine/renderers/Indicator/scale/mom_scale.ts +19 -0
- package/src/engine/renderers/Indicator/scale/rsi_scale.ts +19 -0
- package/src/engine/renderers/Indicator/scale/stoch_scale.ts +19 -0
- package/src/engine/renderers/Indicator/scale/volume_scale.ts +26 -0
- package/src/engine/renderers/Indicator/scale/wmsr_scale.ts +19 -0
- package/src/engine/renderers/Indicator/stoch.ts +359 -0
- package/src/engine/renderers/Indicator/structure.ts +126 -0
- package/src/engine/renderers/Indicator/subPaneConfig.ts +265 -0
- package/src/engine/renderers/Indicator/supertrend.ts +115 -0
- package/src/engine/renderers/Indicator/tema.ts +136 -0
- package/src/engine/renderers/Indicator/trix.ts +158 -0
- package/src/engine/renderers/Indicator/vma.ts +124 -0
- package/src/engine/renderers/Indicator/volumeProfile.ts +125 -0
- package/src/engine/renderers/Indicator/vwap.ts +123 -0
- package/src/engine/renderers/Indicator/wma.ts +136 -0
- package/src/engine/renderers/Indicator/wmsr.ts +328 -0
- package/src/engine/renderers/Indicator/zones.ts +105 -0
- package/src/engine/renderers/__tests__/boll.renderer.test.ts +314 -0
- package/src/engine/renderers/__tests__/ene.renderer.test.ts +305 -0
- package/src/engine/renderers/__tests__/expma.renderer.test.ts +279 -0
- package/src/engine/renderers/__tests__/ma.renderer.test.ts +426 -0
- package/src/engine/renderers/__tests__/mainIndicatorLegend.renderer.test.ts +502 -0
- package/src/engine/renderers/__tests__/yAxis.renderer.test.ts +173 -0
- package/src/engine/renderers/candle.ts +459 -0
- package/src/engine/renderers/crosshair.ts +69 -0
- package/src/engine/renderers/customMarkers.ts +162 -0
- package/src/engine/renderers/extremaMarkers.ts +246 -0
- package/src/engine/renderers/gridLines.ts +90 -0
- package/src/engine/renderers/lastPrice.ts +97 -0
- package/src/engine/renderers/paneTitle.ts +136 -0
- package/src/engine/renderers/subVolume.ts +236 -0
- package/src/engine/renderers/timeAxis.ts +121 -0
- package/src/engine/renderers/webgl/candleSurface.ts +955 -0
- package/src/engine/renderers/webgl/sharedWebGLSurface.ts +146 -0
- package/src/engine/renderers/yAxis.ts +105 -0
- package/src/engine/scale/__tests__/logFormula.spec.ts +148 -0
- package/src/engine/scale/logFormula.ts +130 -0
- package/src/engine/scale/price.ts +39 -0
- package/src/engine/scale/priceScale.ts +264 -0
- package/src/engine/subPaneManager.ts +427 -0
- package/src/engine/theme/colors.ts +642 -0
- package/src/engine/theme/fonts.ts +20 -0
- package/src/engine/utils/klineConfig.ts +49 -0
- package/src/engine/utils/tickCount.ts +11 -0
- package/src/engine/utils/tickPosition.ts +214 -0
- package/src/engine/utils/zoom.ts +83 -0
- package/src/engine/viewport/viewport.ts +67 -0
- package/src/index.ts +3 -0
- package/src/plugin/ConfigManager.ts +93 -0
- package/src/plugin/EventBus.ts +77 -0
- package/src/plugin/HookSystem.ts +106 -0
- package/src/plugin/PluginHost.ts +243 -0
- package/src/plugin/PluginRegistry.ts +92 -0
- package/src/plugin/StateStore.ts +73 -0
- package/src/plugin/index.ts +19 -0
- package/src/plugin/rendererPluginManager.ts +368 -0
- package/src/plugin/stateKeys.ts +8 -0
- package/src/plugin/types.ts +526 -0
- package/src/reactivity/index.ts +2 -0
- package/src/reactivity/signal.ts +119 -0
- package/src/semantic/controller.ts +251 -0
- package/src/semantic/drawShape.ts +260 -0
- package/src/semantic/index.ts +28 -0
- package/src/semantic/schema.json +256 -0
- package/src/semantic/types.ts +251 -0
- package/src/semantic/validator.ts +349 -0
- package/src/types/kLine.ts +13 -0
- package/src/types/price.ts +56 -0
- package/src/types/volumePrice.ts +33 -0
- package/src/utils/dateFormat.ts +208 -0
- package/src/utils/kLineDraw/axis.ts +562 -0
- package/src/utils/priceToY.ts +34 -0
- package/src/utils/volumePrice.ts +203 -0
- package/src/version.ts +1 -0
|
@@ -0,0 +1,831 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest'
|
|
2
|
+
import { IndicatorScheduler } from '../scheduler'
|
|
3
|
+
import { MA_STATE_KEY, EMPTY_MA_STATE, type MARenderState } from '../maState'
|
|
4
|
+
import { BOLL_STATE_KEY, EMPTY_BOLL_STATE, type BOLLRenderState } from '../bollState'
|
|
5
|
+
import { EXPMA_STATE_KEY, EMPTY_EXPMA_STATE, type EXPMARenderState } from '../expmaState'
|
|
6
|
+
import { ENE_STATE_KEY, EMPTY_ENE_STATE, type ENERenderState } from '../eneState'
|
|
7
|
+
import { createRSIStateKey, EMPTY_RSI_STATE, type RSIRenderState } from '../rsiState'
|
|
8
|
+
import type { KLineData } from '@/types/price'
|
|
9
|
+
import type { PluginHost } from '@/plugin'
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* 创建测试用的 K 线数据
|
|
13
|
+
*/
|
|
14
|
+
function createTestData(length: number, startPrice = 100): KLineData[] {
|
|
15
|
+
return Array.from({ length }, (_, i) => ({
|
|
16
|
+
timestamp: 1000000000000 + i * 60000,
|
|
17
|
+
open: startPrice + i,
|
|
18
|
+
high: startPrice + i + 1,
|
|
19
|
+
low: startPrice + i - 1,
|
|
20
|
+
close: startPrice + i,
|
|
21
|
+
volume: 1000 + i * 100,
|
|
22
|
+
}))
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* 创建 mock PluginHost
|
|
27
|
+
*/
|
|
28
|
+
function createMockPluginHost(): PluginHost {
|
|
29
|
+
const stateStore = new Map<string, unknown>()
|
|
30
|
+
|
|
31
|
+
return {
|
|
32
|
+
setSharedState: vi.fn((key: string, state: unknown, _owner: string) => {
|
|
33
|
+
stateStore.set(key, state)
|
|
34
|
+
}),
|
|
35
|
+
getSharedState: vi.fn(<T>(key: string): T | undefined => {
|
|
36
|
+
return stateStore.get(key) as T | undefined
|
|
37
|
+
}),
|
|
38
|
+
clearByOwner: vi.fn(),
|
|
39
|
+
registerService: vi.fn(),
|
|
40
|
+
getService: vi.fn(),
|
|
41
|
+
getCanvas: vi.fn(),
|
|
42
|
+
getMainPane: vi.fn(),
|
|
43
|
+
getSubPane: vi.fn(),
|
|
44
|
+
getAllSubPanes: vi.fn(),
|
|
45
|
+
getTheme: vi.fn(),
|
|
46
|
+
getStyles: vi.fn(),
|
|
47
|
+
getBarStyles: vi.fn(),
|
|
48
|
+
getConfig: vi.fn(),
|
|
49
|
+
setConfig: vi.fn(),
|
|
50
|
+
on: vi.fn(),
|
|
51
|
+
off: vi.fn(),
|
|
52
|
+
once: vi.fn(),
|
|
53
|
+
emit: vi.fn(),
|
|
54
|
+
} as unknown as PluginHost
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* 从 mock 调用中获取指定 key 的状态(最后一次)
|
|
59
|
+
*/
|
|
60
|
+
function getStateFromMockCalls<T>(mockHost: PluginHost, key: string): T | undefined {
|
|
61
|
+
const calls = vi.mocked(mockHost.setSharedState).mock.calls
|
|
62
|
+
// 从后往前找,获取最后一次写入该 key 的状态
|
|
63
|
+
for (let i = calls.length - 1; i >= 0; i--) {
|
|
64
|
+
if (calls[i]![0] === key) {
|
|
65
|
+
return calls[i]![1] as T
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return undefined
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
describe('IndicatorScheduler', () => {
|
|
72
|
+
let scheduler: IndicatorScheduler
|
|
73
|
+
let mockHost: PluginHost
|
|
74
|
+
|
|
75
|
+
beforeEach(() => {
|
|
76
|
+
scheduler = new IndicatorScheduler()
|
|
77
|
+
mockHost = createMockPluginHost()
|
|
78
|
+
scheduler.setPluginHost(mockHost)
|
|
79
|
+
})
|
|
80
|
+
|
|
81
|
+
describe('initialization', () => {
|
|
82
|
+
it('should not write to state store before first update', () => {
|
|
83
|
+
expect(mockHost.setSharedState).not.toHaveBeenCalled()
|
|
84
|
+
})
|
|
85
|
+
|
|
86
|
+
it('should accept plugin host', () => {
|
|
87
|
+
const newScheduler = new IndicatorScheduler()
|
|
88
|
+
newScheduler.setPluginHost(mockHost)
|
|
89
|
+
// Should not throw
|
|
90
|
+
expect(() => newScheduler.recompute()).not.toThrow()
|
|
91
|
+
})
|
|
92
|
+
})
|
|
93
|
+
|
|
94
|
+
describe('data update', () => {
|
|
95
|
+
it('should write MARenderState to StateStore after update', () => {
|
|
96
|
+
const data = createTestData(100)
|
|
97
|
+
const visibleRange = { start: 0, end: 100 }
|
|
98
|
+
|
|
99
|
+
scheduler.update(data, visibleRange)
|
|
100
|
+
|
|
101
|
+
expect(mockHost.setSharedState).toHaveBeenCalledWith(
|
|
102
|
+
MA_STATE_KEY,
|
|
103
|
+
expect.objectContaining({
|
|
104
|
+
timestamp: expect.any(Number),
|
|
105
|
+
series: expect.any(Object),
|
|
106
|
+
enabledPeriods: expect.any(Array),
|
|
107
|
+
visibleMin: expect.any(Number),
|
|
108
|
+
visibleMax: expect.any(Number),
|
|
109
|
+
}),
|
|
110
|
+
'ma_scheduler'
|
|
111
|
+
)
|
|
112
|
+
})
|
|
113
|
+
|
|
114
|
+
it('should calculate all default MA periods', () => {
|
|
115
|
+
const data = createTestData(100)
|
|
116
|
+
const visibleRange = { start: 0, end: 100 }
|
|
117
|
+
|
|
118
|
+
scheduler.update(data, visibleRange)
|
|
119
|
+
|
|
120
|
+
const state = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
121
|
+
expect(state).toBeDefined()
|
|
122
|
+
|
|
123
|
+
expect(state!.enabledPeriods).toContain(5)
|
|
124
|
+
expect(state!.enabledPeriods).toContain(10)
|
|
125
|
+
expect(state!.enabledPeriods).toContain(20)
|
|
126
|
+
expect(state!.enabledPeriods).toContain(30)
|
|
127
|
+
expect(state!.enabledPeriods).toContain(60)
|
|
128
|
+
})
|
|
129
|
+
|
|
130
|
+
it('should set correct visibleMin and visibleMax for full range', () => {
|
|
131
|
+
// Data: 100, 101, 102, ... 199
|
|
132
|
+
const data = createTestData(100, 100)
|
|
133
|
+
const visibleRange = { start: 60, end: 70 } // Viewing prices 160-169
|
|
134
|
+
|
|
135
|
+
scheduler.update(data, visibleRange)
|
|
136
|
+
|
|
137
|
+
const state = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
138
|
+
expect(state).toBeDefined()
|
|
139
|
+
|
|
140
|
+
// MA5 of prices 160-169 should be between 156-169
|
|
141
|
+
expect(state!.visibleMin).toBeLessThan(state!.visibleMax)
|
|
142
|
+
expect(state!.visibleMax).toBeGreaterThan(150)
|
|
143
|
+
})
|
|
144
|
+
|
|
145
|
+
it('should handle empty data', () => {
|
|
146
|
+
const data: KLineData[] = []
|
|
147
|
+
const visibleRange = { start: 0, end: 0 }
|
|
148
|
+
|
|
149
|
+
scheduler.update(data, visibleRange)
|
|
150
|
+
|
|
151
|
+
const state = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
152
|
+
expect(state).toBeDefined()
|
|
153
|
+
|
|
154
|
+
expect(state!.visibleMin).toBe(Infinity)
|
|
155
|
+
expect(state!.visibleMax).toBe(-Infinity)
|
|
156
|
+
})
|
|
157
|
+
})
|
|
158
|
+
|
|
159
|
+
describe('MA config update', () => {
|
|
160
|
+
it('should update enabled periods based on config', () => {
|
|
161
|
+
const data = createTestData(100)
|
|
162
|
+
const visibleRange = { start: 0, end: 100 }
|
|
163
|
+
|
|
164
|
+
scheduler.update(data, visibleRange)
|
|
165
|
+
|
|
166
|
+
// Disable some periods
|
|
167
|
+
scheduler.updateMAConfig({
|
|
168
|
+
ma5: true,
|
|
169
|
+
ma10: false,
|
|
170
|
+
ma20: true,
|
|
171
|
+
ma30: false,
|
|
172
|
+
ma60: false,
|
|
173
|
+
})
|
|
174
|
+
|
|
175
|
+
const state = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
176
|
+
expect(state).toBeDefined()
|
|
177
|
+
|
|
178
|
+
expect(state!.enabledPeriods).toContain(5)
|
|
179
|
+
expect(state!.enabledPeriods).toContain(20)
|
|
180
|
+
expect(state!.enabledPeriods).not.toContain(10)
|
|
181
|
+
expect(state!.enabledPeriods).not.toContain(30)
|
|
182
|
+
expect(state!.enabledPeriods).not.toContain(60)
|
|
183
|
+
})
|
|
184
|
+
|
|
185
|
+
it('should disable all periods when all flags are false', () => {
|
|
186
|
+
const data = createTestData(100)
|
|
187
|
+
const visibleRange = { start: 0, end: 100 }
|
|
188
|
+
|
|
189
|
+
scheduler.update(data, visibleRange)
|
|
190
|
+
scheduler.updateMAConfig({
|
|
191
|
+
ma5: false,
|
|
192
|
+
ma10: false,
|
|
193
|
+
ma20: false,
|
|
194
|
+
ma30: false,
|
|
195
|
+
ma60: false,
|
|
196
|
+
})
|
|
197
|
+
|
|
198
|
+
const state = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
199
|
+
expect(state).toBeDefined()
|
|
200
|
+
|
|
201
|
+
expect(state!.enabledPeriods).toHaveLength(0)
|
|
202
|
+
expect(state!.visibleMin).toBe(Infinity)
|
|
203
|
+
expect(state!.visibleMax).toBe(-Infinity)
|
|
204
|
+
})
|
|
205
|
+
})
|
|
206
|
+
|
|
207
|
+
describe('visible range update (dual dirty flags)', () => {
|
|
208
|
+
it('should recalculate extremes but not series on viewport change only', () => {
|
|
209
|
+
// Mark sub-indicators active so their states get real extremes (not the EMPTY sentinels)
|
|
210
|
+
scheduler.setActiveSubPaneProvider(() => [
|
|
211
|
+
'sub_RSI', 'sub_CCI', 'sub_STOCH', 'sub_MOM', 'sub_WMSR', 'sub_KST', 'sub_FASTK', 'sub_MACD',
|
|
212
|
+
'sub_ATR', 'sub_WMA', 'sub_DEMA', 'sub_TEMA', 'sub_HMA', 'sub_KAMA', 'sub_SAR',
|
|
213
|
+
'sub_SuperTrend', 'sub_Keltner', 'sub_Donchian', 'sub_Ichimoku',
|
|
214
|
+
'sub_ROC', 'sub_TRIX',
|
|
215
|
+
'sub_HV', 'sub_Parkinson', 'sub_ChaikinVol',
|
|
216
|
+
'sub_VMA', 'sub_OBV', 'sub_PVT',
|
|
217
|
+
'sub_VWAP',
|
|
218
|
+
'sub_CMF', 'sub_MFI',
|
|
219
|
+
'sub_Pivot', 'sub_Fib', 'sub_Structure', 'sub_Zones', 'sub_VolumeProfile',
|
|
220
|
+
])
|
|
221
|
+
|
|
222
|
+
const data = createTestData(100)
|
|
223
|
+
|
|
224
|
+
// First update with full range
|
|
225
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
226
|
+
|
|
227
|
+
// Reset mock to track only the viewport change
|
|
228
|
+
vi.mocked(mockHost.setSharedState).mockClear()
|
|
229
|
+
|
|
230
|
+
// Update only viewport
|
|
231
|
+
scheduler.updateVisibleRange({ start: 50, end: 60 })
|
|
232
|
+
|
|
233
|
+
// updateVisibleStatesOnly writes the 32 sub-indicators.
|
|
234
|
+
// Main indicators (MA, BOLL, EXPMA, ENE) are not rewritten on viewport-only changes.
|
|
235
|
+
expect(mockHost.setSharedState).toHaveBeenCalledTimes(35)
|
|
236
|
+
|
|
237
|
+
// Inspect a sub-indicator (RSI) since main indicators are not rewritten on viewport-only updates
|
|
238
|
+
const rsiKey = createRSIStateKey('sub_RSI')
|
|
239
|
+
const state = getStateFromMockCalls<RSIRenderState>(mockHost, rsiKey)
|
|
240
|
+
expect(state).toBeDefined()
|
|
241
|
+
|
|
242
|
+
// Extremes should be recalculated for the new viewport (finite, not the Infinity sentinels)
|
|
243
|
+
expect(Number.isFinite(state!.visibleMin)).toBe(true)
|
|
244
|
+
expect(Number.isFinite(state!.visibleMax)).toBe(true)
|
|
245
|
+
expect(state!.visibleMin).toBeLessThanOrEqual(state!.visibleMax)
|
|
246
|
+
})
|
|
247
|
+
|
|
248
|
+
it('should recalculate series on data change', () => {
|
|
249
|
+
const data1 = createTestData(100)
|
|
250
|
+
scheduler.update(data1, { start: 0, end: 100 })
|
|
251
|
+
|
|
252
|
+
const data2 = createTestData(100, 200)
|
|
253
|
+
scheduler.update(data2, { start: 0, end: 100 })
|
|
254
|
+
|
|
255
|
+
// Should be called 64 times (32 indicators × 2 data updates)
|
|
256
|
+
expect(mockHost.setSharedState).toHaveBeenCalledTimes(78)
|
|
257
|
+
})
|
|
258
|
+
})
|
|
259
|
+
|
|
260
|
+
describe('recompute', () => {
|
|
261
|
+
it('should force full recalculation', () => {
|
|
262
|
+
const data = createTestData(100)
|
|
263
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
264
|
+
|
|
265
|
+
vi.mocked(mockHost.setSharedState).mockClear()
|
|
266
|
+
|
|
267
|
+
scheduler.recompute()
|
|
268
|
+
|
|
269
|
+
// Should write all 32 indicator states (31 from PR 7 + VWAP)
|
|
270
|
+
expect(mockHost.setSharedState).toHaveBeenCalledTimes(39)
|
|
271
|
+
})
|
|
272
|
+
|
|
273
|
+
it('should recalculate with same data and range', () => {
|
|
274
|
+
const data = createTestData(100)
|
|
275
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
276
|
+
|
|
277
|
+
const firstState = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
278
|
+
expect(firstState).toBeDefined()
|
|
279
|
+
|
|
280
|
+
// Small delay to ensure different timestamp
|
|
281
|
+
const start = Date.now()
|
|
282
|
+
while (Date.now() < start + 2) { /* busy wait */ }
|
|
283
|
+
|
|
284
|
+
scheduler.recompute()
|
|
285
|
+
|
|
286
|
+
const secondState = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
287
|
+
expect(secondState).toBeDefined()
|
|
288
|
+
|
|
289
|
+
// Timestamps should be different (or at least not earlier)
|
|
290
|
+
expect(secondState!.timestamp).toBeGreaterThanOrEqual(firstState!.timestamp)
|
|
291
|
+
})
|
|
292
|
+
})
|
|
293
|
+
|
|
294
|
+
describe('series data structure', () => {
|
|
295
|
+
it('should store series as Record with period keys', () => {
|
|
296
|
+
const data = createTestData(100)
|
|
297
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
298
|
+
|
|
299
|
+
const state = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
300
|
+
expect(state).toBeDefined()
|
|
301
|
+
|
|
302
|
+
// Series should be a Record/object with string keys (numbers become strings in JS objects)
|
|
303
|
+
expect(typeof state!.series).toBe('object')
|
|
304
|
+
expect(state!.series[5]).toBeDefined()
|
|
305
|
+
expect(Array.isArray(state!.series[5])).toBe(true)
|
|
306
|
+
expect(state!.series[5]).toHaveLength(100)
|
|
307
|
+
})
|
|
308
|
+
|
|
309
|
+
it('should have undefined values for indices before period-1', () => {
|
|
310
|
+
const data = createTestData(100)
|
|
311
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
312
|
+
|
|
313
|
+
const state = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
314
|
+
expect(state).toBeDefined()
|
|
315
|
+
|
|
316
|
+
// First 4 values of MA5 should be undefined
|
|
317
|
+
expect(state!.series[5][0]).toBeUndefined()
|
|
318
|
+
expect(state!.series[5][3]).toBeUndefined()
|
|
319
|
+
expect(state!.series[5][4]).toBeDefined()
|
|
320
|
+
})
|
|
321
|
+
})
|
|
322
|
+
})
|
|
323
|
+
|
|
324
|
+
describe('EMPTY_MA_STATE', () => {
|
|
325
|
+
it('should have correct structure', () => {
|
|
326
|
+
expect(EMPTY_MA_STATE).toEqual({
|
|
327
|
+
timestamp: 0,
|
|
328
|
+
series: {},
|
|
329
|
+
enabledPeriods: [],
|
|
330
|
+
visibleMin: Infinity,
|
|
331
|
+
visibleMax: -Infinity,
|
|
332
|
+
})
|
|
333
|
+
})
|
|
334
|
+
|
|
335
|
+
it('should indicate no data when visibleMin > visibleMax', () => {
|
|
336
|
+
expect(EMPTY_MA_STATE.visibleMin).toBeGreaterThan(EMPTY_MA_STATE.visibleMax)
|
|
337
|
+
})
|
|
338
|
+
})
|
|
339
|
+
|
|
340
|
+
describe('BOLL State in scheduler', () => {
|
|
341
|
+
let scheduler: IndicatorScheduler
|
|
342
|
+
let mockHost: PluginHost
|
|
343
|
+
|
|
344
|
+
beforeEach(() => {
|
|
345
|
+
scheduler = new IndicatorScheduler()
|
|
346
|
+
mockHost = createMockPluginHost()
|
|
347
|
+
scheduler.setPluginHost(mockHost)
|
|
348
|
+
})
|
|
349
|
+
|
|
350
|
+
it('should write BOLLRenderState to StateStore after update', () => {
|
|
351
|
+
const data = createTestData(100)
|
|
352
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
353
|
+
|
|
354
|
+
const state = getStateFromMockCalls<BOLLRenderState>(mockHost, BOLL_STATE_KEY)
|
|
355
|
+
expect(state).toBeDefined()
|
|
356
|
+
expect(state!.timestamp).toBeGreaterThan(0)
|
|
357
|
+
expect(state!.series).toHaveLength(100)
|
|
358
|
+
expect(state!.params.period).toBe(20)
|
|
359
|
+
expect(state!.params.multiplier).toBe(2)
|
|
360
|
+
})
|
|
361
|
+
|
|
362
|
+
it('should have sparse BOLL series with undefined before period-1', () => {
|
|
363
|
+
const data = createTestData(100)
|
|
364
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
365
|
+
|
|
366
|
+
const state = getStateFromMockCalls<BOLLRenderState>(mockHost, BOLL_STATE_KEY)
|
|
367
|
+
expect(state).toBeDefined()
|
|
368
|
+
|
|
369
|
+
// First 19 values should be undefined (period=20)
|
|
370
|
+
for (let i = 0; i < 19; i++) {
|
|
371
|
+
expect(state!.series[i]).toBeUndefined()
|
|
372
|
+
}
|
|
373
|
+
expect(state!.series[19]).toBeDefined()
|
|
374
|
+
})
|
|
375
|
+
|
|
376
|
+
it('should pass BOLL params including show flags', () => {
|
|
377
|
+
const data = createTestData(100)
|
|
378
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
379
|
+
|
|
380
|
+
const state = getStateFromMockCalls<BOLLRenderState>(mockHost, BOLL_STATE_KEY)
|
|
381
|
+
expect(state!.params.showUpper).toBe(true)
|
|
382
|
+
expect(state!.params.showMiddle).toBe(true)
|
|
383
|
+
expect(state!.params.showLower).toBe(true)
|
|
384
|
+
expect(state!.params.showBand).toBe(true)
|
|
385
|
+
})
|
|
386
|
+
|
|
387
|
+
it('should update BOLL config via updateBOLLConfig', () => {
|
|
388
|
+
const data = createTestData(100)
|
|
389
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
390
|
+
|
|
391
|
+
scheduler.updateBOLLConfig({ period: 10, multiplier: 3 })
|
|
392
|
+
|
|
393
|
+
const state = getStateFromMockCalls<BOLLRenderState>(mockHost, BOLL_STATE_KEY)
|
|
394
|
+
expect(state!.params.period).toBe(10)
|
|
395
|
+
expect(state!.params.multiplier).toBe(3)
|
|
396
|
+
})
|
|
397
|
+
|
|
398
|
+
it('should recalculate BOLL series when config changes', () => {
|
|
399
|
+
const data = createTestData(100)
|
|
400
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
401
|
+
|
|
402
|
+
const stateBefore = getStateFromMockCalls<BOLLRenderState>(mockHost, BOLL_STATE_KEY)
|
|
403
|
+
const seriesBefore = stateBefore!.series[19]
|
|
404
|
+
|
|
405
|
+
scheduler.updateBOLLConfig({ period: 10 })
|
|
406
|
+
|
|
407
|
+
const stateAfter = getStateFromMockCalls<BOLLRenderState>(mockHost, BOLL_STATE_KEY)
|
|
408
|
+
// With period=10, index 9 is first valid point, index 19 should differ
|
|
409
|
+
expect(stateAfter!.series[9]).toBeDefined()
|
|
410
|
+
})
|
|
411
|
+
|
|
412
|
+
it('should handle empty data', () => {
|
|
413
|
+
scheduler.update([], { start: 0, end: 0 })
|
|
414
|
+
|
|
415
|
+
const state = getStateFromMockCalls<BOLLRenderState>(mockHost, BOLL_STATE_KEY)
|
|
416
|
+
expect(state).toBeDefined()
|
|
417
|
+
expect(state!.visibleMin).toBe(Infinity)
|
|
418
|
+
expect(state!.visibleMax).toBe(-Infinity)
|
|
419
|
+
})
|
|
420
|
+
})
|
|
421
|
+
|
|
422
|
+
describe('EXPMA State in scheduler', () => {
|
|
423
|
+
let scheduler: IndicatorScheduler
|
|
424
|
+
let mockHost: PluginHost
|
|
425
|
+
|
|
426
|
+
beforeEach(() => {
|
|
427
|
+
scheduler = new IndicatorScheduler()
|
|
428
|
+
mockHost = createMockPluginHost()
|
|
429
|
+
scheduler.setPluginHost(mockHost)
|
|
430
|
+
})
|
|
431
|
+
|
|
432
|
+
it('should write EXPMARenderState to StateStore after update', () => {
|
|
433
|
+
const data = createTestData(100)
|
|
434
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
435
|
+
|
|
436
|
+
const state = getStateFromMockCalls<EXPMARenderState>(mockHost, EXPMA_STATE_KEY)
|
|
437
|
+
expect(state).toBeDefined()
|
|
438
|
+
expect(state!.timestamp).toBeGreaterThan(0)
|
|
439
|
+
expect(state!.series).toHaveLength(100)
|
|
440
|
+
expect(state!.params.fastPeriod).toBe(12)
|
|
441
|
+
expect(state!.params.slowPeriod).toBe(50)
|
|
442
|
+
})
|
|
443
|
+
|
|
444
|
+
it('should have dense EXPMA series from index 0', () => {
|
|
445
|
+
const data = createTestData(100)
|
|
446
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
447
|
+
|
|
448
|
+
const state = getStateFromMockCalls<EXPMARenderState>(mockHost, EXPMA_STATE_KEY)
|
|
449
|
+
expect(state!.series[0]).toBeDefined()
|
|
450
|
+
expect(state!.series[0]!.fast).toBeDefined()
|
|
451
|
+
expect(state!.series[0]!.slow).toBeDefined()
|
|
452
|
+
})
|
|
453
|
+
|
|
454
|
+
it('should update EXPMA config via updateEXPMAConfig', () => {
|
|
455
|
+
const data = createTestData(100)
|
|
456
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
457
|
+
|
|
458
|
+
scheduler.updateEXPMAConfig({ fastPeriod: 6, slowPeriod: 30 })
|
|
459
|
+
|
|
460
|
+
const state = getStateFromMockCalls<EXPMARenderState>(mockHost, EXPMA_STATE_KEY)
|
|
461
|
+
expect(state!.params.fastPeriod).toBe(6)
|
|
462
|
+
expect(state!.params.slowPeriod).toBe(30)
|
|
463
|
+
})
|
|
464
|
+
|
|
465
|
+
it('should handle empty data', () => {
|
|
466
|
+
scheduler.update([], { start: 0, end: 0 })
|
|
467
|
+
|
|
468
|
+
const state = getStateFromMockCalls<EXPMARenderState>(mockHost, EXPMA_STATE_KEY)
|
|
469
|
+
expect(state).toBeDefined()
|
|
470
|
+
expect(state!.visibleMin).toBe(Infinity)
|
|
471
|
+
expect(state!.visibleMax).toBe(-Infinity)
|
|
472
|
+
})
|
|
473
|
+
})
|
|
474
|
+
|
|
475
|
+
describe('ENE State in scheduler', () => {
|
|
476
|
+
let scheduler: IndicatorScheduler
|
|
477
|
+
let mockHost: PluginHost
|
|
478
|
+
|
|
479
|
+
beforeEach(() => {
|
|
480
|
+
scheduler = new IndicatorScheduler()
|
|
481
|
+
mockHost = createMockPluginHost()
|
|
482
|
+
scheduler.setPluginHost(mockHost)
|
|
483
|
+
})
|
|
484
|
+
|
|
485
|
+
it('should write ENERenderState to StateStore after update', () => {
|
|
486
|
+
const data = createTestData(100)
|
|
487
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
488
|
+
|
|
489
|
+
const state = getStateFromMockCalls<ENERenderState>(mockHost, ENE_STATE_KEY)
|
|
490
|
+
expect(state).toBeDefined()
|
|
491
|
+
expect(state!.timestamp).toBeGreaterThan(0)
|
|
492
|
+
expect(state!.series).toHaveLength(100)
|
|
493
|
+
expect(state!.params.period).toBe(10)
|
|
494
|
+
expect(state!.params.deviation).toBe(11)
|
|
495
|
+
})
|
|
496
|
+
|
|
497
|
+
it('should have sparse ENE series with undefined before period-1', () => {
|
|
498
|
+
const data = createTestData(100)
|
|
499
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
500
|
+
|
|
501
|
+
const state = getStateFromMockCalls<ENERenderState>(mockHost, ENE_STATE_KEY)
|
|
502
|
+
expect(state).toBeDefined()
|
|
503
|
+
|
|
504
|
+
for (let i = 0; i < 9; i++) {
|
|
505
|
+
expect(state!.series[i]).toBeUndefined()
|
|
506
|
+
}
|
|
507
|
+
expect(state!.series[9]).toBeDefined()
|
|
508
|
+
})
|
|
509
|
+
|
|
510
|
+
it('should update ENE config via updateENEConfig', () => {
|
|
511
|
+
const data = createTestData(100)
|
|
512
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
513
|
+
|
|
514
|
+
scheduler.updateENEConfig({ period: 20, deviation: 8 })
|
|
515
|
+
|
|
516
|
+
const state = getStateFromMockCalls<ENERenderState>(mockHost, ENE_STATE_KEY)
|
|
517
|
+
expect(state!.params.period).toBe(20)
|
|
518
|
+
expect(state!.params.deviation).toBe(8)
|
|
519
|
+
})
|
|
520
|
+
|
|
521
|
+
it('should handle empty data', () => {
|
|
522
|
+
scheduler.update([], { start: 0, end: 0 })
|
|
523
|
+
|
|
524
|
+
const state = getStateFromMockCalls<ENERenderState>(mockHost, ENE_STATE_KEY)
|
|
525
|
+
expect(state).toBeDefined()
|
|
526
|
+
expect(state!.visibleMin).toBe(Infinity)
|
|
527
|
+
expect(state!.visibleMax).toBe(-Infinity)
|
|
528
|
+
})
|
|
529
|
+
})
|
|
530
|
+
|
|
531
|
+
describe('Per-indicator dirty flags', () => {
|
|
532
|
+
let scheduler: IndicatorScheduler
|
|
533
|
+
let mockHost: PluginHost
|
|
534
|
+
|
|
535
|
+
beforeEach(() => {
|
|
536
|
+
scheduler = new IndicatorScheduler()
|
|
537
|
+
mockHost = createMockPluginHost()
|
|
538
|
+
scheduler.setPluginHost(mockHost)
|
|
539
|
+
})
|
|
540
|
+
|
|
541
|
+
it('updateBOLLConfig should not recalculate MA series', () => {
|
|
542
|
+
const data = createTestData(100)
|
|
543
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
544
|
+
|
|
545
|
+
// Capture MA state after initial update
|
|
546
|
+
const maStateBefore = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
547
|
+
const maSeriesBefore = maStateBefore!.series[5]
|
|
548
|
+
|
|
549
|
+
// Reset mock to track new calls
|
|
550
|
+
vi.mocked(mockHost.setSharedState).mockClear()
|
|
551
|
+
|
|
552
|
+
scheduler.updateBOLLConfig({ period: 10 })
|
|
553
|
+
|
|
554
|
+
// MA state should NOT be written (only BOLL state should be written)
|
|
555
|
+
// because MA's dirty flags are not set
|
|
556
|
+
const maStateAfter = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
557
|
+
expect(maStateAfter).toBeUndefined()
|
|
558
|
+
// Verify BOLL state was written
|
|
559
|
+
const bollStateAfter = getStateFromMockCalls<BOLLRenderState>(mockHost, BOLL_STATE_KEY)
|
|
560
|
+
expect(bollStateAfter).toBeDefined()
|
|
561
|
+
expect(bollStateAfter!.params.period).toBe(10)
|
|
562
|
+
})
|
|
563
|
+
|
|
564
|
+
it('updateEXPMAConfig should not recalculate MA series', () => {
|
|
565
|
+
const data = createTestData(100)
|
|
566
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
567
|
+
|
|
568
|
+
const maStateBefore = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
569
|
+
const maSeriesBefore = maStateBefore!.series[5]
|
|
570
|
+
|
|
571
|
+
vi.mocked(mockHost.setSharedState).mockClear()
|
|
572
|
+
|
|
573
|
+
scheduler.updateEXPMAConfig({ fastPeriod: 6 })
|
|
574
|
+
|
|
575
|
+
// MA state should NOT be written (only EXPMA state should be written)
|
|
576
|
+
const maStateAfter = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
577
|
+
expect(maStateAfter).toBeUndefined()
|
|
578
|
+
// Verify EXPMA state was written
|
|
579
|
+
const expmaStateAfter = getStateFromMockCalls<EXPMARenderState>(mockHost, EXPMA_STATE_KEY)
|
|
580
|
+
expect(expmaStateAfter).toBeDefined()
|
|
581
|
+
expect(expmaStateAfter!.params.fastPeriod).toBe(6)
|
|
582
|
+
})
|
|
583
|
+
|
|
584
|
+
it('updateENEConfig should not recalculate MA series', () => {
|
|
585
|
+
const data = createTestData(100)
|
|
586
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
587
|
+
|
|
588
|
+
const maStateBefore = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
589
|
+
const maSeriesBefore = maStateBefore!.series[5]
|
|
590
|
+
|
|
591
|
+
vi.mocked(mockHost.setSharedState).mockClear()
|
|
592
|
+
|
|
593
|
+
scheduler.updateENEConfig({ period: 20 })
|
|
594
|
+
|
|
595
|
+
// MA state should NOT be written (only ENE state should be written)
|
|
596
|
+
const maStateAfter = getStateFromMockCalls<MARenderState>(mockHost, MA_STATE_KEY)
|
|
597
|
+
expect(maStateAfter).toBeUndefined()
|
|
598
|
+
// Verify ENE state was written
|
|
599
|
+
const eneStateAfter = getStateFromMockCalls<ENERenderState>(mockHost, ENE_STATE_KEY)
|
|
600
|
+
expect(eneStateAfter).toBeDefined()
|
|
601
|
+
expect(eneStateAfter!.params.period).toBe(20)
|
|
602
|
+
})
|
|
603
|
+
|
|
604
|
+
it('updateBOLLConfig should recalculate BOLL extremes', () => {
|
|
605
|
+
const data = createTestData(100)
|
|
606
|
+
scheduler.update(data, { start: 0, end: 100 })
|
|
607
|
+
|
|
608
|
+
const bollStateBefore = getStateFromMockCalls<BOLLRenderState>(mockHost, BOLL_STATE_KEY)
|
|
609
|
+
|
|
610
|
+
scheduler.updateBOLLConfig({ period: 10 })
|
|
611
|
+
|
|
612
|
+
const bollStateAfter = getStateFromMockCalls<BOLLRenderState>(mockHost, BOLL_STATE_KEY)
|
|
613
|
+
// Extremes should be recalculated
|
|
614
|
+
expect(bollStateAfter!.visibleMin).toBeLessThan(bollStateAfter!.visibleMax)
|
|
615
|
+
})
|
|
616
|
+
})
|
|
617
|
+
|
|
618
|
+
describe('EMPTY_BOLL_STATE', () => {
|
|
619
|
+
it('should have correct structure', () => {
|
|
620
|
+
expect(EMPTY_BOLL_STATE).toEqual({
|
|
621
|
+
timestamp: 0,
|
|
622
|
+
series: [],
|
|
623
|
+
params: {
|
|
624
|
+
period: 20,
|
|
625
|
+
multiplier: 2,
|
|
626
|
+
showUpper: true,
|
|
627
|
+
showMiddle: true,
|
|
628
|
+
showLower: true,
|
|
629
|
+
showBand: true,
|
|
630
|
+
},
|
|
631
|
+
visibleMin: Infinity,
|
|
632
|
+
visibleMax: -Infinity,
|
|
633
|
+
})
|
|
634
|
+
})
|
|
635
|
+
|
|
636
|
+
it('should indicate no data when visibleMin > visibleMax', () => {
|
|
637
|
+
expect(EMPTY_BOLL_STATE.visibleMin).toBeGreaterThan(EMPTY_BOLL_STATE.visibleMax)
|
|
638
|
+
})
|
|
639
|
+
})
|
|
640
|
+
|
|
641
|
+
describe('EMPTY_EXPMA_STATE', () => {
|
|
642
|
+
it('should have correct structure', () => {
|
|
643
|
+
expect(EMPTY_EXPMA_STATE).toEqual({
|
|
644
|
+
timestamp: 0,
|
|
645
|
+
series: [],
|
|
646
|
+
params: {
|
|
647
|
+
fastPeriod: 12,
|
|
648
|
+
slowPeriod: 50,
|
|
649
|
+
},
|
|
650
|
+
visibleMin: Infinity,
|
|
651
|
+
visibleMax: -Infinity,
|
|
652
|
+
})
|
|
653
|
+
})
|
|
654
|
+
|
|
655
|
+
it('should indicate no data when visibleMin > visibleMax', () => {
|
|
656
|
+
expect(EMPTY_EXPMA_STATE.visibleMin).toBeGreaterThan(EMPTY_EXPMA_STATE.visibleMax)
|
|
657
|
+
})
|
|
658
|
+
})
|
|
659
|
+
|
|
660
|
+
describe('EMPTY_ENE_STATE', () => {
|
|
661
|
+
it('should have correct structure', () => {
|
|
662
|
+
expect(EMPTY_ENE_STATE).toEqual({
|
|
663
|
+
timestamp: 0,
|
|
664
|
+
series: [],
|
|
665
|
+
params: {
|
|
666
|
+
period: 10,
|
|
667
|
+
deviation: 11,
|
|
668
|
+
},
|
|
669
|
+
visibleMin: Infinity,
|
|
670
|
+
visibleMax: -Infinity,
|
|
671
|
+
})
|
|
672
|
+
})
|
|
673
|
+
|
|
674
|
+
it('should indicate no data when visibleMin > visibleMax', () => {
|
|
675
|
+
expect(EMPTY_ENE_STATE.visibleMin).toBeGreaterThan(EMPTY_ENE_STATE.visibleMax)
|
|
676
|
+
})
|
|
677
|
+
})
|
|
678
|
+
|
|
679
|
+
describe('RSI State in scheduler', () => {
|
|
680
|
+
let scheduler: IndicatorScheduler
|
|
681
|
+
let mockHost: PluginHost
|
|
682
|
+
|
|
683
|
+
beforeEach(() => {
|
|
684
|
+
scheduler = new IndicatorScheduler()
|
|
685
|
+
mockHost = createMockPluginHost()
|
|
686
|
+
scheduler.setPluginHost(mockHost)
|
|
687
|
+
})
|
|
688
|
+
|
|
689
|
+
it('should write RSIRenderState to StateStore after update', () => {
|
|
690
|
+
const data = createTestData(50)
|
|
691
|
+
scheduler.update(data, { start: 0, end: 20 })
|
|
692
|
+
|
|
693
|
+
const rsiKey = createRSIStateKey('sub_RSI')
|
|
694
|
+
const setSharedState = mockHost.setSharedState as ReturnType<typeof vi.fn>
|
|
695
|
+
const rsiCall = setSharedState.mock.calls.find((call: unknown[]) => call[0] === rsiKey)
|
|
696
|
+
expect(rsiCall).toBeDefined()
|
|
697
|
+
|
|
698
|
+
const rsiState = rsiCall?.[1] as RSIRenderState
|
|
699
|
+
expect(rsiState.series).toBeDefined()
|
|
700
|
+
expect(rsiState.enabledPeriods).toEqual([6, 12, 24])
|
|
701
|
+
expect(rsiState.params.period1).toBe(6)
|
|
702
|
+
expect(rsiState.params.period2).toBe(12)
|
|
703
|
+
expect(rsiState.params.period3).toBe(24)
|
|
704
|
+
expect(rsiState.valueMin).toBe(0)
|
|
705
|
+
expect(rsiState.valueMax).toBe(100)
|
|
706
|
+
})
|
|
707
|
+
|
|
708
|
+
it('should have sparse RSI series (first period+1 entries undefined)', () => {
|
|
709
|
+
const data = createTestData(50)
|
|
710
|
+
scheduler.update(data, { start: 0, end: 30 })
|
|
711
|
+
|
|
712
|
+
const rsiKey = createRSIStateKey('sub_RSI')
|
|
713
|
+
const setSharedState = mockHost.setSharedState as ReturnType<typeof vi.fn>
|
|
714
|
+
const rsiCall = setSharedState.mock.calls.find((call: unknown[]) => call[0] === rsiKey)
|
|
715
|
+
const rsiState = rsiCall?.[1] as RSIRenderState
|
|
716
|
+
|
|
717
|
+
// RSI(6): indices 0-5 should be undefined, index 6 should be valid
|
|
718
|
+
expect(rsiState.series[6][0]).toBeUndefined()
|
|
719
|
+
expect(rsiState.series[6][5]).toBeUndefined()
|
|
720
|
+
expect(rsiState.series[6][6]).toBeDefined()
|
|
721
|
+
})
|
|
722
|
+
|
|
723
|
+
it('should pass RSI params including show flags', () => {
|
|
724
|
+
scheduler.updateRSIConfig({ showRSI1: true, showRSI2: false, showRSI3: true }, 'sub_RSI')
|
|
725
|
+
const data = createTestData(50)
|
|
726
|
+
scheduler.update(data, { start: 0, end: 20 })
|
|
727
|
+
|
|
728
|
+
const rsiKey = createRSIStateKey('sub_RSI')
|
|
729
|
+
const setSharedState = mockHost.setSharedState as ReturnType<typeof vi.fn>
|
|
730
|
+
const rsiCall = setSharedState.mock.calls.find((call: unknown[]) => call[0] === rsiKey)
|
|
731
|
+
const rsiState = rsiCall?.[1] as RSIRenderState
|
|
732
|
+
|
|
733
|
+
expect(rsiState.params.showRSI1).toBe(true)
|
|
734
|
+
expect(rsiState.params.showRSI2).toBe(false)
|
|
735
|
+
expect(rsiState.params.showRSI3).toBe(true)
|
|
736
|
+
// Only RSI1 and RSI3 should be in series and enabledPeriods
|
|
737
|
+
expect(rsiState.enabledPeriods).toContain(6)
|
|
738
|
+
expect(rsiState.enabledPeriods).not.toContain(12)
|
|
739
|
+
expect(rsiState.enabledPeriods).toContain(24)
|
|
740
|
+
})
|
|
741
|
+
|
|
742
|
+
it('should update RSI config via updateRSIConfig', () => {
|
|
743
|
+
scheduler.updateRSIConfig({ period1: 10, period2: 20, period3: 30 }, 'sub_RSI')
|
|
744
|
+
const data = createTestData(100)
|
|
745
|
+
scheduler.update(data, { start: 0, end: 50 })
|
|
746
|
+
|
|
747
|
+
const rsiKey = createRSIStateKey('sub_RSI')
|
|
748
|
+
const setSharedState = mockHost.setSharedState as ReturnType<typeof vi.fn>
|
|
749
|
+
const rsiCall = setSharedState.mock.calls.find((call: unknown[]) => call[0] === rsiKey)
|
|
750
|
+
const rsiState = rsiCall?.[1] as RSIRenderState
|
|
751
|
+
|
|
752
|
+
expect(rsiState.params.period1).toBe(10)
|
|
753
|
+
expect(rsiState.params.period2).toBe(20)
|
|
754
|
+
expect(rsiState.params.period3).toBe(30)
|
|
755
|
+
})
|
|
756
|
+
|
|
757
|
+
it('should not recalculate MA series on RSI config change', () => {
|
|
758
|
+
const data = createTestData(50)
|
|
759
|
+
scheduler.update(data, { start: 0, end: 20 })
|
|
760
|
+
|
|
761
|
+
// Get the MA state after first update
|
|
762
|
+
const maStateBefore = (mockHost.setSharedState as ReturnType<typeof vi.fn>).mock.calls.find(
|
|
763
|
+
(call: unknown[]) => call[0] === MA_STATE_KEY
|
|
764
|
+
)?.[1] as MARenderState
|
|
765
|
+
|
|
766
|
+
// Update RSI config only
|
|
767
|
+
scheduler.updateRSIConfig({ period1: 14 }, 'sub_RSI')
|
|
768
|
+
|
|
769
|
+
// Get the MA state after RSI config update
|
|
770
|
+
const maStateAfter = (mockHost.setSharedState as ReturnType<typeof vi.fn>).mock.calls.find(
|
|
771
|
+
(call: unknown[]) => call[0] === MA_STATE_KEY
|
|
772
|
+
)?.[1] as MARenderState
|
|
773
|
+
|
|
774
|
+
// MA series should remain the same reference (not recalculated)
|
|
775
|
+
expect(maStateAfter.series).toBe(maStateBefore.series)
|
|
776
|
+
})
|
|
777
|
+
|
|
778
|
+
it('should use dynamic paneId in state key', () => {
|
|
779
|
+
scheduler.updateRSIConfig({}, 'custom_RSI_pane')
|
|
780
|
+
const data = createTestData(50)
|
|
781
|
+
scheduler.update(data, { start: 0, end: 20 })
|
|
782
|
+
|
|
783
|
+
const expectedKey = createRSIStateKey('custom_RSI_pane')
|
|
784
|
+
const setSharedState = mockHost.setSharedState as ReturnType<typeof vi.fn>
|
|
785
|
+
const rsiCall = setSharedState.mock.calls.find((call: unknown[]) => call[0] === expectedKey)
|
|
786
|
+
expect(rsiCall).toBeDefined()
|
|
787
|
+
})
|
|
788
|
+
|
|
789
|
+
it('should have visibleMin=Infinity visibleMax=-Infinity when no data', () => {
|
|
790
|
+
scheduler.update([], { start: 0, end: 0 })
|
|
791
|
+
|
|
792
|
+
const rsiKey = createRSIStateKey('sub_RSI')
|
|
793
|
+
const setSharedState = mockHost.setSharedState as ReturnType<typeof vi.fn>
|
|
794
|
+
const rsiCall = setSharedState.mock.calls.find((call: unknown[]) => call[0] === rsiKey)
|
|
795
|
+
const rsiState = rsiCall?.[1] as RSIRenderState
|
|
796
|
+
|
|
797
|
+
expect(rsiState.visibleMin).toBe(Infinity)
|
|
798
|
+
expect(rsiState.visibleMax).toBe(-Infinity)
|
|
799
|
+
})
|
|
800
|
+
})
|
|
801
|
+
|
|
802
|
+
describe('EMPTY_RSI_STATE', () => {
|
|
803
|
+
it('should have correct structure', () => {
|
|
804
|
+
expect(EMPTY_RSI_STATE).toEqual({
|
|
805
|
+
timestamp: 0,
|
|
806
|
+
series: {},
|
|
807
|
+
enabledPeriods: [],
|
|
808
|
+
params: {
|
|
809
|
+
period1: 6,
|
|
810
|
+
period2: 12,
|
|
811
|
+
period3: 24,
|
|
812
|
+
showRSI1: true,
|
|
813
|
+
showRSI2: true,
|
|
814
|
+
showRSI3: true,
|
|
815
|
+
},
|
|
816
|
+
valueMin: 0,
|
|
817
|
+
valueMax: 100,
|
|
818
|
+
visibleMin: Infinity,
|
|
819
|
+
visibleMax: -Infinity,
|
|
820
|
+
})
|
|
821
|
+
})
|
|
822
|
+
|
|
823
|
+
it('should indicate no data when visibleMin > visibleMax', () => {
|
|
824
|
+
expect(EMPTY_RSI_STATE.visibleMin).toBeGreaterThan(EMPTY_RSI_STATE.visibleMax)
|
|
825
|
+
})
|
|
826
|
+
|
|
827
|
+
it('should have fixed valueMin and valueMax', () => {
|
|
828
|
+
expect(EMPTY_RSI_STATE.valueMin).toBe(0)
|
|
829
|
+
expect(EMPTY_RSI_STATE.valueMax).toBe(100)
|
|
830
|
+
})
|
|
831
|
+
})
|