@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,377 +0,0 @@
|
|
|
1
|
-
import { useState, useEffect, useRef, useCallback } from 'react';
|
|
2
|
-
import type { RefSymbol, ISymbolResolver, SymbolSearchResult } from '@forgecharts/types';
|
|
3
|
-
|
|
4
|
-
const PAGE_SIZE = 100;
|
|
5
|
-
|
|
6
|
-
const TABS = [
|
|
7
|
-
{ label: 'All', market: '' },
|
|
8
|
-
{ label: 'Stocks', market: 'stocks' },
|
|
9
|
-
{ label: 'Funds', market: 'etfs' },
|
|
10
|
-
{ label: 'Futures', market: 'futures' },
|
|
11
|
-
{ label: 'Forex', market: 'forex' },
|
|
12
|
-
{ label: 'Crypto', market: 'crypto' },
|
|
13
|
-
{ label: 'Indices', market: 'indices' },
|
|
14
|
-
{ label: 'Bonds', market: 'bonds' },
|
|
15
|
-
{ label: 'Economy', market: 'economy' },
|
|
16
|
-
{ label: 'Options', market: 'options' },
|
|
17
|
-
];
|
|
18
|
-
|
|
19
|
-
type SymbolEntry = {
|
|
20
|
-
symbol: string;
|
|
21
|
-
name: string;
|
|
22
|
-
symbolKey?: string;
|
|
23
|
-
exchange: string;
|
|
24
|
-
assetType: string;
|
|
25
|
-
market: string;
|
|
26
|
-
logoUrl?: string;
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
function refSymbolsToEntries(symbols: RefSymbol[]): SymbolEntry[] {
|
|
30
|
-
return symbols.map(s => ({
|
|
31
|
-
symbol: s.symbol,
|
|
32
|
-
name: s.displayName,
|
|
33
|
-
symbolKey: s.symbolKey,
|
|
34
|
-
exchange: s.exchange,
|
|
35
|
-
assetType: s.assetType,
|
|
36
|
-
market: s.market,
|
|
37
|
-
...(s.logoUrl ? { logoUrl: s.logoUrl } : {}),
|
|
38
|
-
}));
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
function stringColor(str: string): string {
|
|
42
|
-
const palette = [
|
|
43
|
-
'#f7931a','#627eea','#2775ca','#26a17b','#e84142',
|
|
44
|
-
'#00adef','#e91e63','#9945ff','#00d4aa','#ff6b35',
|
|
45
|
-
];
|
|
46
|
-
let h = 0;
|
|
47
|
-
for (let i = 0; i < str.length; i++) h = (Math.imul(31, h) + str.charCodeAt(i)) | 0;
|
|
48
|
-
return palette[Math.abs(h) % palette.length] ?? '#888888';
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
function badgeLabel(assetType: string, market: string): string {
|
|
52
|
-
const a = assetType?.toLowerCase() ?? '';
|
|
53
|
-
const m = market?.toLowerCase() ?? '';
|
|
54
|
-
if (a && m && a !== m) return `${a} ${m}`;
|
|
55
|
-
return a || m || '';
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
function SymbolIcon({ logoUrl, letter, color }: { logoUrl?: string; letter: string; color: string }) {
|
|
59
|
-
const [failed, setFailed] = useState(false);
|
|
60
|
-
return (
|
|
61
|
-
<span className="sym-row-icon" style={{ background: (logoUrl && !failed) ? 'transparent' : color }}>
|
|
62
|
-
{logoUrl && !failed
|
|
63
|
-
? <img src={logoUrl} alt="" className="sym-logo-img" onError={() => setFailed(true)} />
|
|
64
|
-
: letter}
|
|
65
|
-
</span>
|
|
66
|
-
);
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
type Props = {
|
|
70
|
-
current: string;
|
|
71
|
-
onSelect: (symbol: string) => void;
|
|
72
|
-
onClose: () => void;
|
|
73
|
-
symbolResolver: ISymbolResolver;
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
export function SymbolSearchDialog({ current, onSelect, onClose, symbolResolver }: Props) {
|
|
77
|
-
const [query, setQuery] = useState('');
|
|
78
|
-
const [activeTab, setActiveTab] = useState(0);
|
|
79
|
-
const [tabSymbols, setTabSymbols] = useState<SymbolEntry[]>([]);
|
|
80
|
-
const [tabLoading, setTabLoading] = useState(false);
|
|
81
|
-
const [tabLoadingMore, setTabLoadingMore] = useState(false);
|
|
82
|
-
const [tabOffset, setTabOffset] = useState(0);
|
|
83
|
-
const [tabHasMore, setTabHasMore] = useState(false);
|
|
84
|
-
const [searchResults, setSearchResults] = useState<SymbolEntry[] | null>(null);
|
|
85
|
-
const [isSearching, setIsSearching] = useState(false);
|
|
86
|
-
const [searchingMore, setSearchingMore] = useState(false);
|
|
87
|
-
const [searchOffset, setSearchOffset] = useState(0);
|
|
88
|
-
const [searchHasMore, setSearchHasMore] = useState(false);
|
|
89
|
-
const inputRef = useRef<HTMLInputElement>(null);
|
|
90
|
-
const dialogRef = useRef<HTMLDivElement>(null);
|
|
91
|
-
const sentinelRef = useRef<HTMLDivElement>(null);
|
|
92
|
-
const searchTimer = useRef<ReturnType<typeof setTimeout> | null>(null);
|
|
93
|
-
const queryRef = useRef(query);
|
|
94
|
-
const activeTabRef = useRef(activeTab);
|
|
95
|
-
queryRef.current = query;
|
|
96
|
-
activeTabRef.current = activeTab;
|
|
97
|
-
|
|
98
|
-
useEffect(() => { inputRef.current?.focus(); }, []);
|
|
99
|
-
|
|
100
|
-
useEffect(() => {
|
|
101
|
-
const h = (e: KeyboardEvent) => { if (e.key === 'Escape') onClose(); };
|
|
102
|
-
window.addEventListener('keydown', h);
|
|
103
|
-
return () => window.removeEventListener('keydown', h);
|
|
104
|
-
}, [onClose]);
|
|
105
|
-
|
|
106
|
-
// Tab browse: use getSymbols() for all tabs — supports offset pagination.
|
|
107
|
-
useEffect(() => {
|
|
108
|
-
const market = TABS[activeTab]?.market ?? '';
|
|
109
|
-
let cancelled = false;
|
|
110
|
-
setTabLoading(true);
|
|
111
|
-
setTabSymbols([]);
|
|
112
|
-
setTabOffset(0);
|
|
113
|
-
setTabHasMore(false);
|
|
114
|
-
symbolResolver.getSymbols({ ...(market ? { market } : {}), limit: PAGE_SIZE, offset: 0 })
|
|
115
|
-
.then((r: SymbolSearchResult) => {
|
|
116
|
-
if (!cancelled) {
|
|
117
|
-
setTabSymbols(refSymbolsToEntries(r.symbols));
|
|
118
|
-
setTabHasMore(r.symbols.length === PAGE_SIZE);
|
|
119
|
-
setTabOffset(PAGE_SIZE);
|
|
120
|
-
}
|
|
121
|
-
})
|
|
122
|
-
.catch(() => {})
|
|
123
|
-
.finally(() => { if (!cancelled) setTabLoading(false); });
|
|
124
|
-
return () => { cancelled = true; };
|
|
125
|
-
}, [activeTab]);
|
|
126
|
-
|
|
127
|
-
const loadMoreTab = useCallback(async () => {
|
|
128
|
-
if (tabLoadingMore || !tabHasMore) return;
|
|
129
|
-
const market = TABS[activeTabRef.current]?.market ?? '';
|
|
130
|
-
setTabLoadingMore(true);
|
|
131
|
-
try {
|
|
132
|
-
const r = await symbolResolver.getSymbols({ ...(market ? { market } : {}), limit: PAGE_SIZE, offset: tabOffset });
|
|
133
|
-
setTabSymbols(prev => [...prev, ...refSymbolsToEntries(r.symbols)]);
|
|
134
|
-
setTabHasMore(r.symbols.length === PAGE_SIZE);
|
|
135
|
-
setTabOffset(prev => prev + PAGE_SIZE);
|
|
136
|
-
} catch { /* ignore */ }
|
|
137
|
-
finally { setTabLoadingMore(false); }
|
|
138
|
-
}, [tabLoadingMore, tabHasMore, tabOffset]);
|
|
139
|
-
|
|
140
|
-
const loadMoreSearch = useCallback(async () => {
|
|
141
|
-
if (searchingMore || !searchHasMore) return;
|
|
142
|
-
const q = queryRef.current.trim();
|
|
143
|
-
if (!q) return;
|
|
144
|
-
const market = TABS[activeTabRef.current]?.market;
|
|
145
|
-
setSearchingMore(true);
|
|
146
|
-
try {
|
|
147
|
-
const res = await symbolResolver.searchSymbols(q, {
|
|
148
|
-
limit: PAGE_SIZE, offset: searchOffset,
|
|
149
|
-
...(market ? { market } : {}),
|
|
150
|
-
});
|
|
151
|
-
setSearchResults(prev => prev ? [...prev, ...refSymbolsToEntries(res.symbols)] : refSymbolsToEntries(res.symbols));
|
|
152
|
-
setSearchHasMore(res.symbols.length === PAGE_SIZE);
|
|
153
|
-
setSearchOffset(prev => prev + PAGE_SIZE);
|
|
154
|
-
} catch { /* ignore */ }
|
|
155
|
-
finally { setSearchingMore(false); }
|
|
156
|
-
}, [searchingMore, searchHasMore, searchOffset]);
|
|
157
|
-
|
|
158
|
-
// Stable refs so the IntersectionObserver callback always calls the latest version
|
|
159
|
-
const loadMoreTabRef = useRef(loadMoreTab);
|
|
160
|
-
const loadMoreSearchRef = useRef(loadMoreSearch);
|
|
161
|
-
loadMoreTabRef.current = loadMoreTab;
|
|
162
|
-
loadMoreSearchRef.current = loadMoreSearch;
|
|
163
|
-
|
|
164
|
-
// Sentinel IntersectionObserver — fires loadMore when the bottom of the list enters view
|
|
165
|
-
useEffect(() => {
|
|
166
|
-
const sentinel = sentinelRef.current;
|
|
167
|
-
if (!sentinel) return;
|
|
168
|
-
const observer = new IntersectionObserver(entries => {
|
|
169
|
-
if (entries[0]?.isIntersecting) {
|
|
170
|
-
if (queryRef.current.trim()) {
|
|
171
|
-
void loadMoreSearchRef.current();
|
|
172
|
-
} else {
|
|
173
|
-
void loadMoreTabRef.current();
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
}, { threshold: 0.1 });
|
|
177
|
-
observer.observe(sentinel);
|
|
178
|
-
return () => observer.disconnect();
|
|
179
|
-
}, []); // eslint-disable-line react-hooks/exhaustive-deps
|
|
180
|
-
|
|
181
|
-
const doSearch = useCallback((q: string, tab: number) => {
|
|
182
|
-
if (searchTimer.current) clearTimeout(searchTimer.current);
|
|
183
|
-
if (!q.trim()) {
|
|
184
|
-
setSearchResults(null);
|
|
185
|
-
setSearchOffset(0);
|
|
186
|
-
setSearchHasMore(false);
|
|
187
|
-
return;
|
|
188
|
-
}
|
|
189
|
-
setIsSearching(true);
|
|
190
|
-
searchTimer.current = setTimeout(async () => {
|
|
191
|
-
try {
|
|
192
|
-
const market = TABS[tab]?.market;
|
|
193
|
-
const res = await symbolResolver.searchSymbols(q.trim(), {
|
|
194
|
-
limit: PAGE_SIZE, offset: 0,
|
|
195
|
-
...(market ? { market } : {}),
|
|
196
|
-
});
|
|
197
|
-
setSearchResults(refSymbolsToEntries(res.symbols));
|
|
198
|
-
setSearchHasMore(res.symbols.length === PAGE_SIZE);
|
|
199
|
-
setSearchOffset(PAGE_SIZE);
|
|
200
|
-
} catch {
|
|
201
|
-
setSearchResults([]);
|
|
202
|
-
setSearchHasMore(false);
|
|
203
|
-
} finally {
|
|
204
|
-
setIsSearching(false);
|
|
205
|
-
}
|
|
206
|
-
}, 180);
|
|
207
|
-
}, []);
|
|
208
|
-
|
|
209
|
-
const handleQueryChange = (value: string) => {
|
|
210
|
-
setQuery(value);
|
|
211
|
-
doSearch(value, activeTab);
|
|
212
|
-
};
|
|
213
|
-
|
|
214
|
-
const handleTabChange = (i: number) => {
|
|
215
|
-
setActiveTab(i);
|
|
216
|
-
if (queryRef.current.trim()) doSearch(queryRef.current, i);
|
|
217
|
-
};
|
|
218
|
-
|
|
219
|
-
const handleBackdrop = (e: React.MouseEvent) => {
|
|
220
|
-
if (dialogRef.current && !dialogRef.current.contains(e.target as Node)) onClose();
|
|
221
|
-
};
|
|
222
|
-
|
|
223
|
-
const isSearch = query.trim().length > 0;
|
|
224
|
-
const displayList = isSearch ? (searchResults ?? []) : tabSymbols;
|
|
225
|
-
// Use exchange:symbol format (strip market prefix from symbolKey) so the
|
|
226
|
-
// datafeed can pass it directly to the TV API, e.g. "BINANCE:BTCUSDT"
|
|
227
|
-
const toFeedSymbol = (entry: SymbolEntry): string => {
|
|
228
|
-
if (!entry.symbolKey) return entry.symbol;
|
|
229
|
-
const parts = entry.symbolKey.split(':');
|
|
230
|
-
// symbolKey is MARKET:EXCHANGE:SYMBOL → we want EXCHANGE:SYMBOL
|
|
231
|
-
return parts.length >= 3 ? parts.slice(1).join(':') : entry.symbolKey;
|
|
232
|
-
};
|
|
233
|
-
const pick = (entry: SymbolEntry) => { onSelect(toFeedSymbol(entry)); onClose(); };
|
|
234
|
-
|
|
235
|
-
const renderRow = (entry: SymbolEntry) => {
|
|
236
|
-
const iconColor = stringColor(entry.symbol);
|
|
237
|
-
const exchColor = stringColor(entry.exchange);
|
|
238
|
-
const letter = entry.symbol.charAt(0).toUpperCase();
|
|
239
|
-
const exchAbbr = entry.exchange.slice(0, 2).toUpperCase();
|
|
240
|
-
const badge = badgeLabel(entry.assetType, entry.market);
|
|
241
|
-
return (
|
|
242
|
-
<button
|
|
243
|
-
key={entry.symbolKey ?? `${entry.exchange}:${entry.symbol}`}
|
|
244
|
-
className={`sym-row${entry.symbol === current ? ' active' : ''}`}
|
|
245
|
-
onClick={() => pick(entry)}
|
|
246
|
-
>
|
|
247
|
-
<SymbolIcon
|
|
248
|
-
letter={letter}
|
|
249
|
-
color={iconColor}
|
|
250
|
-
{...(entry.logoUrl ? { logoUrl: entry.logoUrl } : {})}
|
|
251
|
-
/>
|
|
252
|
-
<span className="sym-row-info">
|
|
253
|
-
<span className="sym-row-ticker">{entry.symbol}</span>
|
|
254
|
-
<span className="sym-row-name">{entry.name}</span>
|
|
255
|
-
</span>
|
|
256
|
-
{badge && <span className="sym-row-badge">{badge}</span>}
|
|
257
|
-
<span className="sym-row-exchange">{entry.exchange}</span>
|
|
258
|
-
<span className="sym-row-exch-icon" style={{ background: exchColor }}>{exchAbbr}</span>
|
|
259
|
-
</button>
|
|
260
|
-
);
|
|
261
|
-
};
|
|
262
|
-
|
|
263
|
-
const renderDirectRow = () => {
|
|
264
|
-
const q = query.trim();
|
|
265
|
-
if (!q) return null;
|
|
266
|
-
return (
|
|
267
|
-
<button
|
|
268
|
-
className="sym-row"
|
|
269
|
-
onClick={() => { onSelect(q.toUpperCase()); onClose(); }}
|
|
270
|
-
style={{ borderTop: '1px solid var(--sym-border, rgba(255,255,255,.08))', marginTop: 4 }}
|
|
271
|
-
>
|
|
272
|
-
<span className="sym-row-icon" style={{ background: '#444', fontSize: 11, fontWeight: 700 }}>→</span>
|
|
273
|
-
<span className="sym-row-info">
|
|
274
|
-
<span className="sym-row-ticker">{q.toUpperCase()}</span>
|
|
275
|
-
<span className="sym-row-name">Use this symbol directly</span>
|
|
276
|
-
</span>
|
|
277
|
-
</button>
|
|
278
|
-
);
|
|
279
|
-
};
|
|
280
|
-
|
|
281
|
-
const renderBody = () => {
|
|
282
|
-
if (isSearch && isSearching)
|
|
283
|
-
return <div className="sym-list">{renderDirectRow()}</div>;
|
|
284
|
-
if (isSearch && searchResults !== null && searchResults.length === 0)
|
|
285
|
-
return <div className="sym-list">{renderDirectRow()}</div>;
|
|
286
|
-
if (!isSearch && tabLoading)
|
|
287
|
-
return <div className="sym-empty">Loading...</div>;
|
|
288
|
-
if (displayList.length === 0 && !isSearch && !tabLoading)
|
|
289
|
-
return <div className="sym-empty">No data — run a Symbol Sync from the Studio</div>;
|
|
290
|
-
const loadingMore = isSearch ? searchingMore : tabLoadingMore;
|
|
291
|
-
if (isSearch)
|
|
292
|
-
return (
|
|
293
|
-
<div className="sym-list">
|
|
294
|
-
{displayList.map(renderRow)}
|
|
295
|
-
{renderDirectRow()}
|
|
296
|
-
<div ref={sentinelRef} className="sym-sentinel" />
|
|
297
|
-
{loadingMore && <div className="sym-loading-more">Loading more…</div>}
|
|
298
|
-
</div>
|
|
299
|
-
);
|
|
300
|
-
return (
|
|
301
|
-
<div className="sym-list">
|
|
302
|
-
{displayList.map(renderRow)}
|
|
303
|
-
<div ref={sentinelRef} className="sym-sentinel" />
|
|
304
|
-
{loadingMore && <div className="sym-loading-more">Loading more…</div>}
|
|
305
|
-
</div>
|
|
306
|
-
);
|
|
307
|
-
};
|
|
308
|
-
|
|
309
|
-
return (
|
|
310
|
-
<div className="sym-backdrop" onMouseDown={handleBackdrop}>
|
|
311
|
-
<div className="sym-dialog" ref={dialogRef} role="dialog" aria-modal="true" aria-label="Symbol Search">
|
|
312
|
-
|
|
313
|
-
{/* Header */}
|
|
314
|
-
<div className="sym-header">
|
|
315
|
-
<span className="sym-header-title">Symbol Search</span>
|
|
316
|
-
<button className="sym-header-close" onClick={onClose} aria-label="Close">
|
|
317
|
-
<svg viewBox="0 0 14 14" width="13" height="13" stroke="currentColor"
|
|
318
|
-
strokeWidth="2.2" strokeLinecap="round" fill="none">
|
|
319
|
-
<line x1="2" y1="2" x2="12" y2="12" />
|
|
320
|
-
<line x1="12" y1="2" x2="2" y2="12" />
|
|
321
|
-
</svg>
|
|
322
|
-
</button>
|
|
323
|
-
</div>
|
|
324
|
-
|
|
325
|
-
{/* Search input */}
|
|
326
|
-
<div className="sym-search-row">
|
|
327
|
-
<svg className="sym-search-icon" viewBox="0 0 16 16" width="15" height="15"
|
|
328
|
-
stroke="currentColor" fill="none" strokeWidth="1.8" strokeLinecap="round">
|
|
329
|
-
<circle cx="6.5" cy="6.5" r="4.5" />
|
|
330
|
-
<line x1="10.5" y1="10.5" x2="14" y2="14" />
|
|
331
|
-
</svg>
|
|
332
|
-
<input
|
|
333
|
-
ref={inputRef}
|
|
334
|
-
className="sym-search-input"
|
|
335
|
-
type="text"
|
|
336
|
-
value={query}
|
|
337
|
-
onChange={(e) => handleQueryChange(e.target.value)}
|
|
338
|
-
placeholder="Search symbols or names..."
|
|
339
|
-
autoComplete="off"
|
|
340
|
-
spellCheck={false}
|
|
341
|
-
/>
|
|
342
|
-
{query && (
|
|
343
|
-
<button className="sym-search-clear" onClick={() => { setQuery(''); setSearchResults(null); }} aria-label="Clear">
|
|
344
|
-
<svg viewBox="0 0 12 12" width="11" height="11" stroke="currentColor"
|
|
345
|
-
strokeWidth="2.2" strokeLinecap="round" fill="none">
|
|
346
|
-
<line x1="2" y1="2" x2="10" y2="10" />
|
|
347
|
-
<line x1="10" y1="2" x2="2" y2="10" />
|
|
348
|
-
</svg>
|
|
349
|
-
</button>
|
|
350
|
-
)}
|
|
351
|
-
</div>
|
|
352
|
-
|
|
353
|
-
{/* Category tabs */}
|
|
354
|
-
<div className="sym-tabs">
|
|
355
|
-
{TABS.map((tab, i) => (
|
|
356
|
-
<button
|
|
357
|
-
key={tab.label}
|
|
358
|
-
className={`sym-tab${i === activeTab ? ' active' : ''}`}
|
|
359
|
-
onClick={() => handleTabChange(i)}
|
|
360
|
-
>
|
|
361
|
-
{tab.label}
|
|
362
|
-
</button>
|
|
363
|
-
))}
|
|
364
|
-
</div>
|
|
365
|
-
|
|
366
|
-
{/* Results */}
|
|
367
|
-
<div className="sym-list-wrap">
|
|
368
|
-
{renderBody()}
|
|
369
|
-
</div>
|
|
370
|
-
|
|
371
|
-
{/* Footer */}
|
|
372
|
-
<div className="sym-footer">Search using ISIN and CUSIP codes</div>
|
|
373
|
-
|
|
374
|
-
</div>
|
|
375
|
-
</div>
|
|
376
|
-
);
|
|
377
|
-
}
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
import React, { useRef, useState } from 'react';
|
|
2
|
-
|
|
3
|
-
export type TabItem = {
|
|
4
|
-
id: string;
|
|
5
|
-
label: string;
|
|
6
|
-
/** Whether this tab has been saved to the DB (shows a saved indicator). */
|
|
7
|
-
isSaved?: boolean;
|
|
8
|
-
};
|
|
9
|
-
|
|
10
|
-
type Props = {
|
|
11
|
-
tabs: TabItem[];
|
|
12
|
-
activeId: string;
|
|
13
|
-
onSelect: (id: string) => void;
|
|
14
|
-
onAdd: () => void;
|
|
15
|
-
onClose: (id: string) => void;
|
|
16
|
-
onRename: (id: string, label: string) => void;
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
export function TabBar({ tabs, activeId, onSelect, onAdd, onClose, onRename }: Props) {
|
|
20
|
-
const [editingId, setEditingId] = useState<string | null>(null);
|
|
21
|
-
const [editValue, setEditValue] = useState('');
|
|
22
|
-
const inputRef = useRef<HTMLInputElement>(null);
|
|
23
|
-
|
|
24
|
-
function startEdit(tab: TabItem, e: React.MouseEvent) {
|
|
25
|
-
e.stopPropagation();
|
|
26
|
-
setEditingId(tab.id);
|
|
27
|
-
setEditValue(tab.label);
|
|
28
|
-
setTimeout(() => inputRef.current?.select(), 0);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
function commitEdit() {
|
|
32
|
-
if (editingId && editValue.trim()) {
|
|
33
|
-
onRename(editingId, editValue.trim());
|
|
34
|
-
}
|
|
35
|
-
setEditingId(null);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
return (
|
|
39
|
-
<div className="tab-bar">
|
|
40
|
-
{tabs.map((tab) => (
|
|
41
|
-
<div
|
|
42
|
-
key={tab.id}
|
|
43
|
-
className={`tab-item${tab.id === activeId ? ' active' : ''}`}
|
|
44
|
-
onClick={() => onSelect(tab.id)}
|
|
45
|
-
onDoubleClick={(e) => startEdit(tab, e)}
|
|
46
|
-
title="Double-click to rename"
|
|
47
|
-
>
|
|
48
|
-
{editingId === tab.id ? (
|
|
49
|
-
<input
|
|
50
|
-
ref={inputRef}
|
|
51
|
-
className="tab-rename-input"
|
|
52
|
-
value={editValue}
|
|
53
|
-
onChange={(e) => setEditValue(e.target.value)}
|
|
54
|
-
onBlur={commitEdit}
|
|
55
|
-
onKeyDown={(e) => {
|
|
56
|
-
if (e.key === 'Enter') commitEdit();
|
|
57
|
-
if (e.key === 'Escape') setEditingId(null);
|
|
58
|
-
}}
|
|
59
|
-
onClick={(e) => e.stopPropagation()}
|
|
60
|
-
autoFocus
|
|
61
|
-
/>
|
|
62
|
-
) : (
|
|
63
|
-
<span className="tab-label">
|
|
64
|
-
{tab.label}
|
|
65
|
-
{tab.isSaved && <span className="tab-saved-dot" title="Saved layout" />}
|
|
66
|
-
</span>
|
|
67
|
-
)}
|
|
68
|
-
{tabs.length > 1 && (
|
|
69
|
-
<button
|
|
70
|
-
className="tab-close"
|
|
71
|
-
title="Close tab"
|
|
72
|
-
onClick={(e) => {
|
|
73
|
-
e.stopPropagation();
|
|
74
|
-
onClose(tab.id);
|
|
75
|
-
}}
|
|
76
|
-
>
|
|
77
|
-
×
|
|
78
|
-
</button>
|
|
79
|
-
)}
|
|
80
|
-
</div>
|
|
81
|
-
))}
|
|
82
|
-
<button className="tab-add" onClick={onAdd} title="New chart tab">
|
|
83
|
-
+
|
|
84
|
-
</button>
|
|
85
|
-
</div>
|
|
86
|
-
);
|
|
87
|
-
}
|