@forgecharts/sdk 1.1.27 → 1.1.29

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.
Files changed (356) hide show
  1. package/dist/__tests__/backwardCompatibility.test.d.ts +14 -0
  2. package/dist/__tests__/backwardCompatibility.test.d.ts.map +1 -0
  3. package/dist/__tests__/candleInvariant.test.d.ts +20 -0
  4. package/dist/__tests__/candleInvariant.test.d.ts.map +1 -0
  5. package/dist/__tests__/public-api-surface.d.ts +13 -0
  6. package/dist/__tests__/public-api-surface.d.ts.map +1 -0
  7. package/dist/__tests__/timeframeBoundary.test.d.ts +17 -0
  8. package/dist/__tests__/timeframeBoundary.test.d.ts.map +1 -0
  9. package/dist/api/DrawingManager.d.ts +20 -0
  10. package/dist/api/DrawingManager.d.ts.map +1 -0
  11. package/dist/api/EventBus.d.ts +19 -0
  12. package/dist/api/EventBus.d.ts.map +1 -0
  13. package/dist/api/IndicatorDAG.d.ts +85 -0
  14. package/dist/api/IndicatorDAG.d.ts.map +1 -0
  15. package/dist/api/IndicatorRegistry.d.ts +22 -0
  16. package/dist/api/IndicatorRegistry.d.ts.map +1 -0
  17. package/dist/api/LayoutManager.d.ts +30 -0
  18. package/dist/api/LayoutManager.d.ts.map +1 -0
  19. package/dist/api/PaneManager.d.ts +42 -0
  20. package/dist/api/PaneManager.d.ts.map +1 -0
  21. package/dist/api/ReferenceAPI.d.ts +78 -0
  22. package/dist/api/ReferenceAPI.d.ts.map +1 -0
  23. package/dist/api/TChart.d.ts +345 -0
  24. package/dist/api/TChart.d.ts.map +1 -0
  25. package/{src/api/createChart.ts → dist/api/createChart.d.ts} +2 -7
  26. package/dist/api/createChart.d.ts.map +1 -0
  27. package/dist/api/drawing tools/fib gann menu/fibRetracement.d.ts +4 -0
  28. package/dist/api/drawing tools/fib gann menu/fibRetracement.d.ts.map +1 -0
  29. package/dist/api/drawing tools/lines menu/crossLine.d.ts +4 -0
  30. package/dist/api/drawing tools/lines menu/crossLine.d.ts.map +1 -0
  31. package/dist/api/drawing tools/lines menu/disjointChannel.d.ts +17 -0
  32. package/dist/api/drawing tools/lines menu/disjointChannel.d.ts.map +1 -0
  33. package/dist/api/drawing tools/lines menu/extendedLine.d.ts +4 -0
  34. package/dist/api/drawing tools/lines menu/extendedLine.d.ts.map +1 -0
  35. package/dist/api/drawing tools/lines menu/flatTopBottom.d.ts +4 -0
  36. package/dist/api/drawing tools/lines menu/flatTopBottom.d.ts.map +1 -0
  37. package/dist/api/drawing tools/lines menu/horizontal.d.ts +4 -0
  38. package/dist/api/drawing tools/lines menu/horizontal.d.ts.map +1 -0
  39. package/dist/api/drawing tools/lines menu/horizontalRay.d.ts +4 -0
  40. package/dist/api/drawing tools/lines menu/horizontalRay.d.ts.map +1 -0
  41. package/dist/api/drawing tools/lines menu/infoLine.d.ts +4 -0
  42. package/dist/api/drawing tools/lines menu/infoLine.d.ts.map +1 -0
  43. package/dist/api/drawing tools/lines menu/insidePitchfork.d.ts +4 -0
  44. package/dist/api/drawing tools/lines menu/insidePitchfork.d.ts.map +1 -0
  45. package/dist/api/drawing tools/lines menu/modifiedSchiffPitchfork.d.ts +4 -0
  46. package/dist/api/drawing tools/lines menu/modifiedSchiffPitchfork.d.ts.map +1 -0
  47. package/dist/api/drawing tools/lines menu/parallelChannel.d.ts +4 -0
  48. package/dist/api/drawing tools/lines menu/parallelChannel.d.ts.map +1 -0
  49. package/dist/api/drawing tools/lines menu/pitchfork.d.ts +4 -0
  50. package/dist/api/drawing tools/lines menu/pitchfork.d.ts.map +1 -0
  51. package/dist/api/drawing tools/lines menu/ray.d.ts +4 -0
  52. package/dist/api/drawing tools/lines menu/ray.d.ts.map +1 -0
  53. package/dist/api/drawing tools/lines menu/regressionTrend.d.ts +4 -0
  54. package/dist/api/drawing tools/lines menu/regressionTrend.d.ts.map +1 -0
  55. package/dist/api/drawing tools/lines menu/schiffPitchfork.d.ts +4 -0
  56. package/dist/api/drawing tools/lines menu/schiffPitchfork.d.ts.map +1 -0
  57. package/dist/api/drawing tools/lines menu/trendAngle.d.ts +4 -0
  58. package/dist/api/drawing tools/lines menu/trendAngle.d.ts.map +1 -0
  59. package/dist/api/drawing tools/lines menu/trendline.d.ts +4 -0
  60. package/dist/api/drawing tools/lines menu/trendline.d.ts.map +1 -0
  61. package/dist/api/drawing tools/lines menu/vertical.d.ts +4 -0
  62. package/dist/api/drawing tools/lines menu/vertical.d.ts.map +1 -0
  63. package/{src/api/drawing tools/pointers menu/crosshair.ts → dist/api/drawing tools/pointers menu/crosshair.d.ts } +8 -9
  64. package/dist/api/drawing tools/pointers menu/crosshair.d.ts.map +1 -0
  65. package/dist/api/drawing tools/pointers menu/cursor.d.ts +15 -0
  66. package/dist/api/drawing tools/pointers menu/cursor.d.ts.map +1 -0
  67. package/{src/api/drawing tools/pointers menu/demonstration.ts → dist/api/drawing tools/pointers menu/demonstration.d.ts } +12 -17
  68. package/dist/api/drawing tools/pointers menu/demonstration.d.ts.map +1 -0
  69. package/{src/api/drawing tools/pointers menu/dot.ts → dist/api/drawing tools/pointers menu/dot.d.ts } +10 -13
  70. package/dist/api/drawing tools/pointers menu/dot.d.ts.map +1 -0
  71. package/dist/api/drawing tools/shapes menu/rectangle.d.ts +4 -0
  72. package/dist/api/drawing tools/shapes menu/rectangle.d.ts.map +1 -0
  73. package/dist/api/drawing tools/shapes menu/text.d.ts +4 -0
  74. package/dist/api/drawing tools/shapes menu/text.d.ts.map +1 -0
  75. package/dist/api/drawingUtils.d.ts +22 -0
  76. package/dist/api/drawingUtils.d.ts.map +1 -0
  77. package/dist/core/CanvasLayer.d.ts +26 -0
  78. package/dist/core/CanvasLayer.d.ts.map +1 -0
  79. package/dist/core/Chart.d.ts +164 -0
  80. package/dist/core/Chart.d.ts.map +1 -0
  81. package/dist/core/CoordTransform.d.ts +168 -0
  82. package/dist/core/CoordTransform.d.ts.map +1 -0
  83. package/dist/core/Crosshair.d.ts +30 -0
  84. package/dist/core/Crosshair.d.ts.map +1 -0
  85. package/dist/core/IndicatorEngine.d.ts +51 -0
  86. package/dist/core/IndicatorEngine.d.ts.map +1 -0
  87. package/dist/core/InteractionManager.d.ts +197 -0
  88. package/dist/core/InteractionManager.d.ts.map +1 -0
  89. package/dist/core/PriceScale.d.ts +27 -0
  90. package/dist/core/PriceScale.d.ts.map +1 -0
  91. package/dist/core/Series.d.ts +40 -0
  92. package/dist/core/Series.d.ts.map +1 -0
  93. package/dist/core/TimeScale.d.ts +43 -0
  94. package/dist/core/TimeScale.d.ts.map +1 -0
  95. package/dist/datafeed/DatafeedConnector.d.ts +89 -0
  96. package/dist/datafeed/DatafeedConnector.d.ts.map +1 -0
  97. package/dist/engine/CandleEngine.d.ts +207 -0
  98. package/dist/engine/CandleEngine.d.ts.map +1 -0
  99. package/dist/engine/__tests__/CandleEngine.test.d.ts +2 -0
  100. package/dist/engine/__tests__/CandleEngine.test.d.ts.map +1 -0
  101. package/dist/engine/candleInvariants.d.ts +66 -0
  102. package/dist/engine/candleInvariants.d.ts.map +1 -0
  103. package/{src/engine/mergeUtils.ts → dist/engine/mergeUtils.d.ts} +15 -52
  104. package/dist/engine/mergeUtils.d.ts.map +1 -0
  105. package/dist/engine/timeframeUtils.d.ts +80 -0
  106. package/dist/engine/timeframeUtils.d.ts.map +1 -0
  107. package/dist/index.d.ts +40 -0
  108. package/dist/index.d.ts.map +1 -0
  109. package/dist/index.js +8101 -0
  110. package/dist/index.js.map +1 -0
  111. package/{src/internal.ts → dist/internal.d.ts} +1 -13
  112. package/dist/internal.d.ts.map +1 -0
  113. package/dist/internal.js +8852 -0
  114. package/dist/internal.js.map +1 -0
  115. package/dist/licensing/ChartRuntimeResolver.d.ts +233 -0
  116. package/dist/licensing/ChartRuntimeResolver.d.ts.map +1 -0
  117. package/dist/licensing/LicenseManager.d.ts +55 -0
  118. package/dist/licensing/LicenseManager.d.ts.map +1 -0
  119. package/dist/licensing/__tests__/ChartRuntimeResolver.test.d.ts +13 -0
  120. package/dist/licensing/__tests__/ChartRuntimeResolver.test.d.ts.map +1 -0
  121. package/dist/licensing/__tests__/LicenseManager.test.d.ts +12 -0
  122. package/dist/licensing/__tests__/LicenseManager.test.d.ts.map +1 -0
  123. package/dist/licensing/licenseTypes.d.ts +18 -0
  124. package/dist/licensing/licenseTypes.d.ts.map +1 -0
  125. package/dist/pine/PineCompiler.d.ts +35 -0
  126. package/dist/pine/PineCompiler.d.ts.map +1 -0
  127. package/dist/pine/diagnostics.d.ts +20 -0
  128. package/dist/pine/diagnostics.d.ts.map +1 -0
  129. package/{src/pine/index.ts → dist/pine/index.d.ts} +4 -3
  130. package/dist/pine/index.d.ts.map +1 -0
  131. package/dist/pine/pine-ast.d.ts +142 -0
  132. package/dist/pine/pine-ast.d.ts.map +1 -0
  133. package/dist/pine/pine-lexer.d.ts +41 -0
  134. package/dist/pine/pine-lexer.d.ts.map +1 -0
  135. package/dist/pine/pine-parser.d.ts +51 -0
  136. package/dist/pine/pine-parser.d.ts.map +1 -0
  137. package/dist/pine/pine-transpiler.d.ts +33 -0
  138. package/dist/pine/pine-transpiler.d.ts.map +1 -0
  139. package/dist/pixi/LayerName.d.ts +18 -0
  140. package/dist/pixi/LayerName.d.ts.map +1 -0
  141. package/dist/pixi/PixiCandlestickRenderer.d.ts +23 -0
  142. package/dist/pixi/PixiCandlestickRenderer.d.ts.map +1 -0
  143. package/dist/pixi/PixiChart.d.ts +72 -0
  144. package/dist/pixi/PixiChart.d.ts.map +1 -0
  145. package/dist/pixi/PixiCrosshairRenderer.d.ts +29 -0
  146. package/dist/pixi/PixiCrosshairRenderer.d.ts.map +1 -0
  147. package/dist/pixi/PixiDrawingRenderer.d.ts +17 -0
  148. package/dist/pixi/PixiDrawingRenderer.d.ts.map +1 -0
  149. package/dist/pixi/PixiGridRenderer.d.ts +22 -0
  150. package/dist/pixi/PixiGridRenderer.d.ts.map +1 -0
  151. package/dist/pixi/PixiLayerManager.d.ts +56 -0
  152. package/dist/pixi/PixiLayerManager.d.ts.map +1 -0
  153. package/dist/react/canvas/ChartCanvas.d.ts +85 -0
  154. package/dist/react/canvas/ChartCanvas.d.ts.map +1 -0
  155. package/dist/react/canvas/ChartContextMenu.d.ts +18 -0
  156. package/dist/react/canvas/ChartContextMenu.d.ts.map +1 -0
  157. package/dist/react/canvas/ChartSettingsDialog.d.ts +25 -0
  158. package/dist/react/canvas/ChartSettingsDialog.d.ts.map +1 -0
  159. package/dist/react/canvas/IndicatorLabel.d.ts +21 -0
  160. package/dist/react/canvas/IndicatorLabel.d.ts.map +1 -0
  161. package/dist/react/canvas/IndicatorPane.d.ts +32 -0
  162. package/dist/react/canvas/IndicatorPane.d.ts.map +1 -0
  163. package/dist/react/canvas/PointerOverlay.d.ts +23 -0
  164. package/dist/react/canvas/PointerOverlay.d.ts.map +1 -0
  165. package/dist/react/canvas/toolbars/LeftToolbar.d.ts +19 -0
  166. package/dist/react/canvas/toolbars/LeftToolbar.d.ts.map +1 -0
  167. package/dist/react/hooks/useChartCapabilities.d.ts +21 -0
  168. package/dist/react/hooks/useChartCapabilities.d.ts.map +1 -0
  169. package/{src/react/index.ts → dist/react/index.d.ts} +2 -23
  170. package/dist/react/index.d.ts.map +1 -0
  171. package/dist/react/index.js +11559 -0
  172. package/dist/react/index.js.map +1 -0
  173. package/{src/react/internal.ts → dist/react/internal.d.ts} +2 -26
  174. package/dist/react/internal.d.ts.map +1 -0
  175. package/dist/react/internal.js +12148 -0
  176. package/dist/react/internal.js.map +1 -0
  177. package/dist/react/shell/ManagedAppShell.d.ts +91 -0
  178. package/dist/react/shell/ManagedAppShell.d.ts.map +1 -0
  179. package/dist/react/trading/TradingBridge.d.ts +86 -0
  180. package/dist/react/trading/TradingBridge.d.ts.map +1 -0
  181. package/dist/react/workspace/ChartWorkspace.d.ts +73 -0
  182. package/dist/react/workspace/ChartWorkspace.d.ts.map +1 -0
  183. package/dist/react/workspace/FloatingPanel.d.ts +18 -0
  184. package/dist/react/workspace/FloatingPanel.d.ts.map +1 -0
  185. package/dist/react/workspace/IndicatorsDialog.d.ts +8 -0
  186. package/dist/react/workspace/IndicatorsDialog.d.ts.map +1 -0
  187. package/dist/react/workspace/LayoutMenu.d.ts +33 -0
  188. package/dist/react/workspace/LayoutMenu.d.ts.map +1 -0
  189. package/dist/react/workspace/SymbolSearchDialog.d.ts +10 -0
  190. package/dist/react/workspace/SymbolSearchDialog.d.ts.map +1 -0
  191. package/dist/react/workspace/TabBar.d.ts +17 -0
  192. package/dist/react/workspace/TabBar.d.ts.map +1 -0
  193. package/dist/react/workspace/toolbars/BottomToolbar.d.ts +19 -0
  194. package/dist/react/workspace/toolbars/BottomToolbar.d.ts.map +1 -0
  195. package/dist/react/workspace/toolbars/RightToolbar.d.ts +8 -0
  196. package/dist/react/workspace/toolbars/RightToolbar.d.ts.map +1 -0
  197. package/dist/react/workspace/toolbars/TopToolbar.d.ts +41 -0
  198. package/dist/react/workspace/toolbars/TopToolbar.d.ts.map +1 -0
  199. package/dist/renderers/CandlestickRenderer.d.ts +13 -0
  200. package/dist/renderers/CandlestickRenderer.d.ts.map +1 -0
  201. package/dist/renderers/HistogramRenderer.d.ts +11 -0
  202. package/dist/renderers/HistogramRenderer.d.ts.map +1 -0
  203. package/dist/renderers/LineRenderer.d.ts +12 -0
  204. package/dist/renderers/LineRenderer.d.ts.map +1 -0
  205. package/dist/theme/colors.d.ts +4 -0
  206. package/dist/theme/colors.d.ts.map +1 -0
  207. package/dist/tools/barDivergenceCheck.d.ts +120 -0
  208. package/dist/tools/barDivergenceCheck.d.ts.map +1 -0
  209. package/dist/trading/TradingOverlayStore.d.ts +86 -0
  210. package/dist/trading/TradingOverlayStore.d.ts.map +1 -0
  211. package/dist/trading/UnmanagedIngestion.d.ts +91 -0
  212. package/dist/trading/UnmanagedIngestion.d.ts.map +1 -0
  213. package/dist/trading/__tests__/ManagedTradingController.test.d.ts +18 -0
  214. package/dist/trading/__tests__/ManagedTradingController.test.d.ts.map +1 -0
  215. package/dist/trading/__tests__/TradingOverlayStore.test.d.ts +16 -0
  216. package/dist/trading/__tests__/TradingOverlayStore.test.d.ts.map +1 -0
  217. package/dist/trading/__tests__/UnmanagedIngestion.test.d.ts +16 -0
  218. package/dist/trading/__tests__/UnmanagedIngestion.test.d.ts.map +1 -0
  219. package/dist/trading/managed/ManagedTradingController.d.ts +110 -0
  220. package/dist/trading/managed/ManagedTradingController.d.ts.map +1 -0
  221. package/dist/trading/managed/managedCapabilities.d.ts +45 -0
  222. package/dist/trading/managed/managedCapabilities.d.ts.map +1 -0
  223. package/dist/trading/managed/managedTypes.d.ts +122 -0
  224. package/dist/trading/managed/managedTypes.d.ts.map +1 -0
  225. package/dist/trading/tradingTypes.d.ts +89 -0
  226. package/dist/trading/tradingTypes.d.ts.map +1 -0
  227. package/dist/tscript/TScriptIndicator.d.ts +41 -0
  228. package/dist/tscript/TScriptIndicator.d.ts.map +1 -0
  229. package/dist/tscript/ast.d.ts +89 -0
  230. package/dist/tscript/ast.d.ts.map +1 -0
  231. package/dist/tscript/lexer.d.ts +36 -0
  232. package/dist/tscript/lexer.d.ts.map +1 -0
  233. package/dist/tscript/parser.d.ts +50 -0
  234. package/dist/tscript/parser.d.ts.map +1 -0
  235. package/dist/tscript/runtime.d.ts +123 -0
  236. package/dist/tscript/runtime.d.ts.map +1 -0
  237. package/dist/tscript/series.d.ts +49 -0
  238. package/dist/tscript/series.d.ts.map +1 -0
  239. package/dist/types/IChart.d.ts +48 -0
  240. package/dist/types/IChart.d.ts.map +1 -0
  241. package/{src/types/IRenderer.ts → dist/types/IRenderer.d.ts} +2 -8
  242. package/dist/types/IRenderer.d.ts.map +1 -0
  243. package/dist/types/ISeries.d.ts +26 -0
  244. package/dist/types/ISeries.d.ts.map +1 -0
  245. package/package.json +5 -1
  246. package/src/__tests__/backwardCompatibility.test.ts +0 -191
  247. package/src/__tests__/candleInvariant.test.ts +0 -500
  248. package/src/__tests__/public-api-surface.ts +0 -76
  249. package/src/__tests__/timeframeBoundary.test.ts +0 -583
  250. package/src/api/DrawingManager.ts +0 -188
  251. package/src/api/EventBus.ts +0 -53
  252. package/src/api/IndicatorDAG.ts +0 -389
  253. package/src/api/IndicatorRegistry.ts +0 -47
  254. package/src/api/LayoutManager.ts +0 -72
  255. package/src/api/PaneManager.ts +0 -129
  256. package/src/api/ReferenceAPI.ts +0 -195
  257. package/src/api/TChart.ts +0 -881
  258. package/src/api/drawing tools/fib gann menu/fibRetracement.ts +0 -27
  259. package/src/api/drawing tools/lines menu/crossLine.ts +0 -21
  260. package/src/api/drawing tools/lines menu/disjointChannel.ts +0 -74
  261. package/src/api/drawing tools/lines menu/extendedLine.ts +0 -22
  262. package/src/api/drawing tools/lines menu/flatTopBottom.ts +0 -45
  263. package/src/api/drawing tools/lines menu/horizontal.ts +0 -24
  264. package/src/api/drawing tools/lines menu/horizontalRay.ts +0 -25
  265. package/src/api/drawing tools/lines menu/infoLine.ts +0 -127
  266. package/src/api/drawing tools/lines menu/insidePitchfork.ts +0 -21
  267. package/src/api/drawing tools/lines menu/modifiedSchiffPitchfork.ts +0 -18
  268. package/src/api/drawing tools/lines menu/parallelChannel.ts +0 -47
  269. package/src/api/drawing tools/lines menu/pitchfork.ts +0 -15
  270. package/src/api/drawing tools/lines menu/ray.ts +0 -28
  271. package/src/api/drawing tools/lines menu/regressionTrend.ts +0 -157
  272. package/src/api/drawing tools/lines menu/schiffPitchfork.ts +0 -18
  273. package/src/api/drawing tools/lines menu/trendAngle.ts +0 -64
  274. package/src/api/drawing tools/lines menu/trendline.ts +0 -16
  275. package/src/api/drawing tools/lines menu/vertical.ts +0 -16
  276. package/src/api/drawing tools/pointers menu/cursor.ts +0 -16
  277. package/src/api/drawing tools/shapes menu/rectangle.ts +0 -24
  278. package/src/api/drawing tools/shapes menu/text.ts +0 -30
  279. package/src/api/drawingUtils.ts +0 -82
  280. package/src/core/CanvasLayer.ts +0 -77
  281. package/src/core/Chart.ts +0 -917
  282. package/src/core/CoordTransform.ts +0 -282
  283. package/src/core/Crosshair.ts +0 -207
  284. package/src/core/IndicatorEngine.ts +0 -216
  285. package/src/core/InteractionManager.ts +0 -899
  286. package/src/core/PriceScale.ts +0 -133
  287. package/src/core/Series.ts +0 -132
  288. package/src/core/TimeScale.ts +0 -175
  289. package/src/datafeed/DatafeedConnector.ts +0 -300
  290. package/src/engine/CandleEngine.ts +0 -458
  291. package/src/engine/__tests__/CandleEngine.test.ts +0 -402
  292. package/src/engine/candleInvariants.ts +0 -172
  293. package/src/engine/timeframeUtils.ts +0 -118
  294. package/src/index.ts +0 -190
  295. package/src/licensing/ChartRuntimeResolver.ts +0 -380
  296. package/src/licensing/LicenseManager.ts +0 -131
  297. package/src/licensing/__tests__/ChartRuntimeResolver.test.ts +0 -207
  298. package/src/licensing/__tests__/LicenseManager.test.ts +0 -180
  299. package/src/licensing/licenseTypes.ts +0 -19
  300. package/src/pine/PineCompiler.ts +0 -68
  301. package/src/pine/diagnostics.ts +0 -30
  302. package/src/pine/pine-ast.ts +0 -163
  303. package/src/pine/pine-lexer.ts +0 -265
  304. package/src/pine/pine-parser.ts +0 -439
  305. package/src/pine/pine-transpiler.ts +0 -301
  306. package/src/pixi/LayerName.ts +0 -35
  307. package/src/pixi/PixiCandlestickRenderer.ts +0 -125
  308. package/src/pixi/PixiChart.ts +0 -425
  309. package/src/pixi/PixiCrosshairRenderer.ts +0 -134
  310. package/src/pixi/PixiDrawingRenderer.ts +0 -121
  311. package/src/pixi/PixiGridRenderer.ts +0 -136
  312. package/src/pixi/PixiLayerManager.ts +0 -102
  313. package/src/react/canvas/ChartCanvas.tsx +0 -984
  314. package/src/react/canvas/ChartContextMenu.tsx +0 -60
  315. package/src/react/canvas/ChartSettingsDialog.tsx +0 -133
  316. package/src/react/canvas/IndicatorLabel.tsx +0 -347
  317. package/src/react/canvas/IndicatorPane.tsx +0 -503
  318. package/src/react/canvas/PointerOverlay.tsx +0 -126
  319. package/src/react/canvas/toolbars/LeftToolbar.tsx +0 -1096
  320. package/src/react/hooks/useChartCapabilities.ts +0 -76
  321. package/src/react/shell/ManagedAppShell.tsx +0 -699
  322. package/src/react/trading/TradingBridge.ts +0 -156
  323. package/src/react/workspace/ChartWorkspace.tsx +0 -228
  324. package/src/react/workspace/FloatingPanel.tsx +0 -131
  325. package/src/react/workspace/IndicatorsDialog.tsx +0 -246
  326. package/src/react/workspace/LayoutMenu.tsx +0 -345
  327. package/src/react/workspace/SymbolSearchDialog.tsx +0 -377
  328. package/src/react/workspace/TabBar.tsx +0 -87
  329. package/src/react/workspace/toolbars/BottomToolbar.tsx +0 -372
  330. package/src/react/workspace/toolbars/RightToolbar.tsx +0 -46
  331. package/src/react/workspace/toolbars/TopToolbar.tsx +0 -431
  332. package/src/renderers/CandlestickRenderer.ts +0 -130
  333. package/src/renderers/HistogramRenderer.ts +0 -63
  334. package/src/renderers/LineRenderer.ts +0 -77
  335. package/src/theme/colors.ts +0 -21
  336. package/src/tools/barDivergenceCheck.ts +0 -305
  337. package/src/trading/TradingOverlayStore.ts +0 -161
  338. package/src/trading/UnmanagedIngestion.ts +0 -156
  339. package/src/trading/__tests__/ManagedTradingController.test.ts +0 -338
  340. package/src/trading/__tests__/TradingOverlayStore.test.ts +0 -323
  341. package/src/trading/__tests__/UnmanagedIngestion.test.ts +0 -205
  342. package/src/trading/managed/ManagedTradingController.ts +0 -292
  343. package/src/trading/managed/managedCapabilities.ts +0 -98
  344. package/src/trading/managed/managedTypes.ts +0 -151
  345. package/src/trading/tradingTypes.ts +0 -135
  346. package/src/tscript/TScriptIndicator.ts +0 -54
  347. package/src/tscript/ast.ts +0 -105
  348. package/src/tscript/lexer.ts +0 -190
  349. package/src/tscript/parser.ts +0 -334
  350. package/src/tscript/runtime.ts +0 -525
  351. package/src/tscript/series.ts +0 -84
  352. package/src/types/IChart.ts +0 -56
  353. package/src/types/ISeries.ts +0 -30
  354. package/tsconfig.json +0 -23
  355. package/tsup.config.ts +0 -16
  356. 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
- }