@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,68 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest'
|
|
2
|
+
import { calcTEMAData } from '../calculators'
|
|
3
|
+
import {
|
|
4
|
+
empty,
|
|
5
|
+
singleBar,
|
|
6
|
+
constantPrice,
|
|
7
|
+
pureUptrend,
|
|
8
|
+
pureDowntrend,
|
|
9
|
+
sideways,
|
|
10
|
+
spikeAtBar19,
|
|
11
|
+
} from './__fixtures__/synthetic'
|
|
12
|
+
import { TEMA_GOLDEN, assertSeriesClose } from './__fixtures__/golden'
|
|
13
|
+
import {
|
|
14
|
+
assertFiniteOrUndefined,
|
|
15
|
+
} from './_propertyAssertions'
|
|
16
|
+
|
|
17
|
+
describe('calcTEMAData — Triple Exponential Moving Average', () => {
|
|
18
|
+
describe('edge cases', () => {
|
|
19
|
+
it('empty returns empty array', () => {
|
|
20
|
+
expect(calcTEMAData(empty, 20)).toEqual([])
|
|
21
|
+
})
|
|
22
|
+
|
|
23
|
+
it('single bar produces a single defined value', () => {
|
|
24
|
+
const out = calcTEMAData(singleBar, 20)
|
|
25
|
+
expect(out).toHaveLength(1)
|
|
26
|
+
expect(out[0]).toBeCloseTo(100, 9)
|
|
27
|
+
})
|
|
28
|
+
|
|
29
|
+
it('period = 0 returns all undefined', () => {
|
|
30
|
+
const zero = calcTEMAData(pureUptrend, 0)
|
|
31
|
+
for (const v of zero) expect(v).toBeUndefined()
|
|
32
|
+
})
|
|
33
|
+
})
|
|
34
|
+
|
|
35
|
+
describe('golden values', () => {
|
|
36
|
+
it('constantPrice → TEMA(20) = 100 throughout', () => {
|
|
37
|
+
assertSeriesClose(calcTEMAData(constantPrice, 20), TEMA_GOLDEN.constantPrice!.series)
|
|
38
|
+
})
|
|
39
|
+
})
|
|
40
|
+
|
|
41
|
+
describe('mathematical properties', () => {
|
|
42
|
+
it('all values finite', () => {
|
|
43
|
+
for (const fx of [pureUptrend, pureDowntrend, sideways, spikeAtBar19]) {
|
|
44
|
+
assertFiniteOrUndefined(calcTEMAData(fx, 20), 'TEMA series')
|
|
45
|
+
}
|
|
46
|
+
})
|
|
47
|
+
|
|
48
|
+
it('tracks uptrend monotonically once warmed', () => {
|
|
49
|
+
const out = calcTEMAData(pureUptrend, 20)
|
|
50
|
+
const tail = out.slice(20).filter((v): v is number => v !== undefined)
|
|
51
|
+
for (let i = 1; i < tail.length; i++) {
|
|
52
|
+
expect(tail[i]!).toBeGreaterThan(tail[i - 1]!)
|
|
53
|
+
}
|
|
54
|
+
})
|
|
55
|
+
|
|
56
|
+
it('extensional consistency', () => {
|
|
57
|
+
const full = calcTEMAData(pureUptrend, 20)
|
|
58
|
+
for (let n = 5; n < pureUptrend.length; n++) {
|
|
59
|
+
const partial = calcTEMAData(pureUptrend.slice(0, n), 20)
|
|
60
|
+
for (let i = 0; i < n; i++) {
|
|
61
|
+
if (full[i] !== undefined && partial[i] !== undefined) {
|
|
62
|
+
expect(partial[i]).toBeCloseTo(full[i]!, 9)
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
})
|
|
67
|
+
})
|
|
68
|
+
})
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest'
|
|
2
|
+
import { calcTRIXData } from '../calculators'
|
|
3
|
+
import {
|
|
4
|
+
empty,
|
|
5
|
+
constantPrice,
|
|
6
|
+
pureUptrend,
|
|
7
|
+
pureDowntrend,
|
|
8
|
+
sideways,
|
|
9
|
+
} from './__fixtures__/synthetic'
|
|
10
|
+
|
|
11
|
+
describe('calcTRIXData', () => {
|
|
12
|
+
it('empty returns empty result', () => {
|
|
13
|
+
const out = calcTRIXData(empty, 15, 9)
|
|
14
|
+
expect(out.series).toEqual([])
|
|
15
|
+
expect(out.signalSeries).toEqual([])
|
|
16
|
+
})
|
|
17
|
+
|
|
18
|
+
it('period <= 0 returns empty series', () => {
|
|
19
|
+
const out = calcTRIXData(pureUptrend, 0, 9)
|
|
20
|
+
for (const v of out.series) expect(v).toBeUndefined()
|
|
21
|
+
})
|
|
22
|
+
|
|
23
|
+
it('on constantPrice TRIX = 0 (constant EMA3 → no change)', () => {
|
|
24
|
+
const out = calcTRIXData(constantPrice, 15, 9)
|
|
25
|
+
for (let t = 1; t < out.series.length; t++) {
|
|
26
|
+
if (out.series[t] !== undefined) expect(out.series[t]).toBeCloseTo(0, 9)
|
|
27
|
+
}
|
|
28
|
+
})
|
|
29
|
+
|
|
30
|
+
it('on pureUptrend TRIX > 0 once warmed', () => {
|
|
31
|
+
const out = calcTRIXData(pureUptrend, 5, 3)
|
|
32
|
+
const tail = out.series.slice(10).filter((v): v is number => v !== undefined)
|
|
33
|
+
expect(tail.length).toBeGreaterThan(0)
|
|
34
|
+
for (const v of tail) {
|
|
35
|
+
expect(v).toBeGreaterThan(0)
|
|
36
|
+
}
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
it('on pureDowntrend TRIX < 0 once warmed', () => {
|
|
40
|
+
const out = calcTRIXData(pureDowntrend, 5, 3)
|
|
41
|
+
const tail = out.series.slice(10).filter((v): v is number => v !== undefined)
|
|
42
|
+
for (const v of tail) {
|
|
43
|
+
expect(v).toBeLessThan(0)
|
|
44
|
+
}
|
|
45
|
+
})
|
|
46
|
+
|
|
47
|
+
it('signal series is a smoothing of TRIX (less volatile)', () => {
|
|
48
|
+
const out = calcTRIXData(sideways, 5, 3)
|
|
49
|
+
// Both should have defined tails; signal range should not exceed series range
|
|
50
|
+
const series = out.series.filter((v): v is number => v !== undefined)
|
|
51
|
+
const signal = out.signalSeries.filter((v): v is number => v !== undefined)
|
|
52
|
+
if (series.length >= 5 && signal.length >= 5) {
|
|
53
|
+
const seriesRange = Math.max(...series) - Math.min(...series)
|
|
54
|
+
const signalRange = Math.max(...signal) - Math.min(...signal)
|
|
55
|
+
expect(signalRange).toBeLessThanOrEqual(seriesRange + 1e-9)
|
|
56
|
+
}
|
|
57
|
+
})
|
|
58
|
+
|
|
59
|
+
it('extensional consistency', () => {
|
|
60
|
+
const full = calcTRIXData(pureUptrend, 5, 3)
|
|
61
|
+
for (let n = 10; n < pureUptrend.length; n++) {
|
|
62
|
+
const partial = calcTRIXData(pureUptrend.slice(0, n), 5, 3)
|
|
63
|
+
for (let i = 0; i < n; i++) {
|
|
64
|
+
if (full.series[i] !== undefined && partial.series[i] !== undefined) {
|
|
65
|
+
expect(partial.series[i]).toBeCloseTo(full.series[i]!, 9)
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
})
|
|
70
|
+
})
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest'
|
|
2
|
+
import { calcHVData, calcParkinsonData, calcChaikinVolData } from '../calculators'
|
|
3
|
+
import {
|
|
4
|
+
empty,
|
|
5
|
+
constantPrice,
|
|
6
|
+
pureUptrend,
|
|
7
|
+
sideways,
|
|
8
|
+
spikeAtBar19,
|
|
9
|
+
} from './__fixtures__/synthetic'
|
|
10
|
+
|
|
11
|
+
describe('calcHVData — Historical Volatility', () => {
|
|
12
|
+
it('empty returns empty', () => {
|
|
13
|
+
expect(calcHVData(empty, 20, 252)).toEqual([])
|
|
14
|
+
})
|
|
15
|
+
|
|
16
|
+
it('period <= 0 or annualization <= 0 returns all undefined', () => {
|
|
17
|
+
const out1 = calcHVData(pureUptrend, 0, 252)
|
|
18
|
+
for (const v of out1) expect(v).toBeUndefined()
|
|
19
|
+
const out2 = calcHVData(pureUptrend, 20, 0)
|
|
20
|
+
for (const v of out2) expect(v).toBeUndefined()
|
|
21
|
+
})
|
|
22
|
+
|
|
23
|
+
it('on constantPrice HV = 0 (no return variance)', () => {
|
|
24
|
+
const out = calcHVData(constantPrice, 10, 252)
|
|
25
|
+
for (let t = 10; t < out.length; t++) {
|
|
26
|
+
expect(out[t]).toBeCloseTo(0, 9)
|
|
27
|
+
}
|
|
28
|
+
})
|
|
29
|
+
|
|
30
|
+
it('on pureUptrend HV > 0 once warm-up complete', () => {
|
|
31
|
+
const out = calcHVData(pureUptrend, 10, 252)
|
|
32
|
+
for (let t = 10; t < out.length; t++) {
|
|
33
|
+
expect(out[t]).toBeGreaterThanOrEqual(0)
|
|
34
|
+
}
|
|
35
|
+
})
|
|
36
|
+
|
|
37
|
+
it('HV ≥ 0 always', () => {
|
|
38
|
+
for (const fx of [pureUptrend, sideways, spikeAtBar19]) {
|
|
39
|
+
for (const v of calcHVData(fx, 10, 252)) {
|
|
40
|
+
if (v !== undefined) expect(v).toBeGreaterThanOrEqual(0)
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
})
|
|
44
|
+
|
|
45
|
+
it('higher annualization → higher HV value (sqrt scaling)', () => {
|
|
46
|
+
const low = calcHVData(spikeAtBar19, 10, 100)
|
|
47
|
+
const high = calcHVData(spikeAtBar19, 10, 400)
|
|
48
|
+
for (let t = 10; t < low.length; t++) {
|
|
49
|
+
if (low[t] !== undefined && high[t] !== undefined) {
|
|
50
|
+
expect(high[t]).toBeCloseTo(low[t]! * 2, 9) // sqrt(400)/sqrt(100) = 2
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
})
|
|
54
|
+
})
|
|
55
|
+
|
|
56
|
+
describe('calcParkinsonData — Parkinson Volatility', () => {
|
|
57
|
+
it('empty returns empty', () => {
|
|
58
|
+
expect(calcParkinsonData(empty, 20, 252)).toEqual([])
|
|
59
|
+
})
|
|
60
|
+
|
|
61
|
+
it('on constantPrice (H=L) Parkinson = 0', () => {
|
|
62
|
+
const out = calcParkinsonData(constantPrice, 10, 252)
|
|
63
|
+
for (let t = 9; t < out.length; t++) {
|
|
64
|
+
expect(out[t]).toBeCloseTo(0, 9)
|
|
65
|
+
}
|
|
66
|
+
})
|
|
67
|
+
|
|
68
|
+
it('Parkinson ≥ 0 always', () => {
|
|
69
|
+
for (const fx of [pureUptrend, sideways, spikeAtBar19]) {
|
|
70
|
+
for (const v of calcParkinsonData(fx, 10, 252)) {
|
|
71
|
+
if (v !== undefined) expect(v).toBeGreaterThanOrEqual(0)
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
})
|
|
75
|
+
|
|
76
|
+
it('on spike fixture Parkinson responds to the spike bar', () => {
|
|
77
|
+
const out = calcParkinsonData(spikeAtBar19, 5, 252)
|
|
78
|
+
const preSpike = out[18]
|
|
79
|
+
const atSpike = out[19]
|
|
80
|
+
if (preSpike !== undefined && atSpike !== undefined) {
|
|
81
|
+
expect(atSpike).toBeGreaterThanOrEqual(preSpike)
|
|
82
|
+
}
|
|
83
|
+
})
|
|
84
|
+
})
|
|
85
|
+
|
|
86
|
+
describe('calcChaikinVolData — Chaikin Volatility', () => {
|
|
87
|
+
it('empty returns empty', () => {
|
|
88
|
+
expect(calcChaikinVolData(empty, 10, 10)).toEqual([])
|
|
89
|
+
})
|
|
90
|
+
|
|
91
|
+
it('on constantPrice ChaikinVol stays at 0 (EMA(H-L) constant)', () => {
|
|
92
|
+
const out = calcChaikinVolData(constantPrice, 10, 10)
|
|
93
|
+
for (let t = 10; t < out.length; t++) {
|
|
94
|
+
if (out[t] !== undefined) expect(out[t]).toBeCloseTo(0, 6)
|
|
95
|
+
}
|
|
96
|
+
})
|
|
97
|
+
|
|
98
|
+
it('values finite or undefined', () => {
|
|
99
|
+
for (const fx of [pureUptrend, sideways, spikeAtBar19]) {
|
|
100
|
+
for (const v of calcChaikinVolData(fx, 10, 10)) {
|
|
101
|
+
if (v !== undefined) expect(Number.isFinite(v)).toBe(true)
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
})
|
|
105
|
+
|
|
106
|
+
it('extensional consistency on spike fixture', () => {
|
|
107
|
+
const full = calcChaikinVolData(spikeAtBar19, 5, 5)
|
|
108
|
+
for (let n = 12; n < spikeAtBar19.length; n++) {
|
|
109
|
+
const partial = calcChaikinVolData(spikeAtBar19.slice(0, n), 5, 5)
|
|
110
|
+
for (let i = 0; i < n; i++) {
|
|
111
|
+
if (full[i] !== undefined && partial[i] !== undefined) {
|
|
112
|
+
expect(partial[i]).toBeCloseTo(full[i]!, 9)
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
})
|
|
117
|
+
})
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest'
|
|
2
|
+
import { calcVMAData, calcOBVData, calcPVTData } from '../calculators'
|
|
3
|
+
import {
|
|
4
|
+
empty,
|
|
5
|
+
constantPrice,
|
|
6
|
+
pureUptrend,
|
|
7
|
+
pureDowntrend,
|
|
8
|
+
sideways,
|
|
9
|
+
spikeAtBar19,
|
|
10
|
+
} from './__fixtures__/synthetic'
|
|
11
|
+
|
|
12
|
+
describe('calcVMAData', () => {
|
|
13
|
+
it('empty returns empty', () => {
|
|
14
|
+
expect(calcVMAData(empty, 5)).toEqual([])
|
|
15
|
+
})
|
|
16
|
+
|
|
17
|
+
it('shorter than period returns all undefined', () => {
|
|
18
|
+
const out = calcVMAData(pureUptrend.slice(0, 3), 5)
|
|
19
|
+
for (const v of out) expect(v).toBeUndefined()
|
|
20
|
+
})
|
|
21
|
+
|
|
22
|
+
it('period <= 0 returns all undefined', () => {
|
|
23
|
+
const out = calcVMAData(pureUptrend, 0)
|
|
24
|
+
for (const v of out) expect(v).toBeUndefined()
|
|
25
|
+
})
|
|
26
|
+
|
|
27
|
+
it('on constantPrice (volume=1000) VMA = 1000 after warm-up', () => {
|
|
28
|
+
const out = calcVMAData(constantPrice, 5)
|
|
29
|
+
for (let t = 4; t < out.length; t++) {
|
|
30
|
+
expect(out[t]).toBe(1000)
|
|
31
|
+
}
|
|
32
|
+
})
|
|
33
|
+
|
|
34
|
+
it('mathematical exactness: VMA = mean of last `period` volumes', () => {
|
|
35
|
+
const period = 5
|
|
36
|
+
const out = calcVMAData(pureUptrend, period)
|
|
37
|
+
for (let t = period - 1; t < out.length; t++) {
|
|
38
|
+
let sum = 0
|
|
39
|
+
for (let k = 0; k < period; k++) sum += pureUptrend[t - k]!.volume ?? 0
|
|
40
|
+
expect(out[t]!).toBeCloseTo(sum / period, 9)
|
|
41
|
+
}
|
|
42
|
+
})
|
|
43
|
+
})
|
|
44
|
+
|
|
45
|
+
describe('calcOBVData', () => {
|
|
46
|
+
it('empty returns empty', () => {
|
|
47
|
+
expect(calcOBVData(empty)).toEqual([])
|
|
48
|
+
})
|
|
49
|
+
|
|
50
|
+
it('starts at 0', () => {
|
|
51
|
+
const out = calcOBVData(pureUptrend)
|
|
52
|
+
expect(out[0]).toBe(0)
|
|
53
|
+
})
|
|
54
|
+
|
|
55
|
+
it('on pureUptrend OBV monotonically increases (every Δclose > 0 → +volume)', () => {
|
|
56
|
+
const out = calcOBVData(pureUptrend)
|
|
57
|
+
for (let t = 1; t < out.length; t++) {
|
|
58
|
+
expect(out[t]!).toBeGreaterThanOrEqual(out[t - 1]!)
|
|
59
|
+
}
|
|
60
|
+
})
|
|
61
|
+
|
|
62
|
+
it('on pureDowntrend OBV monotonically decreases', () => {
|
|
63
|
+
const out = calcOBVData(pureDowntrend)
|
|
64
|
+
for (let t = 1; t < out.length; t++) {
|
|
65
|
+
expect(out[t]!).toBeLessThanOrEqual(out[t - 1]!)
|
|
66
|
+
}
|
|
67
|
+
})
|
|
68
|
+
|
|
69
|
+
it('on constantPrice (no Δclose) OBV stays at 0', () => {
|
|
70
|
+
const out = calcOBVData(constantPrice)
|
|
71
|
+
for (const v of out) expect(v).toBe(0)
|
|
72
|
+
})
|
|
73
|
+
|
|
74
|
+
it('extensional consistency on spike fixture', () => {
|
|
75
|
+
const full = calcOBVData(spikeAtBar19)
|
|
76
|
+
for (let n = 5; n < spikeAtBar19.length; n++) {
|
|
77
|
+
const partial = calcOBVData(spikeAtBar19.slice(0, n))
|
|
78
|
+
for (let i = 0; i < n; i++) {
|
|
79
|
+
expect(partial[i]).toBe(full[i])
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
})
|
|
83
|
+
})
|
|
84
|
+
|
|
85
|
+
describe('calcPVTData', () => {
|
|
86
|
+
it('empty returns empty', () => {
|
|
87
|
+
expect(calcPVTData(empty)).toEqual([])
|
|
88
|
+
})
|
|
89
|
+
|
|
90
|
+
it('starts at 0', () => {
|
|
91
|
+
expect(calcPVTData(pureUptrend)[0]).toBe(0)
|
|
92
|
+
})
|
|
93
|
+
|
|
94
|
+
it('on constantPrice PVT stays at 0', () => {
|
|
95
|
+
const out = calcPVTData(constantPrice)
|
|
96
|
+
for (const v of out) expect(v).toBe(0)
|
|
97
|
+
})
|
|
98
|
+
|
|
99
|
+
it('on pureUptrend PVT monotonically increases', () => {
|
|
100
|
+
const out = calcPVTData(pureUptrend)
|
|
101
|
+
for (let t = 1; t < out.length; t++) {
|
|
102
|
+
expect(out[t]!).toBeGreaterThanOrEqual(out[t - 1]!)
|
|
103
|
+
}
|
|
104
|
+
})
|
|
105
|
+
|
|
106
|
+
it('extensional consistency', () => {
|
|
107
|
+
const full = calcPVTData(sideways)
|
|
108
|
+
for (let n = 5; n < sideways.length; n++) {
|
|
109
|
+
const partial = calcPVTData(sideways.slice(0, n))
|
|
110
|
+
for (let i = 0; i < n; i++) {
|
|
111
|
+
expect(partial[i]).toBeCloseTo(full[i]!, 9)
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
})
|
|
115
|
+
})
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest'
|
|
2
|
+
import { calcVolumeProfileData } from '../calculators'
|
|
3
|
+
import {
|
|
4
|
+
empty,
|
|
5
|
+
constantPrice,
|
|
6
|
+
pureUptrend,
|
|
7
|
+
sideways,
|
|
8
|
+
spikeAtBar19,
|
|
9
|
+
} from './__fixtures__/synthetic'
|
|
10
|
+
|
|
11
|
+
describe('calcVolumeProfileData', () => {
|
|
12
|
+
it('empty returns empty profile', () => {
|
|
13
|
+
const result = calcVolumeProfileData(empty, 24, 0, 0.7)
|
|
14
|
+
expect(result.bins).toEqual([])
|
|
15
|
+
expect(result.totalVolume).toBe(0)
|
|
16
|
+
})
|
|
17
|
+
|
|
18
|
+
it('bins <= 0 returns empty', () => {
|
|
19
|
+
const result = calcVolumeProfileData(pureUptrend, 0, 0, 0.7)
|
|
20
|
+
expect(result.bins).toEqual([])
|
|
21
|
+
})
|
|
22
|
+
|
|
23
|
+
it('on constantPrice (H=L=100): degenerate range → empty bins (no meaningful distribution)', () => {
|
|
24
|
+
const result = calcVolumeProfileData(constantPrice, 10, 0, 0.7)
|
|
25
|
+
// When priceMax === priceMin, the binning has no range; the function returns empty bins
|
|
26
|
+
expect(result.bins).toEqual([])
|
|
27
|
+
expect(result.totalVolume).toBe(0)
|
|
28
|
+
})
|
|
29
|
+
|
|
30
|
+
it('on pureUptrend: total volume = sum of bar volumes', () => {
|
|
31
|
+
const result = calcVolumeProfileData(pureUptrend, 24, 0, 0.7)
|
|
32
|
+
let expectedTotal = 0
|
|
33
|
+
for (const bar of pureUptrend) expectedTotal += bar.volume ?? 0
|
|
34
|
+
expect(result.totalVolume).toBeCloseTo(expectedTotal, 6)
|
|
35
|
+
})
|
|
36
|
+
|
|
37
|
+
it('POC is within [val, vah] (value area contains POC)', () => {
|
|
38
|
+
for (const fx of [pureUptrend, sideways, spikeAtBar19]) {
|
|
39
|
+
const result = calcVolumeProfileData(fx, 20, 0, 0.7)
|
|
40
|
+
if (result.bins.length === 0) continue
|
|
41
|
+
expect(result.poc).toBeGreaterThanOrEqual(result.val)
|
|
42
|
+
expect(result.poc).toBeLessThanOrEqual(result.vah)
|
|
43
|
+
}
|
|
44
|
+
})
|
|
45
|
+
|
|
46
|
+
it('VAH >= VAL invariant', () => {
|
|
47
|
+
for (const fx of [pureUptrend, sideways, spikeAtBar19]) {
|
|
48
|
+
const result = calcVolumeProfileData(fx, 20, 0, 0.7)
|
|
49
|
+
expect(result.vah).toBeGreaterThanOrEqual(result.val)
|
|
50
|
+
}
|
|
51
|
+
})
|
|
52
|
+
|
|
53
|
+
it('value area sums to >= valueAreaPercent of total volume', () => {
|
|
54
|
+
const result = calcVolumeProfileData(pureUptrend, 20, 0, 0.7)
|
|
55
|
+
const vaVolume = result.bins
|
|
56
|
+
.filter((b) => b.priceLow >= result.val - 1e-9 && b.priceHigh <= result.vah + 1e-9)
|
|
57
|
+
.reduce((a, b) => a + b.volume, 0)
|
|
58
|
+
expect(vaVolume).toBeGreaterThanOrEqual(result.totalVolume * 0.7 - 1e-6)
|
|
59
|
+
})
|
|
60
|
+
|
|
61
|
+
it('bins cover [priceMin, priceMax] contiguously', () => {
|
|
62
|
+
const result = calcVolumeProfileData(pureUptrend, 20, 0, 0.7)
|
|
63
|
+
for (let i = 1; i < result.bins.length; i++) {
|
|
64
|
+
expect(result.bins[i]!.priceLow).toBeCloseTo(result.bins[i - 1]!.priceHigh, 9)
|
|
65
|
+
}
|
|
66
|
+
})
|
|
67
|
+
|
|
68
|
+
it('lookback limits the data window', () => {
|
|
69
|
+
const full = calcVolumeProfileData(pureUptrend, 20, 0, 0.7)
|
|
70
|
+
const last10 = calcVolumeProfileData(pureUptrend, 20, 10, 0.7)
|
|
71
|
+
// Lookback should use less data → lower total volume
|
|
72
|
+
expect(last10.totalVolume).toBeLessThan(full.totalVolume)
|
|
73
|
+
})
|
|
74
|
+
})
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest'
|
|
2
|
+
import { calcVWAPData } from '../calculators'
|
|
3
|
+
import {
|
|
4
|
+
empty,
|
|
5
|
+
constantPrice,
|
|
6
|
+
pureUptrend,
|
|
7
|
+
pureDowntrend,
|
|
8
|
+
sideways,
|
|
9
|
+
spikeAtBar19,
|
|
10
|
+
} from './__fixtures__/synthetic'
|
|
11
|
+
|
|
12
|
+
describe('calcVWAPData', () => {
|
|
13
|
+
it('empty returns empty', () => {
|
|
14
|
+
expect(calcVWAPData(empty, 0)).toEqual([])
|
|
15
|
+
})
|
|
16
|
+
|
|
17
|
+
it('on constantPrice (TP=100, volume=1000) VWAP = 100 throughout', () => {
|
|
18
|
+
const out = calcVWAPData(constantPrice, 0)
|
|
19
|
+
for (const v of out) expect(v).toBeCloseTo(100, 9)
|
|
20
|
+
})
|
|
21
|
+
|
|
22
|
+
it('VWAP between min low and max high of cumulative window', () => {
|
|
23
|
+
for (const fx of [pureUptrend, pureDowntrend, sideways, spikeAtBar19]) {
|
|
24
|
+
const out = calcVWAPData(fx, 0)
|
|
25
|
+
for (let t = 0; t < out.length; t++) {
|
|
26
|
+
const v = out[t]
|
|
27
|
+
if (v === undefined) continue
|
|
28
|
+
let cumLo = Infinity
|
|
29
|
+
let cumHi = -Infinity
|
|
30
|
+
for (let i = 0; i <= t; i++) {
|
|
31
|
+
if (fx[i]!.low < cumLo) cumLo = fx[i]!.low
|
|
32
|
+
if (fx[i]!.high > cumHi) cumHi = fx[i]!.high
|
|
33
|
+
}
|
|
34
|
+
expect(v).toBeGreaterThanOrEqual(cumLo - 1e-9)
|
|
35
|
+
expect(v).toBeLessThanOrEqual(cumHi + 1e-9)
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
})
|
|
39
|
+
|
|
40
|
+
it('on pureUptrend VWAP monotonically increases (each new TP > running average)', () => {
|
|
41
|
+
const out = calcVWAPData(pureUptrend, 0)
|
|
42
|
+
for (let t = 1; t < out.length; t++) {
|
|
43
|
+
expect(out[t]!).toBeGreaterThan(out[t - 1]!)
|
|
44
|
+
}
|
|
45
|
+
})
|
|
46
|
+
|
|
47
|
+
it('session reset triggers when gap exceeds threshold', () => {
|
|
48
|
+
// Construct data with a big timestamp gap to trigger reset
|
|
49
|
+
const HOUR_MS = 3_600_000
|
|
50
|
+
const data = pureUptrend.map((bar, i) => ({
|
|
51
|
+
...bar,
|
|
52
|
+
timestamp: bar.timestamp + (i >= 15 ? 24 * HOUR_MS : 0), // 15-bar gap day-jump
|
|
53
|
+
}))
|
|
54
|
+
const noReset = calcVWAPData(data, 0)
|
|
55
|
+
const withReset = calcVWAPData(data, 12 * HOUR_MS)
|
|
56
|
+
// After reset, VWAP at bar 15+ should be different from no-reset version
|
|
57
|
+
expect(withReset[15]).not.toBeCloseTo(noReset[15]!, 6)
|
|
58
|
+
})
|
|
59
|
+
|
|
60
|
+
it('extensional consistency', () => {
|
|
61
|
+
const full = calcVWAPData(pureUptrend, 0)
|
|
62
|
+
for (let n = 5; n < pureUptrend.length; n++) {
|
|
63
|
+
const partial = calcVWAPData(pureUptrend.slice(0, n), 0)
|
|
64
|
+
for (let i = 0; i < n; i++) {
|
|
65
|
+
expect(partial[i]).toBeCloseTo(full[i]!, 9)
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
})
|
|
69
|
+
})
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest'
|
|
2
|
+
import { calcWMAData } from '../calculators'
|
|
3
|
+
import {
|
|
4
|
+
empty,
|
|
5
|
+
singleBar,
|
|
6
|
+
shortSequence,
|
|
7
|
+
constantPrice,
|
|
8
|
+
pureUptrend,
|
|
9
|
+
pureDowntrend,
|
|
10
|
+
sideways,
|
|
11
|
+
spikeAtBar19,
|
|
12
|
+
} from './__fixtures__/synthetic'
|
|
13
|
+
import { WMA_GOLDEN, assertSeriesClose } from './__fixtures__/golden'
|
|
14
|
+
import {
|
|
15
|
+
assertFiniteOrUndefined,
|
|
16
|
+
assertWarmupThenDefined,
|
|
17
|
+
} from './_propertyAssertions'
|
|
18
|
+
|
|
19
|
+
describe('calcWMAData — Linear-weighted moving average', () => {
|
|
20
|
+
describe('edge cases', () => {
|
|
21
|
+
it('empty returns empty array', () => {
|
|
22
|
+
expect(calcWMAData(empty, 9)).toEqual([])
|
|
23
|
+
})
|
|
24
|
+
|
|
25
|
+
it('single bar with period 9 returns [undefined]', () => {
|
|
26
|
+
expect(calcWMAData(singleBar, 9)).toEqual([undefined])
|
|
27
|
+
})
|
|
28
|
+
|
|
29
|
+
it('shorter than period returns all undefined', () => {
|
|
30
|
+
const out = calcWMAData(shortSequence, 9)
|
|
31
|
+
expect(out).toHaveLength(shortSequence.length)
|
|
32
|
+
for (const v of out) expect(v).toBeUndefined()
|
|
33
|
+
})
|
|
34
|
+
|
|
35
|
+
it('period = 0 or negative returns all undefined', () => {
|
|
36
|
+
const zero = calcWMAData(pureUptrend, 0)
|
|
37
|
+
for (const v of zero) expect(v).toBeUndefined()
|
|
38
|
+
const neg = calcWMAData(pureUptrend, -3)
|
|
39
|
+
for (const v of neg) expect(v).toBeUndefined()
|
|
40
|
+
})
|
|
41
|
+
|
|
42
|
+
it('period = 1 reproduces close[t] exactly', () => {
|
|
43
|
+
const out = calcWMAData(pureUptrend, 1)
|
|
44
|
+
for (let i = 0; i < out.length; i++) {
|
|
45
|
+
expect(out[i]).toBeCloseTo(pureUptrend[i]!.close, 12)
|
|
46
|
+
}
|
|
47
|
+
})
|
|
48
|
+
})
|
|
49
|
+
|
|
50
|
+
describe('golden values', () => {
|
|
51
|
+
it('constantPrice → WMA(9) equals 100 after warm-up', () => {
|
|
52
|
+
assertSeriesClose(calcWMAData(constantPrice, 9), WMA_GOLDEN.constantPrice!.series)
|
|
53
|
+
})
|
|
54
|
+
|
|
55
|
+
it('pureUptrend → WMA(9) matches closed-form derivation', () => {
|
|
56
|
+
assertSeriesClose(calcWMAData(pureUptrend, 9), WMA_GOLDEN.pureUptrend!.series)
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
|
|
60
|
+
describe('mathematical properties', () => {
|
|
61
|
+
it('warm-up region exactly [0, period-1)', () => {
|
|
62
|
+
assertWarmupThenDefined(calcWMAData(pureUptrend, 9), 8, 'WMA(9) pureUptrend')
|
|
63
|
+
})
|
|
64
|
+
|
|
65
|
+
it('all values finite (or undefined in warm-up)', () => {
|
|
66
|
+
for (const fx of [pureUptrend, pureDowntrend, sideways, spikeAtBar19]) {
|
|
67
|
+
assertFiniteOrUndefined(calcWMAData(fx, 9), 'WMA series')
|
|
68
|
+
}
|
|
69
|
+
})
|
|
70
|
+
|
|
71
|
+
it('downtrend WMA mirrors uptrend WMA around the center value', () => {
|
|
72
|
+
// pureUptrend close = 100+i, pureDowntrend close = 200-i
|
|
73
|
+
// sum of corresponding closes = 300 for all i → WMA up + WMA down = 300
|
|
74
|
+
const up = calcWMAData(pureUptrend, 9)
|
|
75
|
+
const dn = calcWMAData(pureDowntrend, 9)
|
|
76
|
+
for (let i = 0; i < up.length; i++) {
|
|
77
|
+
if (up[i] === undefined) {
|
|
78
|
+
expect(dn[i]).toBeUndefined()
|
|
79
|
+
} else {
|
|
80
|
+
expect(up[i]! + dn[i]!).toBeCloseTo(300, 9)
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
})
|
|
84
|
+
|
|
85
|
+
it('WMA lag on linear input equals (period-1)/3', () => {
|
|
86
|
+
// For close = 100+t, WMA(period)(t) = (100+t) - (period-1)/3 at steady state
|
|
87
|
+
const period = 9
|
|
88
|
+
const out = calcWMAData(pureUptrend, period)
|
|
89
|
+
const lag = (period - 1) / 3
|
|
90
|
+
for (let t = period - 1; t < out.length; t++) {
|
|
91
|
+
const expected = 100 + t - lag
|
|
92
|
+
expect(out[t]!).toBeCloseTo(expected, 9)
|
|
93
|
+
}
|
|
94
|
+
})
|
|
95
|
+
})
|
|
96
|
+
|
|
97
|
+
describe('extensional consistency', () => {
|
|
98
|
+
it('extending data preserves earlier WMA values', () => {
|
|
99
|
+
for (let n = 9; n < pureUptrend.length; n++) {
|
|
100
|
+
const prefix = calcWMAData(pureUptrend.slice(0, n), 9)
|
|
101
|
+
const extended = calcWMAData(pureUptrend.slice(0, n + 1), 9)
|
|
102
|
+
for (let i = 0; i < prefix.length; i++) {
|
|
103
|
+
if (prefix[i] === undefined) {
|
|
104
|
+
expect(extended[i]).toBeUndefined()
|
|
105
|
+
} else {
|
|
106
|
+
expect(extended[i]).toBeCloseTo(prefix[i]!, 12)
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
})
|
|
111
|
+
})
|
|
112
|
+
})
|