@forgecharts/sdk 1.1.27 → 1.1.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/__tests__/backwardCompatibility.test.d.ts +14 -0
- package/dist/__tests__/backwardCompatibility.test.d.ts.map +1 -0
- package/dist/__tests__/backwardCompatibility.test.js +159 -0
- package/dist/__tests__/backwardCompatibility.test.js.map +1 -0
- package/dist/__tests__/candleInvariant.test.d.ts +20 -0
- package/dist/__tests__/candleInvariant.test.d.ts.map +1 -0
- package/dist/__tests__/candleInvariant.test.js +415 -0
- package/dist/__tests__/candleInvariant.test.js.map +1 -0
- package/dist/__tests__/public-api-surface.d.ts +13 -0
- package/dist/__tests__/public-api-surface.d.ts.map +1 -0
- package/{src/__tests__/public-api-surface.ts → dist/__tests__/public-api-surface.js} +4 -42
- package/dist/__tests__/public-api-surface.js.map +1 -0
- package/dist/__tests__/timeframeBoundary.test.d.ts +17 -0
- package/dist/__tests__/timeframeBoundary.test.d.ts.map +1 -0
- package/dist/__tests__/timeframeBoundary.test.js +452 -0
- package/dist/__tests__/timeframeBoundary.test.js.map +1 -0
- package/dist/api/DrawingManager.d.ts +20 -0
- package/dist/api/DrawingManager.d.ts.map +1 -0
- package/dist/api/DrawingManager.js +190 -0
- package/dist/api/DrawingManager.js.map +1 -0
- package/dist/api/EventBus.d.ts +19 -0
- package/dist/api/EventBus.d.ts.map +1 -0
- package/dist/api/EventBus.js +44 -0
- package/dist/api/EventBus.js.map +1 -0
- package/dist/api/IndicatorDAG.d.ts +85 -0
- package/dist/api/IndicatorDAG.d.ts.map +1 -0
- package/dist/api/IndicatorDAG.js +316 -0
- package/dist/api/IndicatorDAG.js.map +1 -0
- package/dist/api/IndicatorRegistry.d.ts +22 -0
- package/dist/api/IndicatorRegistry.d.ts.map +1 -0
- package/dist/api/IndicatorRegistry.js +39 -0
- package/dist/api/IndicatorRegistry.js.map +1 -0
- package/dist/api/LayoutManager.d.ts +30 -0
- package/dist/api/LayoutManager.d.ts.map +1 -0
- package/dist/api/LayoutManager.js +51 -0
- package/dist/api/LayoutManager.js.map +1 -0
- package/dist/api/PaneManager.d.ts +42 -0
- package/dist/api/PaneManager.d.ts.map +1 -0
- package/dist/api/PaneManager.js +119 -0
- package/dist/api/PaneManager.js.map +1 -0
- package/dist/api/ReferenceAPI.d.ts +78 -0
- package/dist/api/ReferenceAPI.d.ts.map +1 -0
- package/dist/api/ReferenceAPI.js +153 -0
- package/dist/api/ReferenceAPI.js.map +1 -0
- package/dist/api/TChart.d.ts +345 -0
- package/dist/api/TChart.d.ts.map +1 -0
- package/dist/api/TChart.js +765 -0
- package/dist/api/TChart.js.map +1 -0
- package/{src/api/createChart.ts → dist/api/createChart.d.ts} +2 -7
- package/dist/api/createChart.d.ts.map +1 -0
- package/dist/api/createChart.js +42 -0
- package/dist/api/createChart.js.map +1 -0
- package/dist/api/drawing tools/fib gann menu/fibRetracement.d.ts +4 -0
- package/dist/api/drawing tools/fib gann menu/fibRetracement.d.ts.map +1 -0
- package/dist/api/drawing tools/fib gann menu/fibRetracement.js +22 -0
- package/dist/api/drawing tools/fib gann menu/fibRetracement.js.map +1 -0
- package/dist/api/drawing tools/lines menu/crossLine.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/crossLine.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/crossLine.js +16 -0
- package/dist/api/drawing tools/lines menu/crossLine.js.map +1 -0
- package/dist/api/drawing tools/lines menu/disjointChannel.d.ts +17 -0
- package/dist/api/drawing tools/lines menu/disjointChannel.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/disjointChannel.js +59 -0
- package/dist/api/drawing tools/lines menu/disjointChannel.js.map +1 -0
- package/dist/api/drawing tools/lines menu/extendedLine.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/extendedLine.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/extendedLine.js +17 -0
- package/dist/api/drawing tools/lines menu/extendedLine.js.map +1 -0
- package/dist/api/drawing tools/lines menu/flatTopBottom.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/flatTopBottom.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/flatTopBottom.js +41 -0
- package/dist/api/drawing tools/lines menu/flatTopBottom.js.map +1 -0
- package/dist/api/drawing tools/lines menu/horizontal.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/horizontal.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/horizontal.js +19 -0
- package/dist/api/drawing tools/lines menu/horizontal.js.map +1 -0
- package/dist/api/drawing tools/lines menu/horizontalRay.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/horizontalRay.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/horizontalRay.js +20 -0
- package/dist/api/drawing tools/lines menu/horizontalRay.js.map +1 -0
- package/dist/api/drawing tools/lines menu/infoLine.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/infoLine.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/infoLine.js +107 -0
- package/dist/api/drawing tools/lines menu/infoLine.js.map +1 -0
- package/dist/api/drawing tools/lines menu/insidePitchfork.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/insidePitchfork.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/insidePitchfork.js +31 -0
- package/dist/api/drawing tools/lines menu/insidePitchfork.js.map +1 -0
- package/dist/api/drawing tools/lines menu/modifiedSchiffPitchfork.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/modifiedSchiffPitchfork.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/modifiedSchiffPitchfork.js +15 -0
- package/dist/api/drawing tools/lines menu/modifiedSchiffPitchfork.js.map +1 -0
- package/dist/api/drawing tools/lines menu/parallelChannel.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/parallelChannel.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/parallelChannel.js +43 -0
- package/dist/api/drawing tools/lines menu/parallelChannel.js.map +1 -0
- package/dist/api/drawing tools/lines menu/pitchfork.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/pitchfork.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/pitchfork.js +12 -0
- package/dist/api/drawing tools/lines menu/pitchfork.js.map +1 -0
- package/dist/api/drawing tools/lines menu/ray.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/ray.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/ray.js +23 -0
- package/dist/api/drawing tools/lines menu/ray.js.map +1 -0
- package/dist/api/drawing tools/lines menu/regressionTrend.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/regressionTrend.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/regressionTrend.js +127 -0
- package/dist/api/drawing tools/lines menu/regressionTrend.js.map +1 -0
- package/dist/api/drawing tools/lines menu/schiffPitchfork.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/schiffPitchfork.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/schiffPitchfork.js +15 -0
- package/dist/api/drawing tools/lines menu/schiffPitchfork.js.map +1 -0
- package/dist/api/drawing tools/lines menu/trendAngle.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/trendAngle.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/trendAngle.js +51 -0
- package/dist/api/drawing tools/lines menu/trendAngle.js.map +1 -0
- package/dist/api/drawing tools/lines menu/trendline.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/trendline.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/trendline.js +11 -0
- package/dist/api/drawing tools/lines menu/trendline.js.map +1 -0
- package/dist/api/drawing tools/lines menu/vertical.d.ts +4 -0
- package/dist/api/drawing tools/lines menu/vertical.d.ts.map +1 -0
- package/dist/api/drawing tools/lines menu/vertical.js +11 -0
- package/dist/api/drawing tools/lines menu/vertical.js.map +1 -0
- package/dist/api/drawing tools/pointers menu/crosshair.d.ts +16 -0
- package/dist/api/drawing tools/pointers menu/crosshair.d.ts.map +1 -0
- package/{src/api/drawing tools/pointers menu/crosshair.ts → dist/api/drawing tools/pointers menu/crosshair.js } +6 -7
- package/dist/api/drawing tools/pointers menu/crosshair.js.map +1 -0
- package/dist/api/drawing tools/pointers menu/cursor.d.ts +15 -0
- package/dist/api/drawing tools/pointers menu/cursor.d.ts.map +1 -0
- package/{src/api/drawing tools/pointers menu/cursor.ts → dist/api/drawing tools/pointers menu/cursor.js } +7 -8
- package/dist/api/drawing tools/pointers menu/cursor.js.map +1 -0
- package/dist/api/drawing tools/pointers menu/demonstration.d.ts +30 -0
- package/dist/api/drawing tools/pointers menu/demonstration.d.ts.map +1 -0
- package/{src/api/drawing tools/pointers menu/demonstration.ts → dist/api/drawing tools/pointers menu/demonstration.js } +9 -14
- package/dist/api/drawing tools/pointers menu/demonstration.js.map +1 -0
- package/dist/api/drawing tools/pointers menu/dot.d.ts +23 -0
- package/dist/api/drawing tools/pointers menu/dot.d.ts.map +1 -0
- package/{src/api/drawing tools/pointers menu/dot.ts → dist/api/drawing tools/pointers menu/dot.js } +8 -11
- package/dist/api/drawing tools/pointers menu/dot.js.map +1 -0
- package/dist/api/drawing tools/shapes menu/rectangle.d.ts +4 -0
- package/dist/api/drawing tools/shapes menu/rectangle.d.ts.map +1 -0
- package/dist/api/drawing tools/shapes menu/rectangle.js +19 -0
- package/dist/api/drawing tools/shapes menu/rectangle.js.map +1 -0
- package/dist/api/drawing tools/shapes menu/text.d.ts +4 -0
- package/dist/api/drawing tools/shapes menu/text.d.ts.map +1 -0
- package/dist/api/drawing tools/shapes menu/text.js +25 -0
- package/dist/api/drawing tools/shapes menu/text.js.map +1 -0
- package/dist/api/drawingUtils.d.ts +22 -0
- package/dist/api/drawingUtils.d.ts.map +1 -0
- package/dist/api/drawingUtils.js +83 -0
- package/dist/api/drawingUtils.js.map +1 -0
- package/dist/core/CanvasLayer.d.ts +26 -0
- package/dist/core/CanvasLayer.d.ts.map +1 -0
- package/dist/core/CanvasLayer.js +56 -0
- package/dist/core/CanvasLayer.js.map +1 -0
- package/dist/core/Chart.d.ts +164 -0
- package/dist/core/Chart.d.ts.map +1 -0
- package/dist/core/Chart.js +839 -0
- package/dist/core/Chart.js.map +1 -0
- package/dist/core/CoordTransform.d.ts +168 -0
- package/dist/core/CoordTransform.d.ts.map +1 -0
- package/dist/core/CoordTransform.js +224 -0
- package/dist/core/CoordTransform.js.map +1 -0
- package/dist/core/Crosshair.d.ts +30 -0
- package/dist/core/Crosshair.d.ts.map +1 -0
- package/dist/core/Crosshair.js +186 -0
- package/dist/core/Crosshair.js.map +1 -0
- package/dist/core/IndicatorEngine.d.ts +51 -0
- package/dist/core/IndicatorEngine.d.ts.map +1 -0
- package/dist/core/IndicatorEngine.js +181 -0
- package/dist/core/IndicatorEngine.js.map +1 -0
- package/dist/core/InteractionManager.d.ts +197 -0
- package/dist/core/InteractionManager.d.ts.map +1 -0
- package/dist/core/InteractionManager.js +698 -0
- package/dist/core/InteractionManager.js.map +1 -0
- package/dist/core/PriceScale.d.ts +27 -0
- package/dist/core/PriceScale.d.ts.map +1 -0
- package/dist/core/PriceScale.js +113 -0
- package/dist/core/PriceScale.js.map +1 -0
- package/dist/core/Series.d.ts +40 -0
- package/dist/core/Series.d.ts.map +1 -0
- package/dist/core/Series.js +114 -0
- package/dist/core/Series.js.map +1 -0
- package/dist/core/TimeScale.d.ts +43 -0
- package/dist/core/TimeScale.d.ts.map +1 -0
- package/dist/core/TimeScale.js +150 -0
- package/dist/core/TimeScale.js.map +1 -0
- package/dist/datafeed/DatafeedConnector.d.ts +89 -0
- package/dist/datafeed/DatafeedConnector.d.ts.map +1 -0
- package/dist/datafeed/DatafeedConnector.js +268 -0
- package/dist/datafeed/DatafeedConnector.js.map +1 -0
- package/dist/engine/CandleEngine.d.ts +207 -0
- package/dist/engine/CandleEngine.d.ts.map +1 -0
- package/dist/engine/CandleEngine.js +318 -0
- package/dist/engine/CandleEngine.js.map +1 -0
- package/dist/engine/__tests__/CandleEngine.test.d.ts +2 -0
- package/dist/engine/__tests__/CandleEngine.test.d.ts.map +1 -0
- package/dist/engine/__tests__/CandleEngine.test.js +300 -0
- package/dist/engine/__tests__/CandleEngine.test.js.map +1 -0
- package/dist/engine/candleInvariants.d.ts +66 -0
- package/dist/engine/candleInvariants.d.ts.map +1 -0
- package/dist/engine/candleInvariants.js +134 -0
- package/dist/engine/candleInvariants.js.map +1 -0
- package/{src/engine/mergeUtils.ts → dist/engine/mergeUtils.d.ts} +15 -52
- package/dist/engine/mergeUtils.d.ts.map +1 -0
- package/dist/engine/mergeUtils.js +64 -0
- package/dist/engine/mergeUtils.js.map +1 -0
- package/dist/engine/timeframeUtils.d.ts +80 -0
- package/dist/engine/timeframeUtils.d.ts.map +1 -0
- package/{src/engine/timeframeUtils.ts → dist/engine/timeframeUtils.js} +30 -48
- package/dist/engine/timeframeUtils.js.map +1 -0
- package/dist/index.d.ts +40 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +49 -0
- package/dist/index.js.map +1 -0
- package/dist/internal.d.ts +29 -0
- package/dist/internal.d.ts.map +1 -0
- package/{src/internal.ts → dist/internal.js} +1 -10
- package/dist/internal.js.map +1 -0
- package/dist/licensing/ChartRuntimeResolver.d.ts +233 -0
- package/dist/licensing/ChartRuntimeResolver.d.ts.map +1 -0
- package/dist/licensing/ChartRuntimeResolver.js +310 -0
- package/dist/licensing/ChartRuntimeResolver.js.map +1 -0
- package/dist/licensing/LicenseManager.d.ts +55 -0
- package/dist/licensing/LicenseManager.d.ts.map +1 -0
- package/dist/licensing/LicenseManager.js +114 -0
- package/dist/licensing/LicenseManager.js.map +1 -0
- package/dist/licensing/__tests__/ChartRuntimeResolver.test.d.ts +13 -0
- package/dist/licensing/__tests__/ChartRuntimeResolver.test.d.ts.map +1 -0
- package/dist/licensing/__tests__/ChartRuntimeResolver.test.js +177 -0
- package/dist/licensing/__tests__/ChartRuntimeResolver.test.js.map +1 -0
- package/dist/licensing/__tests__/LicenseManager.test.d.ts +12 -0
- package/dist/licensing/__tests__/LicenseManager.test.d.ts.map +1 -0
- package/dist/licensing/__tests__/LicenseManager.test.js +153 -0
- package/dist/licensing/__tests__/LicenseManager.test.js.map +1 -0
- package/dist/licensing/licenseTypes.d.ts +18 -0
- package/dist/licensing/licenseTypes.d.ts.map +1 -0
- package/dist/licensing/licenseTypes.js +2 -0
- package/dist/licensing/licenseTypes.js.map +1 -0
- package/dist/pine/PineCompiler.d.ts +35 -0
- package/dist/pine/PineCompiler.d.ts.map +1 -0
- package/dist/pine/PineCompiler.js +44 -0
- package/dist/pine/PineCompiler.js.map +1 -0
- package/dist/pine/diagnostics.d.ts +20 -0
- package/dist/pine/diagnostics.d.ts.map +1 -0
- package/dist/pine/diagnostics.js +11 -0
- package/dist/pine/diagnostics.js.map +1 -0
- package/{src/pine/index.ts → dist/pine/index.d.ts} +4 -3
- package/dist/pine/index.d.ts.map +1 -0
- package/dist/pine/index.js +5 -0
- package/dist/pine/index.js.map +1 -0
- package/dist/pine/pine-ast.d.ts +142 -0
- package/dist/pine/pine-ast.d.ts.map +1 -0
- package/dist/pine/pine-ast.js +19 -0
- package/dist/pine/pine-ast.js.map +1 -0
- package/dist/pine/pine-lexer.d.ts +41 -0
- package/dist/pine/pine-lexer.d.ts.map +1 -0
- package/dist/pine/pine-lexer.js +249 -0
- package/dist/pine/pine-lexer.js.map +1 -0
- package/dist/pine/pine-parser.d.ts +51 -0
- package/dist/pine/pine-parser.d.ts.map +1 -0
- package/dist/pine/pine-parser.js +416 -0
- package/dist/pine/pine-parser.js.map +1 -0
- package/dist/pine/pine-transpiler.d.ts +33 -0
- package/dist/pine/pine-transpiler.d.ts.map +1 -0
- package/dist/pine/pine-transpiler.js +260 -0
- package/dist/pine/pine-transpiler.js.map +1 -0
- package/dist/pixi/LayerName.d.ts +18 -0
- package/dist/pixi/LayerName.d.ts.map +1 -0
- package/dist/pixi/LayerName.js +35 -0
- package/dist/pixi/LayerName.js.map +1 -0
- package/dist/pixi/PixiCandlestickRenderer.d.ts +23 -0
- package/dist/pixi/PixiCandlestickRenderer.d.ts.map +1 -0
- package/dist/pixi/PixiCandlestickRenderer.js +107 -0
- package/dist/pixi/PixiCandlestickRenderer.js.map +1 -0
- package/dist/pixi/PixiChart.d.ts +72 -0
- package/dist/pixi/PixiChart.d.ts.map +1 -0
- package/dist/pixi/PixiChart.js +367 -0
- package/dist/pixi/PixiChart.js.map +1 -0
- package/dist/pixi/PixiCrosshairRenderer.d.ts +29 -0
- package/dist/pixi/PixiCrosshairRenderer.d.ts.map +1 -0
- package/dist/pixi/PixiCrosshairRenderer.js +110 -0
- package/dist/pixi/PixiCrosshairRenderer.js.map +1 -0
- package/dist/pixi/PixiDrawingRenderer.d.ts +17 -0
- package/dist/pixi/PixiDrawingRenderer.d.ts.map +1 -0
- package/dist/pixi/PixiDrawingRenderer.js +111 -0
- package/dist/pixi/PixiDrawingRenderer.js.map +1 -0
- package/dist/pixi/PixiGridRenderer.d.ts +22 -0
- package/dist/pixi/PixiGridRenderer.d.ts.map +1 -0
- package/dist/pixi/PixiGridRenderer.js +114 -0
- package/dist/pixi/PixiGridRenderer.js.map +1 -0
- package/dist/pixi/PixiLayerManager.d.ts +56 -0
- package/dist/pixi/PixiLayerManager.d.ts.map +1 -0
- package/dist/pixi/PixiLayerManager.js +92 -0
- package/dist/pixi/PixiLayerManager.js.map +1 -0
- package/dist/react/canvas/ChartCanvas.d.ts +85 -0
- package/dist/react/canvas/ChartCanvas.d.ts.map +1 -0
- package/dist/react/canvas/ChartCanvas.js +604 -0
- package/dist/react/canvas/ChartCanvas.js.map +1 -0
- package/dist/react/canvas/ChartContextMenu.d.ts +18 -0
- package/dist/react/canvas/ChartContextMenu.d.ts.map +1 -0
- package/dist/react/canvas/ChartContextMenu.js +5 -0
- package/dist/react/canvas/ChartContextMenu.js.map +1 -0
- package/dist/react/canvas/ChartSettingsDialog.d.ts +25 -0
- package/dist/react/canvas/ChartSettingsDialog.d.ts.map +1 -0
- package/dist/react/canvas/ChartSettingsDialog.js +28 -0
- package/dist/react/canvas/ChartSettingsDialog.js.map +1 -0
- package/dist/react/canvas/IndicatorLabel.d.ts +21 -0
- package/dist/react/canvas/IndicatorLabel.d.ts.map +1 -0
- package/dist/react/canvas/IndicatorLabel.js +196 -0
- package/dist/react/canvas/IndicatorLabel.js.map +1 -0
- package/dist/react/canvas/IndicatorPane.d.ts +32 -0
- package/dist/react/canvas/IndicatorPane.d.ts.map +1 -0
- package/dist/react/canvas/IndicatorPane.js +395 -0
- package/dist/react/canvas/IndicatorPane.js.map +1 -0
- package/dist/react/canvas/PointerOverlay.d.ts +23 -0
- package/dist/react/canvas/PointerOverlay.d.ts.map +1 -0
- package/dist/react/canvas/PointerOverlay.js +61 -0
- package/dist/react/canvas/PointerOverlay.js.map +1 -0
- package/dist/react/canvas/toolbars/LeftToolbar.d.ts +19 -0
- package/dist/react/canvas/toolbars/LeftToolbar.d.ts.map +1 -0
- package/dist/react/canvas/toolbars/LeftToolbar.js +407 -0
- package/dist/react/canvas/toolbars/LeftToolbar.js.map +1 -0
- package/dist/react/hooks/useChartCapabilities.d.ts +21 -0
- package/dist/react/hooks/useChartCapabilities.d.ts.map +1 -0
- package/dist/react/hooks/useChartCapabilities.js +66 -0
- package/dist/react/hooks/useChartCapabilities.js.map +1 -0
- package/dist/react/index.d.ts +30 -0
- package/dist/react/index.d.ts.map +1 -0
- package/{src/react/index.ts → dist/react/index.js} +1 -24
- package/dist/react/index.js.map +1 -0
- package/dist/react/internal.d.ts +38 -0
- package/dist/react/internal.d.ts.map +1 -0
- package/{src/react/internal.ts → dist/react/internal.js} +1 -19
- package/dist/react/internal.js.map +1 -0
- package/dist/react/shell/ManagedAppShell.d.ts +91 -0
- package/dist/react/shell/ManagedAppShell.d.ts.map +1 -0
- package/dist/react/shell/ManagedAppShell.js +440 -0
- package/dist/react/shell/ManagedAppShell.js.map +1 -0
- package/dist/react/trading/TradingBridge.d.ts +86 -0
- package/dist/react/trading/TradingBridge.d.ts.map +1 -0
- package/dist/react/trading/TradingBridge.js +73 -0
- package/dist/react/trading/TradingBridge.js.map +1 -0
- package/dist/react/workspace/ChartWorkspace.d.ts +73 -0
- package/dist/react/workspace/ChartWorkspace.d.ts.map +1 -0
- package/dist/react/workspace/ChartWorkspace.js +42 -0
- package/dist/react/workspace/ChartWorkspace.js.map +1 -0
- package/dist/react/workspace/FloatingPanel.d.ts +18 -0
- package/dist/react/workspace/FloatingPanel.d.ts.map +1 -0
- package/dist/react/workspace/FloatingPanel.js +82 -0
- package/dist/react/workspace/FloatingPanel.js.map +1 -0
- package/dist/react/workspace/IndicatorsDialog.d.ts +8 -0
- package/dist/react/workspace/IndicatorsDialog.d.ts.map +1 -0
- package/dist/react/workspace/IndicatorsDialog.js +121 -0
- package/dist/react/workspace/IndicatorsDialog.js.map +1 -0
- package/dist/react/workspace/LayoutMenu.d.ts +33 -0
- package/dist/react/workspace/LayoutMenu.d.ts.map +1 -0
- package/dist/react/workspace/LayoutMenu.js +113 -0
- package/dist/react/workspace/LayoutMenu.js.map +1 -0
- package/dist/react/workspace/SymbolSearchDialog.d.ts +10 -0
- package/dist/react/workspace/SymbolSearchDialog.d.ts.map +1 -0
- package/dist/react/workspace/SymbolSearchDialog.js +245 -0
- package/dist/react/workspace/SymbolSearchDialog.js.map +1 -0
- package/dist/react/workspace/TabBar.d.ts +17 -0
- package/dist/react/workspace/TabBar.d.ts.map +1 -0
- package/dist/react/workspace/TabBar.js +29 -0
- package/dist/react/workspace/TabBar.js.map +1 -0
- package/dist/react/workspace/toolbars/BottomToolbar.d.ts +19 -0
- package/dist/react/workspace/toolbars/BottomToolbar.d.ts.map +1 -0
- package/dist/react/workspace/toolbars/BottomToolbar.js +236 -0
- package/dist/react/workspace/toolbars/BottomToolbar.js.map +1 -0
- package/dist/react/workspace/toolbars/RightToolbar.d.ts +8 -0
- package/dist/react/workspace/toolbars/RightToolbar.d.ts.map +1 -0
- package/dist/react/workspace/toolbars/RightToolbar.js +18 -0
- package/dist/react/workspace/toolbars/RightToolbar.js.map +1 -0
- package/dist/react/workspace/toolbars/TopToolbar.d.ts +41 -0
- package/dist/react/workspace/toolbars/TopToolbar.d.ts.map +1 -0
- package/dist/react/workspace/toolbars/TopToolbar.js +82 -0
- package/dist/react/workspace/toolbars/TopToolbar.js.map +1 -0
- package/dist/renderers/CandlestickRenderer.d.ts +13 -0
- package/dist/renderers/CandlestickRenderer.d.ts.map +1 -0
- package/dist/renderers/CandlestickRenderer.js +98 -0
- package/dist/renderers/CandlestickRenderer.js.map +1 -0
- package/dist/renderers/HistogramRenderer.d.ts +11 -0
- package/dist/renderers/HistogramRenderer.d.ts.map +1 -0
- package/dist/renderers/HistogramRenderer.js +50 -0
- package/dist/renderers/HistogramRenderer.js.map +1 -0
- package/dist/renderers/LineRenderer.d.ts +12 -0
- package/dist/renderers/LineRenderer.d.ts.map +1 -0
- package/dist/renderers/LineRenderer.js +64 -0
- package/dist/renderers/LineRenderer.js.map +1 -0
- package/dist/theme/colors.d.ts +4 -0
- package/dist/theme/colors.d.ts.map +1 -0
- package/dist/theme/colors.js +19 -0
- package/dist/theme/colors.js.map +1 -0
- package/dist/tools/barDivergenceCheck.d.ts +120 -0
- package/dist/tools/barDivergenceCheck.d.ts.map +1 -0
- package/dist/tools/barDivergenceCheck.js +200 -0
- package/dist/tools/barDivergenceCheck.js.map +1 -0
- package/dist/trading/TradingOverlayStore.d.ts +86 -0
- package/dist/trading/TradingOverlayStore.d.ts.map +1 -0
- package/dist/trading/TradingOverlayStore.js +139 -0
- package/dist/trading/TradingOverlayStore.js.map +1 -0
- package/dist/trading/UnmanagedIngestion.d.ts +91 -0
- package/dist/trading/UnmanagedIngestion.d.ts.map +1 -0
- package/dist/trading/UnmanagedIngestion.js +114 -0
- package/dist/trading/UnmanagedIngestion.js.map +1 -0
- package/dist/trading/__tests__/ManagedTradingController.test.d.ts +18 -0
- package/dist/trading/__tests__/ManagedTradingController.test.d.ts.map +1 -0
- package/dist/trading/__tests__/ManagedTradingController.test.js +271 -0
- package/dist/trading/__tests__/ManagedTradingController.test.js.map +1 -0
- package/dist/trading/__tests__/TradingOverlayStore.test.d.ts +16 -0
- package/dist/trading/__tests__/TradingOverlayStore.test.d.ts.map +1 -0
- package/dist/trading/__tests__/TradingOverlayStore.test.js +267 -0
- package/dist/trading/__tests__/TradingOverlayStore.test.js.map +1 -0
- package/dist/trading/__tests__/UnmanagedIngestion.test.d.ts +16 -0
- package/dist/trading/__tests__/UnmanagedIngestion.test.d.ts.map +1 -0
- package/dist/trading/__tests__/UnmanagedIngestion.test.js +170 -0
- package/dist/trading/__tests__/UnmanagedIngestion.test.js.map +1 -0
- package/dist/trading/managed/ManagedTradingController.d.ts +110 -0
- package/dist/trading/managed/ManagedTradingController.d.ts.map +1 -0
- package/dist/trading/managed/ManagedTradingController.js +247 -0
- package/dist/trading/managed/ManagedTradingController.js.map +1 -0
- package/dist/trading/managed/managedCapabilities.d.ts +45 -0
- package/dist/trading/managed/managedCapabilities.d.ts.map +1 -0
- package/dist/trading/managed/managedCapabilities.js +79 -0
- package/dist/trading/managed/managedCapabilities.js.map +1 -0
- package/dist/trading/managed/managedTypes.d.ts +122 -0
- package/dist/trading/managed/managedTypes.d.ts.map +1 -0
- package/dist/trading/managed/managedTypes.js +13 -0
- package/dist/trading/managed/managedTypes.js.map +1 -0
- package/dist/trading/tradingTypes.d.ts +89 -0
- package/dist/trading/tradingTypes.d.ts.map +1 -0
- package/dist/trading/tradingTypes.js +8 -0
- package/dist/trading/tradingTypes.js.map +1 -0
- package/dist/tscript/TScriptIndicator.d.ts +41 -0
- package/dist/tscript/TScriptIndicator.d.ts.map +1 -0
- package/dist/tscript/TScriptIndicator.js +47 -0
- package/dist/tscript/TScriptIndicator.js.map +1 -0
- package/dist/tscript/ast.d.ts +89 -0
- package/dist/tscript/ast.d.ts.map +1 -0
- package/dist/tscript/ast.js +22 -0
- package/dist/tscript/ast.js.map +1 -0
- package/dist/tscript/lexer.d.ts +36 -0
- package/dist/tscript/lexer.d.ts.map +1 -0
- package/dist/tscript/lexer.js +187 -0
- package/dist/tscript/lexer.js.map +1 -0
- package/dist/tscript/parser.d.ts +50 -0
- package/dist/tscript/parser.d.ts.map +1 -0
- package/dist/tscript/parser.js +318 -0
- package/dist/tscript/parser.js.map +1 -0
- package/dist/tscript/runtime.d.ts +123 -0
- package/dist/tscript/runtime.d.ts.map +1 -0
- package/dist/tscript/runtime.js +475 -0
- package/dist/tscript/runtime.js.map +1 -0
- package/dist/tscript/series.d.ts +49 -0
- package/dist/tscript/series.d.ts.map +1 -0
- package/dist/tscript/series.js +79 -0
- package/dist/tscript/series.js.map +1 -0
- package/dist/types/IChart.d.ts +48 -0
- package/dist/types/IChart.d.ts.map +1 -0
- package/dist/types/IChart.js +2 -0
- package/dist/types/IChart.js.map +1 -0
- package/{src/types/IRenderer.ts → dist/types/IRenderer.d.ts} +2 -8
- package/dist/types/IRenderer.d.ts.map +1 -0
- package/dist/types/IRenderer.js +2 -0
- package/dist/types/IRenderer.js.map +1 -0
- package/dist/types/ISeries.d.ts +26 -0
- package/dist/types/ISeries.d.ts.map +1 -0
- package/dist/types/ISeries.js +2 -0
- package/dist/types/ISeries.js.map +1 -0
- package/package.json +5 -1
- package/src/__tests__/backwardCompatibility.test.ts +0 -191
- package/src/__tests__/candleInvariant.test.ts +0 -500
- package/src/__tests__/timeframeBoundary.test.ts +0 -583
- package/src/api/DrawingManager.ts +0 -188
- package/src/api/EventBus.ts +0 -53
- package/src/api/IndicatorDAG.ts +0 -389
- package/src/api/IndicatorRegistry.ts +0 -47
- package/src/api/LayoutManager.ts +0 -72
- package/src/api/PaneManager.ts +0 -129
- package/src/api/ReferenceAPI.ts +0 -195
- package/src/api/TChart.ts +0 -881
- package/src/api/drawing tools/fib gann menu/fibRetracement.ts +0 -27
- package/src/api/drawing tools/lines menu/crossLine.ts +0 -21
- package/src/api/drawing tools/lines menu/disjointChannel.ts +0 -74
- package/src/api/drawing tools/lines menu/extendedLine.ts +0 -22
- package/src/api/drawing tools/lines menu/flatTopBottom.ts +0 -45
- package/src/api/drawing tools/lines menu/horizontal.ts +0 -24
- package/src/api/drawing tools/lines menu/horizontalRay.ts +0 -25
- package/src/api/drawing tools/lines menu/infoLine.ts +0 -127
- package/src/api/drawing tools/lines menu/insidePitchfork.ts +0 -21
- package/src/api/drawing tools/lines menu/modifiedSchiffPitchfork.ts +0 -18
- package/src/api/drawing tools/lines menu/parallelChannel.ts +0 -47
- package/src/api/drawing tools/lines menu/pitchfork.ts +0 -15
- package/src/api/drawing tools/lines menu/ray.ts +0 -28
- package/src/api/drawing tools/lines menu/regressionTrend.ts +0 -157
- package/src/api/drawing tools/lines menu/schiffPitchfork.ts +0 -18
- package/src/api/drawing tools/lines menu/trendAngle.ts +0 -64
- package/src/api/drawing tools/lines menu/trendline.ts +0 -16
- package/src/api/drawing tools/lines menu/vertical.ts +0 -16
- package/src/api/drawing tools/shapes menu/rectangle.ts +0 -24
- package/src/api/drawing tools/shapes menu/text.ts +0 -30
- package/src/api/drawingUtils.ts +0 -82
- package/src/core/CanvasLayer.ts +0 -77
- package/src/core/Chart.ts +0 -917
- package/src/core/CoordTransform.ts +0 -282
- package/src/core/Crosshair.ts +0 -207
- package/src/core/IndicatorEngine.ts +0 -216
- package/src/core/InteractionManager.ts +0 -899
- package/src/core/PriceScale.ts +0 -133
- package/src/core/Series.ts +0 -132
- package/src/core/TimeScale.ts +0 -175
- package/src/datafeed/DatafeedConnector.ts +0 -300
- package/src/engine/CandleEngine.ts +0 -458
- package/src/engine/__tests__/CandleEngine.test.ts +0 -402
- package/src/engine/candleInvariants.ts +0 -172
- package/src/index.ts +0 -190
- package/src/licensing/ChartRuntimeResolver.ts +0 -380
- package/src/licensing/LicenseManager.ts +0 -131
- package/src/licensing/__tests__/ChartRuntimeResolver.test.ts +0 -207
- package/src/licensing/__tests__/LicenseManager.test.ts +0 -180
- package/src/licensing/licenseTypes.ts +0 -19
- package/src/pine/PineCompiler.ts +0 -68
- package/src/pine/diagnostics.ts +0 -30
- package/src/pine/pine-ast.ts +0 -163
- package/src/pine/pine-lexer.ts +0 -265
- package/src/pine/pine-parser.ts +0 -439
- package/src/pine/pine-transpiler.ts +0 -301
- package/src/pixi/LayerName.ts +0 -35
- package/src/pixi/PixiCandlestickRenderer.ts +0 -125
- package/src/pixi/PixiChart.ts +0 -425
- package/src/pixi/PixiCrosshairRenderer.ts +0 -134
- package/src/pixi/PixiDrawingRenderer.ts +0 -121
- package/src/pixi/PixiGridRenderer.ts +0 -136
- package/src/pixi/PixiLayerManager.ts +0 -102
- package/src/react/canvas/ChartCanvas.tsx +0 -984
- package/src/react/canvas/ChartContextMenu.tsx +0 -60
- package/src/react/canvas/ChartSettingsDialog.tsx +0 -133
- package/src/react/canvas/IndicatorLabel.tsx +0 -347
- package/src/react/canvas/IndicatorPane.tsx +0 -503
- package/src/react/canvas/PointerOverlay.tsx +0 -126
- package/src/react/canvas/toolbars/LeftToolbar.tsx +0 -1096
- package/src/react/hooks/useChartCapabilities.ts +0 -76
- package/src/react/shell/ManagedAppShell.tsx +0 -699
- package/src/react/trading/TradingBridge.ts +0 -156
- package/src/react/workspace/ChartWorkspace.tsx +0 -228
- package/src/react/workspace/FloatingPanel.tsx +0 -131
- package/src/react/workspace/IndicatorsDialog.tsx +0 -246
- package/src/react/workspace/LayoutMenu.tsx +0 -345
- package/src/react/workspace/SymbolSearchDialog.tsx +0 -377
- package/src/react/workspace/TabBar.tsx +0 -87
- package/src/react/workspace/toolbars/BottomToolbar.tsx +0 -372
- package/src/react/workspace/toolbars/RightToolbar.tsx +0 -46
- package/src/react/workspace/toolbars/TopToolbar.tsx +0 -431
- package/src/renderers/CandlestickRenderer.ts +0 -130
- package/src/renderers/HistogramRenderer.ts +0 -63
- package/src/renderers/LineRenderer.ts +0 -77
- package/src/theme/colors.ts +0 -21
- package/src/tools/barDivergenceCheck.ts +0 -305
- package/src/trading/TradingOverlayStore.ts +0 -161
- package/src/trading/UnmanagedIngestion.ts +0 -156
- package/src/trading/__tests__/ManagedTradingController.test.ts +0 -338
- package/src/trading/__tests__/TradingOverlayStore.test.ts +0 -323
- package/src/trading/__tests__/UnmanagedIngestion.test.ts +0 -205
- package/src/trading/managed/ManagedTradingController.ts +0 -292
- package/src/trading/managed/managedCapabilities.ts +0 -98
- package/src/trading/managed/managedTypes.ts +0 -151
- package/src/trading/tradingTypes.ts +0 -135
- package/src/tscript/TScriptIndicator.ts +0 -54
- package/src/tscript/ast.ts +0 -105
- package/src/tscript/lexer.ts +0 -190
- package/src/tscript/parser.ts +0 -334
- package/src/tscript/runtime.ts +0 -525
- package/src/tscript/series.ts +0 -84
- package/src/types/IChart.ts +0 -56
- package/src/types/ISeries.ts +0 -30
- package/tsconfig.json +0 -23
- package/tsup.config.ts +0 -16
- package/vitest.config.ts +0 -25
|
@@ -1,156 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* UnmanagedIngestion
|
|
3
|
-
*
|
|
4
|
-
* External candle data ingestion for unmanaged mode.
|
|
5
|
-
*
|
|
6
|
-
* In unmanaged mode the client owns their data pipeline. They pass
|
|
7
|
-
* normalised candle data to us; this layer validates the license gate,
|
|
8
|
-
* delegates to the existing CandleEngine for bucket management, and
|
|
9
|
-
* notifies callers via callbacks mirroring the CandleEngine contract.
|
|
10
|
-
*
|
|
11
|
-
* Critical constraint: the default RapidAPI-backed datafeed is completely
|
|
12
|
-
* untouched. UnmanagedIngestion is an additive, opt-in path.
|
|
13
|
-
*
|
|
14
|
-
* Candle rules (matches CandleEngine behaviour):
|
|
15
|
-
* same timeMs → update current candle
|
|
16
|
-
* newer timeMs → append / new bucket
|
|
17
|
-
* older timeMs → silently ignored (logged in debug mode)
|
|
18
|
-
*
|
|
19
|
-
* @example
|
|
20
|
-
* ```ts
|
|
21
|
-
* const ingestion = new UnmanagedIngestion('1m', {
|
|
22
|
-
* onBarUpdated: (bar) => series.update(bar),
|
|
23
|
-
* onResync: (bars) => series.setData(bars),
|
|
24
|
-
* });
|
|
25
|
-
*
|
|
26
|
-
* // Feed a full history snapshot first
|
|
27
|
-
* ingestion.setHistory(historicalBars);
|
|
28
|
-
*
|
|
29
|
-
* // Then stream live ticks
|
|
30
|
-
* ingestion.pushCandle(latestBar);
|
|
31
|
-
* ```
|
|
32
|
-
*/
|
|
33
|
-
|
|
34
|
-
import { CandleEngine } from '../engine/CandleEngine';
|
|
35
|
-
import type { CandleBar, UpdateResult, GapInfo } from '../engine/CandleEngine';
|
|
36
|
-
import { isUnmanagedMode } from '../licensing/ChartRuntimeResolver';
|
|
37
|
-
import type { CandleInput } from './tradingTypes';
|
|
38
|
-
import type { Timeframe } from '@forgecharts/types';
|
|
39
|
-
|
|
40
|
-
export interface UnmanagedIngestionOptions {
|
|
41
|
-
/** Enable debug logging on the underlying CandleEngine. */
|
|
42
|
-
debug?: boolean;
|
|
43
|
-
|
|
44
|
-
/**
|
|
45
|
-
* Fired after every bar mutation (update or append from a live push).
|
|
46
|
-
* Corresponds to CandleEngine.onBarUpdated.
|
|
47
|
-
*/
|
|
48
|
-
onBarUpdated?: (bar: CandleBar, result: UpdateResult) => void;
|
|
49
|
-
|
|
50
|
-
/**
|
|
51
|
-
* Fired when the full bar array changes (after setHistory or gap backfill).
|
|
52
|
-
* The chart adapter should call `series.setData(bars)`.
|
|
53
|
-
*/
|
|
54
|
-
onResync?: (bars: readonly CandleBar[]) => void;
|
|
55
|
-
|
|
56
|
-
/** Fired when a candle bucket closes. */
|
|
57
|
-
onBarClosed?: (bar: CandleBar) => void;
|
|
58
|
-
|
|
59
|
-
/** Fired when the engine detects skipped buckets in the live stream. */
|
|
60
|
-
onGapDetected?: (info: GapInfo) => void;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
export class UnmanagedIngestion {
|
|
64
|
-
private readonly _engine: CandleEngine;
|
|
65
|
-
private readonly _opts: UnmanagedIngestionOptions;
|
|
66
|
-
private _timeframe: Timeframe;
|
|
67
|
-
|
|
68
|
-
constructor(timeframe: Timeframe, opts: UnmanagedIngestionOptions = {}) {
|
|
69
|
-
this._opts = opts;
|
|
70
|
-
this._timeframe = timeframe;
|
|
71
|
-
this._engine = new CandleEngine({
|
|
72
|
-
...(opts.debug !== undefined ? { debug: opts.debug } : {}),
|
|
73
|
-
...(opts.onBarUpdated !== undefined ? { onBarUpdated: opts.onBarUpdated } : {}),
|
|
74
|
-
...(opts.onBarClosed !== undefined ? { onBarClosed: opts.onBarClosed } : {}),
|
|
75
|
-
...(opts.onGapDetected !== undefined ? { onGapDetected: opts.onGapDetected } : {}),
|
|
76
|
-
...(opts.onResync !== undefined ? { onResync: opts.onResync } : {}),
|
|
77
|
-
});
|
|
78
|
-
// Prime the engine so it knows its timeframe before any data arrives
|
|
79
|
-
this._engine.initialize([], timeframe);
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
// ── Guard ────────────────────────────────────────────────────────────────────
|
|
83
|
-
|
|
84
|
-
private _assertUnmanaged(): void {
|
|
85
|
-
if (!isUnmanagedMode()) {
|
|
86
|
-
throw new Error(
|
|
87
|
-
'[ForgeCharts] External data ingestion is only available in unmanaged mode. ' +
|
|
88
|
-
'The active license is in managed mode.',
|
|
89
|
-
);
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
// ── History ──────────────────────────────────────────────────────────────────
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* Load a full historical bar snapshot.
|
|
97
|
-
* Replaces the engine's bar array and triggers `onResync` so the chart
|
|
98
|
-
* series is fully redrawn.
|
|
99
|
-
*
|
|
100
|
-
* Call this once at startup (or on symbol/interval change) before
|
|
101
|
-
* streaming live candles via `pushCandle`.
|
|
102
|
-
*
|
|
103
|
-
* @throws If the active license is not in unmanaged mode.
|
|
104
|
-
*/
|
|
105
|
-
setHistory(bars: CandleInput[]): void {
|
|
106
|
-
this._assertUnmanaged();
|
|
107
|
-
|
|
108
|
-
// Sort ascending — initialize expects oldest → newest
|
|
109
|
-
const sorted = [...bars].sort((a, b) => a.time - b.time);
|
|
110
|
-
this._engine.initialize(sorted, this._timeframe);
|
|
111
|
-
// CandleEngine.initialize() does not fire onResync — invoke it explicitly
|
|
112
|
-
this._opts.onResync?.(this._engine.getBars());
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
// ── Live push ────────────────────────────────────────────────────────────────
|
|
116
|
-
|
|
117
|
-
/**
|
|
118
|
-
* Push a single live candle tick.
|
|
119
|
-
*
|
|
120
|
-
* Behaviour follows CandleEngine rules:
|
|
121
|
-
* - same bucket → updates existing bar (OHLCV merging)
|
|
122
|
-
* - new bucket → appends a new bar (previous bar is finalised)
|
|
123
|
-
* - older bucket → silently ignored; debug-logged when `debug: true`
|
|
124
|
-
*
|
|
125
|
-
* @throws If the active license is not in unmanaged mode.
|
|
126
|
-
*/
|
|
127
|
-
pushCandle(bar: CandleInput): UpdateResult {
|
|
128
|
-
this._assertUnmanaged();
|
|
129
|
-
return this._engine.applyLiveUpdate(bar);
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
// ── Accessors ────────────────────────────────────────────────────────────────
|
|
133
|
-
|
|
134
|
-
/** Returns the current bar array (chronological, ascending). */
|
|
135
|
-
getBars(): readonly CandleBar[] {
|
|
136
|
-
return this._engine.getBars();
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
/** Returns the latest candle, or null if no data has been loaded. */
|
|
140
|
-
getLatestBar(): CandleBar | null {
|
|
141
|
-
const bars = this._engine.getBars();
|
|
142
|
-
return bars.length > 0 ? bars[bars.length - 1]! : null;
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
/** Changes the active timeframe and clears all bar data. */
|
|
146
|
-
setTimeframe(timeframe: Timeframe): void {
|
|
147
|
-
this._timeframe = timeframe;
|
|
148
|
-
// Re-initialise with empty history — caller must follow up with setHistory()
|
|
149
|
-
this._engine.initialize([], timeframe);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
/** Clears all bars (e.g. on symbol change before calling setHistory again). */
|
|
153
|
-
reset(): void {
|
|
154
|
-
this._engine.reset();
|
|
155
|
-
}
|
|
156
|
-
}
|
|
@@ -1,338 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ManagedTradingController — unit tests
|
|
3
|
-
*
|
|
4
|
-
* Covers:
|
|
5
|
-
* - Cannot initialize (registerProvider) in unmanaged mode
|
|
6
|
-
* - Can initialize in managed mode
|
|
7
|
-
* - isReady() reflects provider registration state
|
|
8
|
-
* - placeOrder() throws without a provider
|
|
9
|
-
* - placeOrder() with a mock provider: writes optimistic overlay entry,
|
|
10
|
-
* updates with provider id on success, rolls back on failure
|
|
11
|
-
* - cancelOrder() updates overlay status to 'cancelled'
|
|
12
|
-
* - modifyOrder() patches price / qty / label in overlay
|
|
13
|
-
* - placeBracketOrder() creates 3 orders with the same groupId in the overlay
|
|
14
|
-
* - reportFill() pushes to overlay + updates order status
|
|
15
|
-
* - All methods blocked in unmanaged mode
|
|
16
|
-
*/
|
|
17
|
-
|
|
18
|
-
import { describe, it, expect, beforeEach, afterEach, vi } from 'vitest';
|
|
19
|
-
import { LicenseManager } from '../../licensing/LicenseManager';
|
|
20
|
-
import { TradingOverlayStore } from '../TradingOverlayStore';
|
|
21
|
-
import { ManagedTradingController } from '../managed/ManagedTradingController';
|
|
22
|
-
import type { IExecutionProvider, PlaceOrderInput, PlaceBracketOrderInput } from '../managed/managedTypes';
|
|
23
|
-
import type { ExecutionFill } from '../tradingTypes';
|
|
24
|
-
|
|
25
|
-
// ─── License helpers ──────────────────────────────────────────────────────────
|
|
26
|
-
|
|
27
|
-
function installManaged() {
|
|
28
|
-
LicenseManager.getInstance().loadLicense({ licenseKey: 'm', mode: 'managed' });
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
function installUnmanaged() {
|
|
32
|
-
LicenseManager.getInstance().loadLicense({ licenseKey: 'u', mode: 'unmanaged' });
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
function clearLicense() {
|
|
36
|
-
LicenseManager.getInstance().clear();
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
// ─── Mock provider factory ────────────────────────────────────────────────────
|
|
40
|
-
|
|
41
|
-
function makeMockProvider(overrides: Partial<IExecutionProvider> = {}): IExecutionProvider {
|
|
42
|
-
return {
|
|
43
|
-
providerId: 'mock-provider',
|
|
44
|
-
placeOrder: vi.fn().mockResolvedValue({ orderId: 'prov-001', status: 'open' }),
|
|
45
|
-
cancelOrder: vi.fn().mockResolvedValue(undefined),
|
|
46
|
-
modifyOrder: vi.fn().mockResolvedValue({ orderId: 'prov-001', status: 'open' }),
|
|
47
|
-
placeBracketOrder: vi.fn().mockResolvedValue({
|
|
48
|
-
entry: { orderId: 'prov-entry', timestamp: 1000 },
|
|
49
|
-
stopLoss: { orderId: 'prov-sl', timestamp: 1000 },
|
|
50
|
-
takeProfit: { orderId: 'prov-tp', timestamp: 1000 },
|
|
51
|
-
groupId: 'bracket-test',
|
|
52
|
-
}),
|
|
53
|
-
...overrides,
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
function makeOrderInput(overrides: Partial<PlaceOrderInput> = {}): PlaceOrderInput {
|
|
58
|
-
return {
|
|
59
|
-
symbol: 'BTCUSDT',
|
|
60
|
-
side: 'buy',
|
|
61
|
-
type: 'limit',
|
|
62
|
-
limitPrice: 50_000,
|
|
63
|
-
qty: 1,
|
|
64
|
-
...overrides,
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
// ─── Mode gate ────────────────────────────────────────────────────────────────
|
|
69
|
-
|
|
70
|
-
describe('ManagedTradingController — mode gate', () => {
|
|
71
|
-
afterEach(clearLicense);
|
|
72
|
-
|
|
73
|
-
it('registerProvider() throws in unmanaged mode', () => {
|
|
74
|
-
installUnmanaged();
|
|
75
|
-
const store = new TradingOverlayStore();
|
|
76
|
-
const ctrl = new ManagedTradingController(store);
|
|
77
|
-
expect(() => ctrl.registerProvider(makeMockProvider())).toThrow(/managed/i);
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
it('registerProvider() throws when no license (defaults to unmanaged)', () => {
|
|
81
|
-
clearLicense();
|
|
82
|
-
const store = new TradingOverlayStore();
|
|
83
|
-
const ctrl = new ManagedTradingController(store);
|
|
84
|
-
expect(() => ctrl.registerProvider(makeMockProvider())).toThrow(/managed/i);
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
it('registerProvider() succeeds in managed mode', () => {
|
|
88
|
-
installManaged();
|
|
89
|
-
const store = new TradingOverlayStore();
|
|
90
|
-
const ctrl = new ManagedTradingController(store);
|
|
91
|
-
expect(() => ctrl.registerProvider(makeMockProvider())).not.toThrow();
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it('placeOrder() throws in unmanaged mode', async () => {
|
|
95
|
-
installUnmanaged();
|
|
96
|
-
const store = new TradingOverlayStore();
|
|
97
|
-
const ctrl = new ManagedTradingController(store);
|
|
98
|
-
await expect(ctrl.placeOrder(makeOrderInput())).rejects.toThrow(/managed/i);
|
|
99
|
-
});
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
// ─── isReady / getProviderId ──────────────────────────────────────────────────
|
|
103
|
-
|
|
104
|
-
describe('ManagedTradingController — readiness', () => {
|
|
105
|
-
beforeEach(installManaged);
|
|
106
|
-
afterEach(clearLicense);
|
|
107
|
-
|
|
108
|
-
it('isReady() is false before provider registration', () => {
|
|
109
|
-
const ctrl = new ManagedTradingController(new TradingOverlayStore());
|
|
110
|
-
expect(ctrl.isReady()).toBe(false);
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
it('isReady() is true after registration', () => {
|
|
114
|
-
const ctrl = new ManagedTradingController(new TradingOverlayStore());
|
|
115
|
-
ctrl.registerProvider(makeMockProvider());
|
|
116
|
-
expect(ctrl.isReady()).toBe(true);
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
it('getProviderId() returns null before registration', () => {
|
|
120
|
-
const ctrl = new ManagedTradingController(new TradingOverlayStore());
|
|
121
|
-
expect(ctrl.getProviderId()).toBeNull();
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
it('getProviderId() returns the provider id after registration', () => {
|
|
125
|
-
const ctrl = new ManagedTradingController(new TradingOverlayStore());
|
|
126
|
-
ctrl.registerProvider(makeMockProvider({ providerId: 'rithmic' }));
|
|
127
|
-
expect(ctrl.getProviderId()).toBe('rithmic');
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
|
|
131
|
-
// ─── placeOrder ───────────────────────────────────────────────────────────────
|
|
132
|
-
|
|
133
|
-
describe('ManagedTradingController — placeOrder', () => {
|
|
134
|
-
beforeEach(installManaged);
|
|
135
|
-
afterEach(clearLicense);
|
|
136
|
-
|
|
137
|
-
it('throws when no provider is registered', async () => {
|
|
138
|
-
const ctrl = new ManagedTradingController(new TradingOverlayStore());
|
|
139
|
-
await expect(ctrl.placeOrder(makeOrderInput())).rejects.toThrow(/no execution provider/i);
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
it('writes a pending order to overlay before provider responds', async () => {
|
|
143
|
-
const store = new TradingOverlayStore();
|
|
144
|
-
const ctrl = new ManagedTradingController(store);
|
|
145
|
-
let resolveAck: () => void;
|
|
146
|
-
const provider = makeMockProvider({
|
|
147
|
-
placeOrder: vi.fn().mockImplementation(
|
|
148
|
-
() => new Promise<{ orderId: string; status: 'open' }>((res) => {
|
|
149
|
-
resolveAck = () => res({ orderId: 'prov-001', status: 'open' });
|
|
150
|
-
}),
|
|
151
|
-
),
|
|
152
|
-
});
|
|
153
|
-
ctrl.registerProvider(provider);
|
|
154
|
-
|
|
155
|
-
const promise = ctrl.placeOrder(makeOrderInput());
|
|
156
|
-
// Overlay should have a pending entry immediately (optimistic)
|
|
157
|
-
expect(store.getOrders().some(o => o.status === 'pending')).toBe(true);
|
|
158
|
-
|
|
159
|
-
resolveAck!();
|
|
160
|
-
await promise;
|
|
161
|
-
});
|
|
162
|
-
|
|
163
|
-
it('updates overlay with provider-assigned id on success', async () => {
|
|
164
|
-
const store = new TradingOverlayStore();
|
|
165
|
-
const ctrl = new ManagedTradingController(store);
|
|
166
|
-
const provider = makeMockProvider({
|
|
167
|
-
placeOrder: vi.fn().mockResolvedValue({ orderId: 'server-id-1', status: 'open' }),
|
|
168
|
-
});
|
|
169
|
-
ctrl.registerProvider(provider);
|
|
170
|
-
|
|
171
|
-
await ctrl.placeOrder(makeOrderInput());
|
|
172
|
-
|
|
173
|
-
const orders = store.getOrders();
|
|
174
|
-
expect(orders.some(o => o.id === 'server-id-1' && o.status === 'open')).toBe(true);
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
it('rolls back to rejected status when provider throws', async () => {
|
|
178
|
-
const store = new TradingOverlayStore();
|
|
179
|
-
const ctrl = new ManagedTradingController(store);
|
|
180
|
-
const provider = makeMockProvider({
|
|
181
|
-
placeOrder: vi.fn().mockRejectedValue(new Error('venue rejected')),
|
|
182
|
-
});
|
|
183
|
-
ctrl.registerProvider(provider);
|
|
184
|
-
|
|
185
|
-
await expect(ctrl.placeOrder(makeOrderInput())).rejects.toThrow('venue rejected');
|
|
186
|
-
|
|
187
|
-
const orders = store.getOrders();
|
|
188
|
-
expect(orders.some(o => o.status === 'rejected')).toBe(true);
|
|
189
|
-
});
|
|
190
|
-
|
|
191
|
-
it('delegates to the registered provider', async () => {
|
|
192
|
-
const store = new TradingOverlayStore();
|
|
193
|
-
const ctrl = new ManagedTradingController(store);
|
|
194
|
-
const mockFn = vi.fn().mockResolvedValue({ orderId: 'x', status: 'open' });
|
|
195
|
-
ctrl.registerProvider(makeMockProvider({ placeOrder: mockFn }));
|
|
196
|
-
|
|
197
|
-
const input = makeOrderInput({ side: 'sell', qty: 3 });
|
|
198
|
-
await ctrl.placeOrder(input);
|
|
199
|
-
|
|
200
|
-
expect(mockFn).toHaveBeenCalledOnce();
|
|
201
|
-
expect(mockFn).toHaveBeenCalledWith(input);
|
|
202
|
-
});
|
|
203
|
-
});
|
|
204
|
-
|
|
205
|
-
// ─── cancelOrder ─────────────────────────────────────────────────────────────
|
|
206
|
-
|
|
207
|
-
describe('ManagedTradingController — cancelOrder', () => {
|
|
208
|
-
beforeEach(installManaged);
|
|
209
|
-
afterEach(clearLicense);
|
|
210
|
-
|
|
211
|
-
it('updates overlay status to cancelled after provider confirms', async () => {
|
|
212
|
-
const store = new TradingOverlayStore();
|
|
213
|
-
const ctrl = new ManagedTradingController(store);
|
|
214
|
-
ctrl.registerProvider(makeMockProvider());
|
|
215
|
-
|
|
216
|
-
await ctrl.placeOrder(makeOrderInput());
|
|
217
|
-
// Find the confirmed order id
|
|
218
|
-
const orderId = store.getOrders().find(o => o.status === 'open')?.id;
|
|
219
|
-
expect(orderId).toBeDefined();
|
|
220
|
-
|
|
221
|
-
await ctrl.cancelOrder(orderId!);
|
|
222
|
-
expect(store.getOrders().find(o => o.id === orderId)!.status).toBe('cancelled');
|
|
223
|
-
});
|
|
224
|
-
});
|
|
225
|
-
|
|
226
|
-
// ─── modifyOrder ──────────────────────────────────────────────────────────────
|
|
227
|
-
|
|
228
|
-
describe('ManagedTradingController — modifyOrder', () => {
|
|
229
|
-
beforeEach(installManaged);
|
|
230
|
-
afterEach(clearLicense);
|
|
231
|
-
|
|
232
|
-
it('patches price in overlay when limitPrice is provided', async () => {
|
|
233
|
-
const store = new TradingOverlayStore();
|
|
234
|
-
const ctrl = new ManagedTradingController(store);
|
|
235
|
-
ctrl.registerProvider(makeMockProvider());
|
|
236
|
-
|
|
237
|
-
await ctrl.placeOrder(makeOrderInput({ limitPrice: 50_000 }));
|
|
238
|
-
const orderId = store.getOrders().find(o => o.status === 'open')?.id;
|
|
239
|
-
expect(orderId).toBeDefined();
|
|
240
|
-
|
|
241
|
-
await ctrl.modifyOrder(orderId!, { limitPrice: 51_000 });
|
|
242
|
-
expect(store.getOrders().find(o => o.id === orderId)!.price).toBe(51_000);
|
|
243
|
-
});
|
|
244
|
-
|
|
245
|
-
it('patches qty in overlay when qty is provided', async () => {
|
|
246
|
-
const store = new TradingOverlayStore();
|
|
247
|
-
const ctrl = new ManagedTradingController(store);
|
|
248
|
-
ctrl.registerProvider(makeMockProvider());
|
|
249
|
-
|
|
250
|
-
await ctrl.placeOrder(makeOrderInput({ qty: 1 }));
|
|
251
|
-
const orderId = store.getOrders().find(o => o.status === 'open')?.id;
|
|
252
|
-
await ctrl.modifyOrder(orderId!, { qty: 5 });
|
|
253
|
-
expect(store.getOrders().find(o => o.id === orderId)!.qty).toBe(5);
|
|
254
|
-
});
|
|
255
|
-
});
|
|
256
|
-
|
|
257
|
-
// ─── placeBracketOrder ────────────────────────────────────────────────────────
|
|
258
|
-
|
|
259
|
-
describe('ManagedTradingController — placeBracketOrder', () => {
|
|
260
|
-
beforeEach(installManaged);
|
|
261
|
-
afterEach(clearLicense);
|
|
262
|
-
|
|
263
|
-
it('throws without a provider', async () => {
|
|
264
|
-
const ctrl = new ManagedTradingController(new TradingOverlayStore());
|
|
265
|
-
const input: PlaceBracketOrderInput = {
|
|
266
|
-
entry: makeOrderInput(),
|
|
267
|
-
stopLossPrice: 49_000,
|
|
268
|
-
takeProfitPrice: 55_000,
|
|
269
|
-
};
|
|
270
|
-
await expect(ctrl.placeBracketOrder(input)).rejects.toThrow(/no execution provider/i);
|
|
271
|
-
});
|
|
272
|
-
|
|
273
|
-
it('creates 3 orders sharing a groupId in the overlay', async () => {
|
|
274
|
-
const store = new TradingOverlayStore();
|
|
275
|
-
const ctrl = new ManagedTradingController(store);
|
|
276
|
-
ctrl.registerProvider(makeMockProvider());
|
|
277
|
-
|
|
278
|
-
const groupId = 'bracket-test';
|
|
279
|
-
const input: PlaceBracketOrderInput = {
|
|
280
|
-
entry: makeOrderInput({ groupId }),
|
|
281
|
-
stopLossPrice: 49_000,
|
|
282
|
-
takeProfitPrice: 55_000,
|
|
283
|
-
};
|
|
284
|
-
await ctrl.placeBracketOrder(input);
|
|
285
|
-
|
|
286
|
-
const group = store.getOrdersByGroup(groupId);
|
|
287
|
-
expect(group).toHaveLength(3);
|
|
288
|
-
|
|
289
|
-
const roles = group.map(o => o.role).sort();
|
|
290
|
-
expect(roles).toContain('entry');
|
|
291
|
-
expect(roles).toContain('stop_loss');
|
|
292
|
-
expect(roles).toContain('take_profit');
|
|
293
|
-
});
|
|
294
|
-
});
|
|
295
|
-
|
|
296
|
-
// ─── reportFill ───────────────────────────────────────────────────────────────
|
|
297
|
-
|
|
298
|
-
describe('ManagedTradingController — reportFill', () => {
|
|
299
|
-
beforeEach(installManaged);
|
|
300
|
-
afterEach(clearLicense);
|
|
301
|
-
|
|
302
|
-
it('pushes fill into overlay store', async () => {
|
|
303
|
-
const store = new TradingOverlayStore();
|
|
304
|
-
const ctrl = new ManagedTradingController(store);
|
|
305
|
-
ctrl.registerProvider(makeMockProvider());
|
|
306
|
-
|
|
307
|
-
await ctrl.placeOrder(makeOrderInput());
|
|
308
|
-
const orderId = store.getOrders().find(o => o.status === 'open')?.id ?? 'oid';
|
|
309
|
-
|
|
310
|
-
const fill: ExecutionFill = {
|
|
311
|
-
id: 'fill-1',
|
|
312
|
-
orderId,
|
|
313
|
-
side: 'buy',
|
|
314
|
-
price: 50_000,
|
|
315
|
-
qty: 1,
|
|
316
|
-
timestamp: Date.now(),
|
|
317
|
-
};
|
|
318
|
-
ctrl.reportFill(fill);
|
|
319
|
-
|
|
320
|
-
expect(store.getFills()).toHaveLength(1);
|
|
321
|
-
expect(store.getFills()[0]!.id).toBe('fill-1');
|
|
322
|
-
});
|
|
323
|
-
|
|
324
|
-
it('updates order status to filled after a fill report', async () => {
|
|
325
|
-
const store = new TradingOverlayStore();
|
|
326
|
-
const ctrl = new ManagedTradingController(store);
|
|
327
|
-
ctrl.registerProvider(makeMockProvider());
|
|
328
|
-
|
|
329
|
-
await ctrl.placeOrder(makeOrderInput());
|
|
330
|
-
const orderId = store.getOrders().find(o => o.status === 'open')?.id ?? 'oid';
|
|
331
|
-
|
|
332
|
-
ctrl.reportFill({
|
|
333
|
-
id: 'fill-2', orderId, side: 'buy', price: 50_000, qty: 1, timestamp: Date.now(),
|
|
334
|
-
});
|
|
335
|
-
|
|
336
|
-
expect(store.getOrders().find(o => o.id === orderId)!.status).toBe('filled');
|
|
337
|
-
});
|
|
338
|
-
});
|